ServerController.php 2.4 KB

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