mirror of
				https://github.com/v2board/v2board.git
				synced 2025-10-31 17:31:49 +08:00 
			
		
		
		
	update: code
This commit is contained in:
		
							
								
								
									
										113
									
								
								app/Http/Controllers/Client/Protocols/Shadowrocket.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								app/Http/Controllers/Client/Protocols/Shadowrocket.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | ||||
| <?php | ||||
|  | ||||
| namespace App\Http\Controllers\Client\Protocols; | ||||
|  | ||||
| class Shadowrocket | ||||
| { | ||||
|     public $flag = 'shadowrocket'; | ||||
|     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 = ''; | ||||
|         //display remaining traffic and expire date | ||||
|         $upload = round($user['u'] / (1024*1024*1024), 2); | ||||
|         $download = round($user['d'] / (1024*1024*1024), 2); | ||||
|         $totalTraffic = round($user['transfer_enable'] / (1024*1024*1024), 2); | ||||
|         $expiredDate = date('Y-m-d', $user['expired_at']); | ||||
|         $uri .= "STATUS=🚀↑:{$upload}GB,↓:{$download}GB,TOT:{$totalTraffic}GB💡Expires:{$expiredDate}\r\n"; | ||||
|         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) | ||||
|     { | ||||
|         $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) | ||||
|     { | ||||
|         $userinfo = base64_encode('auto:' . $uuid . '@' . $server['host'] . ':' . $server['port']); | ||||
|         $config = [ | ||||
|             'tfo' => 1, | ||||
|             'remark' => $server['name'], | ||||
|             'alterId' => $server['alter_id'] | ||||
|         ]; | ||||
|         if ($server['tls']) { | ||||
|             $config['tls'] = 1; | ||||
|             if ($server['tlsSettings']) { | ||||
|                 $tlsSettings = json_decode($server['tlsSettings'], true); | ||||
|                 if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure'])) | ||||
|                     $config['allowInsecure'] = (int)$tlsSettings['allowInsecure']; | ||||
|                 if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName'])) | ||||
|                     $config['peer'] = $tlsSettings['serverName']; | ||||
|             } | ||||
|         } | ||||
|         if ($server['network'] === 'ws') { | ||||
|             $config['obfs'] = "websocket"; | ||||
|             if ($server['networkSettings']) { | ||||
|                 $wsSettings = json_decode($server['networkSettings'], true); | ||||
|                 if (isset($wsSettings['path']) && !empty($wsSettings['path'])) | ||||
|                     $config['path'] = $wsSettings['path']; | ||||
|                 if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host'])) | ||||
|                     $config['obfsParam'] = $wsSettings['headers']['Host']; | ||||
|             } | ||||
|         } | ||||
|         if ($server['network'] === 'grpc') { | ||||
|             $config['obfs'] = "grpc"; | ||||
|             if ($server['networkSettings']) { | ||||
|                 $grpcSettings = json_decode($server['networkSettings'], true); | ||||
|                 if (isset($grpcSettings['serviceName']) && !empty($grpcSettings['serviceName'])) | ||||
|                     $config['path'] = $grpcSettings['serviceName']; | ||||
|             } | ||||
|             if (isset($tlsSettings)) { | ||||
|                 $config['host'] = $tlsSettings['serverName']; | ||||
|             } else { | ||||
|                 $config['host'] = $server['host']; | ||||
|             } | ||||
|         } | ||||
|         $query = http_build_query($config, '', '&', PHP_QUERY_RFC3986); | ||||
|         $uri = "vmess://{$userinfo}?{$query}"; | ||||
|         $uri .= "\r\n"; | ||||
|         return $uri; | ||||
|     } | ||||
|  | ||||
|     public static function buildTrojan($password, $server) | ||||
|     { | ||||
|         $name = rawurlencode($server['name']); | ||||
|         $query = http_build_query([ | ||||
|             'allowInsecure' => $server['allow_insecure'], | ||||
|             'peer' => $server['server_name'] | ||||
|         ]); | ||||
|         $uri = "trojan://{$password}@{$server['host']}:{$server['port']}?{$query}&tfo=1#{$name}"; | ||||
|         $uri .= "\r\n"; | ||||
|         return $uri; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user