UserLogController.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?php
  2. namespace App\Module\Game\AdminControllers;
  3. use App\Module\Game\Models\UserLog;
  4. use App\Module\Game\Services\UserLogService;
  5. use Dcat\Admin\Form;
  6. use Dcat\Admin\Grid;
  7. use Dcat\Admin\Show;
  8. use Spatie\RouteAttributes\Attributes\Resource;
  9. use UCore\DcatAdmin\AdminController;
  10. /**
  11. * 用户日志管理控制器
  12. */
  13. #[Resource('game-user-logs', names: 'dcat.admin.game-user-logs')]
  14. class UserLogController extends AdminController
  15. {
  16. /**
  17. * 页面标题
  18. *
  19. * @var string
  20. */
  21. protected $title = '用户日志管理';
  22. /**
  23. * Make a grid builder.
  24. *
  25. * @return Grid
  26. */
  27. protected function grid()
  28. {
  29. return Grid::make(UserLog::with(['user']), function (Grid $grid) {
  30. $grid->column('id', 'ID')->sortable();
  31. $grid->column('user.username', '用户名')
  32. ->link(function ($value) {
  33. return admin_route('dcat.admin.users.show', ['user' => $this->user_id]);
  34. });
  35. $grid->column('user_id', '用户ID');
  36. $grid->column('message', '日志消息')
  37. ->limit(50)
  38. ->help('用户操作的详细描述');
  39. $grid->column('source_type', '来源类型')
  40. ->using([
  41. 'fund' => '资金',
  42. 'item' => '物品',
  43. 'farm' => '农场',
  44. 'pet' => '宠物',
  45. 'system' => '系统',
  46. ])
  47. ->label([
  48. 'fund' => 'success',
  49. 'item' => 'primary',
  50. 'farm' => 'warning',
  51. 'pet' => 'info',
  52. 'system' => 'default',
  53. ]);
  54. $grid->column('source_id', '来源ID');
  55. $grid->column('source_table', '来源表名')
  56. ->limit(20);
  57. $grid->column('created_at', '创建时间')
  58. ->sortable();
  59. // 筛选器
  60. $grid->filter(function (Grid\Filter $filter) {
  61. $filter->equal('user_id', '用户ID');
  62. $filter->like('message', '日志消息');
  63. $filter->equal('source_type', '来源类型')
  64. ->select([
  65. 'fund' => '资金',
  66. 'item' => '物品',
  67. 'farm' => '农场',
  68. 'pet' => '宠物',
  69. 'system' => '系统',
  70. ]);
  71. $filter->between('created_at', '创建时间')->datetime();
  72. });
  73. // 默认排序
  74. $grid->model()->orderBy('created_at', 'desc');
  75. // 禁用创建按钮
  76. $grid->disableCreateButton();
  77. // 禁用编辑
  78. $grid->disableEditButton();
  79. // 批量操作
  80. $grid->batchActions(function (Grid\Tools\BatchActions $batch) {
  81. $batch->add('清理选中日志', new \App\Module\Game\AdminControllers\Actions\BatchDeleteUserLogsAction());
  82. });
  83. // 工具栏
  84. $grid->tools(function (Grid\Tools $tools) {
  85. $tools->append(new \App\Module\Game\AdminControllers\Tools\CleanExpiredLogsButton());
  86. $tools->append(new \App\Module\Game\AdminControllers\Tools\UserLogStatsButton());
  87. });
  88. });
  89. }
  90. /**
  91. * Make a show builder.
  92. *
  93. * @param mixed $id
  94. * @return Show
  95. */
  96. protected function detail($id)
  97. {
  98. return Show::make($id, UserLog::with(['user']), function (Show $show) {
  99. $show->field('id', 'ID');
  100. $show->field('user.username', '用户名')
  101. ->link(function ($value) {
  102. return admin_route('dcat.admin.users.show', ['user' => $this->user_id]);
  103. });
  104. $show->field('user_id', '用户ID');
  105. $show->field('message', '日志消息')
  106. ->unescape();
  107. $show->field('source_type', '来源类型')
  108. ->using([
  109. 'fund' => '资金',
  110. 'item' => '物品',
  111. 'farm' => '农场',
  112. 'pet' => '宠物',
  113. 'system' => '系统',
  114. ]);
  115. $show->field('source_id', '来源ID');
  116. $show->field('source_table', '来源表名');
  117. $show->field('created_at', '创建时间');
  118. // 禁用编辑和删除按钮
  119. $show->disableEditButton();
  120. $show->disableDeleteButton();
  121. });
  122. }
  123. /**
  124. * Make a form builder.
  125. *
  126. * @return Form
  127. */
  128. protected function form()
  129. {
  130. return Form::make(UserLog::class, function (Form $form) {
  131. $form->display('id', 'ID');
  132. $form->number('user_id', '用户ID')
  133. ->required()
  134. ->help('关联的用户ID');
  135. $form->textarea('message', '日志消息')
  136. ->required()
  137. ->rows(3)
  138. ->help('用户操作的详细描述');
  139. $form->select('source_type', '来源类型')
  140. ->options([
  141. 'fund' => '资金',
  142. 'item' => '物品',
  143. 'farm' => '农场',
  144. 'pet' => '宠物',
  145. 'system' => '系统',
  146. ])
  147. ->help('日志来源的模块类型');
  148. $form->number('source_id', '来源ID')
  149. ->help('关联的业务记录ID');
  150. $form->text('source_table', '来源表名')
  151. ->help('关联的数据库表名');
  152. $form->display('created_at', '创建时间');
  153. // 禁用删除按钮
  154. $form->disableDeleteButton();
  155. });
  156. }
  157. /**
  158. * 清理过期日志
  159. *
  160. * @return \Illuminate\Http\JsonResponse
  161. */
  162. public function cleanExpiredLogs()
  163. {
  164. try {
  165. $days = request('days', 30);
  166. $deletedCount = UserLogService::cleanExpiredLogs($days);
  167. return response()->json([
  168. 'status' => true,
  169. 'message' => "成功清理 {$deletedCount} 条过期日志",
  170. ]);
  171. } catch (\Exception $e) {
  172. return response()->json([
  173. 'status' => false,
  174. 'message' => '清理过期日志失败:' . $e->getMessage(),
  175. ]);
  176. }
  177. }
  178. /**
  179. * 获取用户日志统计信息
  180. *
  181. * @return \Illuminate\Http\JsonResponse
  182. */
  183. public function getStats()
  184. {
  185. try {
  186. $userId = request('user_id');
  187. if (!$userId) {
  188. return response()->json([
  189. 'status' => false,
  190. 'message' => '请提供用户ID',
  191. ]);
  192. }
  193. $stats = UserLogService::getUserLogStats($userId);
  194. return response()->json([
  195. 'status' => true,
  196. 'data' => $stats,
  197. ]);
  198. } catch (\Exception $e) {
  199. return response()->json([
  200. 'status' => false,
  201. 'message' => '获取统计信息失败:' . $e->getMessage(),
  202. ]);
  203. }
  204. }
  205. }