| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 | 
							- <?php
 
- namespace App\Http\Controllers;
 
- use Illuminate\Http\Request;
 
- use Cache;
 
- use App\Http\Controllers\Controller;
 
- use App\Models\Server;
 
- use App\Models\ServerLog;
 
- use App\Models\User;
 
- use App\Utils\Helper;
 
- class ServerController extends Controller {
 
-     public function fetch (Request $request) {
 
-         $user = User::find($request->session()->get('id'));
 
-         $server = [];
 
-         if ($user->expired_at > time()) {
 
-             $servers = Server::where('show', 1)
 
-                 ->orderBy('name')
 
-                 ->get();
 
-             foreach ($servers as $item) {
 
-                 $groupId = json_decode($item['group_id']);
 
-                 if (in_array($user->group_id, $groupId)) {
 
-                     array_push($server, $item);
 
-                 }
 
-             }
 
-         }
 
-         for ($i = 0; $i < count($server); $i++) {
 
-             $server[$i]['link'] = Helper::buildVmessLink($server[$i], $user);
 
-             if ($server[$i]['parent_id']) {
 
-                 $server[$i]['last_check_at'] = Cache::get('server_last_check_at_' . $server[$i]['parent_id']);
 
-             } else {
 
-                 $server[$i]['last_check_at'] = Cache::get('server_last_check_at_' . $server[$i]['id']);
 
-             }
 
-         }
 
-         return response([
 
-             'data' => $server
 
-         ]);
 
-     }
 
-     public function logFetch (Request $request) {
 
-     	$type = $request->input('type') ? $request->input('type') : 0;
 
-         $current = $request->input('current') ? $request->input('current') : 1;
 
-         $pageSize = $request->input('pageSize') >= 10 ? $request->input('pageSize') : 10;
 
-         $serverLogModel = ServerLog::where('user_id', $request->session()->get('id'))
 
-             ->orderBy('created_at', 'DESC');
 
-     	switch ($type) {
 
-     		case 0: $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')));
 
-     			break;
 
-     		case 1: $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-d')) - 604800);
 
-     			break;
 
-     		case 2: $serverLogModel->where('created_at', '>=', strtotime(date('Y-m-1')));
 
-     	}
 
-     	$sum = [
 
-     		'u' => $serverLogModel->sum('u'),
 
-     		'd' => $serverLogModel->sum('d')
 
-     	];
 
-         $total = $serverLogModel->count();
 
-         $res = $serverLogModel->forPage($current, $pageSize)
 
-             ->get();
 
-         return response([
 
-             'data' => $res,
 
-             'total' => $total,
 
-             'sum' => $sum
 
-         ]);
 
-     }
 
- }
 
 
  |