mirror of
				https://github.com/v2board/v2board.git
				synced 2025-11-04 03:11:46 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Utils;
 | 
						|
 | 
						|
 | 
						|
class Surfboard
 | 
						|
{
 | 
						|
    public static function buildShadowsocks($password, $server)
 | 
						|
    {
 | 
						|
        $config = [
 | 
						|
            "{$server->name}=custom",
 | 
						|
            "{$server->host}",
 | 
						|
            "{$server->port}",
 | 
						|
            "{$server->cipher}",
 | 
						|
            "password={$password}",
 | 
						|
            "https://raw.githubusercontent.com/Hackl0us/proxy-tool-backup/master/SSEncrypt.module",
 | 
						|
            "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=false"
 | 
						|
        ];
 | 
						|
        if ($server->network === 'tcp') {
 | 
						|
            if ($server->tls) {
 | 
						|
                $tlsSettings = json_decode($server->tlsSettings);
 | 
						|
                array_push($config, $server->tls ? 'tls=true' : 'tls=false');
 | 
						|
                if (isset($tlsSettings->allowInsecure)) {
 | 
						|
                    array_push($config, $tlsSettings->allowInsecure ? 'skip-cert-verify=true' : 'skip-cert-verify=false');
 | 
						|
                }
 | 
						|
                if (isset($tlsSettings->serverName)) {
 | 
						|
                    array_push($config, "obfs-host={$tlsSettings->serverName}");
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        if ($server->network === 'ws') {
 | 
						|
            array_push($config, 'ws=true');
 | 
						|
            if ($server->tls) {
 | 
						|
                $tlsSettings = json_decode($server->tlsSettings);
 | 
						|
                array_push($config, $server->tls ? 'tls=true' : 'tls=false');
 | 
						|
                if (isset($tlsSettings->allowInsecure)) {
 | 
						|
                    array_push($config, $tlsSettings->allowInsecure ? 'skip-cert-verify=true' : 'skip-cert-verify=false');
 | 
						|
                }
 | 
						|
            }
 | 
						|
            if ($server->networkSettings) {
 | 
						|
                $wsSettings = json_decode($server->networkSettings);
 | 
						|
                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;
 | 
						|
    }
 | 
						|
}
 |