game2004api/webapp/controller/RechargeController.class.php
2025-01-03 11:34:09 +08:00

251 lines
8.7 KiB
PHP

<?php
require 'classes/Quest.php';
require 'classes/AddReward.php';
class RechargeController
{
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'];
$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 ($rsp == null || $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 ($rsp == null || $rsp == '') {
phpcommon\sendError(ERR_RETRY, '系统繁忙 2');
return;
}
$response = json_decode($rsp, true);
$diamonds = $response['diamond'];
$diamond_num = -1;
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;
}
$diamond_present = 0;
$shopgoods_conf = metatable\getShopGoodsConf();
$goodsid = 0;
if ($shopgoods_conf) {
for ($i = 1; $i <= count($shopgoods_conf); $i++) {
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 first_data FROM recharge WHERE accountid=:accountid;',
array(
':accountid' => $account_id
)
);
if (!$rechargerow) {
$ret = $conn->execScript(
'INSERT INTO recharge(accountid, first_data, recharge_diamond, present_diamond, create_time, modify_time) ' .
' VALUES(:account_id, :first_data, :recharge_diamond, :present_diamond, :create_time, :modify_time) ' .
' ON DUPLICATE KEY UPDATE accountid=:account_id, first_data=:first_data, recharge_diamond=:recharge_diamond, present_diamond=:present_diamond, modify_time=:modify_time;',
array(
':account_id' => $account_id,
':first_data' => $goodsid,
':recharge_diamond' => $diamonds,
':present_diamond' => $diamond_present,
':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) {
$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, 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,
':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 activityInfo()
{
$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
)
);
$firstrecharge = '';
if ($rechargerow) {
$firstrecharge = $rechargerow['first_data'];
}
echo json_encode(array(
'errcode' => 0,
'errmsg' => '',
'first_recharge' => $firstrecharge,
));
}
}