Files
firstgarden-web-gnu/shop/orderinquirycancel.php
2024-04-03 10:42:04 +09:00

176 lines
6.3 KiB
PHP

<?php
include_once('./_common.php');
$od_id = isset($_REQUEST['od_id']) ? safe_replace_regex($_REQUEST['od_id'], 'od_id') : '';
// 세션에 저장된 토큰과 폼으로 넘어온 토큰을 비교하여 틀리면 에러
if ($token && get_session("ss_token") == $token) {
// 맞으면 세션을 지워 다시 입력폼을 통해서 들어오도록 한다.
set_session("ss_token", "");
} else {
set_session("ss_token", "");
alert("토큰 에러", G5_SHOP_URL);
}
$od = sql_fetch(" select * from {$g5['g5_shop_order_table']} where od_id = '$od_id' and mb_id = '{$member['mb_id']}' ");
if (! (isset($od['od_id']) && $od['od_id'])) {
alert("존재하는 주문이 아닙니다.");
}
// 주문상품의 상태가 주문인지 체크
$sql = " select SUM(IF(ct_status = '주문', 1, 0)) as od_count2,
COUNT(*) as od_count1
from {$g5['g5_shop_cart_table']}
where od_id = '$od_id' ";
$ct = sql_fetch($sql);
$uid = md5($od['od_id'].$od['od_time'].$od['od_ip']);
if($od['od_cancel_price'] > 0 || $ct['od_count1'] != $ct['od_count2']) {
alert("취소할 수 있는 주문이 아닙니다.", G5_SHOP_URL."/orderinquiryview.php?od_id=$od_id&amp;uid=$uid");
}
// PG 결제 취소
if($od['od_tno']) {
switch($od['od_pg']) {
case 'lg':
require_once('./settle_lg.inc.php');
$LGD_TID = $od['od_tno']; //LG유플러스으로 부터 내려받은 거래번호(LGD_TID)
$xpay = new XPay($configPath, $CST_PLATFORM);
// Mert Key 설정
$xpay->set_config_value('t'.$LGD_MID, $config['cf_lg_mert_key']);
$xpay->set_config_value($LGD_MID, $config['cf_lg_mert_key']);
$xpay->Init_TX($LGD_MID);
$xpay->Set("LGD_TXNAME", "Cancel");
$xpay->Set("LGD_TID", $LGD_TID);
if ($xpay->TX()) {
//1)결제취소결과 화면처리(성공,실패 결과 처리를 하시기 바랍니다.)
/*
echo "결제 취소요청이 완료되었습니다. <br>";
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
*/
} else {
//2)API 요청 실패 화면처리
$msg = "결제 취소요청이 실패하였습니다.\\n";
$msg .= "TX Response_code = " . $xpay->Response_Code() . "\\n";
$msg .= "TX Response_msg = " . $xpay->Response_Msg();
alert($msg);
}
break;
case 'inicis':
include_once(G5_SHOP_PATH.'/settle_inicis.inc.php');
$cancel_msg = '주문자 본인 취소-'.$cancel_memo;
$args = array(
'paymethod' => get_type_inicis_paymethod($od['od_settle_case']),
'tid' => $od['od_tno'],
'msg' => $cancel_msg
);
$response = inicis_tid_cancel($args);
$result = json_decode($response, true);
$res_cd = '';
$res_msg = 'curl 로 데이터를 받지 못했습니다.';
if (isset($result['resultCode'])) {
$res_cd = $result['resultCode'];
$res_msg = $result['resultMsg'];
} else {
$res_cd = '';
$res_msg = 'curl 로 데이터를 받지 못했습니다.';
}
if($res_cd != '00') {
alert($res_msg.' 코드 : '.$res_cd);
}
break;
case 'nicepay':
include_once(G5_SHOP_PATH.'/settle_nicepay.inc.php');
$cancel_msg = '주문자 본인 취소-'.$cancel_memo;
$tno = $od['od_tno'];
$cancelAmt = $od['od_receipt_price'];
// 0:전체 취소, 1:부분 취소(별도 계약 필요)
$partialCancelCode = 0;
include G5_SHOP_PATH.'/nicepay/cancel_process.php';
$res_cd = '';
$res_msg = 'curl 로 데이터를 받지 못하거나 통신에 실패했습니다.';
if (isset($result['ResultCode'])) {
$res_cd = $result['ResultCode'];
// 실패했다면
if ($result['ResultCode'] !== '2001') {
$res_msg = $result['ResultMsg'];
}
}
if($res_cd != '2001') {
alert($res_msg.' 코드 : '.$res_cd);
}
break;
default:
require_once('./settle_kcp.inc.php');
$_POST['tno'] = $od['od_tno'];
$_POST['req_tx'] = 'mod';
$_POST['mod_type'] = 'STSC';
if($od['od_escrow']) {
$_POST['req_tx'] = 'mod_escrow';
$_POST['mod_type'] = 'STE2';
if($od['od_settle_case'] == '가상계좌')
$_POST['mod_type'] = 'STE5';
}
$_POST['mod_desc'] = iconv("utf-8", "euc-kr", '주문자 본인 취소-'.$cancel_memo);
$_POST['site_cd'] = $default['de_kcp_mid'];
// 취소내역 한글깨짐방지
setlocale(LC_CTYPE, 'ko_KR.euc-kr');
include G5_SHOP_PATH.'/kcp/pp_ax_hub.php';
// locale 설정 초기화
setlocale(LC_CTYPE, '');
}
}
// 장바구니 자료 취소
sql_query(" update {$g5['g5_shop_cart_table']} set ct_status = '취소' where od_id = '$od_id' ");
// 주문 취소
$cancel_memo = addslashes(strip_tags($cancel_memo));
$cancel_price = $od['od_cart_price'];
$sql = " update {$g5['g5_shop_order_table']}
set od_send_cost = '0',
od_send_cost2 = '0',
od_receipt_price = '0',
od_receipt_point = '0',
od_misu = '0',
od_cancel_price = '$cancel_price',
od_cart_coupon = '0',
od_coupon = '0',
od_send_coupon = '0',
od_status = '취소',
od_shop_memo = concat(od_shop_memo,\"\\n주문자 본인 직접 취소 - ".G5_TIME_YMDHIS." (취소이유 : {$cancel_memo})\")
where od_id = '$od_id' ";
sql_query($sql);
// 주문취소 회원의 포인트를 되돌려 줌
if ($od['od_receipt_point'] > 0)
insert_point($member['mb_id'], $od['od_receipt_point'], "주문번호 $od_id 본인 취소");
goto_url(G5_SHOP_URL."/orderinquiryview.php?od_id=$od_id&amp;uid=$uid");