RuleController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Admin\RuleRequest;
  5. use App\Models\Node;
  6. use App\Models\Rule;
  7. use App\Models\RuleLog;
  8. use Exception;
  9. use Illuminate\Contracts\View\View;
  10. use Illuminate\Http\JsonResponse;
  11. use Illuminate\Http\Request;
  12. use Log;
  13. class RuleController extends Controller
  14. {
  15. public function index(Request $request): View
  16. { // 审计规则列表
  17. $query = Rule::query();
  18. $request->whenFilled('type', function ($value) use ($query) {
  19. $query->whereType($value);
  20. });
  21. return view('admin.rule.index', ['rules' => $query->paginate(15)->appends($request->except('page'))]);
  22. }
  23. public function store(RuleRequest $request): JsonResponse
  24. { // 添加审计规则
  25. try {
  26. if (Rule::create($request->validated())) {
  27. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.add')])]);
  28. }
  29. } catch (Exception $e) {
  30. Log::error(trans('common.error_action_item', ['action' => trans('common.add'), 'attribute' => trans('model.rule.attribute')]).': '.$e->getMessage());
  31. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.add')]).', '.$e->getMessage()]);
  32. }
  33. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.add')])]);
  34. }
  35. public function update(RuleRequest $request, Rule $rule): JsonResponse
  36. { // 编辑审计规则
  37. try {
  38. if ($rule->update($request->validated())) {
  39. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.edit')])]);
  40. }
  41. } catch (Exception $e) {
  42. Log::error(trans('common.error_action_item', ['action' => trans('common.edit'), 'attribute' => trans('model.rule.attribute')]).': '.$e->getMessage());
  43. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.edit')]).', '.$e->getMessage()]);
  44. }
  45. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.edit')])]);
  46. }
  47. public function destroy(Rule $rule): JsonResponse
  48. { // 删除审计规则
  49. try {
  50. if ($rule->delete()) {
  51. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]);
  52. }
  53. } catch (Exception $e) {
  54. Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('model.rule.attribute')]).': '.$e->getMessage());
  55. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]);
  56. }
  57. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')])]);
  58. }
  59. public function ruleLogList(Request $request): View
  60. { // 用户触发审计规则日志
  61. $query = RuleLog::with(['node:id,name', 'user:id,username', 'rule:id,name']);
  62. foreach (['user_id', 'node_id', 'rule_id'] as $field) {
  63. $request->whenFilled($field, function ($value) use ($query, $field) {
  64. $query->where($field, $value);
  65. });
  66. }
  67. $request->whenFilled('username', function ($username) use ($query) {
  68. $query->whereHas('user', function ($query) use ($username) {
  69. $query->where('username', 'like', "%$username%");
  70. });
  71. });
  72. return view('admin.rule.log', [
  73. 'nodes' => Node::pluck('name', 'id'),
  74. 'rules' => Rule::pluck('name', 'id'),
  75. 'ruleLogs' => $query->latest()->paginate(15)->appends($request->except('page')),
  76. ]);
  77. }
  78. // 清除所有审计触发日志
  79. public function clearLog(): JsonResponse
  80. {
  81. try {
  82. $ret = RuleLog::query()->delete();
  83. } catch (Exception $e) {
  84. Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('model.rule.logs')]).': '.$e->getMessage());
  85. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]);
  86. }
  87. if ($ret || RuleLog::doesntExist()) {
  88. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]);
  89. }
  90. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')])]);
  91. }
  92. }