ServerController.php 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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\ServerV2ray;
  10. use App\Models\ServerLog;
  11. use App\Models\User;
  12. use App\Utils\Helper;
  13. use Illuminate\Support\Facades\DB;
  14. class ServerController extends Controller
  15. {
  16. public function fetch(Request $request)
  17. {
  18. $user = User::find($request->session()->get('id'));
  19. $servers = [];
  20. $userService = new UserService();
  21. if ($userService->isAvailable($user)) {
  22. $serverService = new ServerService();
  23. $servers = $serverService->getAvailableServers($user);
  24. }
  25. return response([
  26. 'data' => $servers
  27. ]);
  28. }
  29. public function getServerLogs(Request $request)
  30. {
  31. $serverLogModel = ServerLog::select([
  32. DB::raw('sum(u) as u'),
  33. DB::raw('sum(d) as d'),
  34. 'log_at',
  35. 'user_id',
  36. 'rate'
  37. ])
  38. ->where('user_id', $request->session()->get('id'))
  39. ->where('log_at', '>=', strtotime(date('Y-m-1')))
  40. ->groupBy('log_at', 'user_id', 'rate')
  41. ->orderBy('log_at', 'DESC');
  42. return response([
  43. 'data' => $serverLogModel->get()
  44. ]);
  45. }
  46. }