From 1365febaa47141e9cf1f1fd2d4b199c9fbb6c588 Mon Sep 17 00:00:00 2001 From: divocatt <210179590+divocatt@users.noreply.github.com> Date: Fri, 29 May 2026 16:40:44 +0300 Subject: [PATCH] feat(hy2): add port range support for validator --- fe-app-podkop/locales/calls.json | 32 ++++++------ fe-app-podkop/locales/podkop.pot | 40 +++++++-------- fe-app-podkop/locales/podkop.ru.po | 8 +-- .../tests/validateHysteriaUrl.test.js | 5 ++ .../src/validators/validateHysteriaUrl.ts | 51 +++++++++++-------- .../luci-static/resources/view/podkop/main.js | 43 +++++++++------- luci-app-podkop/po/ru/podkop.po | 8 +-- luci-app-podkop/po/templates/podkop.pot | 40 +++++++-------- 8 files changed, 122 insertions(+), 105 deletions(-) diff --git a/fe-app-podkop/locales/calls.json b/fe-app-podkop/locales/calls.json index ecb7e1c..742d92b 100644 --- a/fe-app-podkop/locales/calls.json +++ b/fe-app-podkop/locales/calls.json @@ -648,56 +648,56 @@ "call": "Invalid HY2 URL: insecure must be 0 or 1", "key": "Invalid HY2 URL: insecure must be 0 or 1", "places": [ - "src/validators/validateHysteriaUrl.ts:76" + "src/validators/validateHysteriaUrl.ts:90" ] }, { "call": "Invalid HY2 URL: invalid port number", "key": "Invalid HY2 URL: invalid port number", "places": [ - "src/validators/validateHysteriaUrl.ts:62" + "src/validators/validateHysteriaUrl.ts:77" ] }, { "call": "Invalid HY2 URL: missing credentials/server", "key": "Invalid HY2 URL: missing credentials/server", "places": [ - "src/validators/validateHysteriaUrl.ts:32" + "src/validators/validateHysteriaUrl.ts:30" ] }, { "call": "Invalid HY2 URL: missing host", "key": "Invalid HY2 URL: missing host", "places": [ - "src/validators/validateHysteriaUrl.ts:49" + "src/validators/validateHysteriaUrl.ts:47" ] }, { "call": "Invalid HY2 URL: missing host & port", "key": "Invalid HY2 URL: missing host & port", "places": [ - "src/validators/validateHysteriaUrl.ts:43" + "src/validators/validateHysteriaUrl.ts:41" ] }, { "call": "Invalid HY2 URL: missing password", "key": "Invalid HY2 URL: missing password", "places": [ - "src/validators/validateHysteriaUrl.ts:38" + "src/validators/validateHysteriaUrl.ts:36" ] }, { "call": "Invalid HY2 URL: missing port", "key": "Invalid HY2 URL: missing port", "places": [ - "src/validators/validateHysteriaUrl.ts:53" + "src/validators/validateHysteriaUrl.ts:50" ] }, { "call": "Invalid HY2 URL: must not contain spaces", "key": "Invalid HY2 URL: must not contain spaces", "places": [ - "src/validators/validateHysteriaUrl.ts:19" + "src/validators/validateHysteriaUrl.ts:18" ] }, { @@ -711,28 +711,28 @@ "call": "Invalid HY2 URL: obfs-password required when obfs is set", "key": "Invalid HY2 URL: obfs-password required when obfs is set", "places": [ - "src/validators/validateHysteriaUrl.ts:99" + "src/validators/validateHysteriaUrl.ts:108" ] }, { "call": "Invalid HY2 URL: parsing failed", "key": "Invalid HY2 URL: parsing failed", "places": [ - "src/validators/validateHysteriaUrl.ts:115" + "src/validators/validateHysteriaUrl.ts:122" ] }, { "call": "Invalid HY2 URL: sni cannot be empty", "key": "Invalid HY2 URL: sni cannot be empty", "places": [ - "src/validators/validateHysteriaUrl.ts:108" + "src/validators/validateHysteriaUrl.ts:116" ] }, { "call": "Invalid HY2 URL: unsupported obfs type", "key": "Invalid HY2 URL: unsupported obfs type", "places": [ - "src/validators/validateHysteriaUrl.ts:88" + "src/validators/validateHysteriaUrl.ts:98" ] }, { @@ -943,7 +943,7 @@ "call": "Latest", "key": "Latest", "places": [ - "src/podkop/tabs/diagnostic/initController.ts:456" + "src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:48" ] }, { @@ -1075,7 +1075,7 @@ "call": "Outdated", "key": "Outdated", "places": [ - "src/podkop/tabs/diagnostic/initController.ts:446" + "src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:38" ] }, { @@ -1685,7 +1685,7 @@ "src/podkop/tabs/diagnostic/initController.ts:41", "src/podkop/tabs/diagnostic/initController.ts:42", "src/podkop/tabs/diagnostic/initController.ts:43", - "src/podkop/tabs/diagnostic/initController.ts:420" + "src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:7" ] }, { @@ -1802,7 +1802,7 @@ "src/validators/validateDns.ts:18", "src/validators/validateDomain.ts:13", "src/validators/validateDomain.ts:30", - "src/validators/validateHysteriaUrl.ts:113", + "src/validators/validateHysteriaUrl.ts:120", "src/validators/validateIp.ts:8", "src/validators/validateOutboundJson.ts:7", "src/validators/validatePath.ts:16", diff --git a/fe-app-podkop/locales/podkop.pot b/fe-app-podkop/locales/podkop.pot index 1387107..d96b948 100644 --- a/fe-app-podkop/locales/podkop.pot +++ b/fe-app-podkop/locales/podkop.pot @@ -1,15 +1,15 @@ # SOME DESCRIPTIVE TITLE. # Copyright (C) 2026 THE PACKAGE'S COPYRIGHT HOLDER # This file is distributed under the same license as the PODKOP package. -# romanvht , 2026. +# divocatt <210179590+divocatt@users.noreply.github.com>, 2026. #, fuzzy msgid "" msgstr "" "Project-Id-Version: PODKOP\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2026-05-09 02:49+1000\n" -"PO-Revision-Date: 2026-05-09 02:49+1000\n" -"Last-Translator: romanvht \n" +"POT-Creation-Date: 2026-05-29 13:40+0300\n" +"PO-Revision-Date: 2026-05-29 13:40+0300\n" +"Last-Translator: divocatt <210179590+divocatt@users.noreply.github.com>\n" "Language-Team: LANGUAGE \n" "Language: \n" "MIME-Version: 1.0\n" @@ -394,35 +394,35 @@ msgstr "" msgid "Invalid format. Use X.X.X.X or X.X.X.X/Y" msgstr "" -#: src/validators/validateHysteriaUrl.ts:76 +#: src/validators/validateHysteriaUrl.ts:90 msgid "Invalid HY2 URL: insecure must be 0 or 1" msgstr "" -#: src/validators/validateHysteriaUrl.ts:62 +#: src/validators/validateHysteriaUrl.ts:77 msgid "Invalid HY2 URL: invalid port number" msgstr "" -#: src/validators/validateHysteriaUrl.ts:32 +#: src/validators/validateHysteriaUrl.ts:30 msgid "Invalid HY2 URL: missing credentials/server" msgstr "" -#: src/validators/validateHysteriaUrl.ts:49 +#: src/validators/validateHysteriaUrl.ts:47 msgid "Invalid HY2 URL: missing host" msgstr "" -#: src/validators/validateHysteriaUrl.ts:43 +#: src/validators/validateHysteriaUrl.ts:41 msgid "Invalid HY2 URL: missing host & port" msgstr "" -#: src/validators/validateHysteriaUrl.ts:38 +#: src/validators/validateHysteriaUrl.ts:36 msgid "Invalid HY2 URL: missing password" msgstr "" -#: src/validators/validateHysteriaUrl.ts:53 +#: src/validators/validateHysteriaUrl.ts:50 msgid "Invalid HY2 URL: missing port" msgstr "" -#: src/validators/validateHysteriaUrl.ts:19 +#: src/validators/validateHysteriaUrl.ts:18 msgid "Invalid HY2 URL: must not contain spaces" msgstr "" @@ -430,19 +430,19 @@ msgstr "" msgid "Invalid HY2 URL: must start with hysteria2:// or hy2://" msgstr "" -#: src/validators/validateHysteriaUrl.ts:99 +#: src/validators/validateHysteriaUrl.ts:108 msgid "Invalid HY2 URL: obfs-password required when obfs is set" msgstr "" -#: src/validators/validateHysteriaUrl.ts:115 +#: src/validators/validateHysteriaUrl.ts:122 msgid "Invalid HY2 URL: parsing failed" msgstr "" -#: src/validators/validateHysteriaUrl.ts:108 +#: src/validators/validateHysteriaUrl.ts:116 msgid "Invalid HY2 URL: sni cannot be empty" msgstr "" -#: src/validators/validateHysteriaUrl.ts:88 +#: src/validators/validateHysteriaUrl.ts:98 msgid "Invalid HY2 URL: unsupported obfs type" msgstr "" @@ -563,7 +563,7 @@ msgstr "" msgid "Issues detected" msgstr "" -#: src/podkop/tabs/diagnostic/initController.ts:456 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:48 msgid "Latest" msgstr "" @@ -641,7 +641,7 @@ msgstr "" msgid "Outbound Configuration" msgstr "" -#: src/podkop/tabs/diagnostic/initController.ts:446 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:38 msgid "Outdated" msgstr "" @@ -996,7 +996,7 @@ msgstr "" #: src/podkop/tabs/diagnostic/initController.ts:41 #: src/podkop/tabs/diagnostic/initController.ts:42 #: src/podkop/tabs/diagnostic/initController.ts:43 -#: src/podkop/tabs/diagnostic/initController.ts:420 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:7 msgid "unknown" msgstr "" @@ -1065,7 +1065,7 @@ msgstr "" #: src/validators/validateDns.ts:18 #: src/validators/validateDomain.ts:13 #: src/validators/validateDomain.ts:30 -#: src/validators/validateHysteriaUrl.ts:113 +#: src/validators/validateHysteriaUrl.ts:120 #: src/validators/validateIp.ts:8 #: src/validators/validateOutboundJson.ts:7 #: src/validators/validatePath.ts:16 diff --git a/fe-app-podkop/locales/podkop.ru.po b/fe-app-podkop/locales/podkop.ru.po index 52b3ff2..77a33a4 100644 --- a/fe-app-podkop/locales/podkop.ru.po +++ b/fe-app-podkop/locales/podkop.ru.po @@ -1,15 +1,15 @@ # RU translations for PODKOP package. # Copyright (C) 2026 THE PODKOP'S COPYRIGHT HOLDER # This file is distributed under the same license as the PODKOP package. -# romanvht, 2026. +# divocatt, 2026. # msgid "" msgstr "" "Project-Id-Version: PODKOP\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2026-05-09 12:50+1000\n" -"PO-Revision-Date: 2026-05-09 12:50+1000\n" -"Last-Translator: romanvht\n" +"POT-Creation-Date: 2026-05-29 16:40+0300\n" +"PO-Revision-Date: 2026-05-29 16:40+0300\n" +"Last-Translator: divocatt\n" "Language-Team: none\n" "Language: ru\n" "MIME-Version: 1.0\n" diff --git a/fe-app-podkop/src/validators/tests/validateHysteriaUrl.test.js b/fe-app-podkop/src/validators/tests/validateHysteriaUrl.test.js index b759fd2..ce1f480 100644 --- a/fe-app-podkop/src/validators/tests/validateHysteriaUrl.test.js +++ b/fe-app-podkop/src/validators/tests/validateHysteriaUrl.test.js @@ -28,6 +28,11 @@ const validUrls = [ // Explicit obfs=none (valid) ['obfs none = ok', 'hysteria2://pw@example.com:443/?obfs=none#hy2-none'], + + [ + 'port range 5000-6000', + 'hysteria2://letmein@example.com:123,5000-6000/?insecure=1&obfs=salamander&obfs-password=gawrgura&pinSHA256=deadbeef&sni=real.example.com', + ], ]; const invalidUrls = [ diff --git a/fe-app-podkop/src/validators/validateHysteriaUrl.ts b/fe-app-podkop/src/validators/validateHysteriaUrl.ts index 464f16d..d9a01fe 100644 --- a/fe-app-podkop/src/validators/validateHysteriaUrl.ts +++ b/fe-app-podkop/src/validators/validateHysteriaUrl.ts @@ -6,19 +6,17 @@ export function validateHysteria2Url(url: string): ValidationResult { const isHY2 = url.startsWith('hysteria2://'); const isHY2Short = url.startsWith('hy2://'); - if (!isHY2 && !isHY2Short) { + if (!isHY2 && !isHY2Short) return { valid: false, message: _('Invalid HY2 URL: must start with hysteria2:// or hy2://'), }; - } - if (/\s/.test(url)) { + if (/\s/.test(url)) return { valid: false, message: _('Invalid HY2 URL: must not contain spaces'), }; - } const prefix = isHY2 ? 'hysteria2://' : 'hy2://'; const body = url.slice(prefix.length); @@ -45,23 +43,39 @@ export function validateHysteria2Url(url: string): ValidationResult { const [host, port] = hostPortPart.split(':'); - if (!host) { + if (!host) return { valid: false, message: _('Invalid HY2 URL: missing host') }; - } - if (!port) { + if (!port) return { valid: false, message: _('Invalid HY2 URL: missing port') }; - } const cleanedPort = port.replace('/', ''); - const portNum = Number(cleanedPort); + const portEntries = cleanedPort.split(','); - if (!Number.isInteger(portNum) || portNum < 1 || portNum > 65535) { + const isValidPortNumber = (value: string) => { + if (!/^\d+$/.test(value)) return false; + const num = Number(value); + return num >= 1 && num <= 65535; + }; + + const isValidPortEntry = (entry: string) => { + if (!entry) return false; + if (!entry.includes('-')) return isValidPortNumber(entry); + + const rangeParts = entry.split('-'); + if (rangeParts.length !== 2) return false; + + const [start, end] = rangeParts; + if (!isValidPortNumber(start) || !isValidPortNumber(end)) return false; + + return Number(start) <= Number(end); + }; + + if (!portEntries.every(isValidPortEntry)) return { valid: false, message: _('Invalid HY2 URL: invalid port number'), }; - } if (queryString) { const params = parseQueryString(queryString); @@ -70,44 +84,37 @@ export function validateHysteria2Url(url: string): ValidationResult { if ( paramsKeys.includes('insecure') && !['0', '1'].includes(params.insecure) - ) { + ) return { valid: false, message: _('Invalid HY2 URL: insecure must be 0 or 1'), }; - } const validObfsTypes = ['none', 'salamander']; - if ( - paramsKeys.includes('obfs') && - !validObfsTypes.includes(params.obfs) - ) { + if (paramsKeys.includes('obfs') && !validObfsTypes.includes(params.obfs)) return { valid: false, message: _('Invalid HY2 URL: unsupported obfs type'), }; - } if ( paramsKeys.includes('obfs') && params.obfs !== 'none' && !params['obfs-password'] - ) { + ) return { valid: false, message: _( 'Invalid HY2 URL: obfs-password required when obfs is set', ), }; - } - if (paramsKeys.includes('sni') && !params.sni) { + if (paramsKeys.includes('sni') && !params.sni) return { valid: false, message: _('Invalid HY2 URL: sni cannot be empty'), }; - } } return { valid: true, message: _('Valid') }; diff --git a/luci-app-podkop/htdocs/luci-static/resources/view/podkop/main.js b/luci-app-podkop/htdocs/luci-static/resources/view/podkop/main.js index f7b9eab..aefd183 100644 --- a/luci-app-podkop/htdocs/luci-static/resources/view/podkop/main.js +++ b/luci-app-podkop/htdocs/luci-static/resources/view/podkop/main.js @@ -453,18 +453,16 @@ function validateHysteria2Url(url) { try { const isHY2 = url.startsWith("hysteria2://"); const isHY2Short = url.startsWith("hy2://"); - if (!isHY2 && !isHY2Short) { + if (!isHY2 && !isHY2Short) return { valid: false, message: _("Invalid HY2 URL: must start with hysteria2:// or hy2://") }; - } - if (/\s/.test(url)) { + if (/\s/.test(url)) return { valid: false, message: _("Invalid HY2 URL: must not contain spaces") }; - } const prefix = isHY2 ? "hysteria2://" : "hy2://"; const body = url.slice(prefix.length); const [mainPart] = body.split("#"); @@ -483,50 +481,57 @@ function validateHysteria2Url(url) { message: _("Invalid HY2 URL: missing host & port") }; const [host, port] = hostPortPart.split(":"); - if (!host) { + if (!host) return { valid: false, message: _("Invalid HY2 URL: missing host") }; - } - if (!port) { + if (!port) return { valid: false, message: _("Invalid HY2 URL: missing port") }; - } const cleanedPort = port.replace("/", ""); - const portNum = Number(cleanedPort); - if (!Number.isInteger(portNum) || portNum < 1 || portNum > 65535) { + const portEntries = cleanedPort.split(","); + const isValidPortNumber = (value) => { + if (!/^\d+$/.test(value)) return false; + const num = Number(value); + return num >= 1 && num <= 65535; + }; + const isValidPortEntry = (entry) => { + if (!entry) return false; + if (!entry.includes("-")) return isValidPortNumber(entry); + const rangeParts = entry.split("-"); + if (rangeParts.length !== 2) return false; + const [start, end] = rangeParts; + if (!isValidPortNumber(start) || !isValidPortNumber(end)) return false; + return Number(start) <= Number(end); + }; + if (!portEntries.every(isValidPortEntry)) return { valid: false, message: _("Invalid HY2 URL: invalid port number") }; - } if (queryString) { const params = parseQueryString(queryString); const paramsKeys = Object.keys(params); - if (paramsKeys.includes("insecure") && !["0", "1"].includes(params.insecure)) { + if (paramsKeys.includes("insecure") && !["0", "1"].includes(params.insecure)) return { valid: false, message: _("Invalid HY2 URL: insecure must be 0 or 1") }; - } const validObfsTypes = ["none", "salamander"]; - if (paramsKeys.includes("obfs") && !validObfsTypes.includes(params.obfs)) { + if (paramsKeys.includes("obfs") && !validObfsTypes.includes(params.obfs)) return { valid: false, message: _("Invalid HY2 URL: unsupported obfs type") }; - } - if (paramsKeys.includes("obfs") && params.obfs !== "none" && !params["obfs-password"]) { + if (paramsKeys.includes("obfs") && params.obfs !== "none" && !params["obfs-password"]) return { valid: false, message: _( "Invalid HY2 URL: obfs-password required when obfs is set" ) }; - } - if (paramsKeys.includes("sni") && !params.sni) { + if (paramsKeys.includes("sni") && !params.sni) return { valid: false, message: _("Invalid HY2 URL: sni cannot be empty") }; - } } return { valid: true, message: _("Valid") }; } catch (_e) { diff --git a/luci-app-podkop/po/ru/podkop.po b/luci-app-podkop/po/ru/podkop.po index 52b3ff2..77a33a4 100644 --- a/luci-app-podkop/po/ru/podkop.po +++ b/luci-app-podkop/po/ru/podkop.po @@ -1,15 +1,15 @@ # RU translations for PODKOP package. # Copyright (C) 2026 THE PODKOP'S COPYRIGHT HOLDER # This file is distributed under the same license as the PODKOP package. -# romanvht, 2026. +# divocatt, 2026. # msgid "" msgstr "" "Project-Id-Version: PODKOP\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2026-05-09 12:50+1000\n" -"PO-Revision-Date: 2026-05-09 12:50+1000\n" -"Last-Translator: romanvht\n" +"POT-Creation-Date: 2026-05-29 16:40+0300\n" +"PO-Revision-Date: 2026-05-29 16:40+0300\n" +"Last-Translator: divocatt\n" "Language-Team: none\n" "Language: ru\n" "MIME-Version: 1.0\n" diff --git a/luci-app-podkop/po/templates/podkop.pot b/luci-app-podkop/po/templates/podkop.pot index 1387107..d96b948 100644 --- a/luci-app-podkop/po/templates/podkop.pot +++ b/luci-app-podkop/po/templates/podkop.pot @@ -1,15 +1,15 @@ # SOME DESCRIPTIVE TITLE. # Copyright (C) 2026 THE PACKAGE'S COPYRIGHT HOLDER # This file is distributed under the same license as the PODKOP package. -# romanvht , 2026. +# divocatt <210179590+divocatt@users.noreply.github.com>, 2026. #, fuzzy msgid "" msgstr "" "Project-Id-Version: PODKOP\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2026-05-09 02:49+1000\n" -"PO-Revision-Date: 2026-05-09 02:49+1000\n" -"Last-Translator: romanvht \n" +"POT-Creation-Date: 2026-05-29 13:40+0300\n" +"PO-Revision-Date: 2026-05-29 13:40+0300\n" +"Last-Translator: divocatt <210179590+divocatt@users.noreply.github.com>\n" "Language-Team: LANGUAGE \n" "Language: \n" "MIME-Version: 1.0\n" @@ -394,35 +394,35 @@ msgstr "" msgid "Invalid format. Use X.X.X.X or X.X.X.X/Y" msgstr "" -#: src/validators/validateHysteriaUrl.ts:76 +#: src/validators/validateHysteriaUrl.ts:90 msgid "Invalid HY2 URL: insecure must be 0 or 1" msgstr "" -#: src/validators/validateHysteriaUrl.ts:62 +#: src/validators/validateHysteriaUrl.ts:77 msgid "Invalid HY2 URL: invalid port number" msgstr "" -#: src/validators/validateHysteriaUrl.ts:32 +#: src/validators/validateHysteriaUrl.ts:30 msgid "Invalid HY2 URL: missing credentials/server" msgstr "" -#: src/validators/validateHysteriaUrl.ts:49 +#: src/validators/validateHysteriaUrl.ts:47 msgid "Invalid HY2 URL: missing host" msgstr "" -#: src/validators/validateHysteriaUrl.ts:43 +#: src/validators/validateHysteriaUrl.ts:41 msgid "Invalid HY2 URL: missing host & port" msgstr "" -#: src/validators/validateHysteriaUrl.ts:38 +#: src/validators/validateHysteriaUrl.ts:36 msgid "Invalid HY2 URL: missing password" msgstr "" -#: src/validators/validateHysteriaUrl.ts:53 +#: src/validators/validateHysteriaUrl.ts:50 msgid "Invalid HY2 URL: missing port" msgstr "" -#: src/validators/validateHysteriaUrl.ts:19 +#: src/validators/validateHysteriaUrl.ts:18 msgid "Invalid HY2 URL: must not contain spaces" msgstr "" @@ -430,19 +430,19 @@ msgstr "" msgid "Invalid HY2 URL: must start with hysteria2:// or hy2://" msgstr "" -#: src/validators/validateHysteriaUrl.ts:99 +#: src/validators/validateHysteriaUrl.ts:108 msgid "Invalid HY2 URL: obfs-password required when obfs is set" msgstr "" -#: src/validators/validateHysteriaUrl.ts:115 +#: src/validators/validateHysteriaUrl.ts:122 msgid "Invalid HY2 URL: parsing failed" msgstr "" -#: src/validators/validateHysteriaUrl.ts:108 +#: src/validators/validateHysteriaUrl.ts:116 msgid "Invalid HY2 URL: sni cannot be empty" msgstr "" -#: src/validators/validateHysteriaUrl.ts:88 +#: src/validators/validateHysteriaUrl.ts:98 msgid "Invalid HY2 URL: unsupported obfs type" msgstr "" @@ -563,7 +563,7 @@ msgstr "" msgid "Issues detected" msgstr "" -#: src/podkop/tabs/diagnostic/initController.ts:456 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:48 msgid "Latest" msgstr "" @@ -641,7 +641,7 @@ msgstr "" msgid "Outbound Configuration" msgstr "" -#: src/podkop/tabs/diagnostic/initController.ts:446 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:38 msgid "Outdated" msgstr "" @@ -996,7 +996,7 @@ msgstr "" #: src/podkop/tabs/diagnostic/initController.ts:41 #: src/podkop/tabs/diagnostic/initController.ts:42 #: src/podkop/tabs/diagnostic/initController.ts:43 -#: src/podkop/tabs/diagnostic/initController.ts:420 +#: src/podkop/tabs/diagnostic/helpers/getPodkopVersionRow.ts:7 msgid "unknown" msgstr "" @@ -1065,7 +1065,7 @@ msgstr "" #: src/validators/validateDns.ts:18 #: src/validators/validateDomain.ts:13 #: src/validators/validateDomain.ts:30 -#: src/validators/validateHysteriaUrl.ts:113 +#: src/validators/validateHysteriaUrl.ts:120 #: src/validators/validateIp.ts:8 #: src/validators/validateOutboundJson.ts:7 #: src/validators/validatePath.ts:16