| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342 |
- <?php
- // 玩家日志逻
- namespace app\v1\logic\dataReport;
- use app\v1\logic\tool\ToolLogic;
- use plugin\saiadmin\basic\BaseLogic;
- use plugin\saiadmin\exception\ApiException;
- use plugin\saiadmin\service\OpenSpoutWriter;
- use support\think\Db;
- class UserLogLogic extends BaseLogic
- {
- // 注册日志
- public function getRegLogList($where): mixed
- {
- $params = $this->searchByAuth($where);
- // 检查注册时间只能查询3个月内
- if (empty($params['reg_time']) || count($params['reg_time']) != 2) {
- throw new ApiException('请选择注册时间范围');
- }
- $startTime = strtotime($params['reg_time'][0]);
- $endTime = strtotime($params['reg_time'][1]);
- if ($endTime < $startTime) {
- throw new ApiException('注册时间范围不正确');
- }
- // 计算时间差,限制为3个月(90天)内
- $maxDays = 90;
- if (($endTime - $startTime) > ($maxDays * 86400)) {
- throw new ApiException('注册时间只能查询3个月内');
- }
- $tableNames = ToolLogic::getMonthlyTableNames('sdk_reg_log_', $params['reg_time'][0], $params['reg_time'][1]);
-
- $limit = request()->input('limit', 10);
- // 公共处理完的where, 自然量ID, auth_id=0为自然量
- [$where, $whereRaw] = $this->getUlogCommonWhere($params);
-
- $regLogQuery = Db::connect('db_game_log');
- foreach($tableNames as $index => $tableName){
- if($index === 0){
- $regLogQuery = $regLogQuery->table($tableName);
- if($where){
- $regLogQuery = $regLogQuery->where($where);
- }
- if($whereRaw){
- $regLogQuery = $regLogQuery->whereRaw($whereRaw);
- }
- }else{
- $regLogQuery = $regLogQuery->unionAll(function($query) use ($tableName, $where, $whereRaw){
- $query = $query->table($tableName);
- if($where){
- $query = $query->where($where);
- }
- if($whereRaw){
- $query = $query->whereRaw($whereRaw);
- }
- });
- }
- }
-
- // 分页
- return $regLogQuery->paginate($limit)->toArray();
- }
- // 登录日志
- 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);
- $tableName = 'sdk_login_log_' . date('Ym', strtotime($params['login_time']));
- $loginLogQuery = Db::connect('db_game_log')->table($tableName);
- // 公共处理完的where, 自然量ID, auth_id=0为自然量
- [$where, $whereRaw] = $this->getUlogCommonWhere($params);
- if($where){
- $loginLogQuery = $loginLogQuery->where($where);
- }
- if($whereRaw){
- $loginLogQuery = $loginLogQuery->whereRaw($whereRaw);
- }
- // 执行查询并排序
- $loginLogQuery->order($orderBy, $orderType);
- return $loginLogQuery->paginate($limit)->toArray();
- }
- // 充值明细
- 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, 自然量ID, auth_id=0为自然量
- [$where, $whereRaw] = $this->getUlogCommonWhere($params);
- if($where){
- $rechargeDetailQuery = $rechargeDetailQuery->where($where);
- }
- if($whereRaw){
- $rechargeDetailQuery = $rechargeDetailQuery->whereRaw($whereRaw);
- }
- $rechargeDetailQuery->order($orderBy, $orderType);
- if ($type == 'all') {
- $data = $rechargeDetailQuery->select()->toArray();
- } else {
- $data = $rechargeDetailQuery->paginate($limit)->toArray();
- }
- return $data;
- }
- // 充值明细导出
- public function exportRechargeDetailList($where): mixed
- {
- $data = $this->getRechargeDetailList($where, 'all');
- $data = $this->trandformListColumn($data, ['game', 'ip', 'agent', 'auth', 'pay_channel']);
- $data = array_map(function ($item) {
- return [
- 'order_id' => $item['order_id'],
- 'user_name' => $item['user_name'],
- 'agent_id' => $item['agent_id'],
- 'site_id' => $item['site_id'],
- 'game_name' => $item['game_name'],
- 'server_id' => $item['server_id'],
- 'server_name' => $item['server_name'],
- 'pay_channel_name' => $item['pay_channel_name'],
- 'money' => $item['money'],
- 'pay_date' => $item['pay_date'],
- 'reg_date' => $item['reg_date'],
- 'first_payment' => $item['first_payment'],
- 'agent_name' => $item['agent_name'],
- 'auth_name' => $item['auth_name'],
- ];
- }, $data);
- // 是否首次付费
- $filter = [
- 'first_payment' => [
- ['value' => 1, 'label' => '是'],
- ['value' => 0, 'label' => '否']
- ]
- ];
- $file_name = '充值明细_' . date('YmdHis') . '.xlsx';
- $header = ['订单号', '用户名', '渠道ID', '广告位ID', '游戏名', '服务器ID', '服务器名', '支付方式', '充值金额', '充值时间', '注册时间', '是否首次付费', '渠道名', '负责人'];
- $writer = new OpenSpoutWriter($file_name);
- $writer->setWidth([15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15]);
- $writer->setHeader($header);
- $writer->setData($data, null, $filter);
- $file_path = $writer->returnFile();
- return response()->download($file_path, urlencode($file_name));
- }
- // 充值排行
- 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, 自然量ID, auth_id=0为自然量
- [$where, $whereRaw] = $this->getUlogCommonWhere($params);
- if($where){
- $rechargeRankQuery = $rechargeRankQuery->where($where);
- }
- if($whereRaw){
- $rechargeRankQuery = $rechargeRankQuery->whereRaw($whereRaw);
- }
- // 先选择字段,包括计算字段
- $rechargeRankQuery->field('user_name,sum(money) as searchTotalMoney,
- order_id,
- game_id,
- media_id,
- agent_id,
- site_id,
- uid,
- pay_channel_id,
- auth_id,
- server_id,
- server_name,
- pay_date,
- reg_date,
- role_name,
- 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);
- $data = $rechargeRankQuery->paginate($limit)->toArray();
- $data['data'] = $this->trandformListColumn($data['data'], ['game', 'auth', 'agent', 'pay_channel']);
- // 告警提示,查询最近登录时间,查询最近充值时间,和现在时间对比,如果超过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();
- // 最近登录时间与现在时间对比,如果超过3天,则告警,并提示
- if ($item['login_time'] < $item['now_time'] - 3 * 86400) {
- $item['login_alert'] = 1;
- } else {
- $item['login_alert'] = 0;
- }
- // 最近充值时间与现在时间对比,如果超过3天,则告警,并提示
- if ($item['pay_time'] < $item['now_time'] - 3 * 86400) {
- $item['pay_alert'] = 1;
- } else {
- $item['pay_alert'] = 0;
- }
- }
- $totalList = Db::connect('db_game_log')->table('sdk_order_success')
- ->where($where);
- if(!empty($whereRaw)){
- $totalList = $totalList->whereRaw($whereRaw);
- }
- $totalList = $totalList
- ->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;
- }
- // 角色数据
- public function getRoleDataList($where): mixed
- {
- $page = request()->input('page', 1);
- $limit = request()->input('limit', 10);
- $params = $this->searchByAuth($where);
- $regTime = $params['reg_time'];
- $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 = $this->generateWhereSql($params);
- $uids = array_column($userData, 'uid');
- 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}";
- $unionSql = implode(" UNION ALL ", $sql_parts);
- // 分页
- $offset = ($page - 1) * $limit;
- $unionSql .= " LIMIT {$offset}, {$limit}";
- $roleData = Db::connect('db_game_log')->query($unionSql);
- // 合并相同uid的数据,将角色信息放到数组中
- $mergedData = [];
- foreach ($roleData as $item) {
- $uid = $item['uid'];
- if (!isset($mergedData[$uid])) {
- // 创建用户基础信息,排除角色相关字段
- $baseInfo = array_diff_key($item, array_flip(['role_id', 'role_name', 'role_level']));
- $mergedData[$uid] = $baseInfo + ['roles' => []];
- }
- // 添加角色信息到数组
- $mergedData[$uid]['roles'][] = [
- 'server_name' => $item['server_name'],
- 'role_name' => $item['role_name'],
- 'role_level' => $item['role_level'],
- ];
- }
- // 转换回数组格式
- $roleData = array_values($mergedData);
- $roleData = $this->trandformListColumn($roleData, ['game', 'ip', 'auth', 'agent']);
- $count = count($roleData);
- return [
- 'data' => $roleData,
- 'current_page' => $page,
- 'per_page' => $limit,
- 'last_page' => ceil($count / $limit),
- 'has_more' => $page < ceil($count / $limit),
- 'total' => $count
- ];
- }
- }
|