ServerController.php 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?php
  2. namespace App\Http\Controllers\User;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\ServerService;
  5. use App\Services\UserService;
  6. use App\Utils\CacheKey;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\Cache;
  9. use App\Models\Server;
  10. use App\Models\ServerLog;
  11. use App\Models\User;
  12. use App\Utils\Helper;
  13. class ServerController extends Controller
  14. {
  15. public function fetch(Request $request)
  16. {
  17. $user = User::find($request->session()->get('id'));
  18. $servers = [];
  19. $userService = new UserService();
  20. if ($userService->isAvailable($user)) {
  21. $serverService = new ServerService();
  22. $servers = $serverService->getAllServers($user);
  23. $servers = array_merge($servers['vmess'], $servers['trojan']);
  24. }
  25. return response([
  26. 'data' => $servers
  27. ]);
  28. }
  29. public function logFetch(Request $request)
  30. {
  31. $type = $request->input('type') ? $request->input('type') : 0;
  32. $current = $request->input('current') ? $request->input('current') : 1;
  33. $pageSize = $request->input('pageSize') >= 10 ? $request->input('pageSize') : 10;
  34. $serverLogModel = ServerLog::where('user_id', $request->session()->get('id'))
  35. ->orderBy('created_at', 'DESC');
  36. switch ($type) {
  37. case 0:
  38. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')));
  39. break;
  40. case 1:
  41. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')) - 604800);
  42. break;
  43. case 2:
  44. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-1')));
  45. }
  46. $total = $serverLogModel->count();
  47. $res = $serverLogModel->forPage($current, $pageSize)
  48. ->get();
  49. return response([
  50. 'data' => $res,
  51. 'total' => $total
  52. ]);
  53. }
  54. }