ssrurl.htm 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  1. <%+cbi/valueheader%>
  2. <script type="text/javascript">
  3. //<![CDATA[
  4. function padright(str, cnt, pad) {
  5. return str + Array(cnt + 1).join(pad);
  6. }
  7. function b64EncodeUnicode(str) {
  8. return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function (match, p1) {
  9. return String.fromCharCode('0x' + p1);
  10. }));
  11. }
  12. function b64encutf8safe(str) {
  13. return b64EncodeUnicode(str).replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/g, '');
  14. }
  15. function b64DecodeUnicode(str) {
  16. return decodeURIComponent(Array.prototype.map.call(atob(str), function (c) {
  17. return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
  18. }).join(''));
  19. }
  20. function b64decutf8safe(str) {
  21. var l;
  22. str = str.replace(/-/g, "+").replace(/_/g, "/");
  23. l = str.length;
  24. l = (4 - l % 4) % 4;
  25. if (l) str = padright(str, l, "=");
  26. return b64DecodeUnicode(str);
  27. }
  28. function b64encsafe(str) {
  29. return btoa(str).replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/g, '')
  30. }
  31. function b64decsafe(str) {
  32. var l;
  33. str = str.replace(/-/g, "+").replace(/_/g, "/");
  34. l = str.length;
  35. l = (4 - l % 4) % 4;
  36. if (l) str = padright(str, l, "=");
  37. return atob(str);
  38. }
  39. function dictvalue(d, key) {
  40. var v = d[key];
  41. if (typeof (v) == 'undefined' || v == '') return '';
  42. return b64decsafe(v);
  43. }
  44. function export_ssr_url(btn, urlname, sid) {
  45. var s = document.getElementById(urlname + '-status');
  46. if (!s) return false;
  47. var v_server = document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0];
  48. var v_port = document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0];
  49. var v_protocol = document.getElementsByName('cbid.shadowsocksr.' + sid + '.protocol')[0];
  50. var v_method = document.getElementsByName('cbid.shadowsocksr.' + sid + '.encrypt_method')[0];
  51. var v_obfs = document.getElementsByName('cbid.shadowsocksr.' + sid + '.obfs')[0];
  52. var v_password = document.getElementsByName('cbid.shadowsocksr.' + sid + '.password')[0];
  53. var v_obfs_param = document.getElementsByName('cbid.shadowsocksr.' + sid + '.obfs_param')[0];
  54. var v_protocol_param = document.getElementsByName('cbid.shadowsocksr.' + sid + '.protocol_param')[0];
  55. var v_alias = document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0];
  56. var ssr_str = v_server.value + ":" + v_port.value + ":" + v_protocol.value + ":" + v_method.value + ":" + v_obfs.value + ":" + b64encsafe(v_password.value) + "/?obfsparam=" + b64encsafe(v_obfs_param.value) + "&protoparam=" + b64encsafe(v_protocol_param.value) + "&remarks=" + b64encutf8safe(v_alias.value);
  57. var textarea = document.createElement("textarea");
  58. textarea.textContent = "ssr://" + b64encsafe(ssr_str);
  59. textarea.style.position = "fixed";
  60. document.body.appendChild(textarea);
  61. textarea.select();
  62. try {
  63. document.execCommand("copy"); // Security exception may be thrown by some browsers.
  64. s.innerHTML = "<font style=\'color:green\'><%:Copy SSR to clipboard successfully.%></font>";
  65. } catch (ex) {
  66. s.innerHTML = "<font style=\'color:red\'><%:Unable to copy SSR to clipboard.%></font>";
  67. } finally {
  68. document.body.removeChild(textarea);
  69. }
  70. return false;
  71. }
  72. function import_ssr_url(btn, urlname, sid) {
  73. var s = document.getElementById(urlname + '-status');
  74. if (!s) return false;
  75. var ssrurl = prompt("<%:Paste sharing link here%>", "");
  76. if (ssrurl == null || ssrurl == "") {
  77. s.innerHTML = "<font style=\'color:red\'><%:User cancelled.%></font>";
  78. return false;
  79. }
  80. s.innerHTML = "";
  81. //var ssu = ssrurl.match(/ssr:\/\/([A-Za-z0-9_-]+)/i);
  82. var ssu = ssrurl.split('://');
  83. //console.log(ssu.length);
  84. var event = document.createEvent("HTMLEvents");
  85. event.initEvent("change", true, true);
  86. switch (ssu[0]) {
  87. case "hysteria":
  88. try {
  89. var url = new URL("http://" + ssu[1]);
  90. var params = url.searchParams;
  91. } catch(e) {
  92. alert(e);
  93. return false;
  94. }
  95. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = ssu[0];
  96. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  97. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = url.hostname;
  98. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = url.port || "80";
  99. document.getElementsByName('cbid.shadowsocksr.' + sid + '.hysteria_protocol')[0].value = params.get("protocol") || "udp";
  100. document.getElementsByName('cbid.shadowsocksr.' + sid + '.auth_type')[0].value = params.get("auth") ? "2" : "0";
  101. document.getElementsByName('cbid.shadowsocksr.' + sid + '.auth_type')[0].dispatchEvent(event);
  102. document.getElementsByName('cbid.shadowsocksr.' + sid + '.auth_payload')[0].value = params.get("auth") || "";
  103. document.getElementsByName('cbid.shadowsocksr.' + sid + '.uplink_capacity')[0].value = params.get("upmbps") || "";
  104. document.getElementsByName('cbid.shadowsocksr.' + sid + '.downlink_capacity')[0].value = params.get("downmbps") || "";
  105. document.getElementsByName('cbid.shadowsocksr.' + sid + '.seed')[0].value = params.get("obfsParam") || "";
  106. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls_host')[0].value = params.get("peer") || "";
  107. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_tls_alpn')[0].value = params.get("alpn") || "";
  108. document.getElementsByName('cbid.shadowsocksr.' + sid + '.insecure')[0].checked = params.get("insecure") ? true : false;
  109. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = url.hash ? decodeURIComponent(url.hash.slice(1)) : "";
  110. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  111. return false;
  112. case "ss":
  113. var url0, param = "";
  114. var sipIndex = ssu[1].indexOf("@");
  115. var ploc = ssu[1].indexOf("#");
  116. if (ploc > 0) {
  117. url0 = ssu[1].substr(0, ploc);
  118. param = ssu[1].substr(ploc + 1);
  119. } else {
  120. url0 = ssu[1];
  121. }
  122. if (sipIndex != -1) {
  123. // SIP002
  124. var userInfo = b64decsafe(url0.substr(0, sipIndex));
  125. var temp = url0.substr(sipIndex + 1).split("/?");
  126. var serverInfo = temp[0].split(":");
  127. var server = serverInfo[0];
  128. var port = serverInfo[1].replace("/","");
  129. var method, password, enable_plugin, plugin, pluginOpts;
  130. if (temp[1]) {
  131. var pluginInfo = decodeURIComponent(temp[1]);
  132. // 使用正則匹配 plugin 參數
  133. var pluginNameInfo = pluginInfo.match(/plugin=([^&]+)/);
  134. if (pluginNameInfo) {
  135. var pluginParams = pluginNameInfo[1].split(";");
  136. plugin = pluginParams.shift(); // 获取 plugin
  137. pluginOpts = pluginParams.length > 0 ? pluginParams.join(";") : "";
  138. }
  139. }
  140. var userInfoSplitIndex = userInfo.indexOf(":");
  141. if (userInfoSplitIndex != -1) {
  142. method = userInfo.substr(0, userInfoSplitIndex);
  143. password = userInfo.substr(userInfoSplitIndex + 1);
  144. }
  145. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = ssu[0];
  146. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  147. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = server;
  148. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = port;
  149. document.getElementsByName('cbid.shadowsocksr.' + sid + '.password')[0].value = password || "";
  150. document.getElementsByName('cbid.shadowsocksr.' + sid + '.encrypt_method_ss')[0].value = method || "";
  151. if (plugin && plugin !== "none") {
  152. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_plugin')[0].checked = true; // 设置 enable_plugin 为 true
  153. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_plugin')[0].dispatchEvent(event); // 触发事件
  154. document.getElementsByName('cbid.shadowsocksr.' + sid + '.plugin')[0].value = plugin || "none";
  155. document.getElementsByName('cbid.shadowsocksr.' + sid + '.plugin')[0].dispatchEvent(event);
  156. if (plugin !== undefined) {
  157. document.getElementsByName('cbid.shadowsocksr.' + sid + '.plugin_opts')[0].value = pluginOpts || "";
  158. }
  159. } else {
  160. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_plugin')[0].checked = false;
  161. }
  162. if (param !== undefined) {
  163. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = decodeURI(param);
  164. }
  165. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  166. } else {
  167. var sstr = b64decsafe(url0);
  168. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = ssu[0];
  169. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  170. var team = sstr.split('@');
  171. var part1 = team[0].split(':');
  172. var part2 = team[1].split(':');
  173. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = part2[0];
  174. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = part2[1];
  175. document.getElementsByName('cbid.shadowsocksr.' + sid + '.password')[0].value = part1[1];
  176. document.getElementsByName('cbid.shadowsocksr.' + sid + '.encrypt_method_ss')[0].value = part1[0];
  177. if (param != undefined) {
  178. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = decodeURI(param);
  179. }
  180. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  181. }
  182. return false;
  183. case "ssr":
  184. var sstr = b64decsafe(ssu[1]);
  185. var ploc = sstr.indexOf("/?");
  186. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = ssu[0];
  187. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  188. var url0, param = "";
  189. if (ploc > 0) {
  190. url0 = sstr.substr(0, ploc);
  191. param = sstr.substr(ploc + 2);
  192. }
  193. var ssm = url0.match(/^(.+):([^:]+):([^:]*):([^:]+):([^:]*):([^:]+)/);
  194. if (!ssm || ssm.length < 7) return false;
  195. var pdict = {};
  196. if (param.length > 2) {
  197. var a = param.split('&');
  198. for (var i = 0; i < a.length; i++) {
  199. var b = a[i].split('=');
  200. pdict[decodeURIComponent(b[0])] = decodeURIComponent(b[1] || '');
  201. }
  202. }
  203. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = ssm[1];
  204. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = ssm[2];
  205. document.getElementsByName('cbid.shadowsocksr.' + sid + '.protocol')[0].value = ssm[3];
  206. document.getElementsByName('cbid.shadowsocksr.' + sid + '.encrypt_method')[0].value = ssm[4];
  207. document.getElementsByName('cbid.shadowsocksr.' + sid + '.obfs')[0].value = ssm[5];
  208. document.getElementsByName('cbid.shadowsocksr.' + sid + '.password')[0].value = b64decsafe(ssm[6]);
  209. document.getElementsByName('cbid.shadowsocksr.' + sid + '.obfs_param')[0].value = dictvalue(pdict, 'obfsparam');
  210. document.getElementsByName('cbid.shadowsocksr.' + sid + '.protocol_param')[0].value = dictvalue(pdict, 'protoparam');
  211. var rem = pdict['remarks'];
  212. if (typeof (rem) != 'undefined' && rem != '' && rem.length > 0) document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = b64decutf8safe(rem);
  213. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  214. return false;
  215. case "trojan":
  216. try {
  217. var url = new URL("http://" + ssu[1]);
  218. var params = url.searchParams;
  219. } catch(e) {
  220. alert(e);
  221. return false;
  222. }
  223. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = url.hash ? decodeURIComponent(url.hash.slice(1)) : "";
  224. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = "v2ray";
  225. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  226. document.getElementsByName('cbid.shadowsocksr.' + sid + '.v2ray_protocol')[0].value = "trojan";
  227. document.getElementsByName('cbid.shadowsocksr.' + sid + '.v2ray_protocol')[0].dispatchEvent(event);
  228. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = url.hostname;
  229. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = url.port || "80";
  230. document.getElementsByName('cbid.shadowsocksr.' + sid + '.password')[0].value = decodeURIComponent(url.username);
  231. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls')[0].checked = true;
  232. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls')[0].dispatchEvent(event);
  233. document.getElementsByName('cbid.shadowsocksr.' + sid + '.fingerprint')[0].value = params.get("fp") || "";
  234. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls_host')[0].value = params.get("sni");
  235. if (params.get("allowInsecure") === "1") {
  236. document.getElementsByName('cbid.shadowsocksr.' + sid + '.insecure')[0].checked = true; // 设置 insecure 为 true
  237. document.getElementsByName('cbid.shadowsocksr.' + sid + '.insecure')[0].dispatchEvent(event); // 触发事件
  238. }
  239. document.getElementsByName('cbid.shadowsocksr.' + sid + '.transport')[0].value =
  240. params.get("type") == "http" ? "h2" :
  241. (["tcp", "raw"].includes(params.get("type")) ? "raw" :
  242. (params.get("type") || "raw"));
  243. document.getElementsByName('cbid.shadowsocksr.' + sid + '.transport')[0].dispatchEvent(event);
  244. switch (params.get("type")) {
  245. case "ws":
  246. if (params.get("security") !== "tls") {
  247. setElementValue('cbid.shadowsocksr.' + sid + '.ws_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  248. }
  249. setElementValue('cbid.shadowsocksr.' + sid + '.ws_path', params.get("path") ? decodeURIComponent(params.get("path")) : "/");
  250. break;
  251. case "httpupgrade":
  252. if (params.get("security") !== "tls") {
  253. document.getElementsByName('cbid.shadowsocksr.' + sid + '.httpupgrade_host')[0].value = params.get("host") ? decodeURIComponent(params.get("host")) : "";
  254. }
  255. document.getElementsByName('cbid.shadowsocksr.' + sid + '.httpupgrade_path')[0].value = params.get("path") ? decodeURIComponent(params.get("path")) : "/";
  256. break;
  257. case "splithttp":
  258. if (params.get("security") !== "tls") {
  259. document.getElementsByName('cbid.shadowsocksr.' + sid + '.splithttp_host')[0].value = params.get("host") ? decodeURIComponent(params.get("host")) : "";
  260. }
  261. document.getElementsByName('cbid.shadowsocksr.' + sid + '.splithttp_path')[0].value = params.get("path") ? decodeURIComponent(params.get("path")) : "/";
  262. break;
  263. case "xhttp":
  264. if (params.get("security") !== "tls") {
  265. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_host')[0].value = params.get("host") ? decodeURIComponent(params.get("host")) : "";
  266. }
  267. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_mode')[0].value = params.get("mode") || "auto";
  268. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_path')[0].value = params.get("path") ? decodeURIComponent(params.get("path")) : "/";
  269. if (params.get("extra") && params.get("extra").trim() !== "") {
  270. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra')[0].checked = true; // 设置 enable_xhttp_extra 为 true
  271. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra')[0].dispatchEvent(event); // 触发事件
  272. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_extra')[0].value = params.get("extra") || "";
  273. }
  274. break;
  275. case "kcp":
  276. document.getElementsByName('cbid.shadowsocksr.' + sid + '.kcp_guise')[0].value = params.get("headerType") || "none";
  277. document.getElementsByName('cbid.shadowsocksr.' + sid + '.seed')[0].value = params.get("seed") || "";
  278. break;
  279. case "http":
  280. /* this is non-standard, bullshit */
  281. case "h2":
  282. document.getElementsByName('cbid.shadowsocksr.' + sid + '.h2_host')[0].value = params.get("host") ? decodeURIComponent(params.get("host")) : "";
  283. document.getElementsByName('cbid.shadowsocksr.' + sid + '.h2_path')[0].value = params.get("path") ? decodeURIComponent(params.get("path")) : "";
  284. break;
  285. case "quic":
  286. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_guise')[0].value = params.get("headerType") || "none";
  287. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_security')[0].value = params.get("quicSecurity") || "none";
  288. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_key')[0].value = params.get("key") || "";
  289. break;
  290. case "grpc":
  291. document.getElementsByName('cbid.shadowsocksr.' + sid + '.serviceName')[0].value = params.get("serviceName") || "";
  292. document.getElementsByName('cbid.shadowsocksr.' + sid + '.grpc_mode')[0].value = params.get("mode") || "gun";
  293. break;
  294. case "raw":
  295. case "tcp":
  296. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tcp_guise')[0].value = params.get("headerType") || "none";
  297. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tcp_guise')[0].dispatchEvent(event);
  298. if (params.get("headerType") === "http") {
  299. document.getElementsByName('cbid.shadowsocksr.' + sid + '.http_host')[0].value = params.get("host") ? decodeURIComponent(params.get("host")) : "";
  300. document.getElementsByName('cbid.shadowsocksr.' + sid + '.http_path')[0].value = params.get("path") ? decodeURIComponent(params.get("path")) : "";
  301. }
  302. break;
  303. }
  304. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  305. return false;
  306. case "vmess":
  307. var sstr = b64DecodeUnicode(ssu[1]);
  308. var ploc = sstr.indexOf("/?");
  309. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].value = "v2ray";
  310. document.getElementsByName('cbid.shadowsocksr.' + sid + '.type')[0].dispatchEvent(event);
  311. document.getElementsByName('cbid.shadowsocksr.' + sid + '.v2ray_protocol')[0].value = "vmess";
  312. document.getElementsByName('cbid.shadowsocksr.' + sid + '.v2ray_protocol')[0].dispatchEvent(event);
  313. var url0, param = "";
  314. if (ploc > 0) {
  315. url0 = sstr.substr(0, ploc);
  316. param = sstr.substr(ploc + 2);
  317. }
  318. var ssm = JSON.parse(sstr);
  319. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alias')[0].value = ssm.ps;
  320. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server')[0].value = ssm.add;
  321. document.getElementsByName('cbid.shadowsocksr.' + sid + '.server_port')[0].value = ssm.port;
  322. document.getElementsByName('cbid.shadowsocksr.' + sid + '.alter_id')[0].value = ssm.aid;
  323. document.getElementsByName('cbid.shadowsocksr.' + sid + '.vmess_id')[0].value = ssm.id;
  324. document.getElementsByName('cbid.shadowsocksr.' + sid + '.transport')[0].value =
  325. (ssm.net === "raw" || ssm.net === "tcp") ? "raw" : ssm.net;
  326. document.getElementsByName('cbid.shadowsocksr.' + sid + '.transport')[0].dispatchEvent(event);
  327. if (ssm.net === "raw" || ssm.net === "tcp") {
  328. if (ssm.type && ssm.type != "http") {
  329. ssm.type = "none";
  330. } else {
  331. document.getElementsByName('cbid.shadowsocksr.' + sid + '.http_host')[0].value = ssm.host;
  332. document.getElementsByName('cbid.shadowsocksr.' + sid + '.http_path')[0].value = ssm.path;
  333. }
  334. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tcp_guise')[0].value = ssm.type;
  335. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tcp_guise')[0].dispatchEvent(event);
  336. }
  337. if (ssm.net == "ws") {
  338. document.getElementsByName('cbid.shadowsocksr.' + sid + '.ws_host')[0].value = ssm.host;
  339. document.getElementsByName('cbid.shadowsocksr.' + sid + '.ws_path')[0].value = ssm.path;
  340. }
  341. if (ssm.net == "httpupgrade") {
  342. document.getElementsByName('cbid.shadowsocksr.' + sid + '.httpupgrade_host')[0].value = ssm.host;
  343. document.getElementsByName('cbid.shadowsocksr.' + sid + '.httpupgrade_path')[0].value = ssm.path;
  344. }
  345. if (ssm.net == "splithttp") {
  346. document.getElementsByName('cbid.shadowsocksr.' + sid + '.splithttp_host')[0].value = ssm.host;
  347. document.getElementsByName('cbid.shadowsocksr.' + sid + '.splithttp_path')[0].value = ssm.path;
  348. }
  349. if (ssm.net == "xhttp") {
  350. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_mode')[0].value = ssm.mode;
  351. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_host')[0].value = ssm.host;
  352. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_path')[0].value = ssm.path;
  353. if (params.get("extra") && params.get("extra").trim() !== "") {
  354. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra')[0].checked = true; // 设置 enable_xhttp_extra 为 true
  355. document.getElementsByName('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra')[0].dispatchEvent(event); // 触发事件
  356. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_extra')[0].value = ssm.extra;
  357. }
  358. }
  359. if (ssm.net == "h2") {
  360. document.getElementsByName('cbid.shadowsocksr.' + sid + '.h2_host')[0].value = ssm.host;
  361. document.getElementsByName('cbid.shadowsocksr.' + sid + '.h2_path')[0].value = ssm.path;
  362. }
  363. if (ssm.net == "quic") {
  364. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_security')[0].value = ssm.securty;
  365. document.getElementsByName('cbid.shadowsocksr.' + sid + '.quic_key')[0].value = ssm.key;
  366. }
  367. if (ssm.net == "kcp") {
  368. document.getElementsByName('cbid.shadowsocksr.' + sid + '.kcp_guise')[0].value = ssm.type;
  369. }
  370. if (ssm.tls == "tls") {
  371. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls')[0].checked = true;
  372. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls')[0].dispatchEvent(event);
  373. document.getElementsByName('cbid.shadowsocksr.' + sid + '.fingerprint')[0].value = ssm.fp;
  374. if (ssm.net == "xhttp") {
  375. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xhttp_alpn')[0].value = ssm.alpn;
  376. }
  377. document.getElementsByName('cbid.shadowsocksr.' + sid + '.tls_host')[0].value = ssm.sni || ssm.host;
  378. }
  379. if (ssm.mux !== undefined) {
  380. document.getElementsByName('cbid.shadowsocksr.' + sid + '.mux')[0].checked = true;
  381. document.getElementsByName('cbid.shadowsocksr.' + sid + '.mux')[0].dispatchEvent(event);
  382. }
  383. if (ssm.xmux !== undefined) {
  384. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xmux')[0].checked = true;
  385. document.getElementsByName('cbid.shadowsocksr.' + sid + '.xmux')[0].dispatchEvent(event);
  386. }
  387. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  388. return false;
  389. case "vless":
  390. try {
  391. var url = new URL("http://" + ssu[1]);
  392. var params = url.searchParams;
  393. } catch(e) {
  394. alert(e);
  395. return false;
  396. }
  397. // Check if the elements exist before trying to modify them
  398. function setElementValue(name, value) {
  399. const element = document.getElementsByName(name)[0];
  400. if (element) {
  401. if (element.type === "checkbox" || element.type === "radio") {
  402. element.checked = value === true;
  403. } else {
  404. element.value = value;
  405. }
  406. }
  407. }
  408. function dispatchEventIfExists(name, event) {
  409. const element = document.getElementsByName(name)[0];
  410. if (element) {
  411. element.dispatchEvent(event);
  412. }
  413. }
  414. setElementValue('cbid.shadowsocksr.' + sid + '.alias', url.hash ? decodeURIComponent(url.hash.slice(1)) : "");
  415. setElementValue('cbid.shadowsocksr.' + sid + '.type', "v2ray");
  416. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.type', event);
  417. setElementValue('cbid.shadowsocksr.' + sid + '.v2ray_protocol', "vless");
  418. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.v2ray_protocol', event);
  419. setElementValue('cbid.shadowsocksr.' + sid + '.server', url.hostname);
  420. setElementValue('cbid.shadowsocksr.' + sid + '.server_port', url.port || "80");
  421. setElementValue('cbid.shadowsocksr.' + sid + '.vmess_id', url.username);
  422. setElementValue('cbid.shadowsocksr.' + sid + '.transport',
  423. params.get("type") === "http" ? "h2" :
  424. (["tcp", "raw"].includes(params.get("type")) ? "raw" :
  425. (params.get("type") || "tcp"))
  426. );
  427. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.transport', event);
  428. setElementValue('cbid.shadowsocksr.' + sid + '.vless_encryption', params.get("encryption") || "none");
  429. if ([ "tls", "xtls", "reality" ].includes(params.get("security"))) {
  430. setElementValue('cbid.shadowsocksr.' + sid + '.' + params.get("security"), true);
  431. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.' + params.get("security"), event);
  432. if (params.get("security") === "reality") {
  433. setElementValue('cbid.shadowsocksr.' + sid + '.reality_publickey', params.get("pbk") ? decodeURIComponent(params.get("pbk")) : "");
  434. setElementValue('cbid.shadowsocksr.' + sid + '.reality_shortid', params.get("sid") || "");
  435. setElementValue('cbid.shadowsocksr.' + sid + '.reality_spiderx', params.get("spx") ? decodeURIComponent(params.get("spx")) : "");
  436. }
  437. setElementValue('cbid.shadowsocksr.' + sid + '.tls_flow', params.get("flow") || "none");
  438. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.tls_flow', event);
  439. setElementValue('cbid.shadowsocksr.' + sid + '.xhttp_alpn', params.get("alpn") || "");
  440. setElementValue('cbid.shadowsocksr.' + sid + '.fingerprint', params.get("fp") || "");
  441. setElementValue('cbid.shadowsocksr.' + sid + '.tls_host', params.get("sni") || "");
  442. }
  443. switch (params.get("type")) {
  444. case "ws":
  445. if (params.get("security") !== "tls") {
  446. setElementValue('cbid.shadowsocksr.' + sid + '.ws_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  447. }
  448. setElementValue('cbid.shadowsocksr.' + sid + '.ws_path', params.get("path") ? decodeURIComponent(params.get("path")) : "/");
  449. break;
  450. case "httpupgrade":
  451. if (params.get("security") !== "tls") {
  452. setElementValue('cbid.shadowsocksr.' + sid + '.httpupgrade_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  453. }
  454. setElementValue('cbid.shadowsocksr.' + sid + '.httpupgrade_path', params.get("path") ? decodeURIComponent(params.get("path")) : "/");
  455. break;
  456. case "splithttp":
  457. if (params.get("security") !== "tls") {
  458. setElementValue('cbid.shadowsocksr.' + sid + '.splithttp_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  459. }
  460. setElementValue('cbid.shadowsocksr.' + sid + '.splithttp_path', params.get("path") ? decodeURIComponent(params.get("path")) : "/");
  461. break;
  462. case "xhttp":
  463. if (params.get("security") !== "tls") {
  464. setElementValue('cbid.shadowsocksr.' + sid + '.xhttp_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  465. }
  466. setElementValue('cbid.shadowsocksr.' + sid + '.xhttp_mode', params.get("mode") || "auto");
  467. setElementValue('cbid.shadowsocksr.' + sid + '.xhttp_path', params.get("path") ? decodeURIComponent(params.get("path")) : "/");
  468. if (params.get("extra") && params.get("extra").trim() !== "") {
  469. setElementValue('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra', true); // 设置 enable_xhttp_extra 为 true
  470. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.enable_xhttp_extra', event); // 触发事件
  471. setElementValue('cbid.shadowsocksr.' + sid + '.xhttp_extra', params.get("extra") || "");
  472. }
  473. break;
  474. case "kcp":
  475. setElementValue('cbid.shadowsocksr.' + sid + '.kcp_guise', params.get("headerType") || "none");
  476. setElementValue('cbid.shadowsocksr.' + sid + '.seed', params.get("seed") || "");
  477. break;
  478. case "http":
  479. /* this is non-standard, bullshit */
  480. case "h2":
  481. setElementValue('cbid.shadowsocksr.' + sid + '.h2_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  482. setElementValue('cbid.shadowsocksr.' + sid + '.h2_path', params.get("path") ? decodeURIComponent(params.get("path")) : "");
  483. break;
  484. case "quic":
  485. setElementValue('cbid.shadowsocksr.' + sid + '.quic_guise', params.get("headerType") || "none");
  486. setElementValue('cbid.shadowsocksr.' + sid + '.quic_security', params.get("quicSecurity") || "none");
  487. setElementValue('cbid.shadowsocksr.' + sid + '.quic_key', params.get("key") || "");
  488. break;
  489. case "grpc":
  490. setElementValue('cbid.shadowsocksr.' + sid + '.serviceName', params.get("serviceName") || "");
  491. setElementValue('cbid.shadowsocksr.' + sid + '.grpc_mode', params.get("mode") || "gun");
  492. break;
  493. case "tcp":
  494. case "raw":
  495. setElementValue('cbid.shadowsocksr.' + sid + '.tcp_guise', params.get("headerType") || "none");
  496. dispatchEventIfExists('cbid.shadowsocksr.' + sid + '.tcp_guise', event);
  497. if (params.get("headerType") === "http") {
  498. setElementValue('cbid.shadowsocksr.' + sid + '.http_host', params.get("host") ? decodeURIComponent(params.get("host")) : "");
  499. setElementValue('cbid.shadowsocksr.' + sid + '.http_path', params.get("path") ? decodeURIComponent(params.get("path")) : "");
  500. }
  501. break;
  502. }
  503. s.innerHTML = "<font style=\'color:green\'><%:Import configuration information successfully.%></font>";
  504. return false;
  505. default:
  506. s.innerHTML = "<font style=\'color:red\'><%:Invalid format.%></font>";
  507. return false;
  508. }
  509. }
  510. //]]>
  511. </script>
  512. <input type="button" class="btn cbi-button cbi-button-apply" value="<%:Import%>" onclick="return import_ssr_url(this, '<%=self.option%>', '<%=self.value%>')" />
  513. <span id="<%=self.option%>-status"></span>
  514. <%+cbi/valuefooter%>