mirror of
https://github.com/v2board/v2board.git
synced 2025-02-25 06:40:26 +08:00
update: add new client protocol
This commit is contained in:
parent
9aed2554ee
commit
4722379e79
@ -25,10 +25,27 @@ class V2rayN
|
|||||||
if ($item['type'] === 'v2ray') {
|
if ($item['type'] === 'v2ray') {
|
||||||
$uri .= self::buildVmess($user['uuid'], $item);
|
$uri .= self::buildVmess($user['uuid'], $item);
|
||||||
}
|
}
|
||||||
|
if ($item['type'] === 'shadowsocks') {
|
||||||
|
$uri .= self::buildShadowsocks($user['uuid'], $item);
|
||||||
|
}
|
||||||
|
if ($item['type'] === 'trojan') {
|
||||||
|
$uri .= self::buildTrojan($user['uuid'], $item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return base64_encode($uri);
|
return base64_encode($uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function buildShadowsocks($password, $server)
|
||||||
|
{
|
||||||
|
$name = rawurlencode($server['name']);
|
||||||
|
$str = str_replace(
|
||||||
|
['+', '/', '='],
|
||||||
|
['-', '_', ''],
|
||||||
|
base64_encode("{$server['cipher']}:{$password}")
|
||||||
|
);
|
||||||
|
return "ss://{$str}@{$server['host']}:{$server['port']}#{$name}\r\n";
|
||||||
|
}
|
||||||
|
|
||||||
public static function buildVmess($uuid, $server)
|
public static function buildVmess($uuid, $server)
|
||||||
{
|
{
|
||||||
$config = [
|
$config = [
|
||||||
@ -57,4 +74,17 @@ class V2rayN
|
|||||||
return "vmess://" . base64_encode(json_encode($config)) . "\r\n";
|
return "vmess://" . base64_encode(json_encode($config)) . "\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function buildTrojan($password, $server)
|
||||||
|
{
|
||||||
|
$name = rawurlencode($server['name']);
|
||||||
|
$query = http_build_query([
|
||||||
|
'allowInsecure' => $server['allow_insecure'],
|
||||||
|
'peer' => $server['server_name'],
|
||||||
|
'sni' => $server['server_name']
|
||||||
|
]);
|
||||||
|
$uri = "trojan://{$password}@{$server['host']}:{$server['port']}?{$query}#{$name}";
|
||||||
|
$uri .= "\r\n";
|
||||||
|
return $uri;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -25,10 +25,27 @@ class V2rayNG
|
|||||||
if ($item['type'] === 'v2ray') {
|
if ($item['type'] === 'v2ray') {
|
||||||
$uri .= self::buildVmess($user['uuid'], $item);
|
$uri .= self::buildVmess($user['uuid'], $item);
|
||||||
}
|
}
|
||||||
|
if ($item['type'] === 'shadowsocks') {
|
||||||
|
$uri .= self::buildShadowsocks($user['uuid'], $item);
|
||||||
|
}
|
||||||
|
if ($item['type'] === 'trojan') {
|
||||||
|
$uri .= self::buildTrojan($user['uuid'], $item);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return base64_encode($uri);
|
return base64_encode($uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function buildShadowsocks($password, $server)
|
||||||
|
{
|
||||||
|
$name = rawurlencode($server['name']);
|
||||||
|
$str = str_replace(
|
||||||
|
['+', '/', '='],
|
||||||
|
['-', '_', ''],
|
||||||
|
base64_encode("{$server['cipher']}:{$password}")
|
||||||
|
);
|
||||||
|
return "ss://{$str}@{$server['host']}:{$server['port']}#{$name}\r\n";
|
||||||
|
}
|
||||||
|
|
||||||
public static function buildVmess($uuid, $server)
|
public static function buildVmess($uuid, $server)
|
||||||
{
|
{
|
||||||
$config = [
|
$config = [
|
||||||
@ -57,4 +74,18 @@ class V2rayNG
|
|||||||
return "vmess://" . base64_encode(json_encode($config)) . "\r\n";
|
return "vmess://" . base64_encode(json_encode($config)) . "\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function buildTrojan($password, $server)
|
||||||
|
{
|
||||||
|
$name = rawurlencode($server['name']);
|
||||||
|
$query = http_build_query([
|
||||||
|
'allowInsecure' => $server['allow_insecure'],
|
||||||
|
'peer' => $server['server_name'],
|
||||||
|
'sni' => $server['server_name']
|
||||||
|
]);
|
||||||
|
$uri = "trojan://{$password}@{$server['host']}:{$server['port']}?{$query}#{$name}";
|
||||||
|
$uri .= "\r\n";
|
||||||
|
return $uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user