diff --git a/app/Config/Routes.php b/app/Config/Routes.php index 62de0c1..903ee9f 100644 --- a/app/Config/Routes.php +++ b/app/Config/Routes.php @@ -67,11 +67,13 @@ $routes->group('', ['namespace' => 'App\Controllers\Article'], static function ( $routes->get('excel', 'Receipt::excel'); $routes->post('saveTel', 'Receipt::saveTel'); // 연락가능전화 저장 + $routes->post('resDbYn', 'Receipt::resDbYn'); // 거주여부 저장 $routes->post('resGround', 'Receipt::resGround'); // 평면도요청 저장 $routes->post('assignRegist', 'Receipt::assignRegist'); // 예약확정 저장 $routes->post('requestMovie', 'Receipt::requestMovie'); // 동영상 촬영여부저장 $routes->post('requestMessage', 'Receipt::requestMessage'); // 중개사메모 저장 $routes->post('rsrvcancel', 'Receipt::rsrvcancel'); // 예약취소 + $routes->post('chgStatus', 'Receipt::chgStatus'); // 상태변경 $routes->post('sendSms', 'Receipt::sendSms'); // 문자발송 $routes->post('saveRecInfo', 'Receipt::saveRecInfo'); // 거주인정보저장 $routes->post('uploadFile', 'Receipt::uploadFile'); // 파일업로드 @@ -206,6 +208,7 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->post('m702a/updateAssign', 'M702::updateAssign'); // 배정변경 $routes->post('m702a/saveTel', 'M702::saveTel'); // 전화확인 정보 저장 $routes->post('m702a/modifyInfo', 'M702::modifyInfo'); // 매물정보저장 + $routes->post('m702a/saveDocu', 'M702::saveDocu'); // 서류정보저장 $routes->post('m702a/uploadFile', 'M702::uploadFile'); // 파일업로드 @@ -297,6 +300,10 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->get('m706a/getResultList', 'M706::getResultList'); $routes->get('m706a/excel', 'M706::excel'); + $routes->post('m706a/modifyInfo', 'M706::modifyInfo'); // 매물정보 저장 + $routes->post('m706a/saveDocu', 'M706::saveDocu'); // 서류정보 저장 + $routes->post('m706a/saveRegi', 'M706::saveRegi'); // 등기부등본 저장 + }); /** @@ -319,7 +326,8 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->post('m708a/saveBunyang', 'M708::saveBunyang'); // 분양권 저장 $routes->post('m708a/saveRequestMessage', 'M708::saveRequestMessage'); // 중개인 요청사항 저장 $routes->post('m708a/saveResult', 'M708::saveResult'); // 결과저장 - $routes->post('m708a/saveBunyangCnt', 'M708::saveBunyangCnt'); // 분양계약서저장 + $routes->post('m708a/saveBunyangCnt', 'M708::saveBunyangCnt'); // 분양계약서조회 + $routes->post('m708a/saveResult3', 'M708::saveResult3'); // 분양계약서저장 $routes->post('m708a/getNextFaxImgs', 'M708::getNextFaxImgs'); // 다음매물 }); @@ -408,7 +416,8 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout $routes->get('m713a/excel', 'M713::excel'); $routes->post('m713a/rotateImage', 'M713::rotateImage'); // 이미지 회전 $routes->post('m713a/saveCorpOwn', 'M713::saveCorpOwn'); // 법인매물저장 - $routes->post('m713a/saveRegi', 'M713::saveRegi'); // 매물저장 + $routes->post('m713a/saveModify', 'M713::saveModify'); + $routes->post('m713a/saveRegi', 'M713::saveRegi'); // 등기부등본 저장 $routes->post('m713a/nextRegi', 'M713::nextRegi'); // 다음매물 }); diff --git a/app/Controllers/Article/Receipt.php b/app/Controllers/Article/Receipt.php index 668e300..b6b6927 100644 --- a/app/Controllers/Article/Receipt.php +++ b/app/Controllers/Article/Receipt.php @@ -5,8 +5,11 @@ use App\Controllers\BaseController; use App\Libraries\Common; use App\Libraries\MyUpload; +use App\Libraries\NaverApiClient; +use App\Models\article\DeptModel; use App\Models\article\ReceiptModel; use App\Models\common\CodeModel; +use Exception; class Receipt extends BaseController { @@ -20,18 +23,31 @@ class Receipt extends BaseController public function lists(): string { + $usr_id = $this->request->getGet('usr_id') ?: ''; + $sBonbu = $this->request->getGet('bonbu') ?: ''; + $sTeanm = $this->request->getGet('dept_sq') ?: ''; + $codes = $this->codeModel->getCodeLists(['NHN_DEAL_TYPE', 'CP_ID', 'ARTICLE_TYPE', 'VRFCREQ_WAY', 'STEP_VERIFICATION']); // 코드조회 $sido = $this->model->getAreaList(); // 지역조회 $bonbu = $this->model->getBonbuList(); $team = $this->model->getTeamList(); $user = $this->model->getUserList(); + $this->data['sido'] = $sido; $this->data['bonbu'] = $bonbu; $this->data['team'] = $team; $this->data['user'] = $user; $this->data['codes'] = $codes; + if (!empty($usr_id)) { + $srchUser = $this->model->getSrchUserInfo($usr_id); + $this->data['srchUser'] = $srchUser; + } + + $this->data['sBonbu'] = $sBonbu; + $this->data['sTeanm'] = $sTeanm; + return view("pages/article/receipt/lists", $this->data); } @@ -143,6 +159,7 @@ class Receipt extends BaseController // 상세화면 public function detail($id) { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -161,6 +178,10 @@ class Receipt extends BaseController $team = $this->model->getTeamList(); log_message('info', '[Receipt::detail] getTeamList {ms}ms', ['ms' => (int) ((microtime(true) - $t2) * 1000)]); + $damdang = $this->model->getUserList(); + + + // sms 코드 $sms = []; foreach ($codes as $c) { @@ -209,6 +230,9 @@ class Receipt extends BaseController $tmCount = $this->model->getUsrRsrvDateTmCount($id); log_message('info', '[Receipt::detail] getUsrRsrvDateTmCount {ms}ms', ['ms' => (int) ((microtime(true) - $t10) * 1000)]); + // 당일 방문예정 매물. + $assignList = $this->model->getAssignReceiptListByUser($data['rsrv_date'], $data['usr_sq'], array($id)); + // 체크리스트 조회 $t11 = microtime(true); if ($data['exp_photo_yn'] === "N") { @@ -217,13 +241,30 @@ class Receipt extends BaseController $result_check = []; } + $pdept = ''; + if (!empty($data['dept_sq'])) { + $pdept = $this->model->getDeptDetail($data['dept_sq']); + } else { + $pdept = $this->model->getDeptDetail($data['region_dept_sq']); + } + $complexList = []; $ptpList = []; + // print_r($data); + // exit; + if ($data['comp_sq'] == '2') { - // $callApi = new CallApi(); + // 아파트단지목록 + $complexList = $naver->complexList($data['rcpt_dong']); + + // 평형목록 + $ptpList = $naver->ptpList($data['rcpt_hscp_no']); } + // print_r($ptpList); + // exit; + log_message('info', '[Receipt::detail] getChecklist {ms}ms', ['ms' => (int) ((microtime(true) - $t11) * 1000)]); log_message('info', '[Receipt::detail] total {ms}ms', ['ms' => (int) ((microtime(true) - $t0) * 1000)]); @@ -231,9 +272,13 @@ class Receipt extends BaseController $this->data['codes'] = $codes; $this->data['bonbu'] = $bonbu; $this->data['team'] = $team; + $this->data['damdang'] = $damdang; + $this->data['pdept'] = $pdept; + $this->data['sms'] = $sms; $this->data['data'] = $data; + $this->data['assignList'] = $assignList; $this->data['history'] = $history; $this->data['dupleGroundPlan'] = $dupleGroundPlan; @@ -247,6 +292,9 @@ class Receipt extends BaseController $this->data['tmCount'] = $tmCount; $this->data['result_check'] = $result_check; + $this->data['complexList'] = $complexList; + $this->data['ptpList'] = $ptpList; + return view("pages/article/receipt/detail", $this->data); } @@ -275,6 +323,48 @@ class Receipt extends BaseController } } + // 거주여부 저장 + public function resDbYn() + { + $naver = new NaverApiClient(); + + try { + + $rcpt_key = $this->request->getPost('rcpt_key'); + $rcpt_sq = $this->request->getPost('rcpt_sq'); + $rsrv_sq = $this->request->getPost('rsrv_sq'); + $res_yn = $this->request->getPost('resYn'); + $dbUsageAgrYn = $this->request->getPost('dbUsageAgrYn'); + + $this->model->saveResDB($rcpt_sq, $rsrv_sq, $res_yn, $dbUsageAgrYn); + + $receipt = $this->getDetail($rcpt_key); + if ($res_yn == 'Y') { + $isResidentsExist = true; + } else { + $isResidentsExist = false; + } + + $api_result = $naver->residentsExistence($rcpt_key, $isResidentsExist); + + + if (!isset($api_result['result'])) { + throw new \Exception('API 통신오류입니다.\n다시 저장하여 주십시요.'); + } + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success' + ]); + + } catch (\Exception $e) { + return $this->response->setJSON([ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + // 평면도요청 저장 public function resGround() { @@ -302,13 +392,42 @@ class Receipt extends BaseController // 예약확정 저장 public function assignRegist() { + $naver = new NaverApiClient(); + $deptModel = new DeptModel(); + try { + //전달받은 값 + $rcpt_sq = $this->request->getPost('rcpt_sq'); + $rcpt_key = $this->request->getPost('rcpt_key'); + $rsrv_sq = $this->request->getPost('rsrv_sq'); + $rsrv_date = $this->request->getPost('rsrv_date'); + $rsrv_tm_ap = $this->request->getPost('rsrv_tm_ap'); + $rsrv_tm_hour = $this->request->getPost('rsrv_tm_hour'); + $bonbu = $this->request->getPost('bonbu'); + $dept_sq = $this->request->getPost('dept_sq'); + $usr_sq = $this->request->getPost('usr_sq'); + + $bonbuInfo = $deptModel->getDeptDetail($bonbu); + $deptInfo = $deptModel->getDeptDetail($dept_sq); + $userInfo = $this->model->getUserDetail($usr_sq); + $receipt = $this->model->getDetail($rcpt_key); + + /*** 네이버 연동[s] ***/ + $na_result = $naver->reserveSuccess($rcpt_key, 'Y', $bonbuInfo['dept_nm'], $deptInfo['dept_nm'], $userInfo['usr_nm'], $userInfo['usr_tel1'], $rsrv_date, $rsrv_tm_ap); + /*** 네이버 연동[e] ***/ + + if (array_key_exists('result', $na_result)) { //네이버연동 상태변경 완료 + $result = $this->model->assignRegist($rcpt_sq, $rsrv_date, $rsrv_tm_ap, $rsrv_tm_hour, $dept_sq, $usr_sq, $receipt); + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success' + ]); + } else { + throw new \Exception($na_result['message']); + } - return $this->response->setJSON([ - 'code' => '0', - 'msg' => 'success' - ]); } catch (\Exception $e) { return $this->response->setJSON([ @@ -371,10 +490,44 @@ class Receipt extends BaseController // 예약취소 public function rsrvcancel() { + $naver = new NaverApiClient(); + try { + //전달받은 값 + $rcpt_sq = $this->request->getPost('rcpt_sq'); + $rsrv_sq = $this->request->getPost('rsrv_sq'); + $rcpt_key = $this->request->getPost('rcpt_key'); + $result_cd2 = $this->request->getPost('result_cd2'); + $result_cd3 = $this->request->getPost('result_cd3'); + $result_msg = $this->request->getPost('result_msg'); + $rcpt_stat1 = $this->request->getPost('rcpt_stat1'); + $receipt = $this->model->getDetail($rcpt_key); + /*** 네이버 연동[s] ***/ + if ($result_cd2 == '9010' || $result_cd2 == '9020') { //예약취소 + $na_result = $naver->reserveFail($rcpt_key, "E11", $result_msg); + } else if ($result_cd2 == '9030') { + if ($rcpt_stat1 == '70') { + throw new \Exception('방문전 취소 할 수 없습니다.'); + } else { + $na_result = $naver->shootFail($rcpt_key, "E21", $result_msg); + } + } else if ($result_cd2 == '9040') { + $na_result = $naver->shootFail($rcpt_key, "E22", $result_msg); + } else if ($result_cd2 == '9045') { + $na_result = $naver->shootFail($rcpt_key, "E23", $result_msg); + } else if ($result_cd2 == '9050') { + $na_result = $naver->inspectFail($rcpt_key, 'E31', $result_msg); + } + /*** 네이버 연동[e] ***/ + if (array_key_exists('result', $na_result)) { //네이버연동 상태변경 완료 + $result = $this->model->rsrvcancel($rcpt_sq, $rsrv_sq, $result_cd2, $result_cd3, $result_msg, $receipt); + + } else { + throw new \Exception($na_result['message']); + } return $this->response->setJSON([ 'code' => '0', @@ -389,6 +542,55 @@ class Receipt extends BaseController } } + // 상태변경 + public function chgStatus() + { + try { + + $rcpt_sq = $this->request->getPost('rcpt_sq'); + $rcpt_key = $this->request->getPost('rcpt_key'); + $rcpt_stat = $this->request->getGet('rcpt_stat'); + $rsrv_sq = $this->request->getPost('rsrv_sq'); + $req_rec_yn = $this->request->getGet('reqRecYn'); + + $rsrv_date = $this->request->getPost('rsrv_date'); + $rsrv_tm_ap = $this->request->getPost('rsrv_tm_ap'); + $rsrv_tm_hour = $this->request->getPost('rsrv_tm_hour'); + $bonbu = $this->request->getPost('bonbu'); + $dept_sq = $this->request->getPost('dept_sq'); + $usr_sq = $this->request->getPost('usr_sq'); + + $rletTypeCd = $this->request->getGet('rletTypeCd'); + + // 파라미터 디버그 로깅 + $p = [ + 'rcpt_sq' => $rcpt_sq, + 'rcpt_key' => $rcpt_key, + 'rcpt_stat' => $rcpt_stat, + 'rsrv_sq' => $rsrv_sq, + 'req_rec_yn' => $req_rec_yn, + 'rsrv_date' => $rsrv_date, + 'rsrv_tm_ap' => $rsrv_tm_ap, + 'rsrv_tm_hour' => $rsrv_tm_hour, + 'bonbu' => $bonbu, + 'dept_sq' => $dept_sq, + 'usr_sq' => $usr_sq, + 'rletTypeCd' => $rletTypeCd, + ]; + + + print_r($p); + exit; + + + } catch (\Exception $e) { + return $this->response->setJSON([ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + // 문자발송 public function sendSms() diff --git a/app/Controllers/V2/M702.php b/app/Controllers/V2/M702.php index 9aa429c..9f8e0c4 100644 --- a/app/Controllers/V2/M702.php +++ b/app/Controllers/V2/M702.php @@ -1006,4 +1006,211 @@ class M702 extends BaseController ]); } } + + // 서류확인정보 저장 + public function saveDocu() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 전화(서류)확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 확인여부 + 홍보확인서 미확인여부 상세, 매물주소, 가격거래구분, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); //오늘날짜 + $atcl_vrtc_way = $this->request->getPost('atcl_vrtc_way'); + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $arr = $this->request->getPost('chTotal'); + $fax_conf_res_d11 = $this->request->getPost('fax_conf_res_d11'); + $fax_conf_yn_1 = $this->request->getPost('fax_conf_yn_1'); + $fax_conf_yn_2 = $this->request->getPost('fax_conf_yn_2'); + $fax_conf_yn_3 = $this->request->getPost('fax_conf_yn_3'); + $fax_conf_yn_4 = $this->request->getPost('fax_conf_yn_4'); + $fax_conf_yn_info_2 = $this->request->getPost('fax_conf_yn_info_2'); + $fax_conf_yn_info_3 = $this->request->getPost('fax_conf_yn_info_3'); + $fax_conf_yn_info_4 = $this->request->getPost('fax_conf_yn_info_4'); + $reg_chk_val = $this->request->getPost('reg_chk_val'); + $memo = $this->request->getPost('memo_fax'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + + + if ((int) $resStat['stat_cd'] >= 40 || (int) $resStat['stat_cd'] == '190') { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsCharger($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, ''); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $resUpdate = $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '30', $toDay); + $chgVrfc = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D11', $fax_conf_res_d11, $arr); + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D12', $fax_conf_yn_2, $fax_conf_yn_info_2); + //v2_check_list 가격거래구분 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D13', $fax_conf_yn_3, $fax_conf_yn_info_3); + //v2_check_list 의뢰인정보 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D14', $fax_conf_yn_4, $fax_conf_yn_info_4); + + //memo 저장 + if (!empty($memo)) { + $this->model->saveMemo([ + 'vr_sq' => $atcl_vr_sq, + 'memo' => $memo + ]); + } + + //API 호출 + $sendData = $this->model->getDataConfirmAPI($atcl_vr_sq); + + if ($fax_conf_yn_4 == '10000' || (int) $try_cnt < 2) { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + if ($send_result['result'] == 'success') { //HISTORY + if ($fax_conf_res_d11 == '10000' && $chk_type == '1') { + + //상태변경 TABLE INSERT : 전화(서류)확인 완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '35', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '35'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '35'); //fax_imgs + + if ($reg_chk_val == '1') { + //등기부등본 확인 대상은 전화(서류)확인 완료 후 -> 등기부등본 확인중 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '40'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + //등기부등본 확인 대상이 아닌 경우 전화(서류)확인 완료 후 -> 검증 완료 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } else { + //상태변경 TABLE INSERT : 전화(서류)확인 불일치 + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgTryCnt($atcl_vr_sq, '1'); + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 2차실패로 저장 + } + + if ($fax_conf_res_d11 == '20013') { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + } else { + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + $this->model->saveHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 39 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + throw new Exception('의뢰인정보 불일치로 저장되었습니다.'); + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } } \ No newline at end of file diff --git a/app/Controllers/V2/M703.php b/app/Controllers/V2/M703.php index a7cbc7e..1e6dfd4 100644 --- a/app/Controllers/V2/M703.php +++ b/app/Controllers/V2/M703.php @@ -126,6 +126,7 @@ class M703 extends BaseController // 상세화면 public function detail($id) { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -162,11 +163,11 @@ class M703 extends BaseController $apt_rlet_type_cd = ['A01', 'A02', 'A03', 'A04', 'B01', 'B02', 'B03']; $villa_rlet_type_cd = ['A05', 'A06']; if (in_array($article['rlet_type_cd'], $apt_rlet_type_cd)) { // apt 단지 - // $detail_hscp = $this->call_kiso_api->aptDetail($article['hscp_no']); + $detail_hscp = $naver->aptDetail($article['hscp_no']); } if (in_array($article['rlet_type_cd'], $villa_rlet_type_cd)) { // villa 단지 - // $detail_hscp = $this->call_kiso_api->villaDetail($article['hscp_no']); + $detail_hscp = $naver->villaDetail($article['hscp_no']); } $this->data['hscp_info'] = $hscp_info; diff --git a/app/Controllers/V2/M704.php b/app/Controllers/V2/M704.php index 5c07310..600f14f 100644 --- a/app/Controllers/V2/M704.php +++ b/app/Controllers/V2/M704.php @@ -595,7 +595,7 @@ class M704 extends BaseController //memo 저장 if (!empty($memo)) { - $this->model->saveMemo(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]); + $this->model->saveMemo([$memo, $atcl_vr_sq]); } //전화실패 사유 저장 if (!empty($tel_fail_cause)) { diff --git a/app/Controllers/V2/M705.php b/app/Controllers/V2/M705.php index 7cf3266..0a94f22 100644 --- a/app/Controllers/V2/M705.php +++ b/app/Controllers/V2/M705.php @@ -58,7 +58,7 @@ class M705 extends BaseController 'srcDong' => $this->request->getGet('srcDong'), // 읍면동 'bonbu' => $this->request->getGet('bonbu'), // 본부 'team' => $this->request->getGet('team'), // 팀 - 'damdang' => $this->request->guploadFileetGet('damdang'), // 담당 + 'damdang' => $this->request->getGet('damdang'), // 담당 'vrfcreq_way' => $this->request->getGet('vrfcreq_way'), // 검증방식1 'vrfc_type_sub' => $this->request->getGet('vrfc_type_sub'), // 검증방식2 'rcpt_cpid' => $this->request->getGet('rcpt_cpid'), // 매체사 @@ -486,7 +486,7 @@ class M705 extends BaseController $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); //memo 저장 - $this->model->saveMemo(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]); + $this->model->saveMemo([$memo, $atcl_vr_sq]); //실소유주 확인 저장 $this->model->update_owner_verifiable($atcl_vr_sq, $owner_verifiable); diff --git a/app/Controllers/V2/M706.php b/app/Controllers/V2/M706.php index 8800edb..5195060 100644 --- a/app/Controllers/V2/M706.php +++ b/app/Controllers/V2/M706.php @@ -2,8 +2,12 @@ namespace App\Controllers\V2; use App\Controllers\BaseController; +use App\Libraries\NaverApiClient; use App\Models\common\CodeModel; +use App\Models\results\M415Model; use App\Models\v2\M706Model; +use App\Models\v2\M710Model; +use Exception; class M706 extends BaseController { @@ -110,6 +114,7 @@ class M706 extends BaseController // 상세화면 public function detail($id) { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -124,6 +129,15 @@ class M706 extends BaseController $memo = $this->model->getMemo($id); $history = $this->model->getHistory($id); + $complexList = []; + $ptpList = []; + + // 아파트단지목록 + $complexList = $naver->complexList($data['address_code']); + + // 평형목록 + $ptpList = $naver->ptpList($data['hscp_no']); + $this->data['codes'] = $codes; $this->data['regist'] = $regist; $this->data['record'] = $record; @@ -132,8 +146,477 @@ class M706 extends BaseController $this->data['memo'] = $memo; $this->data['history'] = $history; + $this->data['complexList'] = $complexList; + $this->data['ptpList'] = $ptpList; + return view("pages/v2/m706/detail", $this->data); + } + // 매물정보 수정 + public function modifyInfo() + { + $naver = new NaverApiClient(); + + try { + $atcl_vr_sq = $this->request->getPost('rcpt_key'); //순번 + $atcl_hscp_nm = $this->request->getPost('atcl_hscp_nm'); //단지명 + $atcl_ptp_nm = $this->request->getPost('atcl_ptp_nm'); //평형명 + $atcl_vrfc_type = $this->request->getPost('atcl_vrtc_way'); //검증구분 + $trade_type = $this->request->getPost('trade_type_cd'); //거래구분 + $atcl_addr1 = $this->request->getPost('atcl_addr1'); //상세주소1 폐기예정 + $atcl_addr1a = $this->request->getPost('atcl_addr1a'); // 리 주소 + $atcl_addr1b = $this->request->getPost('atcl_addr1b'); // 공동 : 동 주소, 비공동 : 지번주소 + $atcl_addr2 = $this->request->getPost('atcl_addr2'); //상세주소2 + $atcl_hscp_no = $this->request->getPost('atcl_hscp_no'); //단지번호 + $atcl_ptp_no = $this->request->getPost('atcl_ptp_no'); //단지명 + $atcl_amt1 = $this->request->getPost('atcl_amt1'); + $atcl_amt2 = $this->request->getPost('atcl_amt2'); + $atcl_amt3 = $this->request->getPost('atcl_amt3'); + $atcl_floor = $this->request->getPost('atcl_floor'); + $atcl_floor2 = $this->request->getPost('atcl_floor2'); // 총층 + + $return = ''; + if ($trade_type == 'A1') { + $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1); + } elseif ($trade_type == 'B1') { + $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt2); + } + + + + if (empty($return)) { + $result = $this->model->saveModifyInfo($atcl_vr_sq, $atcl_hscp_nm, $atcl_ptp_nm, $atcl_vrfc_type, $trade_type, $atcl_addr1, $atcl_addr1a, $atcl_addr1b, $atcl_addr2, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1, $atcl_amt2, $atcl_amt3, $atcl_floor, $atcl_floor2); + $this->model->saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type); + + + if ($result['error_number'] != 0) { + throw new \Exception($result['error_message']); + } else { + //API 호출 + $resultData = $this->model->getDetail($atcl_vr_sq); + + $modifyInfo = $naver->modifyInfo( + $resultData['data']['atcl_no'], + $resultData['data']['hscp_no'], + $resultData['data']['ptp_no'], + $resultData['data']['bild_nm'], + $resultData['data']['rm_no'], + $resultData['data']['trade_type_cd'], + $resultData['data']['deal_amt'], + $resultData['data']['wrrnt_amt'], + $resultData['data']['lease_amt'], + $resultData['data']['isale_amt'], + $resultData['data']['prem_amt'], + $resultData['data']['floor'], + $resultData['data']['floor2'], + $resultData['data']['charger'], + $resultData['data']['address_code'], + $resultData['data']['address2'], + $resultData['data']['address2a'], + $resultData['data']['address2b'], + $resultData['data']['address3'], + $resultData['data']['sply_spc'], + $resultData['data']['excls_spc'], + $resultData['data']['tot_spc'], + $resultData['data']['grnd_spc'], + $resultData['data']['bldg_spc'] + ); + + if ($modifyInfo['result'] != 'success') { //결과값 확인 + $return = $modifyInfo['error']; + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $modifyInfo['error']['code'], $modifyInfo['error']['message'], $err_time, $resultData['data']['atcl_no']); + + } + } + + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 서류확인정보 저장 + public function saveDocu() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 전화(서류)확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 확인여부 + 홍보확인서 미확인여부 상세, 매물주소, 가격거래구분, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); //오늘날짜 + $atcl_vrtc_way = $this->request->getPost('atcl_vrtc_way'); + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $arr = $this->request->getPost('chTotal'); + $fax_conf_res_d11 = $this->request->getPost('fax_conf_res_d11'); + $fax_conf_yn_1 = $this->request->getPost('fax_conf_yn_1'); + $fax_conf_yn_2 = $this->request->getPost('fax_conf_yn_2'); + $fax_conf_yn_3 = $this->request->getPost('fax_conf_yn_3'); + $fax_conf_yn_4 = $this->request->getPost('fax_conf_yn_4'); + $fax_conf_yn_info_2 = $this->request->getPost('fax_conf_yn_info_2'); + $fax_conf_yn_info_3 = $this->request->getPost('fax_conf_yn_info_3'); + $fax_conf_yn_info_4 = $this->request->getPost('fax_conf_yn_info_4'); + $reg_chk_val = $this->request->getPost('reg_chk_val'); + $memo = $this->request->getPost('memo_fax'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + + + if ((int) $resStat['stat_cd'] >= 40 || (int) $resStat['stat_cd'] == '190') { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsCharger($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, ''); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($fax_conf_yn_2 == '10000' && $fax_conf_yn_3 == '10000' && $fax_conf_yn_4 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $resUpdate = $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경 + $result_query2 = $this->model->chgStat($atcl_vr_sq, '30', $toDay); + $chgVrfc = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D11', $fax_conf_res_d11, $arr); + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D12', $fax_conf_yn_2, $fax_conf_yn_info_2); + //v2_check_list 가격거래구분 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D13', $fax_conf_yn_3, $fax_conf_yn_info_3); + //v2_check_list 의뢰인정보 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D14', $fax_conf_yn_4, $fax_conf_yn_info_4); + + //memo 저장 + if (!empty($memo)) { + $this->model->saveMemo([$memo, $usr_id, $atcl_vr_sq]); + } + + //API 호출 + $sendData = $this->model->getDataConfirmAPI($atcl_vr_sq); + + if ($fax_conf_yn_4 == '10000' || (int) $try_cnt < 2) { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + if ($send_result['result'] == 'success') { //HISTORY + if ($fax_conf_res_d11 == '10000' && $chk_type == '1') { + + //상태변경 TABLE INSERT : 전화(서류)확인 완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '35', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '35'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '35'); //fax_imgs + + if ($reg_chk_val == '1') { + //등기부등본 확인 대상은 전화(서류)확인 완료 후 -> 등기부등본 확인중 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '40'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + //등기부등본 확인 대상이 아닌 경우 전화(서류)확인 완료 후 -> 검증 완료 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } else { + //상태변경 TABLE INSERT : 전화(서류)확인 불일치 + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgTryCnt($atcl_vr_sq, '1'); + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 2차실패로 저장 + } + + if ($fax_conf_res_d11 == '20013') { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + } else { + $this->model->chgStat($atcl_vr_sq, '39', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '39'); //fax_imgs + + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 39 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + throw new Exception('의뢰인정보 불일치로 저장되었습니다.'); + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 등기부등본 정보 저장 + public function saveRegi() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 등기부등본 확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 매물주소, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 등기부등본 확인완료 상태. (수정변경이력 저장) + */ + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $mode = $this->request->getGet('mode'); + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); + $atcl_vrtc_way = 'R'; + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1'); + $reg_conf_yn_2 = $this->request->getPost('reg_conf_yn_2'); + $reg_conf_yn_3 = $this->request->getPost('reg_conf_yn_3'); + $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2'); + $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3'); + $memo = $this->request->getPost('memo_reg'); + $try_cnt = '0'; + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $this->model->get_v2_vrfc_req($atcl_vr_sq); + + if ((int) $resStat['stat_cd'] >= 60 || (int) $resStat['stat_cd'] == 19) { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $this->model->InsResChar($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다 + + $resultCnt = $this->model->chkRegiTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['reg_try_cnt'] == 0) { //1차 검증일 때 + $try_cnt = '1'; + } else if ($resultCnt['reg_try_cnt'] == 1) { //2차 검증일 때 + $try_cnt = '2'; + } else { + $try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, $atcl_vrtc_way); + if ($result == 0) { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } + + $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + //상태변경 TABLE INSERT : 등기부등본 확인중 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '40', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT + + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '21', $reg_conf_yn_2, $reg_conf_yn_info_2); + + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); + + //memo 저장 + if (!empty($memo)) { + $this->model->saveMemo([$memo, $atcl_vr_sq]); + } + + //API 호출 + $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R'); + $send_result = $naver->certification($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $sendData['ownerVerifiable']); + if ($send_result['result'] == 'success') { + if ($chk_type == '1') { + //상태변경 TABLE INSERT : 등기부등본 확인완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '45', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '45'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '45'); //fax_imgs + + //상태변경 TABLE INSERT : 검증완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + $v2_vrfc_req->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //등기부등본 확인중 상태로 변경. + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 49 => 30'); //검증결과 변동사항 HISTORY + $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '1'); + } else if ($try_cnt == '2') { + + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + } + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + return $this->response->setJSON(body: [ + 'code' => '0', + 'msg' => '정상적으로 저장되었습니다.', + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON(body: [ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } } } \ No newline at end of file diff --git a/app/Controllers/V2/M708.php b/app/Controllers/V2/M708.php index 4e1ad57..bb2d8a2 100644 --- a/app/Controllers/V2/M708.php +++ b/app/Controllers/V2/M708.php @@ -3,8 +3,12 @@ namespace App\Controllers\V2; use App\Controllers\BaseController; use App\Libraries\Common; +use App\Libraries\NaverApiClient; use App\Models\common\CodeModel; +use App\Models\results\M415Model; use App\Models\v2\M708Model; +use App\Models\v2\M710Model; +use Exception; class M708 extends BaseController { @@ -129,7 +133,6 @@ class M708 extends BaseController $data = $this->model->getDetail($id); $memo = $this->model->getMemo($id); - $article = null; $confirm = null; if (!empty($data)) { @@ -360,6 +363,11 @@ class M708 extends BaseController // 확인결과 저장 public function saveResult() { + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + try { $fax_sq = $this->request->getPost('fax_sq'); $vr_sq = $this->request->getPost('vr_sq'); @@ -387,9 +395,72 @@ class M708 extends BaseController } // DB에 결과 저장 - // $this->model->saveHongBoFAX($fax_sq, $vr_sq, $atcl_no, $work_type, $send_yn, $result_d11, $comment_d11, $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3, $file_type); + $return = $this->model->saveHongBoFAX($fax_sq, $vr_sq, $atcl_no, $work_type, $send_yn, $result_d11 ?? null, $comment_d11 ?? null, $fax_conf_yn_1 ?? null, $fax_conf_yn_2 ?? null, $fax_conf_yn_3 ?? null, $fax_conf_info_1 ?? null, $fax_conf_info_2 ?? null, $fax_conf_info_3 ?? null, $file_type); + if (empty($return['code']) && $work_type == '2') { + // 검증센터에 데이터를 전송한다. + $sendData = $this->model->getDataConfirmAPI($vr_sq); + if (($fax_conf_yn_3 ?? 'N') == 'Y' || (int) $article['try_cnt'] < 1) { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + + if ($send_result['result'] == 'success') { + $this->model->InsCharger($vr_sq); + + // DB에 상태값을 전송완료로 저장한다. + if (empty($sendData['success'])) { + $stat_cd = '39'; // 서류/전화 확인 실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경.. + + if ($sendData['try_cnt'] >= '1') { + $stat_cd = '69'; // 검증실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경.. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 최종실패로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } + // $res_try = $this->m708_model->chgTryCnt($vr_sq, intval($sendData['try_cnt']) +1); + + $this->model->increseTryCnt($vr_sq); + + if (($result_d11 ?? '') == '20013') { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } else { + $stat_cd = '35'; // 서류/전화 확인 성공 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경.. + + $rgbk_cofirm = $this->model->getRgbk_confirm($vr_sq); + if ($rgbk_cofirm == '1') { + $stat_cd = '40'; + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 등기부등본 확인중 상태로 변경.. + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + $stat_cd = '60'; + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 검증완료 상태로 변경.. + + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } + } else { + throw new \Exception($send_result['error']); + } + } else { + $stat_cd = '39'; // 서류/전화 확인 실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); + + $stat_cd = '30'; // 서류/전화 확인 중 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); + + $this->model->increseTryCnt($vr_sq); + + throw new \Exception('의뢰인 정보 불일치로 저장되었습니다.'); + } + + } return $this->response->setJSON([ @@ -408,14 +479,131 @@ class M708 extends BaseController } } - // 분양계약서 저장 + // 분양계약서 조회 public function saveBunyangCnt() { try { $vr_sq = $this->request->getPost('vr_sq'); + $rsrv_sq = $this->model->get_rsrv_sq($vr_sq); + $cnt = $this->model->getI8Cnt($rsrv_sq['rsrv_sq']); + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success', + 'cnt' => $cnt, + ]); + + } catch (\Exception $e) { + return $this->response->setJSON([ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 분양계약서 저장 + public function saveResult3() + { + $naver = new NaverApiClient(); + $v2StDailyModel = new V2StDailyModel(); + + try { + + $fax_sq = $this->request->getPost('fax_sq'); + $vr_sq = $this->request->getPost('vr_sq'); + $atcl_no = $this->request->getPost('atcl_no'); + $work_type = $this->request->getPost('work_type'); + + $resyn = $this->request->getPost('resYn'); + $dbusageagryn = $this->request->getPost('dbUsageAgrYn'); + $send_yn = 'Y'; // 업데이트 된다면 미처리->처리상태로 변경 + + $article = $this->model->getArticleInfo2($atcl_no, $vr_sq); + $v2_vrfc_req = $v2StDailyModel->get_v2_vrfc_req($vr_sq); + + if ((int) $article['stat_cd'] >= 40) { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + if (!empty($resyn)) { + $this->model->updateResDB($resyn, $dbusageagryn, $vr_sq); + } + + // DB에 결과를 저장한다. + $return = $this->model->saveresult3FAX($fax_sq, $vr_sq, $atcl_no, $work_type, $send_yn, $result_d11 ?? null, $comment_d11 ?? null, $fax_conf_yn_1 ?? null, $fax_conf_yn_2 ?? null, $fax_conf_yn_3 ?? null, $fax_conf_info_1 ?? null, $fax_conf_info_2 ?? null, $fax_conf_info_3 ?? null); + + if (empty($return['code']) && $work_type == '2') { + // 검증센터에 데이터를 전송한다. + $sendData = $this->model->getDataConfirmAPI($vr_sq); + + if (($fax_conf_yn_3 ?? 'N') == 'Y' || $article['try_cnt'] < '1') { + $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']); + + if ($send_result['result'] == 'success') { + $this->model->InsCharger($vr_sq); + + // DB에 상태값을 전송완료로 저장한다. + if (empty($sendData['success'])) { + $stat_cd = '39'; // 서류/전화 확인 실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경 + + if ($sendData['try_cnt'] >= '1') { + $stat_cd = '69'; // 검증실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경.. + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0302', '1', 'add'); // 최종실패로 저장 + } else { + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0301', '1', 'add'); // 1차실패로 저장 + } + // $res_try = $this->m708_model->chgTryCnt($vr_sq, intval($sendData['try_cnt']) +1); + + $this->model->increseTryCnt($vr_sq); + + if (($result_d11 ?? '') == '20013') { + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0203', '1', 'add'); // 기타로 저장 + } else { + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0202', '1', 'add'); // 불일치로 저장 + } + } else { + $stat_cd = '35'; // 서류/전화 확인 성공 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 전송완료 상태로 변경.. + + $rgbk_cofirm = $this->model->getRgbk_confirm($vr_sq); + if ($rgbk_cofirm == '1') { + $stat_cd = '40'; + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 등기부등본 확인중 상태로 변경.. + + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0201', '1', 'add'); // 일치로 저장 + } else { + $stat_cd = '60'; + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); // 검증완료 상태로 변경.. + + $v2StDailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'D0205', '1', 'add'); // 홍보확인서완료 등기부등본확인 안함 저장 + } + } + } else { + throw new \Exception($send_result['error']); + } + } else { + $stat_cd = '39'; // 서류/전화 확인 실패 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); + + $stat_cd = '30'; // 서류/전화 확인 중 + $this->model->saveChangeStep($fax_sq, $vr_sq, $stat_cd); + + $this->model->increseTryCnt($vr_sq); + + + throw new \Exception('의뢰인 정보 불일치로 저장되었습니다.'); + } + } + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success', + ]); + + } } catch (\Exception $e) { return $this->response->setJSON([ diff --git a/app/Controllers/V2/M712.php b/app/Controllers/V2/M712.php index 38d7a21..c393640 100644 --- a/app/Controllers/V2/M712.php +++ b/app/Controllers/V2/M712.php @@ -4,7 +4,9 @@ namespace App\Controllers\V2; use App\Controllers\BaseController; use App\Libraries\Common; use App\Libraries\MyUpload; +use App\Libraries\NaverApiClient; use App\Models\common\CodeModel; +use App\Models\results\M415Model; use App\Models\v2\M712Model; class M712 extends BaseController @@ -124,6 +126,7 @@ class M712 extends BaseController public function detail($id): string { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -139,12 +142,37 @@ class M712 extends BaseController $regist = $this->model->getRecordInfo($id, '2'); //등기부등본 $display = $this->model->getDisplay('M705_detail'); + $hscp_info = []; + if (!empty($data['hscp_no'])) { + $apt_rlet_type_cd = ['A01', 'A02', 'A03', 'A04', 'B01', 'B02', 'B03']; + $villa_rlet_type_cd = ['A05', 'A06']; + + + if (in_array($data['rlet_type_cd'], $apt_rlet_type_cd)) { // apt 단지 + $detail_hscp = $naver->aptDetail($data['hscp_no']); + } + + if (in_array($data['rlet_type_cd'], $villa_rlet_type_cd)) { // villa 단지 + $detail_hscp = $naver->villaDetail($data['hscp_no']); + } + + // print_r($data); + // print_r($detail_hscp); + // exit; + + if (!empty($detail_hscp) && isset($detail_hscp['result'])) { + $hscp_info = $detail_hscp['result']; + } + + } + $this->data['codes'] = $codes; $this->data['data'] = $data; $this->data['memo'] = $memo; $this->data['record'] = $record; $this->data['regist'] = $regist; $this->data['display'] = $display; + $this->data['hscp_info'] = $hscp_info; return view("pages/v2/m712/detail", $this->data); } @@ -294,13 +322,383 @@ class M712 extends BaseController // 정보저장 public function saveRegi() { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 등기부등본 확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 매물주소, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 등기부등본 확인완료 상태. (수정변경이력 저장) + 1.12.1 서류 확인내용 v2_article_info_etc document_cert_method 저장 + */ + + $naver = new NaverApiClient(); + // $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + try { + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); + $atcl_vrtc_way = 'R'; //검증구분 + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + // $atcl_no = $this->request->getPost('atcl_no'); + $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1'); //확인내용 + $reg_conf_yn_2 = $this->request->getPost('reg_conf_yn_2'); //매물주소 + $reg_conf_yn_3 = $this->request->getPost('reg_conf_yn_3'); //의뢰인정보 + $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2'); //매물주소 + $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3'); //의뢰인정보 + $memo = $this->request->getPost('memo'); //메모 + $owner_verifiable = $this->request->getPost('owner_verifiable'); //실소유주 확인여부 + $noimg_chk_chk = $this->request->getPost('noimg_chk_chk'); // 등기부등본이미지 파일없음. + $img_chk_chk = $this->request->getPost('img_chk_chk'); // 등기소, 리얼탑 열람, 리얼탑 기열람, 열람 + $atcl_vrtc_type = $this->request->getPost('atcl_vrtc_type'); // 검증구분 + $vrfc_type_sub = $this->request->getPost('vrfc_type_sub'); // 하위검증구분 + $arr_uncnfrm_status = $this->request->getPost('arr_uncnfrm_status'); // 등기부등본 미확인여부 상세 + $ownerTypeCode = $this->request->getPost('ownerTypeCode'); // 소유자명 확인 일치 , 불일치 + $document_cert_method = $this->request->getPost('document_cert_method'); // 서류 내용 확인 + + if ($owner_verifiable == "1") { + $owner_verifiable = true; + } else { + $owner_verifiable = false; + } + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + $rlet_type_cd = $model415->get_rlet_type_cd($atcl_vr_sq); + + if ((int) $resStat['stat_cd'] >= 60 || (int) $resStat['stat_cd'] == 19) { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $resultCnt = $this->model->chkRegiTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['reg_try_cnt'] == 0) { // 1차 검증일 때 + log_message('debug', '712 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 0 '); + $try_cnt = '1'; + } else if ($resultCnt['reg_try_cnt'] == 1) { // 2차 검증일 때 + log_message('debug', '712 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 1 '); + $try_cnt = '2'; + } else { + log_message('debug', '712 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 예외처리 '); + $try_cnt = '2'; + //$try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, $atcl_vrtc_way); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + // 2015.06.29 추가 + // 불일치가 날 경우에 10분 이내에 다시 불일치 처리 불가능(같은 매물을 두사람이 중복처리할 가능성 사전 방지) + // 1. 현재 매물의 마지막으로 업데이트 된 시간을 가져옴. + // 2. 현재 시간과 비교하여 10분 이내면 경고창을 띄어줌. + + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + + $result_tm = $this->model->getUpdateFailTime($atcl_vr_sq); + $update_tm = $result_tm['insert_tm']; + $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 1, date("s"), date("m"), date("d"), date("Y"))); + + if ($update_tm > $ten_ago) { + // 수정한 시간이 현재시간10분전 보다 클 경우 수정불가능 + throw new \Exception('이미 불일치 처리 된 매물입니다.'); + } + } + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + // 2015.06.29 추가 + // 불일치가 날 경우에 10분 이내에 다시 불일치 처리 불가능(같은 매물을 두사람이 중복처리할 가능성 사전 방지) + // 1. 현재 매물의 마지막으로 업데이트 된 시간을 가져옴. + // 2. 현재 시간과 비교하여 10분 이내면 경고창을 띄어줌. + + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + + $result_tm = $this->model->getUpdateFailTime($atcl_vr_sq); + $update_tm = $result_tm['insert_tm']; + $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 1, date("s"), date("m"), date("d"), date("Y"))); + + if ($update_tm > $ten_ago) { + throw new \Exception('이미 불일치 처리 된 매물입니다.'); + } + } + + $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + + $this->model->InsResChar($atcl_vr_sq); //담당자 업데이트 + + // 모바일v1,v2고 등기부등본 미확인여부 상세 저장 + if ($vrfc_type_sub == 'M1' || $vrfc_type_sub == 'O1') { + $this->model->add_cert_uncnfrm_status($atcl_vr_sq, $arr_uncnfrm_status); + if (strpos($arr_uncnfrm_status, '20020') !== false) { //등기부등본 미확인여부 상세에 20020(파일 오첨부)있고 + if ($vrfc_type_sub == 'M1') { // 모바일v1일땐 코드 20020,코멘트x + $reg_conf_yn_2 = '20020'; + $reg_conf_yn_info_2 = ''; + } else { // 모바일v2일땐 일반 불일치코드,코멘트=파일 오첨부 + $reg_conf_yn_info_2 = '파일 오첨부'; + } + } + } + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '21', $reg_conf_yn_2, $reg_conf_yn_info_2); + + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); + + //memo 저장 + $this->model->saveMemo([$memo, $atcl_vr_sq]); + + // document_cert_method + $this->model->updatedocument_cert_method($atcl_vr_sq, $document_cert_method); + + + //실소유주 확인 저장 + $this->model->update_owner_verifiable($atcl_vr_sq, $owner_verifiable); + $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R'); + + log_message('debug', '712 saveRegi => ' . $sendData['atclNo'] . ' ::: ' . json_encode($sendData) . PHP_EOL); + + $d_yn = $this->model->get_send_yn('D'); + + if ($d_yn['stop_yn'] == 'N') { //전송금지 + //1.해당매물정보를v2_stop_api_save_info에다 넣음 + $this->model->insert_v2_stop_api_save_info($sendData['atclNo'], $atcl_vr_sq, 'D', ''); + //2.아무렇지않게 행동한다 + $send_result['result'] = 'success'; + } else { + //API 호출 + $send_result = $naver->certification_712($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $sendData['ownerVerifiable']); + } + + if ($send_result['result'] == 'success') { + if ($chk_type == '1') { + //상태변경 TABLE INSERT : 등기부등본 확인완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '45', $toDay); + $chgVrfc45 = $this->model->chgStatVrfc($atcl_vr_sq, '45'); //v2_vrfc_req INSERT + $statFaxUp45 = $this->model->chgStatFax($atcl_vr_sq, '45'); //fax_imgs + + //상태변경 TABLE INSERT : 검증완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $chgVrfc60 = $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $statFaxUp60 = $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + // ★ 검증완료 + //0.불일치 이력이 있는지 확인 + $cnt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + if (empty($cnt)) { + if ($atcl_vrtc_type == 'M' || $atcl_vrtc_type == 'N') { //모바일은 등기가 첨 시작이니까 insert해줘야함 + if (!($atcl_vrtc_type == 'M' && in_array($rlet_type_cd['rlet_type_cd'], array('B01', 'B02', 'B03')))) {//만약 분양권들이면 넘어가고 아니면 체크 + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인완료 시간 + $cert_comple_dt = $model415->get_cert_confTimeForHistory($atcl_vr_sq); + //3.검증완료시간 + $finishTime = $model415->get_60_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인완료 시간 + $cert_comple_dt = $model415->get_cert_confTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $model415->update_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm']); + } + } + + if ($noimg_chk_chk == 'Y') { + $this->model->chgStat($atcl_vr_sq, '70', $toDay); + $this->model->updateStat($atcl_vr_sq, 'Y'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0103', '1', 'add'); // 등기부등본이미지 없음 저장 + } + if ($img_chk_chk == 'O') { + $this->model->chgStat($atcl_vr_sq, '76', $toDay); + $this->model->updateStat($atcl_vr_sq, 'O'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0105', '1', 'add'); // (열람)간소화확인으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'T') { + $this->model->chgStat($atcl_vr_sq, '80', $toDay); + $this->model->updateStat($atcl_vr_sq, 'T'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0111', '1', 'add'); // 등기소로 일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'R') { + $this->model->chgStat($atcl_vr_sq, '86', $toDay); + $this->model->updateStat($atcl_vr_sq, 'R'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0107', '1', 'add'); // 리얼탑 열람 일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'G') { + $this->model->chgStat($atcl_vr_sq, '87', $toDay); + $this->model->updateStat($atcl_vr_sq, 'G'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0108', '1', 'add'); // 리얼탑 기열람 일치으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } + } else { + if ($atcl_vrtc_type == 'M') { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $chgVrfc49 = $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $statFaxUp49 = $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $chgVrfc69 = $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $statFaxUp69 = $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + // ★모바일이고 검증실패 + if (!in_array($rlet_type_cd['rlet_type_cd'], array('B01', 'B02', 'B03'))) {//만약 분양권들이면 넘어가고 아니면 체크 + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } + } else { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $chgVrfc49 = $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $statFaxUp49 = $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //등기부등본 확인중 상태로 변경. + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 49 => 30'); //검증결과 변동사항 HISTORY + $chgVrfc40 = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $statFaxUp40 = $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '1'); + if ($atcl_vrtc_type == 'T') { + //검증구분이 전화매물일 경우 사전에 일치로 처리된 값을 초기화 시켜준다. + $reset_query = $this->model->resetTelConf($atcl_vr_sq); + } + + // ★1차실패 + if ($atcl_vrtc_type == 'N') { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $sf = 'F'; + $model415->update_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $sf); + } + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $chgVrfc69 = $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $statFaxUp69 = $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + // ★모바일 이외 검증실패 + if ($atcl_vrtc_type == 'N') { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $model415->update_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm']); + } + } + } + + if ($noimg_chk_chk == 'Y') { + $this->model->chgStat($atcl_vr_sq, '70', $toDay); + $this->model->updateStat($atcl_vr_sq, 'Y'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0103', '1', 'add'); // 등기부등본이미지 없음 저장 + } + if ($img_chk_chk == 'O') { + $this->model->chgStat($atcl_vr_sq, '77', $toDay); + $this->model->updateStat($atcl_vr_sq, 'O'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0105', '1', 'add'); // (열람)간소화확인으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'T') { + $this->model->chgStat($atcl_vr_sq, '85', $toDay); + $this->model->updateStat($atcl_vr_sq, 'T'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0112', '1', 'add'); // 등기소 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'R') { + $this->model->chgStat($atcl_vr_sq, '88', $toDay); + $this->model->updateStat($atcl_vr_sq, 'R'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0109', '1', 'add'); // 리얼탑 열람 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'G') { + $this->model->chgStat($atcl_vr_sq, '89', $toDay); + $this->model->updateStat($atcl_vr_sq, 'G'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0110', '1', 'add'); // 리얼탑 기열람 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } + + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success', + ]); + + } - return $this->response->setJSON([ - 'code' => '0', - 'msg' => 'success', - ]); } catch (\Exception $e) { return $this->response->setJSON([ diff --git a/app/Controllers/V2/M713.php b/app/Controllers/V2/M713.php index 262934c..6168f78 100644 --- a/app/Controllers/V2/M713.php +++ b/app/Controllers/V2/M713.php @@ -3,7 +3,10 @@ namespace App\Controllers\V2; use App\Controllers\BaseController; use App\Libraries\MyUpload; +use App\Libraries\NaverApiClient; use App\Models\common\CodeModel; +use App\Models\results\M415Model; +use App\Models\v2\M710Model; use App\Models\v2\M713Model; class M713 extends BaseController @@ -121,6 +124,7 @@ class M713 extends BaseController // 상세화면 public function detail($id): string { + $naver = new NaverApiClient(); $id = (string) $id; if ($id === '') { @@ -138,6 +142,30 @@ class M713 extends BaseController $sido = $this->model->getAreaList(); // 지역조회 + $hscp_info = []; + if (!empty($data['hscp_no'])) { + $apt_rlet_type_cd = ['A01', 'A02', 'A03', 'A04', 'B01', 'B02', 'B03']; + $villa_rlet_type_cd = ['A05', 'A06']; + + + if (in_array($data['rlet_type_cd'], $apt_rlet_type_cd)) { // apt 단지 + $detail_hscp = $naver->aptDetail($data['hscp_no']); + } + + if (in_array($data['rlet_type_cd'], $villa_rlet_type_cd)) { // villa 단지 + $detail_hscp = $naver->villaDetail($data['hscp_no']); + } + + // print_r($data); + // print_r($detail_hscp); + // exit; + + if (!empty($detail_hscp) && isset($detail_hscp['result'])) { + $hscp_info = $detail_hscp['result']; + } + + } + $this->data['codes'] = $codes; $this->data['data'] = $data; $this->data['memo'] = $memo; @@ -145,6 +173,7 @@ class M713 extends BaseController $this->data['regist'] = $regist; $this->data['display'] = $display; $this->data['sido'] = $sido; + $this->data['hscp_info'] = $hscp_info; return view("pages/v2/m713/detail", $this->data); } @@ -293,6 +322,414 @@ class M713 extends BaseController } + public function saveModify() + { + try { + + $vr_sq = $this->request->getPost('vr_sq'); + $owner_birth = $this->request->getPost('owner_birth'); + $address2 = $this->request->getPost('address2'); + $address2a = $this->request->getPost('address2a'); + $address2b = $this->request->getPost('address2b'); + $address3 = $this->request->getPost('address3'); + $address4 = $this->request->getPost('address4'); + $address_code = $this->request->getPost('dong'); + $hscp_no = $this->request->getPost('hscp_no'); + $hscp_nm = $this->request->getPost('hscp_nm'); + $owner_birth = trim($owner_birth); + + $this->model->modify_info($vr_sq, $owner_birth, $address2, $address2a, $address2b, $address3, $address4, $address_code, $hscp_no, $hscp_nm); + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success' + ]); + + } catch (\Exception $e) { + return $this->response->setJSON([ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + + // 등기부등본 저장 + public function saveRegi() + { + /* + 1.0.1 POST 데이터 받기. + 1.1.1 1차 검증인지 2차검증인지 확인. + 1.1.2 1차, 2차 검증이면 v2_confirm.type에 넣을 값을 알맞게 셋팅. + 1.2.1 v2_confirms에 데이터가 있는지 확인. + 1.3.1 데이터가 있음 : success 여부 판단 후 updateConfirm 실행 success값만 UPDATE. (수정변경이력 저장) + 1.4.1 데이터가 없음 : success 여부 판단 후 insertConfirm 실행 v2_confirms INSERT. (수정변경이력 저장) + 1.4.2 상태변경 하기 : 등기부등본 확인중 상태로 변경. (수정변경이력 저장) + 1.5.1 이미지파일 서버에 UPLOAD (수정변경이력 저장) + 1.6.1 기존파일 탐색. + 1.7.1 기존파일 있음 : 기존파일 use_yn 'N'으로 UPDATE 후 v2_files INSERT. + 1.8.1 기존파일 없음 : v2_files INSERT. + 1.9.1 매물주소, 의뢰인 정보 v2_check_list INSERT. (수정변경이력 저장) + 1.10.1 API 전송. + 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 등기부등본 확인완료 상태. (수정변경이력 저장) + */ + + $naver = new NaverApiClient(); + $model710 = new M710Model(); + $model415 = new M415Model(); + $v2DailyModel = new V2StDailyModel(); + + try { + + $usr_id = session('usr_id'); + $toDay = date('Y-m-d H:i:s'); + $atcl_vrtc_way = 'R'; //검증구분 + $atcl_vr_sq = $this->request->getPost('rcpt_key'); + // $atcl_no = $this->request->getPost('atcl_no'); + $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1'); //확인내용 + $reg_conf_yn_2 = $this->request->getPost('reg_conf_yn_2'); //매물주소 + $reg_conf_yn_3 = $this->request->getPost('reg_conf_yn_3'); //의뢰인정보 + $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2'); //매물주소 + $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3'); //의뢰인정보 + $memo = $this->request->getPost('memo'); //메모 + $owner_verifiable = $this->request->getPost('owner_verifiable'); //실소유주 확인여부 + $noimg_chk_chk = $this->request->getPost('noimg_chk_chk'); // 등기부등본이미지 파일없음. + $img_chk_chk = $this->request->getPost('img_chk_chk'); // 등기소, 리얼탑 열람, 리얼탑 기열람, 열람 + $atcl_vrtc_type = $this->request->getPost('atcl_vrtc_type'); // 검증구분 + $vrfc_type_sub = $this->request->getPost('vrfc_type_sub'); // 하위검증구분 + $arr_uncnfrm_status = $this->request->getPost('arr_uncnfrm_status'); // 등기부등본 미확인여부 상세 + + //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다. + $resStat = $this->model->chkStat($atcl_vr_sq); + $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq); + $rlet_type_cd = $model415->get_rlet_type_cd($atcl_vr_sq); + + if ((int) $resStat['stat_cd'] >= 60 || (int) $resStat['stat_cd'] == 19) { + throw new \Exception('이미 저장된 데이터입니다.'); + } else { + $resultCnt = $this->model->chkRegiTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt + if ($resultCnt['reg_try_cnt'] == 0) { // 1차 검증일 때 + log_message('debug', '713 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 0 '); + $try_cnt = '1'; + } else if ($resultCnt['reg_try_cnt'] == 1) { // 2차 검증일 때 + log_message('debug', '713 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 1 '); + $try_cnt = '2'; + } else { + log_message('debug', '713 page >> 매물번호 : ' . $atcl_vr_sq . ' 등기부등본 불일치 횟수 : 예외처리 '); + $try_cnt = '2'; + //$try_cnt = intval($try_cnt) + 1; + } + + $result = $this->model->chkConfirm($atcl_vr_sq, $atcl_vrtc_way); + if ($result == 0) { //v2_confirm 존재하지 않는다면 + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + // 2015.06.29 추가 + // 불일치가 날 경우에 10분 이내에 다시 불일치 처리 불가능(같은 매물을 두사람이 중복처리할 가능성 사전 방지) + // 1. 현재 매물의 마지막으로 업데이트 된 시간을 가져옴. + // 2. 현재 시간과 비교하여 10분 이내면 경고창을 띄어줌. + + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + + $result_tm = $this->model->getUpdateFailTime($atcl_vr_sq); + $update_tm = $result_tm['insert_tm']; + $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 1, date("s"), date("m"), date("d"), date("Y"))); + + if ($update_tm > $ten_ago) { + // 수정한 시간이 현재시간10분전 보다 클 경우 수정불가능 + throw new \Exception('이미 불일치 처리 된 매물입니다.'); + } + } + $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt); + } else { + if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') { //success 여부 판단 + $chk_type = '1'; + //$chk_delay = '0'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + } else { + // 2015.06.29 추가 + // 불일치가 날 경우에 10분 이내에 다시 불일치 처리 불가능(같은 매물을 두사람이 중복처리할 가능성 사전 방지) + // 1. 현재 매물의 마지막으로 업데이트 된 시간을 가져옴. + // 2. 현재 시간과 비교하여 10분 이내면 경고창을 띄어줌. + + $chk_type = '0'; + //$chk_delay = '1'; //지연여부 + //$chk_zombie = '0'; //좀비매물 + + $result_tm = $this->model->getUpdateFailTime($atcl_vr_sq); + $update_tm = $result_tm['insert_tm']; + $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 1, date("s"), date("m"), date("d"), date("Y"))); + + if ($update_tm > $ten_ago) { + // 수정한 시간이 현재시간10분전 보다 클 경우 수정불가능 + throw new \Exception('이미 불일치 처리 된 매물입니다.'); + } + } + + $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type); + } + + + $this->model->InsResChar($atcl_vr_sq); //담당자 업데이트 + + // 모바일v1,v2고 등기부등본 미확인여부 상세 저장 + if ($vrfc_type_sub == 'M1' || $vrfc_type_sub == 'O1') { + $this->model->add_cert_uncnfrm_status($atcl_vr_sq, $arr_uncnfrm_status); + if (strpos($arr_uncnfrm_status, '20020') !== false) { //등기부등본 미확인여부 상세에 20020(파일 오첨부)있고 + if ($vrfc_type_sub == 'M1') { // 모바일v1일땐 코드 20020,코멘트x + $reg_conf_yn_2 = '20020'; + $reg_conf_yn_info_2 = ''; + } else { // 모바일v2일땐 일반 불일치코드,코멘트=파일 오첨부 + $reg_conf_yn_info_2 = '파일 오첨부'; + } + } + } + //v2_check_list 확인여부 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '21', $reg_conf_yn_2, $reg_conf_yn_info_2); + + //v2_check_list 매물주소 INSERT + $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, '22', $reg_conf_yn_3, $reg_conf_yn_info_3); + + //memo 저장 + $this->model->saveMemo([$memo, $atcl_vr_sq]); + + //실소유주 확인 저장 + $this->model->update_owner_verifiable($atcl_vr_sq, $owner_verifiable); + + $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R'); + + //이미지 파일 없음 && 홍보확인서 V2일 경우 + log_message('debug', '713 noimage_chk_chk sendData_return1 => ' . $sendData['atclNo'] . ' ::: ' . json_encode($sendData) . PHP_EOL); + if ($noimg_chk_chk == "Y" && $sendData['vrfcType'] == "D2") { + // $sendData['ownerVerifiable'] = false; + } + + $d_yn = $model710->get_send_yn('O'); + if ($d_yn['stop_yn'] == 'N') { //전송금지 + //1.해당매물정보를v2_stop_api_save_info에다 넣음 + $model710->insert_v2_stop_api_save_info($sendData['atclNo'], $atcl_vr_sq, 'O', ''); + //2.아무렇지않게 행동한다 + $send_result['result'] = 'success'; + } else { + //API 호출 + $send_result = $naver->certification($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $sendData['ownerVerifiable']); + } + + if ($send_result['result'] == 'success') { + if ($chk_type == '1') { + //상태변경 TABLE INSERT : 등기부등본 확인완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '45', $toDay); + $chgVrfc45 = $this->model->chgStatVrfc($atcl_vr_sq, '45'); //v2_vrfc_req INSERT + $statFaxUp45 = $this->model->chgStatFax($atcl_vr_sq, '45'); //fax_imgs + + //상태변경 TABLE INSERT : 검증완료 상태로 변경 + $this->model->chgStat($atcl_vr_sq, '60', $toDay); + $chgVrfc60 = $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT + $statFaxUp60 = $this->model->chgStatFax($atcl_vr_sq, '60'); //fax_imgs + + // ★ 검증완료 + //0.불일치 이력이 있는지 확인 + $cnt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + if (empty($cnt)) { //검증완료일땐 불일치가없어야 통계포함된다 + if ($atcl_vrtc_type == 'M' || $atcl_vrtc_type == 'O') { //모바일은 등기가 첨 시작이니까 insert해줘야함 + if (!($atcl_vrtc_type == 'M' && in_array($rlet_type_cd['rlet_type_cd'], array('B01', 'B02', 'B03')))) {//만약 분양권들이면 넘어가고 아니면 체크 + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인완료 시간 + $cert_comple_dt = $model415->get_cert_confTimeForHistory($atcl_vr_sq); + //3.검증완료시간 + $finishTime = $model415->get_60_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인완료 시간 + $cert_comple_dt = $model415->get_cert_confTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $model415->update_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm']); + } + } + if ($noimg_chk_chk == 'Y') { + $this->model->chgStat($atcl_vr_sq, '70', $toDay); + $this->model->updateStat($atcl_vr_sq, 'Y'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0103', '1', 'add'); // 등기부등본이미지 없음 저장 + } + if ($img_chk_chk == 'O') { + $this->model->chgStat($atcl_vr_sq, '76', $toDay); + $this->model->updateStat($atcl_vr_sq, 'O'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0105', '1', 'add'); // (열람)간소화확인으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'T') { + $this->model->chgStat($atcl_vr_sq, '80', $toDay); + $this->model->updateStat($atcl_vr_sq, 'T'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0111', '1', 'add'); // 등기소로 일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'R') { + $this->model->chgStat($atcl_vr_sq, '86', $toDay); + $this->model->updateStat($atcl_vr_sq, 'R'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0107', '1', 'add'); // 리얼탑 열람 일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } else if ($img_chk_chk == 'G') { + $this->model->chgStat($atcl_vr_sq, '87', $toDay); + $this->model->updateStat($atcl_vr_sq, 'G'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0108', '1', 'add'); // 리얼탑 기열람 일치으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0101', '1', 'add'); // 일치로 저장 + } + } else { + if ($atcl_vrtc_type == 'M') { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $result_query7 = $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $chgVrfc49 = $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $statFaxUp49 = $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //v2_vrfc_req try_cnt 값을 1로 update + $res_try = $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $result_query9 = $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $chgVrfc69 = $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $statFaxUp69 = $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + // ★모바일이고 검증실패 + if (!in_array($rlet_type_cd['rlet_type_cd'], array('B01', 'B02', 'B03'))) {//만약 분양권들이면 넘어가고 아니면 체크 + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } + } else { + //상태변경 TABLE INSERT : 등기부등본 확인 불일치 상태로 변경 + $result_query7 = $this->model->chgStat($atcl_vr_sq, '49', $toDay); + $chgVrfc49 = $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT + $statFaxUp49 = $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_imgs + + //등기부등본 확인중 상태로 변경. + $this->model->saveChangedHistory($atcl_vr_sq, '30', 'C9', $usr_id, '상태변경 : 49 => 30'); //검증결과 변동사항 HISTORY + $chgVrfc40 = $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT + $statFaxUp40 = $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs + + if ($try_cnt == '1') { + //v2_vrfc_req try_cnt 값을 1로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '1'); + if ($atcl_vrtc_type == 'T') { + //검증구분이 전화매물일 경우 사전에 일치로 처리된 값을 초기화 시켜준다. + $reset_query = $this->model->resetTelConf($atcl_vr_sq); + } + + // ★1차실패 + if ($atcl_vrtc_type == 'O') { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $sf = 'F'; + $model415->update_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $sf); + } + } else if ($try_cnt == '2') { + //v2_vrfc_req try_cnt 값을 2로 update + $this->model->chgRegiTryCnt($atcl_vr_sq, '2'); + + //상태변경 TABLE INSERT : 검증실패 상태로 변경. + $result_query9 = $this->model->chgStat($atcl_vr_sq, '69', $toDay); + $chgVrfc69 = $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT + $statFaxUp69 = $this->model->chgStatFax($atcl_vr_sq, '69'); //fax_imgs + + // ★모바일 이외 검증실패 + if ($atcl_vrtc_type == 'O') { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_M_timeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.검증실패시간 + $finishTime = $model415->get_69_ForHistory($atcl_vr_sq); + //4.해당 정보를 테이블에 넣는다 + $model415->insert_v2_time_required_M($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm'], $finishTime['insert_tm']); + } else { + //1.등기부등본 확인중 시간 + $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq); + //2.등기부등본 확인실패 시간 + $cert_comple_dt = $model415->get_cert_failTimeForHistory($atcl_vr_sq); + //3.해당 정보를 테이블에 넣는다 + $model415->update_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $atcl_vrtc_type, $tel_doc_conf_dt['insert_tm'], $cert_comple_dt['insert_tm']); + } + } + } + + if ($noimg_chk_chk == 'Y') { + $this->model->chgStat($atcl_vr_sq, '70', $toDay); + $this->model->updateStat($atcl_vr_sq, 'Y'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0103', '1', 'add'); // 등기부등본이미지 없음 저장 + } + if ($img_chk_chk == 'O') { + $this->model->chgStat($atcl_vr_sq, '77', $toDay); + $this->model->updateStat($atcl_vr_sq, 'O'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0105', '1', 'add'); // (열람)간소화확인으로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'T') { + $this->model->chgStat($atcl_vr_sq, '85', $toDay); + $this->model->updateStat($atcl_vr_sq, 'T'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0112', '1', 'add'); // 등기소 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'R') { + $this->model->chgStat($atcl_vr_sq, '88', $toDay); + $this->model->updateStat($atcl_vr_sq, 'R'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0109', '1', 'add'); // 리얼탑 열람 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } else if ($img_chk_chk == 'G') { + $this->model->chgStat($atcl_vr_sq, '89', $toDay); + $this->model->updateStat($atcl_vr_sq, 'G'); // reg_status를 업데이트해준다. + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0110', '1', 'add'); // 리얼탑 기열람 불일치로 저장 + $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'R0102', '1', 'add'); // 불일치로 저장 + } + } + } else { + if (isset($send_result['error'])) { + $error_message = $send_result['error']['code'] . "\\n" . $send_result['error']['message']; + + // API 호출 에러 발생시 해당 내용들을 DB에 저장해준다. + $err_time = date("Y-m-d H:i:s"); + $this->model->saveApiErr($atcl_vr_sq, $send_result['error']['code'], $send_result['error']['message'], $err_time, $v2_vrfc_req['atcl_no']); + throw new \Exception($error_message); + } else { + throw new \Exception('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.'); + } + } + + return $this->response->setJSON([ + 'code' => '0', + 'msg' => 'success' + ]); + + } + + } catch (\Exception $e) { + return $this->response->setJSON([ + 'code' => '9', + 'msg' => $e->getMessage(), + ]); + } + } + // 다음매물확인 public function nextRegi() { diff --git a/app/Libraries/NaverApiClient.php b/app/Libraries/NaverApiClient.php index 45bd7e1..2598afd 100644 --- a/app/Libraries/NaverApiClient.php +++ b/app/Libraries/NaverApiClient.php @@ -3,6 +3,8 @@ namespace App\Libraries; use App\Models\common\CommonModel; +use App\Models\v2\M712Model; +use CodeIgniter\Model; class NaverApiClient { @@ -43,7 +45,7 @@ class NaverApiClient { $this->charger = $charger; $url = "{$this->baseUrl}/kiso/center/verification-article/{$articleNumber}?charger={$this->charger}"; - + return $this->request('PUT', $url, $updateData); } @@ -106,7 +108,7 @@ class NaverApiClient { $this->charger = $charger; $url = "{$this->baseUrl}/kiso/center/verification-article/price/{$articleNumber}?charger={$this->charger}"; - + return $this->request('POST', $url, $priceData); } @@ -116,14 +118,14 @@ class NaverApiClient $url .= '?reserveNoList=' . $reserveNoList; return $this->request('GET', $url); } - + /** * 단지상세정보조회 * hscpNo : 단지번호(숫자) */ public function aptDetail($hscpNo) { - $url = $this->commonModel->getCompanyInfo(2); + $url = $this->commonModel->getCompanyInfo(3); $url = $url['api_server'] . "/confirms/APTDetail?hscpNo={$hscpNo}"; return $this->request('GET', $url); } @@ -135,7 +137,7 @@ class NaverApiClient public function villaDetail($hscpNo) { - $url = $this->commonModel->getCompanyInfo(2); + $url = $this->commonModel->getCompanyInfo(3); $url = $url['api_server'] . "/confirms/villa/{$hscpNo}"; return $this->request('GET', $url); } @@ -322,7 +324,118 @@ class NaverApiClient return $this->request('POST', $url, $postData); } - + + /** + * 등기부 등본 확인 결과 + * 712 OwnerVerifiable 전송 오류 우회 테스트 + */ + public function certification_712($atclNo, $type, $success, $checkList, $charger, $date, $modifyInfo, $ownerVerifiable) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/confirms/certification"; + + $model712 = new M712Model(); + $data = $model712->getOwnerVerifiable($atclNo); + + $ov = $data['OwnerVerifiable_change']; + if (isset($ov)) { + if ($ov > 0) { + $ownerVerifiable = true; + } else { + $ownerVerifiable = false; + } + } else { + $ownerVerifiable = null; + } + + $postData = [ + "atclNo" => $atclNo, + "type" => $type, + "success" => $success, + "checkList" => $checkList, + "charger" => $charger, + "date" => $date, + "modifyInfo" => $modifyInfo, + "ownerVerifiable" => $ownerVerifiable + ]; + + log_message('debug', '712 certification_712 => ' . $atclNo . ' ::: ' . json_encode($postData) . PHP_EOL); + + return $this->request('POST', $url, $postData); + } + + /** + * 현장확인 거주인 여부 변경 + */ + public function residentsExistence($reserveNumber, $isResidentsExist) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/residents/existence"; + + $postData = [ + 'reserveNumber' => $reserveNumber, + 'isResidentsExist' => $isResidentsExist + ]; + + return $this->request('POST', $url, $postData); + } + + /** + * 예약확인 완료 + */ + public function reserveSuccess($reserveNo, $modyfyYn, $agency, $team, $staff, $staffTel, $reserveYmd, $apm) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/site/reserveSuccess.nhn"; + + $getData = ['reserveNo' => $reserveNo, 'modyfyYn' => $modyfyYn, 'agency' => $agency, 'team' => $team, 'staff' => $staff, 'staffTel' => $staffTel, 'reserveYmd' => $reserveYmd, 'apm' => $apm]; + + return $this->request('POST', $url, $getData); + } + + /** + * 예약확인 실패 + */ + public function reserveFail($reserveNo, $errorCode, $etcTxt) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/site/reserveFail.nhn"; + + $getData = ['reserveNo' => $reserveNo, 'errorCode' => $errorCode, 'errorDesc' => $etcTxt]; + + return $this->request('POST', $url, $getData); + } + + /** + * 촬영 실패 + */ + public function shootFail($reserveNo, $errorCode, $etcTxt) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/site/shootFail.nhn"; + + $getData = ['reserveNo' => $reserveNo, 'errorCode' => $errorCode, 'errorDesc' => $etcTxt]; + + return $this->request('POST', $url, $getData); + } + + /** + * 현장확인2 및 썸네일 검수 실패 + */ + public function inspectFail($reserveNumber, $failDescription) + { + $url = $this->commonModel->getCompanyInfo(3); + $url = $url['api_server'] . "/site/vr/inspect/fail"; + + $postData = [ + 'reserveNumber' => $reserveNumber, + 'failDescription' => $failDescription + ]; + + return $this->request('POST', $url, $postData); + } + + /** * CURL 공통 실행 함수 */ @@ -364,7 +477,7 @@ class NaverApiClient 'X-Naver-Client-Id: yqBbvQZ123_hjH3b3Df9' ]); } - } elseif ( $method === 'PATCH') { + } elseif ($method === 'PATCH') { curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PATCH'); if ($data) { $payload = json_encode($data); diff --git a/app/Models/article/DeptModel.php b/app/Models/article/DeptModel.php index 8c82f82..34e6706 100644 --- a/app/Models/article/DeptModel.php +++ b/app/Models/article/DeptModel.php @@ -115,6 +115,22 @@ class DeptModel extends Model return $query->getResultArray(); } + /** + * 부서검색(상세) + */ + public function getDeptDetail($dept_sq) + { + $sql = "SELECT dept_sq, pdept_sq, dept_nm, dept_desc, dept_head, use_yn, depth, insert_tm, insert_usr, update_tm, update_usr, lft, rgt" . + " FROM departments" . + " WHERE dept_sq = ?"; + + $data = array($dept_sq); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + return $row; + } + // 조직별통계 public function getDeptStatistics($data) { diff --git a/app/Models/article/ReceiptModel.php b/app/Models/article/ReceiptModel.php index 1274dc6..3ca1bb5 100644 --- a/app/Models/article/ReceiptModel.php +++ b/app/Models/article/ReceiptModel.php @@ -116,6 +116,19 @@ class ReceiptModel extends Model return $query->getResultArray(); } + public function getSrchUserInfo($usr_id) + { + $sql = "SELECT a.usr_sq, a.usr_id, b.dept_sq, b.pdept_sq FROM users a + JOIN departments b ON b.dept_sq = a.dept_sq + WHERE a.usr_id = ? AND a.use_yn = 'Y'"; + + $data = [$usr_id]; + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + return $row; + } + /** * 부서검색(상세) */ @@ -149,6 +162,31 @@ class ReceiptModel extends Model return $query->getResultArray(); } + /** + * 사용자 상세정보 + */ + public function getUserDetail($usr_sq) + { + $builder = $this->db->table('users a'); + + $builder->select(" + a.usr_sq, + a.dept_sq, + a.usr_id, + a.usr_nm, + a.usr_level, + a.usr_tel1, + a.usr_tel2, + b.dept_nm + ", false); + + $builder->join('departments b', 'a.dept_sq = b.dept_sq', 'left'); + $builder->where('a.usr_sq', $usr_sq); + + return $builder->get()->getRowArray(); + + } + public function getTotalCount($data) { $usr_sq = session('usr_sq'); @@ -1179,10 +1217,27 @@ class ReceiptModel extends Model $builder->where('a.rcpt_key', $id); - return $builder->get()->getRowArray(); } + /** + * 사용자의 지정일자에 배정된 목록을 가져온다. (시간, 위치만...) + */ + public function getAssignReceiptListByUser($rsrv_date, $usr_sq, $arrExcept = []) + { + $sql = "SELECT a.rcpt_key, a.rcpt_atclno, a.rcpt_x, a.rcpt_y, b.rsrv_tm_ap, b.rsrv_tm_hour" . + " FROM receipt a" . + " INNER JOIN result b ON b.rcpt_sq = a.rcpt_sq AND b.usr_sq = ? AND b.rsrv_date = ?" . + " WHERE a.rcpt_key not in (?)"; + $except_rcptKey = implode(',', $arrExcept); + $data = array($usr_sq, $rsrv_date, $except_rcptKey); + $query = $this->db->query($sql, $data); + $res = $query->getResultArray(); + + + return $res; + } + public function getDupleGP($rcpt_key, $rcpt_sido, $rcpt_gugun, $rcpt_dong, $rcpt_hscp_nm, $rcpt_dtl_addr, $rcpt_ho) { $sql = "select rcpt_sq, c.rcpt_key, c.photo_save_dt from" . @@ -1426,6 +1481,40 @@ class ReceiptModel extends Model ]; } + // 거주여부 저장 + public function saveResDB($rcpt_sq, $rsrv_sq, $resYn, $dbUsageAgrYn) + { + $this->db->transStart(); + $usr_id = session('usr_id'); + + $sql = "SELECT result_cd3, resYn, dbUsageAgrYn FROM result WHERE rsrv_sq = ?"; + $data = array($rsrv_sq); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + $sql = "UPDATE result" . + " SET resYn = ?" . + " ,dbUsageAgrYn = ?" . + " WHERE rsrv_sq = ?" . + " AND rcpt_sq = ?"; + $data = array($resYn, $dbUsageAgrYn, $rsrv_sq, $rcpt_sq); + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '저장실패', + ]; + } + + $this->saveChangedHistory($rcpt_sq, $row['result_cd3'], 'C24', $usr_id, $row['resYn'] . "|" . $row['dbUsageAgrYn']); + + $this->db->transComplete(); + + return [ + 'success' => true, + ]; + } + // 평면도요청 저장 public function saveGround($rcpt_sq, $ground_plan) { @@ -2044,4 +2133,202 @@ class ReceiptModel extends Model } } + + /** + * 배정자 등록 + */ + public function assignRegist($rcpt_sq, $rsrv_date, $rsrv_tm_ap, $rsrv_tm_hour, $dept_sq, $usr_sq, $receipt) + { + // 세션정보 + $usr_id = session('usr_id'); + $reg_usr_sq = session('usr_sq'); + + $this->db->transStart(); + + // 변경전 기존 데이터 가져오기 + $org_sql = "SELECT * FROM result WHERE rcpt_sq = ?"; + $query = $this->db->query($org_sql, [$rcpt_sq]); + $row = $query->getRowArray(); + + // 예약확인 + $sql1 = "UPDATE result" . + " SET rsrv_date = ?" . + " ,rsrv_tm_ap = ?" . + " ,rsrv_tm_hour = ?" . + " ,rsrv_save_dt = now()" . + " ,update_tm = now()" . + " ,update_usr = ?" . + " WHERE rcpt_sq = ?"; + + $data1 = [ + $rsrv_date, + $rsrv_tm_ap, + $rsrv_tm_hour, + $reg_usr_sq, + $rcpt_sq + ]; + + if ($this->db->query($sql1, $data1) === false) { + return [ + 'success' => false, + 'msg' => '저장 실패', + ]; + } + + // 배정 + $sql2 = "UPDATE result" . + " SET dept_sq = ?" . + " ,usr_sq = ?" . + " ,result_cd1 = 20" . + " ,result_cd2 = 2000" . + " ,result_cd3 = 200000" . + " ,update_usr = ?" . + " ,update_tm = now()" . + " ,assign_save_dt = now()" . + " ,rsrv_cplt_dt = now()" . + " WHERE rcpt_sq = ?"; + + $data2 = [ + $dept_sq, + $usr_sq, + $reg_usr_sq, + $rcpt_sq + ]; + + if ($this->db->query($sql2, $data2) === false) { + return [ + 'success' => false, + 'msg' => '저장 실패', + ]; + } + + // 매물상태 변경 + $rcpt_sql = "UPDATE receipt" . + " SET rcpt_stat = 200000" . + " WHERE rcpt_sq = ?"; + $this->db->query($rcpt_sql, [$rcpt_sq]); + + // 정보변경이력 저장 + if (!empty($row)) { + $remark = "{$row['rsrv_date']} {$row['rsrv_tm_ap']} {$row['rsrv_tm_hour']}시 -> {$rsrv_date} {$rsrv_tm_ap} {$rsrv_tm_hour}시"; + } else { + $remark = "{$receipt['rsrv_date']} {$receipt['rsrv_tm_ap']} -> {$rsrv_date} {$rsrv_tm_hour}"; + } + + $this->saveChangedHistory($rcpt_sq, '200000', 'C11', $usr_id, $remark); + + $this->db->transComplete(); + + + return [ + 'success' => true, + ]; + } + + + /** + * 취소 + */ + public function rsrvcancel($rcpt_sq, $rsrv_sq, $result_cd2, $result_cd3, $result_msg, $receipt) + { + // 세션정보 + $usr_id = session('usr_id'); + $usr_sq = session('usr_sq'); + $usr_nm = session('usr_nm'); + + // 변경전 기존 데이터 가져오기 + $org_sql = "SELECT * FROM result WHERE rcpt_sq = ?"; + $query = $this->db->query($org_sql, [$rcpt_sq]); + $row = $query->getRowArray(); + + $this->db->transStart(); + + if ($result_cd2 == "9050") { + $sql = "UPDATE result" . + " SET result_cd1 = '90'" . + " ,result_cd2 = ?" . + " ,result_cd3 = ?" . + " ,result_msg = ?" . + " ,check_fail_dt = now()" . + " ,update_usr = ?" . + " ,update_tm = now()" . + " WHERE rsrv_sq = ?"; + } else { + $sql = "UPDATE result" . + " SET result_cd1 = '90'" . + " ,result_cd2 = ?" . + " ,result_cd3 = ?" . + " ,result_msg = ?" . + " ,cancel_dt = now()" . + " ,update_usr = ?" . + " ,update_tm = now()" . + " WHERE rsrv_sq = ?"; + } + + $data = [ + $result_cd2, + $result_cd3, + $result_msg, + $usr_sq, + $rsrv_sq + ]; + + $res = $this->db->query($sql, $data); + + if (!$res) { + $return = [ + 'success' => false, + 'msg' => '저장실패', + ]; + } else { + // 매물상태 변경 + $rcpt_sql = "UPDATE receipt" . + " SET rcpt_stat = ?" . + " WHERE rcpt_sq = ?"; + $rcpt_data = [$result_cd3, $rcpt_sq]; + $this->db->query($rcpt_sql, $rcpt_data); + + // 정보변경이력 저장 + if (!empty($row['result_msg'])) { + $remark = $row['result_msg'] . " -> " . $result_msg; + } else { + $remark = $result_msg; + } + $this->saveChangedHistory($rcpt_sq, $result_cd3, 'C5', $usr_id, $remark); + + // 문자발송 + if ($result_cd2 == "9010" || $result_cd2 == "9020") { + // 접수취소, 예약취소 + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S2', $receipt); + } else if ($result_cd2 == "9030") { + // 방문전 취소 + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S4', $receipt); + } else if ($result_cd2 == "9040") { + // 방문후 취소 + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S5', $receipt); + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S5-1', $receipt); + } else if ($result_cd2 == "9045") { + // 촬영후 취소 + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S6', $receipt); + } + + if ($result_cd3 == "905010") { + // 거주인녹취실패 취소(검수실패) + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S9', $receipt); + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S9-1', $receipt); + } else if ($result_cd3 == "905020") { + // 홍보확인서 미수취 취소(검수실패) + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S11', $receipt); + $this->sendSms($receipt['agent_head_tel'], $receipt['agent_nm'], '1600-5749', $usr_nm, 0, $rsrv_sq, $rcpt_sq, 'S11-1', $receipt); + } + + $return = [ + 'success' => true, + ]; + } + + $this->db->transComplete(); + + return $return; + } } \ No newline at end of file diff --git a/app/Models/receipt/ReceiptModel.php b/app/Models/receipt/ReceiptModel.php index d1ed894..2454096 100644 --- a/app/Models/receipt/ReceiptModel.php +++ b/app/Models/receipt/ReceiptModel.php @@ -146,4 +146,21 @@ class ReceiptModel extends Model $data = [$imgSq, $faxSq]; $this->db->query($sql, $data); } + + // receipt 에서 지정한 1건만 가져온다. + public function selectReceiptOne($rcpt_sq) + { + $sql = "SELECT a.rcpt_sq,a.comp_sq,a.rcpt_rating,a.rcpt_key,a.rcpt_atclno,a.rcpt_type,a.rcpt_product,a.rcpt_product_nm,a.rcpt_product_area,a.rcpt_product_price,a.rcpt_product_info1,a.rcpt_product_info2,a.rcpt_product_info3,a.rcpt_product_info4,a.rcpt_product_info5,a.rcpt_office,a.rcpt_agent,a.rcpt_sido,a.rcpt_gugun,a.rcpt_dong,a.rcpt_hscp_nm,a.rcpt_dtl_addr,a.rcpt_floor,a.rcpt_bunji,a.rcpt_ho,a.rcpt_tm,a.rcpt_stat,a.rcpt_x,a.rcpt_y,a.rcpt_living_yn,a.cust_nm,a.cust_tel1,a.cust_tel2,a.cust_zip,a.cust_addr1,a.cust_addr2,a.remark,a.agent_id,a.agent_nm,a.agent_head,a.agent_head_tel,a.agent_contact,a.agent_contact_tel,a.agent_fax,a.rsrv_date,a.rsrv_tm_ap,a.insert_usr,a.insert_tm,a.update_usr,a.update_tm,a.svc_type1,a.svc_type2,a.reconf_yn,a.rcpt_exps_type" . + ", b.region_nm" . + ", c.rsrv_sq" . + " FROM receipt a" . + " LEFT JOIN region_codes b ON b.region_cd = a.rcpt_dong" . + " LEFT JOIN result c on c.rcpt_sq = a.rcpt_sq" . + " WHERE a.rcpt_sq = ?" . + " limit 1"; + $data = [$rcpt_sq]; + $query = $this->db->query($sql, $data); + + return $query->getRowArray(); + } } \ No newline at end of file diff --git a/app/Models/v2/M701Model.php b/app/Models/v2/M701Model.php index 57f51af..aafadbe 100644 --- a/app/Models/v2/M701Model.php +++ b/app/Models/v2/M701Model.php @@ -1345,7 +1345,7 @@ class M701Model extends Model $comment = implode('|', $comment); } - $usr_sq = $this->session->userdata('usr_sq'); + $usr_sq = session('usr_sq'); $sql = "INSERT INTO v2_check_list" . "(vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . "VALUES" . diff --git a/app/Models/v2/M702Model.php b/app/Models/v2/M702Model.php index 577466e..a53312f 100644 --- a/app/Models/v2/M702Model.php +++ b/app/Models/v2/M702Model.php @@ -1507,6 +1507,20 @@ class M702Model extends Model ]; } + public function chgTryCnt($vr_sq, $try_cnt) + { //v2_vrfc_req try_cnt 값 변경. + $sql = "UPDATE v2_vrfc_req" . + " SET try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $this->db->query($sql, $data); + } + // 변경이력 조회 public function getHistory($vr_sq) { diff --git a/app/Models/v2/M703Model.php b/app/Models/v2/M703Model.php index 6b5ebc0..7bbb5c6 100644 --- a/app/Models/v2/M703Model.php +++ b/app/Models/v2/M703Model.php @@ -2,6 +2,7 @@ namespace App\Models\v2; use App\Models\receipt\ReceiptModel; +use App\Models\webfax\FaxModel; use CodeIgniter\Model; class M703Model extends Model @@ -1504,8 +1505,9 @@ class M703Model extends Model $this->saveChangedHistory($vr_sq, '35', 'C9', $insert_id, '현장확인 매물'); - $fax = $this->fax_model->selectFax($fax_sq); // fax 이미지 파일 가져오기 - $receipt = $this->receipt_model->selectReceiptOne($vr_sq); // 매물정보 가져오기 + $faxModel = new FaxModel(); + $fax = $faxModel->selectFax($fax_sq); // fax 이미지 파일 가져오기 + $receipt = $this->selectReceiptOne($vr_sq); // 매물정보 가져오기 // 40: 촬영, 70: 검수지연... 상태가 촬용 이전 또는 검수지연 상태일 경우에만 홍보확인서를 등록한다. if (substr($receipt['rcpt_stat'], 0, 2) <= '40' || substr($receipt['rcpt_stat'], 0, 2) == '70') { @@ -2115,8 +2117,8 @@ class M703Model extends Model */ public function saveChangeStep($fax_sq, $vr_sq, $stat_cd) { - $insert_user = $this->session->userdata('usr_sq'); - $insert_id = $this->session->userdata('usr_id'); + $insert_user = session('usr_sq'); + $insert_id = session('usr_id'); $this->db->transStart(); diff --git a/app/Models/v2/M704Model.php b/app/Models/v2/M704Model.php index 1a70a89..e6e45ad 100644 --- a/app/Models/v2/M704Model.php +++ b/app/Models/v2/M704Model.php @@ -1,6 +1,7 @@ db->transComplete(); // 홍보확인서인 경우 주소 변경시 FAX 이미지의 정보도 함께 변경한다. - $faxModel = model('App\Models\FaxModel'); + $faxModel = new FaxModel(); $faxModel->updateAddress($atcl_vr_sq, $list['address_code'], $data['address2'] ?? '', $data['address3'] ?? '', $data['hscp_no'] ?? '', $data['hscp_nm'] ?? ''); return $return; diff --git a/app/Models/v2/M705Model.php b/app/Models/v2/M705Model.php index d458b02..f166c11 100644 --- a/app/Models/v2/M705Model.php +++ b/app/Models/v2/M705Model.php @@ -1187,7 +1187,7 @@ class M705Model extends Model public function InsResChar($atcl_vr_sq) { - $usr_id = $this->session->userdata('usr_id'); + $usr_id = session('usr_id'); $sql = "UPDATE v2_article_info" . " SET reg_charger = ?" . diff --git a/app/Models/v2/M706Model.php b/app/Models/v2/M706Model.php index 3722c0a..f7fa936 100644 --- a/app/Models/v2/M706Model.php +++ b/app/Models/v2/M706Model.php @@ -1,6 +1,7 @@ getRowArray(); } + /* 매물정보를 수정 */ + public function saveModifyInfo($atcl_vr_sq, $atcl_hscp_nm, $atcl_ptp_nm, $atcl_vrfc_type, $trade_type, $atcl_addr1, $atcl_addr1a, $atcl_addr1b, $atcl_addr2, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1, $atcl_amt2, $atcl_amt3, $atcl_floor, $atcl_floor2) + { + $session = session(); + $usr_id = $session->get('usr_id'); + + $list = $this->getDetail($atcl_vr_sq); + + $data = []; + + if ($trade_type != 'B2') { + $atcl_amt3 = '0'; + $data['lease_amt'] = $atcl_amt3; + } + if (!empty($trade_type)) + $data['trade_type'] = $trade_type; + if (!empty($atcl_hscp_nm)) + $data['hscp_nm'] = $atcl_hscp_nm; + if (!empty($atcl_ptp_nm)) + $data['ptp_nm'] = $atcl_ptp_nm; + if (!empty($atcl_addr1)) + $data['address2'] = $atcl_addr1; + if (!empty($atcl_addr1a)) + $data['address2a'] = $atcl_addr1a; + if (!empty($atcl_addr1b)) + $data['address2b'] = $atcl_addr1b; + if (!empty($atcl_addr2)) + $data['address3'] = $atcl_addr2; + if (!empty($atcl_hscp_no)) + $data['hscp_no'] = $atcl_hscp_no; + if (!empty($atcl_ptp_no)) + $data['ptp_no'] = $atcl_ptp_no; + if (!empty($atcl_amt1)) + $data['deal_amt'] = $atcl_amt1; + if (!empty($atcl_amt2)) + $data['wrrnt_amt'] = $atcl_amt2; + if (!empty($atcl_amt3)) + $data['lease_amt'] = $atcl_amt3; + if (!empty($atcl_floor)) + $data['floor'] = $atcl_floor; + if (!empty($atcl_floor2)) + $data['floor2'] = $atcl_floor2; + $data['modify_yn'] = 'Y'; + + $this->db->transStart(); + + $builder = $this->db->table('v2_modify_info'); + $builder->where('vr_sq', $atcl_vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + $current_url = current_url(); + log_message('debug', $current_url . ' :: ' . $last_query); + + $data['trade_type_cd'] = $trade_type; + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + if (empty($return['error_number'])) { + if ($this->db->affectedRows() > 0) { + if (!empty($changed)) { + $this->saveChangedHistory($list['vr_sq'], $list['pre_stat_cd'], 'C25', $usr_id, "매물정보 수정"); + } + } + } + $this->db->transComplete(); + + // 홍보확인서인 경우 주소 변경시 FAX 이미지의 정보도 함께 변경한다. + $faxModel = new FaxModel(); + $faxModel->updateAddress($atcl_vr_sq, $list['address_code'], $data['address2'] ?? '', $data['address3'] ?? '', $data['hscp_no'] ?? '', $data['hscp_nm'] ?? ''); + + return $return; + } + + public function saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type) + { + + $usr_id = session('usr_id'); + + $list = $this->getDetail($atcl_vr_sq); //변경된 내용 비교를 위해. + + $data['vrfc_type'] = $atcl_vrfc_type; + + $this->db->where('vr_sq', $atcl_vr_sq); + $this->db->trans_start(); + $this->db->update('v2_vrfc_req', $data); + + $data['vrfc_type_cd'] = $atcl_vrfc_type; + //echo $this->db->last_query(); + $return['error_number'] = $this->db->_error_number(); + $return['error_message'] = $this->db->_error_message(); + + if (empty($return['error_number'])) { + // 로그를 남긴다. + if ($this->db->affected_rows() > 0) { + if (!empty($changed)) { + $this->saveChangedHistory($list['data']['vr_sq'], $list['data']['pre_stat_cd'], 'C25', $usr_id, "매물정보 저장"); + } + } + } + $this->db->trans_complete(); + return $return; + } + + /* 현재 상태 확인 */ + public function chkStat($vr_sq) + { + $sql = "SELECT stat_cd FROM v2_vrfc_req WHERE vr_sq = ?"; + $data = array( + $vr_sq + ); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + public function InsCharger($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function chkTryCnt($atcl_vr_sq) + { + // 1차 검증인지 2차 검증인지 확인. + $builder = $this->db->table('v2_vrfc_req'); + $builder->select('try_cnt'); + $builder->where('vr_sq', $atcl_vr_sq); + + $query = $builder->get(); + return $query->getRowArray(); + } + + public function chkConfirm($atcl_vr_sq, $reg_yn = null) + { + // 검증결과 table에 있는지 확인. + $builder = $this->db->table('v2_confirm'); + $builder->select('vr_sq'); + $builder->where('vr_sq', $atcl_vr_sq); + + if ($reg_yn) { + $builder->where('vrfc_type', $reg_yn); // 등기부등본 정보 확인시 + } + + $query = $builder->get(); + return $query->getNumRows(); + } + + public function insertConfirm($vr_sq, $vrfc_type, $success, $type) + { //v2_confirm INSERT + + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $sql = "INSERT INTO v2_confirm" . + "(vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, '" . date('YmdHis') . "', ?, NOW(), ?, NOW())"; + + $data = array( + $vr_sq, + $vrfc_type, + $success, + $type, + $usr_id, + $usr_sq, + $usr_sq + ); + + $this->db->query($sql, $data); + } + + public function updateConfirm($vr_sq, $vrfc_type, $success) + { + $data = [ + 'success' => $success, + 'update_tm' => date('Y-m-d H:i:s') + ]; + + $builder = $this->db->table('v2_confirm'); + $builder->where('vr_sq', $vr_sq); + $builder->where('vrfc_type', $vrfc_type); + $builder->update($data); + + $return = [ + 'error_number' => $this->db->error()['code'], + 'error_message' => $this->db->error()['message'] + ]; + + return $return; + } + + public function chgStat($vr_sq, $stat_cd, $insert_tm) + { + // 상태변경 TABLE INSERT + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $list = $this->getDetail($vr_sq); + + $sql = "INSERT INTO v2_chg_stat (vr_sq, stat_cd, insert_user, insert_tm) " . + "VALUES (?, ?, ?, ?) " . + "ON DUPLICATE KEY UPDATE " . + "vr_sq=VALUES(vr_sq), stat_cd=VALUES(stat_cd), insert_user=VALUES(insert_user), insert_tm=VALUES(insert_tm)"; + + $data = [ + $vr_sq, + $stat_cd, + $usr_sq, + $insert_tm + ]; + + $this->db->transStart(); + + $query = $this->db->query($sql, $data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + if (empty($return['error_number'])) { + // 로그를 남긴다. + if ($this->db->affectedRows() > 0) { + $changed = $this->whatIsChanged($list, $data, ''); + if (!empty($changed)) { + $this->saveChangedHistory($list['vr_sq'], $stat_cd, 'C9', $usr_id, $changed); + } + } + } + + $this->db->transComplete(); + + return $return; + } + + public function chgStatVrfc($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('v2_vrfc_req'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + return $return; + } + + public function chgStatFax($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('fax_imgs'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + $return['error_number'] = $this->db->error()['code']; + $return['error_message'] = $this->db->error()['message']; + + return $return; + } + + public function chgTryCnt($vr_sq, $try_cnt) + { //v2_vrfc_req try_cnt 값 변경. + $sql = "UPDATE v2_vrfc_req" . + " SET try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + public function insertChkList($vr_sq, $vrfc_type, $type, $code, $comment) + { //v2_check_list INSERT + + $usr_sq = session('usr_sq'); + + + $sql = "INSERT INTO v2_check_list" . + "(vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, ?, NOW())" . + " ON DUPLICATE KEY UPDATE" . + " vr_sq=values(vr_sq), vrfc_type=values(vrfc_type), type=values(type), code=values(code), comment=values(comment), insert_user=values(insert_user), insert_tm=values(insert_tm)"; + + $data = array( + $vr_sq, + $vrfc_type, + $type, + $code, + $comment, + $usr_sq + ); + + $this->db->query($sql, $data); + } + + /** + * 검증결과 전송 API를 위한 데이터 조회.. + */ + public function getDataConfirmAPI($vr_sq) + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, address4, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2 FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT type, code, comment, ownerNm, ownerBirth FROM v2_check_list WHERE vr_sq = ? AND vrfc_type = ? AND type LIKE CONCAT(vrfc_type, '%')"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm)); + + $atclNo = $row_vrfc_req['atcl_no']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger']; + $date = $row_confirm['date']; + $try_cnt = $row_vrfc_req['try_cnt']; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['ownerBirth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] === 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } else { + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } + } + + public function InsResChar($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET reg_charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function chkRegiTryCnt($atcl_vr_sq) + { + // 1차 검증인지 2차 검증인지 확인. + $builder = $this->db->table('v2_vrfc_req'); + $builder->select('reg_try_cnt'); + $builder->where('vr_sq', $atcl_vr_sq); + + $query = $builder->get(); + + $last_query = $this->db->getLastQuery(); + log_message('debug', $last_query); + + return $query->getRowArray(); + } + + /* 등기부등본 API 호출*/ + public function getDatacertAPI($vr_sq, $vrfc_type = '') + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm, owner_verifiable" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + if (!empty($vrfc_type)) { + $row_vrfc_req['vrfc_type'] = $vrfc_type; + } + + log_message('debug', $this->db->getLastQuery()); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2" . + " FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT a.type, a.code, a.comment, b.ownerNm, b.owner_birth" . + " FROM v2_check_list a " . + " INNER JOIN v2_article_info b ON a.vr_sq = b.vr_sq" . + " WHERE a.vr_sq = ? AND a.vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm)); + + $atclNo = $row_vrfc_req['atcl_no']; + $type = $row_vrfc_req['try_cnt']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger']; + $date = $row_confirm['date']; + $ownerVerifiable = ($row_vrfc_req['owner_verifiable'] === 'false') ? false : true; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['owner_birth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] === 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'ownerVerifiable' => $ownerVerifiable, + ]; + } else { + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'ownerVerifiable' => $ownerVerifiable, + ]; + } + } + + // 메모저장 + public function saveMemo($data) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_vrfc_req SET + memo = ? + WHERE vr_sq = ?"; + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '파일정보 저장 실패', + ]; + } + + $row = $this->getDetail($data[1]); + + $memo = "메모변경 : " . $row['memo'] . " => " . $data[0]; + $this->saveChangedHistory($data[1], $row['pre_stat_cd'], 'C19', $usr_id, $memo); + + return [ + 'success' => true + ]; + } + + public function saveApiErr($err_sq, $err_code, $err_nm, $err_time, $err_no, $err_server = '') + { + + $sql = "INSERT INTO err_api (err_sq, err_code, err_nm, err_time, err_no, err_server)" . + " VALUES (?, ?, ?, ?, ?, ?);"; + + $data = array( + $err_sq, + $err_code, + $err_nm, + $err_time, + $err_no, + $err_server + ); + $this->db->query($sql, $data); + } + + // 정보변경 이력 저장 + public function saveChangedHistory($vr_sq, $stat_cd, $chg_type, $usr_id, $memo) + { + $sql = "INSERT INTO v2_chg_history" . + " (vr_sq, stat_cd, chg_type, insert_id, insert_tm, memo)" . + " VALUES" . + " (?, ?, ?, ?, now(), ?)"; + + $data = [ + $vr_sq, + $stat_cd, + $chg_type, + $usr_id, + $memo + ]; + + $res = $this->db->query($sql, $data); + } + // 변경이력 조회 public function getHistory($id) { diff --git a/app/Models/v2/M708Model.php b/app/Models/v2/M708Model.php index e073e1e..8bffccf 100644 --- a/app/Models/v2/M708Model.php +++ b/app/Models/v2/M708Model.php @@ -1,6 +1,8 @@ getArticleInfo2($atcl_no, $vr_sq); - $this->saveFaxImgs($fax_sq, '2', $vr_sq, $atcl_no, $article['cpid'], $article['realtor_nm'], $article['stat_cd'], $current_tm, $article['address_code'], $article['address2']); + $this->saveFaxImgs($fax_sq, '2', $vr_sq, $atcl_no, $article['cpid'], $article['realtor_nm'], $article['stat_cd'], $current_tm, $article['address_code'], $article['address2'], 'Y'); return [ 'success' => true, @@ -1215,6 +1217,754 @@ class M708Model extends Model return $row; } + /** + * 매물정보와 FAX를 연결해 준다. + */ + public function saveArticleFAX($memo, $fax_sq, $vr_sq, $atcl_no, $work_type, $result_d11, $comment_d11, $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3, $stat_cd = '') + { + // 1. 매물정보 저장 fax_imgs + // 2.1 확인결과 저장 v2_confirms + // 2.2 확인정보 체크 v2_check_list + // 3.1 검증요청 상태변경 v2_vrfc_req + // 3.2 상태변경 저장 v2_chg_stat + // 4. 첨부파일 저장 v2_files + // 5. 변경이력 저장 v2_chg_history + // 6. kiso 전송하기 + + $this->db->transStart(); + + $article = NULL; + $current_tm = date('Y-m-d H:i:s'); + $insert_user = session('usr_sq'); + $insert_id = session('usr_id'); + $update_user = $insert_user; + + switch ($work_type) { + case '1': // 현장확인매물 + $article = $this->getArticleInfo1($atcl_no, $vr_sq); + + // 1. 매물정보 저장 fax_imgs + $this->saveFaxImgs($fax_sq, $work_type, $vr_sq, $atcl_no, $article['cpid'], $article['realtor_nm'], '35', $current_tm, $article['address_code'], $article['address2'], 'Y'); + + // 2.1 확인결과 저장 v2_confirm + + if ($result_d11 == '10000' && $fax_conf_yn_1 == 'Y' && $fax_conf_yn_2 == 'Y' && $fax_conf_yn_3 == 'Y') { + $success = TRUE; + } else { + $success = FALSE; + } + + $fax = $this->getDetail($fax_sq); + $this->saveV2Confirm($vr_sq, 'D', $success, '1', $fax['charger'], $current_tm, $insert_user, $update_user, $work_type); + + // 2.2 확인정보 체크 v2_check_list + // $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, + // $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3 + if (is_array($comment_d11)) { + $comment = implode('|', $comment_d11); + } else { + $comment = $comment_d11; + } + + $this->saveV2CheckList($vr_sq, 'D', 'D11', $result_d11, $comment, $insert_user); + + if ($fax_conf_yn_1 == 'Y') { + $fax_conf_yn_1 = '10000'; + } else { + $fax_conf_yn_1 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D12', $fax_conf_yn_1, $fax_conf_info_1, $insert_user); + + if ($fax_conf_yn_2 == 'Y') { + $fax_conf_yn_2 = '10000'; + } else { + $fax_conf_yn_2 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D13', $fax_conf_yn_2, $fax_conf_info_2, $insert_user); + + if ($fax_conf_yn_3 == 'Y') { + $fax_conf_yn_3 = '10000'; + } else { + $fax_conf_yn_3 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D14', $fax_conf_yn_3, $fax_conf_info_3, $insert_user); + + $this->saveV2ChgHistory($vr_sq, '35', 'C9', $insert_id, '현장확인 매물'); + + $faxModel = new FaxModel(); + $fax = $faxModel->selectFax($fax_sq); // fax 이미지 파일 가져오기 + + $receiptModel = new ReceiptModel(); + $receipt = $receiptModel->selectReceiptOne($vr_sq); // 매물정보 가져오기 + + // 40: 촬영, 70: 검수지연... 상태가 촬용 이전 또는 검수지연 상태일 경우에만 홍보확인서를 등록한다. + if (substr($receipt['rcpt_stat'], 0, 2) <= '40' || substr($receipt['rcpt_stat'], 0, 2) == '70') { + $arrImagePath = array( + '/home/confirms/test-admin.confirms.co.kr/upload/', + '/home/confirms/upload/', + '/home/www/admin.confirms.co.kr/upload/', + '/home/www/upload/', + '/image/confirms_upload/', + '/misc/image/confirms_upload/', + '/storage/web/admin.confirms.co.kr/src/upload/', + '/storage/web/admin.confirms.co.kr/upload/', + $_SERVER['DOCUMENT_ROOT'] . '/upload/', + ); + + $image_path = str_replace($arrImagePath, '/upload/', $fax['file_path']); + + $receiptModel->saveFaxImage($fax_sq, $receipt['rcpt_sq'], $receipt['rsrv_sq'], 'I1', $image_path, $fax['file_name'], '.jpg', $fax['img_size'], $fax['img_width'], $fax['img_height'], $receipt); + } + + + break; + + case '2': // 일반확인매물 + $article = $this->getArticleInfo2($atcl_no, $vr_sq); + + $try_cnt = $article['try_cnt']; // 0 -> 1 차시도, 1 -> 2 차시도 + $try_cnt = $try_cnt + 1; + + //memo 저장 + $res_memo = $this->saveMemo([$memo, $vr_sq]); + + $stat_cd = "30"; // 전화/서류 확인 중 + + if ($result_d11 == '10000' && $fax_conf_yn_1 == 'Y' && $fax_conf_yn_2 == 'Y' && $fax_conf_yn_3 == 'Y') { + $success = TRUE; // 전화/서류 확인 성공 + } else { + $success = FALSE; // 전화/서류 확인 실패 + } + + // 1. 매물정보 저장 fax_imgs + $r = $this->saveFaxImgs($fax_sq, $work_type, $article['vr_sq'], $article['atcl_no'], $article['cpid'], $article['realtor_nm'], $stat_cd, $current_tm, $article['address_code'], $article['address2'], 'Y'); + + // 2.1 확인결과 저장 v2_confirm + $fax = $this->getDetail($fax_sq); + $this->saveV2Confirm($vr_sq, 'D', $success, $try_cnt, $fax['charger'], $current_tm, $insert_user, $update_user, $work_type); + + // 2.2 확인정보 체크 v2_check_list + // $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, + // $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3 + if (is_array($comment_d11)) { + $comment = implode('|', $comment_d11); + } else { + $comment = $comment_d11; + } + + $this->saveV2CheckList($vr_sq, 'D', 'D11', $result_d11, $comment, $insert_user); + + if ($fax_conf_yn_1 == 'Y') { + $fax_conf_yn_1 = '10000'; + } else { + $fax_conf_yn_1 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D12', $fax_conf_yn_1, $fax_conf_info_1, $insert_user); + + if ($fax_conf_yn_2 == 'Y') { + $fax_conf_yn_2 = '10000'; + } else { + $fax_conf_yn_2 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D13', $fax_conf_yn_2, $fax_conf_info_2, $insert_user); + + if ($fax_conf_yn_3 == 'Y') { + $fax_conf_yn_3 = '10000'; + } else { + $fax_conf_yn_3 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D14', $fax_conf_yn_3, $fax_conf_info_3, $insert_user); + + if ($success == TRUE) { + $stat_cd = '35'; // 서류확인완료 + $this->saveV2ChgStat($vr_sq, $stat_cd, $insert_user); + + $rgbk_confirm = $this->getRgbk_confirm($vr_sq); + if (empty($rgbk_confirm)) { + // 등기부등본 확인이 불필요할 경우 + $stat_cd = '60'; // 등기부등본 확인 중 + $this->saveV2ChgStat($vr_sq, $stat_cd, $insert_user); + } else { + // 등기부등본 확인이 필요할 경우 + $stat_cd = '40'; // 등기부등본 확인 중 + $this->saveV2ChgStat($vr_sq, $stat_cd, $insert_user); + } + } else { + $stat_cd = '39'; // 서류확인 불일치 + $this->saveV2ChgStat($vr_sq, $stat_cd, $insert_user); + } + + // 3.1 검증요청 상태변경 v2_vrfc_req + $this->saveV2VrfcReq($vr_sq, $stat_cd); + + // 4. 첨부파일 저장 v2_files + // fax_sq, mid, file_name, file_path, thumbnail, img_width, img_height, img_size, img_sq, remark, work_type, atcl_no, cpid, realtor_nm, stat_cd, proc_tm, send_tm, address_code, address2, charger + $pos = strpos($fax['file_name'], '.'); + if ($pos === false) { + $file_ext = ''; + } else { + $file_ext = substr($fax['file_name'], $pos); + } + $this->saveV2Files($vr_sq, $fax['file_path'], $fax['file_name'], $file_ext, $fax['img_size'], $fax['img_width'], $fax['img_height'], $insert_user); + + // 5. 변경이력 저장 v2_chg_history + $memo = ''; + $this->saveV2ChgHistory($vr_sq, $stat_cd, 'C9', $insert_id, $memo); + + break; + + default: // 오류 + break; + } + } + + + public function saveHongBoFAX($fax_sq, $vr_sq, $atcl_no, $work_type, $send_yn, $result_d11, $comment_d11, $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3, $file_type, $stat_cd = '') + { + // 1. 매물정보 저장 fax_imgs + // 2.1 확인결과 저장 v2_confirms + // 2.2 확인정보 체크 v2_check_list + // 3.1 검증요청 상태변경 v2_vrfc_req + // 3.2 상태변경 저장 v2_chg_stat + // 4. 첨부파일 저장 v2_files + // 5. 변경이력 저장 v2_chg_history + // 6. kiso 전송하기 + + $this->db->transStart(); + + $article = NULL; + $current_tm = date('Y-m-d H:i:s'); + $insert_user = session('usr_sq'); + $insert_id = session('usr_id'); + $update_user = $insert_user; + + $article = $this->getArticleInfo1($atcl_no, $vr_sq); + + // 1. 매물정보 저장 fax_imgs + $this->saveFaxImgs($fax_sq, $work_type, $vr_sq, $atcl_no, $article['cpid'], $article['realtor_nm'], '35', $current_tm, $article['address_code'], $article['address2'], $send_yn); + + + // 2.1 확인결과 저장 v2_confirm + + if ($result_d11 == '10000' && $fax_conf_yn_1 == 'Y' && $fax_conf_yn_2 == 'Y' && $fax_conf_yn_3 == 'Y') { + $success = TRUE; + } else { + $success = FALSE; + } + + $fax = $this->getDetail($fax_sq); + $this->saveV2Confirm($vr_sq, 'D', $success, '1', $fax['charger'], $current_tm, $insert_user, $update_user, $work_type); + + // 2.2 확인정보 체크 v2_check_list +// $fax_conf_yn_1, $fax_conf_yn_2, $fax_conf_yn_3, +// $fax_conf_info_1, $fax_conf_info_2, $fax_conf_info_3 + if (is_array($comment_d11)) { + $comment = implode('|', $comment_d11); + } else { + $comment = $comment_d11; + } + + $this->saveV2CheckList($vr_sq, 'D', 'D11', $result_d11, $comment, $insert_user); + + if ($fax_conf_yn_1 == 'Y') { + $fax_conf_yn_1 = '10000'; + } else { + $fax_conf_yn_1 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D12', $fax_conf_yn_1, $fax_conf_info_1, $insert_user); + + if ($fax_conf_yn_2 == 'Y') { + $fax_conf_yn_2 = '10000'; + } else { + $fax_conf_yn_2 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D13', $fax_conf_yn_2, $fax_conf_info_2, $insert_user); + + if ($fax_conf_yn_3 == 'Y') { + $fax_conf_yn_3 = '10000'; + } else { + $fax_conf_yn_3 = '20000'; + } + $this->saveV2CheckList($vr_sq, 'D', 'D14', $fax_conf_yn_3, $fax_conf_info_3, $insert_user); + + $this->saveV2ChgHistory($vr_sq, '35', 'C9', $insert_id, '현장확인 매물'); + + $faxModel = new FaxModel(); + $fax = $faxModel->selectFax($fax_sq); // fax 이미지 파일 가져오기 + + $receiptModel = new ReceiptModel(); + $receipt = $receiptModel->selectReceiptOne($vr_sq); // 매물정보 가져오기 + + // 40: 촬영, 70: 검수지연... 상태가 촬용 이전 또는 검수지연 상태일 경우에만 홍보확인서를 등록한다. + if (substr($receipt['rcpt_stat'], 0, 2) <= '40' || substr($receipt['rcpt_stat'], 0, 2) == '70') { + $arrImagePath = array( + '/home/confirms/test-admin.confirms.co.kr/upload/', + '/home/confirms/upload/', + '/home/www/admin.confirms.co.kr/upload/', + '/home/www/upload/', + '/image/confirms_upload/', + '/misc/image/confirms_upload/', + '/storage/web/admin.confirms.co.kr/src/upload/', + '/storage/web/admin.confirms.co.kr/upload/', + $_SERVER['DOCUMENT_ROOT'] . '/upload/', + ); + + $image_path = str_replace($arrImagePath, '/upload/', $fax['file_path']); + + $receiptModel->saveFaxImage($fax_sq, $receipt['rcpt_sq'], $receipt['rsrv_sq'], $file_type, $image_path, $fax['file_name'], '.jpg', $fax['img_size'], $fax['img_width'], $fax['img_height'], $receipt); + } + + + $this->db->transComplete(); + $return = array( + 'code' => $this->db->_error_number(), + 'message' => $this->db->_error_message(), + ); + + return $return; + } + + + /** + * 검증결과 저장하기 + */ + public function saveV2Confirm($vr_sq, $vrfc_type, $success, $type, $charger, $date, $insert_user, $update_user, $work_type = '2') + { + $insert_user = session('usr_sq'); + $insert_id = session('usr_id'); + $update_user = $insert_user; + + // DB에서 변경되지 전 값을 읽어온다. + $sql = "select success, type, charger, date from v2_confirm" . + " where vr_sq = ?" . + " and vrfc_type = ?"; + $data = array( + $vr_sq, + $vrfc_type + ); + $query = $this->db->query($sql, $data); + $data_table = array(); + if ($query->getNumRows() > 0) { + $data_table = $query->getRowArray(); + } + + $date = str_replace(array(' ', '-', ':'), '', $date); + $sql = "INSERT INTO v2_confirm" . + " (vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type)" . + " VALUES" . + " (?, ?, ?, ?, ?, ?, ?, now(), ?, now(), ?)" . + " ON DUPLICATE KEY UPDATE" . + " success=values(success), type=values(type), charger=values(charger), date=values(date), update_user=values(update_user), update_tm=values(update_tm), work_type=values(work_type)"; + + $data = array( + 'vr_sq' => $vr_sq, + 'vrfc_type' => $vrfc_type, + 'success' => $success, + 'type' => $type, + 'charger' => $charger, + 'date' => $date, + 'insert_user' => $insert_user, + 'update_user' => $update_user, + 'work_type' => $work_type + ); + + $this->db->query($sql, $data); + + // 변경이력 저장하기 + if (!empty($data_table)) { + $this->saveV2ChgHistory($vr_sq, '30', 'C27', $insert_id, "검증결과 정보 저장"); + } + } + + /** + * 확인정보 저장하기 + */ + public function saveV2CheckList($vr_sq, $vrfc_type, $type, $code, $comment, $insert_user) + { + $insert_id = session('usr_id'); + + $sql = "select code, comment from v2_check_list" . + " where vr_sq = ?" . + " and type = ?"; + $data = array( + $vr_sq, + $type + ); + $query = $this->db->query($sql, $data); + $data_table = array(); + if ($query->getNumRows() > 0) { + $data_table = $query->getRowArray(); + } + + $sql = "INSERT INTO v2_check_list" . + " (vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . + " VALUES" . + " (?, ?, ?, ?, ?, ?, now())" . + " ON DUPLICATE KEY UPDATE" . + " vr_sq=values(vr_sq), vrfc_type=values(vrfc_type), type=values(type), code=values(code), comment=values(comment), insert_user=values(insert_user), insert_tm=values(insert_tm)"; + $data = array( + 'vr_sq' => $vr_sq, + 'vrfc_type' => $vrfc_type, + 'type' => $type, + 'code' => $code, + 'comment' => $comment, + 'insert_user' => $insert_user + ); + + $this->db->query($sql, $data); + + // 변경이력 저장하기 + if (!empty($data_table)) { + $this->saveV2ChgHistory($vr_sq, '30', 'C27', $insert_id, "확인정보 저장"); + } + } + + /** + * 상태변경시간 등록 + */ + public function saveV2ChgStat($vr_sq, $stat_cd, $insert_user) + { + $sql = "INSERT INTO v2_chg_stat" . + " (vr_sq, stat_cd, insert_user, insert_tm)" . + " VALUES" . + " (?, ?, ?, now())" . + " ON DUPLICATE KEY UPDATE" . + " insert_user=VALUES(insert_user), insert_tm=VALUES(insert_tm)"; + $data = array($vr_sq, $stat_cd, $insert_user); + $this->db->query($sql, $data); + log_message('debug', $this->db->getLastQuery()); + } + + /** + * 전송 후 FAX에 상태 및 전송시간을 저장한다. + */ + public function saveFaxImgsAfterSend($fax_sq, $vr_sq, $stat_cd, $send_tm = '') + { + if (empty($send_tm)) + $send_tm = date('Y-m-d H:i:s'); + + $data_fax_imgs = [ + 'stat_cd' => $stat_cd, + 'send_tm' => $send_tm, + ]; + + $builder = $this->db->table('fax_imgs'); + $builder->where('fax_sq', $fax_sq); + $builder->where('vr_sq', $vr_sq); + $builder->update($data_fax_imgs); + + log_message('debug', $this->db->getLastQuery()); + } + + /** + * 검증요청 v2_vrfc_req의 상태 stat_cd를 업데이트한다. + */ + public function saveV2VrfcReq($vr_sq, $stat_cd) + { + + $sql = "update v2_vrfc_req" . + " set stat_cd = ?" . + " where vr_sq = ?"; + $data = array($stat_cd, $vr_sq); + + $res = $this->db->query($sql, $data); + log_message('debug', $this->db->getLastQuery()); + log_message('debug', $res); + } + + /** + * 홍보확인서를 매물정보에 등록한다. + */ + public function saveV2Files($vr_sq, $file_path, $file_name, $file_ext, $file_size, $img_width, $img_height, $insert_user) + { + $arrImagePath = array( + '/home/confirms/test-admin.confirms.co.kr/upload/', + '/home/confirms/upload/', + '/home/www/admin.confirms.co.kr/upload/', + '/home/www/upload/', + '/image/confirms_upload/', + '/misc/image/confirms_upload/', + '/storage/web/admin.confirms.co.kr/src/upload/', + '/storage/web/admin.confirms.co.kr/upload/', + $_SERVER['DOCUMENT_ROOT'] . '/upload/', + ); + + $file_path = str_replace($arrImagePath, '/upload/', $file_path); + $file_type = '1'; // 홍보확인서 + + + // 1. 홍보확이서 등록여부 확인 + $sql = "SELECT count(*) file_cnt FROM v2_files" . + " WHERE vr_sq = ?" . + " AND file_type = ?" . + " AND file_path = ?" . + " AND file_name = ?" . + " AND use_yn = 'Y'"; + $data = array( + $vr_sq, + $file_type, + $file_path, + $file_name + ); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + if (empty($row['file_cnt'])) { + // 2. 다른파일로 등록된 경우를 위해서 업데이트 + $sql = "UPDATE v2_files SET use_yn = 'N' WHERE vr_sq = ? AND file_type = ?"; + $data = array($vr_sq, $file_type); + $this->db->query($sql, $data); + + // 3. 등록 + $sql = "INSERT INTO v2_files " . + " (vr_sq, use_yn, file_type, view_odr, file_path, file_name, file_ext, file_size, img_width, img_height, insert_user, insert_tm)" . + " VALUES" . + " (?, 'Y', ?, '1', ?, ?, ?, ?, ?, ?, ?, NOW())"; + + $data = array($vr_sq, $file_type, $file_path, $file_name, $file_ext, $file_size, $img_width, $img_height, $insert_user); + $this->db->query($sql, $data); + } + } + + /** + * 검증결과 전송 API를 위한 데이터 조회.. + */ + public function getDataConfirmAPI($vr_sq) + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $query->getRowArray(); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, address4, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2 FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + // 확인정보 + $sql = "SELECT type, code, comment, ownerNm, ownerBirth FROM v2_check_list WHERE vr_sq = ? AND vrfc_type = ? AND type LIKE CONCAT(vrfc_type, '%')"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + $atclNo = $row_vrfc_req['atcl_no']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger']; + $date = $row_confirm['date']; + $try_cnt = $row_vrfc_req['try_cnt']; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['ownerBirth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] == 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } + + return [ + 'atclNo' => $atclNo, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'try_cnt' => $try_cnt, + ]; + } + + /** + * 담당자를 지정해준다. + */ + public function InsCharger($vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + + /** + * 상태를 변경한다. + */ + public function saveChangeStep($fax_sq, $vr_sq, $stat_cd) + { + $insert_user = session('usr_sq'); + $insert_id = session('usr_id'); + + $this->db->transStart(); + + // 1. 검증요청 상태변경 v2_vrfc_req + $this->saveV2VrfcReq($vr_sq, $stat_cd); + + // 2. 상태변경 저장 v2_chg_stat + $this->saveV2ChgStat($vr_sq, $stat_cd, $insert_user); + + // 3. 변경이력 저장 v2_chg_history + $this->saveV2ChgHistory($vr_sq, $stat_cd, 'C9', $insert_id, ""); + + // 4. FAX에 최종 저장시 상태값 저장 + $this->saveFaxImgsAfterSend($fax_sq, $vr_sq, $stat_cd, $send_tm = ''); + + $this->db->transComplete(); + + $return = array( + 'code' => $this->db->_error_number(), + 'message' => $this->db->_error_message(), + ); + + return $return; + } + + /** + * 값을 실패횟수 값을 증가시킨다. + */ + public function increseTryCnt($vr_sq) + { + $sql = "update v2_vrfc_req set try_cnt = ifnull(try_cnt,0) +1 where vr_sq = ?"; + $data = array($vr_sq); + $this->db->query($sql, $data); + } + + public function getI8Cnt($rsrv_sq) + { + $sql = "SELECT COUNT(img_sq) cnt" . + " FROM result_imgs" . + " WHERE rsrv_sq = ?" . + " AND img_type = 'I8'" . + " AND use_yn = 'Y'"; + $data = array($rsrv_sq); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + + public function get_rsrv_sq($rcpt_sq) + { + $sql = "SELECT rsrv_sq " . + " FROM result" . + " WHERE rcpt_sq = ?"; + $data = array($rcpt_sq); + $query = $this->db->query($sql, $data); + + return $query->getRowArray(); + } + + // 메모저장 + public function saveMemo($data) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_vrfc_req SET + memo = ? + WHERE vr_sq = ?"; + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '파일정보 저장 실패', + ]; + } + + $row = $this->getDetail($data[1]); + + $memo = "메모변경 : " . $row['memo'] . " => " . $data[0]; + $this->saveChangedHistory($data[1], $row['pre_stat_cd'], 'C19', $usr_id, $memo); + + return [ + 'success' => true + ]; + } + + /** + * 변경이력 저장하기 + */ + public function saveV2ChgHistory($vr_sq, $stat_cd, $chg_type, $insert_id, $memo) + { + $sql = "INSERT INTO v2_chg_history" . + " (vr_sq, stat_cd, chg_type, insert_id, insert_tm, memo)" . + " VALUES" . + " (?, ?, ?, ?, now(), ?)"; + + $data = array($vr_sq, $stat_cd, $chg_type, $insert_id, $memo); + $this->db->query($sql, $data); + log_message('debug', $this->db->getLastQuery()); + } + // 변경내용 저장 public function saveChangedHistory($rcpt_sq, $rcpt_stat, $changed_type, $usr_id, $remark) diff --git a/app/Models/v2/M712Model.php b/app/Models/v2/M712Model.php index 39118aa..69d460c 100644 --- a/app/Models/v2/M712Model.php +++ b/app/Models/v2/M712Model.php @@ -906,6 +906,504 @@ class M712Model extends Model } } + /* 현재 상태 확인 */ + public function chkStat($vr_sq) + { + $sql = "SELECT stat_cd FROM v2_vrfc_req WHERE vr_sq = ?"; + $data = array( + $vr_sq + ); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + + //1차 검증인지 2차 검증인지 확인. + public function chkRegiTryCnt($atcl_vr_sq) + { + $sql = "SELECT reg_try_cnt FROM v2_vrfc_req WHERE vr_sq = ?"; + $query = $this->db->query($sql, [$atcl_vr_sq]); + return $query->getRowArray(); + } + + //검증결과 table에 있는지 확인. + public function chkConfirm($atcl_vr_sq, $reg_yn) + { + $builder = $this->db->table('v2_confirm a'); + $builder->select('a.vr_sq'); + $builder->where('vr_sq', $atcl_vr_sq); + + if ($reg_yn) { + $builder->where('vrfc_type', $reg_yn); + } + + $query = $builder->get(); + return $query->getNumRows(); + } + + public function getUpdateFailTime($vr_sq) + { + $sql = "select vr_sq, stat_cd, insert_user, insert_tm " . + "from v2_chg_stat " . + "where vr_sq = ? and stat_cd = '49' " . + "order by insert_tm desc " . + "limit 1"; + $data = array($vr_sq); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + return $row; + } + + //v2_confirm INSERT + public function insertConfirm($vr_sq, $vrfc_type, $success, $type, $usr_id = '', $usr_sq = '') + { + + if (empty($usr_sq)) + $usr_sq = session('usr_sq'); + if (empty($usr_id)) + $usr_id = session('usr_id'); + + $sql = "INSERT INTO v2_confirm" . + "(vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, '" . date('YmdHis') . "', ?, NOW(), ?, NOW()) " . + " ON DUPLICATE KEY UPDATE" . + " success=values(success), type=values(type), charger=values(charger), date=values(date) + , update_user=values(update_user), update_tm=values(update_tm)"; + + $data = array( + $vr_sq, + $vrfc_type, + $success, + $type, + $usr_id, + $usr_sq, + $usr_sq + ); + + $this->db->query($sql, $data); + } + + public function updateConfirm($vr_sq, $vrfc_type, $success) + { + $data = [ + 'success' => $success, + ]; + + $builder = $this->db->table('v2_confirm'); + $builder->where('vr_sq', $vr_sq); + $builder->where('vrfc_type', $vrfc_type); + $builder->update($data); + + return [ + 'error_number' => $this->db->error()['code'], + 'error_message' => $this->db->error()['message'] + ]; + } + + public function InsResChar($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET reg_charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + //echo $this->db->last_query(); + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function add_cert_uncnfrm_status($vr_sq, $cert_uncnfrm_status) + { + $sql = "UPDATE v2_article_info_etc" . + " SET cert_uncnfrm_status = ?" . + " WHERE vr_sq = ?"; + $data = array( + $cert_uncnfrm_status, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + public function insertChkList($vr_sq, $vrfc_type, $type, $code, $comment) + { //v2_check_list INSERT + + $usr_sq = session('usr_sq'); + + $sql = "INSERT INTO v2_check_list" . + "(vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, ?, NOW())" . + " ON DUPLICATE KEY UPDATE" . + " vr_sq=values(vr_sq), vrfc_type=values(vrfc_type), type=values(type), code=values(code), comment=values(comment), insert_user=values(insert_user), insert_tm=values(insert_tm)"; + + $data = array( + $vr_sq, + $vrfc_type, + $type, + $code, + $comment, + $usr_sq + ); + + + $this->db->query($sql, $data); + + } + + /** + * update updatedocument_cert_method + */ + public function updatedocument_cert_method($vr_sq, $document_cert_method) + { + $sql = "UPDATE v2_article_info_etc SET " . + " document_cert_method = ? " . + " WHERE vr_sq = ? "; + + $document_cert_method = json_encode($document_cert_method, JSON_UNESCAPED_UNICODE); + if ($document_cert_method == 'false') { + $document_cert_method = NULL; + } + $data = array( + $document_cert_method, + $vr_sq + ); + $this->db->query($sql, $data); + $s = $this->db->getLastQuery(); + log_message('debug', "====updatedocument_cert_method:712====" . $s); + } + + public function update_owner_verifiable($vr_sq, $owner_verifiable) + { + $sql = "UPDATE v2_vrfc_req" . + " SET owner_verifiable = ?" . + " WHERE vr_sq = ?"; + $data = array( + $owner_verifiable, + $vr_sq + ); + + $this->db->query($sql, $data); + $s = $this->db->getLastQuery(); + log_message('debug', "====update_owner_verifiable:712====" . $s); + } + + /* 등기부등본 API 호출*/ + public function getDatacertAPI($vr_sq, $vrfc_type = '') + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm, owner_verifiable" . + " FROM v2_vrfc_req where vr_sq = ?"; + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + if (!empty($vrfc_type)) { + $row_vrfc_req['vrfc_type'] = $vrfc_type; + } + + log_message('debug', 'getDatacertApi_query => ' . $this->db->getLastQuery()); + log_message('debug', 'getDatacertApi_result => ' . json_encode($row_vrfc_req)); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2, vrfc_type_sub" . + " FROM v2_article_info where vr_sq = ?"; + $query = $this->db->query($sql, [$vr_sq]); + $row_article_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2" . + " FROM v2_modify_info where vr_sq = ?"; + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm where vr_sq = ? and vrfc_type = ?"; + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT a.type, a.code, a.comment, b.ownerNm, b.owner_birth" . + " FROM v2_check_list a " . + " INNER JOIN v2_article_info b on a.vr_sq = b.vr_sq" . + " WHERE a.vr_sq = ? and a.vrfc_type = ?"; + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm ?? [])); + + $atclNo = $row_vrfc_req['atcl_no']; + $type = $row_vrfc_req['try_cnt']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger'] ?? ''; + $date = $row_confirm['date'] ?? ''; + + switch ($row_vrfc_req['owner_verifiable']) { + case "1": + case "true": + $ownerVerifiable = true; + break; + default: + $ownerVerifiable = false; + break; + } + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['owner_birth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] == 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'vrfcType' => $row_article_info['vrfc_type_sub'], + 'ownerVerifiable' => $ownerVerifiable, + ]; + } else { + return [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'vrfcType' => $row_article_info['vrfc_type_sub'], + 'ownerVerifiable' => $ownerVerifiable, + ]; + } + } + + public function get_send_yn($type) + { + $sql = "SELECT stop_yn + FROM v2_stop_api_chg_stat + WHERE TYPE = ? + ORDER BY pk DESC + LIMIT 1"; + $date = array( + $type + ); + $query = $this->db->query($sql, $date); + $return = $query->getRowArray(); + + return $return; + } + + public function insert_v2_stop_api_save_info($atcl_no, $vr_sq, $type, $fax_sq) + { + $sql = "INSERT INTO v2_stop_api_save_info(atcl_no,vr_sq,type,status,stop_dt,fax_sq)" . + " VALUE(?,?,?,'stop',now(),?)"; + $date = array( + $atcl_no, + $vr_sq, + $type, + $fax_sq + ); + $this->db->query($sql, $date); + } + + /** + * 712 소유자 확인 을 위한 쿼리 + */ + public function getOwnerVerifiable($atcl_no) + { + $sql = "select * , + case + when owner_verifiable = 'true' then '1' + when owner_verifiable = '1' then '1' + when owner_verifiable = 'false' then '0' + when owner_verifiable = '0' then '0' + ELSE null + END AS OwnerVerifiable_change + from v2_vrfc_req where atcl_no = ? "; + $data = array( + $atcl_no + ); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + return $row; + } + + public function chgStat($vr_sq, $stat_cd, $insert_tm) + { //상태변경 TABLE INSERT + + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $list = $this->get_detail($vr_sq); + + $sql = "INSERT INTO v2_chg_stat (vr_sq, stat_cd, insert_user, insert_tm)" . + "VALUES (?, ?, ?, ?)" . + "ON DUPLICATE KEY " . + "UPDATE vr_sq=VALUES(vr_sq), stat_cd=VALUES(stat_cd), insert_user=VALUES(insert_user), insert_tm=VALUES(insert_tm)"; + + $data = array( + 'vr_sq' => $vr_sq, + 'stat_cd' => $stat_cd, + 'usr_sq' => $usr_sq, + 'insert_tm' => $insert_tm + ); + + $this->db->transStart(); + $res = $this->db->query($sql, $data); + + $return['error_number'] = $this->db->_error_number(); + $return['error_message'] = $this->db->_error_message(); + + if (empty($return['error_number'])) { + //로그를 남긴다. + if ($this->db->affected_rows() > 0) { + if (!empty($changed)) { + $this->saveChangedHistory($list['data']['vr_sq'], $stat_cd, 'C9', $usr_id, "상태변경 저장"); //검증결과 변동사항 HISTORY + } + } + } + $this->db->transComplete(); + } + + public function chgStatVrfc($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('v2_vrfc_req'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + return [ + 'error_number' => $this->db->error()['code'], + 'error_message' => $this->db->error()['message'] + ]; + } + + public function chgStatFax($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('fax_imgs'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + return [ + 'error_number' => $this->db->error()['code'], + 'error_message' => $this->db->error()['message'] + ]; + } + + //v2_vrfc_req try_cnt 값 변경. + public function chgRegiTryCnt($vr_sq, $try_cnt) + { + $sql = "UPDATE v2_vrfc_req" . + " SET reg_try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $res = $this->db->query($sql, $data); + } + + public function resetTelConf($vr_sq) + { + $sql = "update v2_check_list " . + "set code = '' " . + "where type in ('T11', 'T12', 'T13', 'T14') " . + "and vr_sq = ?"; + + $data = array($vr_sq); + $this->db->query($sql, $data); + } + + // 메모저장 + public function saveMemo($data) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_vrfc_req SET + memo = ? + WHERE vr_sq = ?"; + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '파일정보 저장 실패', + ]; + } + + $row = $this->getDetail($data[1]); + + $memo = "메모변경 : " . $row['memo'] . " => " . $data[0]; + $this->saveChangedHistory($data[1], $row['pre_stat_cd'], 'C19', $usr_id, $memo); + + return [ + 'success' => true + ]; + } // 정보변경 이력 저장 public function saveChangedHistory($vr_sq, $stat_cd, $chg_type, $usr_id, $memo) diff --git a/app/Models/v2/M713Model.php b/app/Models/v2/M713Model.php index 850e0b6..36c7e91 100644 --- a/app/Models/v2/M713Model.php +++ b/app/Models/v2/M713Model.php @@ -930,6 +930,535 @@ class M713Model extends Model } } + /* 현재 상태 확인 */ + public function chkStat($vr_sq) + { + $sql = "SELECT stat_cd FROM v2_vrfc_req WHERE vr_sq = ?"; + $data = array( + $vr_sq + ); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + + public function chkTryCnt($atcl_vr_sq) + { + // 1차 검증인지 2차 검증인지 확인. + $sql = "SELECT a.try_cnt FROM v2_vrfc_req a WHERE vr_sq = ?"; + $query = $this->db->query($sql, [$atcl_vr_sq]); + return $query->getRowArray(); + } + + public function chkRegiTryCnt($atcl_vr_sq) + { + $sql = "SELECT a.reg_try_cnt FROM v2_vrfc_req a WHERE vr_sq = ?"; + $query = $this->db->query($sql, [$atcl_vr_sq]); + return $query->getRowArray(); + } + + public function chkConfirm($atcl_vr_sq, $reg_yn) + { + // 검증결과 table에 있는지 확인. + $builder = $this->db->table('v2_confirm a'); + $builder->select('a.vr_sq'); + $builder->where('vr_sq', $atcl_vr_sq); + + if ($reg_yn) { + $builder->where('vrfc_type', $reg_yn); // 등기부등본 정보 확인시 + } + + $query = $builder->get(); + $result = $query->getNumRows(); + + return $result; + } + + public function getUpdateFailTime($vr_sq) + { + $sql = "select vr_sq, stat_cd, insert_user, insert_tm " . + "from v2_chg_stat " . + "where vr_sq = ? and stat_cd = '49' " . + "order by insert_tm desc " . + "limit 1"; + $data = array($vr_sq); + $query = $this->db->query($sql, $data); + $row = $query->getRowArray(); + + return $row; + } + + public function insertConfirm($vr_sq, $vrfc_type, $success, $type) + { //v2_confirm INSERT + + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $sql = "INSERT INTO v2_confirm" . + "(vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, '" . date('YmdHis') . "', ?, NOW(), ?, NOW())"; + + $data = array( + $vr_sq, + $vrfc_type, + $success, + $type, + $usr_id, + $usr_sq, + $usr_sq + ); + + $res = $this->db->query($sql, $data); + } + + public function updateConfirm($vr_sq, $vrfc_type, $success): void + { + $data = [ + 'success' => $success + ]; + + $builder = $this->db->table('v2_confirm'); + $builder->where('vr_sq', $vr_sq); + $builder->where('vrfc_type', $vrfc_type); + $builder->update($data); + } + + public function InsResChar($atcl_vr_sq) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_article_info" . + " SET reg_charger = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $usr_id, + $atcl_vr_sq + ); + //echo $this->db->last_query(); + $res = $this->db->query($sql, $data); + $log_v = $this->db->getLastQuery(); + log_message('debug', $log_v); + } + + public function add_cert_uncnfrm_status($vr_sq, $cert_uncnfrm_status) + { + $sql = "UPDATE v2_article_info_etc" . + " SET cert_uncnfrm_status = ?" . + " WHERE vr_sq = ?"; + $data = array( + $cert_uncnfrm_status, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + public function insertChkList($vr_sq, $vrfc_type, $type, $code, $comment) + { //v2_check_list INSERT + + $usr_sq = session('usr_sq'); + + $sql = "INSERT INTO v2_check_list" . + "(vr_sq, vrfc_type, type, code, comment, insert_user, insert_tm)" . + "VALUES" . + "(?, ?, ?, ?, ?, ?, NOW())" . + " ON DUPLICATE KEY UPDATE" . + " vr_sq=values(vr_sq), vrfc_type=values(vrfc_type), type=values(type), code=values(code), comment=values(comment), insert_user=values(insert_user), insert_tm=values(insert_tm)"; + + $data = array( + $vr_sq, + $vrfc_type, + $type, + $code, + $comment, + $usr_sq + ); + + + $res = $this->db->query($sql, $data); + } + + public function update_owner_verifiable($vr_sq, $owner_verifiable) + { + $sql = "UPDATE v2_vrfc_req" . + " SET owner_verifiable = ?" . + " WHERE vr_sq = ?"; + $data = array( + $owner_verifiable, + $vr_sq + ); + + $this->db->query($sql, $data); + $s = $this->db->getLastQuery(); + log_message('debug', "====update_owner_verifiable====" . $s); + } + + /* 등기부등본 API 호출*/ + public function getDatacertAPI($vr_sq, $vrfc_type = '') + { + // 요청정보 + $sql = "SELECT vr_sq, atcl_no, step, cpid, cp_atcl_id, trade_type, realtor_nm, realtor_tel_no, seller_tel_no, vrfc_type, rgbk_confirm, req_type, rdate, stat_cd, try_cnt, insert_user, insert_tm, owner_verifiable" . + " FROM v2_vrfc_req WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_vrfc_req = $query->getRowArray(); + + if (!empty($vrfc_type)) { + $row_vrfc_req['vrfc_type'] = $vrfc_type; + } + + log_message('debug', 'getDatacertApi_query => ' . $this->db->getLastQuery()); + log_message('debug', 'getDatacertApi_result => ' . json_encode($row_vrfc_req)); + + // 매물정보 + $sql = "SELECT vr_sq, atcl_no, cpid, cp_atcl_id, rlet_type_cd, trade_type, address_code, address1, address2, address3, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sise, floor, rdate, seller_tel_no, seller_nm, realtor_nm, realtor_tel_no, hscp_no, hscp_nm, ptp_no, ptp_nm, charger, req_price_yn, reg_charger, dept1_sq, dept2_sq, reg_dept1_sq, reg_dept2_sq, floor2, vrfc_type_sub" . + " FROM v2_article_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_article_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 수정정보 + $sql = "SELECT vr_sq, bild_nm, rm_no, floor, address_code, address2, address3, trade_type, deal_amt, wrrnt_amt, lease_amt, isale_amt, prem_amt, sply_spc, excls_spc, tot_spc, grnd_spc, bldg_spc, hscp_no, hscp_nm, ptp_no, ptp_nm, modify_yn, floor2" . + " FROM v2_modify_info WHERE vr_sq = ?"; + + $query = $this->db->query($sql, [$vr_sq]); + $row_modify_info = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 검증결과 + $sql = "SELECT vr_sq, vrfc_type, success, type, charger, date, insert_user, insert_tm, update_user, update_tm, work_type" . + " FROM v2_confirm WHERE vr_sq = ? AND vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $row_confirm = $query->getRowArray(); + + log_message('debug', $this->db->getLastQuery()); + + // 확인정보 + $sql = "SELECT a.type, a.code, a.comment, b.ownerNm, b.owner_birth" . + " FROM v2_check_list a" . + " INNER JOIN v2_article_info b ON a.vr_sq = b.vr_sq" . + " WHERE a.vr_sq = ? AND a.vrfc_type = ?"; + + $query = $this->db->query($sql, [$vr_sq, $row_vrfc_req['vrfc_type']]); + $res_check_list = $query->getResultArray(); + + log_message('debug', $this->db->getLastQuery()); + + log_message('debug', implode(', ', $row_confirm ?? [])); + + $atclNo = $row_vrfc_req['atcl_no']; + $type = $row_vrfc_req['try_cnt']; + $success = empty($row_confirm['success']) ? false : true; + $charger = $row_confirm['charger'] ?? ''; + $date = $row_confirm['date'] ?? ''; + + $ownerVerifiable = match ($row_vrfc_req['owner_verifiable']) { + "1", "true" => true, + default => false, + }; + + $checkList = []; + foreach ($res_check_list as $row) { + $checkList[] = [ + 'type' => $row['type'], + 'code' => $row['code'], + 'comment' => $row['comment'], + 'ownerNm' => $row['ownerNm'], + 'ownerBirth' => $row['owner_birth'], + ]; + } + + $modifyInfo = []; + if ($row_modify_info['modify_yn'] == 'Y') { + if (!empty($row_modify_info['hscp_no'])) { + // 공동주택 + $modifyInfo = [ + 'hscpNo' => $row_modify_info['hscp_no'], + 'ptpNo' => $row_modify_info['ptp_no'], + 'bildNm' => $row_modify_info['address2'], + 'rmNo' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'isaleAmt' => $row_modify_info['isale_amt'], + 'premAmt' => $row_modify_info['prem_amt'], + 'floor' => $row_modify_info['floor'], + ]; + } else { + // 비공동주택 + $modifyInfo = [ + 'addressCode' => $row_modify_info['address_code'], + 'address2' => $row_modify_info['address2'], + 'address3' => $row_modify_info['address3'], + 'tradeType' => $row_modify_info['trade_type'], + 'dealAmt' => $row_modify_info['deal_amt'], + 'wrrntAmt' => $row_modify_info['wrrnt_amt'], + 'leaseAmt' => $row_modify_info['lease_amt'], + 'splySpc' => $row_modify_info['sply_spc'], + 'exclsSpc' => $row_modify_info['excls_spc'], + 'totSpc' => $row_modify_info['tot_spc'], + 'grndSpc' => $row_modify_info['grnd_spc'], + 'bldgSpc' => $row_modify_info['bldg_spc'], + 'floor' => $row_modify_info['floor'], + 'floor2' => $row_modify_info['floor2'], + ]; + } + + $return_data = [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'modifyInfo' => $modifyInfo, + 'date' => $date, + 'vrfcType' => $row_article_info['vrfc_type_sub'], + 'ownerVerifiable' => $ownerVerifiable, + ]; + + log_message('debug', "713 getDatacertAPI_1 {$atclNo} ::: " . json_encode($return_data) . PHP_EOL); + + return $return_data; + } else { + $return_data = [ + 'atclNo' => $atclNo, + 'type' => $type, + 'success' => $success, + 'checkList' => $checkList, + 'charger' => $charger, + 'date' => $date, + 'vrfcType' => $row_article_info['vrfc_type_sub'], + 'ownerVerifiable' => $ownerVerifiable, + ]; + + log_message('debug', "713 getDatacertAPI_2 {$atclNo} ::: " . json_encode($return_data) . PHP_EOL); + + return $return_data; + } + } + + public function chgStat($vr_sq, $stat_cd, $insert_tm) + { + // 상태변경 TABLE INSERT + $usr_sq = session('usr_sq'); + $usr_id = session('usr_id'); + + $list = $this->getDetail($vr_sq); + + $sql = "INSERT INTO v2_chg_stat (vr_sq, stat_cd, insert_user, insert_tm)" . + "VALUES (?, ?, ?, ?)" . + "ON DUPLICATE KEY " . + "UPDATE vr_sq=VALUES(vr_sq), stat_cd=VALUES(stat_cd), insert_user=VALUES(insert_user), insert_tm=VALUES(insert_tm)"; + + $data = [ + $vr_sq, + $stat_cd, + $usr_sq, + $insert_tm + ]; + + $this->db->transStart(); + + $this->db->query($sql, $data); + + $error = $this->db->error(); + $return = [ + 'error_number' => $error['code'], + 'error_message' => $error['message'] + ]; + + if (empty($return['error_number'])) { + // 로그를 남긴다. + if ($this->db->affectedRows() > 0) { + // $changed = $this->what_is_changed($list, $data, ''); + // if (!empty($changed)) { + $this->saveChangedHistory($list['vr_sq'], $stat_cd, 'C9', $usr_id, "상태변경 저장"); + // } + } + } + + $this->db->transComplete(); + + return $return; + } + + public function chgStatVrfc($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('v2_vrfc_req'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $error = $this->db->error(); + return [ + 'error_number' => $error['code'], + 'error_message' => $error['message'] + ]; + } + + public function chgStatFax($vr_sq, $stat_cd) + { + $data = ['stat_cd' => $stat_cd]; + + $builder = $this->db->table('fax_imgs'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $error = $this->db->error(); + return [ + 'error_number' => $error['code'], + 'error_message' => $error['message'] + ]; + } + + public function updateStat($vr_sq, $reg_status) + { + $data = ['reg_status' => $reg_status]; + + $builder = $this->db->table('v2_article_info'); + $builder->where('vr_sq', $vr_sq); + $builder->update($data); + + $error = $this->db->error(); + return [ + 'error' => [ + 'code' => $error['code'], + 'message' => $error['message'] + ] + ]; + } + + public function chgRegiTryCnt($vr_sq, $try_cnt) + { //v2_vrfc_req try_cnt 값 변경. + $sql = "UPDATE v2_vrfc_req" . + " SET reg_try_cnt = ?" . + " WHERE vr_sq = ?"; + + $data = array( + $try_cnt, + $vr_sq + ); + + $this->db->query($sql, $data); + } + + public function modify_info($vr_sq, $owner_birth, $address2, $address2a, $address2b, $address3, $address4, $address_code, $hscp_no, $hscp_nm) + { + $this->db->transStart(); + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_modify_info + SET address2 = ? + ,address2a = ? + ,address2b = ? + ,address3 = ? + ,address4 = ? + ,address_code = ? + ,hscp_no = ? + ,hscp_nm = ? + ,modify_yn = 'Y' + WHERE vr_sq = ?"; + $data = array( + $address2, + $address2a, + $address2b, + $address3, + $address4, + $address_code, + $hscp_no, + $hscp_nm, + $vr_sq + ); + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '저장 실패', + ]; + } + + $sql2 = "UPDATE v2_article_info + SET owner_birth = ? + ,address2 = ? + ,address3 = ? + ,address_code = ? + ,hscp_no = ? + ,hscp_nm = ? + WHERE vr_sq = ?"; + $data2 = array( + $owner_birth, + $address2, + $address3, + $address_code, + $hscp_no, + $hscp_nm, + $vr_sq + ); + + if ($this->db->query($sql2, $data2) === false) { + return [ + 'success' => false, + 'msg' => '저장 실패', + ]; + } + + $sql3 = "UPDATE v2_article_info_etc + SET address2a = ? + ,address2b = ? + WHERE vr_sq = ?"; + $data3 = array( + $address2a, + $address2b, + $vr_sq + ); + + if ($this->db->query($sql3, $data) === false) { + return [ + 'success' => false, + 'msg' => '저장 실패', + ]; + } + + $this->saveChangedHistory($vr_sq, '40', 'C34', $usr_id, '생년월일 정보 변경'); + + $this->db->transComplete(); + return [ + 'success' => true, + ]; + } + + // 메모저장 + public function saveMemo($data) + { + $usr_id = session('usr_id'); + + $sql = "UPDATE v2_vrfc_req SET + memo = ? + WHERE vr_sq = ?"; + + if ($this->db->query($sql, $data) === false) { + return [ + 'success' => false, + 'msg' => '파일정보 저장 실패', + ]; + } + + $row = $this->getDetail($data[1]); + + $memo = "메모변경 : " . $row['memo'] . " => " . $data[0]; + $this->saveChangedHistory($data[1], $row['pre_stat_cd'], 'C19', $usr_id, $memo); + + return [ + 'success' => true + ]; + } // 정보변경 이력 저장 public function saveChangedHistory($vr_sq, $stat_cd, $chg_type, $usr_id, $memo) diff --git a/app/Models/webfax/FaxModel.php b/app/Models/webfax/FaxModel.php index a6681ba..ff4b9b0 100644 --- a/app/Models/webfax/FaxModel.php +++ b/app/Models/webfax/FaxModel.php @@ -5,6 +5,19 @@ use CodeIgnier\Model; class FaxModel extends Model { + /** + * FAX 내용중 하나만 가져오기 + */ + public function selectFax($faxSq) + { + $sql = "SELECT mid, caller_no, recv_time, fax_sq, file_path, file_name, thumbnail, img_width, img_height, img_size" . + " FROM fax_imgs" . + " WHERE fax_sq = ?"; + $data = array($faxSq); + $query = $this->db->query($sql, $data); + return $query->getRowArray(); + } + public function selectFaxListNotExistsThumb() { helper('cron'); diff --git a/app/Views/layouts/sidebar.php b/app/Views/layouts/sidebar.php index 1ef0df0..c172883 100644 --- a/app/Views/layouts/sidebar.php +++ b/app/Views/layouts/sidebar.php @@ -39,13 +39,13 @@ $serverIp = $_SERVER['SERVER_ADDR'] ?? ''; // 개발 서버 - $devServers = ['192.168.200.8', '192.168.10.231']; + $devServers = ['192.168.200.8', '192.168.10.231', '172.18.0.5']; // 도커 테스트 서버 $dockerServers = ['172.18.0.2']; // 테스트 서버 - $testServers = ['192.168.200.9', '192.168.10.237', '175.126.191.182']; + $testServers = ['192.168.200.9', '192.168.10.237', '175.126.191.182', '192.168.10.243']; // 운영 서버 IP 매핑 $prodServers = [ @@ -58,7 +58,7 @@ if (in_array($serverIp, $devServers, true)) { // 개발 - echo ""; + echo "개발"; } elseif (in_array($serverIp, $dockerServers, true)) { // 도커 @@ -80,8 +80,6 @@ echo "{$serverName}"; } - - ?> diff --git a/app/Views/pages/article/dept/lists.php b/app/Views/pages/article/dept/lists.php index 6bb83f2..d8cf303 100644 --- a/app/Views/pages/article/dept/lists.php +++ b/app/Views/pages/article/dept/lists.php @@ -718,7 +718,7 @@ $usr_nm = session('usr_nm'); const rcpt_key = rowData.rcpt_key; - location.href = "/" + rcpt_key; + window.open("/" + rcpt_key, '_blank'); }); $(document).on('change', '#chkAll', function () { diff --git a/app/Views/pages/article/lists.php b/app/Views/pages/article/lists.php index 8f5c769..3544011 100644 --- a/app/Views/pages/article/lists.php +++ b/app/Views/pages/article/lists.php @@ -749,7 +749,7 @@ if (!rowData) return; const id = rowData.rcpt_no; - location.href = "/" + id; + window.open("/" + id, '_blank'); }); $('#btnSearch').on('click', function () { diff --git a/app/Views/pages/article/receipt/detail.php b/app/Views/pages/article/receipt/detail.php index aeb29b6..36ec4dc 100644 --- a/app/Views/pages/article/receipt/detail.php +++ b/app/Views/pages/article/receipt/detail.php @@ -1,5 +1,6 @@ extend('layouts/main') ?> @@ -53,84 +54,93 @@ $usr_level = session('usr_level'); -
-
+
+ + + + + + + + + + + + + + +
+
-
-
- - - - - - - - - - - -
- 매물ID : - - - CP ID : - -
+
+
+ + + + + + + + + + + +
+ 매물ID : + + + CP ID : + +
+
+ +
+
공인 중개사 정보
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + +
중개사ID중개사명
대표전화담당자전화
검증방식 + 현장V2" + : "현장"; ?> + 연락가능전화 + +
+ + +
+
+ +
-
-
공인 중개사 정보
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
중개사ID중개사명
대표전화담당자전화
검증방식 - 현장V2" - : "현장"; ?> - 연락가능전화 - -
- - -
-
- -
-
- - - - - - - - +
매물 정보
@@ -197,7 +207,7 @@ $usr_level = session('usr_level');
+ value="" size="50" disabled="disabled" /> @@ -237,7 +247,17 @@ $usr_level = session('usr_level'); 단지명 - + + + + 가격 평형 - + + + + + + + + + " size="8" maxlength="3" disabled="disabled" style="width: 100px;" /> + / - - + + + + + + +
+ 전용면적 값 : +       + 공급면적 값 : +
+
+ + + / + + + + + + + + + + + + + + + + + + + + + + + +
+ 면적확인파일1
+ 방 - + + + 면적확인파일2 @@ -411,7 +545,8 @@ $usr_level = session('usr_level'); No Image
- + @@ -436,12 +571,12 @@ $usr_level = session('usr_level');
- - @@ -451,11 +586,13 @@ $usr_level = session('usr_level'); - - @@ -492,7 +629,7 @@ $usr_level = session('usr_level');
- + @@ -614,9 +751,10 @@ $usr_level = session('usr_level'); @@ -645,7 +790,16 @@ $usr_level = session('usr_level');
@@ -780,7 +934,7 @@ $usr_level = session('usr_level');
- +
@@ -2045,49 +2199,50 @@ $usr_level = session('usr_level');
- - -
-
-
정보변경 이력
-
- - - - - - - - - - - - - - - - - + + +
+
+
정보변경 이력
+
+
진행상태변경내용처리자(ID)처리일시세부내용
- - - - - - - - - -
+ + + + + + + + + + + + + + + + + - -
진행상태변경내용처리자(ID)처리일시세부내용
+ + + + + + + + + +
+ +
-
+ - + section('modals') ?> + + - + endSection() ?> \ No newline at end of file diff --git a/app/Views/pages/v2/m706/lists.php b/app/Views/pages/v2/m706/lists.php index d5735c0..bd68712 100644 --- a/app/Views/pages/v2/m706/lists.php +++ b/app/Views/pages/v2/m706/lists.php @@ -481,7 +481,7 @@ if (!rowData) return; const vr_sq = rowData.vr_sq; - location.href = "/" + vr_sq; + window.open("/" + vr_sq, '_blank'); }); $('#btnSearch').on('click', function () { diff --git a/app/Views/pages/v2/m708/detail.php b/app/Views/pages/v2/m708/detail.php index 9356e76..e518cda 100644 --- a/app/Views/pages/v2/m708/detail.php +++ b/app/Views/pages/v2/m708/detail.php @@ -41,9 +41,9 @@ $usr_level = session('usr_level');
-
+ - + @@ -174,7 +174,7 @@ $usr_level = session('usr_level'); style="max-width: 320px;"> @@ -358,7 +358,7 @@ $usr_level = session('usr_level'); + value="" disabled>
-
-
-
+ + + + + + + + + +
+
+
-
-
-
- - - - - +
+
+
+ + + + + + + - - - - - - - + + + + + +
-
-
-
- - - - - +
+
+
+ + + + - - - - + + + -
-
- 등기부등본 - 보기    - - - - +
-
'; - } else { - echo '
'; - if (empty($arrRegist)) { - echo 'Image'; +
+
'; } else { - foreach ($arrRegist as $row) { - $img_path = $row['file_path'] . $row['file_name']; - echo '' . - 'Image' . - ''; + echo '
'; + if (empty($arrRegist)) { + echo 'Image'; + } else { + foreach ($arrRegist as $row) { + $img_path = $row['file_path'] . $row['file_name']; + echo '' . + 'Image' . + ''; + } } + echo '

'; } - echo '
'; - } - } else { //등기api이미지 저장여부가 N - if (strtolower($file_pdf) == 'pdf') { - echo '
'; - } else { - echo '
'; - if (empty($arr_cert_register)) { - echo 'Image'; + } else { //등기api이미지 저장여부가 N + if (strtolower($file_pdf) == 'pdf') { + echo '
'; } else { - foreach ($arr_cert_register as $img_path) { - echo '' . - 'Image' . - ''; + echo '
'; + if (empty($arr_cert_register)) { + echo 'Image'; + } else { + foreach ($arr_cert_register as $img_path) { + echo '' . + 'Image' . + ''; + } } + echo '

'; } - echo '

'; } - } - } else { - if (empty($regist)) { - $regi_img_path = '/plugin/img/photo.gif'; } else { - if (empty($regist['file_path']) || empty($regist['file_name'])) { + if (empty($regist)) { $regi_img_path = '/plugin/img/photo.gif'; } else { - if ($regist['cloud_upload_yn'] == 'Y') { - $regi_img_path = NCLOUD_OBJECT_STORAGE_URL . $regist['file_path'] . $regist['file_name']; + if (empty($regist['file_path']) || empty($regist['file_name'])) { + $regi_img_path = '/plugin/img/photo.gif'; } else { - // 로컬에 저장된 이미지 - $regi_img_path = $regist['file_path'] . $regist['file_name']; + if ($regist['cloud_upload_yn'] == 'Y') { + $regi_img_path = NCLOUD_OBJECT_STORAGE_URL . $regist['file_path'] . $regist['file_name']; + } else { + // 로컬에 저장된 이미지 + $regi_img_path = $regist['file_path'] . $regist['file_name']; + } } } + ?> + +
+
+ 등기부등본 + 보기    + +
-
-
-
- 기본 정보 -
- +
+
+
+
+ 기본 정보 +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + +
매물번호 +
+ +
+
CP ID + +
현재 상태 + + +
등기부등본
불일치횟수
참고용 파일 + Image'; + } elseif ($file_ext == 'zip') { + echo 'Image'; + } else { + echo 'Image'; + } + } + endif; + } + + if (!empty($data['referenceFileUrl'])) { + $arrRefrenceFileUrl = json_decode($data['referenceFileUrl']); + if (!empty($arrRefrenceFileUrl)): + foreach ($arrRefrenceFileUrl as $rows) { + $file_ext = trim(parseurl($rows)); + if ($file_ext == 'pdf') { + echo 'Image'; + } elseif ($file_ext == 'zip') { + echo "\"Image\""; + } else { + echo "\"Image\""; + } + } + endif; + } + ?> +
+
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
매물번호 -
- -
-
CP ID - -
현재 상태 - - -
등기부등본
불일치횟수
참고용 파일 - Image'; - } elseif ($file_ext == 'zip') { - echo 'Image'; - } else { - echo 'Image'; - } - } - endif; - } - - if (!empty($data['referenceFileUrl'])) { - $arrRefrenceFileUrl = json_decode($data['referenceFileUrl']); - if (!empty($arrRefrenceFileUrl)): - foreach ($arrRefrenceFileUrl as $rows) { - $file_ext = trim(parseurl($rows)); - if ($file_ext == 'pdf') { - echo 'Image'; - } elseif ($file_ext == 'zip') { - echo "\"Image\""; - } else { - echo "\"Image\""; - } - } - endif; - } - ?> -
-
- - - -
-
- 매물 정보 -
-
- - - - - - - - - - - - - - - - - - - - - - - + +
+
+ 매물 정보 +
+
+
등록일시 - -
등기부 고유번호
의뢰인(매도자) - -
매물구분 - -
+ + + + + - + - - + + + + + - - + - - + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + - + - - - - - - - - - - - - - - - - - - - + echo $th; + ?> + - - - - - - - - - - - - - - - - - - - - - - + @@ -565,460 +542,512 @@ function parseurl($url) - - + + - + + + + + + + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
지역구분등록일시 - +
사용승인일 - + 등기부 고유번호
의뢰인(매도자) +
승인종료일 - + 매물구분 +
단지 정보지역구분 - - - - - - - - - - - - - - - - - - - - - -
단지명 - -
단지주소 -
상세주소 - -
사용승인일단지 총 동수
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
단지명단지타입명 -
소재법정동번호 - -
소재 주소(전체) -
주소(광역시/도)주소(시군구)
주소(읍면동)소재 동이하 상세주소
단지 총 세대수단지 총 동수
- +
사용승인일 + +
승인종료일 + +
단지 정보 + + + + + + + + + + + + + + + + + + + + +
단지명 + +
단지주소 + +
상세주소 + +
사용승인일 + 단지 총 동수 +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
단지명 + 단지타입명 +
소재법정동번호 + +
소재 주소(전체) + +
주소(광역시/도)주소(시군구)
주소(읍면동)소재 동이하 상세주소
단지 총 세대수 + 단지 총 동수 +
+ +
리 주소 + +
상세주소 + + + +
+ + + +
+ + + +
+
기타주소 + +
리 주소거래구분/가격 - + / + 만원 + / + 만원 (월)
상세주소평형 - - - -
- - - -
- - - -
+
기타주소 - -
거래구분/가격 - / - 만원 - / - 만원 (월) -
평형 - -
- + - - -
공급면적 - - - +
전용면적 - - - -
단지명 - - - ※ 특이단지 - -
재개발구역명 - -
사업단계설명 - -
공급면적 - +
전용면적 - +
대지면적단지명 - - - + + + ※ 특이단지 + +
재개발구역명 +
연면적사업단계설명 - - - +
대지면적 - -
건축면적 - -
가주소 여부 - > - - -
소유자 구분 - -
검증참고란 - -
미등기 검증요청 여부 - -
건축물대장
면적 검증요청
- -
-
-
- - -
-
- 확인 정보 -
-
- - - - - - - - - - - - - - - - - - - - - - + + + + + + + - - - - + elseif ( + ($data['rlet_type_cd'] == 'C03' and $data['trade_type_cd'] == 'A1') || + $data['rlet_type_cd'] == 'C04' || + ($data['rlet_type_cd'] == 'C05' and $data['trade_type_cd'] == 'A1') || + $data['rlet_type_cd'] == 'D03' || + $data['rlet_type_cd'] == 'D04' || + $data['rlet_type_cd'] == 'E01' || + $data['rlet_type_cd'] == 'E02' || + $data['rlet_type_cd'] == 'Z00' + ): ?> + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - + // 소유자 구분 + switch ($data['ownerTypeCode']): + case "0": + $strOwnerTypeCode = "개인"; + break; + case "1": + $strOwnerTypeCode = "법인"; + break; + case "2": + $strOwnerTypeCode = "외국인"; + break; + case "3": + $strOwnerTypeCode = "위임장"; + break; + endswitch; + ?> - + - - - - - - - - - - - - - - - - - - - - - - - - -
확인담당자 - -       - -
등기부등본
미확인여부
상세
- - - - $value) { - if ($cnt % 2 == 0 && $cnt != 0) { - echo ''; - } - - - ?> - - - - - - 0) { ?> - - - -
-
- - -
-
-
서류확인내용 - $method): ?> + + +
공급면적 + + + +
전용면적 + + + +
대지면적 + + + +
연면적 + + + +
대지면적 + +
건축면적 + +
확인내용 - -
매물주소 - - -
의뢰인정보 - - -
실소유주 확인가주소 여부 - />확인  - />미확인 + > + +
매도자명 - -
소유자명 - -
소유자명 확인 - - > - 일치 - - > - 불일치 -
메모 - -
등기부등본 확인 - - - - - - - 소유자명 확인       - - - - - - - - - - - - - - - - -
-
- -
- - -
-
- 기타 정보 -
-
- - - - - - - - - + + + + + + + + + + + + + + + + + +
소유자명 + 소유자 구분 + +
검증참고란 + +
미등기 검증요청 여부 + +
건축물대장
면적 검증요청
+ +
+
+
+ + +
+
+ 확인 정보 +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
확인담당자 + +       + +
등기부등본
미확인여부
상세
+ + + + $value) { + if ($cnt % 2 == 0 && $cnt != 0) { + echo ''; + } + + + ?> + + + + + + 0) { ?> + + + +
+
+ + +
+
+
서류확인내용 + $method): ?> + + + +
확인내용 + +
매물주소 + + +
의뢰인정보 + + +
실소유주 확인 + />확인  + />미확인 +
매도자명 + +
소유자명 + +
소유자명 확인 + + > + 일치 + + > + 불일치 +
메모 + +
등기부등본 확인 + + + + + + + 소유자명 확인       + + + + + + + + + + + + + + + + +
+
+ +
+ + +
+
+ 기타 정보 +
+
+ + + + + + + + + + + + + + > + + - - - > - - - - -
소유자명 + +
소유자 전화번호
소유자 전화번호 - -
-
-
- -
-
- = '35' && $data['stat_cd'] != '39' && $data['stat_cd'] != '49'): - ?> - - - - +
+
-
- - - +
+
+ = '35' && $data['stat_cd'] != '39' && $data['stat_cd'] != '49'): + ?> + + + + +
+ +
+ + + +
+
-
-
+ section('modals') ?>
-
-
-
+
+ + + + + + + + +
+
+
-
-
-
- - - - - +
+
+
+ + + + + + + - - - - 법인매물 - - 법인 - + + 법인매물 + + 법인 + +
-
-
-
- - - - - +
+
+
+ + + + - - - + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
-
'; - } else { - echo '
'; - if (empty($arrRegist)) { - echo 'Image'; +
+
'; } else { - foreach ($arrRegist as $row) { - $img_path = $row['file_path'] . $row['file_name']; - echo '' . - 'Image' . - ''; + echo '
'; + if (empty($arrRegist)) { + echo 'Image'; + } else { + foreach ($arrRegist as $row) { + $img_path = $row['file_path'] . $row['file_name']; + echo '' . + 'Image' . + ''; + } } + echo '

