12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- <?php
- namespace App\Utils;
- class Surge
- {
- public static function buildShadowsocks($password, $server)
- {
- $config = [
- "{$server['name']}=ss",
- "{$server['host']}",
- "{$server['port']}",
- "encrypt-method={$server['cipher']}",
- "password={$password}",
- 'tfo=true',
- 'udp-relay=true'
- ];
- $config = array_filter($config);
- $uri = implode(',', $config);
- $uri .= "\r\n";
- return $uri;
- }
- public static function buildVmess($uuid, $server)
- {
- $config = [
- "{$server['name']}=vmess",
- "{$server['host']}",
- "{$server['port']}",
- "username={$uuid}",
- 'tfo=true',
- 'udp-relay=true'
- ];
- if ($server['network'] === 'tcp') {
- if ($server['tls']) {
- $tlsSettings = json_decode($server['tlsSettings'], true);
- array_push($config, $server['tls'] ? 'tls=true' : 'tls=false');
- if (!empty($tlsSettings['allowInsecure'])) {
- array_push($config, $tlsSettings['allowInsecure'] ? 'skip-cert-verify=true' : 'skip-cert-verify=false');
- }
- if (!empty($tlsSettings['serverName'])) {
- array_push($config, "sni={$tlsSettings['serverName']}");
- }
- }
- }
- if ($server['network'] === 'ws') {
- array_push($config, 'ws=true');
- if ($server['tls']) {
- $tlsSettings = json_decode($server['tlsSettings'], true);
- array_push($config, $server['tls'] ? 'tls=true' : 'tls=false');
- if (!empty($tlsSettings['allowInsecure'])) {
- array_push($config, $tlsSettings['allowInsecure'] ? 'skip-cert-verify=true' : 'skip-cert-verify=false');
- }
- }
- if ($server['networkSettings']) {
- $wsSettings = json_decode($server['networkSettings'], true);
- if (isset($wsSettings['path'])) array_push($config, "ws-path={$wsSettings['path']}");
- if (isset($wsSettings['headers']['Host'])) array_push($config, "ws-headers=host:{$wsSettings['headers']['Host']}");
- }
- }
- $uri = implode(',', $config);
- $uri .= "\r\n";
- return $uri;
- }
- public static function buildTrojan($password, $server)
- {
- $config = [
- "{$server['name']}=trojan",
- "{$server['host']}",
- "{$server['port']}",
- "password={$password}",
- $server['server_name'] ? "sni={$server['server_name']}" : "",
- 'tfo=true',
- 'udp-relay=true'
- ];
- if (!empty($server['allow_insecure'])) {
- array_push($config, $server['allow_insecure'] ? 'skip-cert-verify=true' : 'skip-cert-verify=false');
- }
- $config = array_filter($config);
- $uri = implode(',', $config);
- $uri .= "\r\n";
- return $uri;
- }
- }
|