Shadowrocket.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. namespace App\Http\Controllers\Client\Protocols;
  3. use App\Utils\Helper;
  4. class Shadowrocket
  5. {
  6. public $flag = 'shadowrocket';
  7. private $servers;
  8. private $user;
  9. public function __construct($user, $servers)
  10. {
  11. $this->user = $user;
  12. $this->servers = $servers;
  13. }
  14. public function handle()
  15. {
  16. $servers = $this->servers;
  17. $user = $this->user;
  18. $uri = '';
  19. //display remaining traffic and expire date
  20. $upload = round($user['u'] / (1024*1024*1024), 2);
  21. $download = round($user['d'] / (1024*1024*1024), 2);
  22. $totalTraffic = round($user['transfer_enable'] / (1024*1024*1024), 2);
  23. $expiredDate = date('Y-m-d', $user['expired_at']);
  24. $uri .= "STATUS=🚀↑:{$upload}GB,↓:{$download}GB,TOT:{$totalTraffic}GB💡Expires:{$expiredDate}\r\n";
  25. foreach ($servers as $item) {
  26. if ($item['type'] === 'shadowsocks') {
  27. $uri .= self::buildShadowsocks($user['uuid'], $item);
  28. }
  29. if ($item['type'] === 'v2ray') {
  30. $uri .= self::buildVmess($user['uuid'], $item);
  31. }
  32. if ($item['type'] === 'trojan') {
  33. $uri .= self::buildTrojan($user['uuid'], $item);
  34. }
  35. }
  36. return base64_encode($uri);
  37. }
  38. public static function buildShadowsocks($password, $server)
  39. {
  40. if ($server['cipher'] === '2022-blake3-aes-128-gcm') {
  41. $serverKey = Helper::getShadowsocksServerKey($server['created_at'], 16);
  42. $userKey = Helper::uuidToBase64($password, 16);
  43. $password = "{$serverKey}:{$userKey}";
  44. }
  45. if ($server['cipher'] === '2022-blake3-aes-256-gcm') {
  46. $serverKey = Helper::getShadowsocksServerKey($server['created_at'], 32);
  47. $userKey = Helper::uuidToBase64($password, 32);
  48. $password = "{$serverKey}:{$userKey}";
  49. }
  50. $name = rawurlencode($server['name']);
  51. $str = str_replace(
  52. ['+', '/', '='],
  53. ['-', '_', ''],
  54. base64_encode("{$server['cipher']}:{$password}")
  55. );
  56. return "ss://{$str}@{$server['host']}:{$server['port']}#{$name}\r\n";
  57. }
  58. public static function buildVmess($uuid, $server)
  59. {
  60. $userinfo = base64_encode('auto:' . $uuid . '@' . $server['host'] . ':' . $server['port']);
  61. $config = [
  62. 'tfo' => 1,
  63. 'remark' => $server['name'],
  64. 'alterId' => 0
  65. ];
  66. if ($server['tls']) {
  67. $config['tls'] = 1;
  68. if ($server['tlsSettings']) {
  69. $tlsSettings = $server['tlsSettings'];
  70. if (isset($tlsSettings['allowInsecure']) && !empty($tlsSettings['allowInsecure']))
  71. $config['allowInsecure'] = (int)$tlsSettings['allowInsecure'];
  72. if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
  73. $config['peer'] = $tlsSettings['serverName'];
  74. }
  75. }
  76. if ($server['network'] === 'ws') {
  77. $config['obfs'] = "websocket";
  78. if ($server['networkSettings']) {
  79. $wsSettings = $server['networkSettings'];
  80. if (isset($wsSettings['path']) && !empty($wsSettings['path']))
  81. $config['path'] = $wsSettings['path'];
  82. if (isset($wsSettings['headers']['Host']) && !empty($wsSettings['headers']['Host']))
  83. $config['obfsParam'] = $wsSettings['headers']['Host'];
  84. }
  85. }
  86. if ($server['network'] === 'grpc') {
  87. $config['obfs'] = "grpc";
  88. if ($server['networkSettings']) {
  89. $grpcSettings = $server['networkSettings'];
  90. if (isset($grpcSettings['serviceName']) && !empty($grpcSettings['serviceName']))
  91. $config['path'] = $grpcSettings['serviceName'];
  92. }
  93. if (isset($tlsSettings)) {
  94. $config['host'] = $tlsSettings['serverName'];
  95. } else {
  96. $config['host'] = $server['host'];
  97. }
  98. }
  99. $query = http_build_query($config, '', '&', PHP_QUERY_RFC3986);
  100. $uri = "vmess://{$userinfo}?{$query}";
  101. $uri .= "\r\n";
  102. return $uri;
  103. }
  104. public static function buildTrojan($password, $server)
  105. {
  106. $name = rawurlencode($server['name']);
  107. $query = http_build_query([
  108. 'allowInsecure' => $server['allow_insecure'],
  109. 'peer' => $server['server_name']
  110. ]);
  111. $uri = "trojan://{$password}@{$server['host']}:{$server['port']}?{$query}&tfo=1#{$name}";
  112. $uri .= "\r\n";
  113. return $uri;
  114. }
  115. }