mirror of
				https://github.com/v2board/v2board.git
				synced 2025-11-04 19:31:45 +08:00 
			
		
		
		
	update: reconsitution
This commit is contained in:
		
							
								
								
									
										104
									
								
								app/Protocols/SagerNet.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								app/Protocols/SagerNet.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,104 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
namespace App\Protocols;
 | 
			
		||||
 | 
			
		||||
class SagerNet
 | 
			
		||||
{
 | 
			
		||||
    public $flag = 'sagernet';
 | 
			
		||||
    private $servers;
 | 
			
		||||
    private $user;
 | 
			
		||||
 | 
			
		||||
    public function __construct($user, $servers)
 | 
			
		||||
    {
 | 
			
		||||
        $this->user = $user;
 | 
			
		||||
        $this->servers = $servers;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function handle()
 | 
			
		||||
    {
 | 
			
		||||
        $servers = $this->servers;
 | 
			
		||||
        $user = $this->user;
 | 
			
		||||
        $uri = '';
 | 
			
		||||
 | 
			
		||||
        foreach ($servers as $item) {
 | 
			
		||||
            if ($item['type'] === 'vmess') {
 | 
			
		||||
                $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);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function buildShadowsocks($uuid, $server)
 | 
			
		||||
    {
 | 
			
		||||
        $name = rawurlencode($server['name']);
 | 
			
		||||
        $str = str_replace(
 | 
			
		||||
            ['+', '/', '='],
 | 
			
		||||
            ['-', '_', ''],
 | 
			
		||||
            base64_encode("{$server['cipher']}:{$uuid}")
 | 
			
		||||
        );
 | 
			
		||||
        return "ss://{$str}@{$server['host']}:{$server['port']}#{$name}\r\n";
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function buildShadowsocksSIP008($uuid, $server)
 | 
			
		||||
    {
 | 
			
		||||
        $config = [
 | 
			
		||||
            "id" => $server['id'],
 | 
			
		||||
            "remarks" => $server['name'],
 | 
			
		||||
            "server" => $server['host'],
 | 
			
		||||
            "server_port" => $server['port'],
 | 
			
		||||
            "password" => $uuid,
 | 
			
		||||
            "method" => $server['cipher']
 | 
			
		||||
        ];
 | 
			
		||||
        return $config;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function buildVmess($uuid, $server)
 | 
			
		||||
    {
 | 
			
		||||
        $config = [
 | 
			
		||||
            "encryption" => "none",
 | 
			
		||||
            "type" => urlencode($server['network']),
 | 
			
		||||
            "security" => $server['tls'] ? "tls" : "",
 | 
			
		||||
        ];
 | 
			
		||||
        if ($server['tls']) {
 | 
			
		||||
            if ($server['tlsSettings']) {
 | 
			
		||||
                $tlsSettings = $server['tlsSettings'];
 | 
			
		||||
                if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
 | 
			
		||||
                    $config['sni'] = urlencode($tlsSettings['serverName']);
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        if ((string)$server['network'] === 'tcp') {
 | 
			
		||||
            $tcpSettings = $server['networkSettings'];
 | 
			
		||||
            if (isset($tcpSettings['header']['type'])) $config['type'] = $tcpSettings['header']['type'];
 | 
			
		||||
            if (isset($tcpSettings['header']['request']['path'][0])) $config['path'] = $tcpSettings['header']['request']['path'][0];
 | 
			
		||||
        }
 | 
			
		||||
        if ((string)$server['network'] === 'ws') {
 | 
			
		||||
            $wsSettings = $server['networkSettings'];
 | 
			
		||||
            if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
 | 
			
		||||
            if (isset($wsSettings['headers']['Host'])) $config['host'] = urlencode($wsSettings['headers']['Host']);
 | 
			
		||||
        }
 | 
			
		||||
        if ((string)$server['network'] === 'grpc') {
 | 
			
		||||
            $grpcSettings = $server['networkSettings'];
 | 
			
		||||
            if (isset($grpcSettings['serviceName'])) $config['serviceName'] = urlencode($grpcSettings['serviceName']);
 | 
			
		||||
        }
 | 
			
		||||
        return "vmess://" . $uuid . "@" . $server['host'] . ":" . $server['port'] . "?" . http_build_query($config) . "#" . urlencode($server['name']) . "\r\n";
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function buildTrojan($uuid, $server)
 | 
			
		||||
    {
 | 
			
		||||
        $name = rawurlencode($server['name']);
 | 
			
		||||
        $query = http_build_query([
 | 
			
		||||
            'allowInsecure' => $server['allow_insecure'],
 | 
			
		||||
            'peer' => $server['server_name'],
 | 
			
		||||
            'sni' => $server['server_name']
 | 
			
		||||
        ]);
 | 
			
		||||
        $uri = "trojan://{$uuid}@{$server['host']}:{$server['port']}?{$query}#{$name}";
 | 
			
		||||
        $uri .= "\r\n";
 | 
			
		||||
        return $uri;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user