-
-| 매물ID : = $data['atcl_no'] ?> - | -CP ID : = $data['cpid'] ?> | -현재 상태 - : = $data['pre_stat'] ?> | -
| - | - | - |
공인 중개사 정보
-| 중개사명 | -= $data['realtor_nm'] ?> | -대표전화 | -= $data['realtor_tel_no'] ?> | -
|---|
diff --git a/app/Config/Routes.php b/app/Config/Routes.php
index 9854374..37c5006 100644
--- a/app/Config/Routes.php
+++ b/app/Config/Routes.php
@@ -176,10 +176,19 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout
*/
$routes->get('m701a/getResultList', 'M701::getResultList');
$routes->get('m701a/excel', 'M701::excel');
- $routes->post('m701a/chgArticleStatus', 'M701::chgArticleStatus'); // 상태정보변경
+ $routes->post('m701a/changePrice', 'M701::changePrice'); // 가격수정
+ $routes->post('m701a/chgArticleStatus', 'M701::chgArticleStatus'); // 상태정보변경
+ $routes->post('m701a/modifyInfo', 'M701::modifyInfo'); // 정보수정
$routes->post('m701a/saveMemo', 'M701::saveMemo'); // 메모저장
+ $routes->post('m701a/saveDocu', 'M701::saveDocu'); // 서류 저장
+ $routes->post('m701a/saveTel', 'M701::saveTel'); // 전화정보 저장
+ $routes->post('m701a/saveRegi', 'M701::saveRegi'); // 등기부등본 저장
+ $routes->post('m701a/saveFinalRegi', 'M701::saveFinalRegi'); // 검증최종실패 처리
+
+ $routes->post('m701a/uploadFile', 'M701::uploadFile'); // 파일업로드
+
});
/**
@@ -220,6 +229,7 @@ $routes->group('', ['namespace' => 'App\Controllers\V2'], static function ($rout
$routes->post('m703a/saveRequestMessage', 'M703::saveRequestMessage'); // 중개사요청사항저장
$routes->post('m703a/saveResult', 'M703::saveResult'); // 결과저장
+
/**
* 홍보확인서 확인
*/
diff --git a/app/Controllers/V2/M701.php b/app/Controllers/V2/M701.php
index 86002f9..966e784 100644
--- a/app/Controllers/V2/M701.php
+++ b/app/Controllers/V2/M701.php
@@ -2,8 +2,15 @@
namespace App\Controllers\V2;
use App\Controllers\BaseController;
+use App\Libraries\FormValidation;
+use App\Libraries\MyUpload;
+use App\Libraries\NaverApiClient;
use App\Models\common\CodeModel;
+use App\Models\results\M415Model;
use App\Models\v2\M701Model;
+use App\Models\v2\M710Model;
+use Exception;
+use function PHPUnit\Framework\throwException;
class M701 extends BaseController
{
@@ -121,6 +128,7 @@ class M701 extends BaseController
public function detail($id = null)
{
$id = (int) $id;
+ $naver = new NaverApiClient();
if ($id <= 0) {
throw \CodeIgniter\Exceptions\PageNotFoundException::forPageNotFound();
@@ -137,6 +145,34 @@ class M701 extends BaseController
$history = $this->model->getHistory($id);
+ $complexList = [];
+ $ptpList = [];
+
+ // 아파트단지목록
+ $complexList = $naver->complexList($data['address_code']);
+
+ // 평형목록
+ $ptpList = $naver->ptpList($data['hscp_no']);
+
+ $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']);
+ }
+
+ $hscp_info = $detail_hscp['result'];
+
+ }
+
+
$this->data['codes'] = $codes;
$this->data['record'] = $record;
@@ -147,11 +183,180 @@ class M701 extends BaseController
$this->data['data'] = $data;
$this->data['history'] = $history;
+ $this->data['complexList'] = $complexList;
+ $this->data['ptpList'] = $ptpList;
+ $this->data['detail_hscp'] = $hscp_info;
+
+ // print_r($data);
+ // print ('===================');
+ // print_r($complexList);
+ // print ('===================');
+ // print_r($ptpList);
+ // exit;
+
return view("pages/v2/m701/detail", $this->data);
}
+ // 가격수정
+ public function changePrice()
+ {
+ $naver = new NaverApiClient();
+
+ try {
+
+ $data = [
+ 'rcpt_key' => $this->request->getPost('rcpt_key'),
+ 'trade_type' => $this->request->getPost('trade_type_cd'),
+ 'atcl_amt1' => $this->request->getPost('atcl_amt1'),
+ 'atcl_amt2' => $this->request->getPost('atcl_amt2'),
+ 'atcl_amt3' => $this->request->getPost('atcl_amt3'),
+ 'atcl_amt4' => $this->request->getPost('atcl_amt4'),
+ 'isale_amt' => $this->request->getPost('isale_amt'),
+ 'prem_amt' => $this->request->getPost('prem_amt'),
+ ];
+
+ // UPDATE v2_vrfc_req
+ $this->model->changePrice($data);
+
+ // API 호출
+ $detail = $this->model->getDetail($data['rcpt_key']);
+
+ $priceInfo = $naver->priceChange($detail['atcl_no'], $detail['deal_amt'], $detail['wrrnt_amt'], $detail['lease_amt'], $detail['isale_amt'], $detail['prem_amt'], $detail['charger']);
+
+ // print_r($priceInfo['error']);
+ // exit;
+
+ $priceInfo = $priceInfo['error'];
+
+ if ($priceInfo['code'] !== 'success') {
+ $return = $priceInfo['error'] ?? null;
+
+ if (is_array($return) && isset($return['code'], $return['message'])) {
+ $err_time = date("Y-m-d H:i:s");
+ $this->model->saveApiErr($data['rcpt_key'], $return['code'], $return['message'], $err_time, $detail['atcl_no']);
+ throw new \Exception("가격수정 오류: " . $return['message']);
+ }
+
+ throw new \Exception($priceInfo['message']);
+ }
+
+
+ return $this->response->setJSON([
+ 'code' => '0',
+ 'msg' => 'success'
+ ]);
+
+ } catch (\Exception $e) {
+ return $this->response->setJSON([
+ 'code' => '9',
+ 'msg' => $e->getMessage(),
+ ]);
+ }
+ }
+
+ // 정보수정
+ public function modifyInfo()
+ {
+ $naver = new NaverApiClient();
+
+ try {
+
+ $atcl_vr_sq = $this->request->getPost('rcpt_key'); // 순번(vr_sq)
+ $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_amt4 = $this->request->getPost('atcl_amt4'); // 분양권매매 가격 2
+ $isale_amt = $this->request->getPost('isale_amt'); // 분양가
+ $prem_amt = $this->request->getPost('prem_amt'); // 프리미엄가
+ $atcl_floor = $this->request->getPost('atcl_floor'); // 층
+ $atcl_floor2 = $this->request->getPost('atcl_floor2'); // 총층
+ $price_ignore = $this->request->getPost('price_ignore'); // 가격무시 체크여부
+
+
+ $return = "";
+ if ($price_ignore != '1') {
+ if ($trade_type == 'A1') {
+ $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1);
+ } else if ($trade_type == 'B1') {
+ $return = limitHscpMarketPriceInfo($this, $trade_type, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt2);
+ }
+ }
+
+ if (empty($return)) {
+
+ $this->model->modifyInfo($atcl_vr_sq, $atcl_hscp_nm, $atcl_ptp_nm, $atcl_vrfc_type, $trade_type, $atcl_addr1b, $atcl_addr1a, $atcl_addr1b, $atcl_addr2, $atcl_hscp_no, $atcl_ptp_no, $atcl_amt1, $atcl_amt2, $atcl_amt3, $atcl_floor, $atcl_floor2, $atcl_amt4, $isale_amt, $prem_amt);
+
+
+ $this->model->saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type);
+
+ // API 호출
+ $detail = $this->model->getDetail($atcl_vr_sq);
+
+ $result = $naver->modifyInfo(
+ $detail['atcl_no'],
+ $detail['hscp_no'],
+ $detail['ptp_no'],
+ $detail['bild_nm'],
+ $detail['rm_no'],
+ $detail['trade_type_cd'],
+ $detail['deal_amt'],
+ $detail['wrrnt_amt'],
+ $detail['lease_amt'],
+ $detail['isale_amt'],
+ $detail['prem_amt'],
+ $detail['floor'],
+ $detail['floor2'],
+ $detail['charger'],
+ $detail['address_code'],
+ $detail['address2'],
+ $detail['address2a'],
+ $detail['address2b'],
+ $detail['address3'],
+ $detail['sply_spc'],
+ $detail['excls_spc'],
+ $detail['tot_spc'],
+ $detail['grnd_spc'],
+ $detail['bldg_spc']
+ );
+
+
+ if ($result['code'] !== 'success') {
+ $return = $priceInfo['error'] ?? null;
+
+ if (is_array($return) && isset($return['code'], $return['message'])) {
+ $err_time = date("Y-m-d H:i:s");
+ $this->model->saveApiErr($atcl_vr_sq, $return['code'], $return['message'], $err_time, $detail['atcl_no']);
+ throw new \Exception("가격수정 오류: " . $return['message']);
+ }
+
+ throw new \Exception($result['message']);
+ }
+ }
+
+ return $this->response->setJSON([
+ 'code' => '0',
+ 'msg' => 'success'
+ ]);
+
+ } catch (\Exception $e) {
+ return $this->response->setJSON([
+ 'code' => '9',
+ 'msg' => $e->getMessage(),
+ ]);
+ }
+ }
// 상태변경
public function chgArticleStatus()
@@ -207,6 +412,1281 @@ class M701 extends BaseController
$this->model->saveMemo($data);
+ return $this->response->setJSON([
+ 'code' => '0',
+ 'msg' => 'success'
+ ]);
+
+ } catch (\Exception $e) {
+ return $this->response->setJSON([
+ 'code' => '9',
+ 'msg' => $e->getMessage(),
+ ]);
+ }
+ }
+
+
+ /**
+ * 홍보확인서 확인
+ * 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 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장)
+ */
+ public function saveDocu()
+ {
+ $lib = new MyUpload();
+ $naver = new NaverApiClient();
+ $model415 = new M415Model();
+
+ 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');
+ $comment = $this->request->getPost('comment'); //홍보확인서 미확인여부 상세
+ $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'); //메모
+
+ //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다.
+ $resStat = $this->model->chkStat($atcl_vr_sq);
+
+ if ($resStat['stat_cd'] >= '40' || $resStat['stat_cd'] == '19') {
+ throw new \Exception('이미 저장된 데이터입니다.');
+ } else {
+
+ $v2DailyModel = new V2StDailyModel();
+
+ $v2_vrfc_req = $v2DailyModel->get_v2_vrfc_req($atcl_vr_sq);
+
+ $resultCnt = $this->model->chkTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt
+
+ $try_cnt = '0';
+ 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'; //좀비매물
+ }
+
+ $this->model->updateConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type);
+ }
+
+ //상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경
+ $this->model->chgStat($atcl_vr_sq, '30', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '30'); //v2_vrfc_req INSERT
+ $this->model->chgStatFax($atcl_vr_sq, '30'); //fax_imgs
+
+ $file = $this->request->getFile('docu_file');
+ if ($file && $file->isValid() && !$file->hasMoved()) {
+ $uploadPath = './upload/v2_file/' . $atcl_vr_sq;
+ $arrUploadfile = [];
+ if ($file->isValid() && !$file->hasMoved()) {
+ $uploadData = $lib->do_upload2($file, $uploadPath);
+
+ if ($uploadData !== false) {
+ $arrUploadfile[] = $uploadData;
+ }
+ }
+
+
+ if (!empty($arrUploadfile)) {
+ foreach ($arrUploadfile as $key => $uploadFile) {
+ $data['file'] = [
+ 'vr_sq' => $atcl_vr_sq,
+ 'orig_name' => $uploadFile['origin_name'],
+ 'new_name' => $uploadFile['file_name'],
+ 'file_path' => $uploadPath, // 필요에 따라 상대경로로만 저장
+ 'ext' => '.' . $uploadFile['ext'],
+ 'size' => $file->getSize(),
+ 'img_yn' => null,
+ // 높이/폭은 나중에 getimagesize 등으로 구해도 됨
+ 'img_height' => null,
+ 'img_width' => null,
+ ];
+ }
+
+ $this->model->saveFileInfo($data['file']);
+
+ }
+ }
+
+ //v2_check_list 확인여부 INSERT
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'D11', $fax_conf_res_d11, $comment);
+
+ //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);
+
+ $model710 = new M710Model();
+ $h_yn = $model710->getDataConfirmAPI($atcl_vr_sq);
+ if ($h_yn['stop_yn'] == 'N') { //전송금지
+ //1.해당매물정보를v2_stop_api_save_info에다 넣음
+ $model710->insert_v2_stop_api_save_info($sendData['atclNo'], $atcl_vr_sq, 'H', '');
+ //2.아무렇지않게 행동한다
+ $send_result['result'] = 'success';
+ } else {
+ $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']);
+ }
+
+ if ($send_result['result'] == 'success') {
+
+ /* 상태변경 */
+ 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
+
+ //★등기 로 넘어갈때
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 확인일자
+ $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq);
+ //3.해당 정보를 테이블에 넣는다
+ $sf = 'T';
+ $model415->insert_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $sf);
+
+ $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
+
+ //★검증완료일때
+ //0.불일치 이력이 있는지 확인
+ $cnt = $model415->getFaxFailTimeForHistory($atcl_vr_sq);
+ if (empty($cnt)) { //검증완료일땐 불일치가없어야 통계포함된다
+//1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 확인일자
+ $tel_doc_conf_dt = $model415->getConfTimeForHistory($atcl_vr_sq);
+ //3.검증시간
+ $finishTime = $model415->get_60_ForHistory($atcl_vr_sq);
+ //4.해당 정보를 테이블에 넣는다
+ $model415->insert_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $finishTime['insert_tm']);
+ }
+ $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') {
+ if ($fax_conf_yn_4 = !'10000') { //의뢰인정보 불일치일경우
+ $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
+
+ // $this->session->set_userdata('alert', "의뢰인정보 불일치로 저장되었습니다..");
+ throw new Exception('의뢰인정보 불일치로 저장되었습니다.');
+ }
+
+ //v2_vrfc_req try_cnt 값을 1로 update
+ $this->model->chgTryCnt($atcl_vr_sq, '1');
+
+ //★ 1차실패니까 검증실패시간 업데이트하고 검증소요시간 산출
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getFaxSaveTime($atcl_vr_sq);
+ //2.서류/전화 불일치 시간
+ $tel_doc_conf_dt = $model415->getFaxFailTimeForHistory($atcl_vr_sq);
+ //3.해당 정보를 테이블에 넣는다
+ $sf = 'F';
+ $model415->insert_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['recv_time'], $tel_doc_conf_dt['insert_tm'], $sf);
+
+ $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
+
+ //★ 검증실패면 검증실패시간 업데이트하고 검증소요시간, 전체소요시간 산출
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getFaxSaveTime($atcl_vr_sq);
+ //2.서류/전화 불일치 시간
+ $tel_doc_conf_dt = $model415->getFaxFailTimeForHistory($atcl_vr_sq);
+ //3.검증실패시간
+ $finishTime = $model415->get_69_ForHistory($atcl_vr_sq);
+ //4.해당 정보를 테이블에 넣는다
+ $model415->insert_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['recv_time'], $tel_doc_conf_dt['insert_tm'], $finishTime['insert_tm']);
+
+ $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 {
+ // 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']);
+
+ }
+
+ }
+
+ return $this->response->setJSON([
+ 'code' => '0',
+ 'msg' => 'success'
+ ]);
+
+ } catch (\Exception $e) {
+ return $this->response->setJSON([
+ 'code' => '9',
+ 'msg' => $e->getMessage(),
+ ]);
+ }
+ }
+
+
+ // 전화정보저장
+ public function saveTel()
+ {
+ /*
+ 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 이면 상태값 변경 : 전화(서류)확인완료 상태. (수정변경이력 저장)
+ */
+ $lib = new MyUpload();
+ $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');
+ $tel_agree = $this->request->getPost('tel_agree');
+
+ // 개인정보 제공 동의가 승인일 경우 필수 필드 검증
+ if ($tel_agree == '10000') {
+ $validation = \Config\Services::validation();
+
+ $validation->setRules([
+ 'tel_conf_yn_2' => [
+ 'label' => '매물주소',
+ 'rules' => 'required',
+ 'errors' => ['required' => '{field} 정보확인 결과를 선택해주세요.']
+ ],
+ 'tel_conf_yn_3' => [
+ 'label' => '가격 거래구분',
+ 'rules' => 'required',
+ 'errors' => ['required' => '{field} 정보확인 결과를 선택해주세요.']
+ ],
+ 'tel_conf_yn_4' => [
+ 'label' => '의뢰인정보',
+ 'rules' => 'required',
+ 'errors' => ['required' => '{field} 정보확인 결과를 선택해주세요.']
+ ],
+ ]);
+
+ if (!$validation->withRequest($this->request)->run()) {
+ $errors = $validation->getErrors();
+ throw new \Exception(implode(', ', $errors));
+ }
+ }
+
+ // POST 데이터 받기
+ $tel_suc = $this->request->getPost('tel_suc');
+ $tel_conf_yn_2 = $this->request->getPost('tel_conf_yn_2');
+ $tel_conf_yn_3 = $this->request->getPost('tel_conf_yn_3');
+ $tel_conf_yn_4 = $this->request->getPost('tel_conf_yn_4');
+ $tel_conf_yn_5 = $this->request->getPost('tel_conf_yn_5');
+ $tel_conf_yn_info_2 = $this->request->getPost('tel_conf_yn_info_2');
+ $tel_conf_yn_info_3 = $this->request->getPost('tel_conf_yn_info_3');
+ $tel_conf_yn_info_4 = $this->request->getPost('tel_conf_yn_info_4');
+ $address_code = $this->request->getPost('address_code');
+ $reg_chk_val = $this->request->getPost('reg_chk_val');
+ $tel_file_yn = $this->request->getPost('tel_file_yn');
+ $memo = $this->request->getPost('memo_tel');
+ $tel_fail_cause = $this->request->getPost('tel_fail_cause');
+
+
+ //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다.
+ $resStat = $this->model->chkStat($atcl_vr_sq);
+
+
+ if ($resStat['stat_cd'] >= '40' || $resStat['stat_cd'] == '19') {
+ throw new \Exception('이미 저장된 데이터입니다.');
+ } else {
+ $v2_vrfc_req = $this->model->get_v2_vrfc_req($atcl_vr_sq);
+
+
+ $this->model->InsCharger($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다
+
+ $try_cnt = '0';
+ $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 ($tel_conf_yn_2 == '10000' && $tel_conf_yn_3 == '10000' && $tel_conf_yn_4 == '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->getUpdateFailTime1($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, date("s"), date("m"), date("d"), date("Y")));
+
+ if ($update_tm > $ten_ago) {
+ throw new \Exception('이미 불일치 처리 된 매물입니다.');
+ }
+ }
+
+ $this->model->insertConfirm($atcl_vr_sq, $atcl_vrtc_way, $chk_type, $try_cnt);
+
+ } else {
+ //v2_confirm 기존데이터에 success 컬럼만 변경 가능하도록
+ //v2_confirm delay, zombie 컬럼추가 (2020.03.05)
+
+ if ($tel_conf_yn_2 == '10000' && $tel_conf_yn_3 == '10000' && $tel_conf_yn_4 == '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->getUpdateFailTime1($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, 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, $chk_delay, $chk_zombie);
+ }
+
+ $file = $this->request->getFile('rec_file');
+ if ($file && $file->isValid() && !$file->hasMoved()) {
+ $uploadPath = './upload/v2_file/' . $atcl_vr_sq . '/';
+ $arrUploadfile = [];
+ if ($file->isValid() && !$file->hasMoved()) {
+ $uploadData = $lib->do_upload2($file, $uploadPath);
+
+ if ($uploadData !== false) {
+ $arrUploadfile[] = $uploadData;
+ }
+ }
+
+
+ if (!empty($arrUploadfile)) {
+ foreach ($arrUploadfile as $key => $uploadFile) {
+ $data['file'] = [
+ 'vr_sq' => $atcl_vr_sq,
+ 'orig_name' => $uploadFile['origin_name'],
+ 'new_name' => $uploadFile['file_name'],
+ 'file_path' => $uploadPath, // 필요에 따라 상대경로로만 저장
+ 'ext' => '.' . $uploadFile['ext'],
+ 'size' => $file->getSize(),
+ 'img_yn' => null,
+ // 높이/폭은 나중에 getimagesize 등으로 구해도 됨
+ 'img_height' => null,
+ 'img_width' => null,
+ ];
+ }
+
+ $this->model->saveFileInfo($data['file']);
+ }
+ }
+
+
+ //v2_check_list 확인여부 INSERT
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'T11', $tel_agree, '');
+ if ($tel_agree == '10000') {
+ //v2_check_list 매물주소 INSERT
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'T12', $tel_conf_yn_2, $tel_conf_yn_info_2);
+
+ //v2_check_list 가격거래구분 INSERT
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'T13', $tel_conf_yn_3, $tel_conf_yn_info_3);
+
+ //v2_check_list 의뢰인정보 INSERT
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'T14', $tel_conf_yn_4, $tel_conf_yn_info_4);
+ } else {
+ $this->model->deleteChkList($atcl_vr_sq, $atcl_vrtc_way, 'T12');
+ $this->model->deleteChkList($atcl_vr_sq, $atcl_vrtc_way, 'T13');
+ $this->model->deleteChkList($atcl_vr_sq, $atcl_vrtc_way, 'T14');
+ }
+ if (!empty($tel_conf_yn_5)) {
+ $this->model->insertChkList($atcl_vr_sq, $atcl_vrtc_way, 'T15', $tel_conf_yn_5, $tel_conf_yn_5);
+ $this->model->deleteChkList($atcl_vr_sq, $atcl_vrtc_way, 'T11');
+ } else {
+ $this->model->deleteChkList($atcl_vr_sq, $atcl_vrtc_way, 'T15');
+ }
+
+ //memo 저장
+ if (!empty($memo)) {
+ $this->model->saveMemo(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]);
+ }
+
+ //전화실패 사유 저장
+ if (!empty($tel_fail_cause)) {
+ $this->model->up_tel_fail_cause($atcl_vr_sq, $tel_fail_cause);
+ }
+
+ $sendData = $this->model->getDataConfirmAPI($atcl_vr_sq);
+ $t_yn = $model710->get_send_yn('T');
+ if ($t_yn['stop_yn'] == 'N') { //전송금지
+ //1.해당매물정보를v2_stop_api_save_info에다 넣음
+ $this->model->insert_v2_stop_api_save_info($sendData['atclNo'], $atcl_vr_sq, 'T1', '');
+ //2.아무렇지않게 행동한다
+ $send_result['result'] = 'success';
+ } else {
+ //API 호출
+ $send_result = $naver->confirm($sendData['atclNo'], $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['modifyInfo'], $sendData['date']);
+ }
+
+ //v2_vrfc_req INSERT//상태변경 TABLE INSERT : 전화(서류)확인중 상태로 변경
+ $this->model->chgStat($atcl_vr_sq, '30', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '30');
+
+ if ($send_result['result'] == 'success') {
+
+ if ($tel_agree == '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
+
+ if ($reg_chk_val == '1') {
+ //등기부등본 확인 대상은 전화(서류)확인 완료 후 -> 등기부등본 확인중 상태로 변경.
+ $this->model->chgStat($atcl_vr_sq, '40', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '40'); //v2_vrfc_req INSERT
+
+ //★등기 로 넘어갈때
+ //0.통화실패 여부를 확인한다
+ $cnt = $model415->getCallfailForHistory($atcl_vr_sq);
+ if (empty($cnt)) { //통화실패가 없어야 통계를 구한다
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 확인일자
+ $tel_doc_conf_dt = $model415->get_cert_ing_TimeForHistory($atcl_vr_sq);
+ //3.해당 정보를 테이블에 넣는다
+ $sf = 'T';
+ $model415->insert_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $sf);
+ }
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0201', '1', 'add'); // 일치로 저장
+ } else {
+ //등기부등본 확인 대상이 아닌 경우 전화(서류)확인 완료 후 -> 검증 완료 상태로 변경.
+ $this->model->chgStat($atcl_vr_sq, '60', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '60'); //v2_vrfc_req INSERT
+
+ //★검증완료일때
+ //0.통화실패 여부를 확인한다
+ $cnt = $model415->getCallfailForHistory($atcl_vr_sq);
+ if (empty($cnt)) { //통화실패가 없어야 통계를 구한다
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 확인일자
+ $tel_doc_conf_dt = $model415->getConfTimeForHistory($atcl_vr_sq);
+ //3.검증완료시간
+ $finishTime = $model415->get_60_ForHistory($atcl_vr_sq);
+ //4.해당 정보를 테이블에 넣는다
+ $model415->insert_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $finishTime['insert_tm']);
+ }
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0206', '1', 'add'); // 전화확인완료 등기부등본확인 안함 저장
+ }
+
+ } else {
+ //상태변경 TABLE INSERT : 전화(서류)확인 불일치 상태로 변경
+ $this->model->chgStat($atcl_vr_sq, '39', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '39'); //v2_vrfc_req INSERT
+
+ if ($try_cnt == '1') {
+ //v2_vrfc_req try_cnt 값을 1로 update
+ $this->model->chgTryCnt($atcl_vr_sq, '1');
+
+ //★불일치
+ //0.통화실패 여부를 확인한다
+ $cnt = $model415->getCallfailForHistory($atcl_vr_sq);
+ if (empty($cnt)) { //통화실패가 없어야 통계를 구한다
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 불일치 시간
+ $tel_doc_conf_dt = $model415->getFaxFailTimeForHistory($atcl_vr_sq);
+ //3.해당 정보를 테이블에 넣는다
+ $sf = 'F';
+ $model415->insert_v2_time_required_Conf($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $sf);
+ }
+
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0301', '1', 'add'); // 1차실패로 저장
+ } else if ($try_cnt == '2') {
+ //v2_vrfc_req try_cnt 값을 2로 update
+ $res_try = $this->m701_model->chgTryCnt($atcl_vr_sq, '2');
+
+ //상태변경 TABLE INSERT : 검증실패 상태로 변경.
+ $result_query9 = $this->m701_model->chgStat($atcl_vr_sq, '69', $toDay);
+ $chgVrfc69 = $this->m701_model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT
+
+ //★ 검증실패
+ //0.통화실패 여부를 확인한다
+ $cnt = $model415->getCallfailForHistory($atcl_vr_sq);
+ if (empty($cnt)) { //통화실패가 없어야 통계를 구한다
+ //1.서류전화 들어온시간
+ $insert_tm = $model415->getSaveTimeForHistory($atcl_vr_sq);
+ //2.서류/전화 불일치 시간
+ $tel_doc_conf_dt = $model415->getFaxFailTimeForHistory($atcl_vr_sq);
+ //3.검증실패시간
+ $finishTime = $model415->get_69_ForHistory($atcl_vr_sq);
+ //4.해당 정보를 테이블에 넣는다
+ $model415->insert_v2_time_required_Conf_Done($v2_vrfc_req['atcl_no'], $v2_vrfc_req['cpid'], $v2_vrfc_req['vrfc_type'], $insert_tm['insert_tm'], $tel_doc_conf_dt['insert_tm'], $finishTime['insert_tm']);
+ }
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0302', '1', 'add'); // 최종실패로 저장
+ }
+
+ if (in_array($tel_agree, array('20001', '20002'))) {
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0203', '1', 'add'); // 거부로 저장
+ } elseif (in_array($tel_agree, array('20003', '20004', '20005'))) {
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0204', '1', 'add'); // 무응답 외
+ } else {
+ $v2DailyModel->set_v2_st_daily(NULL, $v2_vrfc_req['cpid'], 'T0202', '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'
+ ]);
+
+ //$file = $this->request->getFile('rec_file');
+
+ // print_r($file);
+ // exit;
+
+ } catch (\Exception $e) {
+ return $this->response->setJSON([
+ 'code' => '9',
+ 'msg' => $e->getMessage(),
+ ]);
+ }
+ }
+
+ // 파일업로드
+ public function uploadFile()
+ {
+ $lib = new MyUpload();
+
+ try {
+ $usr_id = session('usr_id');
+ $vr_sq = $this->request->getPost(index: 'vr_sq');
+
+ $files = $this->request->getFiles();
+
+
+
+ $uploadPath = "/upload/v2_file/" . $vr_sq . "/";
+
+ $file = $files['files'];
+ $arrUploadfile = [];
+ $uploadData = $lib->do_upload2($file, $uploadPath);
+
+ if ($uploadData !== false) {
+ $arrUploadfile[] = $uploadData;
+ }
+
+ // print_r($arrUploadfile);
+ // exit;
+
+ if (!empty($arrUploadfile)) {
+ foreach ($arrUploadfile as $key => $uploadFile) {
+ $data = [
+ 'vr_sq' => $vr_sq,
+ // 'file_sq' => $this->request->getPost('file_sq'),
+ 'orig_name' => $uploadFile['origin_name'],
+ 'new_name' => $uploadFile['file_name'],
+ 'file_path' => $uploadPath, // 필요에 따라 상대경로로만 저장
+ 'ext' => '.' . $uploadFile['ext'],
+ 'size' => $file->getSize(),
+ 'img_yn' => null,
+ 'img_height' => null,
+ 'img_width' => null,
+ 'usr_id' => $usr_id,
+ 'file_type' => '2',
+ ];
+ }
+
+ if (!empty($data)) {
+
+ $detail = $this->model->getDetail($vr_sq);
+ $this->model->saveHistory($vr_sq, $detail['stat_cd'], 'C28', $usr_id, '이미지파일 업로드');
+
+ // 파일업로드 정보 저장
+ $this->model->saveFileInfo($data);
+
+ }
+
+ }
+
+ // 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 전송 certification.
+ 1.11.1 API 전송결과 : SUCCESS 이면 상태값 변경 : 등기부등본 확인완료 상태. (수정변경이력 저장)
+ */
+
+ $model415 = new M415Model();
+ $model710 = new M710Model();
+ $v2DailyModel = new V2StDailyModel();
+ $naver = new NaverApiClient();
+
+ try {
+
+ $atcl_vrtc_type = $this->request->getGet('atcl_vrtc_type', TRUE); // 검증방식
+ if ($atcl_vrtc_type == "N") {
+ $ownerVerifiable = $this->request->getPost('ownerVerifiable', TRUE); //소유자명 확인
+ }
+ $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', TRUE);
+ $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1', TRUE); //확인내용
+ $reg_conf_yn_2 = $this->request->getPost('reg_conf_yn_2', TRUE); //매물주소
+ $reg_conf_yn_3 = $this->request->getPost('reg_conf_yn_3', TRUE); //의뢰인정보
+ $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2', TRUE); //매물주소
+ $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3', TRUE); //의뢰인정보
+ $memo = $this->request->getPost('memo_reg', TRUE); //메모
+
+ //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다.
+ $this->model->chkStat($atcl_vr_sq);
+ $v2_vrfc_req = $this->model->get_v2_vrfc_req($atcl_vr_sq);
+ $rlet_type_cd = $this->model->get_rlet_type_cd($atcl_vr_sq);
+
+
+ $resultCnt = $this->model->chkRegiTryCnt($atcl_vr_sq); //1차검증인지 2차검증인지 확인 쿼리 : v2_vrfc_req.type_cnt
+
+ $try_cnt = '0';
+ 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 {
+ // 2015.06.29 추가
+ // 불일치가 날 경우에 10분 이내에 다시 불일치 처리 불가능(같은 매물을 두사람이 중복처리할 가능성 사전 방지)
+ // 1. 현재 매물의 마지막으로 업데이트 된 시간을 가져옴.
+ // 2. 현재 시간과 비교하여 10분 이내면 경고창을 띄어줌.
+
+ $chk_type = '0';
+ //$chk_delay = '1'; //지연여부
+ //$chk_zombie = '0'; //좀비매물
+
+ $result_tm = $this->model->getUpdateFailTime2($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, date("s"), date("m"), date("d"), date("Y")));
+
+ if ($update_tm > $ten_ago) {
+ 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->getUpdateFailTime2($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, 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);
+ }
+
+ //상태변경 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(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]);
+ }
+
+ $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R');
+
+ $d_yn = $model710->get_send_yn('D');
+ if ($d_yn['stop_yn'] == 'N') { //전송금지
+ //1.해당매물정보를v2_stop_api_save_info에다 넣음
+ $model710->insert_v2_stop_api_save_info($sendData['atclNo'], $atcl_vr_sq, 'D', '');
+ //2.아무렇지않게 행동한다
+ $send_result['result'] = 'success';
+ } else {
+ if ($atcl_vrtc_type == "N") {
+
+ if ($ownerVerifiable == '1') {
+ $ownerVerifiable = true;
+ } else {
+ $ownerVerfiable = false;
+ }
+
+ } else {
+ $ownerVerifiable = $sendData['ownerVerifiable'];
+
+ }
+
+ // 소유주 확인 여부 업데이트
+ $result_verifiable = $this->model->updateOwnerVerifiable($atcl_vr_sq, $ownerVerifiable);
+
+ $send_result = $naver->certification($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $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
+
+ //★검증완료일때
+ //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']);
+ }
+ }
+ $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);
+ $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT
+ $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);
+ $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT
+ $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);
+ $this->model->chgStatVrfc($atcl_vr_sq, '49'); //v2_vrfc_req INSERT
+ $this->model->chgStatFax($atcl_vr_sq, '49'); //fax_img
+
+ //등기부등본 확인중 상태로 변경.
+ $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');
+
+ // ★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 : 검증실패 상태로 변경.
+ $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
+
+ // ★모바일 이외 검증실패
+ 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']);
+ }
+ }
+ }
+ $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 saveFinalRegi()
+ {
+ $naver = new NaverApiClient();
+ $model710 = new M710Model();
+ $model415 = new M415Model();
+ $v2DailyModel = new V2StDailyModel();
+
+ try {
+
+ $atcl_vrtc_type = $this->request->getGet('atcl_vrtc_type', TRUE); // 검증방식
+ if ($atcl_vrtc_type == "N") {
+ $ownerVerifiable = $this->request->getPost('ownerVerifiable', TRUE); //소유자명 확인
+ }
+
+ $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', TRUE);
+ // $atcl_no = $this->input->post('atcl_no', TRUE);
+ $reg_conf_yn_1 = $this->request->getPost('reg_conf_yn_1', TRUE); //확인내용
+ $reg_conf_yn_2 = '20000'; //매물주소 불일치 처리
+ $reg_conf_yn_3 = '20000'; //의뢰인정보 불일치 처리
+ $reg_conf_yn_info_2 = $this->request->getPost('reg_conf_yn_info_2', TRUE); //매물주소
+ $reg_conf_yn_info_3 = $this->request->getPost('reg_conf_yn_info_3', TRUE); //의뢰인정보
+ $memo = $this->request->getPost('memo_reg', TRUE); //메모
+ $try_cnt = '2';
+
+ //상태가 이미 등기부등본확인중 이상이면 저장하지 않는다.
+ $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 ($resStat['stat_cd'] >= '60' || $resStat['stat_cd'] == '19') {
+ throw new \Exception('이미 최종처리된 매물입니다.');
+ } else {
+
+ $this->model->InsResChar($atcl_vr_sq); //담당자가 없을 경우 강제로 session 정보로 넣어준다
+
+ $result = $this->model->chkConfirm($atcl_vr_sq, $atcl_vrtc_way);
+
+ //v2_confirm 존재하지 않는다면
+ if ($result == 0) {
+ if ($reg_conf_yn_2 == '10000' && $reg_conf_yn_3 == '10000') {
+ $chk_type = '1';
+ } else {
+ $chk_type = '0';
+
+ $result_tm = $this->model->getUpdateFailTime2($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, date("s"), date("m"), date("d"), date("Y")));
+
+ if ($update_tm > $ten_ago) {
+ 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->getUpdateFailTime2($atcl_vr_sq);
+ $update_tm = $result_tm['insert_tm'];
+ $ten_ago = date("Y-m-d H:i:s", mktime(date("H"), date("i") - 10, 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);
+ }
+
+ //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(['vr_sq' => $atcl_vr_sq, 'memo' => $memo]);
+ }
+
+ $sendData = $this->model->getDatacertAPI($atcl_vr_sq, 'R');
+ $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 {
+ if ($atcl_vrtc_type == "N") {
+
+ if ($ownerVerifiable == '1') {
+ $ownerVerifiable = true;
+ } else {
+ $ownerVerifiable = false;
+ }
+
+ } else {
+ $ownerVerifiable = $sendData['ownerVerifiable'];
+ }
+
+ // 소유주 확인 여부 업데이트
+ $result_verifiable = $this->model->updateOwnerVerifiable($atcl_vr_sq, $ownerVerifiable);
+
+ $send_result = $naver->certification($sendData['atclNo'], $try_cnt, $sendData['success'], $sendData['checkList'], $sendData['charger'], $sendData['date'], $sendData['modifyInfo'], $ownerVerifiable);
+ }
+
+ if ($send_result['result'] == 'success') {
+ if ($atcl_vrtc_type == 'M') {
+ //상태변경 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
+
+ //v2_vrfc_req try_cnt 값을 1로 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
+
+ // ★모바일이고 검증실패
+ 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);
+ $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 == '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
+
+ // ★모바일 이외 검증실패
+ 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']);
+ }
+ }
+ }
+ $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('네이버 전송 중 오류가 발생되었습니다. 다시 시도하세요.');
+ }
+ }
+
+ //상태변경 TABLE INSERT : 최종실패 상태로 변경
+ $this->model->chgStat($atcl_vr_sq, '69', $toDay);
+ $this->model->chgStatVrfc($atcl_vr_sq, '69'); //v2_vrfc_req INSERT
+
+ }
+
+
return $this->response->setJSON([
'code' => '0',
'msg' => 'success'
diff --git a/app/Controllers/V2/V2StDailyModel.php b/app/Controllers/V2/V2StDailyModel.php
new file mode 100644
index 0000000..e114327
--- /dev/null
+++ b/app/Controllers/V2/V2StDailyModel.php
@@ -0,0 +1,73 @@
+db->query($sql, $data);
+
+ $return['error_number'] = $this->db->_error_number();
+ $return['error_message'] = $this->db->_error_message();
+
+ return $return;
+ }
+
+ /**
+ * 지정한 매물의 요청번호를 이용하여 요청내역을 가져온다.
+ */
+ public function get_v2_vrfc_req($vr_sq)
+ {
+ $columns = "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,memo,contact_fail_cnt,sync_yn,reg_try_cnt";
+ $builder = $this->db->table('v2_vrfc_req');
+ $builder->select($columns, false);
+ $builder->where('vr_sq', $vr_sq);
+ $row = $builder->get()->getRowArray();
+ return $row;
+ }
+}
\ No newline at end of file
diff --git a/app/Libraries/FormValidation.php b/app/Libraries/FormValidation.php
new file mode 100644
index 0000000..05ba0ac
--- /dev/null
+++ b/app/Libraries/FormValidation.php
@@ -0,0 +1,57 @@
+commonModel = new CommonModel();
+ }
+
/**
* [GET] 매물 정보 조회
*/
@@ -27,7 +36,7 @@ class NaverApiClient
{
$this->charger = $charger;
$url = "{$this->baseUrl}/kiso/center/verification-article/{$articleNumber}?charger={$this->charger}";
-
+
return $this->request('PUT', $url, $updateData);
}
@@ -38,6 +47,212 @@ class NaverApiClient
return $this->request('GET', $url);
}
+ /**
+ * 단지상세정보조회
+ * hscpNo : 단지번호(숫자)
+ */
+ public function aptDetail($hscpNo)
+ {
+ $url = $this->commonModel->getCompanyInfo(2);
+ $url = $url['api_server'] . "/confirms/APTDetail?hscpNo={$hscpNo}";
+ return $this->request('GET', $url);
+ }
+
+ /**
+ * 빌라 단지상세정보 조회
+ * hscpNo : 단지번호(숫자)
+ */
+
+ public function villaDetail($hscpNo)
+ {
+ $url = $this->commonModel->getCompanyInfo(2);
+ $url = $url['api_server'] . "/confirms/villa/{$hscpNo}";
+ return $this->request('GET', $url);
+ }
+
+
+ /**
+ * 단지목록
+ * cortarNo : 법정동코드
+ */
+ public function complexList($cortarNo)
+ {
+ $url = $this->commonModel->getCompanyInfo(2);
+ $url = $url['api_server'] . "/common/complexList.nhn?cortarNo={$cortarNo}";
+ return $this->request('GET', $url);
+ }
+
+ /**
+ * 평형목록
+ * rletNo : 단지번호
+ */
+ public function ptpList($rletNo)
+ {
+ $url = $this->commonModel->getCompanyInfo(2);
+ $url = $url['api_server'] . "/common/ptpList.nhn?rletNo={$rletNo}";
+ return $this->request('GET', $url);
+ }
+
+ /**
+ * 가격수정
+ * @param String atclNo 매물번호
+ * @param integer dealAmt 매매가, 전세(보증금) 단위 : 만원
+ * @param integer wrrntAmt 전세가(보증금) 단위 : 만원
+ * @param integer leaseAmt 월세가 단위 : 만원
+ * @param integer isaleAmt 분양가 단위 : 만원
+ * @param integer premAmt 프리미엄 단위 : 만원
+ * @param integer charger 담당자id
+ */
+ public function priceChange($atclNo, $dealAmt, $wrrntAmt, $leaseAmt, $isaleAmt, $premAmt, $charger)
+ {
+ $url = $this->commonModel->getCompanyInfo(3);
+ $url = $url['api_server'] . "/confirms/priceChange";
+
+ $postData = [
+ "atclNo" => $atclNo,
+ "dealAmt" => $dealAmt,
+ "wrrntAmt" => $wrrntAmt,
+ "leaseAmt" => $leaseAmt,
+ "isaleAmt" => $isaleAmt,
+ "premAmt" => $premAmt,
+ "charger" => $charger
+ ];
+
+ return $this->request('POST', $url, $postData);
+ }
+
+ /**
+ * 매물정보수정
+ * @param String atclNo 매물번호
+ * @param integer hscpNo 단지번호
+ * @param integer ptpNo 평형번호
+ * @param String bildNm 동이름
+ * @param String rmNo 호수
+ * @param String tradeType 거래종류(A1,B1,B2 / 변경시 B1 <-> B2만 가능)
+ * @param integer dealAmt 매매가, 전세(보증금) 단위 : 만원
+ * @param integer wrrntAmt 전세가(보증금) 단위 : 만원
+ * @param integer leaseAmt 월세가 단위 : 만원
+ * @param integer isaleAmt 분양가 단위 : 만원
+ * @param integer premAmt 프리미엄 단위 : 만원
+ * @param integer floor 층
+ * @param integer charger 담당자id
+ *
+ * @param String addressCode 주소코드 : 비공동 주택 법정동 코드
+ * @param String address2 지번주소 : 비공동 주택 지번 주소
+ * @param String address3 기타주소 : 비공동 주택 기타 주소
+ * @param float splySpc 공급면적
+ * @param float exclsSpc 대지면적
+ * @param float totSpc 전체면적
+ * @param float grndSpc 대지면적
+ * @param float bldgSpc 건축면적
+ *
+ */
+ public function modifyInfo($atclNo, $hscpNo, $ptpNo, $bildNm, $rmNo, $tradeType, $dealAmt, $wrrntAmt, $leaseAmt, $isaleAmt, $premAmt, $floor, $floor2, $charger, $addressCode, $address2, $address2a, $address2b, $address3, $splySpc, $exclsSpc, $totSpc, $grndSpc, $bldgSpc)
+ {
+ $url = $this->commonModel->getCompanyInfo(3);
+ $url = $url['api_server'] . "/confirms/modifyInfo";
+
+ // 공통
+ $postData = [
+ "atclNo" => $atclNo,
+ "tradeType" => $tradeType,
+ "dealAmt" => $dealAmt,
+ "wrrntAmt" => $wrrntAmt,
+ "leaseAmt" => $leaseAmt,
+ "isaleAmt" => $isaleAmt,
+ "charger" => $charger
+ ];
+
+ // 공동주택
+ $apartData["hscpNo"] = $hscpNo;
+ $apartData["ptpNo"] = $ptpNo;
+ $apartData["bildNm"] = $address2; // 네이버에서 보내주는거랑 수정되어 전달하는 거랑 다른 타입임. 2014년 11월 13일 수정
+ $apartData["rmNo"] = $address3; // 네이버에서 보내주는거랑 수정되어 전달하는 거랑 다른 타입임. 2014년 11월 13일 수정
+// $apartData["bildNm"] = $bildNm;
+// $apartData["rmNo"] = $rmNo;
+ $apartData["premAmt"] = $premAmt;
+ $apartData["floor"] = $floor;
+ $apartData["floor2"] = $floor2;
+
+ // 비공동주택 연동
+ $detachData["addressCode"] = $addressCode;
+ $detachData["address2"] = $address2;
+ $detachData["address2a"] = $address2a;
+ $detachData["address2b"] = $address2b;
+ $detachData["address3"] = $address3;
+ $detachData["splySpc"] = $splySpc;
+ $detachData["exclsSpc"] = $exclsSpc;
+ $detachData["totSpc"] = $totSpc;
+ $detachData["grndSpc"] = $grndSpc;
+ $detachData["bldgSpc"] = $bldgSpc;
+ $detachData["floor"] = $floor;
+ $detachData["floor2"] = $floor2;
+
+ if (!empty($hscpNo)) { //공동주택일 때
+ $postData = array_merge($postData, $apartData);
+ } else { //비공동주택일 때
+ $postData = array_merge($postData, $detachData);
+ }
+
+ return $this->request('POST', $url, $postData);
+ }
+
+
+ /**
+ * 검증결과 전송
+ * @param String atclNo 매물번호
+ * @param boolean success 성공여부
+ * @param array checkList 확인정보 array('type'=>'T11','code'=>'10000','comment'=>'01|02|03'); 또는 array('type'=>'T11','code'=>'10000','comment'=>'코멘트');
+ * @param String charger 담당자 사번
+ * @param array modifyInfo 공동 비공동에 따라 다른 배열을 넘긴다.
+ * @param String date 상담일시
+ */
+ public function confirm($atclNo, $success, $checkList, $charger, $modifyInfo, $date)
+ {
+ $url = $this->commonModel->getCompanyInfo(3);
+ $url = $url['api_server'] . "/confirms/confirm";
+
+ $postData = [
+ "atclNo" => $atclNo,
+ "success" => $success,
+ "checkList" => $checkList,
+ "charger" => $charger,
+ "modifyInfo" => $modifyInfo,
+ "date" => $date,
+ ];
+
+ return $this->request('POST', $url, $postData);
+ }
+
+ /**
+ * 등기부 등본 확인 결과
+ * @param String atclNo 매물번호
+ * @param String type 1: 1차 확인(등기부확인) / 2: 2차 확인(최종확인 또는 중개업소 TM)
+ * @param boolean success 성공여부
+ * @param array checkList 확인정보
+ * @param String charger 담당자 사번
+ * @param String date 상담일시
+ * @param array modifyInfo 수정정보 - success:true 에서만 허용
+ */
+ public function certification($atclNo, $type, $success, $checkList, $charger, $date, $modifyInfo, $ownerVerifiable)
+ {
+ $url = $this->commonModel->getCompanyInfo(3);
+ $url = $url['api_server'] . "/confirms/certification";
+
+ $postData = [
+ "atclNo" => $atclNo,
+ "type" => $type,
+ "success" => $success,
+ "checkList" => $checkList,
+ "charger" => $charger,
+ "date" => $date,
+ "modifyInfo" => $modifyInfo,
+ "ownerVerifiable" => $ownerVerifiable
+ ];
+
+ return $this->request('POST', $url, $postData);
+ }
+
/**
* CURL 공통 실행 함수
*/
diff --git a/app/Models/common/CommonModel.php b/app/Models/common/CommonModel.php
index 5340252..9b95d1d 100644
--- a/app/Models/common/CommonModel.php
+++ b/app/Models/common/CommonModel.php
@@ -17,4 +17,12 @@ class CommonModel extends Model
return $query->getResultArray();
}
+
+ public function getCompanyInfo($compSq)
+ {
+ $sql = "SELECT api_server, api_key, comp_nm FROM companies WHERE comp_sq = ?";
+ $data = [$compSq];
+ $query = $this->db->query($sql, $data);
+ return $query->getRowArray();
+ }
}
\ No newline at end of file
diff --git a/app/Models/results/M415Model.php b/app/Models/results/M415Model.php
index e57f1de..177a77d 100644
--- a/app/Models/results/M415Model.php
+++ b/app/Models/results/M415Model.php
@@ -191,6 +191,42 @@ class M415Model extends Model
return $res;
}
+ // 서류/전화 확인완료 시간 = 등기부등본 확인중 시간
+ public function getConfTimeForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '35'" .
+ " and chg_type= 'C9'" .
+ " order by seq desc" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
+ // 검증완료 시간
+ public function get_60_ForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '60'" .
+ " and chg_type= 'C9'" .
+ " order by seq desc" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
// 등기부등본 확인중 시간, 서류에서 등기로 넘어갈때 간혹 서류전화 확인 완료가 안찍히는 건들이 있다
public function get_cert_ing_TimeForHistory($vr_sq)
{
@@ -338,4 +374,196 @@ class M415Model extends Model
);
$this->db->query($sql, $data);
}
+
+ //전화확인 - 통화실패 카운트
+ public function getCallfailForHistory($vr_sq)
+ {
+ $sql = "SELECT 'x' from v2_chg_history" .
+ " WHERE vr_sq = ?" .
+ " AND chg_type= 'C29'" .
+ " ORDER BY seq desc" .
+ " LIMIT 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
+ // 서류/전화 인입시간
+ public function getSaveTimeForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '30'" .
+ " and chg_type= 'C9'" .
+ " order by seq desc" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+
+ $res = $query->getRowArray();
+ return $res;
+ }
+
+ // 등기부등본 확인실패 시간
+ public function get_cert_failTimeForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '49'" .
+ " and chg_type= 'C9'" .
+ " order by seq desc" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
+ //등기부등본 확인완료(모바일)
+ public function insert_v2_time_required_M($atcl_no, $cpid, $vrfc_type, $insert_tm, $cert_comple_dt, $finishTime)
+ {
+ if (substr($insert_tm, 0, 10) == substr($cert_comple_dt, 0, 10)) {
+ if (('12:00:00' < substr($insert_tm, -8)) && (substr($insert_tm, -8) < '13:00:00')) {//접수시간이 12~13시 사이면 13시로 해준다
+ if ($cert_comple_dt > '13:00:00') { //검증완료가 13시 '이후'에 끝나면 접수시간을 13시로 변경해준다
+ $insert_tm = date("Y-m-d", time()) . " 13:00:00";
+ }
+ } else if (
+ (substr($insert_tm, -8) > '17:30:00' || substr($insert_tm, -8) < '08:59:59') && //접수와 확인완료시간이 모두 17:30:00 ~ 09:00:00 사이가 아니면
+ (substr($cert_comple_dt, -8) < '17:30:00' || substr($cert_comple_dt, -8) < '08:59:59')
+ ) {
+ $insert_tm = date("Y-m-d", time()) . " 09:00:00";
+ }
+ } else {
+ if (substr($insert_tm, -8) > '17:30:00' || substr($insert_tm, -8) < '08:59:59') {
+ $insert_tm = date("Y-m-d", time()) . " 09:00:00";
+ }
+ }
+ $stan_date = substr($insert_tm, 0, 10);
+
+ $sql = "INSERT INTO v2_time_required(stan_date, atcl_no, cpid, vrfc_type, insert_tm, cert_comple_dt, cert_required_tm, tot_required_tm)" .
+ " VALUES(?, ?, ?, ?, ?, ?, TIMEDIFF(?,?), TIMEDIFF(?,?)) " .
+ " ON DUPLICATE KEY UPDATE insert_tm = VALUES(insert_tm), tel_doc_conf_dt=VALUES(tel_doc_conf_dt),conf_required_tm = VALUES(conf_required_tm),tot_required_tm = VALUES(tot_required_tm) ";
+ $data = array(
+ $stan_date,
+ $atcl_no,
+ $cpid,
+ $vrfc_type,
+ $insert_tm,
+ $cert_comple_dt,
+ $cert_comple_dt,
+ $insert_tm,
+ $cert_comple_dt,
+ $insert_tm
+ );
+ $this->db->query($sql, $data);
+ }
+
+ //등기부등본 확인완료(불일치)
+ public function update_v2_time_required_Conf($atcl_no, $cpid, $vrfc_type, $tel_doc_conf_dt, $cert_comple_dt, $sf)
+ {
+ if ($sf == 'F') {
+ if (substr($tel_doc_conf_dt, 0, 10) == substr($cert_comple_dt, 0, 10)) {
+ if (('12:00:00' < substr($tel_doc_conf_dt, -8)) && (substr($tel_doc_conf_dt, -8) < '13:00:00')) {//전서확인시간이 12~13시 사이면 13시로 해준다
+ // if (substr($finishTime, -8) > '13:00:00'){ //등본완료가 13시 '이후'에 끝나면 전서확인시간을 13시로 변경해준다
+ // $tel_doc_conf_dt = date("Y-m-d",time())." 13:00:00";
+ // }
+ }
+ }
+ }
+ $sql = "UPDATE v2_time_required " .
+ " SET cert_comple_dt = ?" .
+ " ,cert_required_tm = TIMEDIFF(?,?)" .//등본 소요시간 = 등본완료시간-전/서확인완료시간
+ " WHERE atcl_no = ?";
+ $data = array(
+ $cert_comple_dt,
+ $cert_comple_dt,
+ $tel_doc_conf_dt,
+ $atcl_no
+ );
+ $this->db->query($sql, $data);
+ // echo $this->db->last_query().'
';
+ }
+
+ // 최초! 등기부등본 확인중 시간-모바일용
+ public function get_cert_M_timeForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '40'" .
+ " and chg_type= 'C9'" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
+ // 검증실패 시간
+ public function get_69_ForHistory($vr_sq)
+ {
+ $sql = "select insert_tm from v2_chg_history" .
+ " where vr_sq = ?" .
+ " and stat_cd = '69'" .
+ " and chg_type= 'C9'" .
+ " order by seq desc" .
+ " limit 1";
+ $data = array(
+ $vr_sq
+ );
+ $query = $this->db->query($sql, $data);
+ $res = $query->getRowArray();
+
+ return $res;
+ }
+
+ //등기부등본 확인완료(일치/불일치), 검증완료/실패까지 갈때만!
+ public function update_v2_time_required_Conf_Done($atcl_no, $cpid, $vrfc_type, $tel_doc_conf_dt, $cert_comple_dt)
+ {
+ //1.검증소요시간 가져온다
+ $sql = "SELECT conf_required_tm" .
+ " FROM v2_time_required" .
+ " WHERE atcl_no = ?";
+ $data = array(
+ $atcl_no
+ );
+ $query = $this->db->query($sql, $data);
+
+ $res = $query->row_array();
+
+ if (substr($tel_doc_conf_dt, 0, 10) == substr($cert_comple_dt, 0, 10)) {
+ if (('12:00:00' < substr($tel_doc_conf_dt, -8)) && (substr($tel_doc_conf_dt, -8) < '13:00:00')) {//전서확인시간이 12~13시 사이면 13시로 해준다
+ if (substr($cert_comple_dt, -8) > '13:00:00') { //등본완료가 13시 '이후'에 끝나면 전서확인시간을 13시로 변경해준다
+ $tel_doc_conf_dt = date("Y-m-d", time()) . " 13:00:00";
+ }
+ }
+ }
+ //2.등본소요시간, 등본완료시간, 총소요시간을 넣는다
+ $sql = "UPDATE v2_time_required " .
+ " SET cert_comple_dt = ?" .
+ " ,cert_required_tm = TIMEDIFF(?,?)" . //등본 소요시간 = 등본완료시간-전/서확인완료시간
+ " ,tot_required_tm = ADDTIME(?,TIMEDIFF(?,?))" .//총소요시간 = 검증소요시간+등본소요시간
+ " WHERE atcl_no = ?";
+ $data = array(
+ $cert_comple_dt,
+ $cert_comple_dt,
+ $tel_doc_conf_dt,
+ $res['conf_required_tm'],
+ $cert_comple_dt,
+ $tel_doc_conf_dt,
+ $atcl_no
+ );
+ $this->db->query($sql, $data);
+ }
}
\ No newline at end of file
diff --git a/app/Models/v2/M701Model.php b/app/Models/v2/M701Model.php
index 3e08378..78bac4b 100644
--- a/app/Models/v2/M701Model.php
+++ b/app/Models/v2/M701Model.php
@@ -1,6 +1,7 @@
db->transStart();
+
+ $usr_id = session('usr_id');
+
+ $detail = $this->getDetail($param['rcpt_key']);
+
+ if ($param['trade_type'] != 'B2') {
+ // 월세가 아닐경우에는 월세가에 0으로 ....
+ $data['lease_amt'] = $param['atcl_amt3'];
+ }
+
+ if (!empty($param['atcl_amt1']))
+ $data['deal_amt'] = $param['atcl_amt1'];
+ if (!empty($param['atcl_amt2']))
+ $data['wrrnt_amt'] = $param['atcl_amt2'];
+ if (!empty($param['atcl_amt3']))
+ $data['lease_amt'] = $param['atcl_amt3']; // 월세이고 월세가격이 입력되지 않았으면... 원래 금액으로
+ if (!empty($param['atcl_amt4']))
+ $data['deal_amt'] = $param['atcl_amt4'];
+ if (!empty($param['isale_amt']))
+ $data['isale_amt'] = $param['isale_amt'];
+ if (!empty($param['prem_amt']))
+ $data['prem_amt'] = $param['prem_amt'];
+
+ $data['modify_yn'] = 'Y';
+
+ $builder = $this->db->table('v2_modify_info');
+ $ok = $builder->where('vr_sq', $param['rcpt_key'])->update($data);
+ if ($ok === false) {
+ return [
+ 'success' => false,
+ 'msg' => '저장 실패',
+ ];
+ }
+
+ $memo = "가격변경 ";
+ $this->saveHistory($detail['vr_sq'], $detail['pre_stat_cd'], 'C25', $usr_id, $memo);
+
+ $this->db->transComplete();
+
+ return [
+ 'success' => true,
+ ];
+ }
+
+ // 정보수정
+ public function modifyInfo($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, $atcl_amt4, $isale_amt, $prem_amt)
+ {
+ $this->db->transStart();
+
+ $usr_id = session('usr_id');
+
+ $detail = $this->getDetail($atcl_vr_sq);
+
+ if ($trade_type != 'B2') {
+ // 월세가 아닐경우에는 월세가에 0으로 ....
+ $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_amt4))
+ $data['deal_amt'] = $atcl_amt4;
+ if (!empty($isale_amt))
+ $data['isale_amt'] = $isale_amt;
+ if (!empty($prem_amt))
+ $data['prem_amt'] = $prem_amt;
+ if (!empty($atcl_floor))
+ $data['floor'] = $atcl_floor;
+ if (!empty($atcl_floor2))
+ $data['floor2'] = $atcl_floor2;
+ $data['modify_yn'] = 'Y';
+
+ $builder = $this->db->table('v2_modify_info');
+ $ok = $builder->where('vr_sq', $atcl_vr_sq)->update($data);
+ if ($ok === false) {
+ return [
+ 'success' => false,
+ 'msg' => '저장 실패',
+ ];
+ }
+
+ $last_query = $this->db->getLastQuery();
+ $current_url = current_url();
+
+
+ $memo = "상세정보수정 ";
+ $this->saveHistory(vr_sq: $detail['vr_sq'], stat_cd: $detail['pre_stat_cd'], chg_type: 'C25', usr_id: $usr_id, memo: $memo);
+
+ $faxModel = new FaxModel();
+ $faxModel->updateAddress($atcl_vr_sq, $detail['address_code'], $data['address2'], $data['address3'], $data['hscp_no'], $data['hscp_nm']);
+
+
+ $this->db->transComplete();
+
+ return [
+ 'success' => true,
+ ];
+
+ }
+
+ public function saveModifyVrfc($atcl_vr_sq, $atcl_vrfc_type)
+ {
+
+ $usr_id = session('usr_id');
+
+ $list = $this->get_detail($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;
+ $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) {
+ // $changed = $this->what_is_changed($list['data'], $data, $atcl_vr_sq);
+ if (!empty($changed)) {
+ $this->saveHistory($list['data']['vr_sq'], $list['data']['pre_stat_cd'], 'C25', $usr_id, "상세정보 수정");
+ }
+ }
+ }
+ $this->db->transComplete();
+ return $return;
+ }
+
+ 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 = [
+ $err_sq,
+ $err_code,
+ $err_nm,
+ $err_time,
+ $err_no,
+ $err_server
+ ];
+
+ $this->db->query($sql, $data);
+ }
+
// 상태변경
public function chgArticleStatus($data)
{
@@ -961,6 +1135,601 @@ class M701Model extends Model
];
}
+ // 현재상태확인
+ public function chkStat($vr_sq)
+ {
+ $sql = "SELECT stat_cd FROM v2_vrfc_req WHERE vr_sq = ?";
+ $data = [
+ $vr_sq
+ ];
+ $query = $this->db->query($sql, $data);
+ return $query->getRowArray();
+ }
+
+ public function chkTryCnt($vr_sq)
+ {
+ $columns = 'a.try_cnt';
+ $builder = $this->db->table('v2_vrfc_req a');
+ $builder->select($columns);
+ $builder->where('vr_sq', $vr_sq);
+ $query = $builder->get();
+
+ return $query->getRowArray();
+ }
+
+ public function chkRegiTryCnt($atcl_vr_sq)
+ { //1차 검증인지 2차 검증인지 확인.
+ $builder = $this->db->table('v2_vrfc_req a');
+ $builder->select('a.reg_try_cnt');
+ $builder->where('vr_sq', $atcl_vr_sq);
+ $query = $builder->get();
+
+ return $query->getRowArray();
+ }
+
+ public function chkConfirm($vr_sq, $reg_yn)
+ {
+ $columns = "a.vr_sq";
+ $builder = $this->db->table('v2_confirm a');
+ $builder->select($columns);
+ $builder->where('vr_sq', $vr_sq);
+
+ if ($reg_yn) {
+ $builder->where('vrfc_type', $reg_yn); // 등기부등본 정보 확인시
+ }
+
+ $query = $builder->get();
+ $result = $query->getNumRows();
+
+ return $result;
+ }
+
+ 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), charger=values(charger)
+ , date=values(date), update_user=values(update_user), update_tm=values(update_tm)";
+
+ $data = [
+ $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);
+ }
+
+ 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 chgStat($vr_sq, $stat_cd, $insert_tm)
+ {
+ $usr_sq = session('usr_sq');
+ $usr_id = session('usr_id');
+
+ $list = $this->getDetail($vr_sq);
+
+ $this->db->transStart();
+
+ $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,
+ ];
+
+ if ($this->db->query($sql, $data) === false) {
+ return [
+ 'success' => false,
+ 'msg' => '저장 실패',
+ ];
+ }
+
+ $this->saveHistory($list['vr_sq'], $stat_cd, 'C9', $usr_id, '서류확인 정보 변경');
+
+ $this->db->transComplete();
+
+ return [
+ 'success' => true,
+ ];
+ }
+
+ 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);
+ }
+
+ 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);
+ }
+
+
+ // 파일정보 저장
+ public function saveFileInfo($file)
+ {
+ $this->db->transStart();
+
+ $fileType = $file['file_type'] ?? '1';
+
+ // 기존 파일 확인
+ $sql = "SELECT seq FROM v2_files WHERE vr_sq = ? AND use_yn = 'Y' AND file_type = ?";
+ $query = $this->db->query($sql, [$file['vr_sq'], $fileType]);
+ $result = $query->getRow();
+
+ if (!empty($result)) {
+ // 기존 파일을 비활성화
+ $sql = "UPDATE v2_files SET use_yn = 'N' WHERE vr_sq = ? AND file_type = ?";
+ $this->db->query($sql, [$file['vr_sq'], $fileType]);
+ }
+
+ // 새 파일 정보 INSERT
+ $data = [
+ 'vr_sq' => $file['vr_sq'],
+ 'use_yn' => 'Y',
+ 'file_type' => $fileType,
+ 'view_odr' => $file['view_odr'] ?? 0,
+ 'file_path' => $file['file_path'],
+ 'file_name' => $file['new_name'],
+ 'file_ext' => $file['ext'],
+ 'file_size' => $file['size'],
+ 'insert_user' => session('usr_sq'),
+ 'insert_tm' => date('Y-m-d H:i:s'),
+ 'cloud_upload_yn' => 'Y',
+ ];
+
+ $builder = $this->db->table('v2_files');
+ $builder->insert($data);
+
+ $this->db->transComplete();
+ }
+
+ public function insertChkList($vr_sq, $vrfc_type, $type, $code, $comment)
+ {
+ if (is_array($comment)) {
+ $comment = implode('|', $comment);
+ }
+
+ $usr_sq = $this->session->userdata('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 = [
+ $vr_sq,
+ $vrfc_type,
+ $type,
+ $code,
+ $comment,
+ $usr_sq
+ ];
+
+
+ $res = $this->db->query($sql, $data);
+ }
+
+ 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 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);
+ }
+
+ /**
+ * 검증결과 전송 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]);
+ $rowVrfcReq = $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]);
+ $rowArticleInfo = $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]);
+ $rowModifyInfo = $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, $rowVrfcReq['vrfc_type']]);
+ $rowConfirm = $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, $rowVrfcReq['vrfc_type']]);
+ $resCheckList = $query->getResultArray();
+
+ log_message('debug', $this->db->getLastQuery());
+
+ if (!empty($rowConfirm)) {
+ log_message('debug', implode(', ', $rowConfirm));
+ }
+
+ $atclNo = $rowVrfcReq['atcl_no'] ?? null;
+ $success = !empty($rowConfirm['success']);
+ $charger = $rowConfirm['charger'] ?? null;
+ $date = $rowConfirm['date'] ?? null;
+ $tryCnt = $rowVrfcReq['try_cnt'] ?? 0;
+
+ $checkList = [];
+ foreach ($resCheckList as $row) {
+ $checkList[] = [
+ 'type' => $row['type'],
+ 'code' => $row['code'],
+ 'comment' => $row['comment'],
+ 'ownerNm' => $row['ownerNm'],
+ 'ownerBirth' => $row['ownerBirth'],
+ ];
+ }
+
+ $modifyInfo = [];
+ if (($rowModifyInfo['modify_yn'] ?? 'N') === 'Y') {
+ if (!empty($rowModifyInfo['hscp_no'])) {
+ // 공동주택
+ $modifyInfo = [
+ 'hscpNo' => $rowModifyInfo['hscp_no'],
+ 'ptpNo' => $rowModifyInfo['ptp_no'],
+ 'bildNm' => $rowModifyInfo['address2'],
+ 'rmNo' => $rowModifyInfo['address3'],
+ 'tradeType' => $rowModifyInfo['trade_type'],
+ 'dealAmt' => $rowModifyInfo['deal_amt'],
+ 'wrrntAmt' => $rowModifyInfo['wrrnt_amt'],
+ 'leaseAmt' => $rowModifyInfo['lease_amt'],
+ 'isaleAmt' => $rowModifyInfo['isale_amt'],
+ 'premAmt' => $rowModifyInfo['prem_amt'],
+ 'floor' => $rowModifyInfo['floor'],
+ ];
+ } else {
+ // 비공동주택
+ $modifyInfo = [
+ 'addressCode' => $rowModifyInfo['address_code'],
+ 'address2' => $rowModifyInfo['address2'],
+ 'address3' => $rowModifyInfo['address3'],
+ 'tradeType' => $rowModifyInfo['trade_type'],
+ 'dealAmt' => $rowModifyInfo['deal_amt'],
+ 'wrrntAmt' => $rowModifyInfo['wrrnt_amt'],
+ 'leaseAmt' => $rowModifyInfo['lease_amt'],
+ 'splySpc' => $rowModifyInfo['sply_spc'],
+ 'exclsSpc' => $rowModifyInfo['excls_spc'],
+ 'totSpc' => $rowModifyInfo['tot_spc'],
+ 'grndSpc' => $rowModifyInfo['grnd_spc'],
+ 'bldgSpc' => $rowModifyInfo['bldg_spc'],
+ 'floor' => $rowModifyInfo['floor'],
+ 'floor2' => $rowModifyInfo['floor2'],
+ ];
+ }
+
+ return [
+ 'atclNo' => $atclNo,
+ 'success' => $success,
+ 'checkList' => $checkList,
+ 'charger' => $charger,
+ 'modifyInfo' => $modifyInfo,
+ 'date' => $date,
+ 'try_cnt' => $tryCnt,
+ ];
+ }
+
+ return [
+ 'atclNo' => $atclNo,
+ 'success' => $success,
+ 'checkList' => $checkList,
+ 'charger' => $charger,
+ 'date' => $date,
+ 'try_cnt' => $tryCnt,
+ ];
+ }
+
+ /* 등기부등본 API 호출*/
+ /**
+ * $vrfc_type: 값이 R이면 등기부등본
+ */
+ 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, reg_try_cnt, owner_verifiable
+ FROM v2_vrfc_req WHERE vr_sq = ?";
+ $query = $this->db->query($sql, [$vr_sq]);
+ $rowVrfcReq = $query->getRowArray();
+
+ if (!empty($vrfc_type)) {
+ $rowVrfcReq['vrfc_type'] = $vrfc_type;
+ }
+
+ log_message('debug', (string) $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]);
+ $rowArticleInfo = $query->getRowArray();
+
+ log_message('debug', (string) $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]);
+ $rowModifyInfo = $query->getRowArray();
+
+ log_message('debug', (string) $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, $rowVrfcReq['vrfc_type']]);
+ $rowConfirm = $query->getRowArray();
+
+ log_message('debug', (string) $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, $rowVrfcReq['vrfc_type']]);
+ $resCheckList = $query->getResultArray();
+
+ log_message('debug', (string) $this->db->getLastQuery());
+
+ if (!empty($rowConfirm)) {
+ log_message('debug', implode(', ', $rowConfirm));
+ }
+
+ $atclNo = $rowVrfcReq['atcl_no'] ?? null;
+ $type = $rowVrfcReq['try_cnt'] ?? null;
+ $success = !empty($rowConfirm['success']);
+ $charger = $rowConfirm['charger'] ?? null;
+ $date = $rowConfirm['date'] ?? null;
+
+ switch ($rowVrfcReq['owner_verifiable'] ?? null) {
+ case '1':
+ case 'true':
+ $ownerVerifiable = true;
+ break;
+ default:
+ $ownerVerifiable = false;
+ break;
+ }
+
+ $checkList = [];
+ foreach ($resCheckList as $row) {
+ $checkList[] = [
+ 'type' => $row['type'],
+ 'code' => $row['code'],
+ 'comment' => $row['comment'],
+ 'ownerNm' => $row['ownerNm'],
+ 'ownerBirth' => $row['owner_birth'],
+ ];
+ }
+
+ $modifyInfo = [];
+ if (($rowModifyInfo['modify_yn'] ?? 'N') === 'Y') {
+ if (!empty($rowModifyInfo['hscp_no'])) {
+ $modifyInfo = [
+ 'hscpNo' => $rowModifyInfo['hscp_no'],
+ 'ptpNo' => $rowModifyInfo['ptp_no'],
+ 'bildNm' => $rowModifyInfo['address2'],
+ 'rmNo' => $rowModifyInfo['address3'],
+ 'tradeType' => $rowModifyInfo['trade_type'],
+ 'dealAmt' => $rowModifyInfo['deal_amt'],
+ 'wrrntAmt' => $rowModifyInfo['wrrnt_amt'],
+ 'leaseAmt' => $rowModifyInfo['lease_amt'],
+ 'isaleAmt' => $rowModifyInfo['isale_amt'],
+ 'premAmt' => $rowModifyInfo['prem_amt'],
+ 'floor' => $rowModifyInfo['floor'],
+ ];
+ } else {
+ $modifyInfo = [
+ 'addressCode' => $rowModifyInfo['address_code'],
+ 'address2' => $rowModifyInfo['address2'],
+ 'address3' => $rowModifyInfo['address3'],
+ 'tradeType' => $rowModifyInfo['trade_type'],
+ 'dealAmt' => $rowModifyInfo['deal_amt'],
+ 'wrrntAmt' => $rowModifyInfo['wrrnt_amt'],
+ 'leaseAmt' => $rowModifyInfo['lease_amt'],
+ 'splySpc' => $rowModifyInfo['sply_spc'],
+ 'exclsSpc' => $rowModifyInfo['excls_spc'],
+ 'totSpc' => $rowModifyInfo['tot_spc'],
+ 'grndSpc' => $rowModifyInfo['grnd_spc'],
+ 'bldgSpc' => $rowModifyInfo['bldg_spc'],
+ 'floor' => $rowModifyInfo['floor'],
+ 'floor2' => $rowModifyInfo['floor2'],
+ ];
+ }
+
+ return [
+ 'atclNo' => $atclNo,
+ 'type' => $type,
+ 'success' => $success,
+ 'checkList' => $checkList,
+ 'charger' => $charger,
+ 'modifyInfo' => $modifyInfo,
+ 'date' => $date,
+ 'ownerVerifiable' => $ownerVerifiable,
+ ];
+ }
+
+ return [
+ 'atclNo' => $atclNo,
+ 'type' => $type,
+ 'success' => $success,
+ 'checkList' => $checkList,
+ 'charger' => $charger,
+ 'date' => $date,
+ 'ownerVerifiable' => $ownerVerifiable,
+ ];
+ }
+
+ 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
+ );
+
+ $this->db->query($sql, $data);
+ }
+
+ public function getUpdateFailTime1($vr_sq)
+ {
+ $sql = "select vr_sq, stat_cd, insert_user, insert_tm " .
+ "from v2_chg_stat " .
+ "where vr_sq = ? and stat_cd = '39' " .
+ "order by insert_tm desc " .
+ "limit 1";
+ $data = array($vr_sq);
+ $query = $this->db->query($sql, $data);
+ $row = $query->getRowArray();
+
+ return $row;
+
+ }
+
+ public function getUpdateFailTime2($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 deleteChkList($vr_sq, $vrfc_type, $type)
+ {
+ $sql = "delete from v2_check_list where vr_sq = ? and vrfc_type = ? and type = ?";
+ $data = array(
+ $vr_sq,
+ $vrfc_type,
+ $type
+ );
+ $this->db->query($sql, $data);
+ }
+
+ public function up_tel_fail_cause($vr_sq, $tel_fail_cause)
+ {
+ $sql = "UPDATE v2_vrfc_req" .
+ " SET tel_fail_cause = ? " .
+ " WHERE vr_sq = ?";
+
+ $data = array(
+ $tel_fail_cause,
+ $vr_sq
+ );
+
+ $this->db->query($sql, $data);
+ }
// 변경이력 저장
public function saveHistory($vr_sq, $stat_cd, $chg_type, $usr_id, $memo)
diff --git a/app/Models/v2/M710Model.php b/app/Models/v2/M710Model.php
index fd5e86e..3c876d5 100644
--- a/app/Models/v2/M710Model.php
+++ b/app/Models/v2/M710Model.php
@@ -704,4 +704,19 @@ class M710Model extends Model
}
+ 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;
+ }
}
\ No newline at end of file
diff --git a/app/Views/pages/v2/m701/detail.php b/app/Views/pages/v2/m701/detail.php
index 2f0f6cb..094fddc 100644
--- a/app/Views/pages/v2/m701/detail.php
+++ b/app/Views/pages/v2/m701/detail.php
@@ -101,241 +101,210 @@ if (!empty($data['cert_register']) && $data['cert_register_save_yn'] != 'Y') { /
-
-
-| 매물ID : = $data['atcl_no'] ?> - | -CP ID : = $data['cpid'] ?> | -현재 상태 - : = $data['pre_stat'] ?> | -
| - | - | - |
| 중개사명 | -= $data['realtor_nm'] ?> | -대표전화 | -= $data['realtor_tel_no'] ?> | -
|---|
| 단지명 | += $detail_hscp['aptName']; ?> | +소재주소 | += $detail_hscp['addr']; ?> | +상세주소 | += $detail_hscp['dtlAddr']; ?> | +사용승인일 | += $detail_hscp['useAprvYmd']; ?> | +단지 총 동수 | += $detail_hscp['dongCount']; ?> | +
|---|
| 단지명 | += $detail_hscp['villaName']; ?> | +단지타입명 | += $detail_hscp['villaTypeName']; ?> | +단지 총 세대수 | += $detail_hscp['totHsehCnt']; ?> | +단지 총 동수 | += $detail_hscp['totDongCnt']; ?> | + +주소(광역시/도) | += $detail_hscp['city']; ?> | +주소(시군구) | += $detail_hscp['dvsn']; ?> | + +주소(읍면동) | += $detail_hscp['sec']; ?> | +소재 동이하 상세주소 | += $detail_hscp['dtlAddr']; ?> | +||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 소재 주소(전체) | += $detail_hscp['addr']; ?> | +||||||||||||||||
|
+
+
+
+ + +
+
+
+
+
+ + + + + + +
+
+
+
+
+ + + + + + + +
+
+
+ 등기부등본
+ 보기
+ 홍보확인서 보기
+
+ |
+
+
+
+
|
+
| 진행상태 | +변경내용 | +처리자(ID) | +처리일시 | +세부내용 | +||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| = $h['stat_cd_nm'] ?> | += $h['chg_type'] ?> | += $h['insert_id'] ?> | += $h['insert_tm'] ?> | += $h['memo'] ?> | -
| 진행상태 | -변경내용 | -처리자(ID) | -처리일시 | -세부내용 | -
|---|---|---|---|---|
| = $h['stat_cd_nm'] ?> | -= $h['chg_type'] ?> | -= $h['insert_id'] ?> | -= $h['insert_tm'] ?> | -= $h['memo'] ?> | - + - -