UserLogLogic.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. <?php
  2. // 玩家日志逻
  3. namespace app\v1\logic\dataReport;
  4. use plugin\saiadmin\basic\BaseLogic;
  5. use plugin\saiadmin\service\OpenSpoutWriter;
  6. use support\think\Db;
  7. class UserLogLogic extends BaseLogic
  8. {
  9. // 注册日志
  10. public function getRegLogList($where): mixed
  11. {
  12. $params = $this->searchByAuth($where);
  13. $regTime = $params['reg_time'];
  14. $tableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
  15. $params['reg_time'] = strtotime($regTime . " 00:00:00") . "<=" . strtotime($regTime . " 23:59:59");
  16. $limit = request()->input('limit', 10);
  17. // 获取这一天的注册日志
  18. $regLogQuery = Db::connect('db_game_log')
  19. ->table($tableName)
  20. ->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))
  21. ->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'));
  22. // 公共处理完的where
  23. $where = $this->getCommonWhere($params);
  24. if($where){
  25. $regLogQuery = $regLogQuery->where($where);
  26. }
  27. // 自然量ID, auth_id=0为自然量
  28. $whereRaw = $this->nomalGameWhere($params['nomal_game_id']);
  29. $regLogQuery = $regLogQuery->whereRaw($whereRaw);
  30. // 分页
  31. return $regLogQuery->paginate($limit)->toArray();
  32. }
  33. // 登录日志
  34. public function getLoginLogList($where): mixed
  35. {
  36. $orderBy = request()->input('orderBy', 'login_time');
  37. $orderType = request()->input('orderType', 'desc');
  38. $page = request()->input('page', 1);
  39. $limit = request()->input('limit', 10);
  40. $params = $this->searchByAuth($where);
  41. $loginTime = $params['login_time'];
  42. $tableName = 'sdk_login_log_' . date('Ym', strtotime($loginTime));
  43. $loginLogQuery = Db::connect('db_game_log')
  44. ->table($tableName);
  45. // 公共处理完的where
  46. $where = $this->getCommonWhere($params);
  47. if($where){
  48. $loginLogQuery = $loginLogQuery->where($where);
  49. }
  50. // 自然量ID, auth_id=0为自然量
  51. $whereRaw = $this->nomalGameWhere($params['nomal_game_id']);
  52. $loginLogQuery = $loginLogQuery->whereRaw($whereRaw);
  53. // 执行查询并排序
  54. $loginLogQuery->order($orderBy, $orderType);
  55. return $loginLogQuery->paginate($limit)->toArray();
  56. }
  57. // 充值明细
  58. public function exportRechargeDetailList($where): mixed
  59. {
  60. $data = $this->getRechargeDetailList($where, 'all');
  61. $data = $this->trandformListColumn($data, ['game', 'ip', 'agent', 'auth', 'pay_channel']);
  62. $data = array_map(function ($item) {
  63. return [
  64. 'order_id' => $item['order_id'],
  65. 'user_name' => $item['user_name'],
  66. 'agent_id' => $item['agent_id'],
  67. 'site_id' => $item['site_id'],
  68. 'game_name' => $item['game_name'],
  69. 'server_id' => $item['server_id'],
  70. 'server_name' => $item['server_name'],
  71. 'pay_channel_name' => $item['pay_channel_name'],
  72. 'money' => $item['money'],
  73. 'pay_date' => $item['pay_date'],
  74. 'reg_date' => $item['reg_date'],
  75. 'first_payment' => $item['first_payment'],
  76. 'agent_name' => $item['agent_name'],
  77. 'auth_name' => $item['auth_name'],
  78. ];
  79. }, $data);
  80. // 是否首次付费
  81. $filter = [
  82. 'first_payment' => [
  83. ['value' => 1, 'label' => '是'],
  84. ['value' => 0, 'label' => '否']
  85. ]
  86. ];
  87. $file_name = '充值明细_' . date('YmdHis') . '.xlsx';
  88. $header = ['订单号', '用户名', '渠道ID', '广告位ID', '游戏名', '服务器ID', '服务器名', '支付方式', '充值金额', '充值时间', '注册时间', '是否首次付费', '渠道名', '负责人'];
  89. $writer = new OpenSpoutWriter($file_name);
  90. $writer->setWidth([15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15]);
  91. $writer->setHeader($header);
  92. $writer->setData($data, null, $filter);
  93. $file_path = $writer->returnFile();
  94. return response()->download($file_path, urlencode($file_name));
  95. }
  96. // 充值明细导出
  97. public function getRechargeDetailList($where, $type = "list"): mixed
  98. {
  99. $orderBy = request()->input('orderBy', 'pay_date');
  100. $orderType = request()->input('orderType', 'desc');
  101. $page = request()->input('page', 1);
  102. $limit = request()->input('limit', 10);
  103. $params = $this->searchByAuth($where);
  104. $tableName = 'sdk_order_success';
  105. $rechargeDetailQuery = Db::connect('db_game_log')
  106. ->table($tableName);
  107. $where = $this->getCommonWhere($params);
  108. if($where){
  109. $rechargeDetailQuery = $rechargeDetailQuery->where($where);
  110. }
  111. // 自然量ID, auth_id=0为自然量
  112. $whereRaw = $this->nomalGameWhere($params['nomal_game_id']);
  113. $rechargeDetailQuery = $rechargeDetailQuery->whereRaw($whereRaw);
  114. $rechargeDetailQuery->order($orderBy, $orderType);
  115. if ($type == 'all') {
  116. $data = $rechargeDetailQuery->select()->toArray();
  117. } else {
  118. $data = $rechargeDetailQuery->paginate($limit)->toArray();
  119. }
  120. return $data;
  121. }
  122. // 充值排行
  123. public function getRechargeRankList($where): mixed
  124. {
  125. $orderBy = request()->input('orderBy', 'searchTotalMoney');
  126. $orderType = request()->input('orderType', 'desc');
  127. $page = request()->input('page', 1);
  128. $limit = request()->input('limit', 10);
  129. $params = $this->searchByAuth($where);
  130. $tableName = 'sdk_order_success';
  131. $rechargeRankQuery = Db::connect('db_game_log')
  132. ->table($tableName);
  133. $where = $this->getCommonWhere($params);
  134. if($where){
  135. $rechargeRankQuery = $rechargeRankQuery->where($where);
  136. }
  137. // 自然量ID, auth_id=0为自然量
  138. $whereRaw = $this->nomalGameWhere($params['nomal_game_id']);
  139. $rechargeRankQuery = $rechargeRankQuery->whereRaw($whereRaw);
  140. // 先选择字段,包括计算字段
  141. $rechargeRankQuery->field('user_name,sum(money) as searchTotalMoney,
  142. order_id,
  143. game_id,
  144. media_id,
  145. agent_id,
  146. site_id,
  147. uid,
  148. pay_channel_id,
  149. auth_id,
  150. server_id,
  151. server_name,
  152. pay_date,
  153. reg_date,
  154. role_name,
  155. role_id');
  156. $rechargeRankQuery->group('uid, game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id');
  157. $rechargeRankQuery->order($orderBy, $orderType);
  158. $data = $rechargeRankQuery->paginate($limit)->toArray();
  159. $data['data'] = $this->trandformListColumn($data['data'], ['game', 'auth', 'agent', 'pay_channel']);
  160. // 告警提示,查询最近登录时间,查询最近充值时间,和现在时间对比,如果超过3天,则告警,并提示
  161. foreach ($data['data'] as &$item) {
  162. // 最后登录时间
  163. $item['login_time'] = Db::connect('db_origin')->table('user_' . $item['uid'] % 10)->where('uid', $item['uid'])->value('login_time');
  164. // 最近注册时间
  165. $item['pay_time'] = Db::connect('db_origin')->table('user_' . $item['uid'] % 10)->where('uid', $item['uid'])->value('pay_time');
  166. // 现在时间
  167. $item['now_time'] = time();
  168. // 最近登录时间与现在时间对比,如果超过3天,则告警,并提示
  169. if ($item['login_time'] < $item['now_time'] - 3 * 86400) {
  170. $item['login_alert'] = 1;
  171. } else {
  172. $item['login_alert'] = 0;
  173. }
  174. // 最近充值时间与现在时间对比,如果超过3天,则告警,并提示
  175. if ($item['pay_time'] < $item['now_time'] - 3 * 86400) {
  176. $item['pay_alert'] = 1;
  177. } else {
  178. $item['pay_alert'] = 0;
  179. }
  180. }
  181. $totalList = Db::connect('db_game_log')->table('sdk_order_success')
  182. ->where($where)
  183. ->whereRaw($whereRaw)
  184. ->field('game_id,uid,sum(money) as totalMoney')
  185. ->group('uid,game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id')
  186. ->select()->toArray();
  187. // 查询累计充值金额(对每一行数据单独查询历史充值金额)
  188. $totalMoneyMap = [];
  189. if (!empty($data['data']) && !empty($totalList)) {
  190. foreach ($totalList as $totalItem) {
  191. $key = $totalItem['uid'] . '_' . $totalItem['game_id'];
  192. $totalMoneyMap[$key] = $totalItem['totalMoney'] ?? 0;
  193. }
  194. }
  195. // 为搜索结果添加累计充值金额
  196. foreach ($data['data'] as &$item) {
  197. $key = $item['uid'] . '_' . $item['game_id'];
  198. $item['totalMoney'] = $totalMoneyMap[$key] ?? 0;
  199. }
  200. return $data;
  201. }
  202. // 角色数据
  203. public function getRoleDataList($where): mixed
  204. {
  205. $page = request()->input('page', 1);
  206. $limit = request()->input('limit', 10);
  207. $params = $this->searchByAuth($where);
  208. $regTime = $params['reg_time'];
  209. $egTableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
  210. $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();
  211. $where_sql = $this->generateWhereSql($params);
  212. $uids = array_column($userData, 'uid');
  213. if (empty($userData)) return [];
  214. $where_sql = " AND uid in (" . implode(',', $uids) . ") {$where_sql}";
  215. $sql_parts = [];
  216. $sql_parts[] = "SELECT * FROM role_data_and WHERE 1=1 {$where_sql}";
  217. $sql_parts[] = "SELECT * FROM role_data_ios WHERE 1=1 {$where_sql}";
  218. $unionSql = implode(" UNION ALL ", $sql_parts);
  219. // 分页
  220. $offset = ($page - 1) * $limit;
  221. $unionSql .= " LIMIT {$offset}, {$limit}";
  222. $roleData = Db::connect('db_game_log')->query($unionSql);
  223. // 合并相同uid的数据,将角色信息放到数组中
  224. $mergedData = [];
  225. foreach ($roleData as $item) {
  226. $uid = $item['uid'];
  227. if (!isset($mergedData[$uid])) {
  228. // 创建用户基础信息,排除角色相关字段
  229. $baseInfo = array_diff_key($item, array_flip(['role_id', 'role_name', 'role_level']));
  230. $mergedData[$uid] = $baseInfo + ['roles' => []];
  231. }
  232. // 添加角色信息到数组
  233. $mergedData[$uid]['roles'][] = [
  234. 'server_name' => $item['server_name'],
  235. 'role_name' => $item['role_name'],
  236. 'role_level' => $item['role_level'],
  237. ];
  238. }
  239. // 转换回数组格式
  240. $roleData = array_values($mergedData);
  241. $roleData = $this->trandformListColumn($roleData, ['game', 'ip', 'auth', 'agent']);
  242. $count = count($roleData);
  243. return [
  244. 'data' => $roleData,
  245. 'current_page' => $page,
  246. 'per_page' => $limit,
  247. 'last_page' => ceil($count / $limit),
  248. 'has_more' => $page < ceil($count / $limit),
  249. 'total' => $count
  250. ];
  251. }
  252. }