1144 lines
45 KiB
PHP
1144 lines
45 KiB
PHP
<?php
|
|
|
|
require 'classes/Quest.php';
|
|
require 'classes/AddReward.php';
|
|
require 'classes/Privilege.php';
|
|
require 'classes/RechargeActivity.php';
|
|
require_once 'metatable/shopGoods.php';
|
|
require_once 'metatable/privilegecard.php';
|
|
require_once 'metatable/rechargeActivity.php';
|
|
require_once 'metatable/item.php';
|
|
require_once 'metatable/parameter.php';
|
|
require_once 'RechargeActivity.trait.php';
|
|
|
|
class RechargeController
|
|
{
|
|
use RechargeActivity;
|
|
protected function getRedis($key)
|
|
{
|
|
$redis_conf = getRedisConfig(crc32($key));
|
|
$r = new phpcommon\Redis(array(
|
|
'host' => $redis_conf['host'],
|
|
'port' => $redis_conf['port'],
|
|
'passwd' => $redis_conf['passwd']
|
|
|
|
));
|
|
return $r;
|
|
}
|
|
|
|
protected function getMysql($account_id)
|
|
{
|
|
$mysql_conf = getMysqlConfig(crc32($account_id));
|
|
$conn = new phpcommon\Mysql(array(
|
|
'host' => $mysql_conf['host'],
|
|
'port' => $mysql_conf['port'],
|
|
'user' => $mysql_conf['user'],
|
|
'passwd' => $mysql_conf['passwd'],
|
|
'dbname' => DBNAME_PREFIX . $mysql_conf['instance_id']
|
|
));
|
|
return $conn;
|
|
}
|
|
|
|
public function prePay()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
//登录校验
|
|
$login = loginVerify($account_id, $_REQUEST['session_id']);
|
|
if (!$login) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, 'session无效');
|
|
return;
|
|
}
|
|
$conn = $this->getMysql($account_id);
|
|
if (!$conn) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$goods_id = $_REQUEST['goods_id'];
|
|
if (!$this->checkPurchaseLimit($conn, $account_id, $goods_id)) {
|
|
phpcommon\sendError(ERR_USER_BASE + 2, '不能购买');
|
|
return;
|
|
}
|
|
|
|
$url = '';
|
|
if (SERVER_ENV == _ONLINE) {
|
|
$url = 'https://payservice.kingsome.cn/api/ingame/spreorder';
|
|
} else {
|
|
$url = 'https://payservice-test.kingsome.cn/api/ingame/spreorder';
|
|
}
|
|
$sign = md5($_REQUEST['account_id'] . $_REQUEST['goods_id'] . 'f3a6a9a5-217a-4079-ab99-b5d69b8212be' . $_REQUEST['session_id']);
|
|
$params = array(
|
|
'account_id' => $_REQUEST['account_id'],
|
|
'goods_id' => $goods_id,
|
|
'session_id' => $_REQUEST['session_id'],
|
|
'user_ip' => phpcommon\getIPv4(),
|
|
'sign' => $sign
|
|
);
|
|
if (!phpcommon\HttpClient::get($url, $params, $rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙');
|
|
return;
|
|
}
|
|
|
|
if (is_null($rsp) || empty($rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙2');
|
|
return;
|
|
}
|
|
|
|
$response = json_decode($rsp, true);
|
|
echo json_encode(array(
|
|
'errcode' => $response['errcode'],
|
|
'errmsg' => $response['errmsg'],
|
|
'order_id' => $response['order_id']
|
|
));
|
|
}
|
|
|
|
public function payDone()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
//登录校验
|
|
$login = loginVerify($account_id, $_REQUEST['session_id']);
|
|
if (!$login) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, 'session无效');
|
|
return;
|
|
}
|
|
$conn = $this->getMysql($account_id);
|
|
if (!$conn) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$order_id = $_REQUEST['order_id'];
|
|
|
|
$url = '';
|
|
if (SERVER_ENV == _ONLINE) {
|
|
$url = 'https://payservice.kingsome.cn/api/ingame/paid';
|
|
} else {
|
|
$url = 'https://payservice-test.kingsome.cn/api/ingame/paid';
|
|
}
|
|
$sign = md5($_REQUEST['account_id'] . $_REQUEST['order_id'] . 'f3a6a9a5-217a-4079-ab99-b5d69b8212be' . $_REQUEST['session_id']);
|
|
$params = array(
|
|
'account_id' => $_REQUEST['account_id'],
|
|
'order_id' => $order_id,
|
|
'session_id' => $_REQUEST['session_id'],
|
|
'user_ip' => phpcommon\getIPv4(),
|
|
'sign' => $sign
|
|
);
|
|
if (!phpcommon\HttpClient::get($url, $params, $rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙');
|
|
return;
|
|
}
|
|
|
|
if (is_null($rsp) || empty($rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙 2');
|
|
return;
|
|
}
|
|
|
|
$response = json_decode($rsp, true);
|
|
$diamonds = $response['diamond'];
|
|
$diamond_num = -1;
|
|
$diamond_present = 0;
|
|
if ($diamonds > 0) {
|
|
$userrow = $conn->execQueryOne(
|
|
'SELECT diamond_num, free_diamond FROM user WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
if (!$userrow) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$shopgoods_conf = metatable\getShopGoodsConf();
|
|
$goodsid = 0;
|
|
if ($shopgoods_conf) {
|
|
for ($i = 1; $i <= count($shopgoods_conf); $i++) {
|
|
if ($shopgoods_conf[$i]['type'] != 1) {
|
|
continue;
|
|
}
|
|
|
|
if ($diamonds < $shopgoods_conf[$i]['item_num']) {
|
|
continue;
|
|
}
|
|
|
|
if ($shopgoods_conf[$i]['first_present'] > $diamond_present) {
|
|
$diamond_present = $shopgoods_conf[$i]['first_present'];
|
|
$goodsid = $shopgoods_conf[$i]['shop_id'];
|
|
}
|
|
}
|
|
}
|
|
|
|
$rechargerow = $conn->execQueryOne(
|
|
'SELECT * FROM recharge WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
|
|
$rechargeactivity = new classes\RechargeActivity();
|
|
$activity = array();
|
|
if ($rechargerow && !is_null($rechargerow['activity']) && !empty($rechargerow['activity'])) {
|
|
$activity = json_decode($rechargerow['activity'], true);
|
|
}
|
|
$rechargeactivity->updateActivityCur($activity, $diamonds, true);
|
|
if (!$rechargerow) {
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO recharge(accountid, first_data, recharge_diamond, present_diamond, activity, daily_purchase, vip_info, first_purchase, create_time, modify_time) ' .
|
|
' VALUES(:account_id, :first_data, :recharge_diamond, :present_diamond, :activity, :daily_purchase, :vip_info, :first_purchase, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, first_data=:first_data, recharge_diamond=:recharge_diamond, present_diamond=:present_diamond, activity=:activity, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':first_data' => $goodsid,
|
|
':recharge_diamond' => $diamonds,
|
|
':present_diamond' => $diamond_present,
|
|
':activity' => json_encode($activity),
|
|
':daily_purchase' => '',
|
|
':vip_info' => '',
|
|
':first_purchase' => '',
|
|
':create_time' => time(),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
} else {
|
|
$firstlist = explode(',', $rechargerow['first_data']);
|
|
$firstrecharge = true;
|
|
for ($i = 0; $i < count($firstlist); $i++) {
|
|
if ($firstlist[$i] == $goodsid) {
|
|
$firstrecharge = false;
|
|
}
|
|
}
|
|
|
|
$firstdata = $rechargerow['first_data'];
|
|
if ($firstrecharge) {
|
|
if (is_null($firstdata) || empty($firstdata)) {
|
|
$firstdata = $goodsid;
|
|
} else {
|
|
$firstdata = $rechargerow['first_data'] . ',' . $goodsid;
|
|
}
|
|
} else {
|
|
$diamond_present = 0;
|
|
}
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE recharge SET first_data=:first_data, recharge_diamond=:recharge_diamond, present_diamond=:present_diamond, activity=:activity, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':first_data' => $firstdata,
|
|
':recharge_diamond' => $rechargerow['recharge_diamond'] + $diamonds,
|
|
':present_diamond' => $rechargerow['present_diamond'] + $diamond_present,
|
|
':activity' => json_encode($activity),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
}
|
|
|
|
$diamond_num = $userrow['diamond_num'] + $diamonds + $diamond_present;
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE user SET diamond_num=:diamond_num' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':diamond_num' => $diamond_num
|
|
)
|
|
);
|
|
if (!$ret) {
|
|
die();
|
|
return;
|
|
}
|
|
}
|
|
echo json_encode(array(
|
|
'errcode' => $response['errcode'],
|
|
'errmsg' => $response['errmsg'],
|
|
'order_id' => $response['order_id'],
|
|
'diamond_nums' => $diamond_num,
|
|
'diamond_present' => $diamond_present,
|
|
));
|
|
}
|
|
|
|
public function preparePay()
|
|
{
|
|
$this->prePay();
|
|
}
|
|
|
|
public function preparePayDone()
|
|
{
|
|
$this->purchaseDone();
|
|
}
|
|
|
|
public function prePurchase()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
//登录校验
|
|
$login = loginVerify($account_id, $_REQUEST['session_id']);
|
|
if (!$login) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, 'session无效');
|
|
return;
|
|
}
|
|
$conn = $this->getMysql($account_id);
|
|
if (!$conn) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$raw_data = file_get_contents('php://input');
|
|
$sigdata = json_decode($raw_data, true);
|
|
if (!$this->checkPurchaseLimit($conn, $account_id, $sigdata['productId'])) {
|
|
phpcommon\sendError(ERR_USER_BASE + 2, '不能购买');
|
|
return;
|
|
}
|
|
|
|
$url = '';
|
|
if (SERVER_ENV == _ONLINE) {
|
|
$url = 'https://payservice.kingsome.cn/api/ingame/sprepurchase';
|
|
} else {
|
|
$url = 'https://payservice-test.kingsome.cn/api/ingame/sprepurchase';
|
|
}
|
|
$sign = md5($_REQUEST['account_id'] . 'f3a6a9a5-217a-4079-ab99-b5d69b8212be' . $_REQUEST['session_id']);
|
|
$params = array(
|
|
'account_id' => $_REQUEST['account_id'],
|
|
'session_id' => $_REQUEST['session_id'],
|
|
'user_ip' => phpcommon\getIPv4(),
|
|
'sign' => $sign,
|
|
'sig_data' => $raw_data,
|
|
);
|
|
if (!phpcommon\HttpClient::post($url, json_encode($params), $rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙');
|
|
return;
|
|
}
|
|
|
|
if (is_null($rsp) || empty($rsp)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙2');
|
|
return;
|
|
}
|
|
|
|
$response = json_decode($rsp, true);
|
|
echo json_encode(array(
|
|
'errcode' => $response['errcode'],
|
|
'errmsg' => $response['errmsg'],
|
|
'order_id' => $response['errcode'] == 0 ? $response['order_id'] : '',
|
|
'pay_sig' => $response['errcode'] == 0 ? $response['pay_sig'] : '',
|
|
'signature' => $response['errcode'] == 0 ? $response['signature'] : '',
|
|
'sig_data' => $response['errcode'] == 0 ? $response['sig_data'] : '',
|
|
));
|
|
}
|
|
|
|
public function purchaseDone()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
//登录校验
|
|
$login = loginVerify($account_id, $_REQUEST['session_id']);
|
|
if (!$login) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, 'session无效');
|
|
return;
|
|
}
|
|
|
|
$order_id = $_REQUEST['order_id'];
|
|
if ($order_id == '') {
|
|
die();
|
|
return;
|
|
}
|
|
|
|
$key = 'game2004api-purchase:' . $account_id . '-' . $order_id;
|
|
$r = $this->getRedis($key);
|
|
if (!$r) {
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => '',
|
|
'order_id' => $order_id,
|
|
'status' => 0,
|
|
));
|
|
return;
|
|
}
|
|
|
|
$user_purchase_str = $r->get($key);
|
|
if (empty($user_purchase_str)) {
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => '',
|
|
'order_id' => $order_id,
|
|
'status' => 0,
|
|
));
|
|
return;
|
|
}
|
|
|
|
echo $user_purchase_str;
|
|
}
|
|
|
|
public function adFree()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
//登录校验
|
|
$login = loginVerify($account_id, $_REQUEST['session_id']);
|
|
if (!$login) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, 'session无效');
|
|
return;
|
|
}
|
|
$conn = $this->getMysql($account_id);
|
|
if (!$conn) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
|
|
$rechargerow = $conn->execQueryOne(
|
|
'SELECT * FROM recharge WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
|
|
if (!$rechargerow || $rechargerow['adfree'] < 1) {
|
|
phpcommon\sendError(ERR_USER_BASE + 2, '券不足');
|
|
return;
|
|
}
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE recharge SET adfree=adfree-1, modify_time=:modify_time WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':modify_time' => time(),
|
|
)
|
|
);
|
|
|
|
if (!$ret) {
|
|
phpcommon\sendError(ERR_INTERNAL + 1, '系统繁忙');
|
|
return;
|
|
}
|
|
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => '',
|
|
'adfree' => $rechargerow['adfree'] - 1,
|
|
));
|
|
}
|
|
|
|
protected function checkPurchaseLimit($conn, $account_id, $productid)
|
|
{
|
|
$prod_conf = metatable\getShopGoodsById($productid);
|
|
if (!$prod_conf) {
|
|
return false;
|
|
}
|
|
|
|
if ($prod_conf['type'] != 2) {
|
|
return true;
|
|
}
|
|
|
|
$conn = $this->getMysql($_REQUEST['account_id']);
|
|
$rechargerow = $conn->execQueryOne(
|
|
'SELECT * FROM recharge WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
|
|
if (!$rechargerow) {
|
|
return true;
|
|
}
|
|
|
|
$daily_purchase = $rechargerow['daily_purchase'];
|
|
if (is_null($daily_purchase) || empty($daily_purchase)) {
|
|
return true;
|
|
}
|
|
|
|
$todaysecs = phpcommon\getdayseconds(time());
|
|
$daily_obj = json_decode($daily_purchase . true);
|
|
if (!$daily_obj) {
|
|
return true;
|
|
}
|
|
|
|
if ($productid == 10) {
|
|
foreach ($daily_obj as $item) {
|
|
if ($item['time'] > $todaysecs) {
|
|
return false;
|
|
}
|
|
}
|
|
} else {
|
|
foreach ($daily_obj as $item) {
|
|
if (($item['id'] == $productid || $item['id'] == 10) && $item['time'] > $todaysecs) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public function purchaseNotify()
|
|
{
|
|
$params = array(
|
|
'account_id' => $_REQUEST['account_id'],
|
|
'goodsid' => $_REQUEST['goodsid'],
|
|
'orderid' => $_REQUEST['orderid'],
|
|
'amount' => $_REQUEST['amount'],
|
|
);
|
|
$goodsid = $_REQUEST['goodsid'];
|
|
$oristr = 'account_id=' . $_REQUEST['account_id'] . '&goodsid=' . $goodsid . '&orderid=' . $_REQUEST['orderid'] . '&amount=' . $_REQUEST['amount'] . ':' . $_REQUEST['timestamp'] . 'NrN3zkVOzXF1vRzUc9eJM9ZKRO5eLooD';
|
|
//$sign = phpcommon\md5Sign($params, 'NrN3zkVOzXF1vRzUc9eJM9ZKRO5eLooD', $_REQUEST['timestamp']);
|
|
$sign = md5($oristr);
|
|
error_log('src:' . $oristr . '|' . $sign . '|' . $_REQUEST['sign']);
|
|
if ($sign != $_REQUEST['sign']) {
|
|
error_log('game2004api payNotify sign error:' + $sign + '|' + json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 1,
|
|
'errmsg' => '签名校验失败'
|
|
));
|
|
die();
|
|
}
|
|
|
|
$shopgoods = metatable\getShopGoodsById($goodsid);
|
|
if (!$shopgoods) {
|
|
error_log('game2004api payNotify goods error:' + json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 2,
|
|
'errmsg' => 'goods 未找到'
|
|
));
|
|
die();
|
|
}
|
|
|
|
if (
|
|
$shopgoods['type'] != 1 && //钻石
|
|
$shopgoods['type'] != 2 && //特惠礼包
|
|
$shopgoods['type'] != 3 && //月卡
|
|
$shopgoods['type'] != 5 && //等级基金
|
|
$shopgoods['type'] != 6 && //首充
|
|
$shopgoods['type'] != 7 && //关卡基金
|
|
$shopgoods['type'] != 8 && //体力基金
|
|
$shopgoods['type'] != 9 //精英手册
|
|
) {
|
|
error_log('game2004api payNotify goods type error:' + json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 3,
|
|
'errmsg' => 'goods type error'
|
|
));
|
|
die();
|
|
}
|
|
|
|
$privilegecard_conf = null;
|
|
if ($shopgoods['type'] == 3) {
|
|
$privilegecard_conf = metatable\getPrivilegeCardById($goodsid);
|
|
if (!$privilegecard_conf) {
|
|
error_log('game2004api payNotify privilege card goods config error:' + json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 4,
|
|
'errmsg' => 'privilege card error'
|
|
));
|
|
die();
|
|
}
|
|
}
|
|
|
|
$conn = $this->getMysql($_REQUEST['account_id']);
|
|
if (!$conn) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$orderRow = $conn->execQueryOne(
|
|
'SELECT * FROM orderinfo WHERE orderid=:orderid',
|
|
array(
|
|
':orderid' => $_REQUEST['orderid']
|
|
)
|
|
);
|
|
if ($orderRow) {
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => ''
|
|
));
|
|
die();
|
|
}
|
|
|
|
$nowtime = time();
|
|
$this->insertNewOrder($conn, $nowtime);
|
|
$this->updateUserTable($conn);
|
|
$this->addToBuyHis($conn, $nowtime);
|
|
$account_id = $_REQUEST['account_id'];
|
|
$rechargerow = $conn->execQueryOne(
|
|
'SELECT * FROM recharge WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
|
|
$all_item_list = array();
|
|
$item_list = array();
|
|
$addreward = new classes\AddReward();
|
|
if ($shopgoods['type'] != 1 && $shopgoods['first_present'] > 0) {
|
|
array_push($item_list, array(
|
|
'item_id' => 10003,
|
|
'item_num' => $shopgoods['first_present'],
|
|
'time' => 0,
|
|
));
|
|
$addreward->addReward(10003, $shopgoods['first_present'], $account_id, 0, 0);
|
|
}
|
|
|
|
$rechargeactivity = new classes\RechargeActivity();
|
|
$activity = array();
|
|
if ($rechargerow && !is_null($rechargerow['activity']) && !empty($rechargerow['activity'])) {
|
|
$activity = json_decode($rechargerow['activity'], true);
|
|
}
|
|
$rechargeactivity->updateActivityCur($activity, $shopgoods['price'] * 10, true);
|
|
|
|
$diamond_present = 0;
|
|
if ($shopgoods['type'] == 1) {
|
|
$diamonds = $shopgoods['item_num'];
|
|
$userrow = $conn->execQueryOne(
|
|
'SELECT diamond_num, free_diamond FROM user WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
if (!$userrow) {
|
|
phpcommon\sendError(ERR_USER_BASE + 1, '没有这个玩家');
|
|
return;
|
|
}
|
|
|
|
$diamond_present = $shopgoods['first_present'];
|
|
if (!$rechargerow) {
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO recharge(accountid, first_data, recharge_diamond, present_diamond, activity, daily_purchase, vip_info, first_purchase, create_time, modify_time) ' .
|
|
' VALUES(:account_id, :first_data, :recharge_diamond, :present_diamond, :activity, :daily_purchase, :vip_info, :first_purchase, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, first_data=:first_data, recharge_diamond=:recharge_diamond, present_diamond=:present_diamond, activity=:activity, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':first_data' => $goodsid,
|
|
':recharge_diamond' => $diamonds,
|
|
':present_diamond' => $diamond_present,
|
|
':activity' => json_encode($activity),
|
|
':daily_purchase' => '',
|
|
':vip_info' => '',
|
|
':first_purchase' => '',
|
|
':create_time' => time(),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
} else {
|
|
$firstlist = explode(',', $rechargerow['first_data']);
|
|
$firstrecharge = true;
|
|
for ($i = 0; $i < count($firstlist); $i++) {
|
|
if ($firstlist[$i] == $goodsid) {
|
|
$firstrecharge = false;
|
|
}
|
|
}
|
|
|
|
$firstdata = $rechargerow['first_data'];
|
|
if ($firstrecharge) {
|
|
if (is_null($firstdata) || empty($firstdata)) {
|
|
$firstdata = $goodsid;
|
|
} else {
|
|
$firstdata = $rechargerow['first_data'] . ',' . $goodsid;
|
|
}
|
|
} else {
|
|
$diamond_present = 0;
|
|
}
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE recharge SET first_data=:first_data, recharge_diamond=:recharge_diamond, present_diamond=:present_diamond, activity=:activity, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':first_data' => $firstdata,
|
|
':recharge_diamond' => $rechargerow['recharge_diamond'] + $diamonds,
|
|
':present_diamond' => $rechargerow['present_diamond'] + $diamond_present,
|
|
':activity' => json_encode($activity),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
}
|
|
|
|
$diamond_num = $userrow['diamond_num'] + $diamonds + $diamond_present;
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE user SET diamond_num=:diamond_num' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':diamond_num' => $diamond_num
|
|
)
|
|
);
|
|
array_push($item_list, array(
|
|
'item_id' => 10003,
|
|
'item_num' => $diamonds + $diamond_present,
|
|
'time' => 0,
|
|
));
|
|
} else if ($shopgoods['type'] == 3) {
|
|
$nowtime = time();
|
|
// update vip_info
|
|
if (!$rechargerow) {
|
|
$vip_info = array();
|
|
$expire = 0;
|
|
if ($privilegecard_conf['time'] > 0) {
|
|
$expire = phpcommon\getdayseconds($nowtime) + $privilegecard_conf['time'] * 3600 * 24 + 3600 * 24 - 1;
|
|
}
|
|
array_push($vip_info, array(
|
|
'id' => $_REQUEST['goodsid'],
|
|
'expire' => $expire,
|
|
'daily_time' => 0,
|
|
));
|
|
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO recharge(accountid, vip_info, activity, first_data, daily_purchase, first_purchase, create_time, modify_time) ' .
|
|
' VALUES(:account_id, :vip_info, :activity, :first_data, :daily_purchase, :first_purchase, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, vip_info=:vip_info, activity=:activity, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':vip_info' => json_encode($vip_info),
|
|
':activity' => json_encode($activity),
|
|
':first_data' => '',
|
|
':daily_purchase' => '',
|
|
':first_purchase' => '',
|
|
':create_time' => $nowtime,
|
|
':modify_time' => $nowtime,
|
|
)
|
|
);
|
|
} else {
|
|
$vip_info = array();
|
|
if (!is_null($rechargerow['vip_info'])) {
|
|
$vip_info = json_decode($rechargerow['vip_info'], true);
|
|
}
|
|
$found = false;
|
|
foreach ($vip_info as $key => $carditem) {
|
|
if ($carditem['id'] == $_REQUEST['goodsid']) {
|
|
$found = true;
|
|
if ($vip_info[$key]['expire'] > $nowtime) {
|
|
$vip_info[$key]['expire'] += $privilegecard_conf['time'] * 3600 * 24;
|
|
} else {
|
|
if ($privilegecard_conf['time'] > 0) {
|
|
$vip_info[$key]['expire'] = phpcommon\getdayseconds($nowtime) + $privilegecard_conf['time'] * 3600 * 24 + 3600 * 24 - 1;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$found) {
|
|
$expire = 0;
|
|
if ($privilegecard_conf['time'] > 0) {
|
|
$expire = phpcommon\getdayseconds($nowtime) + $privilegecard_conf['time'] * 3600 * 24 + 3600 * 24 - 1;
|
|
}
|
|
array_push($vip_info, array(
|
|
'id' => $_REQUEST['goodsid'],
|
|
'expire' => $expire,
|
|
'daily_time' => 0,
|
|
));
|
|
}
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE recharge SET vip_info=:vip_info, activity=:activity, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':vip_info' => json_encode($vip_info),
|
|
':activity' => json_encode($activity),
|
|
':modify_time' => time(),
|
|
)
|
|
);
|
|
}
|
|
} else if ($shopgoods['type'] == 2) {
|
|
$itemconf = metatable\getItemById($shopgoods['item_id']);
|
|
if (!$itemconf) {
|
|
error_log('game2004api purchaseNotify daily goods config error:' . json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 4,
|
|
'errmsg' => 'privilege card error 2'
|
|
));
|
|
die();
|
|
}
|
|
|
|
$dropconf = $this->getDrop($itemconf['fuctionindex']);
|
|
if (!$dropconf) {
|
|
error_log('game2004api purchaseNotify daily goods config error 1:' . json_encode($_REQUEST));
|
|
echo json_encode(array(
|
|
'errcode' => 4,
|
|
'errmsg' => 'privilege card error 3'
|
|
));
|
|
die();
|
|
}
|
|
$itemidlist = explode('|', $dropconf['item_id']);
|
|
$itemnumlist = explode('|', $dropconf['num']);
|
|
foreach ($itemidlist as $key => $itemid) {
|
|
array_push($item_list, array(
|
|
'item_id' => $itemid,
|
|
'item_num' => $itemnumlist[$key],
|
|
'time' => 0,
|
|
));
|
|
$items = $addreward->addReward($itemid, $itemnumlist[$key], $account_id, 0, 0);
|
|
foreach ($items as $i) {
|
|
array_push($all_item_list, array(
|
|
'item_id' => $i['item_id'],
|
|
'item_num' => $i['item_num'],
|
|
'time' => $i['time'],
|
|
));
|
|
}
|
|
}
|
|
|
|
error_log(json_encode($item_list));
|
|
|
|
//update daily purchase
|
|
if (!$rechargerow) {
|
|
$daily_purchase = array();
|
|
array_push($daily_purchase, array(
|
|
'id' => $_REQUEST['goodsid'],
|
|
'time' => $_REQUEST['timestamp'],
|
|
));
|
|
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO recharge(accountid, daily_purchase, activity, first_data, vip_info, first_purchase, create_time, modify_time) ' .
|
|
' VALUES(:account_id, :daily_purchase, :activity, :first_data, :vip_info, :first_purchase, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, daily_purchase=:daily_purchase, activity=:activity, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':daily_purchase' => json_encode($daily_purchase),
|
|
':activity' => json_encode($activity),
|
|
':first_data' => '',
|
|
':vip_info' => '',
|
|
':first_purchase' => '',
|
|
':create_time' => time(),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
} else {
|
|
$daily_purchase = array();
|
|
if (!is_null($rechargerow['daily_purchase'])) {
|
|
$daily_purchase = json_decode($rechargerow['daily_purchase'], true);
|
|
}
|
|
$found = false;
|
|
foreach ($daily_purchase as $key => $dailyitem) {
|
|
if ($dailyitem['id'] == $_REQUEST['goodsid']) {
|
|
$found = true;
|
|
$daily_purchase[$key]['time'] = $_REQUEST['timestamp'];
|
|
}
|
|
}
|
|
|
|
if (!$found) {
|
|
array_push($daily_purchase, array(
|
|
'id' => $_REQUEST['goodsid'],
|
|
'time' => $_REQUEST['timestamp'],
|
|
));
|
|
}
|
|
|
|
$ret = $conn->execScript(
|
|
'UPDATE recharge SET daily_purchase=:daily_purchase, activity=:activity, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':daily_purchase' => json_encode($daily_purchase),
|
|
':activity' => json_encode($activity),
|
|
':modify_time' => time(),
|
|
)
|
|
);
|
|
}
|
|
} else if ($shopgoods['type'] == 6) {
|
|
$purchasekey = 'shop_' . $goodsid;
|
|
$purchaseinfo = array(
|
|
'count' => 0,
|
|
'time' => 0,
|
|
);
|
|
if (!$rechargerow) {
|
|
$first_purchase = array(
|
|
$purchasekey => $purchaseinfo,
|
|
);
|
|
$conn->execScript(
|
|
'INSERT INTO recharge(accountid, first_purchase, activity, first_data, vip_info, daily_purchase, create_time, modify_time) ' .
|
|
' VALUES(:account_id, :first_purchase, :activity, :first_data, :vip_info, :daily_purchase, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, first_purchase=:first_purchase, activity=:activity, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':first_purchase' => json_encode($first_purchase),
|
|
':activity' => json_encode($activity),
|
|
':first_data' => '',
|
|
':vip_info' => '',
|
|
':daily_purchase' => '',
|
|
':create_time' => time(),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
} else {
|
|
$first_purchase = array();
|
|
if (!is_null($rechargerow['first_purchase']) && !empty($rechargerow['first_purchase'])) {
|
|
$first_purchase = json_decode($rechargerow['first_purchase'], true);
|
|
}
|
|
$first_purchase[$purchasekey] = $purchaseinfo;
|
|
$conn->execScript(
|
|
'UPDATE recharge SET first_purchase=:first_purchase, activity=:activity, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':first_purchase' => json_encode($first_purchase),
|
|
':activity' => json_encode($activity),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
}
|
|
} else if ($shopgoods['type'] == 9) {
|
|
//判断当前赛季
|
|
$number = 0;
|
|
$season_meta_table = require('../res/season@season.php');
|
|
for ($i = 1; $i <= count($season_meta_table); $i++) {
|
|
$season = $season_meta_table[$i];
|
|
if (time() >= strtotime($season['time1']) && time() <= strtotime($season['time2'])) {
|
|
$number = $i;
|
|
$item_multiply = explode('|', $season['season_reward']);
|
|
|
|
$passportname = 'shop_' . $goodsid;
|
|
for ($ii = 1; $ii <= count($item_multiply); $ii++) {
|
|
$rowpass = $conn->execQueryOne(
|
|
'SELECT active_status, honor_status, season_passport ' .
|
|
' FROM passinfo WHERE accountid=:accountid AND passid=:passid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':passid' => $ii,
|
|
)
|
|
);
|
|
|
|
$season_passport = array(
|
|
$passportname => 0
|
|
);
|
|
if (!$rowpass) {
|
|
$conn->execScript(
|
|
'INSERT INTO passinfo(accountid, passid, active_status, honor_status, season_passport, create_time, modify_time) ' .
|
|
' VALUES(:accountid, :passid, 0, 0, :season_passport, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:accountid, passid=:passid, active_status=0, honor_status=0, modify_time=:modify_time;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':passid' => $ii,
|
|
':season_passport' => json_encode($season_passport),
|
|
':create_time' => time(),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
} else {
|
|
if (!is_null($rowpass['season_passport']) && !empty($rowpass['season_passport'])) {
|
|
$season_passport = json_decode($rowpass['season_passport'], true);
|
|
$season_passport[$passportname] = 0;
|
|
}
|
|
|
|
$conn->execScript(
|
|
'UPDATE passinfo SET season_passport=:season_passport, modify_time=:modify_time ' .
|
|
' WHERE accountid=:accountid AND passid=:passid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':passid' => $ii,
|
|
':season_passport' => json_encode($season_passport),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
if ($number == 0) {
|
|
phpcommon\sendError(ERR_USER_BASE + 2, '赛季未开启');
|
|
return;
|
|
}
|
|
} else {
|
|
//等级基金,关卡基金,体力基金
|
|
$solorow = $conn->execQueryOne(
|
|
'SELECT funds FROM solo WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id
|
|
)
|
|
);
|
|
|
|
$funds = array();
|
|
$fundsname = 'shop_' . $goodsid;
|
|
if (!$solorow || is_null($solorow['funds']) || empty($solorow['funds'])) {
|
|
$funds = array(
|
|
"playerlevel" => array(
|
|
"hit" => 0,
|
|
"details" => array(
|
|
"free" => array(),
|
|
),
|
|
),
|
|
"gamelevel" => array(
|
|
"hit" => 0,
|
|
"details" => array(
|
|
"free" => array(),
|
|
),
|
|
),
|
|
"medalcost" => array(
|
|
"hit" => 0,
|
|
"sum" => 0,
|
|
"details" => array(
|
|
"free" => array(),
|
|
),
|
|
),
|
|
);
|
|
switch ($shopgoods['type']) {
|
|
case 5;
|
|
$funds['playerlevel']['details'][$fundsname] = array();
|
|
break;
|
|
case 7;
|
|
$funds['gamelevel']['details'][$fundsname] = array();
|
|
break;
|
|
case 8;
|
|
$funds['medalcost']['details'][$fundsname] = array();
|
|
break;
|
|
}
|
|
} else {
|
|
$funds = json_decode($solorow['funds'], true);
|
|
switch ($shopgoods['type']) {
|
|
case 5;
|
|
for ($id = 1; $id <= $funds['playerlevel']['hit']; $id++) {
|
|
$funds['playerlevel']['details'][$fundsname][] = $id;
|
|
}
|
|
break;
|
|
case 7;
|
|
for ($id = 1; $id <= $funds['gamelevel']['hit']; $id++) {
|
|
$funds['gamelevel']['details'][$fundsname][] = $id;
|
|
}
|
|
break;
|
|
case 8;
|
|
for ($id = 1; $id <= $funds['medalcost']['hit']; $id++) {
|
|
$funds['medalcost']['details'][$fundsname][] = $id;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!$solorow) {
|
|
$privilege = new classes\Privilege();
|
|
$medals = intval(metatable\getParameterById(MEDAL_LIMIT)['param_value']) + $privilege->getMedalLimitPlus($account_id);
|
|
$gamelevel = array(
|
|
'curlevel' => 1,
|
|
'curwave' => 0,
|
|
'levelinfo' => array(),
|
|
);
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO solo(accountid, level, exp, medals, lastredeem, lastoffline, gamelevel, funds, create_time, modify_time) ' .
|
|
' VALUES(:account_id, 1, 0, :medals, :lastredeem, :lastoffline, :gamelevel, :funds, :create_time, :modify_time) ' .
|
|
' ON DUPLICATE KEY UPDATE accountid=:account_id, level=1, exp=0, medals=:medals, lastredeem=:lastredeem, lastoffline=:lastoffline, gamelevel=:gamelevel, funds=:funds, modify_time=:modify_time;',
|
|
array(
|
|
':account_id' => $account_id,
|
|
':medals' => $medals,
|
|
':lastredeem' => $nowtime,
|
|
':lastoffline' => $nowtime,
|
|
':gamelevel' => json_encode($gamelevel),
|
|
':funds' => json_encode($funds),
|
|
':create_time' => $nowtime,
|
|
':modify_time' => $nowtime
|
|
)
|
|
);
|
|
} else {
|
|
$ret = $conn->execScript(
|
|
'UPDATE solo SET funds=:funds, modify_time=:modify_time' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $account_id,
|
|
':funds' => json_encode($funds),
|
|
':modify_time' => time()
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => ''
|
|
));
|
|
|
|
$key = 'game2004api-purchase:' . $account_id . '-' . $_REQUEST['orderid'];
|
|
$r = $this->getRedis($key);
|
|
if ($r) {
|
|
$coin_num = $addreward->getCoinNum($account_id);
|
|
$diamond_num = $addreward->getDiamondNum($account_id);
|
|
$adfree = $addreward->getAdfree($account_id);
|
|
$privilege = new classes\Privilege();
|
|
$plustimes = $privilege->getCoinTimesPlus($account_id);
|
|
$user_purchase = array(
|
|
'errcode' => 0,
|
|
'errmsg' => '',
|
|
'order_id' => $_REQUEST['orderid'],
|
|
'status' => 1,
|
|
'coin_nums' => $coin_num,
|
|
'diamond_nums' => $diamond_num,
|
|
'diamond_present' => $diamond_present,
|
|
'adfree' => $adfree,
|
|
'vip_plustime' => $plustimes,
|
|
'item_list' => $item_list,
|
|
'all_item_list' => $all_item_list,
|
|
);
|
|
$purchasestr = json_encode($user_purchase);
|
|
$r->set($key, $purchasestr);
|
|
$r->pexpire($key, 1000 * 15);
|
|
error_log($key . ':' . $purchasestr);
|
|
}
|
|
}
|
|
|
|
private function insertNewOrder($conn, $nowtime)
|
|
{
|
|
$ret = $conn->execScript(
|
|
'INSERT INTO orderinfo(accountid, orderid, goodsid, price, ' .
|
|
' create_time, modify_time)' .
|
|
' VALUES(:accountid, :orderid, :goodsid, :price, ' .
|
|
' :create_time, :modify_time);',
|
|
array(
|
|
':accountid' => $_REQUEST['account_id'],
|
|
':orderid' => $_REQUEST['orderid'],
|
|
':price' => $_REQUEST['amount'],
|
|
':goodsid' => $_REQUEST['goodsid'],
|
|
':create_time' => $nowtime,
|
|
':modify_time' => $nowtime
|
|
)
|
|
);
|
|
if (!$ret) {
|
|
echo json_encode(array(
|
|
'errcode' => 2,
|
|
'errmsg' => '服务器内部错误'
|
|
));
|
|
die();
|
|
}
|
|
}
|
|
|
|
private function updateUserTable($conn)
|
|
{
|
|
$ret = $conn->execScript(
|
|
'UPDATE user SET recharge_times_total=recharge_times_total + 1 ' .
|
|
' WHERE accountid=:accountid;',
|
|
array(
|
|
':accountid' => $_REQUEST['account_id'],
|
|
)
|
|
);
|
|
}
|
|
|
|
private function addToBuyHis($conn, $nowtime)
|
|
{
|
|
$dayseconds = phpcommon\getdayseconds($nowtime);
|
|
$conn->execScript(
|
|
'INSERT INTO buy_his(accountid, goodsid, sum_times, today_times, ' .
|
|
' last_buy_time, create_time, modify_time)' .
|
|
' VALUES(:accountid, :goodsid, 1, 1, ' .
|
|
' :last_buy_time, :create_time, :modify_time)' .
|
|
' ON DUPLICATE KEY UPDATE sum_times=sum_times + 1, ' .
|
|
' modify_time=:modify_time, last_buy_time=:last_buy_time,' .
|
|
' today_times=' .
|
|
" CASE WHEN last_buy_time < $dayseconds THEN 1 ELSE today_times + 1 END;",
|
|
array(
|
|
':accountid' => $_REQUEST['account_id'],
|
|
':goodsid' => $_REQUEST['goodsid'],
|
|
':last_buy_time' => $nowtime,
|
|
':create_time' => $nowtime,
|
|
':modify_time' => $nowtime,
|
|
)
|
|
);
|
|
}
|
|
|
|
protected function getDrop($drop_id)
|
|
{
|
|
$drop_meta_table = require('../res/drop@drop.php');
|
|
$drop_meta = getDropConfig($drop_meta_table, $drop_id);
|
|
if (!$drop_meta) {
|
|
return null;
|
|
}
|
|
|
|
$d = array(
|
|
'drop_id' => $drop_meta['drop_id'],
|
|
'item_id' => $drop_meta['item_id'],
|
|
'num' => $drop_meta['num'],
|
|
'weight' => $drop_meta['weight'],
|
|
'type' => $drop_meta['type']
|
|
);
|
|
return $d;
|
|
}
|
|
}
|