|
@@ -7,185 +7,122 @@ namespace app\v1\logic\gameLog;
|
|
|
use plugin\saiadmin\basic\BaseLogic;
|
|
use plugin\saiadmin\basic\BaseLogic;
|
|
|
use plugin\saiadmin\service\OpenSpoutWriter;
|
|
use plugin\saiadmin\service\OpenSpoutWriter;
|
|
|
use support\think\Db;
|
|
use support\think\Db;
|
|
|
-use support\Request;
|
|
|
|
|
|
|
|
|
|
class UserLogLogic extends BaseLogic
|
|
class UserLogLogic extends BaseLogic
|
|
|
{
|
|
{
|
|
|
|
|
|
|
|
- // 注册日志
|
|
|
|
|
|
|
+ // 注册日志
|
|
|
public function getRegLogList($where): mixed
|
|
public function getRegLogList($where): mixed
|
|
|
{
|
|
{
|
|
|
-
|
|
|
|
|
- $params = $this->searchByAuth($where);
|
|
|
|
|
-
|
|
|
|
|
- $regTime = $params['reg_time'];
|
|
|
|
|
- $tableName = 'sdk_reg_log_'.date('Ym',strtotime($regTime));
|
|
|
|
|
- $params['reg_time'] =strtotime($regTime . " 00:00:00") . "<=" . strtotime($regTime . " 23:59:59");
|
|
|
|
|
- $orderBy = request()->input('orderBy', 'reg_time');
|
|
|
|
|
- $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
- $page = request()->input('page', 1);
|
|
|
|
|
- $limit = request()->input('limit', 10);
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- // 获取这一天的注册日志
|
|
|
|
|
- $regLogQuery = Db::connect('db_game_log')
|
|
|
|
|
- ->table($tableName)
|
|
|
|
|
- ->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))
|
|
|
|
|
- ->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'));
|
|
|
|
|
-
|
|
|
|
|
- // 添加其他查询条件
|
|
|
|
|
- if (!empty($params['game_id'])) {
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['user_name'])){
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('user_name', $params['user_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['media_id'])){
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('media_id', $params['media_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['site_id'])){
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('site_id', $params['site_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['agent_id'])){
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['vt'])){
|
|
|
|
|
- $regLogQuery = $regLogQuery->where('vt', $params['vt']);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- // 执行查询并排序
|
|
|
|
|
- $data = $regLogQuery->order($orderBy, $orderType)->select()->toArray();
|
|
|
|
|
-
|
|
|
|
|
- // 分页
|
|
|
|
|
-
|
|
|
|
|
- $data = $regLogQuery->paginate($limit, false, ['page' => $page])->toArray();
|
|
|
|
|
-
|
|
|
|
|
- return $data;
|
|
|
|
|
|
|
+ $params = $this->searchByAuth($where);
|
|
|
|
|
+
|
|
|
|
|
+ $regTime = $params['reg_time'];
|
|
|
|
|
+ $tableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
|
|
|
|
|
+ $params['reg_time'] = strtotime($regTime . " 00:00:00") . "<=" . strtotime($regTime . " 23:59:59");
|
|
|
|
|
+ $orderBy = request()->input('orderBy', 'reg_time');
|
|
|
|
|
+ $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
+ $page = request()->input('page', 1);
|
|
|
|
|
+ $limit = request()->input('limit', 10);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ // 获取这一天的注册日志
|
|
|
|
|
+ $regLogQuery = Db::connect('db_game_log')
|
|
|
|
|
+ ->table($tableName)
|
|
|
|
|
+ ->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))
|
|
|
|
|
+ ->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'));
|
|
|
|
|
+
|
|
|
|
|
+ // 添加其他查询条件
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['user_name'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('user_name', $params['user_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['media_id'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('media_id', $params['media_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['site_id'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('site_id', $params['site_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['agent_id'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['vt'])) {
|
|
|
|
|
+ $regLogQuery = $regLogQuery->where('vt', $params['vt']);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // 执行查询并排序
|
|
|
|
|
+ // $data = $regLogQuery->order($orderBy, $orderType)->select()->toArray();
|
|
|
|
|
+
|
|
|
|
|
+ // 分页
|
|
|
|
|
+ $data = $regLogQuery->paginate($limit)->toArray();
|
|
|
|
|
+
|
|
|
|
|
+ return $data;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// 登录日志
|
|
// 登录日志
|
|
|
public function getLoginLogList($where): mixed
|
|
public function getLoginLogList($where): mixed
|
|
|
{
|
|
{
|
|
|
-
|
|
|
|
|
- $orderBy = request()->input('orderBy', 'login_time');
|
|
|
|
|
- $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
- $page = request()->input('page', 1);
|
|
|
|
|
- $limit = request()->input('limit', 10);
|
|
|
|
|
-
|
|
|
|
|
- $params = $this->searchByAuth($where);
|
|
|
|
|
- $loginTime = $params['login_time'];
|
|
|
|
|
- $tableName = 'sdk_login_log_'.date('Ym',strtotime($loginTime));
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- $loginLogQuery = Db::connect('db_game_log')
|
|
|
|
|
- ->table($tableName)
|
|
|
|
|
- ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
|
|
|
|
|
- ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
|
|
|
|
|
-
|
|
|
|
|
- if(!empty($params['game_id'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['user_name'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('user_name', $params['user_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['media_id'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('media_id', $params['media_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['site_id'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('site_id', $params['site_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['auth_id'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['agent_id'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['reg_time'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery
|
|
|
|
|
- ->where('reg_time', '>=', strtotime($params['reg_time'] . ' 00:00:00'))
|
|
|
|
|
- ->where('reg_time', '<=', strtotime($params['reg_time'] . ' 23:59:59'));
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['login_time'])){
|
|
|
|
|
- $loginLogQuery = $loginLogQuery
|
|
|
|
|
- ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
|
|
|
|
|
- ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
|
|
|
|
|
- }
|
|
|
|
|
- // 执行查询并排序
|
|
|
|
|
-
|
|
|
|
|
- $loginLogQuery->order($orderBy, $orderType);
|
|
|
|
|
-
|
|
|
|
|
- $data = $loginLogQuery->paginate($limit, false, ['page' => $page])->toArray();
|
|
|
|
|
- return $data;
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ $orderBy = request()->input('orderBy', 'login_time');
|
|
|
|
|
+ $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
+ $page = request()->input('page', 1);
|
|
|
|
|
+ $limit = request()->input('limit', 10);
|
|
|
|
|
|
|
|
- // 充值明细
|
|
|
|
|
- public function getRechargeDetailList($where,$type="list"): mixed
|
|
|
|
|
- {
|
|
|
|
|
- $orderBy = request()->input('orderBy', 'pay_date');
|
|
|
|
|
- $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
- $page = request()->input('page', 1);
|
|
|
|
|
- $limit = request()->input('limit', 10);
|
|
|
|
|
-
|
|
|
|
|
- $params = $this->searchByAuth($where);
|
|
|
|
|
-
|
|
|
|
|
- $tableName = 'sdk_order_success';
|
|
|
|
|
-
|
|
|
|
|
- $rechargeDetailQuery = Db::connect('db_game_log')
|
|
|
|
|
- ->table($tableName)
|
|
|
|
|
- ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
|
|
|
|
|
- ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- if(!empty($params['game_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['user_name'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('user_name', $params['user_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['media_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('media_id', $params['media_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['auth_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['agent_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['site_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('site_id', $params['site_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['server_id'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('server_id', $params['server_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['server_name'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery->where('server_name', $params['server_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['reg_date'])){
|
|
|
|
|
- $rechargeDetailQuery = $rechargeDetailQuery
|
|
|
|
|
- ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
|
|
|
|
|
- ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- $rechargeDetailQuery->order($orderBy, $orderType);
|
|
|
|
|
-
|
|
|
|
|
- if($type == 'all'){
|
|
|
|
|
- $data = $rechargeDetailQuery->select()->toArray();
|
|
|
|
|
- }else{
|
|
|
|
|
- $data = $rechargeDetailQuery->paginate($limit, false, ['page' => $page])->toArray();
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- return $data;
|
|
|
|
|
|
|
+ $params = $this->searchByAuth($where);
|
|
|
|
|
+ $loginTime = $params['login_time'];
|
|
|
|
|
+ $tableName = 'sdk_login_log_' . date('Ym', strtotime($loginTime));
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ $loginLogQuery = Db::connect('db_game_log')
|
|
|
|
|
+ ->table($tableName)
|
|
|
|
|
+ ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
|
|
|
|
|
+ ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
|
|
|
|
|
+
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['user_name'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('user_name', $params['user_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['media_id'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('media_id', $params['media_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['site_id'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('site_id', $params['site_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['auth_id'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['agent_id'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['reg_time'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery
|
|
|
|
|
+ ->where('reg_time', '>=', strtotime($params['reg_time'] . ' 00:00:00'))
|
|
|
|
|
+ ->where('reg_time', '<=', strtotime($params['reg_time'] . ' 23:59:59'));
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['login_time'])) {
|
|
|
|
|
+ $loginLogQuery = $loginLogQuery
|
|
|
|
|
+ ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
|
|
|
|
|
+ ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // 执行查询并排序
|
|
|
|
|
+ $loginLogQuery->order($orderBy, $orderType);
|
|
|
|
|
+
|
|
|
|
|
+ $data = $loginLogQuery->paginate($limit)->toArray();
|
|
|
|
|
+ return $data;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- // 充值明细导出
|
|
|
|
|
|
|
+ // 充值明细
|
|
|
public function exportRechargeDetailList($where): mixed
|
|
public function exportRechargeDetailList($where): mixed
|
|
|
{
|
|
{
|
|
|
$data = $this->getRechargeDetailList($where, 'all');
|
|
$data = $this->getRechargeDetailList($where, 'all');
|
|
|
|
|
|
|
|
print_r($data);
|
|
print_r($data);
|
|
|
-
|
|
|
|
|
- $data = $this->trandformListColumn($data, ['game', 'ip', 'agent','auth', 'pay_channel']);
|
|
|
|
|
- $data = array_map(function($item){
|
|
|
|
|
|
|
+
|
|
|
|
|
+ $data = $this->trandformListColumn($data, ['game', 'ip', 'agent', 'auth', 'pay_channel']);
|
|
|
|
|
+ $data = array_map(function ($item) {
|
|
|
return [
|
|
return [
|
|
|
'order_id' => $item['order_id'],
|
|
'order_id' => $item['order_id'],
|
|
|
'user_name' => $item['user_name'],
|
|
'user_name' => $item['user_name'],
|
|
@@ -198,13 +135,12 @@ class UserLogLogic extends BaseLogic
|
|
|
'money' => $item['money'],
|
|
'money' => $item['money'],
|
|
|
'pay_date' => $item['pay_date'],
|
|
'pay_date' => $item['pay_date'],
|
|
|
'reg_date' => $item['reg_date'],
|
|
'reg_date' => $item['reg_date'],
|
|
|
-
|
|
|
|
|
'first_payment' => $item['first_payment'],
|
|
'first_payment' => $item['first_payment'],
|
|
|
'agent_name' => $item['agent_name'],
|
|
'agent_name' => $item['agent_name'],
|
|
|
'auth_name' => $item['auth_name'],
|
|
'auth_name' => $item['auth_name'],
|
|
|
];
|
|
];
|
|
|
}, $data);
|
|
}, $data);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
// 是否首次付费
|
|
// 是否首次付费
|
|
|
$filter = [
|
|
$filter = [
|
|
|
'first_payment' => [
|
|
'first_payment' => [
|
|
@@ -212,9 +148,9 @@ class UserLogLogic extends BaseLogic
|
|
|
['value' => 0, 'label' => '否']
|
|
['value' => 0, 'label' => '否']
|
|
|
]
|
|
]
|
|
|
];
|
|
];
|
|
|
- $file_name = '充值明细_'.date('YmdHis').'.xlsx';
|
|
|
|
|
- $header = ['订单号', '用户名', '渠道ID', '广告位ID', '游戏名', '服务器ID', '服务器名', '支付方式', '充值金额', '充值时间', '注册时间', '是否首次付费', '渠道名', '负责人'];
|
|
|
|
|
-
|
|
|
|
|
|
|
+ $file_name = '充值明细_' . date('YmdHis') . '.xlsx';
|
|
|
|
|
+ $header = ['订单号', '用户名', '渠道ID', '广告位ID', '游戏名', '服务器ID', '服务器名', '支付方式', '充值金额', '充值时间', '注册时间', '是否首次付费', '渠道名', '负责人'];
|
|
|
|
|
+
|
|
|
$writer = new OpenSpoutWriter($file_name);
|
|
$writer = new OpenSpoutWriter($file_name);
|
|
|
$writer->setWidth([15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15]);
|
|
$writer->setWidth([15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15]);
|
|
|
$writer->setHeader($header);
|
|
$writer->setHeader($header);
|
|
@@ -224,55 +160,116 @@ class UserLogLogic extends BaseLogic
|
|
|
return response()->download($file_path, urlencode($file_name));
|
|
return response()->download($file_path, urlencode($file_name));
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ // 充值明细导出
|
|
|
|
|
+
|
|
|
|
|
+ public function getRechargeDetailList($where, $type = "list"): mixed
|
|
|
|
|
+ {
|
|
|
|
|
+ $orderBy = request()->input('orderBy', 'pay_date');
|
|
|
|
|
+ $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
+ $page = request()->input('page', 1);
|
|
|
|
|
+ $limit = request()->input('limit', 10);
|
|
|
|
|
+
|
|
|
|
|
+ $params = $this->searchByAuth($where);
|
|
|
|
|
+
|
|
|
|
|
+ $tableName = 'sdk_order_success';
|
|
|
|
|
+
|
|
|
|
|
+ $rechargeDetailQuery = Db::connect('db_game_log')
|
|
|
|
|
+ ->table($tableName)
|
|
|
|
|
+ ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
|
|
|
|
|
+ ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['user_name'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('user_name', $params['user_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['media_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('media_id', $params['media_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['auth_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['agent_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['site_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('site_id', $params['site_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['server_id'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('server_id', $params['server_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['server_name'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery->where('server_name', $params['server_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['reg_date'])) {
|
|
|
|
|
+ $rechargeDetailQuery = $rechargeDetailQuery
|
|
|
|
|
+ ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
|
|
|
|
|
+ ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $rechargeDetailQuery->order($orderBy, $orderType);
|
|
|
|
|
+
|
|
|
|
|
+ if ($type == 'all') {
|
|
|
|
|
+ $data = $rechargeDetailQuery->select()->toArray();
|
|
|
|
|
+ } else {
|
|
|
|
|
+ $data = $rechargeDetailQuery->paginate($limit)->toArray();
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ return $data;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
// 充值排行
|
|
// 充值排行
|
|
|
|
|
+
|
|
|
public function getRechargeRankList($where): mixed
|
|
public function getRechargeRankList($where): mixed
|
|
|
{
|
|
{
|
|
|
- $orderBy = request()->input('orderBy', 'searchTotalMoney');
|
|
|
|
|
- $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
- $page = request()->input('page', 1);
|
|
|
|
|
- $limit = request()->input('limit', 10);
|
|
|
|
|
-
|
|
|
|
|
- $params = $this->searchByAuth($where);
|
|
|
|
|
-
|
|
|
|
|
- $tableName = 'sdk_order_success';
|
|
|
|
|
-
|
|
|
|
|
- $rechargeRankQuery = Db::connect('db_game_log')
|
|
|
|
|
- ->table($tableName)
|
|
|
|
|
- ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
|
|
|
|
|
- ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
|
|
|
|
|
-
|
|
|
|
|
- if(!empty($params['game_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['user_name'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('user_name', $params['user_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['media_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('media_id', $params['media_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['auth_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['agent_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['site_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('site_id', $params['site_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['server_id'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('server_id', $params['server_id']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['server_name'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery->where('server_name', $params['server_name']);
|
|
|
|
|
- }
|
|
|
|
|
- if(!empty($params['reg_date'])){
|
|
|
|
|
- $rechargeRankQuery = $rechargeRankQuery
|
|
|
|
|
- ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
|
|
|
|
|
- ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- // 先选择字段,包括计算字段
|
|
|
|
|
- $rechargeRankQuery->field('user_name,sum(money) as searchTotalMoney,
|
|
|
|
|
|
|
+ $orderBy = request()->input('orderBy', 'searchTotalMoney');
|
|
|
|
|
+ $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
+ $page = request()->input('page', 1);
|
|
|
|
|
+ $limit = request()->input('limit', 10);
|
|
|
|
|
+
|
|
|
|
|
+ $params = $this->searchByAuth($where);
|
|
|
|
|
+
|
|
|
|
|
+ $tableName = 'sdk_order_success';
|
|
|
|
|
+
|
|
|
|
|
+ $rechargeRankQuery = Db::connect('db_game_log')
|
|
|
|
|
+ ->table($tableName)
|
|
|
|
|
+ ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
|
|
|
|
|
+ ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
|
|
|
|
|
+
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['user_name'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('user_name', $params['user_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['media_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('media_id', $params['media_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['auth_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('auth_id', $params['auth_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['agent_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('agent_id', $params['agent_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['site_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('site_id', $params['site_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['server_id'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('server_id', $params['server_id']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['server_name'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery->where('server_name', $params['server_name']);
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($params['reg_date'])) {
|
|
|
|
|
+ $rechargeRankQuery = $rechargeRankQuery
|
|
|
|
|
+ ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
|
|
|
|
|
+ ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // 先选择字段,包括计算字段
|
|
|
|
|
+ $rechargeRankQuery->field('user_name,sum(money) as searchTotalMoney,
|
|
|
order_id,
|
|
order_id,
|
|
|
game_id,
|
|
game_id,
|
|
|
media_id,
|
|
media_id,
|
|
@@ -288,91 +285,91 @@ class UserLogLogic extends BaseLogic
|
|
|
role_name,
|
|
role_name,
|
|
|
role_id');
|
|
role_id');
|
|
|
|
|
|
|
|
- $rechargeRankQuery->group('uid, game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id');
|
|
|
|
|
|
|
+ $rechargeRankQuery->group('uid, game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id');
|
|
|
|
|
|
|
|
- $rechargeRankQuery->order($orderBy, $orderType);
|
|
|
|
|
|
|
+ $rechargeRankQuery->order($orderBy, $orderType);
|
|
|
|
|
|
|
|
|
|
|
|
|
- $data = $rechargeRankQuery->paginate($limit, false, ['page' => $page])->toArray();
|
|
|
|
|
|
|
+ $data = $rechargeRankQuery->paginate($limit)->toArray();
|
|
|
|
|
|
|
|
|
|
|
|
|
- $data['data'] = $this->trandformListColumn($data['data'], ['game','auth', 'agent', 'pay_channel']);
|
|
|
|
|
|
|
+ $data['data'] = $this->trandformListColumn($data['data'], ['game', 'auth', 'agent', 'pay_channel']);
|
|
|
|
|
|
|
|
|
|
|
|
|
- // // 告警提示,查询最近登录时间,查询最近充值时间,和现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
|
|
+ // // 告警提示,查询最近登录时间,查询最近充值时间,和现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
|
|
|
- foreach($data['data'] as &$item){
|
|
|
|
|
- // 最后登录时间
|
|
|
|
|
- $item['login_time'] = Db::connect('db_origin')->table('user_'.$item['uid']%10)->where('uid', $item['uid'])->value('login_time');
|
|
|
|
|
- // 最近注册时间
|
|
|
|
|
- $item['pay_time'] = Db::connect('db_origin')->table('user_'.$item['uid']%10)->where('uid', $item['uid'])->value('pay_time');
|
|
|
|
|
- // 现在时间
|
|
|
|
|
- $item['now_time'] = time();
|
|
|
|
|
|
|
+ foreach ($data['data'] as &$item) {
|
|
|
|
|
+ // 最后登录时间
|
|
|
|
|
+ $item['login_time'] = Db::connect('db_origin')->table('user_' . $item['uid'] % 10)->where('uid', $item['uid'])->value('login_time');
|
|
|
|
|
+ // 最近注册时间
|
|
|
|
|
+ $item['pay_time'] = Db::connect('db_origin')->table('user_' . $item['uid'] % 10)->where('uid', $item['uid'])->value('pay_time');
|
|
|
|
|
+ // 现在时间
|
|
|
|
|
+ $item['now_time'] = time();
|
|
|
|
|
|
|
|
- // 最近登录时间与现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
- if($item['login_time'] < $item['now_time'] - 3 * 24 * 60 * 60){
|
|
|
|
|
- $item['login_alert'] = 1;
|
|
|
|
|
- }else{
|
|
|
|
|
- $item['login_alert'] = 0;
|
|
|
|
|
- }
|
|
|
|
|
- // 最近充值时间与现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
- if($item['pay_time'] < $item['now_time'] - 3 * 24 * 60 * 60){
|
|
|
|
|
- $item['pay_alert'] = 1;
|
|
|
|
|
- }else{
|
|
|
|
|
- $item['pay_alert'] = 0;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ // 最近登录时间与现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
+ if ($item['login_time'] < $item['now_time'] - 3 * 24 * 60 * 60) {
|
|
|
|
|
+ $item['login_alert'] = 1;
|
|
|
|
|
+ } else {
|
|
|
|
|
+ $item['login_alert'] = 0;
|
|
|
|
|
+ }
|
|
|
|
|
+ // 最近充值时间与现在时间对比,如果超过3天,则告警,并提示
|
|
|
|
|
+ if ($item['pay_time'] < $item['now_time'] - 3 * 24 * 60 * 60) {
|
|
|
|
|
+ $item['pay_alert'] = 1;
|
|
|
|
|
+ } else {
|
|
|
|
|
+ $item['pay_alert'] = 0;
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
|
|
|
|
|
- $totalWhere = [];
|
|
|
|
|
- if(!empty($params['game_id'])){
|
|
|
|
|
|
|
+ $totalWhere = [];
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
$totalWhere[] = ['game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']];
|
|
$totalWhere[] = ['game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['auth_id'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['auth_id'])) {
|
|
|
$totalWhere[] = ['auth_id', 'in', is_array($params['auth_id']) ? implode(',', $params['auth_id']) : $params['auth_id']];
|
|
$totalWhere[] = ['auth_id', 'in', is_array($params['auth_id']) ? implode(',', $params['auth_id']) : $params['auth_id']];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['agent_id'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['agent_id'])) {
|
|
|
$totalWhere['agent_id'] = $params['agent_id'];
|
|
$totalWhere['agent_id'] = $params['agent_id'];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['site_id'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['site_id'])) {
|
|
|
$totalWhere['site_id'] = $params['site_id'];
|
|
$totalWhere['site_id'] = $params['site_id'];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['server_id'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['server_id'])) {
|
|
|
$totalWhere['server_id'] = $params['server_id'];
|
|
$totalWhere['server_id'] = $params['server_id'];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['user_name'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['user_name'])) {
|
|
|
$totalWhere['user_name'] = $params['user_name'];
|
|
$totalWhere['user_name'] = $params['user_name'];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['server_name'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['server_name'])) {
|
|
|
$totalWhere['server_name'] = $params['server_name'];
|
|
$totalWhere['server_name'] = $params['server_name'];
|
|
|
- }
|
|
|
|
|
- if(!empty($where['reg_date'])){
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (!empty($where['reg_date'])) {
|
|
|
$totalWhere['reg_date'] = $params['reg_date'];
|
|
$totalWhere['reg_date'] = $params['reg_date'];
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- $totalList = Db::connect('db_game_log')->table('sdk_order_success')
|
|
|
|
|
- ->where($totalWhere)
|
|
|
|
|
- ->field('game_id,uid,sum(money) as totalMoney')
|
|
|
|
|
- ->group('uid,game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id')
|
|
|
|
|
- ->select()->toArray();
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- // 查询累计充值金额(对每一行数据单独查询历史充值金额)
|
|
|
|
|
- $totalMoneyMap = [];
|
|
|
|
|
- if (!empty($data['data']) && !empty($totalList)) {
|
|
|
|
|
- foreach ($totalList as $totalItem) {
|
|
|
|
|
- $key = $totalItem['uid'] . '_' . $totalItem['game_id'];
|
|
|
|
|
- $totalMoneyMap[$key] = $totalItem['totalMoney'] ?? 0;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- // 为搜索结果添加累计充值金额
|
|
|
|
|
- foreach($data['data'] as &$item){
|
|
|
|
|
- $key = $item['uid'] . '_' . $item['game_id'];
|
|
|
|
|
- $item['totalMoney'] = $totalMoneyMap[$key] ?? 0;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- return $data;
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $totalList = Db::connect('db_game_log')->table('sdk_order_success')
|
|
|
|
|
+ ->where($totalWhere)
|
|
|
|
|
+ ->field('game_id,uid,sum(money) as totalMoney')
|
|
|
|
|
+ ->group('uid,game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id')
|
|
|
|
|
+ ->select()->toArray();
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ // 查询累计充值金额(对每一行数据单独查询历史充值金额)
|
|
|
|
|
+ $totalMoneyMap = [];
|
|
|
|
|
+ if (!empty($data['data']) && !empty($totalList)) {
|
|
|
|
|
+ foreach ($totalList as $totalItem) {
|
|
|
|
|
+ $key = $totalItem['uid'] . '_' . $totalItem['game_id'];
|
|
|
|
|
+ $totalMoneyMap[$key] = $totalItem['totalMoney'] ?? 0;
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // 为搜索结果添加累计充值金额
|
|
|
|
|
+ foreach ($data['data'] as &$item) {
|
|
|
|
|
+ $key = $item['uid'] . '_' . $item['game_id'];
|
|
|
|
|
+ $item['totalMoney'] = $totalMoneyMap[$key] ?? 0;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ return $data;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// 角色数据
|
|
// 角色数据
|
|
@@ -380,63 +377,61 @@ class UserLogLogic extends BaseLogic
|
|
|
|
|
|
|
|
public function getRoleDataList($where): mixed
|
|
public function getRoleDataList($where): mixed
|
|
|
{
|
|
{
|
|
|
- $orderBy = request()->input('orderBy', 'reg_time');
|
|
|
|
|
- $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
- $page = request()->input('page', 1);
|
|
|
|
|
- $limit = request()->input('limit', 10);
|
|
|
|
|
|
|
+ $orderBy = request()->input('orderBy', 'reg_time');
|
|
|
|
|
+ $orderType = request()->input('orderType', 'desc');
|
|
|
|
|
+ $page = request()->input('page', 1);
|
|
|
|
|
+ $limit = request()->input('limit', 10);
|
|
|
|
|
+
|
|
|
|
|
+ $params = $this->searchByAuth($where);
|
|
|
|
|
+ $regTime = $params['reg_time'];
|
|
|
|
|
+
|
|
|
|
|
|
|
|
- $params = $this->searchByAuth($where);
|
|
|
|
|
- $regTime = $params['reg_time'];
|
|
|
|
|
|
|
+ $egTableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
|
|
|
|
|
|
|
|
|
|
|
|
|
- $egTableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
|
|
|
|
|
|
|
+ $userData = Db::connect('db_game_log')->table($egTableName)->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'))->select()->toArray();
|
|
|
|
|
|
|
|
|
|
+ $where_sql = "";
|
|
|
|
|
+ if (!empty($params['game_id'])) {
|
|
|
|
|
+ $where_sql .= is_array($params['game_id']) ? " AND game_id in (" . implode(',', $params['game_id']) . ")" : " AND game_id = {$params['game_id']}";
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- $userData = Db::connect('db_game_log')->table($egTableName)->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'))->select()->toArray();
|
|
|
|
|
|
|
+ if (!empty($params['media_id'])) {
|
|
|
|
|
+ $where_sql .= " AND media_id = {$params['media_id']}";
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- $where_sql = "";
|
|
|
|
|
- if(!empty($params['game_id'])){
|
|
|
|
|
- $where_sql .= is_array($params['game_id']) ? " AND game_id in (".implode(',', $params['game_id']).")" : " AND game_id = {$params['game_id']}";
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ if (!empty($params['site_id'])) {
|
|
|
|
|
+ $where_sql .= " AND site_id = {$params['site_id']}";
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if(!empty($params['media_id'])){
|
|
|
|
|
- $where_sql .= " AND media_id = {$params['media_id']}";
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ if (!empty($params['auth_id'])) {
|
|
|
|
|
+ $where_sql .= " AND auth_id = {$params['auth_id']}";
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if(!empty($params['site_id'])){
|
|
|
|
|
- $where_sql .= " AND site_id = {$params['site_id']}";
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ if (!empty($params['user_name'])) {
|
|
|
|
|
+ $where_sql .= " AND user_name = {$params['user_name']}";
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if(!empty($params['auth_id'])){
|
|
|
|
|
- $where_sql .= " AND auth_id = {$params['auth_id']}";
|
|
|
|
|
- }
|
|
|
|
|
|
|
|
|
|
- if(!empty($params['user_name'])){
|
|
|
|
|
- $where_sql .= " AND user_name = {$params['user_name']}";
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ $uids = array_column($userData, 'uid');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+ if (empty($userData)) {
|
|
|
|
|
+ return [];
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- $uids = array_column($userData, 'uid');
|
|
|
|
|
|
|
+ $where_sql = " AND uid in (" . implode(',', $uids) . ") {$where_sql}";
|
|
|
|
|
|
|
|
-
|
|
|
|
|
- if(empty($userData)){
|
|
|
|
|
- return [];
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- $where_sql = " AND uid in (".implode(',', $uids).") {$where_sql}";
|
|
|
|
|
-
|
|
|
|
|
|
|
|
|
|
- $sql_parts = [];
|
|
|
|
|
- $sql_parts[] = "SELECT * FROM role_data_and WHERE 1=1 {$where_sql}";
|
|
|
|
|
- $sql_parts[] = "SELECT * FROM role_data_ios WHERE 1=1 {$where_sql}";
|
|
|
|
|
|
|
+ $sql_parts = [];
|
|
|
|
|
+ $sql_parts[] = "SELECT * FROM role_data_and WHERE 1=1 {$where_sql}";
|
|
|
|
|
+ $sql_parts[] = "SELECT * FROM role_data_ios WHERE 1=1 {$where_sql}";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+ $unionSql = implode(" UNION ALL ", $sql_parts);
|
|
|
|
|
|
|
|
- $unionSql = implode(" UNION ALL ", $sql_parts);
|
|
|
|
|
|
|
+ // 分页
|
|
|
|
|
|
|
|
- // 分页
|
|
|
|
|
-
|
|
|
|
|
$offset = ($page - 1) * $limit;
|
|
$offset = ($page - 1) * $limit;
|
|
|
$unionSql .= " LIMIT {$offset}, {$limit}";
|
|
$unionSql .= " LIMIT {$offset}, {$limit}";
|
|
|
$roleData = Db::connect('db_game_log')->query($unionSql);
|
|
$roleData = Db::connect('db_game_log')->query($unionSql);
|
|
@@ -445,13 +440,13 @@ class UserLogLogic extends BaseLogic
|
|
|
$mergedData = [];
|
|
$mergedData = [];
|
|
|
foreach ($roleData as $item) {
|
|
foreach ($roleData as $item) {
|
|
|
$uid = $item['uid'];
|
|
$uid = $item['uid'];
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
if (!isset($mergedData[$uid])) {
|
|
if (!isset($mergedData[$uid])) {
|
|
|
// 创建用户基础信息,排除角色相关字段
|
|
// 创建用户基础信息,排除角色相关字段
|
|
|
$baseInfo = array_diff_key($item, array_flip(['role_id', 'role_name', 'role_level']));
|
|
$baseInfo = array_diff_key($item, array_flip(['role_id', 'role_name', 'role_level']));
|
|
|
$mergedData[$uid] = $baseInfo + ['roles' => []];
|
|
$mergedData[$uid] = $baseInfo + ['roles' => []];
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
// 添加角色信息到数组
|
|
// 添加角色信息到数组
|
|
|
$mergedData[$uid]['roles'][] = [
|
|
$mergedData[$uid]['roles'][] = [
|
|
|
'server_name' => $item['server_name'],
|
|
'server_name' => $item['server_name'],
|
|
@@ -459,19 +454,19 @@ class UserLogLogic extends BaseLogic
|
|
|
'role_level' => $item['role_level'],
|
|
'role_level' => $item['role_level'],
|
|
|
];
|
|
];
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
// 转换回数组格式
|
|
// 转换回数组格式
|
|
|
$roleData = array_values($mergedData);
|
|
$roleData = array_values($mergedData);
|
|
|
$roleData = $this->trandformListColumn($roleData, ['game', 'ip', 'auth', 'agent']);
|
|
$roleData = $this->trandformListColumn($roleData, ['game', 'ip', 'auth', 'agent']);
|
|
|
$count = count($roleData);
|
|
$count = count($roleData);
|
|
|
|
|
|
|
|
return [
|
|
return [
|
|
|
- 'data' => $roleData,
|
|
|
|
|
- 'current_page' => $page,
|
|
|
|
|
- 'per_page' => $limit,
|
|
|
|
|
- 'last_page' => ceil($count / $limit),
|
|
|
|
|
- 'has_more' => $page < ceil($count / $limit),
|
|
|
|
|
- 'total' => $count
|
|
|
|
|
|
|
+ 'data' => $roleData,
|
|
|
|
|
+ 'current_page' => $page,
|
|
|
|
|
+ 'per_page' => $limit,
|
|
|
|
|
+ 'last_page' => ceil($count / $limit),
|
|
|
|
|
+ 'has_more' => $page < ceil($count / $limit),
|
|
|
|
|
+ 'total' => $count
|
|
|
];
|
|
];
|
|
|
|
|
|
|
|
}
|
|
}
|