verifyToken($request)) { return $r; } $nodeId = $request->input('node_id'); $server = Server::find($nodeId); if (!$server) { return $this->error("server could not be found", 404); } Cache::put('server_last_check_at_' . $server->id, time()); $users = User::whereIn('group_id', json_decode($server->group_id)) ->select([ 'id', 'email', 't', 'u', 'd', 'transfer_enable', 'enable', 'v2ray_uuid', 'v2ray_alter_id', 'v2ray_level' ]) ->whereRaw('u + d < transfer_enable') ->where('enable', 1) ->get(); $result = []; foreach ($users as $user) { $user->v2ray_user = [ "uuid" => $user->v2ray_uuid, "email" => sprintf("%s@v2board.user", $user->v2ray_uuid), "alter_id" => $user->v2ray_alter_id, "level" => $user->v2ray_level, ]; unset($user['v2ray_uuid']); unset($user['v2ray_alter_id']); unset($user['v2ray_level']); array_push($result, $user); } return $this->success($result); } // 后端提交数据 public function submit(Request $request) { if ($r = $this->verifyToken($request)) { return $r; } Log::info('serverSubmitData:' . $request->input('node_id') . ':' . file_get_contents('php://input')); $server = Server::find($request->input('node_id')); if (!$server) { return $this->error("server could not be found", 404); } $data = file_get_contents('php://input'); $data = json_decode($data, true); foreach ($data as $item) { $u = $item['u'] * $server->rate; $d = $item['d'] * $server->rate; $user = User::find($item['user_id']); $user->t = time(); $user->u = $user->u + $u; $user->d = $user->d + $d; $user->save(); $serverLog = new ServerLog(); $serverLog->user_id = $item['user_id']; $serverLog->server_id = $request->input('node_id'); $serverLog->u = $item['u']; $serverLog->d = $item['d']; $serverLog->rate = $server->rate; $serverLog->save(); } return $this->success(''); } // 后端获取配置 public function config(Request $request) { if ($r = $this->verifyToken($request)) { return $r; } $nodeId = $request->input('node_id'); $localPort = $request->input('local_port'); if (empty($nodeId) || empty($localPort)) { return $this->error('invalid parameters', 400); } $server = Server::find($nodeId); if (!$server) { return $this->error("server could not be found", 404); } $json = json_decode(self::SERVER_CONFIG); $json->inboundDetour[0]->port = (int)$localPort; $json->inbound->port = (int)$server->server_port; $json->inbound->streamSettings->network = $server->network; if ($server->settings) { switch ($server->network) { case 'tcp': $json->inbound->streamSettings->tcpSettings = json_decode($server->settings); break; case 'kcp': $json->inbound->streamSettings->kcpSettings = json_decode($server->settings); break; case 'ws': $json->inbound->streamSettings->wsSettings = json_decode($server->settings); break; case 'http': $json->inbound->streamSettings->httpSettings = json_decode($server->settings); break; case 'domainsocket': $json->inbound->streamSettings->dsSettings = json_decode($server->settings); break; case 'quic': $json->inbound->streamSettings->quicSettings = json_decode($server->settings); break; } } if ($server->rules) { $rules = json_decode($server->rules); // domain if (isset($rules->domain)) { $domainObj = new \StdClass(); $domainObj->type = 'field'; $domainObj->domain = $rules->domain; $domainObj->outboundTag = 'block'; array_push($json->routing->settings->rules, $domainObj); } // protocol if (isset($rules->protocol)) { $protocolObj = new \StdClass(); $protocolObj->type = 'field'; $protocolObj->protocol = $rules->protocol; $protocolObj->outboundTag = 'block'; array_push($json->routing->settings->rules, $protocolObj); } } if ((int)$server->tls) { $json->inbound->streamSettings->security = 'tls'; $tls = (object)[ 'certificateFile' => '/home/v2ray.crt', 'keyFile' => '/home/v2ray.key' ]; $json->inbound->streamSettings->tlsSettings = new \StdClass(); $json->inbound->streamSettings->tlsSettings->certificates[0] = $tls; } $json->poseidon = [ 'license_key' => (string)config('v2board.server_license'), ]; return $this->success($json); } protected function verifyToken(Request $request) { $token = $request->input('token'); if (empty($token)) { return $this->error("token must be set"); } if ($token !== config('v2board.server_token')) { return $this->error("invalid token"); } } protected function error($msg, int $status = 400) { return response([ 'msg' => $msg, ], $status); } protected function success($data) { return response([ 'msg' => 'ok', 'data' => $data, ]); } }