mirror of
https://github.com/v2board/v2board.git
synced 2025-02-11 07:59:11 +08:00
update trojan server
This commit is contained in:
parent
da98dcad9c
commit
9874ef2f72
@ -108,7 +108,7 @@ class TrojanTidalabController extends Controller
|
|||||||
}
|
}
|
||||||
$serverService = new ServerService();
|
$serverService = new ServerService();
|
||||||
try {
|
try {
|
||||||
$json = $serverService->getConfig($nodeId, $localPort);
|
$json = $serverService->getTrojanConfig($nodeId, $localPort);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
abort(500, $e->getMessage());
|
abort(500, $e->getMessage());
|
||||||
}
|
}
|
||||||
|
@ -13,8 +13,8 @@ use Illuminate\Support\Facades\Cache;
|
|||||||
class ServerService
|
class ServerService
|
||||||
{
|
{
|
||||||
|
|
||||||
CONST SERVER_CONFIG = '{"api":{"services":["HandlerService","StatsService"],"tag":"api"},"dns":{},"stats":{},"inbound":{"port":443,"protocol":"vmess","settings":{"clients":[]},"sniffing":{"enabled":true,"destOverride":["http","tls"]},"streamSettings":{"network":"tcp"},"tag":"proxy"},"inboundDetour":[{"listen":"0.0.0.0","port":23333,"protocol":"dokodemo-door","settings":{"address":"0.0.0.0"},"tag":"api"}],"log":{"loglevel":"debug","access":"access.log","error":"error.log"},"outbound":{"protocol":"freedom","settings":{}},"outboundDetour":[{"protocol":"blackhole","settings":{},"tag":"block"}],"routing":{"rules":[{"inboundTag":"api","outboundTag":"api","type":"field"}]},"policy":{"levels":{"0":{"handshake":4,"connIdle":300,"uplinkOnly":5,"downlinkOnly":30,"statsUserUplink":true,"statsUserDownlink":true}}}}';
|
CONST V2RAY_CONFIG = '{"api":{"services":["HandlerService","StatsService"],"tag":"api"},"dns":{},"stats":{},"inbound":{"port":443,"protocol":"vmess","settings":{"clients":[]},"sniffing":{"enabled":true,"destOverride":["http","tls"]},"streamSettings":{"network":"tcp"},"tag":"proxy"},"inboundDetour":[{"listen":"0.0.0.0","port":23333,"protocol":"dokodemo-door","settings":{"address":"0.0.0.0"},"tag":"api"}],"log":{"loglevel":"debug","access":"access.log","error":"error.log"},"outbound":{"protocol":"freedom","settings":{}},"outboundDetour":[{"protocol":"blackhole","settings":{},"tag":"block"}],"routing":{"rules":[{"inboundTag":"api","outboundTag":"api","type":"field"}]},"policy":{"levels":{"0":{"handshake":4,"connIdle":300,"uplinkOnly":5,"downlinkOnly":30,"statsUserUplink":true,"statsUserDownlink":true}}}}';
|
||||||
|
CONST TROJAN_CONFIG = '{"run_type":"server","local_addr":"0.0.0.0","local_port":443,"remote_addr":"www.taobao.com","remote_port":80,"password":[],"ssl":{"cert":"server.crt","key":"server.key","sni":"domain.com","fallback_port":1234},"api":{"enabled":true,"api_addr":"127.0.0.1","api_port":10000}}';
|
||||||
public function getVmess(User $user, $all = false):array
|
public function getVmess(User $user, $all = false):array
|
||||||
{
|
{
|
||||||
$vmess = [];
|
$vmess = [];
|
||||||
@ -97,7 +97,7 @@ class ServerService
|
|||||||
if (!$server) {
|
if (!$server) {
|
||||||
abort(500, '节点不存在');
|
abort(500, '节点不存在');
|
||||||
}
|
}
|
||||||
$json = json_decode(self::SERVER_CONFIG);
|
$json = json_decode(self::V2RAY_CONFIG);
|
||||||
$json->log->loglevel = config('v2board.server_log_level', 'none');
|
$json->log->loglevel = config('v2board.server_log_level', 'none');
|
||||||
$json->inboundDetour[0]->port = (int)$localPort;
|
$json->inboundDetour[0]->port = (int)$localPort;
|
||||||
$json->inbound->port = (int)$server->server_port;
|
$json->inbound->port = (int)$server->server_port;
|
||||||
@ -110,6 +110,19 @@ class ServerService
|
|||||||
return $json;
|
return $json;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getTrojanConfig(int $nodeId, int $localPort)
|
||||||
|
{
|
||||||
|
$server = ServerTrojan::find($nodeId);
|
||||||
|
if (!$server) {
|
||||||
|
abort(500, '节点不存在');
|
||||||
|
}
|
||||||
|
|
||||||
|
$json = json_decode(self::TROJAN_CONFIG);
|
||||||
|
$json->ssl->sni = $server->host;
|
||||||
|
$json->api->api_port = $localPort;
|
||||||
|
return $json;
|
||||||
|
}
|
||||||
|
|
||||||
private function setDns(Server $server, object $json)
|
private function setDns(Server $server, object $json)
|
||||||
{
|
{
|
||||||
if ($server->dnsSettings) {
|
if ($server->dnsSettings) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user