73 lines
2.7 KiB
PHP
73 lines
2.7 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* [Discuz!] (C)2001-2099 Comsenz Inc.
|
||
|
* This is NOT a freeware, use is subject to license terms
|
||
|
*
|
||
|
* $Id: notify_credit.php 34251 2013-11-25 03:10:11Z nemohou $
|
||
|
*/
|
||
|
|
||
|
define('IN_API', true);
|
||
|
define('CURSCRIPT', 'api');
|
||
|
define('DISABLEXSSCHECK', true);
|
||
|
|
||
|
require '../../source/class/class_core.php';
|
||
|
require '../../source/function/function_forum.php';
|
||
|
|
||
|
$discuz = C::app();
|
||
|
$discuz->init();
|
||
|
|
||
|
$apitype = empty($_GET['attach']) || !preg_match('/^[a-z0-9]+$/i', $_GET['attach']) ? 'alipay' : $_GET['attach'];
|
||
|
require_once DISCUZ_ROOT.'./api/trade/api_'.$apitype.'.php';
|
||
|
$PHP_SELF = $_SERVER['PHP_SELF'];
|
||
|
$_G['siteurl'] = dhtmlspecialchars('http://'.$_SERVER['HTTP_HOST'].preg_replace("/\/+(api\/trade)?\/*$/i", '', substr($PHP_SELF, 0, strrpos($PHP_SELF, '/'))).'/');
|
||
|
$notifydata = trade_notifycheck('credit');
|
||
|
|
||
|
if($notifydata['validator']) {
|
||
|
|
||
|
$orderid = $notifydata['order_no'];
|
||
|
$postprice = $notifydata['price'];
|
||
|
$order = C::t('forum_order')->fetch($orderid);
|
||
|
$order = array_merge($order, C::t('common_member')->fetch_by_username($order['uid']));
|
||
|
if($order && floatval($postprice) == floatval($order['price']) && ($apitype == 'tenpay' || strtolower($_G['setting']['ec_account']) == strtolower($_REQUEST['seller_email']))) {
|
||
|
|
||
|
if($order['status'] == 1) {
|
||
|
C::t('forum_order')->update($orderid, array('status' => '2', 'buyer' => "$notifydata[trade_no]\t$apitype", 'confirmdate' => $_G['timestamp']));
|
||
|
updatemembercount($order['uid'], array($_G['setting']['creditstrans'] => $order['amount']), 1, 'AFD', $order['uid']);
|
||
|
updatecreditbyaction($action, $uid = 0, $extrasql = array(), $needle = '', $coef = 1, $update = 1, $fid = 0);
|
||
|
C::t('forum_order')->delete_by_submitdate($_G['timestamp']-60*86400);
|
||
|
$submitdate = dgmdate($order['submitdate']);
|
||
|
$confirmdate = dgmdate(TIMESTAMP);
|
||
|
|
||
|
notification_add($order['uid'], 'credit', 'addfunds', array(
|
||
|
'orderid' => $order['orderid'],
|
||
|
'price' => $order['price'],
|
||
|
'value' => $_G['setting']['extcredits'][$_G['setting']['creditstrans']]['title'].' '.$order['amount'].' '.$_G['setting']['extcredits'][$_G['setting']['creditstrans']]['unit']
|
||
|
), 1);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
if($notifydata['location']) {
|
||
|
$url = rawurlencode('home.php?mod=spacecp&ac=credit');
|
||
|
if($apitype == 'tenpay') {
|
||
|
echo <<<EOS
|
||
|
<meta name="TENCENT_ONLINE_PAYMENT" content="China TENCENT">
|
||
|
<html>
|
||
|
<body>
|
||
|
<script language="javascript" type="text/javascript">
|
||
|
window.location.href='$_G[siteurl]forum.php?mod=misc&action=paysucceed';
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|
||
|
EOS;
|
||
|
} else {
|
||
|
dheader('location: '.$_G['siteurl'].'forum.php?mod=misc&action=paysucceed');
|
||
|
}
|
||
|
} else {
|
||
|
exit($notifydata['notify']);
|
||
|
}
|
||
|
|
||
|
?>
|