<?php
/**
* Hangang System inc.
*
* Customer Doc Class
* 고객 증빙 서류 upload 클래스 정보
* 2019.11.04
*
*/
class Customer_Doc
{
public static $instance ;
private $c_db = NULL ;
private $results = NULL ;
private $agent_id = NULL ;
private $contract_kind = NULL ;
private $current_password = NULL ;
private $work_kind = NULL;
private $ContractInfo = NULL;
private $DocumentInfo = NULL;
public function __construct()
{
$this->c_db = DBController::getInstance() ;
}
public static function getInstance()
{
if (!isset(self::$instance)) {
$c = __CLASS__;
self::$instance = new $c;
}
return self::$instance;
}
public function check_login($market_code, $agent_id)
{
$results = $this->c_db->SQLGetRow("GET_GROUP_LOGIN_USER", array($market_code, $agent_id));
if( $results == false )
{
return false;
}
else
{
$this->makeSession($results);
}
$this->c_db->disconn();
return true ;
}
public function getResult()
{
return $this->results;
}
public function makeSession($results)
{
@logHandler
(PEAR_LOG_INFO
, "Make Session : ". print_r($results, true), $PHP_SELF, __FILE__, __LINE__ ) ;
$this->results = $results;
}
public function setContractInfo($con_info)
{
// Hangang_auto_start (autopay - upload)
/* 작업 정보 */
if ($con_info['contract_kind'] =="P")
{
if ($con_info['activity_code'] == "C84"){
$this->ContractInfo = $this->c_db->SQLGetRow('GET_REC_PAYMENT_METHOD_HISTORY', array($con_info['market_code'], $con_info['work_group'])) ; }
else{
$this->ContractInfo = $this->c_db->SQLGetRow('GET_REC_CCM_WORK_GROUP', array($con_info['market_code'], $con_info['work_group'], CCM_WORK_STATUS_COMPLETE
)) ; }
{
throw new Exception (ERROR_CODE_NO_WORK_GROUP);
}
}
// Hangang_auto_end
// 2018.10.17 ==> for encryption password
{
$customerInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_PASSWORD_INFO', array($con_info['market_code'], $con_info['cid'] )) ;
{
@logHandler(PEAR_LOG_ERR, "GET_CUSTOMER_PASSWORD_INFO FAILURE", $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_NO_WORK_GROUP);
}
if( strlen($customerInfo['BIRTHDAY']) == 6) {
$this->ContractInfo['CUSTYYMMDD'] = $customerInfo['BIRTHDAY'];
}
elseif( strlen($customerInfo['BIRTHDAY']) == 10 ) {
$this->ContractInfo['CUSTYYMMDD'] = substr($customerInfo['BIRTHDAY'],0,6); }
else
{
$this->ContractInfo['CUSTYYMMDD'] = substr($customerInfo['REP_ID'],0,6); }
}
// 2018.10.17 ==> for encryption password
$this->ContractInfo['INFO'] = $con_info;
//폴더명과 파일명 세팅처리
if (!$this->ContractInfo['INFO']['seq'])
{
$folder_name = $this->getPDFServerFolderName();
$file_name = $this->getPDFServerFileName();
$this->ContractInfo['INFO']['seq'] = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_SEQ',array($this->ContractInfo['INFO']['market_code'], $this->ContractInfo['INFO']['cid']));
$file_name .= "_".$this->ContractInfo['INFO']['seq'].".pdf";
$this->ContractInfo['INFO']['folder_name'] =$folder_name;
$this->ContractInfo['INFO']['file_name'] =$file_name;
}
@logHandler
(PEAR_LOG_INFO
, print_r($this->ContractInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ; }
public function getContractInfo()
{
return $this->ContractInfo;
}
//------------------------------------------------------------
// insert Document -- 이 부분 다시 수정해야 한다.
public function insertDocumentInfo($doc_info) {
$seq_cnt = $this->c_db->SQLGetOne('GET_CUSTOMER_DOCUMENT_SEQ', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'] ));
if($seq_cnt = 2) {
if( false == $this->c_db->SQLExecute('UPD_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt - 1)) ) throw new Exception(ERROR_CODE_DB_FAILURE);
} else if($seq_cnt > 2) {
if( false == $this->c_db->SQLExecute('INS_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt)) ) throw new Exception(ERROR_CODE_DB_FAILURE);
}
}
// set Document
public function setDocumentInfo($doc_info, $ext) {
// Hangang_auto_end
// 2018.10.17 ==> for encryption password
/*
{
$customerInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_PASSWORD_INFO', array($con_info['market_code'], $con_info['cid'] )) ;
if(! is_array($customerInfo))
{
@logHandler(PEAR_LOG_ERR, "GET_CUSTOMER_PASSWORD_INFO FAILURE", $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_NO_WORK_GROUP);
}
if( strlen($customerInfo['BIRTHDAY']) == 6)
{
$this->DocumentInfo['CUSTYYMMDD'] = $customerInfo['BIRTHDAY'];
}
elseif( strlen($customerInfo['BIRTHDAY']) == 10 )
{
$this->DocumentInfo['CUSTYYMMDD'] = substr($customerInfo['BIRTHDAY'],0,6);
}
else
{
$this->DocumentInfo['CUSTYYMMDD'] = substr($customerInfo['REP_ID'],0,6);
}
}
*/
$seq_cnt = $this->c_db->SQLGetOne('GET_CUSTOMER_DOCUMENT_SEQ', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'] )); $seq_cnt = $seq_cnt - 1;
$this->DocumentInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_DOCUMENT_INFO', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt));
throw new Exception (ERROR_CODE_NO_WORK_GROUP);
}
$this->DocumentInfo['INFO'] = $doc_info;
//폴더명과 파일명 세팅처리
if (!$this->DocumentInfo['INFO']['seq']) {
$folder_name = $this->getDocumentFolderName();
$file_name = $this->getDocumentFileName();
$this->DocumentInfo['INFO']['seq'] = $seq_cnt;
$file_name .= "_" . $this->DocumentInfo['INFO']['seq'] . "." . $ext;
$this->DocumentInfo['INFO']['folder_name'] = $folder_name;
$this->DocumentInfo['INFO']['file_name'] = $file_name;
}
@logHandler
(PEAR_LOG_INFO
, print_r($this->DocumentInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ;
}
public function getDocumentInfo() {
return $this->DocumentInfo;
}
//ftp 서버 접속
public function _connect_ftpServer()
{
$msg = "";
$c_imgServer = ImageServer::getInstance() ;
$imgServerInfo = $c_imgServer->getImageServerInfo();
if($imgServerInfo['SERVER_IP'] == "" || $imgServerInfo['SERVER_PORT'] == "" || $imgServerInfo['USER_ID'] == "")
{
@logHandler(PEAR_LOG_ERR, "No ImageServer FTP Server Connection Info", $PHP_SELF, __FILE__, __LINE__ ) ;
@logHandler
(PEAR_LOG_ERR
, print_r($imgServerInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ; throw new Exception (ERROR_CODE_NO_INF_INFO);
}
$this->ftp_conn = @ftp_connect ($imgServerInfo['SERVER_IP'], $imgServerInfo['SERVER_PORT'] );
if(false == $this->ftp_conn)
{
@logHandler(PEAR_LOG_ERR, "FTP Server Connection Failure [{$imgServerInfo['SERVER_IP']}[{$imgServerInfo['SERVER_PORT']}]", $PHP_SELF, __FILE__, __LINE__ ) ;
// throw new Exception (ERROR_CODE_ERR_INF_SERVER);
}
if(false == @ftp_login($this->ftp_conn, $imgServerInfo['USER_ID'], $imgServerInfo['USER_PW'])) {
@logHandler(PEAR_LOG_ERR, "FTP Server Login Failure [{$imgServerInfo['USER_ID']}[{$imgServerInfo['USER_PW']}]", $PHP_SELF, __FILE__, __LINE__ ) ;
//throw new Exception (ERROR_CODE_ERR_INF_SERVER);
}else{
@logHandler(PEAR_LOG_INFO, "set ftp to passive mode.".FTP_MODE, $PHP_SELF, __FILE__, __LINE__ );
ftp_pasv($this->ftp_conn, FTP_MODE
=="PASSIVE" ); }
if( $imgServerInfo['FOLDER'] )
{
@ftp_chdir($this->ftp_conn, $imgServerInfo['FOLDER']); }
}
//계약서 upload
// 2018.10.17 ==> for encryption password
//public function _uploadImageServerPDF($contract_kind, $att_file_info = array())
public function _uploadImageServerPDF
($contract_kind, $att_file_info = array(), $enc_password) // 2018.10.17 ==> for encryption password
{
$this->_connect_ftpServer();
if( !is_file( $att_file_info['tmp_name'] ) ) {
@logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach : " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
try
{
// 2018.10.17 ==> for encryption password
//$this->_saveImageServerPDF($att_file_info, $contract_kind);
$this->_saveImageServerPDF($att_file_info, $contract_kind, $enc_password);
// 2018.10.17 ==> for encryption password
}
catch (Exception $e)
{
throw $e;
}
}
// 고객 증빙 서류 업로드
public function _uploadDocumentServer
($att_file_info = array()) {
$this->_connect_ftpServer();
if( !is_file( $att_file_info['tmp_name'] ) ) {
@logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach : " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
try
{
// 2018.10.17 ==> for encryption password
//$this->_saveImageServerPDF($att_file_info, $contract_kind);
//$this->_saveImageServerPDF($att_file_info, $contract_kind, $enc_password);
$this->_saveDocumentServer($att_file_info);
}
catch (Exception $e)
{
throw $e;
}
}
public function _saveDocumentServer($att_file_info) {
if( !is_file( $att_file_info['tmp_name'] ) ) {
@logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach : " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
$folder = $this->DocumentInfo['INFO']['folder_name'];
$file = $this->DocumentInfo['INFO']['file_name'];
$parts = explode('/',$folder); // SOID/YYYY/MMDD foreach($parts as $part)
{
{
}
}
// $tmpfile = TMP_DIR . "/" . uniqid();
$tmpfile = TMP_DIR . "/" . $file;
/* DRM 해지 처리 : 2018.08.28 */
if(isDRMEncryptedFile($tmpfile))
{
$encfile = TMP_DIR . "/enc_" . $file;
if(doDRMExtract($tmpfile, $encfile))
{
$tmpfile = $encfile;
}
}
/*
// 2018.10.17 ==> for encryption password
$exec_command = PDFSECURE_PROGRAM . " --encrypt '{$enc_password}' '' 128 --use-aes=y -- " . $tmpfile . " " . $tmpfile . "__enc_pass";
@logHandler(PEAR_LOG_INFO, $exec_command , $PHP_SELF, __FILE__, __LINE__ ) ;
exec( $exec_command );
if( !is_file( $tmpfile . "__enc_pass" ) )
{
@logHandler(PEAR_LOG_ERR, "NO FILE Found (Secured Applied) : " . $tmpfile . "__enc_pass", $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
}
$tmpfile = $tmpfile . "__enc_pass";
// 2018.10.17 ==> for encryption password
*/
if(!@ftp_put($this->ftp_conn, $file, $tmpfile, FTP_BINARY
)) {
@logHandler(PEAR_LOG_ERR, "FTP upload Failure : " . $tmpfile . " ===> $file ", $PHP_SELF, __FILE__, __LINE__ ) ;
// throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
// Hangang_auto_start (autopay - upload)
//개인 계약서 일 경우 cid_install_barcode 에 저장한다.
/*
if (($this->ContractInfo['INFO']['contract_kind']=="P") && ($this->ContractInfo['INFO']['activity_code']!="C84"))
// if ($this->ContractInfo['INFO']['contract_kind']=="P")
{
@logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode", $PHP_SELF, __FILE__, __LINE__ );
$this->insertBarcode();
}
*/
// Hangang_auto_end
//신규테이블에 계약서 upload 정보를 저장한다.
//@logHandler(PEAR_LOG_INFO, "Insert into customer_document", $PHP_SELF, __FILE__, __LINE__ );
/*
$this->insertGroupContract();
//insert ccm_memo
@logHandler(PEAR_LOG_INFO, "Insert into ccm_memo", $PHP_SELF, __FILE__, __LINE__ );
$sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 업로드]":"작업상태:[단체 계약서 업로드]";
$usr_memo_text = "1.파일명: [".$this->ContractInfo['INFO']['file_name']."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
$this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);
// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
//insert payment_method_history
@logHandler(PEAR_LOG_INFO, "Insert into payment_method_history", $PHP_SELF, __FILE__, __LINE__ );
$this->insertPaymentMethodHistory();
// Hangang_auto_end
$this->commit();
*/
// 파일 경로 업데이트 - check status = Y 로 바꾸어야 함 .
// $this->updateDocumentFile();
}
/*
public function updateDocumentFile() {
if( false == $this->c_db->SQLExecute('UPD_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt)) )
throw new Exception(ERROR_CODE_DB_FAILURE);
}
*/
//계약서 서버 저장
// 2018.10.17 ==> for encryption password
//public function _saveImageServerPDF($att_file_info, $contract_kind)
public function _saveImageServerPDF($att_file_info, $contract_kind, $enc_password)
// 2018.10.17 ==> for encryption password
{
if( !is_file( $att_file_info['tmp_name'] ) ) {
@logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach : " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
$folder = $this->ContractInfo['INFO']['folder_name'];
$file = $this->ContractInfo['INFO']['file_name'];
$parts = explode('/',$folder); // SOID/YYYY/MMDD foreach($parts as $part)
{
{
}
}
$tmpfile = TMP_DIR
. "/" . uniqid();
/* DRM 해지 처리 : 2018.08.28 */
if(isDRMEncryptedFile($tmpfile))
{
$encfile = TMP_DIR
. "/enc_" . uniqid(); if(doDRMExtract($tmpfile, $encfile))
{
$tmpfile = $encfile;
}
}
// 2018.10.17 ==> for encryption password
$exec_command = PDFSECURE_PROGRAM . " --encrypt '{$enc_password}' '' 128 --use-aes=y -- " . $tmpfile . " " . $tmpfile . "__enc_pass";
@logHandler(PEAR_LOG_INFO, $exec_command , $PHP_SELF, __FILE__, __LINE__ ) ;
if( !is_file( $tmpfile . "__enc_pass" ) ) {
@logHandler(PEAR_LOG_ERR, "NO FILE Found (Secured Applied) : " . $tmpfile . "__enc_pass", $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
}
$tmpfile = $tmpfile . "__enc_pass";
// 2018.10.17 ==> for encryption password
if(!@ftp_put($this->ftp_conn, $file, $tmpfile, FTP_BINARY
)) {
@logHandler(PEAR_LOG_ERR, "FTP upload Failure : " . $tmpfile . " ===> $file ", $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
}
// Hangang_auto_start (autopay - upload)
//개인 계약서 일 경우 cid_install_barcode 에 저장한다.
if (($this->ContractInfo['INFO']['contract_kind']=="P") && ($this->ContractInfo['INFO']['activity_code']!="C84"))
// if ($this->ContractInfo['INFO']['contract_kind']=="P")
{
@logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode", $PHP_SELF, __FILE__, __LINE__ );
$this->insertBarcode();
}
// Hangang_auto_end
//신규테이블에 계약서 upload 정보를 저장한다.
@logHandler(PEAR_LOG_INFO, "Insert into group_contract_info", $PHP_SELF, __FILE__, __LINE__ );
$this->insertGroupContract();
//insert ccm_memo
@logHandler(PEAR_LOG_INFO, "Insert into ccm_memo", $PHP_SELF, __FILE__, __LINE__ );
$sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 업로드]":"작업상태:[단체 계약서 업로드]";
$usr_memo_text = "1.파일명: [".$this->ContractInfo['INFO']['file_name']."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
$this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);
// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
//insert payment_method_history
@logHandler(PEAR_LOG_INFO, "Insert into payment_method_history", $PHP_SELF, __FILE__, __LINE__ );
$this->insertPaymentMethodHistory();
// Hangang_auto_end
$this->commit();
}
//파일 다운로드
public function _downImageServerPDF($file_name)
{
$this->_connect_ftpServer();
$sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 다운로드]":"작업상태:[단체 계약서 다운로드]";
$usr_memo_text = "1.파일명: [".$file_name."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
$this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);
if(0 < ftp_size($this->ftp_conn, $file_name)) {
if(!ftp_get($this->ftp_conn, TMP_DIR
. "/" . $this->file, $file_name, FTP_BINARY
)) {
@logHandler(PEAR_LOG_ERR, "FTP DownLoad Failure : " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
}
}
else
{
@logHandler(PEAR_LOG_ERR, "FTP FILE NOT EXISTS : " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
prtErr("이미지 서버에 파일({$file_name})이 없습니다.");
return "이미지 서버에 파일({$file_name})이 없습니다.";
}
return TMP_DIR
. "/" . $this->file ; }
// 파일 삭제
public function _deleteImageServerPDF($file_name)
{
$this->_connect_ftpServer();
if(0 < ftp_size($this->ftp_conn, $file_name)) {
{
@logHandler(PEAR_LOG_ERR, "FTP delete Failure : " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
}
}
}
//insert cid_install_barcode
public function insertBarcode()
{
@logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode start", $PHP_SELF, __FILE__, __LINE__ ) ;
$exist = $this->c_db->SQLGetOne('GET_CID_INSTALL_BARCODE_COUNT',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['work_group']
));
if($exist){
if(false == $this->c_db->SQLExecute('UPD_CID_INSTALL_BARCODE',
"Y" // --scan_yn
,$this->ContractInfo['INFO']['agree_yn'] // -- agree_yn
,$this->ContractInfo['INFO']['agree_yn2'] // -- agree_yn2
,$this->ContractInfo['INFO']['agree_yn3'] // -- agree_yn3
,$this->ContractInfo['INFO']['agree_yn4'] // -- agree_yn4
,$this->ContractInfo['INFO']['agent_id'] // -- scan_agent
,""
,"" // -- post_gubun
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['work_group']
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}else{
if(false == $this->c_db->SQLExecute('INS_CID_INSTALL_BARCODE',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['work_group']
,$this->ContractInfo['WORK_REG_DATE']
,$this->ContractInfo['ACTIVITY_CODE']
,"1"
,$this->ContractInfo['INFO']['agent_id']
,"FTP" // -- sys_application_id
,"INS" // -- dl_service_code
,"0" // -- dl_update_stamp
,$this->ContractInfo['FULL_NAME'] // -- full_name
,$this->ContractInfo['CID_STATUS'] // -- cid_status
,"W" // -- keep_status
,substr($this->ContractInfo['WORK_DATETIME'], 0, 8) // -- actv_date ,$this->ContractInfo['INFO']['agent_id'] // -- actv_agent
,"Y" // -- scan_yn
,$this->ContractInfo['INFO']['agree_yn'] // -- agree_yn
,$this->ContractInfo['INFO']['agree_yn2'] // -- agree_yn2
,$this->ContractInfo['INFO']['agree_yn3'] // -- agree_yn3
,$this->ContractInfo['INFO']['agree_yn4'] // -- agree_yn4
,"" // -- doc_type
,$this->ContractInfo['INFO']['agent_id'] // -- scan_agent
,"" // -- post_gubun
,""
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
@logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode end", $PHP_SELF, __FILE__, __LINE__ ) ;
}
//install group_contract_info
public function insertGroupContract()
{
@logHandler(PEAR_LOG_INFO, "Insert into group_contract_info start", $PHP_SELF, __FILE__, __LINE__ ) ;
$exist = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_COUNT',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
));
if($exist){
//기존 이력 저장
$this->insertGroupHistory();
if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO',
$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['agent_id'] // --reg_agent_id
,$this->ContractInfo['INFO']['remark'] // --remark
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
else
{ //신규저장
if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO',
$this->ContractInfo['INFO']['market_code'] // --market_code
,$this->ContractInfo['INFO']['cid'] // --cid
,$this->ContractInfo['INFO']['seq'] // --seq
,date('Ymd') // --reg_date ,$this->ContractInfo['INFO']['agent_id'] // --reg_agent_id
,$this->ContractInfo['INFO']['contract_kind'] // --contract_kind
,$this->ContractInfo['INFO']['contract_type'] // --contract_type
,$this->ContractInfo['INFO']['work_group'] // --work_group
,$this->ContractInfo['ACTIVITY_CODE'] // --activity_code
,$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['folder_name'] // --folder_name
,$this->ContractInfo['INFO']['file_name'] // --file_name
,"Y" // --flag
,$this->ContractInfo['INFO']['remark'] // --remark
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
//$this->commit();
@logHandler(PEAR_LOG_INFO, "Insert into group_contract_info end", $PHP_SELF, __FILE__, __LINE__ ) ;
}
//install customer_document
public function insertCustomerDocument()
{
@logHandler(PEAR_LOG_INFO, "Insert into customer_document start", $PHP_SELF, __FILE__, __LINE__ ) ;
$exist = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_COUNT',
$this->DocumentInfo['INFO']['market_code']
,$this->DocumentInfo['INFO']['cid']
,$this->DocumentInfo['INFO']['seq']
));
if($exist){
//기존 이력 저장
$this->insertDocumentHistory();
if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO',
$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['agent_id'] // --reg_agent_id
,$this->ContractInfo['INFO']['remark'] // --remark
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
else
{ //신규저장
if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO',
$this->ContractInfo['INFO']['market_code'] // --market_code
,$this->ContractInfo['INFO']['cid'] // --cid
,$this->ContractInfo['INFO']['seq'] // --seq
,date('Ymd') // --reg_date ,$this->ContractInfo['INFO']['agent_id'] // --reg_agent_id
,$this->ContractInfo['INFO']['contract_kind'] // --contract_kind
,$this->ContractInfo['INFO']['contract_type'] // --contract_type
,$this->ContractInfo['INFO']['work_group'] // --work_group
,$this->ContractInfo['ACTIVITY_CODE'] // --activity_code
,$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['folder_name'] // --folder_name
,$this->ContractInfo['INFO']['file_name'] // --file_name
,"Y" // --flag
,$this->ContractInfo['INFO']['remark'] // --remark
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
//$this->commit();
@logHandler(PEAR_LOG_INFO, "Insert into group_contract_info end", $PHP_SELF, __FILE__, __LINE__ ) ;
}
//insert group_contract_info_his
public function insertGroupHistory()
{
if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO_HIS',
$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['market_code'] // --market_code
,$this->ContractInfo['INFO']['cid'] // --cid
,$this->ContractInfo['INFO']['seq'] // --seq
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
//insert customer_document_his
public function insertDocumentHistory()
{
if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO_HIS',
$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['market_code'] // --market_code
,$this->ContractInfo['INFO']['cid'] // --cid
,$this->ContractInfo['INFO']['seq'] // --seq
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
}
//비고항목및 동의항목 수정
public function editContract()
{
//기존 이력 저장
$this->insertGroupHistory();
if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO_DATA',
$this->ContractInfo['INFO']['agent_id'] // --sys_operator_id
,$this->ContractInfo['INFO']['contract_type']
,$this->ContractInfo['INFO']['reg_agent_id']
,$this->ContractInfo['INFO']['remark']
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
if ($this->ContractInfo['INFO']['contract_kind'] == "P")
{
$sys_memo_text = "작업내역:[개인 계약서 정보 수정]";
$usr_memo_text = "1.변경사항:[비고 - ".$this->ContractInfo['INFO']['remark']."],3.작업그룹:[".$this->ContractInfo['INFO']['work_group']."] 3.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
}
else
{
$sys_memo_text = "작업내역:[단체 계약서 정보 수정]";
$usr_memo_text = "1.변경사항:[비고 - ".$this->ContractInfo['INFO']['remark']."],2.SEQ_NO:[".$this->ContractInfo['INFO']['seq']."] 3.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
}
$this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);
$this->commit();
}
// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
//insert payment_method_history
public function insertPaymentMethodHistory()
{
@logHandler(PEAR_LOG_INFO, "Insert into payment_method_history start", $PHP_SELF, __FILE__, __LINE__ ) ;
$agree_name = $this->ContractInfo['INFO']['folder_name']."/".$this->ContractInfo['INFO']['file_name'];
if(false == $this->c_db->SQLExecute('UPD_PAYMENT_METHOD_HISTORY',
$agree_name // agree_name
,'SCAN' // agree_type
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['work_group']
)))
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
//$this->commit();
@logHandler(PEAR_LOG_INFO, "Insert into payment_method_history end", $PHP_SELF, __FILE__, __LINE__ ) ;
}
// Hangang_auto_end
//단체계약서 저장이력 삭제
public function deleteContract($file_name)
{
$this->_deleteImageServerPDF($file_name);
//이력삭제
if(false == $this->c_db->SQLExecute('DELETE_GROUP_CONTRACT_INFO_HIS',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
)))
{
throw new Exception(ERROR_CODE_DB_FAILURE);
}
//정보삭제
if(false == $this->c_db->SQLExecute('DELETE_GROUP_CONTRACT_INFO',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['seq']
)))
{
throw new Exception(ERROR_CODE_DB_FAILURE);
}
$sys_memo_text = "작업냐역:[단체 계약서 삭제처리]";
$usr_memo_text = "1.삭제파일명:[".$file_name."],2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
$this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);
$this->commit();
}
public function insertCCM_MEMO($sys_memo_text, $usr_memo_text)
{
if(false == $this->c_db->SQLExecute('INS_CCM_MEMO',
$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid']
,$this->ContractInfo['INFO']['agent_id']
,"0038"
,$sys_memo_text
,$usr_memo_text
,$this->ContractInfo['INFO']['market_code']
,$this->ContractInfo['INFO']['cid'])) )
{
throw new Exception (ERROR_CODE_DB_FAILURE);
}
// $this->commit();
}
//PDF 저장 폴더
public function getPDFServerFolderName()
{
$yyyymmdd = substr($yyyymmdd, 0, 8);
$folder = $this->ContractInfo['INFO']['market_code'] . "/" . substr($yyyymmdd, 0, 4) . "/" . substr($yyyymmdd, -4) ;
return $folder;
}
// 서류 저장 폴더
public function getDocumentFolderName()
{
$yyyymmdd = substr($yyyymmdd, 0, 8);
$folder = $this->DocumentInfo['INFO']['market_code'] . "/" . substr($yyyymmdd, 0, 4) . "/" . substr($yyyymmdd, -4) ;
return $folder;
}
//PDF 파일명
public function getPDFServerFileName()
{
$yyyymmdd = substr($yyyymmdd, 0, 8); $file_name = $this->ContractInfo['INFO']['market_code'] ."_". $this->ContractInfo['INFO']['cid'];
$file_name = ($this->ContractInfo['INFO']['contract_kind'] =="P") ? $file_name ."_". $this->ContractInfo['INFO']['work_group'] ."_". $yyyymmdd : $file_name."_".$yyyymmdd ;
return $file_name ;
}
// 서류 파일명
public function getDocumentFileName()
{
$yyyymmdd = substr($yyyymmdd, 0, 8);
$file_name = $this->DocumentInfo['INFO']['market_code'] ."_". $this->DocumentInfo['INFO']['cid'] ."_". $yyyymmdd ;
//$file_name = ($this->DocumentInfo['INFO']['contract_kind'] =="P") ? $file_name ."_". $this->DocumentInfo['INFO']['work_group'] ."_". $yyyymmdd : $file_name."_".$yyyymmdd ;
return $file_name ;
}
//계약서 종류 가져오기
public function get_contract_type($market_code)
{
$this->c_db = DBController::getInstance();
$_list = $this->c_db->SQLQuery("GET_CONTRACT_TYPE_LIST", array($market_code));
for($i=0; $i < count($_list); $i++) {
$arr[$_list[$i]['CODE_VAL'] ] = $_list[$i]['CODE_STR'];
}
return $arr;
}
public function commit()
{
$this->c_db->commit();
}
public function rollback()
{
$this->c_db->rollback();
}
public function disconn($flag=FALSE)
{
$this->c_db->disconn($flag);
}
//파일정보 재배열 처리
public function multiple
(array $_files, $top = TRUE) {
foreach($_files as $name=>$file){
if($top) $sub_name = $file['name'];
else $sub_name = $name;
$files[$name][$key] = array( 'name' => $file['name'][$key],
'type' => $file['type'][$key],
'tmp_name' => $file['tmp_name'][$key],
'error' => $file['error'][$key],
'size' => $file['size'][$key],
);
$files[$name] = $this->multiple($files[$name], FALSE);
}
}else{
$files[$name] = $file;
}
}
return $files;
}
public function login_chk()
{
if (!$_SESSION['fromSMS'])
{
header("Location: /group_contract/index.php"); }
}
public function prt_return
($str, $url, array $data) {
echo "<script type=\"text/javascript\">alert(\"$str\");</script>";
_user_reaction($url, $data);
}
}
<?php
    /**
     *  Hangang System inc.
     *
     *  Customer Doc Class
     *  고객 증빙 서류 upload 클래스 정보
     *  2019.11.04
     *
     */
    class Customer_Doc
    {
        public static $instance   ;

        private $c_db             = NULL  ;
        private $results          = NULL  ;
        private $agent_id         = NULL  ;
        private $contract_kind    = NULL ;
        private $current_password = NULL ;
        private $work_kind        = NULL;

        private $ContractInfo = NULL;
        
        private $DocumentInfo = NULL;

        public function __construct()
        {
            $this->c_db = DBController::getInstance() ;
        }

        public static function getInstance()
        {
            if (!isset(self::$instance))
            {
                $c = __CLASS__;
                self::$instance = new $c;
            }

            return self::$instance;
        }

        public function check_login($market_code, $agent_id)
        {
            $results = $this->c_db->SQLGetRow("GET_GROUP_LOGIN_USER", array($market_code, $agent_id));

            if( $results == false )
            {
                return false;
            }
            else
            {
                $this->makeSession($results);
            }

            $this->c_db->disconn();
            return true ;
        }

        public function getResult()
        {
            return $this->results;
        }
        public function makeSession($results)
        {
            @logHandler(PEAR_LOG_INFO, "Make Session : ". print_r($results, true), $PHP_SELF, __FILE__, __LINE__ ) ;

            $this->results = $results;
        }

        public function setContractInfo($con_info)
        {
// Hangang_auto_start (autopay - upload)
            /* 작업 정보 */
            if ($con_info['contract_kind'] =="P")
            {
                if ($con_info['activity_code'] == "C84"){
                    $this->ContractInfo = $this->c_db->SQLGetRow('GET_REC_PAYMENT_METHOD_HISTORY', array($con_info['market_code'], $con_info['work_group'])) ;
                }
                else{
                    $this->ContractInfo = $this->c_db->SQLGetRow('GET_REC_CCM_WORK_GROUP', array($con_info['market_code'], $con_info['work_group'], CCM_WORK_STATUS_COMPLETE )) ;
                }

                if(! is_array($this->ContractInfo))
                {
                    throw new Exception (ERROR_CODE_NO_WORK_GROUP);
                }
            }
            
// Hangang_auto_end

            // 2018.10.17 ==> for encryption password
            {
                $customerInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_PASSWORD_INFO', array($con_info['market_code'], $con_info['cid'] )) ;

                if(! is_array($customerInfo))
                {
                    @logHandler(PEAR_LOG_ERR, "GET_CUSTOMER_PASSWORD_INFO FAILURE", $PHP_SELF, __FILE__, __LINE__ ) ;
                    throw new Exception (ERROR_CODE_NO_WORK_GROUP);
                }

                if( strlen($customerInfo['BIRTHDAY']) == 6)
                {
                    $this->ContractInfo['CUSTYYMMDD'] = $customerInfo['BIRTHDAY'];
                }
                elseif( strlen($customerInfo['BIRTHDAY']) == 10 )
                {
                    $this->ContractInfo['CUSTYYMMDD'] = substr($customerInfo['BIRTHDAY'],0,6);
                }
                else
                {
                    $this->ContractInfo['CUSTYYMMDD'] = substr($customerInfo['REP_ID'],0,6);
                }
            }
            // 2018.10.17 ==> for encryption password

            $this->ContractInfo['INFO'] = $con_info;

            //폴더명과 파일명 세팅처리
            if (!$this->ContractInfo['INFO']['seq'])
            {
                $folder_name   = $this->getPDFServerFolderName();
                $file_name     = $this->getPDFServerFileName();

                $this->ContractInfo['INFO']['seq'] = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_SEQ',array($this->ContractInfo['INFO']['market_code'], $this->ContractInfo['INFO']['cid']));

                $file_name    .= "_".$this->ContractInfo['INFO']['seq'].".pdf";
                $this->ContractInfo['INFO']['folder_name'] =$folder_name;
                $this->ContractInfo['INFO']['file_name']   =$file_name;
            }

            @logHandler(PEAR_LOG_INFO, print_r($this->ContractInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ;
        }

        public function getContractInfo()
        {
            return $this->ContractInfo;
        }
               
        //------------------------------------------------------------

				// insert Document -- 이 부분 다시 수정해야 한다.      
 				public function insertDocumentInfo($doc_info) {
 					  $seq_cnt = $this->c_db->SQLGetOne('GET_CUSTOMER_DOCUMENT_SEQ', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'] ));
								
						if($seq_cnt = 2) {
							  if( false == $this->c_db->SQLExecute('UPD_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt - 1)) )
	 					 				throw new Exception(ERROR_CODE_DB_FAILURE);
					  } else if($seq_cnt > 2) {
	 					 		if( false == $this->c_db->SQLExecute('INS_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt)) )
	 					 				throw new Exception(ERROR_CODE_DB_FAILURE);
 						}
 				}      
       
        // set Document
        public function setDocumentInfo($doc_info, $ext) {
          
// Hangang_auto_end

            // 2018.10.17 ==> for encryption password
            /*
            {
                $customerInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_PASSWORD_INFO', array($con_info['market_code'], $con_info['cid'] )) ;

                if(! is_array($customerInfo))
                {
                    @logHandler(PEAR_LOG_ERR, "GET_CUSTOMER_PASSWORD_INFO FAILURE", $PHP_SELF, __FILE__, __LINE__ ) ;
                    throw new Exception (ERROR_CODE_NO_WORK_GROUP);
                }

                if( strlen($customerInfo['BIRTHDAY']) == 6)
                {
                    $this->DocumentInfo['CUSTYYMMDD'] = $customerInfo['BIRTHDAY'];
                }
                elseif( strlen($customerInfo['BIRTHDAY']) == 10 )
                {
                    $this->DocumentInfo['CUSTYYMMDD'] = substr($customerInfo['BIRTHDAY'],0,6);
                }
                else
                {
                    $this->DocumentInfo['CUSTYYMMDD'] = substr($customerInfo['REP_ID'],0,6);
                }
            }
            */         	        
            
						$seq_cnt = $this->c_db->SQLGetOne('GET_CUSTOMER_DOCUMENT_SEQ', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'] ));
  					$seq_cnt = $seq_cnt - 1;
            
            $this->DocumentInfo = $this->c_db->SQLGetRow('GET_CUSTOMER_DOCUMENT_INFO', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt));
            
            if(! is_array($this->DocumentInfo)) {
            	throw new Exception (ERROR_CODE_NO_WORK_GROUP);	   
            } 
            
          
            $this->DocumentInfo['INFO'] = $doc_info;

            //폴더명과 파일명 세팅처리
            if (!$this->DocumentInfo['INFO']['seq']) {
                $folder_name   = $this->getDocumentFolderName();
                $file_name     = $this->getDocumentFileName();

                $this->DocumentInfo['INFO']['seq'] = $seq_cnt;
								
                $file_name     .= "_" . $this->DocumentInfo['INFO']['seq'] . "." . $ext;
                $this->DocumentInfo['INFO']['folder_name'] = $folder_name;
                $this->DocumentInfo['INFO']['file_name']   = $file_name;
            } 

            @logHandler(PEAR_LOG_INFO, print_r($this->DocumentInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ;
            
        }

        public function getDocumentInfo() {
            	return $this->DocumentInfo;
        }

        //ftp 서버 접속
        public function _connect_ftpServer()
        {
            $msg = "";

            $c_imgServer   = ImageServer::getInstance() ;
            $imgServerInfo = $c_imgServer->getImageServerInfo();

            if($imgServerInfo['SERVER_IP'] == "" || $imgServerInfo['SERVER_PORT'] == "" || $imgServerInfo['USER_ID'] == "")
            {
                @logHandler(PEAR_LOG_ERR, "No ImageServer FTP Server Connection Info", $PHP_SELF, __FILE__, __LINE__ ) ;
                @logHandler(PEAR_LOG_ERR, print_r($imgServerInfo, true), $PHP_SELF, __FILE__, __LINE__ ) ;
                throw new Exception (ERROR_CODE_NO_INF_INFO);
            }
						
            $this->ftp_conn = @ftp_connect ($imgServerInfo['SERVER_IP'], $imgServerInfo['SERVER_PORT'] );    
            
            if(false == $this->ftp_conn)
            {
                @logHandler(PEAR_LOG_ERR, "FTP Server Connection Failure [{$imgServerInfo['SERVER_IP']}[{$imgServerInfo['SERVER_PORT']}]", $PHP_SELF, __FILE__, __LINE__ ) ;
                // throw new Exception (ERROR_CODE_ERR_INF_SERVER);
            }
						
            if(false == @ftp_login($this->ftp_conn, $imgServerInfo['USER_ID'], $imgServerInfo['USER_PW']))
            {
                @logHandler(PEAR_LOG_ERR, "FTP Server Login Failure [{$imgServerInfo['USER_ID']}[{$imgServerInfo['USER_PW']}]", $PHP_SELF, __FILE__, __LINE__ ) ;
                ftp_close($this->ftp_conn);
                //throw new Exception (ERROR_CODE_ERR_INF_SERVER);
            }else{
                @logHandler(PEAR_LOG_INFO, "set ftp to passive mode.".FTP_MODE, $PHP_SELF, __FILE__, __LINE__ );
                ftp_pasv($this->ftp_conn, FTP_MODE=="PASSIVE" );
            }
						
            if( $imgServerInfo['FOLDER'] )
            {
                @ftp_chdir($this->ftp_conn, $imgServerInfo['FOLDER']);
            }
        }

        //계약서 upload
        // 2018.10.17 ==> for encryption password
        //public function _uploadImageServerPDF($contract_kind, $att_file_info = array())
        public function _uploadImageServerPDF($contract_kind, $att_file_info = array(), $enc_password)
        // 2018.10.17 ==> for encryption password
        {
            $this->_connect_ftpServer();

            if( !is_file( $att_file_info['tmp_name'] ) )
            {
                @logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach :  " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
                throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
            }

            try
            {
                // 2018.10.17 ==> for encryption password
                //$this->_saveImageServerPDF($att_file_info, $contract_kind);
                $this->_saveImageServerPDF($att_file_info, $contract_kind, $enc_password);
                // 2018.10.17 ==> for encryption password
            }
            catch (Exception $e)
            {
                ftp_close($this->ftp_conn);
                throw $e;
            }

            ftp_close($this->ftp_conn);
        }
        
        // 고객 증빙 서류 업로드
        public function _uploadDocumentServer($att_file_info = array()) {
        	
          $this->_connect_ftpServer();
        	
        	if( !is_file( $att_file_info['tmp_name'] ) )
          {
              @logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach :  " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
              throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
          }
          
        	try
          {
              // 2018.10.17 ==> for encryption password
              //$this->_saveImageServerPDF($att_file_info, $contract_kind);  
              //$this->_saveImageServerPDF($att_file_info, $contract_kind, $enc_password);
              $this->_saveDocumentServer($att_file_info);

          }
          catch (Exception $e)
          {
              ftp_close($this->ftp_conn);
              throw $e;
          }
			
          ftp_close($this->ftp_conn);
          
        }
        
        public function _saveDocumentServer($att_file_info) {
        	if( !is_file( $att_file_info['tmp_name'] ) )
          {
              @logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach :  " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
              throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
          }

          $folder   = $this->DocumentInfo['INFO']['folder_name'];
          $file     = $this->DocumentInfo['INFO']['file_name'];

          $parts = explode('/',$folder); // SOID/YYYY/MMDD
          foreach($parts as $part)
          {
              @ftp_pwd($this->ftp_conn);
              if(!@ftp_chdir($this->ftp_conn, $part))
              {
                  @ftp_pwd($this->ftp_conn);
                  @ftp_mkdir($this->ftp_conn, $part);
                  @ftp_chdir($this->ftp_conn, $part);
              }
          }

          // $tmpfile = TMP_DIR . "/" . uniqid();     
 					$tmpfile = TMP_DIR . "/" . $file;     
          move_uploaded_file($att_file_info['tmp_name'], $tmpfile);


          /* DRM 해지 처리 : 2018.08.28 */         
          if(isDRMEncryptedFile($tmpfile))
          {
              $encfile = TMP_DIR . "/enc_" . $file;
              if(doDRMExtract($tmpfile, $encfile))
              {
                  $tmpfile = $encfile;
              }
          }

/*
          // 2018.10.17 ==> for encryption password
          $exec_command = PDFSECURE_PROGRAM . " --encrypt '{$enc_password}' '' 128 --use-aes=y -- " . $tmpfile . " " . $tmpfile . "__enc_pass";
          @logHandler(PEAR_LOG_INFO, $exec_command , $PHP_SELF, __FILE__, __LINE__ ) ;
          exec( $exec_command );

          if( !is_file( $tmpfile . "__enc_pass" ) )
          {
              @logHandler(PEAR_LOG_ERR, "NO FILE Found (Secured Applied) :  " . $tmpfile . "__enc_pass", $PHP_SELF, __FILE__, __LINE__ ) ;
              throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
          }
          $tmpfile = $tmpfile . "__enc_pass";
          // 2018.10.17 ==> for encryption password
*/

          if(!@ftp_put($this->ftp_conn, $file, $tmpfile, FTP_BINARY))
          {
              @logHandler(PEAR_LOG_ERR, "FTP upload Failure :  " . $tmpfile . " ===> $file ", $PHP_SELF, __FILE__, __LINE__ ) ;
              // throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
          }


// Hangang_auto_start (autopay - upload)
          //개인 계약서 일 경우 cid_install_barcode 에 저장한다.
         /*
          if (($this->ContractInfo['INFO']['contract_kind']=="P") && ($this->ContractInfo['INFO']['activity_code']!="C84"))
//            if ($this->ContractInfo['INFO']['contract_kind']=="P")
          {
              @logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode", $PHP_SELF, __FILE__, __LINE__ );
               $this->insertBarcode();
          }
          */
       
// Hangang_auto_end


          //신규테이블에 계약서 upload 정보를 저장한다.
          //@logHandler(PEAR_LOG_INFO, "Insert into customer_document", $PHP_SELF, __FILE__, __LINE__ );
/*          
          $this->insertGroupContract();

          //insert ccm_memo
          @logHandler(PEAR_LOG_INFO, "Insert into ccm_memo", $PHP_SELF, __FILE__, __LINE__ );

          $sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 업로드]":"작업상태:[단체 계약서 업로드]";
          $usr_memo_text = "1.파일명: [".$this->ContractInfo['INFO']['file_name']."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
          $this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);

// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
          //insert payment_method_history
          @logHandler(PEAR_LOG_INFO, "Insert into payment_method_history", $PHP_SELF, __FILE__, __LINE__ );
          $this->insertPaymentMethodHistory();
// Hangang_auto_end

          $this->commit();
          
          */
          
          // 파일 경로 업데이트 - check status = Y 로 바꾸어야 함 . 
          // $this->updateDocumentFile();
          
        }
        
        /*
        public function updateDocumentFile() {
        		if( false == $this->c_db->SQLExecute('UPD_CUSTOMER_DOCUMENT', array($doc_info['market_code'], $doc_info['cid'], $doc_info['reg_date'], $seq_cnt)) )
	 					 				throw new Exception(ERROR_CODE_DB_FAILURE);
					  
        }
        */

        //계약서 서버 저장
        // 2018.10.17 ==> for encryption password
        //public function _saveImageServerPDF($att_file_info, $contract_kind)
        public function _saveImageServerPDF($att_file_info, $contract_kind, $enc_password)
        // 2018.10.17 ==> for encryption password
        {
            if( !is_file( $att_file_info['tmp_name'] ) )
            {
                @logHandler(PEAR_LOG_ERR, "NO FILE To FTP Put Attach :  " . $att_file_info['tmp_name'], $PHP_SELF, __FILE__, __LINE__ ) ;
                throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
            }

            $folder   = $this->ContractInfo['INFO']['folder_name'];
            $file     = $this->ContractInfo['INFO']['file_name'];

            $parts = explode('/',$folder); // SOID/YYYY/MMDD
            foreach($parts as $part)
            {
                @ftp_pwd($this->ftp_conn);
                if(!@ftp_chdir($this->ftp_conn, $part))
                {
                    @ftp_pwd($this->ftp_conn);
                    @ftp_mkdir($this->ftp_conn, $part);
                    @ftp_chdir($this->ftp_conn, $part);
                }
            }

            $tmpfile = TMP_DIR . "/" . uniqid();
            move_uploaded_file($att_file_info['tmp_name'], $tmpfile);

            /* DRM 해지 처리 : 2018.08.28 */
            if(isDRMEncryptedFile($tmpfile))
            {
                $encfile = TMP_DIR . "/enc_" . uniqid();
                if(doDRMExtract($tmpfile, $encfile))
                {
                    $tmpfile = $encfile;
                }
            }


            // 2018.10.17 ==> for encryption password
            $exec_command = PDFSECURE_PROGRAM . " --encrypt '{$enc_password}' '' 128 --use-aes=y -- " . $tmpfile . " " . $tmpfile . "__enc_pass";
            @logHandler(PEAR_LOG_INFO, $exec_command , $PHP_SELF, __FILE__, __LINE__ ) ;
            exec( $exec_command );

            if( !is_file( $tmpfile . "__enc_pass" ) )
            {
                @logHandler(PEAR_LOG_ERR, "NO FILE Found (Secured Applied) :  " . $tmpfile . "__enc_pass", $PHP_SELF, __FILE__, __LINE__ ) ;
                throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
            }
            $tmpfile = $tmpfile . "__enc_pass";
            // 2018.10.17 ==> for encryption password



            if(!@ftp_put($this->ftp_conn, $file, $tmpfile, FTP_BINARY))
            {
                @logHandler(PEAR_LOG_ERR, "FTP upload Failure :  " . $tmpfile . " ===> $file ", $PHP_SELF, __FILE__, __LINE__ ) ;
                throw new Exception (ERROR_CODE_ERR_ATT_PROCESS);
            }
// Hangang_auto_start (autopay - upload)
            //개인 계약서 일 경우 cid_install_barcode 에 저장한다.
            if (($this->ContractInfo['INFO']['contract_kind']=="P") && ($this->ContractInfo['INFO']['activity_code']!="C84"))
//            if ($this->ContractInfo['INFO']['contract_kind']=="P")
            {
                @logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode", $PHP_SELF, __FILE__, __LINE__ );
                 $this->insertBarcode();
            }
// Hangang_auto_end

            //신규테이블에 계약서 upload 정보를 저장한다.
            @logHandler(PEAR_LOG_INFO, "Insert into group_contract_info", $PHP_SELF, __FILE__, __LINE__ );
            $this->insertGroupContract();

            //insert ccm_memo
            @logHandler(PEAR_LOG_INFO, "Insert into ccm_memo", $PHP_SELF, __FILE__, __LINE__ );

            $sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 업로드]":"작업상태:[단체 계약서 업로드]";
            $usr_memo_text = "1.파일명: [".$this->ContractInfo['INFO']['file_name']."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
            $this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);

// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
            //insert payment_method_history
            @logHandler(PEAR_LOG_INFO, "Insert into payment_method_history", $PHP_SELF, __FILE__, __LINE__ );
            $this->insertPaymentMethodHistory();
// Hangang_auto_end

            $this->commit();
        }

        //파일 다운로드
        public function _downImageServerPDF($file_name)
        {
            $this->_connect_ftpServer();

            $sys_memo_text = $this->ContractInfo['INFO']['contract_kind'] =="P"? "작업내역:[개인 계약서 다운로드]":"작업상태:[단체 계약서 다운로드]";
            $usr_memo_text = "1.파일명: [".$file_name."], 2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
            $this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);

            $this->file = uniqid() . ".pdf";

            if(0 < ftp_size($this->ftp_conn, $file_name))
            {
                if(!ftp_get($this->ftp_conn, TMP_DIR . "/" . $this->file, $file_name, FTP_BINARY))
                {
                    @logHandler(PEAR_LOG_ERR, "FTP DownLoad Failure :  " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
                    throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
                }
            }
            else
            {
                @logHandler(PEAR_LOG_ERR, "FTP FILE NOT EXISTS :  " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
                ftp_close($this->ftp_conn);
                prtErr("이미지 서버에 파일({$file_name})이 없습니다.");
                return "이미지 서버에 파일({$file_name})이 없습니다.";
            }

            ftp_close($this->ftp_conn);

            return TMP_DIR . "/" . $this->file ;
        }

        // 파일 삭제
        public function _deleteImageServerPDF($file_name)
        {
            $this->_connect_ftpServer();

            if(0 < ftp_size($this->ftp_conn, $file_name))
            {
                if(!ftp_delete($this->ftp_conn, $file_name))
                {
                    @logHandler(PEAR_LOG_ERR, "FTP delete Failure :  " . $file_name, $PHP_SELF, __FILE__, __LINE__ ) ;
                    throw new Exception (ERROR_CODE_ERR_PDF_PROCESS);
                }
            }

            ftp_close($this->ftp_conn);
        }

        //insert cid_install_barcode
        public function insertBarcode()
        {
            @logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode start", $PHP_SELF, __FILE__, __LINE__ ) ;
            $exist = $this->c_db->SQLGetOne('GET_CID_INSTALL_BARCODE_COUNT',
                                            array(
                                                  $this->ContractInfo['INFO']['market_code']
                                                 ,$this->ContractInfo['INFO']['cid']
                                                 ,$this->ContractInfo['INFO']['work_group']
                                           ));

            if($exist){
                if(false == $this->c_db->SQLExecute('UPD_CID_INSTALL_BARCODE',
                                            array(
                                                     "Y"                                                            // --scan_yn
                                                    ,$this->ContractInfo['INFO']['agree_yn']                        // -- agree_yn
                                                    ,$this->ContractInfo['INFO']['agree_yn2']                       // -- agree_yn2
                                                    ,$this->ContractInfo['INFO']['agree_yn3']                       // -- agree_yn3
                                                    ,$this->ContractInfo['INFO']['agree_yn4']                       // -- agree_yn4
                                                    ,$this->ContractInfo['INFO']['agent_id']                        // -- scan_agent
                                                    ,""
                                                    ,""                                                             // -- post_gubun
                                                    ,$this->ContractInfo['INFO']['market_code']
                                                    ,$this->ContractInfo['INFO']['cid']
                                                    ,$this->ContractInfo['INFO']['work_group']
                                                  )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }else{
                if(false == $this->c_db->SQLExecute('INS_CID_INSTALL_BARCODE',
                                              array(
                                                     $this->ContractInfo['INFO']['market_code']
                                                    ,$this->ContractInfo['INFO']['cid']
                                                    ,$this->ContractInfo['INFO']['work_group']
                                                    ,$this->ContractInfo['WORK_REG_DATE']
                                                    ,$this->ContractInfo['ACTIVITY_CODE']
                                                    ,"1"
                                                    ,$this->ContractInfo['INFO']['agent_id']
                                                    ,"FTP"                                                          // -- sys_application_id
                                                    ,"INS"                                                          // -- dl_service_code
                                                    ,"0"                                                            // -- dl_update_stamp
                                                    ,$this->ContractInfo['FULL_NAME']                               // -- full_name
                                                    ,$this->ContractInfo['CID_STATUS']                              // -- cid_status
                                                    ,"W"                                                            // -- keep_status
                                                    ,substr($this->ContractInfo['WORK_DATETIME'], 0, 8)             // -- actv_date
                                                    ,$this->ContractInfo['INFO']['agent_id']                        // -- actv_agent
                                                    ,"Y"                                                            // -- scan_yn
                                                    ,$this->ContractInfo['INFO']['agree_yn']                        // -- agree_yn
                                                    ,$this->ContractInfo['INFO']['agree_yn2']                       // -- agree_yn2
                                                    ,$this->ContractInfo['INFO']['agree_yn3']                       // -- agree_yn3
                                                    ,$this->ContractInfo['INFO']['agree_yn4']                       // -- agree_yn4
                                                    ,""                                                             // -- doc_type
                                                    ,$this->ContractInfo['INFO']['agent_id']                        // -- scan_agent
                                                    ,""                                                             // -- post_gubun
                                                    ,""
                                                  )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }

            @logHandler(PEAR_LOG_INFO, "Insert into cid_install_barcode end", $PHP_SELF, __FILE__, __LINE__ ) ;
        }

        //install group_contract_info
        public function insertGroupContract()
        {
            @logHandler(PEAR_LOG_INFO, "Insert into group_contract_info start", $PHP_SELF, __FILE__, __LINE__ ) ;
            $exist = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_COUNT',
                                            array(
                                                  $this->ContractInfo['INFO']['market_code']
                                                 ,$this->ContractInfo['INFO']['cid']
                                                 ,$this->ContractInfo['INFO']['seq']
                                            ));
            if($exist){
                //기존 이력 저장
                $this->insertGroupHistory();

                if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO',
                                            array(
                                                 $this->ContractInfo['INFO']['agent_id']                               // --sys_operator_id
                                                ,$this->ContractInfo['INFO']['agent_id']                               // --reg_agent_id
                                                ,$this->ContractInfo['INFO']['remark']                                 // --remark
                                                ,$this->ContractInfo['INFO']['market_code']
                                                ,$this->ContractInfo['INFO']['cid']
                                                ,$this->ContractInfo['INFO']['seq']
                                            )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }
            else
            {                //신규저장
                if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO',
                                              array(
                                                     $this->ContractInfo['INFO']['market_code']                    // --market_code
                                                    ,$this->ContractInfo['INFO']['cid']                            // --cid
                                                    ,$this->ContractInfo['INFO']['seq']                            // --seq
                                                    ,date('Ymd')                                                   // --reg_date
                                                    ,$this->ContractInfo['INFO']['agent_id']                       // --reg_agent_id
                                                    ,$this->ContractInfo['INFO']['contract_kind']                  // --contract_kind
                                                    ,$this->ContractInfo['INFO']['contract_type']                  // --contract_type
                                                    ,$this->ContractInfo['INFO']['work_group']                     // --work_group
                                                    ,$this->ContractInfo['ACTIVITY_CODE']                          // --activity_code
                                                    ,$this->ContractInfo['INFO']['agent_id']                       // --sys_operator_id
                                                    ,$this->ContractInfo['INFO']['folder_name']                    // --folder_name
                                                    ,$this->ContractInfo['INFO']['file_name']                      // --file_name
                                                    ,"Y"                                                           // --flag
                                                    ,$this->ContractInfo['INFO']['remark']                         // --remark
                                                  )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }

            //$this->commit();
            @logHandler(PEAR_LOG_INFO, "Insert into group_contract_info end", $PHP_SELF, __FILE__, __LINE__ ) ;
        }
        
        //install customer_document
        public function insertCustomerDocument()
        {
            @logHandler(PEAR_LOG_INFO, "Insert into customer_document start", $PHP_SELF, __FILE__, __LINE__ ) ;
            $exist = $this->c_db->SQLGetOne('GET_GROUP_CONTRACT_INFO_COUNT',
                                            array(
                                                  $this->DocumentInfo['INFO']['market_code']
                                                 ,$this->DocumentInfo['INFO']['cid']
                                                 ,$this->DocumentInfo['INFO']['seq']
                                            ));
            if($exist){
                //기존 이력 저장
                $this->insertDocumentHistory();

                if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO',
                                            array(
                                                 $this->ContractInfo['INFO']['agent_id']                               // --sys_operator_id
                                                ,$this->ContractInfo['INFO']['agent_id']                               // --reg_agent_id
                                                ,$this->ContractInfo['INFO']['remark']                                 // --remark
                                                ,$this->ContractInfo['INFO']['market_code']
                                                ,$this->ContractInfo['INFO']['cid']
                                                ,$this->ContractInfo['INFO']['seq']
                                            )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }
            else
            {                //신규저장
                if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO',
                                              array(
                                                     $this->ContractInfo['INFO']['market_code']                    // --market_code
                                                    ,$this->ContractInfo['INFO']['cid']                            // --cid
                                                    ,$this->ContractInfo['INFO']['seq']                            // --seq
                                                    ,date('Ymd')                                                   // --reg_date
                                                    ,$this->ContractInfo['INFO']['agent_id']                       // --reg_agent_id
                                                    ,$this->ContractInfo['INFO']['contract_kind']                  // --contract_kind
                                                    ,$this->ContractInfo['INFO']['contract_type']                  // --contract_type
                                                    ,$this->ContractInfo['INFO']['work_group']                     // --work_group
                                                    ,$this->ContractInfo['ACTIVITY_CODE']                          // --activity_code
                                                    ,$this->ContractInfo['INFO']['agent_id']                       // --sys_operator_id
                                                    ,$this->ContractInfo['INFO']['folder_name']                    // --folder_name
                                                    ,$this->ContractInfo['INFO']['file_name']                      // --file_name
                                                    ,"Y"                                                           // --flag
                                                    ,$this->ContractInfo['INFO']['remark']                         // --remark
                                                  )))
                {
                    throw new Exception (ERROR_CODE_DB_FAILURE);
                }
            }

            //$this->commit();
            @logHandler(PEAR_LOG_INFO, "Insert into group_contract_info end", $PHP_SELF, __FILE__, __LINE__ ) ;
        }

        //insert group_contract_info_his
        public function insertGroupHistory()
        {
            if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO_HIS',
                                          array(
                                                 $this->ContractInfo['INFO']['agent_id']                                 // --sys_operator_id
                                                ,$this->ContractInfo['INFO']['market_code']                              // --market_code
                                                ,$this->ContractInfo['INFO']['cid']                                      // --cid
                                                ,$this->ContractInfo['INFO']['seq']                                      // --seq
                                              )))
            {
                throw new Exception (ERROR_CODE_DB_FAILURE);
            }
        }
        
        //insert customer_document_his
        public function insertDocumentHistory()
        {
            if(false == $this->c_db->SQLExecute('INS_GROUP_CONTRACT_INFO_HIS',
                                          array(
                                                 $this->ContractInfo['INFO']['agent_id']                                 // --sys_operator_id
                                                ,$this->ContractInfo['INFO']['market_code']                              // --market_code
                                                ,$this->ContractInfo['INFO']['cid']                                      // --cid
                                                ,$this->ContractInfo['INFO']['seq']                                      // --seq
                                              )))
            {
                throw new Exception (ERROR_CODE_DB_FAILURE);
            }
        }

        //비고항목및 동의항목 수정
        public function editContract()
        {
            //기존 이력 저장
            $this->insertGroupHistory();

            if(false == $this->c_db->SQLExecute('UPD_GROUP_CONTRACT_INFO_DATA',
                                        array(
                                             $this->ContractInfo['INFO']['agent_id']                                               // --sys_operator_id
                                            ,$this->ContractInfo['INFO']['contract_type']
                                            ,$this->ContractInfo['INFO']['reg_agent_id']
                                            ,$this->ContractInfo['INFO']['remark']
                                            ,$this->ContractInfo['INFO']['market_code']
                                            ,$this->ContractInfo['INFO']['cid']
                                            ,$this->ContractInfo['INFO']['seq']
                                        )))
            {
                throw new Exception (ERROR_CODE_DB_FAILURE);
            }

            if ($this->ContractInfo['INFO']['contract_kind'] == "P")
            {
                $sys_memo_text = "작업내역:[개인 계약서 정보 수정]";
                $usr_memo_text = "1.변경사항:[비고 - ".$this->ContractInfo['INFO']['remark']."],3.작업그룹:[".$this->ContractInfo['INFO']['work_group']."] 3.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
            }
            else
            {
                $sys_memo_text = "작업내역:[단체 계약서 정보 수정]";
                $usr_memo_text = "1.변경사항:[비고 - ".$this->ContractInfo['INFO']['remark']."],2.SEQ_NO:[".$this->ContractInfo['INFO']['seq']."] 3.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";
            }

            $this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);

            $this->commit();
        }

// Hangang_auto_start : insertPaymentMethodHistory (autopay - upload)
        //insert payment_method_history
        public function insertPaymentMethodHistory()
        {
            @logHandler(PEAR_LOG_INFO, "Insert into payment_method_history start", $PHP_SELF, __FILE__, __LINE__ ) ;

            $agree_name = $this->ContractInfo['INFO']['folder_name']."/".$this->ContractInfo['INFO']['file_name'];

            if(false == $this->c_db->SQLExecute('UPD_PAYMENT_METHOD_HISTORY',
                                        array(
                     $agree_name                     // agree_name
                    ,'SCAN'                          // agree_type
                    ,$this->ContractInfo['INFO']['market_code']
                    ,$this->ContractInfo['INFO']['cid']
                    ,$this->ContractInfo['INFO']['work_group']
                                        )))
            {
                throw new Exception (ERROR_CODE_DB_FAILURE);
            }

            //$this->commit();
            @logHandler(PEAR_LOG_INFO, "Insert into payment_method_history end", $PHP_SELF, __FILE__, __LINE__ ) ;
        }
// Hangang_auto_end

        //단체계약서 저장이력 삭제
        public function deleteContract($file_name)
        {
            $this->_deleteImageServerPDF($file_name);

            //이력삭제
            if(false == $this->c_db->SQLExecute('DELETE_GROUP_CONTRACT_INFO_HIS',
                                                 array(
                                                        $this->ContractInfo['INFO']['market_code']
                                                       ,$this->ContractInfo['INFO']['cid']
                                                       ,$this->ContractInfo['INFO']['seq']
                                                      )))
            {
                throw new Exception(ERROR_CODE_DB_FAILURE);
            }

            //정보삭제
            if(false == $this->c_db->SQLExecute('DELETE_GROUP_CONTRACT_INFO',
                                                 array(
                                                         $this->ContractInfo['INFO']['market_code']
                                                        ,$this->ContractInfo['INFO']['cid']
                                                        ,$this->ContractInfo['INFO']['seq']
                                                       )))
            {
                throw new Exception(ERROR_CODE_DB_FAILURE);
            }

            $sys_memo_text = "작업냐역:[단체 계약서 삭제처리]";
            $usr_memo_text = "1.삭제파일명:[".$file_name."],2.작업자:[".$this->ContractInfo['INFO']['agent_name']."]";

            $this->insertCCM_MEMO($sys_memo_text, $usr_memo_text);

            $this->commit();
        }

        public function insertCCM_MEMO($sys_memo_text, $usr_memo_text)
        {
            if(false == $this->c_db->SQLExecute('INS_CCM_MEMO',
                                        array(
                                            $this->ContractInfo['INFO']['market_code']
                                           ,$this->ContractInfo['INFO']['cid']
                                           ,$this->ContractInfo['INFO']['agent_id']
                                           ,"0038"
                                           ,$sys_memo_text
                                           ,$usr_memo_text
                                           ,$this->ContractInfo['INFO']['market_code']
                                           ,$this->ContractInfo['INFO']['cid'])) )
            {
                throw new Exception (ERROR_CODE_DB_FAILURE);
            }
//            $this->commit();
        }

        //PDF 저장 폴더
        public function getPDFServerFolderName()
        {
            $yyyymmdd = str_replace(".","", date('Y.m.d'));
            $yyyymmdd = substr($yyyymmdd, 0, 8);

            $folder   = $this->ContractInfo['INFO']['market_code'] . "/" . substr($yyyymmdd, 0, 4) . "/" . substr($yyyymmdd, -4) ;

            return $folder;
        }
        
        // 서류 저장 폴더
        public function getDocumentFolderName()
        {
            $yyyymmdd = str_replace(".","", date('Y.m.d'));
            $yyyymmdd = substr($yyyymmdd, 0, 8);

            $folder   = $this->DocumentInfo['INFO']['market_code'] . "/" . substr($yyyymmdd, 0, 4) . "/" . substr($yyyymmdd, -4) ;
						
            return $folder;
        }

        //PDF 파일명
        public function getPDFServerFileName()
        {
            $yyyymmdd = str_replace(".","", date('Y.m.d'));
            $yyyymmdd = substr($yyyymmdd, 0, 8);
            $file_name = $this->ContractInfo['INFO']['market_code'] ."_". $this->ContractInfo['INFO']['cid'];

            $file_name = ($this->ContractInfo['INFO']['contract_kind'] =="P") ? $file_name ."_". $this->ContractInfo['INFO']['work_group'] ."_". $yyyymmdd : $file_name."_".$yyyymmdd ;

            return $file_name ;
        }
        
        // 서류 파일명 
        public function getDocumentFileName()
        {
            $yyyymmdd = str_replace(".","", date('Y.m.d'));
            $yyyymmdd = substr($yyyymmdd, 0, 8);
             
            $file_name = $this->DocumentInfo['INFO']['market_code'] ."_". $this->DocumentInfo['INFO']['cid'] ."_". $yyyymmdd ;
				
            //$file_name = ($this->DocumentInfo['INFO']['contract_kind'] =="P") ? $file_name ."_". $this->DocumentInfo['INFO']['work_group'] ."_". $yyyymmdd : $file_name."_".$yyyymmdd ;

            return $file_name ;
        }
        

        //계약서 종류 가져오기
        public function get_contract_type($market_code)
        {
            $this->c_db = DBController::getInstance();
            $_list = $this->c_db->SQLQuery("GET_CONTRACT_TYPE_LIST", array($market_code));

            $arr = array();

            for($i=0; $i < count($_list); $i++)
            {
                $arr[$_list[$i]['CODE_VAL'] ] = $_list[$i]['CODE_STR'];
            }

            return $arr;
        }

        public function commit()
        {
            $this->c_db->commit();
        }

        public function rollback()
        {
            $this->c_db->rollback();
        }

        public function disconn($flag=FALSE)
        {
            $this->c_db->disconn($flag);
        }

        //파일정보 재배열 처리
        public function multiple(array $_files, $top = TRUE)
        {
            $files = array();
            foreach($_files as $name=>$file){
                if($top) $sub_name = $file['name'];
                else     $sub_name = $name;

                if(is_array($sub_name)){
                    foreach(array_keys($sub_name) as $key){
                        $files[$name][$key] = array(
                            'name'     => $file['name'][$key],
                            'type'     => $file['type'][$key],
                            'tmp_name' => $file['tmp_name'][$key],
                            'error'    => $file['error'][$key],
                            'size'     => $file['size'][$key],
                        );
                        $files[$name] = $this->multiple($files[$name], FALSE);
                    }
                }else{
                    $files[$name] = $file;
                }
            }
            return $files;
        }

        public function login_chk()
        {
            if (!$_SESSION['fromSMS'])
            {
                session_destroy();
                header("Location: /group_contract/index.php");
                die();
            }
        }

        public function prt_return($str, $url, array $data)
        {
            echo "<script type=\"text/javascript\">alert(\"$str\");</script>";
            _user_reaction($url, $data);
        }

    }