UserLogLogic.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480
  1. <?php
  2. // 玩家日志逻
  3. namespace app\v1\logic\gameLog;
  4. use plugin\saiadmin\basic\BaseLogic;
  5. use plugin\saiadmin\service\OpenSpoutWriter;
  6. use support\think\Db;
  7. use support\Request;
  8. class UserLogLogic extends BaseLogic
  9. {
  10. // 注册日志
  11. public function getRegLogList($where): mixed
  12. {
  13. $params = $this->searchByAuth($where);
  14. $regTime = $params['reg_time'];
  15. $tableName = 'sdk_reg_log_'.date('Ym',strtotime($regTime));
  16. $params['reg_time'] =strtotime($regTime . " 00:00:00") . "<=" . strtotime($regTime . " 23:59:59");
  17. $orderBy = request()->input('orderBy', 'reg_time');
  18. $orderType = request()->input('orderType', 'desc');
  19. $page = request()->input('page', 1);
  20. $limit = request()->input('limit', 10);
  21. // 获取这一天的注册日志
  22. $regLogQuery = Db::connect('db_game_log')
  23. ->table($tableName)
  24. ->where('reg_time', '>=', strtotime($regTime . ' 00:00:00'))
  25. ->where('reg_time', '<=', strtotime($regTime . ' 23:59:59'));
  26. // 添加其他查询条件
  27. if (!empty($params['game_id'])) {
  28. $regLogQuery = $regLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
  29. }
  30. if(!empty($params['user_name'])){
  31. $regLogQuery = $regLogQuery->where('user_name', $params['user_name']);
  32. }
  33. if(!empty($params['media_id'])){
  34. $regLogQuery = $regLogQuery->where('media_id', $params['media_id']);
  35. }
  36. if(!empty($params['site_id'])){
  37. $regLogQuery = $regLogQuery->where('site_id', $params['site_id']);
  38. }
  39. if(!empty($params['agent_id'])){
  40. $regLogQuery = $regLogQuery->where('agent_id', $params['agent_id']);
  41. }
  42. if(!empty($params['vt'])){
  43. $regLogQuery = $regLogQuery->where('vt', $params['vt']);
  44. }
  45. // 执行查询并排序
  46. $data = $regLogQuery->order($orderBy, $orderType)->select()->toArray();
  47. // 分页
  48. $data = $regLogQuery->paginate($limit, false, ['page' => $page])->toArray();
  49. return $data;
  50. }
  51. // 登录日志
  52. public function getLoginLogList($where): mixed
  53. {
  54. $orderBy = request()->input('orderBy', 'login_time');
  55. $orderType = request()->input('orderType', 'desc');
  56. $page = request()->input('page', 1);
  57. $limit = request()->input('limit', 10);
  58. $params = $this->searchByAuth($where);
  59. $loginTime = $params['login_time'];
  60. $tableName = 'sdk_login_log_'.date('Ym',strtotime($loginTime));
  61. $loginLogQuery = Db::connect('db_game_log')
  62. ->table($tableName)
  63. ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
  64. ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
  65. if(!empty($params['game_id'])){
  66. $loginLogQuery = $loginLogQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
  67. }
  68. if(!empty($params['user_name'])){
  69. $loginLogQuery = $loginLogQuery->where('user_name', $params['user_name']);
  70. }
  71. if(!empty($params['media_id'])){
  72. $loginLogQuery = $loginLogQuery->where('media_id', $params['media_id']);
  73. }
  74. if(!empty($params['site_id'])){
  75. $loginLogQuery = $loginLogQuery->where('site_id', $params['site_id']);
  76. }
  77. if(!empty($params['auth_id'])){
  78. $loginLogQuery = $loginLogQuery->where('auth_id', $params['auth_id']);
  79. }
  80. if(!empty($params['agent_id'])){
  81. $loginLogQuery = $loginLogQuery->where('agent_id', $params['agent_id']);
  82. }
  83. if(!empty($params['reg_time'])){
  84. $loginLogQuery = $loginLogQuery
  85. ->where('reg_time', '>=', strtotime($params['reg_time'] . ' 00:00:00'))
  86. ->where('reg_time', '<=', strtotime($params['reg_time'] . ' 23:59:59'));
  87. }
  88. if(!empty($params['login_time'])){
  89. $loginLogQuery = $loginLogQuery
  90. ->where('login_time', '>=', strtotime($params['login_time'] . ' 00:00:00'))
  91. ->where('login_time', '<=', strtotime($params['login_time'] . ' 23:59:59'));
  92. }
  93. // 执行查询并排序
  94. $loginLogQuery->order($orderBy, $orderType);
  95. $data = $loginLogQuery->paginate($limit, false, ['page' => $page])->toArray();
  96. return $data;
  97. }
  98. // 充值明细
  99. public function getRechargeDetailList($where,$type="list"): mixed
  100. {
  101. $orderBy = request()->input('orderBy', 'pay_date');
  102. $orderType = request()->input('orderType', 'desc');
  103. $page = request()->input('page', 1);
  104. $limit = request()->input('limit', 10);
  105. $params = $this->searchByAuth($where);
  106. $tableName = 'sdk_order_success';
  107. $rechargeDetailQuery = Db::connect('db_game_log')
  108. ->table($tableName)
  109. ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
  110. ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
  111. if(!empty($params['game_id'])){
  112. $rechargeDetailQuery = $rechargeDetailQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
  113. }
  114. if(!empty($params['user_name'])){
  115. $rechargeDetailQuery = $rechargeDetailQuery->where('user_name', $params['user_name']);
  116. }
  117. if(!empty($params['media_id'])){
  118. $rechargeDetailQuery = $rechargeDetailQuery->where('media_id', $params['media_id']);
  119. }
  120. if(!empty($params['auth_id'])){
  121. $rechargeDetailQuery = $rechargeDetailQuery->where('auth_id', $params['auth_id']);
  122. }
  123. if(!empty($params['agent_id'])){
  124. $rechargeDetailQuery = $rechargeDetailQuery->where('agent_id', $params['agent_id']);
  125. }
  126. if(!empty($params['site_id'])){
  127. $rechargeDetailQuery = $rechargeDetailQuery->where('site_id', $params['site_id']);
  128. }
  129. if(!empty($params['server_id'])){
  130. $rechargeDetailQuery = $rechargeDetailQuery->where('server_id', $params['server_id']);
  131. }
  132. if(!empty($params['server_name'])){
  133. $rechargeDetailQuery = $rechargeDetailQuery->where('server_name', $params['server_name']);
  134. }
  135. if(!empty($params['reg_date'])){
  136. $rechargeDetailQuery = $rechargeDetailQuery
  137. ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
  138. ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
  139. }
  140. $rechargeDetailQuery->order($orderBy, $orderType);
  141. if($type == 'all'){
  142. $data = $rechargeDetailQuery->select()->toArray();
  143. }else{
  144. $data = $rechargeDetailQuery->paginate($limit, false, ['page' => $page])->toArray();
  145. }
  146. return $data;
  147. }
  148. // 充值明细导出
  149. public function exportRechargeDetailList($where): mixed
  150. {
  151. $data = $this->getRechargeDetailList($where, 'all');
  152. print_r('====>');
  153. print_r($data);
  154. $data = $this->trandformListColumn($data, ['game', 'ip', 'agent','auth', 'pay_channel']);
  155. $data = array_map(function($item){
  156. return [
  157. 'order_id' => $item['order_id'],
  158. 'user_name' => $item['user_name'],
  159. 'agent_id' => $item['agent_id'],
  160. 'site_id' => $item['site_id'],
  161. 'game_name' => $item['game_name'],
  162. 'server_id' => $item['server_id'],
  163. 'server_name' => $item['server_name'],
  164. 'pay_channel_name' => $item['pay_channel_name'],
  165. 'money' => $item['money'],
  166. 'pay_date' => $item['pay_date'],
  167. 'reg_date' => $item['reg_date'],
  168. 'first_payment' => $item['first_payment'],
  169. 'agent_name' => $item['agent_name'],
  170. 'auth_name' => $item['auth_name'],
  171. ];
  172. }, $data);
  173. // 是否首次付费
  174. $filter = [
  175. 'first_payment' => [
  176. ['value' => 1, 'label' => '是'],
  177. ['value' => 0, 'label' => '否']
  178. ]
  179. ];
  180. $file_name = '充值明细_'.date('YmdHis').'.xlsx';
  181. $header = ['订单号', '用户名', '渠道ID', '广告位ID', '游戏名', '服务器ID', '服务器名', '支付方式', '充值金额', '充值时间', '注册时间', '是否首次付费', '渠道名', '负责人'];
  182. $writer = new OpenSpoutWriter($file_name);
  183. $writer->setWidth([15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15]);
  184. $writer->setHeader($header);
  185. // $writer->setData($data, null);
  186. $writer->setData($data, null, $filter);
  187. $file_path = $writer->returnFile();
  188. return response()->download($file_path, urlencode($file_name));
  189. }
  190. // 充值排行
  191. public function getRechargeRankList($where): mixed
  192. {
  193. $orderBy = request()->input('orderBy', 'searchTotalMoney');
  194. $orderType = request()->input('orderType', 'desc');
  195. $page = request()->input('page', 1);
  196. $limit = request()->input('limit', 10);
  197. $params = $this->searchByAuth($where);
  198. $tableName = 'sdk_order_success';
  199. $rechargeRankQuery = Db::connect('db_game_log')
  200. ->table($tableName)
  201. ->where('pay_date', '>=', $params['pay_date'][0] . ' 00:00:00')
  202. ->where('pay_date', '<=', $params['pay_date'][1] . ' 23:59:59');
  203. if(!empty($params['game_id'])){
  204. $rechargeRankQuery = $rechargeRankQuery->where('game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']);
  205. }
  206. if(!empty($params['user_name'])){
  207. $rechargeRankQuery = $rechargeRankQuery->where('user_name', $params['user_name']);
  208. }
  209. if(!empty($params['media_id'])){
  210. $rechargeRankQuery = $rechargeRankQuery->where('media_id', $params['media_id']);
  211. }
  212. if(!empty($params['auth_id'])){
  213. $rechargeRankQuery = $rechargeRankQuery->where('auth_id', $params['auth_id']);
  214. }
  215. if(!empty($params['agent_id'])){
  216. $rechargeRankQuery = $rechargeRankQuery->where('agent_id', $params['agent_id']);
  217. }
  218. if(!empty($params['site_id'])){
  219. $rechargeRankQuery = $rechargeRankQuery->where('site_id', $params['site_id']);
  220. }
  221. if(!empty($params['server_id'])){
  222. $rechargeRankQuery = $rechargeRankQuery->where('server_id', $params['server_id']);
  223. }
  224. if(!empty($params['server_name'])){
  225. $rechargeRankQuery = $rechargeRankQuery->where('server_name', $params['server_name']);
  226. }
  227. if(!empty($params['reg_date'])){
  228. $rechargeRankQuery = $rechargeRankQuery
  229. ->where('reg_date', '>=', $params['reg_date'][0] . ' 00:00:00')
  230. ->where('reg_date', '<=', $params['reg_date'][1] . ' 23:59:59');
  231. }
  232. // 先选择字段,包括计算字段
  233. $rechargeRankQuery->field('user_name,sum(money) as searchTotalMoney,
  234. order_id,
  235. game_id,
  236. media_id,
  237. agent_id,
  238. site_id,
  239. uid,
  240. pay_channel_id,
  241. auth_id,
  242. server_id,
  243. server_name,
  244. pay_date,
  245. reg_date,
  246. role_name,
  247. role_id');
  248. $rechargeRankQuery->group('uid, game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id');
  249. $rechargeRankQuery->order($orderBy, $orderType);
  250. $data = $rechargeRankQuery->paginate($limit, false, ['page' => $page])->toArray();
  251. $data['data'] = $this->trandformListColumn($data['data'], ['game','auth', 'agent', 'pay_channel']);
  252. // // 告警提示,查询最近登录时间,查询最近充值时间,和现在时间对比,如果超过3天,则告警,并提示
  253. foreach($data['data'] as &$item){
  254. // 最后登录时间
  255. $item['login_time'] = Db::connect('db_origin')->table('user_'.$item['uid']%10)->where('uid', $item['uid'])->value('login_time');
  256. // 最近注册时间
  257. $item['pay_time'] = Db::connect('db_origin')->table('user_'.$item['uid']%10)->where('uid', $item['uid'])->value('pay_time');
  258. // 现在时间
  259. $item['now_time'] = time();
  260. // 最近登录时间与现在时间对比,如果超过3天,则告警,并提示
  261. if($item['login_time'] < $item['now_time'] - 3 * 24 * 60 * 60){
  262. $item['login_alert'] = 1;
  263. }else{
  264. $item['login_alert'] = 0;
  265. }
  266. // 最近充值时间与现在时间对比,如果超过3天,则告警,并提示
  267. if($item['pay_time'] < $item['now_time'] - 3 * 24 * 60 * 60){
  268. $item['pay_alert'] = 1;
  269. }else{
  270. $item['pay_alert'] = 0;
  271. }
  272. }
  273. $totalWhere = [];
  274. if(!empty($params['game_id'])){
  275. $totalWhere[] = ['game_id', 'in', is_array($params['game_id']) ? implode(',', $params['game_id']) : $params['game_id']];
  276. }
  277. if(!empty($where['auth_id'])){
  278. $totalWhere[] = ['auth_id', 'in', is_array($params['auth_id']) ? implode(',', $params['auth_id']) : $params['auth_id']];
  279. }
  280. if(!empty($where['agent_id'])){
  281. $totalWhere['agent_id'] = $params['agent_id'];
  282. }
  283. if(!empty($where['site_id'])){
  284. $totalWhere['site_id'] = $params['site_id'];
  285. }
  286. if(!empty($where['server_id'])){
  287. $totalWhere['server_id'] = $params['server_id'];
  288. }
  289. if(!empty($where['user_name'])){
  290. $totalWhere['user_name'] = $params['user_name'];
  291. }
  292. if(!empty($where['server_name'])){
  293. $totalWhere['server_name'] = $params['server_name'];
  294. }
  295. if(!empty($where['reg_date'])){
  296. $totalWhere['reg_date'] = $params['reg_date'];
  297. }
  298. $totalList = Db::connect('db_game_log')->table('sdk_order_success')
  299. ->where($totalWhere)
  300. ->field('game_id,uid,sum(money) as totalMoney')
  301. ->group('uid,game_id,site_id,server_id,media_id,auth_id,agent_id,server_id,auth_id,role_id')
  302. ->select()->toArray();
  303. // 查询累计充值金额(对每一行数据单独查询历史充值金额)
  304. $totalMoneyMap = [];
  305. if (!empty($data['data']) && !empty($totalList)) {
  306. foreach ($totalList as $totalItem) {
  307. $key = $totalItem['uid'] . '_' . $totalItem['game_id'];
  308. $totalMoneyMap[$key] = $totalItem['totalMoney'] ?? 0;
  309. }
  310. }
  311. // 为搜索结果添加累计充值金额
  312. foreach($data['data'] as &$item){
  313. $key = $item['uid'] . '_' . $item['game_id'];
  314. $item['totalMoney'] = $totalMoneyMap[$key] ?? 0;
  315. }
  316. return $data;
  317. }
  318. // 角色数据
  319. public function getRoleDataList($where): mixed
  320. {
  321. $orderBy = request()->input('orderBy', 'reg_time');
  322. $orderType = request()->input('orderType', 'desc');
  323. $page = request()->input('page', 1);
  324. $limit = request()->input('limit', 10);
  325. $params = $this->searchByAuth($where);
  326. $regTime = $params['reg_time'];
  327. $egTableName = 'sdk_reg_log_' . date('Ym', strtotime($regTime));
  328. $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();
  329. $where_sql = "";
  330. if(!empty($params['game_id'])){
  331. $where_sql .= is_array($params['game_id']) ? " AND game_id in (".implode(',', $params['game_id']).")" : " AND game_id = {$params['game_id']}";
  332. }
  333. if(!empty($params['media_id'])){
  334. $where_sql .= " AND media_id = {$params['media_id']}";
  335. }
  336. if(!empty($params['site_id'])){
  337. $where_sql .= " AND site_id = {$params['site_id']}";
  338. }
  339. if(!empty($params['auth_id'])){
  340. $where_sql .= " AND auth_id = {$params['auth_id']}";
  341. }
  342. if(!empty($params['user_name'])){
  343. $where_sql .= " AND user_name = {$params['user_name']}";
  344. }
  345. $uids = array_column($userData, 'uid');
  346. if(empty($userData)){
  347. return [];
  348. }
  349. $where_sql = " AND uid in (".implode(',', $uids).") {$where_sql}";
  350. $sql_parts = [];
  351. $sql_parts[] = "SELECT * FROM role_data_and WHERE 1=1 {$where_sql}";
  352. $sql_parts[] = "SELECT * FROM role_data_ios WHERE 1=1 {$where_sql}";
  353. $unionSql = implode(" UNION ALL ", $sql_parts);
  354. // 分页
  355. $offset = ($page - 1) * $limit;
  356. $unionSql .= " LIMIT {$offset}, {$limit}";
  357. $roleData = Db::connect('db_game_log')->query($unionSql);
  358. // 合并相同uid的数据,将角色信息放到数组中
  359. $mergedData = [];
  360. foreach ($roleData as $item) {
  361. $uid = $item['uid'];
  362. if (!isset($mergedData[$uid])) {
  363. // 创建用户基础信息,排除角色相关字段
  364. $baseInfo = array_diff_key($item, array_flip(['role_id', 'role_name', 'role_level']));
  365. $mergedData[$uid] = $baseInfo + ['roles' => []];
  366. }
  367. // 添加角色信息到数组
  368. $mergedData[$uid]['roles'][] = [
  369. 'server_name' => $item['server_name'],
  370. 'role_name' => $item['role_name'],
  371. 'role_level' => $item['role_level'],
  372. ];
  373. }
  374. // 转换回数组格式
  375. $roleData = array_values($mergedData);
  376. $roleData = $this->trandformListColumn($roleData, ['game', 'ip', 'auth', 'agent']);
  377. $count = count($roleData);
  378. return [
  379. 'data' => $roleData,
  380. 'current_page' => $page,
  381. 'per_page' => $limit,
  382. 'last_page' => ceil($count / $limit),
  383. 'has_more' => $page < ceil($count / $limit),
  384. 'total' => $count
  385. ];
  386. }
  387. }