2018-08-28 14:05:06 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file orderpay.step2.pgkcp.php
|
|
|
|
* @date 2018-08-27
|
|
|
|
* @author Go Namhyeon <gnh1201@gmail.com>
|
|
|
|
* @brief KCP PG(Payment Gateway) contoller when done
|
|
|
|
*/
|
|
|
|
|
|
|
|
if(!defined("_DEF_RSF_")) set_error_exit("do not allow access");
|
|
|
|
|
|
|
|
// detect CSRF attack
|
|
|
|
if(check_token_abuse_by_requests("_token", "_POST")) {
|
|
|
|
set_error("Access denied. (Expired session or Website attacker)");
|
|
|
|
show_errors();
|
|
|
|
}
|
|
|
|
|
|
|
|
loadHelper("networktool"); // load network tools
|
|
|
|
loadHelper("pgkcp.lnk"); // load KCP PG Helper
|
|
|
|
loadHelper("JSLoader.class"); // load javascript loader
|
|
|
|
|
|
|
|
// load PGKCP configuration
|
|
|
|
$pgkcp_config = get_pgkcp_config();
|
|
|
|
|
|
|
|
// extract PGKCP configuration
|
|
|
|
extract($pgkcp_config);
|
|
|
|
|
|
|
|
// load PGKCP library
|
|
|
|
load_pgkcp_library();
|
|
|
|
|
|
|
|
// 01. 지불 요청 정보 설정
|
|
|
|
$payres = array();
|
|
|
|
$payinfo = array(
|
|
|
|
"req_tx" => get_requested_value("req_tx"),
|
|
|
|
"tran_cd" => get_requested_value("tran_cd"),
|
|
|
|
"cust_ip" => get_network_client_addr(),
|
|
|
|
"ordr_idxx" => get_requested_value("ordr_idxx"),
|
|
|
|
"good_name" => get_requested_value("good_name"),
|
|
|
|
"res_cd" => "",
|
|
|
|
"res_msg" => "",
|
|
|
|
"res_en_msg" => "",
|
|
|
|
"tno" => get_requested_value("tno"),
|
|
|
|
"buyr_name" => get_requested_value("buyr_name"),
|
|
|
|
"buyr_tel1" => get_requested_value("buyr_tel1"),
|
|
|
|
"buyr_tel2" => get_requested_value("buyr_tel2"),
|
|
|
|
"buyr_mail" => get_requested_value("buyr_mail"),
|
|
|
|
"use_pay_method_alias" => "",
|
|
|
|
"use_pay_method" => get_requested_value("use_pay_method"),
|
|
|
|
"bSucc" => "",
|
|
|
|
"app_time" => "",
|
|
|
|
"amount" => "",
|
|
|
|
"total_amount" => 0,
|
|
|
|
"coupon_mny" => "",
|
|
|
|
"app_time" => "",
|
|
|
|
"amount" => "",
|
|
|
|
"total_amount" => 0,
|
|
|
|
"coupon_mny" => "",
|
|
|
|
"card_cd" => "",
|
|
|
|
"card_name" => "",
|
|
|
|
"app_no" => "",
|
|
|
|
"noinf" => "",
|
|
|
|
"quota" => "",
|
|
|
|
"partcanc_yn" => "",
|
|
|
|
"card_bin_type_01" => "",
|
|
|
|
"card_bin_type_02" => "",
|
|
|
|
"card_mny" => "",
|
|
|
|
"bank_name" => "",
|
|
|
|
"bank_code" => "",
|
|
|
|
"bk_mny" => "",
|
|
|
|
"bankname" => "",
|
|
|
|
"depositor" => "",
|
|
|
|
"account" => "",
|
|
|
|
"va_date" => "",
|
|
|
|
"pnt_issue" => "",
|
|
|
|
"pnt_amount" => "",
|
|
|
|
"pnt_app_time" => "",
|
|
|
|
"pnt_app_no" => "",
|
|
|
|
"add_pnt" => "",
|
|
|
|
"use_pnt" => "",
|
|
|
|
"rsv_pnt" => "",
|
|
|
|
"commid" => "",
|
|
|
|
"mobile_no" => "",
|
|
|
|
"shop_user_id" => get_requested_value("shop_user_id"),
|
|
|
|
"tk_van_code" => "",
|
|
|
|
"tk_app_no" => "",
|
|
|
|
"cash_yn" => get_requested_value("cash_yn"),
|
|
|
|
"cash_authno" => "",
|
|
|
|
"cash_tr_code" => get_requested_value("cash_tr_code"),
|
|
|
|
"cash_id_info" => get_requested_value("cash_id_info"),
|
|
|
|
"cash_no" => get_requested_value("cash_no")
|
|
|
|
);
|
|
|
|
|
|
|
|
// extract payinfo
|
|
|
|
extract($payinfo);
|
|
|
|
|
|
|
|
// initalize data
|
|
|
|
$data = array(
|
|
|
|
"payinfo" => $payinfo,
|
|
|
|
"result" => $result,
|
|
|
|
"_token" => get_session_token(),
|
2018-08-28 14:05:35 +00:00
|
|
|
"_next_route" => "orderpay.step3.pgkcp",
|
2018-08-28 14:05:06 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
// 02. 인스턴스 생성 및 초기화
|
|
|
|
$c_PayPlus = new C_PP_CLI;
|
|
|
|
$c_PayPlus->mf_clear();
|
|
|
|
|
|
|
|
// 03. 처리 요청 정보 설정
|
|
|
|
if($req_tx == "pay") {
|
|
|
|
$c_PayPlus->mf_set_ordr_data( "ordr_mony", get_requested_value("good_mny") );
|
|
|
|
$c_PayPlus->mf_set_encx_data( get_requested_value("enc_data"), get_requested_value("enc_info") );
|
|
|
|
}
|
|
|
|
|
|
|
|
// 04. 실행
|
|
|
|
if($tran_cd != "") {
|
|
|
|
// 응답 전문 처리
|
|
|
|
$c_PayPlus->mf_do_tx( "", $g_conf_home_dir, $g_conf_site_cd, $g_conf_site_key, $tran_cd, "",
|
|
|
|
$g_conf_gw_url, $g_conf_gw_port, "payplus_cli_slib", $ordr_idxx,
|
|
|
|
$cust_ip, $g_conf_log_level, 0, 0, $g_conf_log_path );
|
|
|
|
|
|
|
|
$payres['res_cd'] = $c_PayPlus->m_res_cd; // 결과 코드
|
|
|
|
$payres['res_msg'] = $c_PayPlus->m_res_msg; // 결과 메시지
|
|
|
|
|
|
|
|
// 결과 영문 메세지
|
|
|
|
//$payres['res_en_msg'] = $c_PayPlus->mf_get_res_data( "res_en_msg" );
|
|
|
|
} else {
|
|
|
|
$c_PayPlus->m_res_cd = "9562";
|
|
|
|
$c_PayPlus->m_res_msg = "연동 오류 tran_cd값이 설정되지 않았습니다.";
|
|
|
|
}
|
|
|
|
|
|
|
|
// 05. 승인 결과 값 추출
|
|
|
|
if($req_tx == "pay") {
|
|
|
|
if($res_cd == "0000") {
|
|
|
|
$payres['tno'] = $c_PayPlus->mf_get_res_data("tno"); // KCP 거래 고유 번호
|
|
|
|
$payres['amount'] = $c_PayPlus->mf_get_res_data("amount"); // KCP 실제 거래 금액
|
|
|
|
$payres['pnt_issue'] = $c_PayPlus->mf_get_res_data("pnt_issue"); // 결제 포인트사 코드
|
|
|
|
$payres['coupon_mny'] = $c_PayPlus->mf_get_res_data("coupon_mny" ); // 쿠폰금액
|
|
|
|
|
|
|
|
switch($use_pay_method) {
|
|
|
|
case "100000000000": // 05-1. 신용카드 승인 결과 처리
|
|
|
|
$payres['card_cd'] = $c_PayPlus->mf_get_res_data( "card_cd" ); // 카드사 코드
|
|
|
|
$payres['card_name'] = $c_PayPlus->mf_get_res_data( "card_name" ); // 카드 종류
|
|
|
|
$payres['app_time'] = $c_PayPlus->mf_get_res_data( "app_time" ); // 승인 시간
|
|
|
|
$payres['app_no'] = $c_PayPlus->mf_get_res_data( "app_no" ); // 승인 번호
|
|
|
|
$payres['noinf'] = $c_PayPlus->mf_get_res_data( "noinf" ); // 무이자 여부 ( 'Y' : 무이자 )
|
|
|
|
$payres['quota'] = $c_PayPlus->mf_get_res_data( "quota" ); // 할부 개월 수
|
|
|
|
$payres['partcanc_yn'] = $c_PayPlus->mf_get_res_data( "partcanc_yn" ); // 부분취소 가능유무
|
|
|
|
$payres['card_bin_type_01'] = $c_PayPlus->mf_get_res_data( "card_bin_type_01" ); // 카드구분1
|
|
|
|
$payres['card_bin_type_02'] = $c_PayPlus->mf_get_res_data( "card_bin_type_02" ); // 카드구분2
|
|
|
|
$payres['card_mny'] = $c_PayPlus->mf_get_res_data( "card_mny" ); // 카드결제금액
|
|
|
|
|
|
|
|
// 05-1.1. 복합결제(포인트+신용카드) 승인 결과 처리
|
|
|
|
if(in_array($pnt_issue, array("SCSK", "SCWB"))) {
|
|
|
|
$payres['pnt_amount'] = $c_PayPlus->mf_get_res_data ( "pnt_amount" ); // 적립금액 or 사용금액
|
|
|
|
$payres['pnt_app_time'] = $c_PayPlus->mf_get_res_data ( "pnt_app_time" ); // 승인시간
|
|
|
|
$payres['pnt_app_no'] = $c_PayPlus->mf_get_res_data ( "pnt_app_no" ); // 승인번호
|
|
|
|
$payres['add_pnt'] = $c_PayPlus->mf_get_res_data ( "add_pnt" ); // 발생 포인트
|
|
|
|
$payres['use_pnt'] = $c_PayPlus->mf_get_res_data ( "use_pnt" ); // 사용가능 포인트
|
|
|
|
$payres['rsv_pnt'] = $c_PayPlus->mf_get_res_data ( "rsv_pnt" ); // 총 누적 포인트
|
|
|
|
$payres['total_amount'] = $amount + $pnt_amount; // 복합결제시 총 거래금액
|
|
|
|
}
|
|
|
|
|
|
|
|
break; // END 05-1
|
|
|
|
|
|
|
|
case "010000000000": // 05-2. 계좌이체 승인 결과 처리
|
|
|
|
$payres['app_time'] = $c_PayPlus->mf_get_res_data( "app_time" ); // 승인 시간
|
|
|
|
$payres['bank_name'] = $c_PayPlus->mf_get_res_data( "bank_name" ); // 은행명
|
|
|
|
$payres['bank_code'] = $c_PayPlus->mf_get_res_data( "bank_code" ); // 은행코드
|
|
|
|
$payres['bk_mny'] = $c_PayPlus->mf_get_res_data( "bk_mny" ); // 계좌이체결제금액
|
|
|
|
|
|
|
|
break; // END 05-2
|
|
|
|
|
|
|
|
case "001000000000": // 05-3. 가상계좌 승인 결과 처리
|
|
|
|
$payres['bankname'] = $c_PayPlus->mf_get_res_data( "bankname" ); // 입금할 은행 이름
|
|
|
|
$payres['depositor'] = $c_PayPlus->mf_get_res_data( "depositor" ); // 입금할 계좌 예금주
|
|
|
|
$payres['account'] = $c_PayPlus->mf_get_res_data( "account" ); // 입금할 계좌 번호
|
|
|
|
$payres['va_date'] = $c_PayPlus->mf_get_res_data( "va_date" ); // 가상계좌 입금마감시간
|
|
|
|
|
|
|
|
break; // END 05-3
|
|
|
|
|
|
|
|
case "000100000000": // 05-4. 포인트 승인 결과 처리
|
|
|
|
$payres['pnt_amount'] = $c_PayPlus->mf_get_res_data( "pnt_amount" ); // 적립금액 or 사용금액
|
|
|
|
$payres['pnt_app_time'] = $c_PayPlus->mf_get_res_data( "pnt_app_time" ); // 승인시간
|
|
|
|
$payres['pnt_app_no'] = $c_PayPlus->mf_get_res_data( "pnt_app_no" ); // 승인번호
|
|
|
|
$payres['add_pnt'] = $c_PayPlus->mf_get_res_data( "add_pnt" ); // 발생 포인트
|
|
|
|
$payres['use_pnt'] = $c_PayPlus->mf_get_res_data( "use_pnt" ); // 사용가능 포인트
|
|
|
|
$payres['rsv_pnt'] = $c_PayPlus->mf_get_res_data( "rsv_pnt" ); // 적립 포인트
|
|
|
|
|
|
|
|
break; // END 05-4
|
|
|
|
|
|
|
|
case "000010000000": // 05-5. 휴대폰 승인 결과 처리
|
|
|
|
$payres['app_time'] = $c_PayPlus->mf_get_res_data( "hp_app_time" ); // 승인 시간
|
|
|
|
$payres['commid'] = $c_PayPlus->mf_get_res_data( "commid" ); // 통신사 코드
|
|
|
|
$payres['mobile_no'] = $c_PayPlus->mf_get_res_data( "mobile_no" ); // 휴대폰 번호
|
|
|
|
|
|
|
|
break; // END 05-5
|
|
|
|
|
|
|
|
case "000000001000": // 05-6. 상품권 승인 결과 처리
|
|
|
|
$payres['app_time'] = $c_PayPlus->mf_get_res_data( "tk_app_time" ); // 승인 시간
|
|
|
|
$payres['tk_van_code'] = $c_PayPlus->mf_get_res_data( "tk_van_code" ); // 발급사 코드
|
|
|
|
$payres['tk_app_no'] = $c_PayPlus->mf_get_res_data( "tk_app_no" ); // 승인 번호
|
|
|
|
|
|
|
|
break; // END 05-6
|
|
|
|
}
|
|
|
|
|
|
|
|
// 05-7. 현금영수증 결과 처리
|
|
|
|
$payres['cash_authno'] = $c_PayPlus->mf_get_res_data( "cash_authno" ); // 현금 영수증 승인 번호
|
|
|
|
$payres['cash_no'] = $c_PayPlus->mf_get_res_data( "cash_no" ); // 현금 영수증 거래 번호
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// extract result
|
|
|
|
extract($payres);
|
|
|
|
|
|
|
|
// process database
|
|
|
|
$use_pay_method_alias = get_value_in_array("use_pay_method_alias", $payinfo, "");
|
|
|
|
$pay_method_rules = array(
|
|
|
|
"CRE" => "100000000000", // 신용카드
|
|
|
|
"ACC" => "010000000000", // 계좌이체
|
|
|
|
"VAC" => "001000000000", // 가상계좌
|
|
|
|
"POI" => "000100000000", // 포인트
|
|
|
|
"PHO" => "000010000000", // 휴대폰
|
|
|
|
"GIF" => "000000001000", // 상품권
|
|
|
|
"ARS" => "000000000010", // ARS
|
|
|
|
"CAV" => "111000000000" // 신용카드/계좌이체/가상계좌
|
|
|
|
);
|
|
|
|
if(in_array($pay_method_rules, array_values($pay_method_rules)) {
|
|
|
|
foreach($pay_method_rules as $k=>$v) {
|
|
|
|
if($use_pay_method == $v) {
|
|
|
|
$use_pay_method_alias = $k;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$payres['bSucc'] = "true";
|
|
|
|
} else {
|
|
|
|
$payres['bSucc'] = "false";
|
|
|
|
}
|
|
|
|
|
|
|
|
// cancel payment when failed
|
|
|
|
if($req_tx == "pay") {
|
|
|
|
if($res_cd == "0000") {
|
|
|
|
if($bSucc == "false") {
|
|
|
|
$c_PayPlus->mf_clear();
|
|
|
|
|
|
|
|
$payres['tran_cd'] = "00200000";
|
|
|
|
$c_PayPlus->mf_set_modx_data( "tno", $tno ); // KCP 원거래 거래번호
|
|
|
|
$c_PayPlus->mf_set_modx_data( "mod_type", "STSC" ); // 원거래 변경 요청 종류
|
|
|
|
$c_PayPlus->mf_set_modx_data( "mod_ip", $cust_ip); // 변경 요청자 IP
|
|
|
|
$c_PayPlus->mf_set_modx_data( "mod_desc", "결과 처리 오류 - 자동 취소" ); // 변경 사유
|
|
|
|
|
|
|
|
$c_PayPlus->mf_do_tx( "", $g_conf_home_dir, $g_conf_site_cd, $g_conf_site_key, $tran_cd, "",
|
|
|
|
$g_conf_gw_url, $g_conf_gw_port, "payplus_cli_slib", $ordr_idxx,
|
|
|
|
$cust_ip, $g_conf_log_level, 0, 0, $g_conf_log_path ); // 응답 전문 처리
|
|
|
|
|
|
|
|
$payres['res_cd'] = $c_PayPlus->m_res_cd;
|
|
|
|
$payres['res_msg'] = $c_PayPlus->m_res_msg;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} // End of [res_cd = "0000"]
|
|
|
|
|
|
|
|
// extract result
|
|
|
|
extract($payres);
|
|
|
|
|
|
|
|
// 08. 폼 구성 및 결과페이지 호출
|
|
|
|
|
|
|
|
// set javascript files
|
|
|
|
$jsloader = new JSLoader();
|
|
|
|
$jsloader->add_scripts(base_url() . "view/public/route/orderpay.step2.pgkcp.js");
|
|
|
|
$jsoutput = $jsloader->get_output();
|
|
|
|
$data['jsoutput'] = $jsoutput;
|
|
|
|
|
|
|
|
// convert payres to payinfo
|
|
|
|
foreach($payres as $k=>$v) {
|
|
|
|
$payinfo[$k] = $v;
|
|
|
|
}
|
|
|
|
$data['payinfo'] = $payinfo;
|
|
|
|
|
|
|
|
// 결제 진행 URL
|
|
|
|
$data['pgkcp_action_url'] = base_url();
|
|
|
|
|
|
|
|
// 결제창 불러오기
|
|
|
|
renderView("view_orderpay.pgkcp", $data);
|