mirror of
				https://github.com/v2board/v2board.git
				synced 2025-10-31 09:21:46 +08:00 
			
		
		
		
	update: code
This commit is contained in:
		
							
								
								
									
										116
									
								
								app/Http/Controllers/Client/Protocols/QuantumultX.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								app/Http/Controllers/Client/Protocols/QuantumultX.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | ||||
| <?php | ||||
|  | ||||
| namespace App\Http\Controllers\Client\Protocols; | ||||
|  | ||||
|  | ||||
| class QuantumultX | ||||
| { | ||||
|     public $flag = 'quantumult x'; | ||||
|     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 = ''; | ||||
|         header("subscription-userinfo: upload={$user['u']}; download={$user['d']}; total={$user['transfer_enable']}; expire={$user['expired_at']}"); | ||||
|         foreach ($servers as $item) { | ||||
|             if ($item['type'] === 'shadowsocks') { | ||||
|                 $uri .= self::buildShadowsocks($user['uuid'], $item); | ||||
|             } | ||||
|             if ($item['type'] === 'v2ray') { | ||||
|                 $uri .= self::buildVmess($user['uuid'], $item); | ||||
|             } | ||||
|             if ($item['type'] === 'trojan') { | ||||
|                 $uri .= self::buildTrojan($user['uuid'], $item); | ||||
|             } | ||||
|         } | ||||
|         return base64_encode($uri); | ||||
|     } | ||||
|  | ||||
|     public static function buildShadowsocks($password, $server) | ||||
|     { | ||||
|         $config = [ | ||||
|             "shadowsocks={$server['host']}:{$server['port']}", | ||||
|             "method={$server['cipher']}", | ||||
|             "password={$password}", | ||||
|             'fast-open=true', | ||||
|             'udp-relay=true', | ||||
|             "tag={$server['name']}" | ||||
|         ]; | ||||
|         $config = array_filter($config); | ||||
|         $uri = implode(',', $config); | ||||
|         $uri .= "\r\n"; | ||||
|         return $uri; | ||||
|     } | ||||
|  | ||||
|     public static function buildVmess($uuid, $server) | ||||
|     { | ||||
|         $config = [ | ||||
|             "vmess={$server['host']}:{$server['port']}", | ||||
|             'method=chacha20-poly1305', | ||||
|             "password={$uuid}", | ||||
|             'fast-open=true', | ||||
|             'udp-relay=true', | ||||
|             "tag={$server['name']}" | ||||
|         ]; | ||||
|  | ||||
|         if ($server['tls']) { | ||||
|             if ($server['network'] === 'tcp') | ||||
|                 array_push($config, 'obfs=over-tls'); | ||||
|             if ($server['tlsSettings']) { | ||||
|                 $tlsSettings = json_decode($server['tlsSettings'], true); | ||||
|                 if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) | ||||
|                     array_push($config, 'tls-verification=' . ($tlsSettings['allowInsecure'] ? 'false' : 'true')); | ||||
|                 if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) | ||||
|                     $host = $tlsSettings['serverName']; | ||||
|             } | ||||
|         } | ||||
|         if ($server['network'] === 'ws') { | ||||
|             if ($server['tls']) | ||||
|                 array_push($config, 'obfs=wss'); | ||||
|             else | ||||
|                 array_push($config, 'obfs=ws'); | ||||
|             if ($server['networkSettings']) { | ||||
|                 $wsSettings = json_decode($server['networkSettings'], true); | ||||
|                 if (isset($wsSettings['path']) && !empty($wsSettings['path'])) | ||||
|                     array_push($config, "obfs-uri={$wsSettings['path']}"); | ||||
|                 if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']) && !isset($host)) | ||||
|                     $host = $wsSettings['headers']['Host']; | ||||
|             } | ||||
|         } | ||||
|         if (isset($host)) { | ||||
|             array_push($config, "obfs-host={$host}"); | ||||
|         } | ||||
|  | ||||
|         $uri = implode(',', $config); | ||||
|         $uri .= "\r\n"; | ||||
|         return $uri; | ||||
|     } | ||||
|  | ||||
|     public static function buildTrojan($password, $server) | ||||
|     { | ||||
|         $config = [ | ||||
|             "trojan={$server['host']}:{$server['port']}", | ||||
|             "password={$password}", | ||||
|             'over-tls=true', | ||||
|             $server['server_name'] ? "tls-host={$server['server_name']}" : "", | ||||
|             // Tips: allowInsecure=false = tls-verification=true | ||||
|             $server['allow_insecure'] ? 'tls-verification=false' : 'tls-verification=true', | ||||
|             'fast-open=true', | ||||
|             'udp-relay=true', | ||||
|             "tag={$server['name']}" | ||||
|         ]; | ||||
|         $config = array_filter($config); | ||||
|         $uri = implode(',', $config); | ||||
|         $uri .= "\r\n"; | ||||
|         return $uri; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user