mirror of
				https://github.com/v2board/v2board.git
				synced 2025-11-01 01:41:47 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			126 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers\Client\Protocols;
 | |
| 
 | |
| use App\Utils\Helper;
 | |
| 
 | |
| 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'] === 'vmess') {
 | |
|                 $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)
 | |
|     {
 | |
|         if ($server['cipher'] === '2022-blake3-aes-128-gcm') {
 | |
|             $serverKey = Helper::getServerKey($server['created_at'], 16);
 | |
|             $userKey = Helper::uuidToBase64($password, 16);
 | |
|             $password = "{$serverKey}:{$userKey}";
 | |
|         }
 | |
|         if ($server['cipher'] === '2022-blake3-aes-256-gcm') {
 | |
|             $serverKey = Helper::getServerKey($server['created_at'], 32);
 | |
|             $userKey = Helper::uuidToBase64($password, 32);
 | |
|             $password = "{$serverKey}:{$userKey}";
 | |
|         }
 | |
|         $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' => 0
 | |
|         ];
 | |
|         if ($server['tls']) {
 | |
|             $config['tls'] = 1;
 | |
|             if ($server['tlsSettings']) {
 | |
|                 $tlsSettings = $server['tlsSettings'];
 | |
|                 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 = $server['networkSettings'];
 | |
|                 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 = $server['networkSettings'];
 | |
|                 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;
 | |
|     }
 | |
| }
 |