ServerController.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. namespace App\Http\Controllers\User;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\UserService;
  5. use App\Utils\CacheKey;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Cache;
  8. use App\Models\Server;
  9. use App\Models\ServerLog;
  10. use App\Models\User;
  11. use App\Utils\Helper;
  12. class ServerController extends Controller
  13. {
  14. public function fetch(Request $request)
  15. {
  16. $user = User::find($request->session()->get('id'));
  17. $server = [];
  18. $userService = new UserService();
  19. if ($userService->isAvailable($user)) {
  20. $servers = Server::where('show', 1)
  21. ->orderBy('sort', 'ASC')
  22. ->get();
  23. foreach ($servers as $item) {
  24. $groupId = json_decode($item['group_id']);
  25. if (in_array($user->group_id, $groupId)) {
  26. array_push($server, $item);
  27. }
  28. }
  29. }
  30. for ($i = 0; $i < count($server); $i++) {
  31. $server[$i]['link'] = Helper::buildVmessLink($server[$i], $user);
  32. if ($server[$i]['parent_id']) {
  33. $server[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_LAST_CHECK_AT', $server[$i]['parent_id']));
  34. } else {
  35. $server[$i]['last_check_at'] = Cache::get(CacheKey::get('SERVER_LAST_CHECK_AT', $server[$i]['id']));
  36. }
  37. }
  38. return response([
  39. 'data' => $server
  40. ]);
  41. }
  42. public function logFetch(Request $request)
  43. {
  44. $type = $request->input('type') ? $request->input('type') : 0;
  45. $current = $request->input('current') ? $request->input('current') : 1;
  46. $pageSize = $request->input('pageSize') >= 10 ? $request->input('pageSize') : 10;
  47. $serverLogModel = ServerLog::where('user_id', $request->session()->get('id'))
  48. ->orderBy('created_at', 'DESC');
  49. switch ($type) {
  50. case 0:
  51. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')));
  52. break;
  53. case 1:
  54. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')) - 604800);
  55. break;
  56. case 2:
  57. $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-1')));
  58. }
  59. $total = $serverLogModel->count();
  60. $res = $serverLogModel->forPage($current, $pageSize)
  61. ->get();
  62. return response([
  63. 'data' => $res,
  64. 'total' => $total
  65. ]);
  66. }
  67. }