Passwall.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. <?php
  2. namespace App\Http\Controllers\Client\Protocols;
  3. class Passwall
  4. {
  5. public $flag = 'passwall';
  6. private $servers;
  7. private $user;
  8. public function __construct($user, $servers)
  9. {
  10. $this->user = $user;
  11. $this->servers = $servers;
  12. }
  13. public function handle()
  14. {
  15. $servers = $this->servers;
  16. $user = $this->user;
  17. $uri = '';
  18. foreach ($servers as $item) {
  19. if ($item['type'] === 'vmess') {
  20. $uri .= self::buildVmess($user['uuid'], $item);
  21. }
  22. if ($item['type'] === 'shadowsocks') {
  23. $uri .= self::buildShadowsocks($user['uuid'], $item);
  24. }
  25. if ($item['type'] === 'trojan') {
  26. $uri .= self::buildTrojan($user['uuid'], $item);
  27. }
  28. }
  29. return base64_encode($uri);
  30. }
  31. public static function buildShadowsocks($password, $server)
  32. {
  33. $name = rawurlencode($server['name']);
  34. $str = str_replace(
  35. ['+', '/', '='],
  36. ['-', '_', ''],
  37. base64_encode("{$server['cipher']}:{$password}")
  38. );
  39. return "ss://{$str}@{$server['host']}:{$server['port']}#{$name}\r\n";
  40. }
  41. public static function buildVmess($uuid, $server)
  42. {
  43. $config = [
  44. "v" => "2",
  45. "ps" => $server['name'],
  46. "add" => $server['host'],
  47. "port" => (string)$server['port'],
  48. "id" => $uuid,
  49. "aid" => '0',
  50. "net" => $server['network'],
  51. "type" => "none",
  52. "host" => "",
  53. "path" => "",
  54. "tls" => $server['tls'] ? "tls" : "",
  55. ];
  56. if ($server['tls']) {
  57. if ($server['tlsSettings']) {
  58. $tlsSettings = $server['tlsSettings'];
  59. if (isset($tlsSettings['serverName']) && !empty($tlsSettings['serverName']))
  60. $config['sni'] = $tlsSettings['serverName'];
  61. }
  62. }
  63. if ((string)$server['network'] === 'tcp') {
  64. $tcpSettings = $server['networkSettings'];
  65. if (isset($tcpSettings['header']['type'])) $config['type'] = $tcpSettings['header']['type'];
  66. if (isset($tcpSettings['header']['request']['path'][0])) $config['path'] = $tcpSettings['header']['request']['path'][0];
  67. }
  68. if ((string)$server['network'] === 'ws') {
  69. $wsSettings = $server['networkSettings'];
  70. if (isset($wsSettings['path'])) $config['path'] = $wsSettings['path'];
  71. if (isset($wsSettings['headers']['Host'])) $config['host'] = $wsSettings['headers']['Host'];
  72. }
  73. if ((string)$server['network'] === 'grpc') {
  74. $grpcSettings = $server['networkSettings'];
  75. if (isset($grpcSettings['serviceName'])) $config['path'] = $grpcSettings['serviceName'];
  76. }
  77. return "vmess://" . base64_encode(json_encode($config)) . "\r\n";
  78. }
  79. public static function buildTrojan($password, $server)
  80. {
  81. $name = rawurlencode($server['name']);
  82. $query = http_build_query([
  83. 'allowInsecure' => $server['allow_insecure'],
  84. 'peer' => $server['server_name'],
  85. 'sni' => $server['server_name']
  86. ]);
  87. $uri = "trojan://{$password}@{$server['host']}:{$server['port']}?{$query}#{$name}";
  88. $uri .= "\r\n";
  89. return $uri;
  90. }
  91. }