mirror of
https://github.com/v2board/v2board.git
synced 2024-11-10 17:49:11 +08:00
update
This commit is contained in:
parent
80f902f7d0
commit
05e2ae94aa
@ -11,6 +11,10 @@ use App\Utils\Helper;
|
|||||||
|
|
||||||
class AppController extends Controller
|
class AppController extends Controller
|
||||||
{
|
{
|
||||||
|
CONST CLIENT_CONFIG = '{"policy":{"levels":{"0":{"uplinkOnly":0}}},"dns":{"servers":["1.1.1.1"]},"outboundDetour":[{"protocol":"freedom","tag":"direct","settings":{}}],"inbound":{"listen":"0.0.0.0","port":31211,"protocol":"socks","settings":{"auth":"noauth","udp":true,"ip":"127.0.0.1"}},"inboundDetour":[{"listen":"0.0.0.0","allocate":{"strategy":"always","refresh":5,"concurrency":3},"port":31210,"protocol":"http","tag":"httpDetour","domainOverride":["http","tls"],"streamSettings":{},"settings":{"timeout":0}}],"routing":{"strategy":"rules","settings":{"domainStrategy":"IPIfNonMatch","rules":[{"port":"1-52","type":"field","outboundTag":"direct"},{"port":"54-79","type":"field","outboundTag":"direct"},{"port":"81-442","type":"field","outboundTag":"direct"},{"port":"444-65535","type":"field","outboundTag":"direct"},{"type":"field","ip":["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.2.0/24","192.168.0.0/16","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","::1/128","fc00::/7","fe80::/10"],"outboundTag":"direct"}]}},"outbound":{"sendThrough":"0.0.0.0","mux":{"enabled":false,"concurrency":8},"protocol":"vmess","settings":{"vnext":[{"address":"server","port":443,"users":[{"id":"uuid","alterId":2,"security":"auto","level":0}],"remark":"remark"}]},"streamSettings":{"network":"tcp","tcpSettings":{"header":{"type":"none"}},"security":"none","tlsSettings":{"allowInsecure":false},"kcpSettings":{"header":{"type":"none"},"mtu":1350,"congestion":false,"tti":20,"uplinkCapacity":5,"writeBufferSize":1,"readBufferSize":1,"downlinkCapacity":20},"wsSettings":{"path":"","headers":{"Host":"server.cc"}}}}}';
|
||||||
|
CONST SOCKS_PORT = 10010;
|
||||||
|
CONST HTTP_PORT = 10011;
|
||||||
|
|
||||||
public function data (Request $request) {
|
public function data (Request $request) {
|
||||||
$user = $request->user;
|
$user = $request->user;
|
||||||
$nodes = [];
|
$nodes = [];
|
||||||
@ -35,8 +39,57 @@ class AppController extends Controller
|
|||||||
'u' => $user->u,
|
'u' => $user->u,
|
||||||
'd' => $user->d,
|
'd' => $user->d,
|
||||||
'transfer_enable' => $user->transfer_enable,
|
'transfer_enable' => $user->transfer_enable,
|
||||||
'expired_time' => $user->expired_at
|
'expired_time' => $user->expired_at,
|
||||||
|
'plan' => isset($user['plan']) ? $user['plan'] : false
|
||||||
]
|
]
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function config (Request $request) {
|
||||||
|
if (empty($request->input('server_id'))) {
|
||||||
|
abort(500, '参数错误');
|
||||||
|
}
|
||||||
|
$user = $request->user;
|
||||||
|
if ($user->expired_at < time()) {
|
||||||
|
abort(500, '订阅计划已过期');
|
||||||
|
}
|
||||||
|
$server = Server::where('show', 1)
|
||||||
|
->where('id', $request->input('server_id'))
|
||||||
|
->first();
|
||||||
|
if (!$server) {
|
||||||
|
abort(500, '服务器不存在');
|
||||||
|
}
|
||||||
|
$json = json_decode(self::CLIENT_CONFIG);
|
||||||
|
//socks
|
||||||
|
$json->inbound->port = (int)self::SOCKS_PORT;
|
||||||
|
//http
|
||||||
|
$json->inboundDetour[0]->port = (int)self::HTTP_PORT;
|
||||||
|
//other
|
||||||
|
$json->outbound->settings->vnext[0]->address = (string)$server->host;
|
||||||
|
$json->outbound->settings->vnext[0]->port = (int)$server->port;
|
||||||
|
$json->outbound->settings->vnext[0]->users[0]->id = (string)$user->v2ray_uuid;
|
||||||
|
$json->outbound->settings->vnext[0]->users[0]->alterId = (int)$user->v2ray_alter_id;
|
||||||
|
$json->outbound->settings->vnext[0]->remark = (string)$server->name;
|
||||||
|
$json->outbound->streamSettings->network = $server->network;
|
||||||
|
if ($server->settings) {
|
||||||
|
switch ($server->network) {
|
||||||
|
case 'tcp': $json->outbound->streamSettings->tcpSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
case 'kcp': $json->outbound->streamSettings->kcpSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
case 'ws': $json->outbound->streamSettings->wsSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
case 'http': $json->outbound->streamSettings->httpSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
case 'domainsocket': $json->outbound->streamSettings->dsSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
case 'quic': $json->outbound->streamSettings->quicSettings = json_decode($server->settings);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($server->tls) {
|
||||||
|
$json->outbound->streamSettings->security = "tls";
|
||||||
|
}
|
||||||
|
die(json_encode($json, JSON_UNESCAPED_UNICODE));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,32 +96,32 @@ class DeepbworkController extends Controller
|
|||||||
$nodeId = $request->input('node_id');
|
$nodeId = $request->input('node_id');
|
||||||
$localPort = $request->input('local_port');
|
$localPort = $request->input('local_port');
|
||||||
$server = Server::find($nodeId);
|
$server = Server::find($nodeId);
|
||||||
$jsonData = json_decode(self::SERVER_CONFIG);
|
$json = json_decode(self::SERVER_CONFIG);
|
||||||
$jsonData->inboundDetour[0]->port = (int)$localPort;
|
$json->inboundDetour[0]->port = (int)$localPort;
|
||||||
$jsonData->inbound->port = (int)$server->server_port;
|
$json->inbound->port = (int)$server->server_port;
|
||||||
$jsonData->inbound->streamSettings->network = $server->network;
|
$json->inbound->streamSettings->network = $server->network;
|
||||||
if ($server->settings) {
|
if ($server->settings) {
|
||||||
switch ($server->network) {
|
switch ($server->network) {
|
||||||
case 'tcp': $jsonData->inbound->streamSettings->tcpSettings = json_decode($server->settings);
|
case 'tcp': $json->inbound->streamSettings->tcpSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
case 'kcp': $jsonData->inbound->streamSettings->kcpSettings = json_decode($server->settings);
|
case 'kcp': $json->inbound->streamSettings->kcpSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
case 'ws': $jsonData->inbound->streamSettings->wsSettings = json_decode($server->settings);
|
case 'ws': $json->inbound->streamSettings->wsSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
case 'http': $jsonData->inbound->streamSettings->httpSettings = json_decode($server->settings);
|
case 'http': $json->inbound->streamSettings->httpSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
case 'domainsocket': $jsonData->inbound->streamSettings->dsSettings = json_decode($server->settings);
|
case 'domainsocket': $json->inbound->streamSettings->dsSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
case 'quic': $jsonData->inbound->streamSettings->quicSettings = json_decode($server->settings);
|
case 'quic': $json->inbound->streamSettings->quicSettings = json_decode($server->settings);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ((int)$server->tls) {
|
if ((int)$server->tls) {
|
||||||
$jsonData->inbound->streamSettings->security = "tls";
|
$json->inbound->streamSettings->security = "tls";
|
||||||
$tls = (object) array("certificateFile" => "/home/v2ray.crt", "keyFile" => "/home/v2ray.key");
|
$tls = (object) array("certificateFile" => "/home/v2ray.crt", "keyFile" => "/home/v2ray.key");
|
||||||
$jsonData->inbound->streamSettings->tlsSettings->certificates[0] = $tls;
|
$json->inbound->streamSettings->tlsSettings->certificates[0] = $tls;
|
||||||
}
|
}
|
||||||
|
|
||||||
die(json_encode($jsonData, JSON_UNESCAPED_UNICODE));
|
die(json_encode($json, JSON_UNESCAPED_UNICODE));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -104,6 +104,7 @@ Route::prefix('v1')
|
|||||||
Route::get ('subscribe', 'ClientController@subscribe');
|
Route::get ('subscribe', 'ClientController@subscribe');
|
||||||
// App
|
// App
|
||||||
Route::get ('app/data', 'AppController@data');
|
Route::get ('app/data', 'AppController@data');
|
||||||
|
Route::get ('app/config', 'AppController@config');
|
||||||
});
|
});
|
||||||
// Server
|
// Server
|
||||||
Route::prefix('server')
|
Route::prefix('server')
|
||||||
|
Loading…
Reference in New Issue
Block a user