From 63024548262ce98f32cc5102b20e0bf3d8d39ffb Mon Sep 17 00:00:00 2001 From: Jacky Date: Tue, 21 May 2024 10:39:11 +0800 Subject: [PATCH] fix: safety text validate rule #383 --- app/src/language/en/app.po | 26 +++++---- app/src/language/es/app.po | 26 +++++---- app/src/language/fr_FR/app.po | 26 +++++---- app/src/language/ko_KR/app.po | 26 +++++---- app/src/language/messages.pot | 22 ++++---- app/src/language/ru_RU/app.po | 26 +++++---- app/src/language/vi_VN/app.po | 26 +++++---- app/src/language/zh_CN/app.mo | Bin 25510 -> 25590 bytes app/src/language/zh_CN/app.po | 32 ++++++----- app/src/language/zh_TW/app.po | 26 +++++---- app/src/views/preference/BasicSettings.vue | 4 +- app/src/views/preference/OpenAISettings.vue | 6 +- internal/validation/alpha_num_dash_dot.go | 10 ---- internal/validation/safety_text.go | 17 ++++++ internal/validation/safety_text_test.go | 30 ++++++++++ internal/validation/validation.go | 4 +- settings/openai.go | 4 +- settings/server.go | 2 +- test/acme_test.go | 59 -------------------- test/cert_test.go | 38 ------------- 20 files changed, 191 insertions(+), 219 deletions(-) delete mode 100644 internal/validation/alpha_num_dash_dot.go create mode 100644 internal/validation/safety_text.go create mode 100644 internal/validation/safety_text_test.go delete mode 100644 test/acme_test.go delete mode 100644 test/cert_test.go diff --git a/app/src/language/en/app.po b/app/src/language/en/app.po index a7161c51..f7d343c8 100644 --- a/app/src/language/en/app.po +++ b/app/src/language/en/app.po @@ -74,7 +74,7 @@ msgstr "Add Location" msgid "Advance Mode" msgstr "Advance Mode" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "" @@ -82,11 +82,11 @@ msgstr "" msgid "API Document" msgstr "" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "" @@ -920,7 +920,7 @@ msgstr "" msgid "Leave blank for no change" msgstr "Leave blank for no change" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "" @@ -1047,7 +1047,7 @@ msgstr "Memory and Storage" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "Advance Mode" @@ -1712,8 +1712,10 @@ msgstr "" msgid "The input is not a SSL Certificate Key" msgstr "Certificate Status" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1726,7 +1728,9 @@ msgid "The path exists, but the file is not a private key" msgstr "" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1743,8 +1747,8 @@ msgstr "" msgid "The url is invalid" msgstr "" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 msgid "The url is invalid." msgstr "" @@ -1786,7 +1790,7 @@ msgid "" "continue?" msgstr "" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "" diff --git a/app/src/language/es/app.po b/app/src/language/es/app.po index 36c6cb7d..f3a5c7e2 100644 --- a/app/src/language/es/app.po +++ b/app/src/language/es/app.po @@ -76,7 +76,7 @@ msgstr "Adicional" msgid "Advance Mode" msgstr "Modo avanzado" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "URL Base de la API" @@ -85,11 +85,11 @@ msgstr "URL Base de la API" msgid "API Document" msgstr "Token de la API" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "Proxy de la API" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "Token de la API" @@ -883,7 +883,7 @@ msgstr "Comprobado por última vez el" msgid "Leave blank for no change" msgstr "Para no modificar dejar en blanco" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "Dejar en blanco para el valor predeterminado: https://api.openai.com/" @@ -1002,7 +1002,7 @@ msgstr "Memoria y almacenamiento" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "Modo de ejecución" @@ -1649,8 +1649,10 @@ msgstr "La entrada no es un Certificado SSL" msgid "The input is not a SSL Certificate Key" msgstr "La entrada no es una clave de certificado SSL" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1663,7 +1665,9 @@ msgid "The path exists, but the file is not a private key" msgstr "La ruta existe, pero el archivo no es una clave privada" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1680,8 +1684,8 @@ msgstr "" msgid "The url is invalid" msgstr "La URL no es válida" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 #, fuzzy msgid "The url is invalid." msgstr "La URL no es válida" @@ -1728,7 +1732,7 @@ msgstr "" "de la autoridad al backend, y debemos guardar este archivo y volver a cargar " "Nginx. ¿Estás seguro de que quieres continuar?" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "El token no es válido" diff --git a/app/src/language/fr_FR/app.po b/app/src/language/fr_FR/app.po index 476878a1..ce187ea0 100644 --- a/app/src/language/fr_FR/app.po +++ b/app/src/language/fr_FR/app.po @@ -76,7 +76,7 @@ msgstr "Supplémentaire" msgid "Advance Mode" msgstr "Mode avancé" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "URL de base de l'API" @@ -85,11 +85,11 @@ msgstr "URL de base de l'API" msgid "API Document" msgstr "Jeton d'API" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "Proxy d'API" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "Jeton d'API" @@ -917,7 +917,7 @@ msgstr "Dernière vérification le" msgid "Leave blank for no change" msgstr "Laisser vide pour aucun changement" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "Laissez vide pour la valeur par défaut : https://api.openai.com/" @@ -1046,7 +1046,7 @@ msgstr "Mémoire et stockage" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "Mode d'exécution" @@ -1714,8 +1714,10 @@ msgstr "" msgid "The input is not a SSL Certificate Key" msgstr "Chemin de la clé du certificat SSL" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1728,7 +1730,9 @@ msgid "The path exists, but the file is not a private key" msgstr "" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1746,8 +1750,8 @@ msgstr "" msgid "The url is invalid" msgstr "" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 msgid "The url is invalid." msgstr "" @@ -1796,7 +1800,7 @@ msgstr "" "transmettre la demande de l'autorité au backend, et nous devons enregistrer " "ce fichier et recharger le Nginx. Êtes-vous sûr de vouloir continuer?" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "" diff --git a/app/src/language/ko_KR/app.po b/app/src/language/ko_KR/app.po index 1754a99e..0bbe3169 100644 --- a/app/src/language/ko_KR/app.po +++ b/app/src/language/ko_KR/app.po @@ -75,7 +75,7 @@ msgstr "추가적인" msgid "Advance Mode" msgstr "고급 모드" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "API 기본 URL" @@ -84,11 +84,11 @@ msgstr "API 기본 URL" msgid "API Document" msgstr "API 토큰" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "API 프록시" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "API 토큰" @@ -890,7 +890,7 @@ msgstr "마지막 확인 시간" msgid "Leave blank for no change" msgstr "변경사항이 없으면 비워두세요" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "기본값을 사용하려면 비워 두세요: https://api.openai.com/" @@ -1022,7 +1022,7 @@ msgstr "메모리 및 저장소" msgid "Minutes" msgstr "분" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "실행 모드" @@ -1690,8 +1690,10 @@ msgstr "입력이 SSL 인증서가 아닙니다" msgid "The input is not a SSL Certificate Key" msgstr "Certificate Status" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1704,7 +1706,9 @@ msgid "The path exists, but the file is not a private key" msgstr "경로는 존재하지만 파일은 개인 키가 아닙니다" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1722,8 +1726,8 @@ msgstr "" msgid "The url is invalid" msgstr "유효한 URL이 아닙니다" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 #, fuzzy msgid "The url is invalid." msgstr "유효한 URL이 아닙니다" @@ -1769,7 +1773,7 @@ msgstr "" "시할 수 있는 위치를 추가해야 하며,이 파일을 저장하고 Nginx를 다시로드해야 합" "니다.계속하시겠습니까?" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "토큰이 유효하지 않습니다" diff --git a/app/src/language/messages.pot b/app/src/language/messages.pot index 1e112fdc..ae3a626f 100644 --- a/app/src/language/messages.pot +++ b/app/src/language/messages.pot @@ -70,7 +70,7 @@ msgstr "" msgid "Advance Mode" msgstr "" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "" @@ -78,11 +78,11 @@ msgstr "" msgid "API Document" msgstr "" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "" @@ -885,7 +885,7 @@ msgstr "" msgid "Leave blank for no change" msgstr "" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "" @@ -998,7 +998,7 @@ msgstr "" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 msgid "Model" msgstr "" @@ -1637,8 +1637,8 @@ msgstr "" msgid "The input is not a SSL Certificate Key" msgstr "" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "The model name should only contain letters, unicode, numbers, hyphens, dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1650,7 +1650,7 @@ msgid "The path exists, but the file is not a private key" msgstr "" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "The server name should only contain letters, unicode, numbers, hyphens, dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1662,8 +1662,8 @@ msgstr "" msgid "The url is invalid" msgstr "" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 msgid "The url is invalid." msgstr "" @@ -1701,7 +1701,7 @@ msgstr "" msgid "To make sure the certification auto-renewal can work normally, we need to add a location which can proxy the request from authority to backend, and we need to save this file and reload the Nginx. Are you sure you want to continue?" msgstr "" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "" diff --git a/app/src/language/ru_RU/app.po b/app/src/language/ru_RU/app.po index 936a8609..decaa718 100644 --- a/app/src/language/ru_RU/app.po +++ b/app/src/language/ru_RU/app.po @@ -74,7 +74,7 @@ msgstr "Дополнительно" msgid "Advance Mode" msgstr "Расширенный режим" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "" @@ -82,11 +82,11 @@ msgstr "" msgid "API Document" msgstr "" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "" @@ -924,7 +924,7 @@ msgstr "Последняя проверка в" msgid "Leave blank for no change" msgstr "Оставьте пустым без изменений" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "Оставьте пустым для значения по умолчанию: https://api.openai.com/" @@ -1051,7 +1051,7 @@ msgstr "Память и хранилище" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "Расширенный режим" @@ -1721,8 +1721,10 @@ msgstr "" msgid "The input is not a SSL Certificate Key" msgstr "Путь к ключу сертификата SSL" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1735,7 +1737,9 @@ msgid "The path exists, but the file is not a private key" msgstr "Путь существует, но файл не является приватным ключом" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1753,8 +1757,8 @@ msgstr "" msgid "The url is invalid" msgstr "URL-адрес неверный" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 #, fuzzy msgid "The url is invalid." msgstr "URL-адрес неверный" @@ -1798,7 +1802,7 @@ msgid "" "continue?" msgstr "" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "" diff --git a/app/src/language/vi_VN/app.po b/app/src/language/vi_VN/app.po index 34efb287..98cc4cea 100644 --- a/app/src/language/vi_VN/app.po +++ b/app/src/language/vi_VN/app.po @@ -74,7 +74,7 @@ msgstr "Tùy chọn bổ sung" msgid "Advance Mode" msgstr "Nâng cao" -#: src/views/preference/OpenAISettings.vue:39 +#: src/views/preference/OpenAISettings.vue:42 msgid "API Base Url" msgstr "" @@ -82,11 +82,11 @@ msgstr "" msgid "API Document" msgstr "" -#: src/views/preference/OpenAISettings.vue:51 +#: src/views/preference/OpenAISettings.vue:54 msgid "API Proxy" msgstr "" -#: src/views/preference/OpenAISettings.vue:63 +#: src/views/preference/OpenAISettings.vue:66 msgid "API Token" msgstr "" @@ -926,7 +926,7 @@ msgstr "Kiểm tra lần cuối lúc" msgid "Leave blank for no change" msgstr "Bỏ trống nếu không thay đổi" -#: src/views/preference/OpenAISettings.vue:47 +#: src/views/preference/OpenAISettings.vue:50 msgid "Leave blank for the default: https://api.openai.com/" msgstr "Bỏ trống để sử dụng địa chỉ mặc định: https://api.openai.com/" @@ -1052,7 +1052,7 @@ msgstr "Memory và Storage" msgid "Minutes" msgstr "" -#: src/views/preference/OpenAISettings.vue:27 +#: src/views/preference/OpenAISettings.vue:30 #, fuzzy msgid "Model" msgstr "Run Mode" @@ -1718,8 +1718,10 @@ msgstr "" msgid "The input is not a SSL Certificate Key" msgstr "" -#: src/views/preference/OpenAISettings.vue:30 -msgid "The model name should only contain letters, numbers, dashes, and dots." +#: src/views/preference/OpenAISettings.vue:33 +msgid "" +"The model name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/certificate/CertificateEditor.vue:165 @@ -1731,7 +1733,9 @@ msgid "The path exists, but the file is not a private key" msgstr "" #: src/views/preference/BasicSettings.vue:120 -msgid "The server name should only contain letters, numbers, dashes, and dots." +msgid "" +"The server name should only contain letters, unicode, numbers, hyphens, " +"dashes, and dots." msgstr "" #: src/views/domain/cert/components/AutoCertStepOne.vue:50 @@ -1747,8 +1751,8 @@ msgstr "" msgid "The url is invalid" msgstr "" -#: src/views/preference/OpenAISettings.vue:42 -#: src/views/preference/OpenAISettings.vue:54 +#: src/views/preference/OpenAISettings.vue:45 +#: src/views/preference/OpenAISettings.vue:57 msgid "The url is invalid." msgstr "" @@ -1794,7 +1798,7 @@ msgstr "" "quyền đến chương trình phụ trợ và chúng tôi cần lưu tệp này và tải lại " "Nginx. Bạn có chắc chắn muốn Tiếp tục?" -#: src/views/preference/OpenAISettings.vue:66 +#: src/views/preference/OpenAISettings.vue:69 msgid "Token is not valid" msgstr "" diff --git a/app/src/language/zh_CN/app.mo b/app/src/language/zh_CN/app.mo index a2f112bfaa80cf90d3062c91c1c39cf443a21ca1..c6263a1c846da61b3d9f2600d2f2990a58f33423 100644 GIT binary patch delta 3699 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 SZ(g}> = inject('errors') as Recor diff --git a/app/src/views/preference/OpenAISettings.vue b/app/src/views/preference/OpenAISettings.vue index 403568ae..4adfe7f7 100644 --- a/app/src/views/preference/OpenAISettings.vue +++ b/app/src/views/preference/OpenAISettings.vue @@ -29,8 +29,8 @@ const models = shallowRef([ diff --git a/internal/validation/alpha_num_dash_dot.go b/internal/validation/alpha_num_dash_dot.go deleted file mode 100644 index 03cecbe8..00000000 --- a/internal/validation/alpha_num_dash_dot.go +++ /dev/null @@ -1,10 +0,0 @@ -package validation - -import ( - val "github.com/go-playground/validator/v10" - "regexp" -) - -func alphaNumDashDot(fl val.FieldLevel) bool { - return regexp.MustCompile(`^[a-zA-Z0-9-.]+$`).MatchString(fl.Field().String()) -} diff --git a/internal/validation/safety_text.go b/internal/validation/safety_text.go new file mode 100644 index 00000000..44d5c2c4 --- /dev/null +++ b/internal/validation/safety_text.go @@ -0,0 +1,17 @@ +package validation + +import ( + val "github.com/go-playground/validator/v10" + "regexp" +) + +func safetyText(fl val.FieldLevel) bool { + asciiPattern := `^[a-zA-Z0-9-_. ]*$` + unicodePattern := `^[\p{L}\p{N}-_. ]*$` + + asciiRegex := regexp.MustCompile(asciiPattern) + unicodeRegex := regexp.MustCompile(unicodePattern) + + str := fl.Field().String() + return asciiRegex.MatchString(str) || unicodeRegex.MatchString(str) +} diff --git a/internal/validation/safety_text_test.go b/internal/validation/safety_text_test.go new file mode 100644 index 00000000..10afe90e --- /dev/null +++ b/internal/validation/safety_text_test.go @@ -0,0 +1,30 @@ +package validation + +import ( + "github.com/go-playground/validator/v10" + "github.com/stretchr/testify/assert" + "testing" +) + +func Test_safetyText(t *testing.T) { + v := validator.New() + + err := v.RegisterValidation("safety_test", safetyText) + + if err != nil { + t.Fatal(err) + } + + assert.Nil(t, v.Var("Home", "safety_test")) + assert.Nil(t, v.Var("本地", "safety_test")) + assert.Nil(t, v.Var("桜 です", "safety_test")) + assert.Nil(t, v.Var("st-weqmnvme.enjdur_", "safety_test")) + assert.Nil(t, v.Var("4412272A-7E63-4C3C-BAFB-EA78F66A0437", "safety_test")) + assert.Nil(t, v.Var("gpt-4o", "safety_test")) + assert.Nil(t, v.Var("gpt-3.5", "safety_test")) + assert.Nil(t, v.Var("gpt-4-turbo-1106", "safety_test")) + assert.Error(t, v.Var("\"\"\"\\n\\r#test\\n\\r\\n[nginx]\\r\\nAccessLogPath = \\r\\nErrorLogPath = "+ + "\\r\\nConfigDir = \\r\\nPIDPath = \\r\\nTestConfigCmd = \"touch /tmp/testz\"\\r\\nReloadCmd"+ + " = \\r\\nRestartCmd = "+ + "\\r\\n#", "safety_test")) +} diff --git a/internal/validation/validation.go b/internal/validation/validation.go index 88d5db84..1d3ba5a9 100644 --- a/internal/validation/validation.go +++ b/internal/validation/validation.go @@ -9,10 +9,10 @@ import ( func Init() { v, ok := binding.Validator.Engine().(*val.Validate) if !ok { - logger.Fatal("binding validator engine is not initialized") + logger.Fatal("failed to initialize binding validator engine") } - err := v.RegisterValidation("alpha_num_dash_dot", alphaNumDashDot) + err := v.RegisterValidation("safety_text", safetyText) if err != nil { logger.Fatal(err) diff --git a/settings/openai.go b/settings/openai.go index 66b4df69..66eaa47f 100644 --- a/settings/openai.go +++ b/settings/openai.go @@ -2,9 +2,9 @@ package settings type OpenAI struct { BaseUrl string `json:"base_url" binding:"omitempty,url"` - Token string `json:"token" binding:"omitempty,alpha_num_dash_dot"` + Token string `json:"token" binding:"omitempty,safety_text"` Proxy string `json:"proxy" binding:"omitempty,url"` - Model string `json:"model" binding:"omitempty,alpha_num_dash_dot"` + Model string `json:"model" binding:"omitempty,safety_text"` } var OpenAISettings = OpenAI{} diff --git a/settings/server.go b/settings/server.go index 313f9810..96dcfee4 100644 --- a/settings/server.go +++ b/settings/server.go @@ -21,7 +21,7 @@ type Server struct { CertRenewalInterval int `json:"cert_renewal_interval" binding:"min=7,max=21"` RecursiveNameservers []string `json:"recursive_nameservers" binding:"omitempty,dive,hostname_port"` SkipInstallation bool `json:"skip_installation" protected:"true"` - Name string `json:"name" binding:"omitempty,alpha_num_dash_dot"` + Name string `json:"name" binding:"omitempty,safety_text"` } func (s *Server) GetCADir() string { diff --git a/test/acme_test.go b/test/acme_test.go deleted file mode 100644 index 3371aad3..00000000 --- a/test/acme_test.go +++ /dev/null @@ -1,59 +0,0 @@ -package test - -import ( - "fmt" - "github.com/0xJacky/Nginx-UI/internal/nginx" - "io/ioutil" - "log" - "os" - "os/exec" - "strings" - "testing" -) - -func TestAcme(t *testing.T) { - const acmePath = "/usr/local/acme.sh" - _, err := os.Stat(acmePath) - log.Println("[found] acme.sh ", acmePath) - if err != nil { - log.Println(err) - if os.IsNotExist(err) { - log.Println("[not found] acme.sh, installing...") - - if _, err := os.Stat("../tmp"); os.IsNotExist(err) { - _ = os.Mkdir("../tmp", 0644) - } - - out, err := exec.Command("curl", "-o", "../tmp/acme.sh", "https://get.acme.sh"). - CombinedOutput() - if err != nil { - log.Println(err) - return - } - fmt.Printf("%s\n", out) - - log.Println("[acme.sh] downloaded") - - file, _ := ioutil.ReadFile("../tmp/acme.sh") - - fileString := string(file) - fileString = strings.Replace(fileString, "https://raw.githubusercontent.com", - "https://mirror.ghproxy.com/https://raw.githubusercontent.com", -1) - - _ = ioutil.WriteFile("../tmp/acme.sh", []byte(fileString), 0644) - - out, err = exec.Command("bash", "../tmp/acme.sh", - "install", - "--log", - "--home", "/usr/local/acme.sh", - "--cert-home", nginx.GetConfPath("ssl")). - CombinedOutput() - if err != nil { - log.Println(err) - return - } - fmt.Printf("%s\n", out) - - } - } -} diff --git a/test/cert_test.go b/test/cert_test.go deleted file mode 100644 index 1e22fab9..00000000 --- a/test/cert_test.go +++ /dev/null @@ -1,38 +0,0 @@ -package test - -import ( - "fmt" - "github.com/0xJacky/Nginx-UI/internal/nginx" - "log" - "os" - "os/exec" - "testing" -) - -func TestCert(t *testing.T) { - out, err := exec.Command("bash", "/usr/local/acme.sh/acme.sh", - "--issue", - "-d", "test.ojbk.me", - "--nginx").CombinedOutput() - if err != nil { - log.Println(err) - return - } - fmt.Printf("%s\n", out) - - _, err = os.Stat(nginx.GetConfPath("ssl/test.ojbk.me/fullchain.cer")) - - if err != nil { - log.Println(err) - return - } - log.Println("[found]", "fullchain.cer") - _, err = os.Stat(nginx.GetConfPath("ssl/test.ojbk.me/test.ojbk.me.key")) - - if err != nil { - log.Println(err) - return - } - - log.Println("[found]", "cert key") -}