'; } - echo '
'; - } - } else { //등기api이미지 저장여부가 N - if (strtolower($file_pdf) == 'pdf') { - echo '
'; - } else { - echo '
'; - if (empty($arr_cert_register)) { - echo 'Image'; + } else { //등기api이미지 저장여부가 N + if (strtolower($file_pdf) == 'pdf') { + echo '
'; } else { - foreach ($arr_cert_register as $img_path) { - echo '' . - 'Image' . - ''; + echo '
'; + if (empty($arr_cert_register)) { + echo 'Image'; + } else { + foreach ($arr_cert_register as $img_path) { + echo '' . + 'Image' . + ''; + } } + echo '

'; } - echo '

'; } - } - } else { - if (empty($regist)) { - $regi_img_path = '/plugin/img/photo.gif'; } else { - if (empty($regist['file_path']) || empty($regist['file_name'])) { + if (empty($regist)) { $regi_img_path = '/plugin/img/photo.gif'; } else { - if ($regist['cloud_upload_yn'] == 'Y') { - $regi_img_path = NCLOUD_OBJECT_STORAGE_URL . $regist['file_path'] . $regist['file_name']; + if (empty($regist['file_path']) || empty($regist['file_name'])) { + $regi_img_path = '/plugin/img/photo.gif'; } else { - // 로컬에 저장된 이미지 - $regi_img_path = $regist['file_path'] . $regist['file_name']; + if ($regist['cloud_upload_yn'] == 'Y') { + $regi_img_path = NCLOUD_OBJECT_STORAGE_URL . $regist['file_path'] . $regist['file_name']; + } else { + // 로컬에 저장된 이미지 + $regi_img_path = $regist['file_path'] . $regist['file_name']; + } } } + ?> + +
+
+ 등기부등본 + 보기    + - -
-
- 등기부등본 - 보기    - -
-
-
-
- 기본 정보 -
- +
+
+
+
+ 기본 정보 +
+ +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + +
매물번호 +
+ +
+
CP ID + + + +
현재 상태 + + + +
등기부등본
불일치횟수
+ +
+
-
- - - - - - - - - - - - - - - - - - - - - - - -
매물번호 -
- -
-
CP ID - - - -
현재 상태 - - - -
등기부등본
불일치횟수
- -
-
- - - -
-
- 매물 정보 -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - + +
+
+ 매물 정보 +
+
+
등록일시 - -
등기부 고유번호
의뢰인(매도자) - -
검증방식 - -
매물구분 - -
+ + + + + - + - - + + + + + - - + - - + + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + - - + + + + + @@ -537,443 +504,498 @@ function parseurl($url) - - + + - + + + + + + + - + - - - - - - - - - - - - - - - - - - - - - - - - -
지역구분등록일시 - +
사용승인일 - + 등기부 고유번호
의뢰인(매도자) +
승인종료일 - + 검증방식 +
매물구분 + +
단지 정보지역구분 - - - - - - - - - - - - - - - - - - - - - -
단지명 - -
단지주소 -
상세주소 - -
사용승인일단지 총 동수
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
단지명단지타입명 -
소재법정동번호 - -
소재 주소(전체) -
주소(광역시/도)주소(시군구)
주소(읍면동)소재 동이하 상세주소
단지 총 세대수단지 총 동수
- +
사용승인일 + +
승인종료일 + +
단지 정보 + + + + + + + + + + + + + + + + + + + + +
단지명 + +
단지주소 +
상세주소 + +
사용승인일단지 총 동수
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
단지명단지타입명 +
소재법정동번호 + +
소재 주소(전체) +
주소(광역시/도)주소(시군구)
주소(읍면동)소재 동이하 상세주소
단지 총 세대수단지 총 동수
+ +
리 주소 + +
상세주소 + + + +
+ + + +
+ + + +
+
기타주소 + +
리 주소거래구분/가격 - -
상세주소 - - - -
- - - -
- - - -
-
기타주소 - -
거래구분/가격 - - - - - - / - 만원 - / - 만원 (월) -
평형 - -
- - - -
공급면적 - - - -
전용면적 - - - -
단지명 - - - ※ 특이단지 + + + + -
재개발구역명 - + / + 만원 + / + 만원 (월)
사업단계설명평형 - +
+ + + +
공급면적 - +
전용면적 - +
대지면적단지명 - - - + + + ※ 특이단지 + +
재개발구역명 +
연면적사업단계설명 - - - +
대지면적 - -
건축면적 - -
가주소 여부 - > - - -
미등기 검증요청 여부 - -
건축물대장
면적 검증요청
- -
-
-
- - -
-
- 확인 정보 -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + - - - -
확인담당자 - -       - -
등기부등본
미확인여부
상세
- - - - $value) { - if ($cnt % 2 == 0 && $cnt != 0) { - echo ''; - } - - - ?> - - - - - - 0) { ?> - - - -
-
- - -
-
-
확인내용 - -
매물주소 - - -
의뢰인정보 - - -
실소유주 확인 - />확인  - />미확인 -
매도자명 - -
소유자명 - -
메모 - -
등기부등본 확인 - - - - - - - 소유자명 확인       - - - - - - - - - - - - + - - - +
공급면적 + + + +
전용면적 + + + +
+
대지면적 + + + +
연면적 + + + +
대지면적 + +
건축면적 + +
가주소 여부 + > + + +
미등기 검증요청 여부 + +
건축물대장
면적 검증요청
+ +
+
-
- -
-
- 기타 정보 + +
+
+ 확인 정보 +
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
확인담당자 + +       + +
등기부등본
미확인여부
상세
+ + + + $value) { + if ($cnt % 2 == 0 && $cnt != 0) { + echo ''; + } + + + ?> + + + + + + 0) { ?> + + + +
+
+ + +
+
+
확인내용 + +
매물주소 + + +
의뢰인정보 + + +
실소유주 확인 + />확인  + />미확인 +
매도자명 + +
소유자명 + +
메모 + +
등기부등본 확인 + + + + + + + 소유자명 확인       + + + + + + + + + + + + + + + + +
+
-
- - - - - - - - - - - - - - - - - + + +
생년월일 - - -
추출주소 - -
지역구분 - - + + + + + + + + + + + + + + + + - - - - - - - - + + + + + + + + + + + + - - - - - - -
생년월일 + + + +
추출주소 + +
지역구분 + + + + + - - - -
리 주소 - -
상세주소 - - +
리 주소 + +
상세주소 + + + + + + + + " + size="60" disabled="disabled" + style="color:#ff0000; font-weight:bold;"> +
기타주소 + - - - - - - " - size="60" disabled="disabled" - style="color:#ff0000; font-weight:bold;"> -
기타주소 - -
- - - -
-
- = 35 && $data['stat_cd'] != '39' && $data['stat_cd'] != '49'): - ?> - - - +
+
-
- - - - +
+
+ = 35 && $data['stat_cd'] != '39' && $data['stat_cd'] != '49'): + ?> + + + +
+ +
+ + + + +
-
+ section('modals') ?> @@ -1538,6 +1560,329 @@ function parseurl($url) }); } + function save_info_onclick() { + var ownerNm = $('#ownerNm').val(); + var owner_birth = $('#owner_birth').val(); + var address2 = $('#address2').val(); + var address2a = $('#address2a').val(); + var address2b = $('#address2b').val(); + var address3 = $('#address3').val(); + var address4 = $('#address4').val(); + + var dong = $('#dong').val(); + var hscp_no = $('#hscp_no option:selected').val(); + var hscp_nm = $('#hscp_no option:selected').text(); + + swal.fire({ + text: "수정 하시겠습니까?", + type: "warning", + showCancelButton: true, + confirmButtonText: "예", + cancelButtonText: "아니오", + closeOnConfirm: false, + closeOnCancel: true, + confirmButtonColor: "#3085d6", + cancelButtonColor: "#d33", + }).then((result) => { + if (result.isConfirmed) { + + $.ajax({ + url: '/m713/m713a/saveModify', + contentType: 'application/x-www-form-urlencoded;charset=UTF-8', + method: 'POST', + data: { + 'vr_sq': '', + 'ownerNm': ownerNm, + 'owner_birth': owner_birth, + 'address2': address2, + 'address2a': address2a, + 'address2b': address2b, + 'address3': address3, + 'address4': address4, + 'dong': dong, + 'hscp_no': hscp_no, + 'hscp_nm': hscp_nm, + }, + beforeSend: function () { + blockUI.blockPage({ + message: tpl + }) + }, + complete: function () { + blockUI.unblockPage() + }, + error: function (xhr, error, thrown) { + blockUI.unblockPage() + var msg = ""; + if (xhr.responseText != null) { + msg = xhr.responseText + } else { + msg = "잠시후 다시 시도해 주세요." + } + + Swal.fire({ + title: msg, + icon: "error" + }) + }, + success: function (result) { + if (result.code == '0') { + + if (result.res != null) { + swal + .fire({ + title: '정상 처리되었습니다.', + icon: "success" + }); + location.reload(); + } else { + Swal.fire({ + title: result.msg ?? '저장에 실패했습니다.', + icon: "error" + }); + } + + } else { + Swal.fire({ + title: result.msg, + icon: "error" + }) + } + } + }); + } + }); + } + + // 등기부등본 저장 + var click = true; + function saveRegi() { + var frm = document.rcptFrm; + var atcl_vrtc_type = frm.atcl_vrtc_type.value; + var chk_hscp_no = frm.chk_hscp_no.value; + var trade_type = ""; + var vrfc_type = ""; + + var chkBox = $('input:checkbox[name=img_chk_chk]').is(':checked'); //등기소, 리얼탑 열람, 리얼탑 기열람, 열람 + + var cert_register = ""; //등기부등본 url이 있을경우 + var filePdf = ''; + + if (vrfc_type == "M") { + // 검증방식이 모바일이면 파일체크는 하지않고 열람인지 등기소, 리얼탑 열람, 리얼탑 기열람인지만 체크함 + if (chkBox == false) { + Swal.fire({ + title: "등기부등본 확인 상태를 선택해주세요.", + icon: "warning" + }); + return false; + } + } else { + if (chk_hscp_no == "" && trade_type == "A1") { + // 비공동매물이고 거래방식이 매매일 경우에 파일 체크를 하지 않고 열람인지 등기소, 리얼탑 열람, 리얼탑 기열람인지만 체크함. + if (chkBox == false) { + Swal.fire({ + title: "등기부등본 확인 상태를 선택해주세요.", + icon: "warning" + }); + return false; + } + } else { + if (cert_register == "") { //등기부등본url이 없을경우 + // 파일이 없으며 등기부등본 이미지 파일없음이 아니면 파일을 선택하도록 함. + if (frm.regi_file.value == "" && reg_file_yn == false) { + if (frm.img_chk_chk.checked == false) { + Swal.fire({ + title: "파일을 선택해주세요", + icon: "warning" + }); + return false; + } + } else { + if (chkBox == false) { + Swal.fire({ + title: "등기부등본 확인 상태를 선택해주세요.", + icon: "warning" + }); + return false; + } + } + } else { + if (chkBox == false) { + Swal.fire({ + title: "등기부등본 확인 상태를 선택해주세요.", + icon: "warning" + }); + return false; + } + } + } + } + + var type = ""; + if ((type == 'D2') && (filePdf == 'pdf' || filePdf == 'PDF')) { //홍보v2고, pdf로 업로드됐을때 + var chk = $("#img_chk_chk4").prop("checked"); + if (chk == false) { + Swal.fire({ + title: "소유자명 확인이 필요합니다", + icon: "warning" + }); + click = true; + return false; + } + } + + var radio_val = $('input:radio[name=owner_verifiable]').is(':checked'); + if (type == 'D2' && radio_val == false) { //홍보확인서v2고 실소유주 확인 선택안되었을때 + Swal.fire({ + title: "실소유주 확인 결과를 선택해주세요", + icon: "warning" + }); + click = true; + return false; + } + + if (frm.reg_conf_yn_2.value == "") { + Swal.fire({ + title: "매물주소 정보확인 결과를 선택해주세요", + icon: "warning" + }); + frm.reg_conf_yn_2.focus(); + click = true; + return false; + } + + if (frm.reg_conf_yn_3.value == "") { + Swal.fire({ + title: "의뢰인정보 확인 결과를 선택해주세요", + icon: "warning" + }); + frm.reg_conf_yn_3.focus(); + click = true; + return false; + } + + if (frm.reg_conf_yn_2.value == "20000") { + if (frm.reg_conf_yn_info_2.value == "") { + Swal.fire({ + title: "매물주소 불일치에 대한 상세내용을 작성해주세요", + icon: "warning" + }); + frm.reg_conf_yn_info_2.focus(); + click = true; + return false; + } + } + + if (frm.reg_conf_yn_3.value == "20000") { + if (frm.reg_conf_yn_info_3.value == "") { + Swal.fire({ + title: "의뢰인정보 불일치에 대한 상세내용을 작성해주세요", + icon: "warning" + }); + frm.reg_conf_yn_info_3.focus(); + click = true; + return false; + } + } + + // 불일치가 하나라도 있으면 + if ((type == 'M1' || type == 'O1') && (frm.reg_conf_yn_2.value == "20000" || frm.reg_conf_yn_3.value == "20000")) { + if (!$("input:checkbox[name='cert_uncnfrm_status[]']").is(":checked")) { + Swal.fire({ + title: "등기부등본 미확인여부 상세를 체크해주세요", + icon: "warning" + }); + frm.cert_uncnfrm_status.focus(); + click = true; + return false; + } + + // 다중체크된거 가져오기 + var arr_uncnfrm_status = ""; + var cnt = 0; + $('input:checkbox[name="cert_uncnfrm_status[]"]').each(function () { + if ($(this).is(':checked')) { + if (cnt == 0) { + arr_uncnfrm_status += $(this).val(); + } else { + arr_uncnfrm_status += "|" + ($(this).val()); + } + cnt++; + } + }); + $('#arr_uncnfrm_status').val(arr_uncnfrm_status); + } + + swal.fire({ + text: "저장하시겠습니까?", + type: "warning", + showCancelButton: true, + confirmButtonText: "예", + cancelButtonText: "아니오", + closeOnConfirm: false, + closeOnCancel: true, + confirmButtonColor: "#3085d6", + cancelButtonColor: "#d33", + }).then((result) => { + if (result.isConfirmed) { + + $.ajax({ + url: '/m713/m713a/saveRegi', + contentType: 'application/x-www-form-urlencoded;charset=UTF-8', + method: 'POST', + data: $("#rcptFrm").serialize(), + beforeSend: function () { + blockUI.blockPage({ + message: tpl + }) + }, + complete: function () { + blockUI.unblockPage() + }, + error: function (xhr, error, thrown) { + blockUI.unblockPage() + var msg = ""; + if (xhr.responseText != null) { + msg = xhr.responseText + } else { + msg = "잠시후 다시 시도해 주세요." + } + + Swal.fire({ + title: msg, + icon: "error" + }) + }, + success: function (result) { + if (result.code == '0') { + + if (result.res != null) { + swal + .fire({ + title: '정상 처리되었습니다.', + icon: "success" + }); + location.reload(); + } else { + Swal.fire({ + title: result.msg ?? '저장에 실패했습니다.', + icon: "error" + }); + } + + } else { + Swal.fire({ + title: result.msg, + icon: "error" + }) + } + } + }); + } + }); + } + //다음매물확인 function nextRegi() { swal.fire({ diff --git a/app/Views/pages/v2/m713/lists.php b/app/Views/pages/v2/m713/lists.php index 5e4f501..5c98611 100644 --- a/app/Views/pages/v2/m713/lists.php +++ b/app/Views/pages/v2/m713/lists.php @@ -570,7 +570,7 @@ if (!rowData) return; const vr_sq = rowData.vr_sq; - location.href = "/" + vr_sq; + window.open("/" + vr_sq, '_blank'); }); $('#btnSearch').on('click', function () {