Browse Source

Shadowrocket specified url generator

shadowrocket ClientController

enable tfo on vmess for shadowrocket

enable tfo on trojan for shadowrocket

fix typo
phlinhng 4 years ago
parent
commit
84d852f396
2 changed files with 61 additions and 0 deletions
  1. 18 0
      app/Http/Controllers/Client/ClientController.php
  2. 43 0
      app/Utils/Shadowrocket.php

+ 18 - 0
app/Http/Controllers/Client/ClientController.php

@@ -6,6 +6,7 @@ use App\Http\Controllers\Controller;
 use App\Services\ServerService;
 use App\Utils\Clash;
 use App\Utils\QuantumultX;
+use App\Utils\Shadowrocket;
 use App\Utils\Surge;
 use Illuminate\Http\Request;
 use App\Models\Server;
@@ -41,6 +42,9 @@ class ClientController extends Controller
                 if (strpos($_SERVER['HTTP_USER_AGENT'], 'surge') !== false) {
                     die($this->surge($user, $servers['vmess'], $servers['trojan']));
                 }
+                if (strpos($_SERVER['HTTP_USER_AGENT'], 'shadowrocket') !== false) {
+                    die($this->shadowrocket($user, $servers['vmess'], $servers['trojan']));
+                }
             }
             die($this->origin($user, $servers['vmess'], $servers['trojan']));
         }
@@ -66,6 +70,20 @@ class ClientController extends Controller
         return base64_encode($uri);
     }
 
+    private function shadowrocket($user, $vmess = [], $trojan = [])
+    {
+        $uri = '';
+        //TODO: display remaining traffic and expire date
+        //$uri .= 'STATUS=' . 'Traffic:' . 'Expiry:' . '\r\n';
+        foreach ($vmess as $item) {
+            $uri .= Shadowrocket::buildVmess($user->uuid, $item);
+        }
+        foreach ($trojan as $item) {
+            $uri .= Shadowrocket::buildTrojan($user->uuid, $item);
+        }
+        return base64_encode($uri);
+    }
+
     private function quantumultX($user, $vmess = [], $trojan = [])
     {
         $uri = '';

+ 43 - 0
app/Utils/Shadowrocket.php

@@ -0,0 +1,43 @@
+<?php
+
+namespace App\Utils;
+
+
+class Shadowrocket
+{
+    public static function buildVmess($uuid, $server)
+    {
+        $userinfo = base64_encode('auto:' . $uuid . '@' . $server->host . ':' . $server->port);
+        $config = [
+            'remark' => $server->name
+        ];
+        if ($server->tls) {
+            $tlsSettings = json_decode($server->tlsSettings);
+            $config['tls'] = 1;
+            if (isset($tlsSettings->serverName)) $config['peer'] = $tlsSettings->serverName;
+            if (isset($tlsSettings->allowInsecure)) $config['allowInsecure'] = 1;
+        }
+        if ($server->network === 'ws') {
+            $wsSettings = json_decode($server->networkSettings);
+            $config['obfs'] = "websocket";
+            if (isset($wsSettings->path)) $config['path'] = $wsSettings->path;
+            if (isset($wsSettings->headers->Host)) $config['obfsParam'] = $wsSettings->headers->Host;
+        }
+        $query = http_build_query($config);
+        $uri = "vmess://{$userinfo}?{$query}&tfo=1";
+        $uri .= "\r\n";
+        return $uri;
+    }
+
+    public static function buildTrojan($password, $server)
+    {
+        $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#{$server->name}";
+        $uri .= "\r\n";
+        return $uri;
+    }
+}