LogController.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Log;
  4. use App\Services\LogService;
  5. use Exception;
  6. use Illuminate\Contracts\Foundation\Application;
  7. use Illuminate\Contracts\Pagination\LengthAwarePaginator;
  8. use Illuminate\Database\Eloquent\Builder;
  9. use Illuminate\Http\RedirectResponse;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Http\Response;
  12. use Illuminate\Routing\Redirector;
  13. use Illuminate\Support\Facades\Auth;
  14. use Illuminate\Support\Facades\Gate;
  15. use Illuminate\Support\Facades\Validator;
  16. use function GuzzleHttp\Psr7\str;
  17. class LogController extends Controller
  18. {
  19. /**
  20. * Display a listing of the resource.
  21. *
  22. * @param Request $request
  23. * @return Application|LengthAwarePaginator|\Illuminate\Contracts\View\Factory|\Illuminate\View\View
  24. */
  25. public function index(Request $request)
  26. {
  27. if (!Gate::allows('日志-查询')) {
  28. return redirect(url('/'));
  29. }
  30. //没有查询条件,默认展示最近50条
  31. if (!$request->has('created_at_start') &&
  32. !$request->has('created_at_end') &&
  33. !$request->has('operation') &&
  34. !$request->has('type') &&
  35. !$request->has('description') &&
  36. !$request->has("is_exception")
  37. ) {
  38. $logs = Log::query()
  39. ->orderBy('id', 'desc')
  40. ->paginate(50);
  41. return view('maintenance.log.index', ['logs' => $logs]);
  42. }
  43. //不传开始时间提示错误信息并返回
  44. if (!$request->has('created_at_start')) {
  45. session()->flash('warning', '请选择开始时间');
  46. return view('maintenance.log.index', ['logs' => null]);
  47. }
  48. $query = Log::query();
  49. if ($request->has('operation')) {
  50. $query->where('operation', 'like', $request->operation . '%');
  51. }
  52. if ($request->has('type')) {
  53. $query->where('type', 'like', $request->type . '%');
  54. }
  55. if ($request->has('description')) {
  56. $str = $request->description;
  57. $str = trim($str, '\\');
  58. $str = str_replace('\\', '\\\\', $str);
  59. $query->where('description', 'like', '%' . $str . '%');
  60. }
  61. if ($request->has('created_at_start')) {
  62. $query->where('created_at', '>=', $request->created_at_start);
  63. }
  64. if ($request->has('created_at_end')) {
  65. $query->where('created_at', '<=', $request->created_at_end);
  66. }
  67. if ($request->has("is_exception")){
  68. $query->where(function(Builder $query){
  69. $query->where("type","like","ERROR%")->orWhere("type","like","EXCEPTION%");
  70. });
  71. }
  72. $query->orderByDesc('id');
  73. $logs = $query->paginate($request->paginate??50);
  74. return view('maintenance.log.index', ['logs' => $logs]);
  75. }
  76. /**
  77. * Display the specified resource.
  78. *
  79. * @param Log $log
  80. * @return Response
  81. */
  82. public function show(Log $log)
  83. {
  84. return view('maintenance.log.show', ['log' => $log]);
  85. }
  86. public function syncRedisLogs()
  87. {
  88. LogService::syncRedisLogs();
  89. return redirect('maintenance/log');
  90. }
  91. }