337 lines
13 KiB
PHP
337 lines
13 KiB
PHP
<?php
|
|
|
|
require 'classes/AddReward.php';
|
|
|
|
require_once('mt/SeasonPoint.php');
|
|
|
|
class RankController extends BaseAuthedController {
|
|
|
|
public function rankInfo()
|
|
{
|
|
$account_id = $_REQUEST['account_id'];
|
|
$conn = $this->_getMysql($account_id);
|
|
$kill_list = array();
|
|
$kill_rank = 0;
|
|
$win_list = array();
|
|
$win_rank = 0;
|
|
$user_list = array();
|
|
$integral_rank = 0;
|
|
$integral_list = array();
|
|
$score = 0;
|
|
$myname = '';
|
|
$myavatar_url = '';
|
|
//个人信息
|
|
$row = $conn->execQueryOne('SELECT user_name, avatar_url, kills, alive_time, harm, win_times, game_times, integral FROM user ' .
|
|
' WHERE account_id=:account_id;',
|
|
array(
|
|
':account_id' => $account_id
|
|
));
|
|
if ($row) {
|
|
$seaPoint_meta_table = require('../res/seasomPoint@seasomPoint.php');
|
|
for ($ii = 1; $ii <= count($seaPoint_meta_table); $ii++) {
|
|
$seaPoint = mt\SeasonPoint::getOldSeasonPoint($ii);
|
|
if ($row['integral'] >= $seaPoint['min'] && $row['integral'] <= $seaPoint['max']
|
|
|| $seaPoint['max'] == -1) {
|
|
$rank = $ii;
|
|
break;
|
|
}
|
|
}
|
|
if ($row['avatar_url'] == '' || $row['user_name'] == '') {
|
|
$address = '../res/robot@robot' . 1 . '.php';
|
|
$robot_meta_cluster = require($address);
|
|
$i = Rand(1, 100);
|
|
$robot_id = 1000 + $i;
|
|
$robot_meta = getRobotConfig($robot_meta_cluster, $robot_id);
|
|
$rob = array(
|
|
'name' => $robot_meta['name'],
|
|
'avatar_url' => $robot_meta['avatar_url'],
|
|
);
|
|
if ($row['user_name'] == '') {
|
|
$myname = $rob['name'];
|
|
} else {
|
|
$myname = $row['user_name'];
|
|
}
|
|
if ($row['avatar_url'] == '') {
|
|
$myavatar_url = $rob['avatar_url'];
|
|
} else {
|
|
$myavatar_url = $row['avatar_url'];
|
|
}
|
|
} else {
|
|
$myname = $row['user_name'];
|
|
$myavatar_url = $row['avatar_url'];
|
|
}
|
|
$myavatar_url = urldecode($myavatar_url);
|
|
array_push($user_list, array(
|
|
'account_id' => $account_id,
|
|
'name' => $myname,
|
|
'avatar_url' => $myavatar_url,
|
|
'kill' => phpcommon\safediv($row['kills'], $row['game_times']),
|
|
'alive'=> phpcommon\safediv($row['alive_time'], $row['game_times']),
|
|
'harm' => phpcommon\safediv($row['harm'], $row['game_times']),
|
|
'win_rate' => phpcommon\safediv($row['win_times'], $row['game_times']),
|
|
'win_game' => $row['win_times'],
|
|
'score' => $row['integral'],
|
|
'level' => $rank,
|
|
));
|
|
}
|
|
ini_set('memory_limit','3072M');
|
|
//击杀榜
|
|
$r = $this->_getRedis('');
|
|
//胜场榜
|
|
$channel = phpcommon\extractChannel($account_id);
|
|
$win_rank_db = $r->get("game2005api:win_rank_" . $channel);
|
|
$win_db = json_decode($win_rank_db);
|
|
$i = 0;
|
|
foreach ($win_db as $win) {
|
|
$name = '';
|
|
$avatar_url = '';
|
|
if ($i > 49) {
|
|
break;
|
|
}
|
|
if ($win_db[$i][0] == $account_id) {
|
|
$win_rank = $i + 1;
|
|
}
|
|
$row = $conn->execQueryOne('SELECT head_kuang_id, sex FROM user WHERE account_id=:account_id;',
|
|
array(
|
|
':account_id' => $win_db[$i][0],
|
|
));
|
|
$head_kuang_id = 0;
|
|
if ($row['head_kuang_id']) {
|
|
$head_kuang_id = $row['head_kuang_id'];
|
|
}
|
|
$sex = 2;
|
|
if ($row['sex']) {
|
|
$sex = $row['sex'];
|
|
}
|
|
$addreward = new classes\Addreward();
|
|
$vip_level = $addreward->getVipLevel($win_db[$i][0]);
|
|
if ($win_db[$i][2] == '' || $win_db[$i][1] == '') {
|
|
if ($win_db[$i][0] == $account_id) {
|
|
$name = $myname;
|
|
$avatar_url = $myavatar_url;
|
|
} else {
|
|
$address = '../res/robot@robot' . 1 . '.php';
|
|
$robot_meta_cluster = require($address);
|
|
$j = Rand(1, 100);
|
|
$robot_id = 1000 + $j;
|
|
$robot_meta = getRobotConfig($robot_meta_cluster, $robot_id);
|
|
$rob = array(
|
|
'name' => $robot_meta['name'],
|
|
'avatar_url' => $robot_meta['avatar_url'],
|
|
);
|
|
if ($win_db[$i][1] == '') {
|
|
$name = $rob['name'];
|
|
} else {
|
|
$name = $win_db[$i][1];
|
|
}
|
|
if ($win_db[$i][2] == '') {
|
|
$avatar_url = $rob['avatar_url'];
|
|
} else {
|
|
$avatar_url = $win_db[$i][2];
|
|
}
|
|
}
|
|
} else {
|
|
$name = $win_db[$i][1];
|
|
$avatar_url = $win_db[$i][2];
|
|
}
|
|
$url = urldecode($avatar_url);
|
|
array_push($win_list, array(
|
|
'account_id' => $win_db[$i][0],
|
|
'name' => $name,
|
|
'avatar_url' => $url,
|
|
'kill' => $win_db[$i][3],
|
|
'alive'=> $win_db[$i][4],
|
|
'harm' => $win_db[$i][5],
|
|
'win_rate' => $win_db[$i][6],
|
|
'win_game' => $win_db[$i][7],
|
|
'head_kuang_id' => $head_kuang_id,
|
|
'vip_level' => $vip_level,
|
|
'sex' => $sex,
|
|
));
|
|
$i++;
|
|
}
|
|
|
|
//积分榜
|
|
$channel = phpcommon\extractChannel($account_id);
|
|
$integral_rank_db = $r->get("game2005api:integral_rank_" . $channel);
|
|
$integral_db = json_decode($integral_rank_db);
|
|
$i = 0;
|
|
foreach ($integral_db as $integral) {
|
|
$name = '';
|
|
$avatar_url = '';
|
|
if ($i > 49) {
|
|
break;
|
|
}
|
|
$score = 0;
|
|
$rank = 0;
|
|
$seaPoint_meta_table = require('../res/seasomPoint@seasomPoint.php');
|
|
for ($ii = 1; $ii <= count($seaPoint_meta_table); $ii++) {
|
|
$seaPoint = mt\SeasonPoint::getOldSeasonPoint($ii);
|
|
if ($integral_db[$i][8] >= $seaPoint['min'] && $integral_db[$i][8] <= $seaPoint['max']
|
|
|| $integral_db[$i][8] >= $seaPoint['min'] && $seaPoint['max'] == -1)
|
|
{
|
|
$rank = $ii;
|
|
break;
|
|
}
|
|
}
|
|
$row = $conn->execQueryOne('SELECT head_kuang_id, sex FROM user WHERE account_id=:account_id;',
|
|
array(
|
|
':account_id' => $integral_db[$i][0],
|
|
));
|
|
$head_kuang_id = 0;
|
|
if ($row['head_kuang_id']) {
|
|
$head_kuang_id = $row['head_kuang_id'];
|
|
}
|
|
$sex = 2;
|
|
if ($row['sex']) {
|
|
$sex = $row['sex'];
|
|
}
|
|
$addreward = new classes\Addreward();
|
|
$vip_level = $addreward->getVipLevel($integral_db[$i][0]);
|
|
if ($integral_db[$i][0] == $account_id) {
|
|
$integral_rank = $i + 1;
|
|
}
|
|
if ($integral_db[$i][2] == '' || $integral_db[$i][1] == '') {
|
|
if ($integral_db[$i][0] == $account_id) {
|
|
$name = $myname;
|
|
$avatar_url = $myavatar_url;
|
|
} else {
|
|
$address = '../res/robot@robot' . 1 . '.php';
|
|
$robot_meta_cluster = require($address);
|
|
$j = Rand(1, 100);
|
|
$robot_id = 1000 + $j;
|
|
$robot_meta = getRobotConfig($robot_meta_cluster, $robot_id);
|
|
$rob = array(
|
|
'name' => $robot_meta['name'],
|
|
'avatar_url' => $robot_meta['avatar_url'],
|
|
);
|
|
if ($integral_db[$i][1] == '') {
|
|
$name = $rob['name'];
|
|
} else {
|
|
$name = $integral_db[$i][1];
|
|
}
|
|
if ($integral_db[$i][2] == '') {
|
|
$avatar_url = $rob['avatar_url'];
|
|
} else {
|
|
$avatar_url = $integral_db[$i][2];
|
|
}
|
|
}
|
|
} else {
|
|
$name = $integral_db[$i][1];
|
|
$avatar_url = $integral_db[$i][2];
|
|
}
|
|
$url = urldecode($avatar_url);
|
|
array_push($integral_list, array(
|
|
'account_id' => $integral_db[$i][0],
|
|
'name' => $name,
|
|
'avatar_url' => $url,
|
|
'kill' => $integral_db[$i][3],
|
|
'alive'=> $integral_db[$i][4],
|
|
'harm' => $integral_db[$i][5],
|
|
'win_rate' => $integral_db[$i][6],
|
|
'win_game' => $integral_db[$i][7],
|
|
'score' => $integral_db[$i][8],
|
|
'level' => $rank,
|
|
'head_kuang_id' => $head_kuang_id,
|
|
'vip_level' => $vip_level,
|
|
'sex' => $sex,
|
|
));
|
|
$i++;
|
|
}
|
|
|
|
echo json_encode(array(
|
|
'errcode' => 0,
|
|
'errmsg' => "",
|
|
'user_list' => $user_list,
|
|
'win_rank' => $win_rank,
|
|
'win_list' => $win_list,
|
|
'integral_rank' => $integral_rank,
|
|
'integral_list' => $integral_list,
|
|
));
|
|
}
|
|
|
|
public function getRankInfo()
|
|
{
|
|
|
|
$account_id = $_REQUEST['account_id'];
|
|
$conn = $this->_getMysql($account_id);
|
|
|
|
|
|
$killResultArr = array();
|
|
$rankPointArr = array();
|
|
//获得自己的击杀排行榜
|
|
$sqlStr = "SELECT account_id,user_name,hi_id,head_kuang_id,kills,win_times FROM user WHERE account_id=:account_id";
|
|
$row = $conn->execQuery($sqlStr,array(':account_id' => $account_id));
|
|
if($row)
|
|
{
|
|
array_push($killResultArr,$row[0]);
|
|
}
|
|
//击杀排行榜
|
|
$sqlStr = "SELECT account_id,user_name,hi_id,head_kuang_id,kills,win_times FROM user order by win_times desc limit 50";
|
|
$row = $conn->execQuery($sqlStr);
|
|
if($row) {
|
|
$len = count($row);
|
|
for($i = 0 ; $i < $len ; $i ++)
|
|
{
|
|
array_push($killResultArr,$row[$i]);
|
|
}
|
|
}
|
|
//获得自己的排位积分
|
|
$sqlStr = "SELECT account_id,user_name,hi_id,head_kuang_id,integral FROM user WHERE account_id=:account_id";
|
|
$row = $conn->execQuery($sqlStr,array(':account_id' => $account_id));
|
|
if($row)
|
|
{
|
|
array_push($rankPointArr,$row[0]);
|
|
}
|
|
//积分排行榜
|
|
$sqlStr = "SELECT account_id,user_name,hi_id,head_kuang_id,integral FROM user order by integral desc limit 50";
|
|
$row = $conn->execQuery($sqlStr);
|
|
if($row) {
|
|
$len = count($row);
|
|
for($i = 0 ; $i < $len ; $i ++)
|
|
{
|
|
array_push($rankPointArr,$row[$i]);
|
|
}
|
|
}
|
|
//好友排行榜
|
|
|
|
$resultData = array();
|
|
array_push($resultData,$killResultArr);
|
|
array_push($resultData,$rankPointArr);
|
|
|
|
|
|
|
|
|
|
$this->sendDataToClient(100,"getRankInfo",$resultData);
|
|
}
|
|
public function mailTest()
|
|
{
|
|
$url = '';
|
|
$account_id = $_REQUEST['account_id'];
|
|
|
|
if (SERVER_ENV == _ONLINE) {
|
|
$url = 'https://gamemail.kingsome.cn/webapp/index.php?c=MailMgr&a=sendMail&';
|
|
} else {
|
|
$url = 'https://gamemail-test.kingsome.cn/webapp/index.php?c=MailMgr&a=sendMail&';
|
|
}
|
|
$params = array(
|
|
'gameid' => "1234",
|
|
'to' => $account_id,
|
|
'from' => $account_id,
|
|
'mailsubtype'=>12,
|
|
'content'=>"采蘑菇的小朋友",
|
|
'subject'=>"皮卡猪",
|
|
"attachments"=>"1001:10|1002:20",
|
|
"ext"=>"10"
|
|
);
|
|
if (!phpcommon\HttpClient::get($url, $params, $response)) {
|
|
phpcommon\sendError(ERR_RETRY, '系统繁忙');
|
|
return;
|
|
}
|
|
$data = json_decode($response, true);
|
|
//error_log("邮件测试=====".json_encode($data));
|
|
$this->sendDataToClient(100,"MailTest",$data);
|
|
}
|
|
|
|
}
|