1
0
Fork 0
mirror of synced 2024-06-14 08:44:49 +12:00

resolve merge conflicts

This commit is contained in:
Khushboo Verma 2024-01-12 01:55:32 +05:30
commit d443602cbc
100 changed files with 505 additions and 237 deletions

3
.env
View file

@ -4,12 +4,13 @@ _APP_WORKER_PER_CORE=6
_APP_CONSOLE_WHITELIST_ROOT=disabled
_APP_CONSOLE_WHITELIST_EMAILS=
_APP_CONSOLE_WHITELIST_IPS=
_APP_CONSOLE_HOSTNAMES=localhost,appwrite.io,*.appwrite.io
_APP_SYSTEM_EMAIL_NAME=Appwrite
_APP_SYSTEM_EMAIL_ADDRESS=team@appwrite.io
_APP_SYSTEM_SECURITY_EMAIL_ADDRESS=security@appwrite.io
_APP_SYSTEM_RESPONSE_FORMAT=
_APP_OPTIONS_ABUSE=disabled
_APP_OPTIONS_ROUTER_PROTECTION=disbled
_APP_OPTIONS_ROUTER_PROTECTION=disabled
_APP_OPTIONS_FORCE_HTTPS=disabled
_APP_OPTIONS_FUNCTIONS_FORCE_HTTPS=disabled
_APP_OPENSSL_KEY_V1=your-secret-key

View file

@ -17,4 +17,8 @@
<p>{{clientInfo}}</p>
<p style="margin-bottom: 0px;">{{thanks}}</p>
<p style="margin-top: 0px;">{{signature}}</p>
<p style="margin-top: 0px;">{{signature}}</p>
<hr style="margin-block-start: 1rem; margin-block-end: 1rem;">
<p style="opacity: 0.7;">{{securityPhrase}}</p>

View file

@ -231,12 +231,13 @@
"continents.sa": "Suid-Amerika",
"emails.magicSession.optionButton": "Klik op die knoppie hieronder om veilig aan te meld by jou {{project}} rekening. Dit sal oor 1 uur verval.",
"emails.magicSession.buttonText": "Meld aan by {{project}}",
"emails.magicSession.optionUrl": "As die knoppie hierbo nie verskyn nie, gebruik die volgende skakel:",
"emails.magicSession.clientInfo": "Hierdie teken-in is aangevra met behulp van {{agentClient}} op {{agentDevice}} {{agentOs}}. As jy nie die teken-in versoek het nie, kan jy hierdie e-pos veilig ignoreer.",
"emails.certificate.subject": "Sertifikaatfout vir %s",
"emails.certificate.hello": "Hallo",
"emails.certificate.body": "Sertifikaat vir jou domein '{{domain}}' kon nie gegenereer word nie. Dit is poging no. {{attempt}}, en die mislukking was veroorsaak deur: {{error}}",
"emails.certificate.footer": "U vorige sertifikaat sal geldig wees vir 30 dae vanaf die eerste mislukking. Ons beveel ten sterkste aan dat u hierdie geval ondersoek, anders sal u domein sonder 'n geldige SSL-kommunikasie eindig.",
"emails.certificate.thanks": "Dankie",
"emails.certificate.signature": "{{project}} span"
"emails.certificate.signature": "{{project}} span",
"emails.magicSession.securityPhrase": "Die sekuriteitsfrase vir hierdie e-pos is {{phrase}}. Jy kan hierdie e-pos vertrou as hierdie frase ooreenstem met die frase wat tydens aanmelding getoon is.",
"emails.magicSession.optionUrl": "As u nie met die knoppie hierbo kan aanmeld nie, besoek asseblief die volgende skakel:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "امريكا الجنوبية",
"emails.magicSession.optionButton": "انقر على الزر أدناه لتسجيل الدخول بأمان إلى حساب {{project}} الخاص بك. سينتهي في غضون ساعة واحدة.",
"emails.magicSession.buttonText": "تسجيل الدخول إلى {{project}}",
"emails.magicSession.optionUrl": "إذا لم يظهر الزر أعلاه، استخدم الرابط التالي:",
"emails.magicSession.clientInfo": "تم طلب هذا الدخول باستخدام {{agentClient}} على {{agentDevice}} {{agentOs}}. إذا لم تطلب الدخول، يمكنك تجاهل هذا البريد الإلكتروني بأمان.",
"emails.certificate.subject": "فشل الشهادة لـ %s",
"emails.certificate.hello": "مرحبا",
"emails.certificate.body": "لم يتمكن من إصدار شهادة لنطاق '{{domain}}' الخاص بك. هذه المحاولة رقم {{attempt}}، وكان سبب الفشل هو: {{error}}",
"emails.certificate.footer": "ستظل شهادتك السابقة صالحة لمدة 30 يومًا منذ الفشل الأول. نوصي بشدة بالتحقيق في هذه الحالة، وإلا سينتهي نطاقك دون اتصال SSL صالح.",
"emails.certificate.thanks": "شكرا",
"emails.certificate.signature": "فريق {{project}}"
"emails.certificate.signature": "فريق {{project}}",
"emails.magicSession.securityPhrase": "عبارة الأمان لهذا البريد الإلكتروني هي {{phrase}}. يمكنك الوثوق بهذا البريد الإلكتروني إذا كانت هذه العبارة تطابق العبارة التي تظهر أثناء التسجيل.",
"emails.magicSession.optionUrl": "إذا لم تتمكن من تسجيل الدخول باستخدام الزر أعلاه، يرجى زيارة الرابط التالي:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "দক্ষিণ আমেৰিকা",
"emails.magicSession.optionButton": "Bấm vào nút bên dưới để đăng nhập an toàn vào tài khoản {{project}} của bạn. Nó sẽ hết hạn trong 1 giờ.",
"emails.magicSession.buttonText": "Inngå á {{project}}",
"emails.magicSession.optionUrl": "I apologize for the confusion, but you've indicated \"as\" as the country code. \"As\" does not correspond to any active ISO country code. If you could specify the correct country code or language, I would be happy to assist with the translation.",
"emails.magicSession.clientInfo": "I'm sorry, but you haven't provided the specific language associated with a country code for translation, and \"as\" doesn't correspond to any current ISO country code. Could you please clarify the target language you want the translation in?",
"emails.certificate.subject": "In the context of your request, it is not entirely clear what the country code \"as\" refers to. However, \"AS\" is often used as the country code for American Samoa, where the primary language is English. If you meant another \"as\" for a specific language, please provide clarification. If you did mean American Samoa, the translation would remain the same as the original text:\n\nCertificate failure for %s",
"emails.certificate.hello": "Since you haven't specified which country \"as\" refers to, I can't provide a translation. If you could provide the name of the country or another form of the country code, that would be very helpful.",
"emails.certificate.body": "Beklagar, men det är inte tillräckligt med information för att avgöra vilket lands specifika språk som avses med landskoden \"as\". \"AS\" kan antingen avse Amerikanska Samoa, vars officiella språk är engelska och samoanska, eller det kan avse en generell landskod. Om du kan ge mer information eller specificera ett land, kan jag ge en exakt översättning.",
"emails.certificate.footer": "Since you haven't specified the target language and only provided the country code \"as,\" which refers to American Samoa, where English and Samoan are the official languages, I will translate it into Samoan:\n\nO lau tusi pasi ua mavae o le a talafeagai mo aso e 30 talu ona tupu le tulaga muamua le manuia. Matou te fautuaina malosi le su'esu'e i lenei mataupu, a leai o le a leai sau vaega e iai se SSL fa'amaoniga talafeagai.",
"emails.certificate.thanks": "The language of the country with the country code \"AS\" which stands for American Samoa is primarily Samoan. The translation of \"Thanks\" in Samoan is:\n\nFa'afetai",
"emails.certificate.signature": "I'm sorry, but to provide a translation into the target language, I need to know the specific language you're referring to with the country code \"as.\" The country code \"AS\" is generally used for American Samoa, where the languages spoken are English and Samoan. If you need a translation into Samoan, please confirm, and I will proceed with the translation."
"emails.certificate.signature": "I'm sorry, but to provide a translation into the target language, I need to know the specific language you're referring to with the country code \"as.\" The country code \"AS\" is generally used for American Samoa, where the languages spoken are English and Samoan. If you need a translation into Samoan, please confirm, and I will proceed with the translation.",
"emails.magicSession.securityPhrase": "I apologize, but it appears there might be a misunderstanding with the country code provided. The country code \"as\" commonly refers to American Samoa, and the languages spoken there are English and Samoan. If translation into Samoan is desired, here it is:\n\nO le upu fa'amau mo lenei imeli o {{phrase}}. E mafai ona e talitonu i lenei imeli pe afai e ōgatusa le upu lea ma le upu na fa'aalia i le taimi o le saini i totonu.",
"emails.magicSession.optionUrl": "There appears to be a misunderstanding. The country code \"as\" is associated with American Samoa, where the primary language is English. Therefore, the translation would remain the same as English:\n\nIf you are unable to sign in using the button above, please visit the following link:"
}

View file

@ -224,7 +224,6 @@
"countries.zw": "Zimbabve",
"emails.magicSession.optionButton": "Aşağıdaki düyməyə basaraq {{project}} hesabınıza təhlükəsiz şəkildə daxil olun. Bu, 1 saat sonra müddəti bitəcək.",
"emails.magicSession.buttonText": "{{project}} layihəsinə daxil olun",
"emails.magicSession.optionUrl": "Əgər yuxarıdakı düymə görsənmirsə, aşağıdaki keçidi istifadə edin:",
"emails.magicSession.clientInfo": "Bu giriş, {{agentClient}} vasitəsi ilə {{agentDevice}} {{agentOs}} istifadə edərək tələb olunmuşdur. Əgər siz girişi tələb etməmisinizsə, bu e-poçtu təhlükəsiz şəkildə yoksayabilirsiniz.",
"emails.certificate.subject": "%s üçün sertifikat xətası",
"emails.certificate.hello": "Salam",
@ -238,5 +237,7 @@
"continents.eu": "Avropa",
"continents.na": "Şimali Amerika",
"continents.oc": "Okeaniya",
"continents.sa": "Cənubi Amerika"
"continents.sa": "Cənubi Amerika",
"emails.magicSession.securityPhrase": "Bu e-poçt üçün təhlükəsizlik ifadəsi {{phrase}}-dir. Əgər bu ifadə daxil olarkən göstərilən ifadə ilə üst-üstə düşürsə, bu e-poçta etibar edə bilərsiniz.",
"emails.magicSession.optionUrl": "Əgər yuxarıdakı düyməni istifadə edərək daxil ola bilmirsizsə, zəhmət olmasa aşağıdakı linkə daxil olun:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Паўднёвая Амерыка",
"emails.magicSession.optionButton": "Клікніце кнопку ніжэй, каб бяспечна ўвайсці ў свой рахунак {{project}}. Ён скончыцца праз 1 гадзіну.",
"emails.magicSession.buttonText": "Aanmelden bij {{project}}",
"emails.magicSession.optionUrl": "Als de knop hierboven niet weergegeven wordt, gebruik dan de volgende link:",
"emails.magicSession.clientInfo": "Als u niet om de aanmelding heeft gevraagd, kunt u deze e-mail gerust negeren.",
"emails.certificate.subject": "The country code BE refers to Belgium, which has three official languages: Dutch, French, and German. Please specify which language you would like the translation in.",
"emails.certificate.hello": "To provide you with the correct translation, I need to clarify the country code \"be\" you mentioned. It might refer to Belgium, which has three official languages: Dutch, French, and German. \n\nPlease specify which language you would like me to translate \"Hello\" into: Dutch, French, or German.",
"emails.certificate.body": "Certificaat voor uw domein '{{domain}}' kon niet worden gegenereerd. Dit is poging nr. {{attempt}}, en de fout werd veroorzaakt door: {{error}}",
"emails.certificate.footer": "Ваш папярэдні сертыфікат будзе дзейнічаць 30 дзён з моманту першай няўдачы. Мы вельмі рэкамендуем разабрацца ў гэтай сітуацыі, інакш ваш дамен застанецца без дзейнага сертыфіката SSL забеспячэння.",
"emails.certificate.thanks": "The country code BE stands for Belgium, where there are two main languages spoken: Dutch and French. Since you did not specify the language, I will provide the translation in both:\n\nDutch: Dank je\nFrench: Merci",
"emails.certificate.signature": "{{project}} équipe"
"emails.certificate.signature": "{{project}} équipe",
"emails.magicSession.securityPhrase": "De beveiligingszin voor deze e-mail is {{phrase}}. U kunt deze e-mail vertrouwen als deze zin overeenkomt met de zin die getoond wordt bij het aanmelden.",
"emails.magicSession.optionUrl": "Si vous n'arrivez pas à vous connecter en utilisant le bouton ci-dessus, veuillez visiter le lien suivant :"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Южна Америка",
"emails.magicSession.optionButton": "Натиснете бутона по-долу, за да се впишете сигурно във вашия {{project}} акаунт. Той ще изтече след 1 час.",
"emails.magicSession.buttonText": "Влезте в {{project}}",
"emails.magicSession.optionUrl": "Ако горният бутон не се показва, използвайте следния линк:",
"emails.magicSession.clientInfo": "Този вход беше заявен чрез {{agentClient}} на {{agentDevice}} {{agentOs}}. Ако не сте поискали входа, можете безопасно да игнорирате този имейл.",
"emails.certificate.subject": "Сертификатен провал за %s",
"emails.certificate.hello": "Здравейте",
"emails.certificate.body": "Сертификатът за вашия домейн '{{domain}}' не може да бъде генериран. Това е опит номер {{attempt}}, а причината за неуспеха е: {{error}}",
"emails.certificate.footer": "Предишният ви сертификат ще бъде валиден за 30 дни от първия неуспех. Настоятелно препоръчваме да разследвате този случай, в противен случай вашият домейн ще остане без валидно SSL комуникация.",
"emails.certificate.thanks": "Благодаря",
"emails.certificate.signature": "екип на {{project}}"
"emails.certificate.signature": "екип на {{project}}",
"emails.magicSession.securityPhrase": "Фразата за сигурност на този имейл е {{phrase}}. Можете да се доверите на този имейл, ако тази фраза съвпада с фразата, показана по време на вписването.",
"emails.magicSession.optionUrl": "Ако не можете да влезете чрез горния бутон, моля, посетете следния линк:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "दक्षिण अमेरिका",
"emails.magicSession.optionButton": "Klike sou bouton ki pi ba a pou ou konekte an sekirite nan kont {{project}} ou. Li ap ekspire nan 1 è.",
"emails.magicSession.buttonText": "There might be some confusion here, as there is no specific language associated with the country code \"bh,\" which stands for Bahrain. The primary language spoken in Bahrain is Arabic. Assuming you are asking for a translation into Arabic, the translation would be:\n\nتسجيل الدخول إلى {{project}}",
"emails.magicSession.optionUrl": "जदि उपरका बटन नै देखाई पड़त, तऽ निम्न लिंक के प्रयोग करी:",
"emails.magicSession.clientInfo": "Sorry, but I cannot provide the translation as \"bh\" is not a recognized ISO language code and does not correspond to any specific language. Please provide a valid language or country code for translation.",
"emails.certificate.subject": "लिए प्रमाणपत्र असफलता %s",
"emails.certificate.hello": "Namaste",
"emails.certificate.body": "Sorry, I am unable to provide the translation as there is no language associated with the country code \"bh.\" \"BH\" is the country code for Bahrain, where the official language is Arabic. Please provide specific instructions for the target language if Arabic translation is required.",
"emails.certificate.footer": "साँचे सर्टिफिकेट 30 दिन तक मान्य होता, पहिलका असफलता के बाद। हमनी के राउर से जोर देके कहतानी कि एह मामला के जांच करीं, ना त राउर डोमेन बिना जायज SSL संवाद के रह जाई.",
"emails.certificate.thanks": "धन्यवाद",
"emails.certificate.signature": "تیم {{project}}"
"emails.certificate.signature": "تیم {{project}}",
"emails.magicSession.securityPhrase": "La frase de seguridad para este correo electrónico es {{phrase}}. Puedes confiar en este correo electrónico si esta frase coincide con la frase mostrada durante el inicio de sesión.",
"emails.magicSession.optionUrl": "Yadi aap uppar diye gaye button ka upayog karke sign in nahi kar pa rahe hain, toh kripaya is link ka anusaran karein:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "দক্ষিণ আমেরিকা",
"emails.magicSession.optionButton": "নীচের বোতামে ক্লিক করুন আপনার {{project}} অ্যাকাউন্টে নিরাপদে সাইন ইন করতে। এটি ১ ঘন্টা পরে মেয়াদ উত্তীর্ণ হবে।",
"emails.magicSession.buttonText": "{{project}}-এ সাইন ইন করুন",
"emails.magicSession.optionUrl": "উপরের বোতামটি যদি না দেখায়, তাহলে নিম্নলিখিত লিংকটি ব্যবহার করুন:",
"emails.magicSession.clientInfo": "এই সাইন ইনটি {{agentClient}} ব্যবহার করে {{agentDevice}} {{agentOs}}-এ অনুরোধ করা হয়েছিল। যদি আপনি সাইন ইনের অনুরোধ করেননি, আপনি নিরাপদে এই ইমেইলটি উপেক্ষা করতে পারেন।",
"emails.certificate.subject": "%s-এর জন্য শংসাপত্র ব্যর্থতা",
"emails.certificate.hello": "হ্যালো",
"emails.certificate.body": "আপনার ডোমেইন '{{domain}}' এর জন্য সার্টিফিকেট জেনারেট করা যায়নি। এটি প্রচেষ্টা নম্বর {{attempt}}, এবং ব্যর্থতার কারণ হচ্ছে: {{error}}",
"emails.certificate.footer": "আপনার আগের সার্টিফিকেটটি প্রথম বিফলতার পর থেকে ৩০ দিনের জন্য বৈধ থাকবে। আমরা এই মামলাটি অনুসন্ধান করার জন্য প্রবলভাবে অনুরোধ করছি, নতুবা আপনার ডোমেইনটি বৈধ SSL যোগাযোগ ছাড়া চলে যাবে।",
"emails.certificate.thanks": "ধন্যবাদ",
"emails.certificate.signature": "{{project}} টিম"
"emails.certificate.signature": "{{project}} টিম",
"emails.magicSession.securityPhrase": "এই ইমেলের জন্য নিরাপত্তা বাক্যটি হল {{phrase}}। সাইন-ইনের সময় দেখানো বাক্যটির সাথে এই বাক্যটি মিলে গেলে আপনি এই ইমেইলকে বিশ্বাস করতে পারেন।",
"emails.magicSession.optionUrl": "উপরের বোতামটি ব্যবহার করে আপনি যদি সাইন ইন করতে অক্ষম হন, অনুগ্রহ করে নিম্নলিখিত লিঙ্কটি দেখুন:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Južna Amerika",
"emails.magicSession.optionButton": "Kliknite na dugme ispod kako biste se sigurno prijavili na svoj {{project}} račun. Istek će se dogoditi za 1 sat.",
"emails.magicSession.buttonText": "Prijavi se na {{project}}",
"emails.magicSession.optionUrl": "Ako se gornji gumb ne prikaže, koristite sljedeći link:",
"emails.magicSession.clientInfo": "Ova prijava je zatražena korištenjem {{agentClient}} na {{agentDevice}} {{agentOs}}. Ako niste zahtjevali prijavu, možete sigurno ignorirati ovaj e-mail.",
"emails.certificate.subject": "Nemogućnost certifikata za %s",
"emails.certificate.hello": "Zdravo",
"emails.certificate.body": "Certifikat za vaš domen '{{domain}}' nije mogao biti generisan. Ovo je pokušaj br. {{attempt}}, a greška je uzrokovana: {{error}}",
"emails.certificate.footer": "Vaš prethodni certifikat će biti važeći 30 dana od prvog neuspeha. Visoko preporučujemo da istražite ovaj slučaj, inače će vaš domen završiti bez važeće SSL komunikacije.",
"emails.certificate.thanks": "Hvala",
"emails.certificate.signature": "{{project}} tim"
"emails.certificate.signature": "{{project}} tim",
"emails.magicSession.securityPhrase": "Sigurnosna fraza za ovaj email je {{phrase}}. Ovom emailu možete vjerovati ako se fraza poklapa sa frazom prikazanom prilikom prijave.",
"emails.magicSession.optionUrl": "Ako ne možete da se prijavite koristeći gornje dugme, molimo posetite sledeći link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Amèrica del Sud",
"emails.magicSession.optionButton": "Feu clic al botó de sota per iniciar sessió de manera segura al vostre compte {{project}}. Caducarà en 1 hora.",
"emails.magicSession.buttonText": "Inicia sessió a {{project}}",
"emails.magicSession.optionUrl": "Si el botó superior no apareix, utilitzeu l'enllaç següent:",
"emails.magicSession.clientInfo": "Aquest inici de sessió s'ha sol·licitat utilitzant {{agentClient}} en {{agentDevice}} {{agentOs}}. Si no has sol·licitat l'inici de sessió, pots ignorar aquest correu electrònic amb seguretat.",
"emails.certificate.subject": "Error de certificat per a %s",
"emails.certificate.hello": "Hola",
"emails.certificate.body": "El certificat per al vostre domini '{{domain}}' no s'ha pogut generar. Aquest és l'intent núm. {{attempt}}, i el fracàs ha estat causat per: {{error}}",
"emails.certificate.footer": "El vostre certificat anterior serà vàlid durant 30 dies des de la primera fallada. Us recomanem encaridament que investigueu aquest cas, d'altra manera el vostre domini quedarà sense una comunicació SSL vàlida.",
"emails.certificate.thanks": "Gràcies",
"emails.certificate.signature": "equip {{project}}"
"emails.certificate.signature": "equip {{project}}",
"emails.magicSession.securityPhrase": "La frase de seguretat d'aquest correu electrònic és {{phrase}}. Podeu confiar en aquest correu si aquesta frase coincideix amb la frase mostrada durant l'inici de sessió.",
"emails.magicSession.optionUrl": "Si no podeu iniciar sessió utilitzant el botó de dalt, visiteu l'enllaç següent:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Jižní Amerika",
"emails.magicSession.optionButton": "Klikněte na tlačítko níže pro bezpečné přihlášení do vašeho účtu {{project}}. Platnost vyprší za 1 hodinu.",
"emails.magicSession.buttonText": "Přihlaste se k {{project}}",
"emails.magicSession.optionUrl": "Pokud se tlačítko výše nezobrazuje, použijte následující odkaz:",
"emails.magicSession.clientInfo": "Toto přihlášení bylo požadováno prostřednictvím {{agentClient}} na {{agentDevice}} {{agentOs}}. Pokud jste se nepřihlašovali, můžete tento e-mail bezpečně ignorovat.",
"emails.certificate.subject": "Selhání certifikátu pro %s",
"emails.certificate.hello": "Ahoj",
"emails.certificate.body": "Certifikát pro váš doménu '{{domain}}' se nepodařilo vygenerovat. Jedná se o pokus č. {{attempt}} a selhání bylo způsobeno: {{error}}",
"emails.certificate.footer": "Vaše předchozí certifikát bude platný 30 dní od prvního selhání. Důrazně doporučujeme vyšetřovat tento případ, jinak váš doménový server skončí bez platné komunikace SSL.",
"emails.certificate.thanks": "Děkuji",
"emails.certificate.signature": "tým {{project}}"
"emails.certificate.signature": "tým {{project}}",
"emails.magicSession.securityPhrase": "Bezpečnostní fráze pro tento e-mail je {{phrase}}. Tomuto e-mailu můžete důvěřovat, pokud tato fráze odpovídá frázi zobrazené při přihlášení.",
"emails.magicSession.optionUrl": "Pokud se nemůžete přihlásit pomocí výše uvedeného tlačítka, prosím navštivte následující odkaz:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Sydamerica",
"emails.magicSession.optionButton": "Klik på knappen nedenfor for sikkert at logge ind på din {{project}} konto. Den udløber om 1 time.",
"emails.magicSession.buttonText": "Log ind på {{project}}",
"emails.magicSession.optionUrl": "Hvis knappen herover ikke vises, skal du bruge følgende link:",
"emails.magicSession.clientInfo": "Denne log ind blev anmodet ved hjælp af {{agentClient}} på {{agentDevice}} {{agentOs}}. Hvis du ikke anmodede om log ind, kan du trygt ignorere denne e-mail.",
"emails.certificate.subject": "Certifikatfejl for %s",
"emails.certificate.hello": "Hej",
"emails.certificate.body": "Certifikatet til dit domæne '{{domain}}' kunne ikke genereres. Dette er forsøg nr. {{attempt}}, og fejlen blev forårsaget af: {{error}}",
"emails.certificate.footer": "Dit tidligere certifikat vil være gyldigt i 30 dage fra den første fejl. Vi anbefaler kraftigt at undersøge denne sag, ellers vil dit domæne ende uden en gyldig SSL-kommunikation.",
"emails.certificate.thanks": "Tak",
"emails.certificate.signature": "{{project}} hold"
"emails.certificate.signature": "{{project}} hold",
"emails.magicSession.securityPhrase": "Sikkerhedsfrasen for denne e-mail er {{phrase}}. Du kan stole på denne e-mail, hvis denne frase matcher den viste frase under log ind.",
"emails.magicSession.optionUrl": "Hvis du ikke kan logge ind ved at bruge knappen ovenfor, besøg venligst følgende link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Südamerika",
"emails.magicSession.optionButton": "Klicken Sie auf den unten stehenden Button, um sicher in Ihr {{project}}-Konto einzuloggen. Er verfällt in 1 Stunde.",
"emails.magicSession.buttonText": "Melden Sie sich bei {{project}} an",
"emails.magicSession.optionUrl": "Wenn die obige Schaltfläche nicht angezeigt wird, verwenden Sie folgenden Link:",
"emails.magicSession.clientInfo": "Dieser Anmeldeversuch wurde über {{agentClient}} auf {{agentDevice}} {{agentOs}} angefordert. Wenn Sie die Anmeldung nicht angefordert haben, können Sie diese E-Mail getrost ignorieren.",
"emails.certificate.subject": "Zertifikatsfehler für %s",
"emails.certificate.hello": "Hallo",
"emails.certificate.body": "Das Zertifikat für Ihre Domain \"{{domain}}\" konnte nicht erstellt werden. Dies ist der {{attempt}}. Versuch, und der Fehler wurde verursacht durch: {{error}}",
"emails.certificate.footer": "Ihr vorheriges Zertifikat ist ab dem ersten Fehler 30 Tage lang gültig. Wir empfehlen dringend, diesen Fall zu untersuchen, sonst wird Ihre Domain ohne gültige SSL-Kommunikation enden.",
"emails.certificate.thanks": "Danke",
"emails.certificate.signature": "{{project}} Team"
"emails.certificate.signature": "{{project}} Team",
"emails.magicSession.securityPhrase": "Die Sicherheitsphrase für diese E-Mail lautet {{phrase}}. Sie können dieser E-Mail vertrauen, wenn diese Phrase mit der Phrase übereinstimmt, die beim Anmelden angezeigt wurde.",
"emails.magicSession.optionUrl": "Wenn Sie sich nicht über den obigen Button anmelden können, besuchen Sie bitte den folgenden Link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Νότια Αμερική",
"emails.magicSession.optionButton": "Κάντε κλικ στο κουμπί παρακάτω για να συνδεθείτε με ασφάλεια στον λογαριασμό σας στο {{project}}. Θα λήξει σε 1 ώρα.",
"emails.magicSession.buttonText": "Συνδεθείτε στο {{project}}",
"emails.magicSession.optionUrl": "Εάν το παραπάνω κουμπί δεν εμφανίζεται, χρησιμοποιήστε τον ακόλουθο σύνδεσμο:",
"emails.magicSession.clientInfo": "Η σύνδεση αυτή ζητήθηκε χρησιμοποιώντας το {{agentClient}} στο {{agentDevice}} {{agentOs}}. Εάν δεν ζητήσατε τη σύνδεση, μπορείτε να αγνοήσετε με ασφάλεια αυτό το email.",
"emails.certificate.subject": "Αποτυχία πιστοποιητικού για το %s",
"emails.certificate.hello": "Γεια",
"emails.certificate.body": "Το πιστοποιητικό για τον τομέα σας '{{domain}}' δεν μπόρεσε να δημιουργηθεί. Αυτή είναι η προσπάθεια αρ. {{attempt}}, και η αποτυχία προκλήθηκε από: {{error}}",
"emails.certificate.footer": "Το προηγούμενο πιστοποιητικό σας θα είναι έγκυρο για 30 ημέρες από την πρώτη αποτυχία. Σας προτείνουμε ανεπιφύλακτα να ερευνήσετε αυτή την υπόθεση, διαφορετικά το domain σας θα καταλήξει χωρίς έγκυρη SSL επικοινωνία.",
"emails.certificate.thanks": "Ευχαριστώ",
"emails.certificate.signature": "ομάδα του {{project}}"
"emails.certificate.signature": "ομάδα του {{project}}",
"emails.magicSession.securityPhrase": "Η φράση ασφαλείας για αυτό το email είναι {{phrase}}. Μπορείτε να εμπιστευτείτε αυτό το email αν αυτή η φράση ταιριάζει με τη φράση που εμφανίζεται κατά την είσοδο.",
"emails.magicSession.optionUrl": "Εάν δεν μπορείτε να συνδεθείτε χρησιμοποιώντας το παραπάνω κουμπί, παρακαλώ επισκεφτείτε τον παρακάτω σύνδεσμο:"
}

View file

@ -13,8 +13,9 @@
"emails.magicSession.hello": "Hello,",
"emails.magicSession.optionButton": "Click the button below to securely sign in to your {{project}} account. It will expire in 1 hour.",
"emails.magicSession.buttonText": "Sign in to {{project}}",
"emails.magicSession.optionUrl": "If the button above doesn't show, use the following link:",
"emails.magicSession.optionUrl": "If you are unable to sign in using the button above, please visit the following link:",
"emails.magicSession.clientInfo": "This sign in was requested using {{agentClient}} on {{agentDevice}} {{agentOs}}. If you didn't request the sign in, you can safely ignore this email.",
"emails.magicSession.securityPhrase": "Security phrase for this email is {{phrase}}. You can trust this email if this phrase matches the phrase shown during sign in.",
"emails.magicSession.thanks": "Thanks,",
"emails.magicSession.signature": "{{project}} team",
"emails.recovery.subject": "Password Reset",

View file

@ -231,12 +231,13 @@
"settings.inspire": "\"La arto esti saĝa estas la arto scii kion preteratenti.\"",
"emails.magicSession.optionButton": "Alklaku la suban butonon por sekure ensaluti al via {{project}}-konto. Ĝi eksvalidiĝos post 1 horo.",
"emails.magicSession.buttonText": "Ensalutu al {{project}}",
"emails.magicSession.optionUrl": "Se la supra butono ne aperas, uzu la jenan ligilon:",
"emails.magicSession.clientInfo": "Ĉi tiu ensaluto estis petita per {{agentClient}} en {{agentDevice}} {{agentOs}}. Se vi ne petis la ensaluton, vi povas sekure ignori ĉi tiun retpoŝton.",
"emails.certificate.subject": "Atestilo malsukceso por %s",
"emails.certificate.hello": "Saluton",
"emails.certificate.body": "Atestilo por via retejo '{{domain}}' ne povis esti generita. Tio estas provo numero {{attempt}}, kaj la malsukceso estis kaŭzita de: {{error}}",
"emails.certificate.footer": "Via antaŭa atestilo estos valida dum 30 tagoj ekde la unua malsukceso. Ni tre rekomendas esplori ĉi tiun kazon, alie via domajno finiĝos sen valida SSL-komunikado.",
"emails.certificate.thanks": "Dankon",
"emails.certificate.signature": "teamo de {{project}}"
"emails.certificate.signature": "teamo de {{project}}",
"emails.magicSession.securityPhrase": "La sekureca frazo por ĉi tiu retpoŝto estas {{phrase}}. Vi povas fidi ĉi tiun retpoŝton se ĉi tiu frazo kongruas kun la frazo montrita dum ensaluto.",
"emails.magicSession.optionUrl": "Se vi ne povas ensaluti per la supra butono, bonvolu viziti la jenan ligilon:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "América del Sur",
"emails.magicSession.optionButton": "Haz clic en el botón de abajo para iniciar sesión de forma segura en tu cuenta de {{project}}. Caducará en 1 hora.",
"emails.magicSession.buttonText": "Iniciar sesión en {{project}}",
"emails.magicSession.optionUrl": "Si el botón de arriba no aparece, utiliza el siguiente enlace:",
"emails.magicSession.clientInfo": "Este inicio de sesión fue solicitado usando {{agentClient}} en {{agentDevice}} {{agentOs}}. Si no solicitaste el inicio de sesión, puedes ignorar este correo electrónico de forma segura.",
"emails.certificate.subject": "Fallo del certificado para %s",
"emails.certificate.hello": "Hola",
"emails.certificate.body": "El certificado para tu dominio '{{domain}}' no pudo generarse. Este es el intento n.º {{attempt}}, y el fallo fue causado por: {{error}}",
"emails.certificate.footer": "Su certificado anterior será válido durante 30 días desde el primer error. Recomendamos encarecidamente investigar este caso, de lo contrario, su dominio terminará sin una comunicación SSL válida.",
"emails.certificate.thanks": "Gracias",
"emails.certificate.signature": "equipo {{project}}"
"emails.certificate.signature": "equipo {{project}}",
"emails.magicSession.securityPhrase": "La frase de seguridad para este correo electrónico es {{phrase}}. Puedes confiar en este correo electrónico si esta frase coincide con la frase que se muestra durante el inicio de sesión.",
"emails.magicSession.optionUrl": "Si no puedes iniciar sesión utilizando el botón anterior, visita el siguiente enlace:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "آمریکای جنوبی",
"emails.magicSession.optionButton": "بر روی دکمه زیر کلیک کنید تا به صورت امن وارد حساب {{project}} خود شوید. این دکمه یک ساعت دیگر منقضی می‌شود.",
"emails.magicSession.buttonText": "ورود به {{project}}",
"emails.magicSession.optionUrl": "اگر دکمه بالا نمایش داده نشود، از لینک زیر استفاده کنید:",
"emails.magicSession.clientInfo": "این ورود به سیستم با استفاده از {{agentClient}} در {{agentDevice}} {{agentOs}} درخواست شده است. اگر شما این ورود به سیستم را درخواست نکرده‌اید، می‌توانید به راحتی این ایمیل را نادیده بگیرید.",
"emails.certificate.subject": "خطا در گواهینامه برای %s",
"emails.certificate.hello": "سلام",
"emails.certificate.body": "گواهی برای دامنه شما '{{domain}}' نتوانست تولید شود. این تلاش شماره {{attempt}} بود، و شکست به علت: {{error}} اتفاق افتاد.",
"emails.certificate.footer": "گواهی قبلی شما از زمان اولین شکست، به مدت 30 روز معتبر خواهد بود. ما به شدت توصیه می‌کنیم که این مورد را بررسی کنید، در غیر این صورت دامنه شما بدون ارتباط SSL معتبر باقی خواهد ماند.",
"emails.certificate.thanks": "متشکرم",
"emails.certificate.signature": "تیم {{project}}"
"emails.certificate.signature": "تیم {{project}}",
"emails.magicSession.securityPhrase": "عبارت امنیتی برای این ایمیل {{phrase}} است. اگر این عبارت با عبارت نشان داده شده در هنگام ورود به سیستم مطابقت داشت، می‌توانید به این ایمیل اعتماد کنید.",
"emails.magicSession.optionUrl": "اگر قادر به ورود با استفاده از دکمه بالا نیستید، لطفاً از لینک زیر دیدن فرمایید:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Etelä Amerikka",
"emails.magicSession.optionButton": "Napsauta alla olevaa painiketta kirjautuaksesi turvallisesti {{project}}-tiliisi. Se vanhenee tunnissa.",
"emails.magicSession.buttonText": "Kirjaudu sisään {{project}}",
"emails.magicSession.optionUrl": "Jos yllä oleva painike ei näy, käytä seuraavaa linkkiä:",
"emails.magicSession.clientInfo": "Tämä kirjautuminen pyydettiin käyttäen {{agentClient}} {{agentDevice}} {{agentOs}}. Jos et pyytänyt kirjautumista, voit huoletta jättää tämän sähköpostin huomiotta.",
"emails.certificate.subject": "Varmentotodistuksen vika %s:ssa",
"emails.certificate.hello": "Hei",
"emails.certificate.body": "Verkkotunnuksellesi '{{domain}}' ei voitu luoda sertifikaattia. Tämä oli yritysnumero {{attempt}}, ja epäonnistuminen johtui virheestä: {{error}}",
"emails.certificate.footer": "Aiempi sertifikaattisi on voimassa 30 päivää ensimmäisestä epäonnistumisesta lähtien. Suosittelemme tutkimaan tämän tapauksen, muuten verkkotunnuksesi jää ilman voimassa olevaa SSL-salausta.",
"emails.certificate.thanks": "Kiitos",
"emails.certificate.signature": "{{project}} tiimi"
"emails.certificate.signature": "{{project}} tiimi",
"emails.magicSession.securityPhrase": "Tämän sähköpostin turvalause on {{phrase}}. Voit luottaa tähän sähköpostiin, jos tämä lause vastaa kirjautumisen yhteydessä näytettyä lausetta.",
"emails.magicSession.optionUrl": "Jos et pysty kirjautumaan sisään yllä olevaa painiketta käyttäen, käy seuraavassa linkissä:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Suðuramerika",
"emails.magicSession.optionButton": "Trýst á knøttin niðanfyri fyri at rita trygt inn á tína {{project}} konto. Tað fer at ganga út um 1 tíma.",
"emails.magicSession.buttonText": "Innrita á {{project}}",
"emails.magicSession.optionUrl": "Um knøttin omanfyri ikki vísir, brúka so hesa leinkjuna:",
"emails.magicSession.clientInfo": "Hetta innritingarbeiðið varð umbiðið við {{agentClient}} á {{agentDevice}} {{agentOs}}. Um tú ikki bað um innritingina, kanst tú trygt ignoreri hendan teldupostin.",
"emails.certificate.subject": "Váttanarfeilur fyri %s",
"emails.certificate.hello": "Hallo",
"emails.certificate.body": "Váttan fyri títt øki '{{domain}}' kundi ikki verða framleidd. Hetta er roynd nr. {{attempt}}, og feilurin var orsakaður av: {{error}}",
"emails.certificate.footer": "Títt fyrra prógv verður gildaði í 30 dagar frá fyrstu miseydnaðu royndini. Vit mæla staðiliga til at kanna hesa støðuna, annars endar tín domæni uttan gildað SSL samskifti.",
"emails.certificate.thanks": "Takk",
"emails.certificate.signature": "{{project}} bólkur"
"emails.certificate.signature": "{{project}} bólkur",
"emails.magicSession.securityPhrase": "Trygdarorðið fyri hesa teldupostadressuna er {{phrase}}. Tú kanst líta á hesa teldupostadressu, um hetta orðið samsvarar við orðið víst tá tú ritaði inn.",
"emails.magicSession.optionUrl": "Um tú ikki fært innritað við at brúka knøttin omanfyri, vinarliga vitja hesa leinkjuna:"
}

View file

@ -237,6 +237,7 @@
"continents.sa": "Amérique du Sud",
"emails.magicSession.optionButton": "Cliquez sur le bouton ci-dessous pour vous connecter en toute sécurité à votre compte {{project}}. Il expirera dans 1 heure.",
"emails.magicSession.buttonText": "Connectez-vous à {{project}}",
"emails.magicSession.optionUrl": "Si le bouton ci-dessus ne s'affiche pas, utilisez le lien suivant :",
"emails.magicSession.clientInfo": "Cette connexion a été demandée en utilisant {{agentClient}} sur {{agentDevice}} {{agentOs}}. Si vous n'avez pas demandé cette connexion, vous pouvez ignorer cet email en toute sécurité."
"emails.magicSession.clientInfo": "Cette connexion a été demandée en utilisant {{agentClient}} sur {{agentDevice}} {{agentOs}}. Si vous n'avez pas demandé cette connexion, vous pouvez ignorer cet email en toute sécurité.",
"emails.magicSession.securityPhrase": "La phrase de sécurité pour cet email est {{phrase}}. Vous pouvez faire confiance à cet email si cette phrase correspond à celle affichée lors de la connexion.",
"emails.magicSession.optionUrl": "Si vous ne parvenez pas à vous connecter en utilisant le bouton ci-dessus, veuillez visiter le lien suivant :"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Meiriceá Theas",
"emails.magicSession.optionButton": "Cliceáil ar an gcnaipe thíos le síní isteach go sábháilte i do chuntas {{project}}. Rachaidh sé in éag i gceann 1 uair.",
"emails.magicSession.buttonText": "Sínigh isteach i {{project}}",
"emails.magicSession.optionUrl": "Mura n-éiríonn an cnaipe thuas le feiceáil, bain úsáid as an nasc seo a leanas:",
"emails.magicSession.clientInfo": "Rinneadh an logáil isteach seo a iarraidh ag baint úsáide as {{agentClient}} ar {{agentDevice}} {{agentOs}}. Mura ndearna tú an logáil isteach a iarraidh, is féidir leat neamhaird sábháilte a dhéanamh den ríomhphost seo.",
"emails.certificate.subject": "Teip deimhnithe do %s",
"emails.certificate.hello": "Dia dhuit",
"emails.certificate.body": "Níorbh fhéidir teastas a chruthú do do réimse '{{domain}}'. Is é seo iarracht uimh. {{attempt}}, agus ba é an locht a bhí air: {{error}}",
"emails.certificate.footer": "Beidh do theastas roimhe seo bailí ar feadh 30 lá ón gcéad theip. Molaimid go mór cás seo a fhiosrú, murach sin rachaidh do réimse gan cumarsáid SSL bailí.",
"emails.certificate.thanks": "Go raibh maith agat",
"emails.certificate.signature": "foireann {{project}}"
"emails.certificate.signature": "foireann {{project}}",
"emails.magicSession.securityPhrase": "Is é an abairt slándála don ríomhphost seo ná {{phrase}}. Is féidir muinín a bheith agat as an ríomhphost seo má mheaitseálann an abairt seo leis an abairt a taispeántar le linn sínithe isteach.",
"emails.magicSession.optionUrl": "Mura bhfuil tú in ann síniú isteach ag baint úsáid as an gcnaipe thuas, téigh chuig an nasc seo a leanas:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "દક્ષિણ અમેરિકા",
"emails.magicSession.optionButton": "નીચે આપેલ બટન પર ક્લિક કરો તમારા {{project}} ખાતામાં સુરક્ષિત રીતે સાઇન ઈન કરવા માટે. તે 1 કલાકમાં સમાપ્ત થઈ જશે.",
"emails.magicSession.buttonText": "સાઇન ઇન કરો {{project}}",
"emails.magicSession.optionUrl": "જો ઉપરનું બટન દેખાતું નથી, તો નીચેની લિંકનો ઉપયોગ કરો:",
"emails.magicSession.clientInfo": "આ સાઇન ઇન વિનંતી {{agentClient}} નો ઉપયોગ કરીને {{agentDevice}} {{agentOs}} પર કરવામાં આવી હતી. જો તમે સાઇન ઇનની વિનંતી કરી ન હોય, તો આ ઇમેઇલને સલામત રીતે અવગણી શકો છો.",
"emails.certificate.subject": "પ્રમાણપત્ર નિષ્ફળતા %s માટે",
"emails.certificate.hello": "હેલો",
"emails.certificate.body": "તમારા ડોમેન '{{domain}}' માટેનું પ્રમાણપત્ર બનાવી શકાયું નથી. આ પ્રયાસ નંબર {{attempt}} છે, અને ભૂલ આવા કારણે થયું છે: {{error}}",
"emails.certificate.footer": "તમારું અગાઉનું પ્રમાણપત્ર પ્રથમ નિષ્ફળતા થી ૩૦ દિવસ સુધી માન્ય રહેશે. અમે આ કેસની તપાસ કરવાની દૃઢપણે ભલામણ કરીએ છીએ, નહીં તો તમારું ડોમેન માન્ય SSL સંવાદ વિનાનું રહી જશે.",
"emails.certificate.thanks": "Dhanyavad",
"emails.certificate.signature": "પ્રોજેક્ટ ટીમ"
"emails.certificate.signature": "પ્રોજેક્ટ ટીમ",
"emails.magicSession.securityPhrase": "આ ઇમેઇલ માટેનું સુરક્ષા વાક્ય {{phrase}} છે. જો આ વાક્ય સાઇન ઇન દરમિયાન દર્શાવેલા વાક્ય સાથે મેળ ખાય તો તમે આ ઇમેઇલ પર વિશ્વાસ કરી શકો છો.",
"emails.magicSession.optionUrl": "જો તમે ઉપરની બટનનો ઉપયોગ કરીને સાઇન ઇન કરી શકતા નથી, કૃપા કરીને નીચેની લિંક પર જાઓ:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "דרום אמריקה",
"emails.magicSession.optionButton": "לחץ על הכפתור למטה כדי להיכנס לחשבון {{project}} שלך באופן מאובטח. תוקף הכניסה יפוג תוך שעה.",
"emails.magicSession.buttonText": "היכנס ל-{{project}}",
"emails.magicSession.optionUrl": "אם הכפתור למעלה לא מופיע, השתמש בקישור הבא:",
"emails.magicSession.clientInfo": "ההתחברות הזו נעשתה באמצעות {{agentClient}} על {{agentDevice}} {{agentOs}}. אם לא ביקשת את ההתחברות הזו, באפשרותך להתעלם בבטחה מהאימייל הזה.",
"emails.certificate.subject": "תקלת תעודה עבור %s",
"emails.certificate.hello": "שלום",
"emails.certificate.body": "תעודה עבור הדומיין '{{domain}}' לא ניתנה ליצירה. זו ניסיונות מספר {{attempt}}, והכישלון נגרם על ידי: {{error}}",
"emails.certificate.footer": "תעודתך הקודמת תהיה בתוקף ל-30 ימים מהכשל הראשון. אנו ממליצים בחום לבדוק את המקרה הזה, אחרת הדומיין שלך יישאר ללא אמצעי תקשורת SSL תקף.",
"emails.certificate.thanks": "תודה",
"emails.certificate.signature": "צוות {{project}}"
"emails.certificate.signature": "צוות {{project}}",
"emails.magicSession.securityPhrase": "משפט הביטחון עבור הודעת הדוא\"ל הזו הוא {{phrase}}. תוכל לסמוך על הודעת הדוא\"ל הזו אם המשפט הזה תואם למשפט שהוצג בעת ההתחברות.",
"emails.magicSession.optionUrl": "אם אינך יכול להיכנס באמצעות הכפתור למעלה, בקר בקישור הבא:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "दक्षिण अमेरिका",
"emails.magicSession.optionButton": "नीचे दिए गए बटन पर क्लिक करके अपने {{project}} खाते में सुरक्षित रूप से साइन इन करें। यह 1 घंटे में समाप्त हो जाएगा।",
"emails.magicSession.buttonText": "{{project}} में साइन इन करें",
"emails.magicSession.optionUrl": "यदि ऊपर दिया गया बटन नहीं दिख रहा है, तो निम्नलिखित लिंक का उपयोग करें:",
"emails.magicSession.clientInfo": "यह साइन इन {{agentClient}} का उपयोग करके {{agentDevice}} {{agentOs}} पर किया गया था। यदि आपने साइन इन का अनुरोध नहीं किया है, तो आप इस ईमेल को सुरक्षित रूप से अनदेखा कर सकते हैं।",
"emails.certificate.subject": "%s के लिए प्रमाणपत्र विफलता",
"emails.certificate.hello": "नमस्ते",
"emails.certificate.body": "आपके डोमेन '{{domain}}' के लिए प्रमाणपत्र उत्पन्न नहीं किया जा सका। यह प्रयास संख्या {{attempt}} है, और असफलता का कारण था: {{error}}",
"emails.certificate.footer": "आपका पिछला प्रमाणपत्र पहली असफलता के बाद 30 दिनों के लिए मान्य होगा। हम इस मामले की जांच करने की दृढ़ता से सिफारिश करते हैं, अन्यथा आपका डोमेन वैध SSL संचार के बिना छूट जाएगा।",
"emails.certificate.thanks": "धन्यवाद",
"emails.certificate.signature": "{{project}} टीम"
"emails.certificate.signature": "{{project}} टीम",
"emails.magicSession.securityPhrase": "इस ईमेल का सुरक्षा वाक्यांश {{phrase}} है। यदि यह वाक्यांश साइन इन के दौरान दिखाए गए वाक्यांश से मेल खाता है तो आप इस ईमेल पर भरोसा कर सकते हैं।",
"emails.magicSession.optionUrl": "यदि आप ऊपर दिए गए बटन का उपयोग करके साइन इन नहीं कर पा रहे हैं, कृपया निम्नलिखित लिंक पर जाएँ:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Južna Amerika",
"emails.magicSession.optionButton": "Kliknite gumb ispod kako biste sigurno prijavili u svoj {{project}} račun. Istek će za 1 sat.",
"emails.magicSession.buttonText": "Prijavite se u {{project}}",
"emails.magicSession.optionUrl": "Ako gumb iznad se ne prikazuje, upotrijebite sljedeći link:",
"emails.magicSession.clientInfo": "Ova se prijava zatražila koristeći {{agentClient}} na uređaju {{agentDevice}} {{agentOs}}. Ako niste zatražili prijavu, možete slobodno zanemariti ovaj e-mail.",
"emails.certificate.subject": "Nepostojanje certifikata za %s",
"emails.certificate.hello": "Pozdrav",
"emails.certificate.body": "Certifikat za vašu domenu '{{domain}}' nije mogao biti generiran. Ovo je pokušaj br. {{attempt}}, a neuspjeh je uzrokovan: {{error}}",
"emails.certificate.footer": "Vaš prethodni certifikat bit će važeći 30 dana od prvog neuspjeha. Visoko preporučujemo istraživanje ovog slučaja, inače će vaša domena završiti bez važeće SSL komunikacije.",
"emails.certificate.thanks": "Hvala",
"emails.certificate.signature": "tim {{project}}"
"emails.certificate.signature": "tim {{project}}",
"emails.magicSession.securityPhrase": "Sigurnosna fraza za ovaj e-mail je {{phrase}}. Ovom e-mailu možete vjerovati ako se fraza podudara s frazom prikazanom tijekom prijave.",
"emails.magicSession.optionUrl": "Ako se ne možete prijaviti koristeći gornji gumb, posjetite sljedeću poveznicu:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Dél-Amerika",
"emails.magicSession.optionButton": "Kattintson az alábbi gombra, hogy biztonságosan bejelentkezzen a {{project}} fiókjába. A link 1 óra múlva lejár.",
"emails.magicSession.buttonText": "Jelentkezzen be a {{project}} szolgáltatásba.",
"emails.magicSession.optionUrl": "Ha a fenti gomb nem jelenik meg, használja a következő linket:",
"emails.magicSession.clientInfo": "Ezt a bejelentkezést a(z) {{agentClient}} használatával kérték az Ön {{agentDevice}} {{agentOs}} eszközén. Ha Ön nem kezdeményezte ezt a bejelentkezést, nyugodtan hagyja figyelmen kívül ezt az e-mailt.",
"emails.certificate.subject": "Tanúsítvány hiba a következőhöz: %s",
"emails.certificate.hello": "Szia",
"emails.certificate.body": "Az Ön '{{domain}}' domainjához a tanúsítvány nem generálható. Ez a {{attempt}}. kísérlet, és a következő hiba okozta: {{error}}",
"emails.certificate.footer": "Az előző tanúsítvány 30 napig lesz érvényes az első hiba óta. Nagyon ajánljuk, hogy vizsgálja meg ezt az esetet, különben a domainje érvényes SSL kommunikáció nélkül marad.",
"emails.certificate.thanks": "Köszönöm",
"emails.certificate.signature": "{{project}} csapat"
"emails.certificate.signature": "{{project}} csapat",
"emails.magicSession.securityPhrase": "Az e-mailhez tartozó biztonsági kifejezés: {{phrase}}. Megbízhat ebben az e-mailben, ha ez a kifejezés megegyezik a bejelentkezéskor megjelenített kifejezéssel.",
"emails.magicSession.optionUrl": "Amennyiben az előző gomb használatával nem tud bejelentkezni, kérjük látogassa meg a következő linket:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Հարավային Ամերիկա",
"emails.magicSession.optionButton": "Սեղմեք ներքևի կոճակը՝ ապահով մուտք գործելու {{project}} հաշիվդ։ Այն կանցնի 1 ժամից։",
"emails.magicSession.buttonText": "Մուտք գործեք {{project}} համար",
"emails.magicSession.optionUrl": "Եթե վերևի կոճակը չի բացվում, օգտագործեք հետևյալ հղումը՝",
"emails.magicSession.clientInfo": "Սա մուտք գործելը խնդրվել է `{{agentClient}}`-ի միջոցով {{agentDevice}} {{agentOs}}-ում: Եթե դուք չեք խնդրել մուտք գործելը, ապա կարող եք անտեղյակ մնալ այս էլփոստից:",
"emails.certificate.subject": "%s համար վկայագրի ձախողում",
"emails.certificate.hello": "Բարև",
"emails.certificate.body": "Ձեր '{{domain}}' տիրույթի համար գերծանգը չի ստացվել։ Սա արդեն {{attempt}} փորձն է, և ձախողումը հետևանք է՝ {{error}}։",
"emails.certificate.footer": "Ձեր նախորդ վկայագիրը կմնա վավերական 30 օրվա ընթացքում առաջին ձախողումից հետո: Մենք խորհրդանշում ենք հետաքրքրել այս դեպքը, հակառակ դեպքում Ձեր տիրույթը կմնա առանց վավերական SSL կապի:",
"emails.certificate.thanks": "Շնորհակալ եմ",
"emails.certificate.signature": "{{project}} թիմ"
"emails.certificate.signature": "{{project}} թիմ",
"emails.magicSession.securityPhrase": "Այս էլհասցեի անվտանգության արտահայտությունը {{phrase}} է: Դուք կարող եք հավատալ այս էլհասցեին, եթե այդ արտահայտությունը համընկնում է ներմուծման պրոցեսին՝ երբ դուք գրանցվել եք։",
"emails.magicSession.optionUrl": "Եթե չեք կարող մուտք գործել վերը նշված կոճակով, այցելեք հետևյալ հղումը՝"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Amerika Selatan",
"emails.magicSession.optionButton": "Klik tombol di bawah ini untuk masuk ke akun {{project}} Anda dengan aman. Ini akan kedaluwarsa dalam 1 jam.",
"emails.magicSession.buttonText": "Masuk ke {{project}}",
"emails.magicSession.optionUrl": "Jika tombol di atas tidak muncul, gunakan link berikut:",
"emails.magicSession.clientInfo": "Tanda masuk ini diminta menggunakan {{agentClient}} di {{agentDevice}} {{agentOs}}. Jika Anda tidak meminta untuk masuk, Anda dapat mengabaikan email ini dengan aman.",
"emails.certificate.subject": "Kegagalan sertifikat untuk %s",
"emails.certificate.hello": "Halo",
"emails.certificate.body": "Sertifikat untuk domain Anda '{{domain}}' tidak dapat dibuat. Ini adalah percobaan ke-{{attempt}}, dan kegagalan disebabkan oleh: {{error}}",
"emails.certificate.footer": "Sertifikat sebelumnya Anda akan berlaku selama 30 hari sejak kegagalan pertama. Kami sangat menyarankan untuk menyelidiki kasus ini, jika tidak domain Anda akan berakhir tanpa komunikasi SSL yang valid.",
"emails.certificate.thanks": "Terima kasih",
"emails.certificate.signature": "tim {{project}}"
"emails.certificate.signature": "tim {{project}}",
"emails.magicSession.securityPhrase": "Frasa keamanan untuk email ini adalah {{phrase}}. Anda dapat mempercayai email ini jika frasa tersebut cocok dengan frasa yang ditampilkan saat masuk.",
"emails.magicSession.optionUrl": "Jika Anda tidak dapat masuk menggunakan tombol di atas, silakan kunjungi tautan berikut:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Suður Ameríka",
"emails.magicSession.optionButton": "Smelltu á hnappinn hér fyrir neðan til að skrá þig örugglega inn á {{project}} reikninginn þinn. Hann rennur út eftir 1 klukkustund.",
"emails.magicSession.buttonText": "Skráðu þig inn á {{project}}",
"emails.magicSession.optionUrl": "Ef takkinn að ofan birtist ekki skal nota eftirfarandi hlekk:",
"emails.magicSession.clientInfo": "Þessi innskráning var óskað eftir með {{agentClient}} á {{agentDevice}} {{agentOs}}. Ef þú baðst ekki um innskráninguna geturðu hundsað þennan tölvupóst örugglega.",
"emails.certificate.subject": "Vottorðabilun fyrir %s",
"emails.certificate.hello": "Halló",
"emails.certificate.body": "Vottorð fyrir léninu þínu '{{domain}}' gat ekki verið búið til. Þetta er tilraun nr. {{attempt}}, og mistökin voru af völdum: {{error}}",
"emails.certificate.footer": "Fyrri vottorðið þitt verður gilt í 30 daga frá fyrstu mistökum. Við mælum eindregið með því að rannsaka þetta tilvik, ella mun lén þitt enda án gildrar SSL-samskipta.",
"emails.certificate.thanks": "Takk",
"emails.certificate.signature": "{{project}} liðið"
"emails.certificate.signature": "{{project}} liðið",
"emails.magicSession.securityPhrase": "Öryggisfrasi fyrir þetta tölvupóst er {{phrase}}. Þú getur treyst þessum tölvupósti ef þessi frasi passar við frasann sem birtist við innskráningu.",
"emails.magicSession.optionUrl": "Ef þú getur ekki skráð þig inn með hnappnum hér að ofan, vinsamlegast heimsækðu eftirfarandi tengil:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Sud America",
"emails.magicSession.optionButton": "Fai clic sul pulsante qui sotto per accedere in modo sicuro al tuo account {{project}}. Scadrà tra 1 ora.",
"emails.magicSession.buttonText": "Accedi a {{project}}",
"emails.magicSession.optionUrl": "Se il pulsante sopra non appare, utilizza il seguente link:",
"emails.magicSession.clientInfo": "Questo accesso è stato richiesto utilizzando {{agentClient}} su {{agentDevice}} {{agentOs}}. Se non hai richiesto l'accesso, puoi tranquillamente ignorare questa email.",
"emails.certificate.subject": "Certificato non valido per %s",
"emails.certificate.hello": "Ciao",
"emails.certificate.body": "Il certificato per il tuo dominio '{{domain}}' non ha potuto essere generato. Questo è il tentativo n. {{attempt}}, e l'errore è stato causato da: {{error}}",
"emails.certificate.footer": "Il tuo certificato precedente sarà valido per 30 giorni dalla prima mancata riuscita. Consigliamo vivamente di indagare su questo caso, altrimenti il tuo dominio si troverà senza una valida comunicazione SSL.",
"emails.certificate.thanks": "Grazie",
"emails.certificate.signature": "team {{project}}"
"emails.certificate.signature": "team {{project}}",
"emails.magicSession.securityPhrase": "La frase di sicurezza per questa email è {{phrase}}. Puoi fidarti di questa email se questa frase corrisponde alla frase mostrata durante l'accesso.",
"emails.magicSession.optionUrl": "Se non riesci ad accedere utilizzando il pulsante qui sopra, ti preghiamo di visitare il seguente link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "南アメリカ",
"emails.magicSession.optionButton": "以下のボタンをクリックして、安全に{{project}}アカウントにサインインしてください。有効期限は1時間です。",
"emails.magicSession.buttonText": "{{project}} にサインイン",
"emails.magicSession.optionUrl": "上のボタンが表示されない場合は、次のリンクを使用してください:",
"emails.magicSession.clientInfo": "このサインインは{{agentClient}}を使用して{{agentDevice}} {{agentOs}}で要求されました。サインインを要求していない場合は、このメールを安全に無視してください。",
"emails.certificate.subject": "%s の証明書エラー",
"emails.certificate.hello": "こんにちは",
"emails.certificate.body": "ドメイン「{{domain}}」の証明書を生成できませんでした。これは試行回数{{attempt}}で、原因は以下のエラーです: {{error}}",
"emails.certificate.footer": "以前の証明書は最初の失敗から30日間有効です。この問題を調査することを強く推奨します。さもなければ、ドメインは有効なSSL通信なしで終わってしまいます。",
"emails.certificate.thanks": "ありがとう",
"emails.certificate.signature": "{{project}} チーム"
"emails.certificate.signature": "{{project}} チーム",
"emails.magicSession.securityPhrase": "このメールのセキュリティフレーズは{{phrase}}です。サインイン時に表示されたフレーズと一致する場合、このメールは信頼できます。",
"emails.magicSession.optionUrl": "上記のボタンを使用してサインインすることができない場合は、次のリンクにアクセスしてください:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Amérika Kidul",
"emails.magicSession.optionButton": "Klik tombol ing ngisor iki kanggo mlebu kanthi aman ing akun {{project}} panjenengan. Bakal kadaluwarsa sajroning 1 jam.",
"emails.magicSession.buttonText": "Mlebu ing {{project}}",
"emails.magicSession.optionUrl": "Yen tombol ing ndhuwur ora katon, gunakna tautan ing ngisor iki:",
"emails.magicSession.clientInfo": "Penandatanganan iki dijaluk nganggo {{agentClient}} ing {{agentDevice}} {{agentOs}}. Yen panjenengan ora njaluk penandatanganan, panjenengan bisa ngabaikan email iki kanthi aman.",
"emails.certificate.subject": "Gagal sertifikat kanggo %s",
"emails.certificate.hello": "Halo",
"emails.certificate.body": "Sertifikat kanggo domain panjenengan '{{domain}}' ora bisa digawe. Iki nyoba nomer {{attempt}}, lan gagal amarga: {{error}}",
"emails.certificate.footer": "Sertifikat sadurunge bakal tetep sah sajrone 30 dina wiwit kagagalan pisanan. Kita menehi saran sing kuat supaya panjenengan nyelidiki kasus iki, manawa-mawa domain panjenengan bakal pungkasan tanpa komunikasi SSL sing sah.",
"emails.certificate.thanks": "Matur nuwun",
"emails.certificate.signature": "tim {{project}}"
"emails.certificate.signature": "tim {{project}}",
"emails.magicSession.securityPhrase": "Frasa keamanan kanggo email iki yaiku {{phrase}}. Sampeyan bisa percaya marang email iki yen frasa iki cocog karo frasa sing ditampilake nalika mlebu.",
"emails.magicSession.optionUrl": "Yen sampeyan ora bisa mlebu nganggo tombol ing ndhuwur, monggo ngunjungi pranala ing ngisor iki:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "អាមេរិកខាងត្បូង",
"emails.magicSession.optionButton": "ចុចប៊ូតុងខាងក្រោមដើម្បីចូលប្រើគណនី {{project}} របស់អ្នកដោយសុវត្ថិភាព។ វានឹងផុតកំណត់ក្នុងរយៈពេល 1 ម៉ោង។",
"emails.magicSession.buttonText": "ចូលទៅកាន់ {{project}}",
"emails.magicSession.optionUrl": "ប្រសិនបើប៊ូតុងខាងលើមិនបង្ហាញ សូមប្រើតំណភ្ជាប់ខាងក្រោម៖",
"emails.magicSession.clientInfo": "ការចូលប្រើនេះត្រូវបានស្នើរអោយប្រើ {{agentClient}} នៅលើ {{agentDevice}} {{agentOs}}។ ប្រសិនបើអ្នកមិនបានស្នើរការចូលប្រើនេះ អ្នកអាចមិនអើពើនឹងអ៊ីម៉ែលនេះបាន។",
"emails.certificate.subject": "បរាជ័យនៃវិញ្ញាបនបត្រសម្រាប់ %s",
"emails.certificate.hello": "សួស្តី",
"emails.certificate.body": "សញ្ញាបត្រសម្រាប់ដែន '{{domain}}' របស់អ្នកមិនអាចបង្កើតបានទេ។ នេះគឺជាការព្យាយាមលេខ {{attempt}} ហើយភាពបរាជ័យត្រូវបានបង្កដោយ: {{error}}",
"emails.certificate.footer": "វិញ្ញាបនបត្រមុនរបស់អ្នកនឹងនៅមានសុពលភាពរយៈពេល 30 ថ្ងៃចាប់ពីការបរាជ័យលើកដំបូង។ យើងខ្ញុំណែនាំយ៉ាងខ្លាំងអោយស្រាវជ្រាវលើករណីនេះ, បើមិនដូច្នេះទេដីមែនរបស់អ្នកនឹងបញ្ចប់ដោយគ្មានការតភ្ជាប់ SSL មានសុពលភាព។",
"emails.certificate.thanks": "អរគុណ",
"emails.certificate.signature": "ក្រុម {{project}}"
"emails.certificate.signature": "ក្រុម {{project}}",
"emails.magicSession.securityPhrase": "ឃ្លាសម្ងាត់សម្រាប់អ៊ីមែលនេះគឺ {{phrase}}។ អ្នកអាចទុកចិត្តលើអ៊ីមែលនេះប្រសិនបើឃ្លានេះត្រូវគ្នាជាមួយឃ្លាដែលបង្ហាញឡើងពេលចូលប្រើ។",
"emails.magicSession.optionUrl": "ប្រសិនបើអ្នកមិនអាចចូលប្រើប្រាស់ដោយប្រើប៊ូតុងខាងលើនេះទេ សូមចូលទៅកាន់តំណភ្ជាប់ខាងក្រោម៖"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "ದಕ್ಷಿಣ ಅಮೆರಿಕಾ",
"emails.magicSession.optionButton": "ಕೆಳಗಿನ ಬಟನ್ ಒತ್ತಿ ನಿಮ್ಮ {{project}} ಖಾತೆಗೆ ಸುರಕ್ಷಿತವಾಗಿ ಸೈನ್ ಇನ್ ಮಾಡಿ. ಇದು 1 ಗಂಟೆಯಲ್ಲಿ ಅವಧಿ ಮುಗಿಯುತ್ತದೆ.",
"emails.magicSession.buttonText": "ಸೈನ್ ಇನ್ ಮಾಡಿ {{project}}",
"emails.magicSession.optionUrl": "ಮೇಲಿನ ಬಟನ್ ತೋರಿಸದಿದ್ದರೆ, ಕೆಳಗಿನ ಲಿಂಕ್ ಬಳಸಿ:",
"emails.magicSession.clientInfo": "ಈ ಸೈನ್ ಇನ್ ಅನ್ನು {{agentClient}} ಬಳಸಿ {{agentDevice}} {{agentOs}} ಮೂಲಕ ಕೋರಲಾಗಿದೆ. ನೀವು ಸೈನ್ ಇನ್ ಅನ್ನು ಕೋರಿಲ್ಲದಿದ್ದರೆ, ನೀವು ಈ ಇಮೇಲ್ ಅನ್ನು ಸುರಕ್ಷಿತವಾಗಿ ನಿರ್ಲಕ್ಷಿಸಬಹುದು.",
"emails.certificate.subject": "ಪ್ರಮಾಣಪತ್ರ ವೈಫಲ್ಯ ಇದಕ್ಕಾಗಿ %s",
"emails.certificate.hello": "ಹಲೋ\n",
"emails.certificate.body": "ನಿಮ್ಮ ಡೊಮೇನ್ '{{domain}}' ಗಾಗಿ ಪ್ರಮಾಣಪತ್ರ ರಚಿಸಲು ಸಾಧ್ಯವಾಗಲಿಲ್ಲ. ಇದು ಪ್ರಯತ್ನ ಸಂಖ್ಯೆ {{attempt}} ಮತ್ತು ಈ ವಿಫಲತೆಯು ಕಾರಣವಾಗಿದೆ: {{error}}",
"emails.certificate.footer": "ನಿಮ್ಮ ಹಿಂದಿನ ಪ್ರಮಾಣಪತ್ರವು ಮೊದಲ ವೈಫಲ್ಯದಿಂದ 30 ದಿನಗಳ ಕಾಲ ಮಾನ್ಯವಾಗಿರುತ್ತದೆ. ಈ ಪ್ರಕರಣವನ್ನು ತನಿಖೆ ಮಾಡುವುದರಲ್ಲಿ ನಾವು ಬಹಳಷ್ಟು ಶಿಫಾರಸು ಮಾಡುತ್ತೇವೆ, ಇಲ್ಲವೇ ನಿಮ್ಮ ಡೊಮೈನ್ ಮಾನ್ಯವಲ್ಲದ SSL ಸಂವಹನದೊಂದಿಗೆ ಉಳಿದುಬಿಡುತ್ತದೆ.",
"emails.certificate.thanks": "ಧನ್ಯವಾದಗಳು",
"emails.certificate.signature": "ತಂಡ"
"emails.certificate.signature": "ತಂಡ",
"emails.magicSession.securityPhrase": "ಈ ಇಮೇಲ್‌ಗಾಗಿ ಭದ್ರತಾ ಪದ ಇದೆ {{phrase}}. ಸೈನ್ ಇನ್ ಮಾಡುವಾಗ ತೋರಿದ ಪದವು ಈ ಪದವು ಹೊಂದಿಕೆಯಾಗಿದ್ದರೆ ನೀವು ಈ ಇಮೇಲ್‌ಅನ್ನು ನಂಬಬಹುದು.",
"emails.magicSession.optionUrl": "ಮೇಲಿನ ಬಟನ್ ಬಳಸಿ ನೀವು ಸೈನ್ ಇನ್ ಮಾಡಲು ಅಸಮರ್ಥರಾಗಿದ್ದರೆ, ದಯವಿಟ್ಟು ಈ ಕೆಳಗಿನ ಲಿಂಕ್ ಭೇಟಿಯನ್ನು ಕೊಡಿ:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "남아메리카",
"emails.magicSession.optionButton": "아래 버튼을 클릭하여 안전하게 {{project}} 계정에 로그인하세요. 1시간 후에 만료됩니다.",
"emails.magicSession.buttonText": "{{project}}에 로그인하세요",
"emails.magicSession.optionUrl": "위의 버튼이 보이지 않으면 다음 링크를 사용하세요:",
"emails.magicSession.clientInfo": "이 로그인은 {{agentClient}}을(를) 사용하여 {{agentDevice}} {{agentOs}}에서 요청되었습니다. 로그인을 요청하지 않았다면, 이 이메일을 안전하게 무시하셔도 됩니다.",
"emails.certificate.subject": "%s 인증서 오류",
"emails.certificate.hello": "안녕하세요",
"emails.certificate.body": "'{{domain}}' 도메인에 대한 인증서를 생성할 수 없었습니다. 이것은 시도 번호 {{attempt}}이며, 다음과 같은 이유로 실패하였습니다: {{error}}",
"emails.certificate.footer": "이전 인증서는 첫 실패로부터 30일 동안 유효할 것입니다. 이 문제를 조사할 것을 강력히 권장합니다, 그렇지 않으면 도메인이 유효한 SSL 통신 없이 남게 될 것입니다.",
"emails.certificate.thanks": "감사합니다",
"emails.certificate.signature": "{{project}} 팀"
"emails.certificate.signature": "{{project}} 팀",
"emails.magicSession.securityPhrase": "이 이메일의 보안 구절은 {{phrase}}입니다. 로그인할 때 표시되는 구절과 일치한다면 이 이메일을 신뢰할 수 있습니다.",
"emails.magicSession.optionUrl": "위의 버튼을 사용하여 로그인할 수 없다면, 다음 링크를 방문해 주세요:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "America del Sur",
"emails.magicSession.optionButton": "Preme el boton infra pro signar securmente in tu conto de {{project}}. Illo expirara in 1 hora.",
"emails.magicSession.buttonText": "Inicia sesión en {{project}}",
"emails.magicSession.optionUrl": "Si el botón de arriba no se muestra, utilice el siguiente enlace:",
"emails.magicSession.clientInfo": "Esta conexión fue solicitada usando {{agentClient}} en {{agentDevice}} {{agentOs}}. Si usted no solicitó la conexión, puede ignorar este correo electrónico de forma segura.",
"emails.certificate.subject": "Fracaso del certificado para %s",
"emails.certificate.hello": "There seems to be a misunderstanding. The country code \"LA\" refers to Laos, and the primary language used there is Lao. However, without specific instructions to translate into Lao, I cannot proceed with the translation. If Lao is indeed the intended language, please confirm, and I will provide you with the translation.",
"emails.certificate.body": "El certificado para su dominio '{{domain}}' no pudo ser generado. Este es el intento número {{attempt}}, y el fallo fue causado por: {{error}}.",
"emails.certificate.footer": "Su certificado anterior será válido por 30 días desde el primer fallo. Recomendamos encarecidamente investigar este caso, de lo contrario su dominio quedará sin una comunicación SSL válida.",
"emails.certificate.thanks": "Gracias",
"emails.certificate.signature": "{{project}} equipo"
"emails.certificate.signature": "{{project}} equipo",
"emails.magicSession.securityPhrase": "La locución de seguridat pro iste correo es {{phrase}}. Podes confiar en iste correo si esta locución coincidit con la locución amostrada durante el ingreso.",
"emails.magicSession.optionUrl": "Si no puedes iniciar sesión utilizando el botón de arriba, por favor visita el siguiente enlace:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Südamerika",
"emails.magicSession.optionButton": "Klickt op de Knäppchen hei drënner fir sécher an Äre {{project}} Kont anzeloggen. Et wäert an 1 Stonn oflafen.",
"emails.magicSession.buttonText": "Connectez-vous à {{project}}",
"emails.magicSession.optionUrl": "Wann de Knäppchen hei uewen net ugewisen gëtt, benotzt de folgende Link:",
"emails.magicSession.clientInfo": "Dëse Login gouf duerch {{agentClient}} op {{agentDevice}} {{agentOs}} ugefrot. Wann Dir de Login net gefrot hutt, kënnt Dir dësen E-Mail ouni weideres ignoréieren.",
"emails.certificate.subject": "Zertifikatsfehler fir %s",
"emails.certificate.hello": "Moien",
"emails.certificate.body": "De Certificat fir äre Domain '{{domain}}' konnt net erstallt ginn. Dat ass den Versuch Nummer {{attempt}}, an de Feeler gouf verursaacht duerch: {{error}}",
"emails.certificate.footer": "Äert viregt Zertifikat wäert fir 30 Deeg gëlteg sinn zënter dem éischten Ausfall. Mir recommandéieren Iech staark, dëse Fall z'ënnersichen, soss wäert Är Domain ouni eng valabel SSL-Kommunikatioun enden.",
"emails.certificate.thanks": "Merci",
"emails.certificate.signature": "Équipe {{project}}"
"emails.certificate.signature": "Équipe {{project}}",
"emails.magicSession.securityPhrase": "D'Sécherheetsphrase fir dësen E-Mail ass {{phrase}}. Dir kënnt dësem E-Mail vertrauen, wann dës Phrase mat der Phrase iwwereneestëmmt, déi beim Umellen ugewise ginn ass.",
"emails.magicSession.optionUrl": "Wann Dir Iech net kënnt umellen andeems Dir op de Knäppchen uewendriwwer klickt, besicht w.e.g. de folgenden Link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Pietų Amerika",
"emails.magicSession.optionButton": "Spustelėkite žemiau esantį mygtuką, kad saugiai prisijungtumėte prie savo {{project}} paskyros. Galiojimas baigsis po 1 valandos.",
"emails.magicSession.buttonText": "Prisijunkite prie {{project}}",
"emails.magicSession.optionUrl": "Jei viršuje esantis mygtukas nesimato, naudokite šią nuorodą:",
"emails.magicSession.clientInfo": "Šis prisijungimas buvo užklaustas naudojant {{agentClient}} {{agentDevice}} {{agentOs}}. Jei neprašėte prisijungimo, galite saugiai ignoruoti šį el. laišką.",
"emails.certificate.subject": "Sertifikato klaida %s",
"emails.certificate.hello": "Sveiki",
"emails.certificate.body": "Jūsų domeno '{{domain}}' sertifikato sukurti nepavyko. Tai bandymas Nr. {{attempt}}, ir nepavykimo priežastis: {{error}}",
"emails.certificate.footer": "Jūsų ankstesnis sertifikatas bus galiojantis 30 dienų nuo pirmojo nesėkmingo bandymo. Mes primygtinai rekomenduojame ištirti šią situaciją, kitaip jūsų domenas liks be galiojančio SSL ryšio.",
"emails.certificate.thanks": "Ačiū",
"emails.certificate.signature": "{{project}} komanda"
"emails.certificate.signature": "{{project}} komanda",
"emails.magicSession.securityPhrase": "Šio el. laiško saugumo frazė yra {{phrase}}. Šiam el. laiškui galite pasitikėti, jei ši frazė atitinka prisijungimo metu rodytą frazę.",
"emails.magicSession.optionUrl": "Jei negalite prisijungti naudodami aukščiau esantį mygtuką, apsilankykite šioje nuorodoje:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Dienvidamerika",
"emails.magicSession.optionButton": "Noklikšķiniet uz zemāk esošās pogas, lai droši pieteiktos savā {{project}} kontā. Tas beigsies pēc 1 stundas.",
"emails.magicSession.buttonText": "Pierakstieties {{project}}",
"emails.magicSession.optionUrl": "Ja poga augstāk neparādās, izmantojiet šo saiti:",
"emails.magicSession.clientInfo": "Šī autorizācija tika pieprasīta, izmantojot {{agentClient}} ierīcē {{agentDevice}} operētājsistēmā {{agentOs}}. Ja jūs neesat pieprasījis autorizāciju, šo e-pastu varat droši ignorēt.",
"emails.certificate.subject": "Sertifikāta kļūme %s",
"emails.certificate.hello": "Sveiki",
"emails.certificate.body": "Sertifikāts jūsu domēnam '{{domain}}' nevarēja tikt ģenerēts. Tā ir mēģinājuma nr. {{attempt}}, un neizdošanās iemesls bija: {{error}}",
"emails.certificate.footer": "Jūsu iepriekšējais sertifikāts būs derīgs 30 dienas no pirmās neveiksmes. Mēs ļoti iesakām izmeklēt šo gadījumu, citādi jūsu domēns paliks bez derīga SSL saziņas.",
"emails.certificate.thanks": "Paldies",
"emails.certificate.signature": "{{project}} komanda"
"emails.certificate.signature": "{{project}} komanda",
"emails.magicSession.securityPhrase": "Drošības frāze šim e-pastam ir {{phrase}}. Šim e-pastam var uzticēties, ja šī frāze sakrīt ar frāzi, kas parādās, piesakoties sistēmā.",
"emails.magicSession.optionUrl": "Ja nevarat pierakstīties, izmantojot iepriekš minēto pogu, lūdzu, apmeklējiet sekojošo saiti:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "തെക്കേ അമേരിക്ക",
"emails.magicSession.optionButton": "ಕೆಳಗಿನ ಬಟನ್ ಒತ್ತಿ ನಿಮ್ಮ {{project}} ಖಾತೆಗೆ ಸುರಕ್ಷಿತವಾಗಿ ಸೈನ್ ಇನ್ ಮಾಡಿ. ಇದು 1 ಗಂಟೆಯಲ್ಲಿ ಅವಧಿ ಮುಗಿಯುವುದು.",
"emails.magicSession.buttonText": "Se connecter à {{project}}",
"emails.magicSession.optionUrl": "Raha bokotra eo ambony tsy miseho, ampiasao ny rohy manaraka:",
"emails.magicSession.clientInfo": "I'm sorry, but there appears to be some confusion. The country code \"ml\" stands for Mali, where the official language is French. However, many local languages such as Bambara are also widely spoken. Please specify if you would like the translation in French or any other specific local language.",
"emails.certificate.subject": "Tsy fahombiazan'ny fahaizana ho an'ny %s",
"emails.certificate.hello": "Bonjour",
"emails.certificate.body": "നിങ്ങളുടെ ഡൊമെയ്‌ൻ '{{domain}}'നായുള്ള സർട്ടിഫിക്കറ്റ് ഉണ്ടാക്കാൻ കഴിയിച്ചില്ല. ഇത് ശ്രമമായ {{attempt}} ആണ്, പരാജയത്തിനു കാരണം: {{error}}",
"emails.certificate.footer": "Ny zom-pokotaninao teo aloha dia hanan-kery mandritra ny 30 andro manomboka amin'ny tsy fahombiazana voalohany. Izahay dia manoro hevitra mafy ny hanaovana fikarohana momba ity tranga ity, raha tsy izany ny sehatra misy anao dia ho tonga amin'ny toerana tsy misy fifandraisana SSL manan-kery.",
"emails.certificate.thanks": "Merci",
"emails.certificate.signature": "{{project}} ekipi"
"emails.certificate.signature": "{{project}} ekipi",
"emails.magicSession.securityPhrase": "ഈ ഇമെയിലിന്റെ സുരക്ഷാ വാചകം {{phrase}} ആണ്. സൈൻ ഇൻ ചെയ്യുമ്പോൾ കാണിച്ച വാചകവുമായി ഈ വാചകം ഒത്തുപോകുന്നെങ്കിൽ ഈ ഇമെയിലിനെ വിശ്വസിക്കാം.",
"emails.magicSession.optionUrl": "Raha toa ka tsy afaka miditra ianao amin'ny alàlan'ny bokotra etsy ambony, azafady mba tsidiho ity rohy manaraka ity:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "दक्षिण अमेरिका",
"emails.magicSession.optionButton": "खालील बटणावर क्लिक करा आणि आपल्या {{project}} खात्यात सुरक्षितपणे साइन इन करा. हे १ तासात समाप्त होईल.",
"emails.magicSession.buttonText": "{{project}} मध्ये साइन इन करा",
"emails.magicSession.optionUrl": "वरील बटण दिसत नसेल तर, खालील लिंक वापरा:",
"emails.magicSession.clientInfo": "ही साइन इन विनंती केली गेली {{agentClient}} वरून {{agentDevice}} {{agentOs}} वापरून. जर आपणास ही साइन इन विनंती केली नसेल तर आपण हा ईमेल सुरक्षितपणे दुर्लक्षित करू शकता.",
"emails.certificate.subject": "%s साठी प्रमाणपत्र अयशस्वी",
"emails.certificate.hello": "नमस्कार",
"emails.certificate.body": "आपल्या डोमेनसाठी '{{domain}}' प्रमाणपत्र तयार करणे शक्य नव्हते. ही प्रयत्न क्रमांक {{attempt}} आहे, आणि त्यामागील कारण म्हणजे: {{error}}",
"emails.certificate.footer": "तुमचे मागील प्रमाणपत्र पहिल्या अपयशापासून ३० दिवसांपर्यंत वैध राहील. आम्ही आपल्याला विशेषतः सूचित करतो की, या प्रकरणाची चौकशी करा, अन्यथा तुमचे डोमेन वैध SSL संवादाशिवाय राहील.",
"emails.certificate.thanks": "धन्यवाद",
"emails.certificate.signature": "{{project}} संघ"
"emails.certificate.signature": "{{project}} संघ",
"emails.magicSession.securityPhrase": "या ईमेलसाठी सुरक्षा वाक्य हे {{phrase}} आहे. साइन इन केल्यावेळी दाखवलेले वाक्य जर हे वाक्याशी जुळत असेल तर तुम्ही या ईमेलवर विश्वास ठेवू शकता.",
"emails.magicSession.optionUrl": "जर आपण वरील बटणाचा वापर करून साइन इन करू शकत नसाल, तर कृपया खालील दुवा भेट द्या:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Amerika Selatan",
"emails.magicSession.optionButton": "Klik butang di bawah untuk log masuk ke akaun {{project}} anda dengan selamat. Ia akan luput dalam masa 1 jam.",
"emails.magicSession.buttonText": "Masuk ke {{project}}",
"emails.magicSession.optionUrl": "Jika butang di atas tidak dipaparkan, gunakan pautan berikut:",
"emails.magicSession.clientInfo": "Pendaftaran ini diminta menggunakan {{agentClient}} pada {{agentDevice}} {{agentOs}}. Jika anda tidak meminta untuk daftar masuk, anda boleh abaikan e-mel ini dengan selamat.",
"emails.certificate.subject": "Kegagalan sijil bagi %s",
"emails.certificate.hello": "Halo",
"emails.certificate.body": "Sijil untuk domain anda '{{domain}}' tidak dapat dijana. Ini adalah percubaan ke-{{attempt}}, dan kegagalan disebabkan oleh: {{error}}",
"emails.certificate.footer": "Sijil sebelum ini anda akan sah selama 30 hari selepas kegagalan pertama. Kami sangat mengesyorkan untuk menyiasat kes ini, jika tidak domain anda akan berakhir tanpa komunikasi SSL yang sah.",
"emails.certificate.thanks": "Terima kasih",
"emails.certificate.signature": "pasukan {{project}}"
"emails.certificate.signature": "pasukan {{project}}",
"emails.magicSession.securityPhrase": "Frasa keselamatan untuk emel ini adalah {{phrase}}. Anda boleh mempercayai emel ini jika frasa ini sepadan dengan frasa yang ditunjukkan semasa log masuk.",
"emails.magicSession.optionUrl": "Jika anda tidak dapat log masuk menggunakan butang di atas, sila kunjungi pautan berikut:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Sør-Amerika",
"emails.magicSession.optionButton": "Klikk på knappen nedenfor for å logge inn på din {{project}}-konto på en sikker måte. Den vil utløpe om 1 time.",
"emails.magicSession.buttonText": "Logg inn på {{project}}",
"emails.magicSession.optionUrl": "Hvis knappen over ikke vises, bruk følgende lenke:",
"emails.magicSession.clientInfo": "Dette innloggingen ble forespurt ved hjelp av {{agentClient}} på {{agentDevice}} {{agentOs}}. Hvis du ikke ba om innloggingen, kan du trygt se bort fra denne e-posten.",
"emails.certificate.subject": "Sertifikatfeil for %s",
"emails.certificate.hello": "Hei",
"emails.certificate.body": "Sertifikatet for domenet ditt '{{domain}}' kunne ikke genereres. Dette er forsøk nr. {{attempt}}, og feilen ble forårsaket av: {{error}}",
"emails.certificate.footer": "Ditt forrige sertifikat vil være gyldig i 30 dager fra den første feilen. Vi anbefaler sterkt at du undersøker denne saken, ellers vil domenet ditt ende opp uten en gyldig SSL-kommunikasjon.",
"emails.certificate.thanks": "Takk",
"emails.certificate.signature": "{{project}}-laget"
"emails.certificate.signature": "{{project}}-laget",
"emails.magicSession.securityPhrase": "Sikkerhetsfrasen for denne e-posten er {{phrase}}. Du kan stole på denne e-posten hvis denne frasen stemmer overens med frasen som ble vist under innlogging.",
"emails.magicSession.optionUrl": "Hvis du ikke klarer å logge inn ved å bruke knappen ovenfor, vennligst besøk følgende lenke:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "दक्षिण अमेरिका",
"emails.magicSession.optionButton": "कृपया तलको बटनमा क्लिक गरी आफ्नो {{project}} खातामा सुरक्षित रूपमा साइन इन गर्नुहोस्। यो १ घण्टामा समाप्त हुनेछ।",
"emails.magicSession.buttonText": "Connectez-vous à {{project}}",
"emails.magicSession.optionUrl": "यदि माथिको बटन देखिँदैन भने, निम्न लिंक प्रयोग गर्नुहोस्:",
"emails.magicSession.clientInfo": "यो साइन इन अनुरोध गरिएको थियो {{agentClient}} प्रयोग गरेर {{agentDevice}} {{agentOs}} मा। यदि तपाईंले साइन इन अनुरोध गर्नुभएको छैन भने, यो इमेललाई सुरक्षित रूपमा अनदेखा गर्न सक्नुहुन्छ।",
"emails.certificate.subject": "सर्टिफिकेट विफलता %s को लागि",
"emails.certificate.hello": "नमस्ते",
"emails.certificate.body": "दर्ता गर्नु भएको डोमेन '{{domain}}' को प्रमाणपत्र उत्पन्न गर्न सकिएन। यो प्रयास नं. {{attempt}} हो, र यस असफलताको कारण यस्तो थियो: {{error}}",
"emails.certificate.footer": "Votre certificat précédent sera valide pendant 30 jours depuis le premier échec. Nous recommandons fortement d'enquêter sur ce cas, sinon votre domaine se retrouvera sans communication SSL valide.",
"emails.certificate.thanks": "धन्यवाद",
"emails.certificate.signature": "équipe {{project}}"
"emails.certificate.signature": "équipe {{project}}",
"emails.magicSession.securityPhrase": "यस ईमेलको लागि सुरक्षा वाक्य {{phrase}} हो। यो वाक्य साइन इन गर्दा देखाइएको वाक्यसँग मेल खाए मात्र तपाईंले यस ईमेललाई विश्वास गर्न सक्नुहुन्छ।",
"emails.magicSession.optionUrl": "सँगै उल्लेख गरिएको बटन प्रयोग गरेर साइन इन गर्न असमर्थ हुनुहुन्छ भने, कृपया तलको लिंकमा भ्रमण गर्नुहोस्:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Zuid Amerika",
"emails.magicSession.optionButton": "Klik op de knop hieronder om veilig in te loggen op uw {{project}} account. Deze zal verlopen over 1 uur.",
"emails.magicSession.buttonText": "Meld u aan bij {{project}}",
"emails.magicSession.optionUrl": "Als de knop hierboven niet wordt weergegeven, gebruik dan de volgende link:",
"emails.magicSession.clientInfo": "Deze aanmelding is aangevraagd met {{agentClient}} op {{agentDevice}} {{agentOs}}. Als u de aanmelding niet hebt aangevraagd, kunt u deze e-mail gerust negeren.",
"emails.certificate.subject": "Certificaatfalen voor %s",
"emails.certificate.hello": "Hallo",
"emails.certificate.body": "Certificaat voor uw domein '{{domain}}' kon niet worden gegenereerd. Dit is poging nr. {{attempt}}, en de mislukking werd veroorzaakt door: {{error}}",
"emails.certificate.footer": "Uw vorige certificaat zal 30 dagen geldig zijn vanaf de eerste fout. We raden u ten zeerste aan dit geval te onderzoeken, anders zal uw domein eindigen zonder een geldige SSL-communicatie.",
"emails.certificate.thanks": "Dank je",
"emails.certificate.signature": "{{project}} team"
"emails.certificate.signature": "{{project}} team",
"emails.magicSession.securityPhrase": "De beveiligingszin voor deze e-mail is {{phrase}}. U kunt deze e-mail vertrouwen als deze zin overeenkomt met de zin die getoond werd tijdens het aanmelden.",
"emails.magicSession.optionUrl": "Als u zich niet kunt aanmelden via de bovenstaande knop, bezoekt u dan de volgende link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Sør-Amerika",
"emails.magicSession.optionButton": "Klikk på knappen under for å trygt logge inn på din {{project}}-konto. Den vil utløpe om 1 time.",
"emails.magicSession.buttonText": "Innlogging til {{project}}",
"emails.magicSession.optionUrl": "Beklager, men du har ikke oppgitt et gyldig landskode. \"nn\" er ikke en gyldig ISO-landskode. Vennligst oppgi en gyldig to-bokstavs landskode slik at jeg kan oversette meldingen til riktig språk.",
"emails.magicSession.clientInfo": "Denne innloggingen ble forespurt ved hjelp av {{agentClient}} på {{agentDevice}} {{agentOs}}. Hvis du ikke ba om innloggingen, kan du trygt se bort fra denne e-posten.",
"emails.certificate.subject": "Unfortunately, the country code \"nn\" is ambiguous, as it doesn't correspond to a recognized ISO 3166-1 alpha-2 country code. However, “nn” often refers to “Nynorsk,” one of the written standards of the Norwegian language. If you intended to translate the sentence into Nynorsk (Norwegian), here is the translation:\n\n\"Seritifikatsvikt for %s\"",
"emails.certificate.hello": "In order to translate the message to the target language corresponding to the country code \"nn,\" I need to clarify that \"nn\" is not a valid ISO country code. However, if you intended \"nn\" to stand for Nynorsk, which is one of the written standards of the Norwegian language (not to be confused with a country code), then the translation would be:\n\nHallo",
"emails.certificate.body": "Sertifikat for domenet ditt '{{domain}}' kunne ikke genereres. Dette er forsøk nr. {{attempt}}, og mislykkelsen ble forårsaket av: {{error}}",
"emails.certificate.footer": "Ditt førre sertifikat vil vere gyldig i 30 dagar etter den første feilen. Vi rår sterkt til å undersøke denne saka, elles vil domenet ditt ende opp utan ein gyldig SSL-kommunikasjon.",
"emails.certificate.thanks": "The country code \"nn\" provided is not sufficient to determine the target language as it does not correspond to an official ISO 3166-1 alpha-2 country code. Please provide more context or the specific target language you need the translation for.",
"emails.certificate.signature": "{{project}} lag"
"emails.certificate.signature": "{{project}} lag",
"emails.magicSession.securityPhrase": "For the country code \"nn\", there is no officially designated language. The country code \"NN\" is typically used as a placeholder in documentation for a country that is not specified. Please provide a valid country code or specify the target language for the translation.",
"emails.magicSession.optionUrl": "Dersom du ikkje klarer å logge inn ved å bruke knappen over, kan du gå til følgjande lenke:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "ସାଉଥ ଆମେରିକା",
"emails.magicSession.optionButton": "Kliknite na gumb ispod kako biste se sigurno prijavili na svoj {{project}} račun. Istječe za 1 sat.",
"emails.magicSession.buttonText": "Inicia sesión en {{project}}",
"emails.magicSession.optionUrl": "Ako gumb iznad ne prikazuje, upotrijebite sljedeći link:",
"emails.magicSession.clientInfo": "Tento přihlašovací požadavek byl zaznamenán pomocí {{agentClient}} na {{agentDevice}} {{agentOs}}. Pokud jste o přihlášení nepožádali, můžete tento e-mail bezpečně ignorovat.",
"emails.certificate.subject": "شهادة الفشل لـ %s",
"emails.certificate.hello": "Hola",
"emails.certificate.body": "Sertifika jūsų domenui \"{{domain}}\" negalėjo būti sugeneruotas. Tai bandymas Nr. {{attempt}}, ir nesėkmę sukėlė: {{error}}",
"emails.certificate.footer": "Vaš prethodni certifikat će biti važeći 30 dana od prvog neuspeha. Visoko preporučujemo istraživanje ovog slučaja, inače će vaš domen ostati bez važeće SSL komunikacije.",
"emails.certificate.thanks": "\n\nTack",
"emails.certificate.signature": "{{project}} команда"
"emails.certificate.signature": "{{project}} команда",
"emails.magicSession.securityPhrase": "Frase de segurança para este e-mail é {{phrase}}. Você pode confiar neste e-mail se essa frase coincidir com a frase mostrada durante o acesso.",
"emails.magicSession.optionUrl": "אם אתם לא מצליחים להיכנס באמצעות הכפתור שמעל, אנא בקרו בקישור הבא:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "ਸਾਉਥ ਅਮਰੀਕਾ",
"emails.magicSession.optionButton": "Haz clic en el botón de abajo para iniciar sesión de manera segura en tu cuenta de {{project}}. Expirará en una hora.",
"emails.magicSession.buttonText": "Inicia sesión en {{project}}",
"emails.magicSession.optionUrl": "Si el botón de arriba no aparece, utiliza el siguiente enlace:",
"emails.magicSession.clientInfo": "Este ingreso fue solicitado usando {{agentClient}} en {{agentDevice}} {{agentOs}}. Si no solicitaste el ingreso, puedes ignorar este correo electrónico sin problema.",
"emails.certificate.subject": "Falló el certificado para %s",
"emails.certificate.hello": "Hola",
"emails.certificate.body": "El certificado para su dominio '{{domain}}' no pudo ser generado. Este es el intento n.º {{attempt}}, y el fallo fue causado por: {{error}}",
"emails.certificate.footer": "Su certificado anterior será válido por 30 días desde el primer fallo. Recomendamos encarecidamente investigar este caso, de lo contrario su dominio terminará sin una comunicación SSL válida.",
"emails.certificate.thanks": "Gracias",
"emails.certificate.signature": "equipo de {{project}}"
"emails.certificate.signature": "equipo de {{project}}",
"emails.magicSession.securityPhrase": "La frase de seguridad para este correo electrónico es {{phrase}}. Puedes confiar en este correo si esta frase coincide con la frase que se muestra al iniciar sesión.",
"emails.magicSession.optionUrl": "Si no puedes iniciar sesión utilizando el botón superior, por favor visita el siguiente enlace:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Ameryka południowa",
"emails.magicSession.optionButton": "Kliknij przycisk poniżej, aby bezpiecznie zalogować się na swoje konto {{project}}. Link wygaśnie po 1 godzinie.",
"emails.magicSession.buttonText": "Zaloguj się do {{project}}",
"emails.magicSession.optionUrl": "Jeśli powyższy przycisk się nie wyświetla, użyj poniższego linku:",
"emails.magicSession.clientInfo": "To logowanie zostało zażądane przy użyciu {{agentClient}} na {{agentDevice}} {{agentOs}}. Jeśli nie zażądałeś logowania, możesz zignorować tę wiadomość e-mail.",
"emails.certificate.subject": "Błąd certyfikatu dla %s",
"emails.certificate.hello": "Cześć",
"emails.certificate.body": "Certyfikat dla Twojej domeny '{{domain}}' nie mógł zostać wygenerowany. To jest próba nr {{attempt}}, a przyczyną niepowodzenia było: {{error}}",
"emails.certificate.footer": "Twój poprzedni certyfikat będzie ważny przez 30 dni od pierwszej awarii. Zalecamy dokładne zbadanie tej sprawy, w przeciwnym razie Twój domena zostanie bez ważnego certyfikatu SSL.",
"emails.certificate.thanks": "Dziękuję",
"emails.certificate.signature": "zespół {{project}}"
"emails.certificate.signature": "zespół {{project}}",
"emails.magicSession.securityPhrase": "Hasło bezpieczeństwa dla tego e-maila to {{phrase}}. Możesz ufać temu e-mailowi, jeśli hasło to jest zgodne z hasłem wyświetlonym podczas logowania.",
"emails.magicSession.optionUrl": "Jeśli nie możesz się zalogować, używając powyższego przycisku, odwiedź następujący link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "América do Sul",
"emails.magicSession.optionButton": "Clique no botão abaixo para acessar sua conta {{project}} com segurança. Ele expirará em 1 hora.",
"emails.magicSession.buttonText": "Faça login no {{project}}",
"emails.magicSession.optionUrl": "Caso o botão acima não apareça, utilize o seguinte link:",
"emails.magicSession.clientInfo": "Este acesso foi solicitado usando {{agentClient}} em {{agentDevice}} {{agentOs}}. Se você não solicitou o acesso, pode ignorar este e-mail com segurança.",
"emails.certificate.subject": "Falha no certificado para %s",
"emails.certificate.hello": "Olá",
"emails.certificate.body": "O certificado para o seu domínio '{{domain}}' não pôde ser gerado. Esta é a tentativa nº {{attempt}}, e a falha foi causada por: {{error}}",
"emails.certificate.footer": "Seu certificado anterior será válido por 30 dias desde a primeira falha. Recomendamos fortemente que você investigue este caso, caso contrário, seu domínio ficará sem uma comunicação SSL válida.",
"emails.certificate.thanks": "Obrigado",
"emails.certificate.signature": "equipe {{project}}"
"emails.certificate.signature": "equipe {{project}}",
"emails.magicSession.securityPhrase": "A frase de segurança para este e-mail é {{phrase}}. Você pode confiar neste e-mail se essa frase corresponder à frase mostrada durante o acesso.",
"emails.magicSession.optionUrl": "Se você não consegue fazer login usando o botão acima, por favor visite o seguinte link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "América do Sul",
"emails.magicSession.optionButton": "Clique no botão abaixo para iniciar sessão na sua conta {{project}} de forma segura. Irá expirar em 1 hora.",
"emails.magicSession.buttonText": "Inicie sessão no {{project}}",
"emails.magicSession.optionUrl": "Se o botão acima não aparecer, utilize o seguinte link:",
"emails.magicSession.clientInfo": "Este início de sessão foi solicitado usando o {{agentClient}} no {{agentDevice}} {{agentOs}}. Se não foi você quem solicitou o início de sessão, pode ignorar este e-mail com segurança.",
"emails.certificate.subject": "Falha no certificado para %s",
"emails.certificate.hello": "Olá",
"emails.certificate.body": "Não foi possível gerar certificado para o seu domínio '{{domain}}'. Esta é a tentativa nº {{attempt}}, e a falha foi causada por: {{error}}",
"emails.certificate.footer": "O seu certificado anterior será válido por 30 dias desde a primeira falha. Recomendamos vivamente que investigue este caso, caso contrário, o seu domínio ficará sem uma comunicação SSL válida.",
"emails.certificate.thanks": "Obrigado",
"emails.certificate.signature": "equipa {{project}}"
"emails.certificate.signature": "equipa {{project}}",
"emails.magicSession.securityPhrase": "A frase de segurança deste e-mail é {{phrase}}. Pode confiar neste e-mail se esta frase coincidir com a frase mostrada durante o início de sessão.",
"emails.magicSession.optionUrl": "Se não conseguir iniciar sessão utilizando o botão acima, por favor visite o seguinte link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "America de Sud",
"emails.magicSession.optionButton": "Faceți clic pe butonul de mai jos pentru a vă autentifica în siguranță în contul dvs. {{project}}. Va expira în 1 oră.",
"emails.magicSession.buttonText": "Conectați-vă la {{project}}",
"emails.magicSession.optionUrl": "Dacă butonul de mai sus nu apare, folosiți următorul link:",
"emails.magicSession.clientInfo": "Această autentificare a fost solicitată folosind {{agentClient}} pe {{agentDevice}} {{agentOs}}. Dacă nu ați solicitat autentificarea, puteți ignora în siguranță acest email.",
"emails.certificate.subject": "Eșec al certificatului pentru %s",
"emails.certificate.hello": "Salut",
"emails.certificate.body": "Certificatul pentru domeniul dumneavoastră '{{domain}}' nu a putut fi generat. Aceasta este încercarea nr. {{attempt}}, iar eșecul a fost provocat de: {{error}}",
"emails.certificate.footer": "Certificatul dumneavoastră anterior va fi valid pentru 30 de zile de la prima defecțiune. Vă recomandăm insistent să investigați acest caz, altfel domeniul dumneavoastră va rămâne fără o comunicare SSL validă.",
"emails.certificate.thanks": "Mulțumesc",
"emails.certificate.signature": "echipa {{project}}"
"emails.certificate.signature": "echipa {{project}}",
"emails.magicSession.securityPhrase": "Frază de securitate pentru acest e-mail este {{phrase}}. Puteți avea încredere în acest e-mail dacă fraza se potrivește cu fraza afișată în timpul autentificării.",
"emails.magicSession.optionUrl": "Dacă nu puteți să vă autentificați folosind butonul de mai sus, vă rugăm să vizitați următorul link:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Южная Америка",
"emails.magicSession.optionButton": "Нажмите на кнопку ниже, чтобы безопасно войти в свою учетную запись {{project}}. Срок действия истечет через 1 час.",
"emails.magicSession.buttonText": "Войти в {{project}}",
"emails.magicSession.optionUrl": "Если кнопка выше не отображается, используйте следующую ссылку:",
"emails.magicSession.clientInfo": "Этот вход был запрошен с использованием {{agentClient}} на {{agentDevice}} {{agentOs}}. Если вы не запрашивали вход, можете спокойно игнорировать это письмо.",
"emails.certificate.subject": "Сбой сертификата для %s",
"emails.certificate.hello": "Здравствуйте",
"emails.certificate.body": "Сертификат для вашего домена '{{domain}}' не может быть создан. Это попытка номер {{attempt}}, и причина сбоя: {{error}}",
"emails.certificate.footer": "Ваш предыдущий сертификат будет действителен в течение 30 дней с момента первой неудачи. Настоятельно рекомендуем изучить этот случай, иначе ваш домен останется без действующего SSL-соединения.",
"emails.certificate.thanks": "Спасибо",
"emails.certificate.signature": "команда {{project}}"
"emails.certificate.signature": "команда {{project}}",
"emails.magicSession.securityPhrase": "Фраза безопасности для этого электронного письма - {{phrase}}. Вы можете доверять этому письму, если эта фраза совпадает с фразой, отображаемой при входе в систему.",
"emails.magicSession.optionUrl": "Если вы не можете войти, используя кнопку выше, пожалуйста, посетите следующую ссылку:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "दक्षिण अमेरिका",
"emails.magicSession.optionButton": "اضغط على الزر أدناه لتسجيل الدخول بأمان إلى حساب {{project}} الخاص بك. سينتهي في غضون ساعة واحدة.",
"emails.magicSession.buttonText": "تسجيل الدخول إلى {{project}}",
"emails.magicSession.optionUrl": "إذا لم يظهر الزر أعلاه، استخدم الرابط التالي:",
"emails.magicSession.clientInfo": "هذا الطلب لتسجيل الدخول قد تم باستخدام {{agentClient}} على {{agentDevice}} {{agentOs}}. إذا لم تطلب تسجيل الدخول، يمكنك تجاهل هذا البريد الإلكتروني بأمان.",
"emails.certificate.subject": "فشل الشهادة لـ %s",
"emails.certificate.hello": "مرحبا",
"emails.certificate.body": "شهادة لنطاق '{{domain}}' الخاص بك لا يمكن إنشاؤها. هذه هي المحاولة رقم {{attempt}}، وكان سبب الفشل: {{error}}",
"emails.certificate.footer": "سيكون شهادتك السابقة صالحة لمدة 30 يوماً منذ الفشل الأول. نوصي بشدة بالتحقيق في هذه الحالة، وإلا سينتهي مجالك بدون اتصال SSL صالح.",
"emails.certificate.thanks": "شكرا",
"emails.certificate.signature": "فريق {{project}}"
"emails.certificate.signature": "فريق {{project}}",
"emails.magicSession.securityPhrase": "العبارة الأمنية لهذا البريد الإلكتروني هي {{phrase}}. يمكنك الوثوق بهذا البريد الإلكتروني إذا كانت هذه العبارة متطابقة مع العبارة المعروضة أثناء تسجيل الدخول.",
"emails.magicSession.optionUrl": "إذا لم تتمكن من تسجيل الدخول باستخدام الزر أعلاه، يرجى زيارة الرابط التالي:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "ڏکڻ آمريڪا",
"emails.magicSession.optionButton": "محفوظ طريقہ سے اپنے {{project}} اکاؤنٹ میں داخل ہونے کے لئے نيچے دئے گئے بٹن پر کلک کریں۔ یہ ایک گھنٹے ميں ختم ہو جائے گا۔",
"emails.magicSession.buttonText": "It seems that you're referring to a country code \"sd\" which typically represents Sudan. The official languages in Sudan are Arabic and English. Without specific instruction for Arabic, I will provide the translation in Arabic:\n\nتسجيل الدخول إلى {{project}}",
"emails.magicSession.optionUrl": "إذا لم يظهر الزر أعلاه، استخدم الرابط التالي:",
"emails.magicSession.clientInfo": "هن وقت جي لاڳ ان جي درخواست {{agentClient}} تي ڪئي وئي آهي {{agentDevice}} {{agentOs}} تي. جيڪڏهن توهان کي لاڳ ان جي درخواست نه جي آهي، توهان اهو ایميل نظر انداز ڪري سگهو ٿا.",
"emails.certificate.subject": "شهادة فشل ل %s",
"emails.certificate.hello": "مرحبا",
"emails.certificate.body": "I'm sorry, but there is no country code \"sd.\" If you meant Sudan, the country code is \"SD,\" not lowercase, but the official languages of Sudan are Arabic and English. If you need a translation into Arabic, here is the message:\n\nشهادة لنطاق '{{domain}}' الخاص بك لم تتمكن من التوليد. هذه هي المحاولة رقم {{attempt}}، وكان الفشل بسبب: {{error}}",
"emails.certificate.footer": "سابقه سند توهان جي پهلي ناكامي کان 30 ڏينهن لاءِ موزون آهي. اسان توهان کي پوري قائلي سان گهڻي سفارش ڪنداسين ته هن ڪيس کي تحقيق ڪريو، نه ته توهان جو ڊومين بغير موزون SSL مواصلتي جي حالت ۾ ختم ٿي ويندو.",
"emails.certificate.thanks": "شكرا",
"emails.certificate.signature": "I believe there has been a misunderstanding. The country code \"sd\" refers to Sudan, and the official languages of Sudan are Arabic and English. If you are requesting a translation into Arabic, the phrase \"project team\" would be \"فريق المشروع\". If you need a translation into a different language, please provide the correct language or country code."
"emails.certificate.signature": "I believe there has been a misunderstanding. The country code \"sd\" refers to Sudan, and the official languages of Sudan are Arabic and English. If you are requesting a translation into Arabic, the phrase \"project team\" would be \"فريق المشروع\". If you need a translation into a different language, please provide the correct language or country code.",
"emails.magicSession.securityPhrase": "محفوظ جملو آهي هن اي ميل لاءِ {{phrase}}. توهان هن اي ميل تي اعتماد ڪري سگهو ٿا جيڪڏهن اهو جملو توهان کي سائن ان ڪرڻ وقت داخل ٿيل جملي سان ملي ويسي.",
"emails.magicSession.optionUrl": "You have provided \"sd\" as the country code; however, \"sd\" is not a valid ISO 3166-1 alpha-2 country code. If you meant \"sd\" to refer to the Sindhi language code, the translation would be:\n\n\"جيڪڏھن توھان مٿي واريل بٽڪَ جي مدد سان سائن ان ڪرڻ ۾ ناڪام آھيو، ته مھرباني ڪري هيٺيان ديئل لنڪ جو ڏورو قدم چونڊو:\""
}

View file

@ -231,12 +231,13 @@
"continents.sa": "දකුණු ඇමරිකාව",
"emails.magicSession.optionButton": "Kliknite spodnji gumb, da varno vstopite v svoj {{project}} račun. Poteče čez 1 uro.",
"emails.magicSession.buttonText": "Prijavite se v {{project}}",
"emails.magicSession.optionUrl": "Če gumb zgoraj se ne prikaže, uporabite naslednjo povezavo:",
"emails.magicSession.clientInfo": "Ta prijava je bila zahtevana z uporabo {{agentClient}} na {{agentDevice}} {{agentOs}}. Če te prijave niste zahtevali, lahko to e-pošto varno prezrete.",
"emails.certificate.subject": "Potrdilo ni uspelo za %s",
"emails.certificate.hello": "Živjo",
"emails.certificate.body": "Vaš certifikat za domeno '{{domain}}' ni bilo mogoče ustvariti. To je poskus št. {{attempt}} in napako je povzročilo: {{error}}",
"emails.certificate.footer": "Vaše prethodno certifikat će biti važeći 30 dana od prvog neuspeha. Visoko preporučujemo da istražite ovaj slučaj, u suprotnom vaš domen će ostati bez važeće SSL komunikacije.",
"emails.certificate.thanks": "Hvala",
"emails.certificate.signature": "{{project}} ekipa"
"emails.certificate.signature": "{{project}} ekipa",
"emails.magicSession.securityPhrase": "Zaščitna fraza za ta e-poštni naslov je {{phrase}}. Temu e-poštnemu naslovu lahko zaupate, če se ta fraza ujema s frazo, prikazano med prijavo.",
"emails.magicSession.optionUrl": "Če se z zgornjim gumbom ne morete prijaviti, obiščite naslednjo povezavo:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Južná Amerika",
"emails.magicSession.optionButton": "Kliknite na tlačidlo nižšie, aby ste sa bezpečne prihlásili do vášho účtu {{project}}. Platnosť vyprší za 1 hodinu.",
"emails.magicSession.buttonText": "Prihláste sa do {{project}}",
"emails.magicSession.optionUrl": "Ak sa tlačidlo vyššie nezobrazuje, použite nasledujúci odkaz:",
"emails.magicSession.clientInfo": "Toto prihlásenie bolo požadované pomocou {{agentClient}} na {{agentDevice}} {{agentOs}}. Ak ste si nepožiadali o prihlásenie, tento e-mail môžete bezpečne ignorovať.",
"emails.certificate.subject": "Certifikačná chyba pre %s",
"emails.certificate.hello": "Ahoj",
"emails.certificate.body": "Certifikát pre váš domén '{{domain}}' sa nepodarilo vygenerať. Ide o pokus č. {{attempt}}, a dôvod zlyhania bol: {{error}}",
"emails.certificate.footer": "Váš predchádzajúci certifikát bude platný 30 dní od prvého zlyhania. Dôrazne odporúčame vyšetrenie tohto prípadu, inak váš doménový názov zostane bez platnej SSL komunikácie.",
"emails.certificate.thanks": "Ďakujem",
"emails.certificate.signature": "tím {{project}}"
"emails.certificate.signature": "tím {{project}}",
"emails.magicSession.securityPhrase": "Bezpečnostná fráza pre tento email je {{phrase}}. Tomuto emailu môžete dôverovať, ak sa táto fráza zhoduje s frázou zobrazenou počas prihlásenia.",
"emails.magicSession.optionUrl": "Ak sa vám nedarí prihlásiť sa pomocou vyššie uvedeného tlačidla, prosím navštívte nasledujúci odkaz:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Južna Amerika",
"emails.magicSession.optionButton": "Kliknite spodnji gumb, da se varno prijavite v svoj {{project}} račun. Poteče čez 1 uro.",
"emails.magicSession.buttonText": "Vpišite se v {{project}}",
"emails.magicSession.optionUrl": "Če zgornji gumb ne prikaže, uporabite naslednjo povezavo:",
"emails.magicSession.clientInfo": "Ta prijava je bila zahtevana z uporabo {{agentClient}} na {{agentDevice}} {{agentOs}}. Če te prijave niste zahtevali, lahko to e-pošto varno prezrete.",
"emails.certificate.subject": "Napaka potrdila za %s",
"emails.certificate.hello": "Živijo",
"emails.certificate.body": "Potrdilo za vaše domeno '{{domain}}' ni bilo mogoče ustvariti. To je poskus št. {{attempt}}, napako pa je povzročilo: {{error}}",
"emails.certificate.footer": "Vaše prejšnje potrdilo bo veljavno 30 dni od prve napake. Močno priporočamo, da to zadevo preučite, saj bo sicer vaše domeno brez veljavne SSL komunikacije.",
"emails.certificate.thanks": "Hvala",
"emails.certificate.signature": "{{project}} ekipa"
"emails.certificate.signature": "{{project}} ekipa",
"emails.magicSession.securityPhrase": "Varnostni stavek za to e-pošto je {{phrase}}. Temu e-poštu lahko zaupate, če se ta stavek ujema s stavkom, prikazanim ob prijavi.",
"emails.magicSession.optionUrl": "Če se ne morete prijaviti s pomočjo zgornjega gumba, prosimo obiščite naslednjo povezavo:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "South America",
"emails.magicSession.optionButton": "Cliquez sur le bouton ci-dessous pour vous connecter de manière sécurisée à votre compte {{project}}. Il expirera dans 1 heure.",
"emails.magicSession.buttonText": "Connectez-vous à {{project}}",
"emails.magicSession.optionUrl": "Si le bouton ci-dessus ne s'affiche pas, utilisez le lien suivant :",
"emails.magicSession.clientInfo": "Cette connexion a été demandée en utilisant {{agentClient}} sur {{agentDevice}} {{agentOs}}. Si vous n'avez pas demandé cette connexion, vous pouvez ignorer cet e-mail en toute sécurité.",
"emails.certificate.subject": "Échec du certificat pour %s",
"emails.certificate.hello": "Bonjour",
"emails.certificate.body": "Le certificat pour votre domaine '{{domain}}' n'a pas pu être généré. C'est la tentative n° {{attempt}}, et l'échec a été causé par : {{error}}",
"emails.certificate.footer": "Votre certificat précédent sera valable pendant 30 jours après le premier échec. Nous vous recommandons vivement d'enquêter sur ce cas, sinon votre domaine se retrouvera sans communication SSL valide.",
"emails.certificate.thanks": "Merci",
"emails.certificate.signature": "équipe {{project}}"
"emails.certificate.signature": "équipe {{project}}",
"emails.magicSession.securityPhrase": "La phrase de sécurité pour ce courriel est {{phrase}}. Vous pouvez faire confiance à ce courriel si cette phrase correspond à la phrase affichée lors de la connexion.",
"emails.magicSession.optionUrl": "Si vous ne pouvez pas vous connecter en utilisant le bouton ci-dessus, veuillez visiter le lien suivant :"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Amerika e Jugut",
"emails.magicSession.optionButton": "Klikoni butonin më poshtë për të hyrë në mënyrë të sigurt në llogarinë tuaj {{project}}. Do të skadojë në 1 orë.",
"emails.magicSession.buttonText": "Kyçu në {{project}}",
"emails.magicSession.optionUrl": "Nëse butoni më lart nuk shfaqet, përdorni lidhjen e mëposhtme:",
"emails.magicSession.clientInfo": "Ky hyrje është kërkuar duke përdorur {{agentClient}} në {{agentDevice}} {{agentOs}}. Nëse nuk e keni kërkuar hyrjen, mund ta injoroni këtë email pa pasur shqetësim.",
"emails.certificate.subject": "Dështim i certifikatës për %s",
"emails.certificate.hello": "Përshëndetje",
"emails.certificate.body": "Certifikata për domain-in tuaj '{{domain}}' nuk mund të gjenerohej. Ky është përpjekja nr. {{attempt}}, dhe dështimi u shkaktua nga: {{error}}",
"emails.certificate.footer": "Certifikata juaj e mëparshme do të jetë e vlefshme për 30 ditë që nga dështimi i parë. Ju rekomandojmë fuqishëm të hetoni këtë rast, përndryshe domeni juaj do të mbetet pa një komunikim të vlefshëm SSL.",
"emails.certificate.thanks": "Faleminderit",
"emails.certificate.signature": "ekipi i {{project}}"
"emails.certificate.signature": "ekipi i {{project}}",
"emails.magicSession.securityPhrase": "Fjalia e sigurisë për këtë email është {{phrase}}. Mund të besoni këtë email nëse kjo fjali përputhet me fjalën e shfaqur gjatë hyrjes në sistem.",
"emails.magicSession.optionUrl": "Nëse nuk mund të hyni duke përdorur butonin më sipër, ju lutem vizitoni lidhjen e mëposhtme:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Sydamerika",
"emails.magicSession.optionButton": "Klicka på knappen nedan för att säkert logga in på ditt {{project}} konto. Den kommer att gå ut om 1 timme.",
"emails.magicSession.buttonText": "Inicia sesión en {{project}}",
"emails.magicSession.optionUrl": "Om knappen ovan inte visas, använd följande länk:",
"emails.magicSession.clientInfo": "Den här inloggningen begärdes med hjälp av {{agentClient}} på {{agentDevice}} {{agentOs}}. Om du inte begärde inloggningen kan du bortse från det här e-postmeddelandet.",
"emails.certificate.subject": "Fallo del certificado para %s",
"emails.certificate.hello": "Hej",
"emails.certificate.body": "Certifikatet för din domän '{{domain}}' kunde inte skapas. Detta är försök nr {{attempt}}, och felet orsakades av: {{error}}",
"emails.certificate.footer": "Ditt tidigare certifikat kommer att vara giltigt i 30 dagar från det första felet. Vi rekommenderar starkt att du undersöker detta fall, annars kommer din domän att sluta utan en giltig SSL-kommunikation.",
"emails.certificate.thanks": "Tack",
"emails.certificate.signature": "equipo {{project}}"
"emails.certificate.signature": "equipo {{project}}",
"emails.magicSession.securityPhrase": "Frasen för säkerhet i detta e-postmeddelande är {{phrase}}. Du kan lita på detta e-postmeddelande om frasen stämmer överens med den fras som visas vid inloggning.",
"emails.magicSession.optionUrl": "Si no puedes iniciar sesión utilizando el botón de arriba, por favor visita el siguiente enlace:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "தென் அமெரிக்கா",
"emails.magicSession.optionButton": "கீழே உள்ள பொத்தானை அழுத்தி, உங்கள் {{project}} கணக்கில் பாதுகாப்பாக உள்நுழையவும். இது 1 மணி நேரத்தில் காலாவதியாகும்.",
"emails.magicSession.buttonText": "{{project}} இல் உள்நுழைக",
"emails.magicSession.optionUrl": "மேலே உள்ள பொத்தான் காட்சிப்படுத்தப்படவில்லை எனில், கீழே உள்ள இணைப்பைப் பயன்படுத்தவும்:",
"emails.magicSession.clientInfo": "இந்த உள்நுழைவு {{agentClient}} மூலம் {{agentDevice}} {{agentOs}} இல் கோரப்பட்டது. நீங்கள் உள்நுழைவு கோரவில்லை என்றால், இந்த மின்னஞ்சலை புறக்கணிக்கலாம்.",
"emails.certificate.subject": "%s சான்றிதழ் தோல்வி",
"emails.certificate.hello": "வணக்கம்",
"emails.certificate.body": "உங்கள் டொமைன் '{{domain}}' க்கான சான்றிதழ் உருவாக்க முடியவில்லை. இது முயற்சியின் எண் {{attempt}}, மற்றும் தோல்விக்கு காரணமாக இருந்தது: {{error}}",
"emails.certificate.footer": "உங்களுடைய முந்தைய சான்றிதழ் முதல் தவறு ஏற்பட்ட நாளிலிருந்து 30 நாட்கள் வரை செல்லுபடியாகும். இந்த வழக்கை ஆராய்வதை நாங்கள் மிகவும் பரிந்துரைக்கிறோம், இல்லையெனில் உங்களுடைய டொமைன் செல்லுபடியான SSL தகவல் தொடர்பை இழந்துவிடும்.",
"emails.certificate.thanks": "நன்றி",
"emails.certificate.signature": "{{project}} குழு"
"emails.certificate.signature": "{{project}} குழு",
"emails.magicSession.securityPhrase": "இந்த மின்னஞ்சலுக்கான பாதுகாப்பு வாசகம் {{phrase}}. இந்த வாசகம் உள்நுழைவு போது காட்டப்பட்ட வாசகத்துடன் பொருந்தும் போது இந்த மின்னஞ்சலை நம்பலாம்.",
"emails.magicSession.optionUrl": "மேலே உள்ள பொத்தானை பயன்படுத்தி உள்நுழைய முடியாவிட்டால், கீழே உள்ள இணைப்பை பார்வையிடவும்:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "దక్షిణ అమెరికా",
"emails.magicSession.optionButton": "కింది బటన్ ను నొక్కి భద్రతగా మీ {{project}} ఖాతాలో సైన్ ఇన్ చేయండి. ఇది 1 గంటలో గడువు తీరుతుంది.",
"emails.magicSession.buttonText": "{{project}}లో సైన్ ఇన్ చేయండి",
"emails.magicSession.optionUrl": "పైన ఉన్న బటన్ కనిపించకపోతే, కింది లింక్‌‌ని వాడండి:",
"emails.magicSession.clientInfo": "ఈ సైన్ ఇన్ అభ్యర్థనను {{agentClient}} ఉపయోగించి {{agentDevice}} {{agentOs}} పై అభ్యర్థించారు. మీరు ఈ సైన్ ఇన్ అభ్యర్థనను చేయలేదనుకుంటే, ఈ ఈమెయిల్‌ను సురక్షితంగా పట్టించుకోకుండా ఉండవచ్చు.",
"emails.certificate.subject": "%s కోసం సర్టిఫికేట్ విఫలం",
"emails.certificate.hello": "హలో",
"emails.certificate.body": "మీ డొమైన్ '{{domain}}' కోసం సర్టిఫికెట్ జారీ చేయలేకపోయాము. ఇది {{attempt}} ప్రయత్నం, మరియు విఫలం కారణం ఇది: {{error}}",
"emails.certificate.footer": "మీ మునుపటి సర్టిఫికెట్‌ మొదటి వైఫల్యం నుండి 30 రోజుల వరకు చెల్లుబాటు అవుతుంది. ఈ కేసును పరిశోధించడం మాకు ఎంతో ముఖ్యంగా సిఫార్సు ఉంది, లేకపోతే మీ డొమేన్ చెల్లుబాటు అయిన SSL కమ్యూనికేషన్ లేకుండా మిగిలిపోతుంది.",
"emails.certificate.thanks": "ధన్యవాదాలు",
"emails.certificate.signature": "{{project}} జట్టు"
"emails.certificate.signature": "{{project}} జట్టు",
"emails.magicSession.securityPhrase": "ఈ ఇమెయిల్ కోసం భద్రతా పదబంధం {{phrase}}. మీరు సైన్ ఇన్ సమయంలో చూపబడిన పదబంధంతో ఈ పదబంధం సరిపోలుతుంది అయితే ఈ ఇమెయిల్ నమ్మవచ్చు.",
"emails.magicSession.optionUrl": "పైన ఉన్న బటన్‌ను ఉపయోగించి సైన్ ఇన్ చేయలేకపోతే, దయచేసి క్రింది లింక్‌ను సందర్శించండి:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "อเมริกาใต้",
"emails.magicSession.optionButton": "คลิกที่ปุ่มด้านล่างเพื่อเข้าสู่บัญชี {{project}} ของคุณอย่างปลอดภัย ลิงก์นี้จะหมดอายุใน 1 ชั่วโมง",
"emails.magicSession.buttonText": "เข้าสู่ระบบใน {{project}}",
"emails.magicSession.optionUrl": "หากปุ่มด้านบนไม่ปรากฏ ให้ใช้ลิงค์ต่อไปนี้:",
"emails.magicSession.clientInfo": "การลงชื่อเข้าใช้นี้ถูกขอใช้งานผ่าน {{agentClient}} บน {{agentDevice}} {{agentOs}} หากคุณไม่ได้ขอลงชื่อเข้าใช้นี้ คุณสามารถละเลยอีเมลนี้ได้อย่างปลอดภัย",
"emails.certificate.subject": "หนังสือรับรองล้มเหลวสำหรับ %s",
"emails.certificate.hello": "สวัสดี",
"emails.certificate.body": "ใบรับรองสำหรับโดเมน '{{domain}}' ไม่สามารถสร้างได้ นี่เป็นความพยายามครั้งที่ {{attempt}} และความล้มเหลวเกิดจาก: {{error}}",
"emails.certificate.footer": "ใบรับรองก่อนหน้านี้ของคุณจะยังใช้งานได้เป็นเวลา 30 วันนับจากวันที่ล้มเหลวครั้งแรก เราขอแนะนำอย่างยิ่งให้คุณสืบสวนกรณีนี้ มิฉะนั้นโดเมนของคุณจะไม่มีการสื่อสาร SSL ที่ถูกต้อง",
"emails.certificate.thanks": "ขอบคุณ",
"emails.certificate.signature": "ทีม {{project}}"
"emails.certificate.signature": "ทีม {{project}}",
"emails.magicSession.securityPhrase": "วลีรักษาความปลอดภัยสำหรับอีเมลนี้คือ {{phrase}} คุณสามารถเชื่อถืออีเมลนี้ได้หากวลีนี้ตรงกับวลีที่แสดงในระหว่างการเข้าสู่ระบบ",
"emails.magicSession.optionUrl": "หากคุณไม่สามารถเข้าสู่ระบบโดยใช้ปุ่มด้านบน โปรดเยี่ยมชมลิงก์ต่อไปนี้:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Timog Amerika",
"emails.magicSession.optionButton": "I-click ang pindutan sa ibaba upang ligtas na mag-sign in sa iyong {{project}} account. Ito ay mag-eexpire sa loob ng 1 oras.",
"emails.magicSession.buttonText": "Mag-sign in sa {{project}}",
"emails.magicSession.optionUrl": "Kung hindi lumalabas ang button sa itaas, gamitin ang sumusunod na link:",
"emails.magicSession.clientInfo": "Ang pag-sign in na ito ay hiniling gamit ang {{agentClient}} sa {{agentDevice}} {{agentOs}}. Kung hindi ikaw ang humiling ng pag-sign in na ito, maaari mong ligtas na huwag pansinin ang email na ito.",
"emails.certificate.subject": "Sertipiko ng kabiguan para sa %s",
"emails.certificate.hello": "Kamusta",
"emails.certificate.body": "Sertipiko para sa iyong domain na '{{domain}}' ay hindi nabuo. Ito ay tangka bilang {{attempt}}, at ang kabiguan ay dulot ng: {{error}}",
"emails.certificate.footer": "Ang iyong naunang sertipiko ay magiging balido sa loob ng 30 araw simula ng unang kabiguan. Mataas ang inirerekomenda namin na imbestigahan ang kasong ito, kung hindi ay magtatapos ang iyong domain na walang balidong SSL na komunikasyon.",
"emails.certificate.thanks": "Salamat",
"emails.certificate.signature": "{{project}} koponan"
"emails.certificate.signature": "{{project}} koponan",
"emails.magicSession.securityPhrase": "Ang pariralang pangseguridad para sa email na ito ay {{phrase}}. Maaari mong pagkatiwalaan ang email na ito kung ang pariralang ito ay tumutugma sa pariralang ipinakita noong nag-sign in ka.",
"emails.magicSession.optionUrl": "Kung hindi ka makapag-sign in gamit ang pindutan sa itaas, mangyaring bisitahin ang sumusunod na link:"
}

View file

@ -237,6 +237,7 @@
"continents.sa": "Güney Amerika",
"emails.magicSession.optionButton": "Aşağıdaki butona tıklayarak {{project}} hesabınıza güvenli bir şekilde giriş yapın. Bu bağlantı bir saat sonra geçerliliğini yitirecektir.",
"emails.magicSession.buttonText": "{{project}}'a giriş yapın",
"emails.magicSession.optionUrl": "Yukarıdaki buton gözükmezse, aşağıdaki bağlantıyı kullanın:",
"emails.magicSession.clientInfo": "Bu oturum açma işlemi, {{agentClient}} kullanılarak {{agentDevice}} {{agentOs}} üzerinde istendi. Eğer oturum açma işlemini siz talep etmediyseniz, bu e-postayı güvenle yok sayabilirsiniz."
"emails.magicSession.clientInfo": "Bu oturum açma işlemi, {{agentClient}} kullanılarak {{agentDevice}} {{agentOs}} üzerinde istendi. Eğer oturum açma işlemini siz talep etmediyseniz, bu e-postayı güvenle yok sayabilirsiniz.",
"emails.magicSession.securityPhrase": "Bu e-postanın güvenlik ifadesi {{phrase}}'dir. Bu ifade, giriş sırasında gösterilen ifadeyle eşleşiyorsa bu e-postaya güvenebilirsiniz.",
"emails.magicSession.optionUrl": "Yukarıdaki butonu kullanarak giriş yapamıyorsanız, lütfen aşağıdaki bağlantıyı ziyaret edin:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Південна Америка",
"emails.magicSession.optionButton": "Натисніть кнопку нижче, щоб безпечно увійти в свій обліковий запис {{project}}. Термін дії закінчиться через 1 годину.",
"emails.magicSession.buttonText": "Увійти в {{project}}",
"emails.magicSession.optionUrl": "Якщо кнопка вище не відображається, скористайтеся наступним посиланням:",
"emails.magicSession.clientInfo": "Цей запит на вхід було здійснено за допомогою {{agentClient}} на {{agentDevice}} {{agentOs}}. Якщо ви не надсилали запит на вхід, ви можете сміливо ігнорувати цей електронний лист.",
"emails.certificate.subject": "Сертифікат не вдалося для %s",
"emails.certificate.hello": "Вітаю",
"emails.certificate.body": "Сертифікат для вашого домену '{{domain}}' не може бути створений. Це спроба № {{attempt}}, а причина збою: {{error}}",
"emails.certificate.footer": "Ваш попередній сертифікат буде дійсний протягом 30 днів з моменту першої помилки. Ми настійно рекомендуємо розслідувати цей випадок, інакше ваш домен залишиться без дійсного SSL-шифрування.",
"emails.certificate.thanks": "Дякую",
"emails.certificate.signature": "команда {{project}}"
"emails.certificate.signature": "команда {{project}}",
"emails.magicSession.securityPhrase": "Фраза безпеки для цього листа - {{phrase}}. Ви можете довіряти цьому листу, якщо ця фраза збігається з фразою, показаною під час входу в систему.",
"emails.magicSession.optionUrl": "Якщо вам не вдається увійти, використовуючи кнопку вище, будь ласка, перейдіть за наступним посиланням:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "جنوبی امریکہ",
"emails.magicSession.optionButton": "نیچے دیئے گئے بٹن پر کلک کرکے اپنے {{project}} اکاؤنٹ میں محفوظ طریقے سے سائن ان کریں۔ یہ ایک گھنٹے میں ختم ہو جائے گا۔",
"emails.magicSession.buttonText": "{{project}} میں سائن ان کریں",
"emails.magicSession.optionUrl": "اگر اوپر دیا گیا بٹن نہیں دکھتا، تو درج ذیل لنک کا استعمال کریں:",
"emails.magicSession.clientInfo": "یہ سائن ان {{agentClient}} کا استعمال کرتے ہوئے {{agentDevice}} {{agentOs}} پر کی گئی تھی۔ اگر آپ نے سائن ان کی درخواست نہیں کی تھی، تو آپ اس ایمیل کو نظرانداز کر سکتے ہیں۔",
"emails.certificate.subject": "%s کے لیے سرٹیفکیٹ کی ناکامی",
"emails.certificate.hello": "ہیلو",
"emails.certificate.body": "آپ کے ڈومین '{{domain}}' کے لئے سرٹیفکیٹ تیار نہیں کیا جا سکا۔ یہ کوشش نمبر {{attempt}} ہے، اور ناکامی کی وجہ یہ رہی: {{error}}",
"emails.certificate.footer": "آپ کا پچھلا سرٹیفیکیٹ پہلی ناکامی کے بعد سے 30 دن کے لیے درست ہوگا۔ ہم آپ کو شدید تاکید کرتے ہیں کہ اس معاملے کی تحقیق کریں، بصورت دیگر آپ کا ڈومین بغیر کسی درست SSL مواصلات کے رہ جائے گا۔",
"emails.certificate.thanks": "شکریہ",
"emails.certificate.signature": "ٹیم {{project}}"
"emails.certificate.signature": "ٹیم {{project}}",
"emails.magicSession.securityPhrase": "اس ای میل کے لئے سیکیورٹی جملہ {{phrase}} ہے۔ اگر یہ جملہ سائن ان کے دوران دکھائے گئے جملے سے میل کھاتا ہے تو آپ اس ای میل پر بھروسہ کرسکتے ہیں۔",
"emails.magicSession.optionUrl": "اگر آپ اوپر دیے گئے بٹن کا استعمال کرکے سائن ان نہیں کر سکتے تو براہ کرم مندرجہ ذیل لنک پر جائیں:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "Nam Mỹ",
"emails.magicSession.optionButton": "Nhấp vào nút bên dưới để đăng nhập an toàn vào tài khoản {{project}} của bạn. Nó sẽ hết hạn sau 1 giờ.",
"emails.magicSession.buttonText": "Đăng nhập vào {{project}}",
"emails.magicSession.optionUrl": "Nếu nút ở trên không hiển thị, hãy sử dụng liên kết sau:",
"emails.magicSession.clientInfo": "Yêu cầu đăng nhập này được thực hiện bằng {{agentClient}} trên {{agentDevice}} {{agentOs}}. Nếu bạn không yêu cầu đăng nhập, bạn có thể bỏ qua email này một cách an toàn.",
"emails.certificate.subject": "Lỗi chứng chỉ cho %s",
"emails.certificate.hello": "Xin chào",
"emails.certificate.body": "Chứng chỉ cho tên miền của bạn '{{domain}}' không thể được tạo ra. Đây là lần thử thứ {{attempt}}, và sự cố xảy ra do: {{error}}",
"emails.certificate.footer": "Chứng chỉ trước đây của bạn sẽ còn hiệu lực trong 30 ngày kể từ lần thất bại đầu tiên. Chúng tôi rất khuyến nghị bạn điều tra vụ việc này, nếu không miền của bạn sẽ kết thúc mà không có một sự giao tiếp SSL hợp lệ.",
"emails.certificate.thanks": "Cảm ơn",
"emails.certificate.signature": "đội {{project}}"
"emails.certificate.signature": "đội {{project}}",
"emails.magicSession.securityPhrase": "Cụm từ bảo mật cho email này là {{phrase}}. Bạn có thể tin tưởng email này nếu cụm từ này khớp với cụm từ hiển thị khi đăng nhập.",
"emails.magicSession.optionUrl": "Nếu bạn không thể đăng nhập bằng cách sử dụng nút ở trên, vui lòng truy cập liên kết sau:"
}

View file

@ -231,12 +231,13 @@
"continents.sa": "南美洲",
"emails.magicSession.optionButton": "点击下面的按钮安全登录您的{{project}}账户。该按钮将在1小时后过期。",
"emails.magicSession.buttonText": "登录{{project}}",
"emails.magicSession.optionUrl": "如果上面的按钮没有显示,请使用以下链接:",
"emails.magicSession.clientInfo": "此登录是通过{{agentClient}}在{{agentDevice}} {{agentOs}}上请求的。如果你没有请求登录,可以放心地忽略此邮件。",
"emails.certificate.subject": "%s 的证书失败",
"emails.certificate.hello": "你好",
"emails.certificate.body": "无法为您的域名“{{domain}}”生成证书。这是第{{attempt}}次尝试,失败的原因是:{{error}}。",
"emails.certificate.footer": "您之前的证书自首次失败之日起将有效期30天。我们强烈建议调查此案件否则您的域名将没有有效的SSL通信。",
"emails.certificate.thanks": "谢谢",
"emails.certificate.signature": "{{project}} 团队"
"emails.certificate.signature": "{{project}} 团队",
"emails.magicSession.securityPhrase": "此电子邮件的安全短语是{{phrase}}。如果此短语与登录时显示的短语相匹配,则您可以信任此电子邮件。",
"emails.magicSession.optionUrl": "如果您无法使用上面的按钮登录,请访问以下链接:"
}

View file

@ -237,6 +237,7 @@
"continents.sa": "南美洲",
"emails.magicSession.optionButton": "點擊下方按鈕安全登入您的{{project}}帳號。該按鈕將於1小時後失效。",
"emails.magicSession.buttonText": "登入 {{project}}",
"emails.magicSession.optionUrl": "如果上面的按鈕沒有顯示,請使用以下鏈接:",
"emails.magicSession.clientInfo": "這次的登入是透過{{agentClient}}在{{agentDevice}} {{agentOs}}上請求的。如果您沒有請求這次登入,您可以放心地忽略這封電子郵件。"
"emails.magicSession.clientInfo": "這次的登入是透過{{agentClient}}在{{agentDevice}} {{agentOs}}上請求的。如果您沒有請求這次登入,您可以放心地忽略這封電子郵件。",
"emails.magicSession.securityPhrase": "這封電子郵件的安全密語是{{phrase}}。如果此密語與登入時顯示的密語相符,您就可以信任此郵件。",
"emails.magicSession.optionUrl": "如果您無法使用上面的按鈕登錄,請訪問以下鏈接:"
}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View file

@ -115,14 +115,6 @@ return [
'question' => '',
'filter' => ''
],
// [
// 'name' => '_APP_CONSOLE_WHITELIST_DOMAINS',
// 'description' => 'This option allows you to limit creation of users to Appwrite console for users sharing the same email domains. This option is very useful for team working with company emails domain.\n\nTo enable this option, pass a list of allowed email domains separated by a comma.',
// 'introduction' => '',
// 'default' => '',
// 'required' => false,
// 'question' => '',
// ],
[
'name' => '_APP_CONSOLE_WHITELIST_IPS',
'description' => "This last option allows you to limit creation of users in Appwrite console for users sharing the same set of IP addresses. This option is very useful for team working with a VPN service or a company IP.\n\nTo enable/activate this option, pass a list of allowed IP addresses separated by a comma.",
@ -132,6 +124,15 @@ return [
'question' => '',
'filter' => ''
],
[
'name' => '_APP_CONSOLE_HOSTNAMES',
'description' => 'This option allows you to add additional hostnames to your Appwrite console. This option is very useful for allowing access to the console project from additional domains. To enable it, pass a list of allowed hostnames separated by a comma.',
'introduction' => '1.5.0',
'default' => '',
'required' => false,
'question' => '',
'filter' => ''
],
[
'name' => '_APP_SYSTEM_EMAIL_NAME',
'description' => 'This is the sender name value that will appear on email messages sent to developers from the Appwrite console. The default value is: \'Appwrite\'. You can use url encoded strings for spaces and special chars.',

View file

@ -8,10 +8,12 @@ use Appwrite\Auth\Validator\Phone;
use Appwrite\Detector\Detector;
use Appwrite\Event\Event;
use Appwrite\Event\Mail;
use Appwrite\Auth\SecurityPhrase;
use Appwrite\Extend\Exception;
use Appwrite\Network\Validator\Email;
use Utopia\Validator\Host;
use Utopia\Validator\URL;
use Utopia\Validator\Boolean;
use Appwrite\OpenSSL\OpenSSL;
use Appwrite\Template\Template;
use Appwrite\URL\URL as URLParser;
@ -932,6 +934,7 @@ App::post('/v1/account/sessions/magic-url')
->param('userId', '', new CustomId(), 'Unique Id. Choose a custom ID or generate a random ID with `ID.unique()`. Valid chars are a-z, A-Z, 0-9, period, hyphen, and underscore. Can\'t start with a special char. Max length is 36 chars.')
->param('email', '', new Email(), 'User email.')
->param('url', '', fn($clients) => new Host($clients), 'URL to redirect the user back to your app from the magic URL login. Only URLs from hostnames in your project platform list are allowed. This requirement helps to prevent an [open redirect](https://cheatsheetseries.owasp.org/cheatsheets/Unvalidated_Redirects_and_Forwards_Cheat_Sheet.html) attack against your project API.', true, ['clients'])
->param('securityPhrase', false, new Boolean(), 'Toggle for security phrase. If enabled, email will be send with a randomly generated phrase and the phrase will also be included in the response. Confirming phrases match increases the security of authentication flow.', true)
->inject('request')
->inject('response')
->inject('user')
@ -940,12 +943,16 @@ App::post('/v1/account/sessions/magic-url')
->inject('locale')
->inject('queueForEvents')
->inject('queueForMails')
->action(function (string $userId, string $email, string $url, Request $request, Response $response, Document $user, Document $project, Database $dbForProject, Locale $locale, Event $queueForEvents, Mail $queueForMails) {
->action(function (string $userId, string $email, string $url, bool $securityPhrase, Request $request, Response $response, Document $user, Document $project, Database $dbForProject, Locale $locale, Event $queueForEvents, Mail $queueForMails) {
if (empty(App::getEnv('_APP_SMTP_HOST'))) {
throw new Exception(Exception::GENERAL_SMTP_DISABLED, 'SMTP disabled');
}
if ($securityPhrase === true) {
$securityPhrase = SecurityPhrase::generate();
}
$roles = Authorization::getRoles();
$isPrivilegedUser = Auth::isPrivilegedUser($roles);
$isAppUser = Auth::isAppUser($roles);
@ -1054,6 +1061,13 @@ App::post('/v1/account/sessions/magic-url')
->setParam('{{clientInfo}}', $locale->getText("emails.magicSession.clientInfo"))
->setParam('{{thanks}}', $locale->getText("emails.magicSession.thanks"))
->setParam('{{signature}}', $locale->getText("emails.magicSession.signature"));
if (!empty($securityPhrase)) {
$message->setParam('{{securityPhrase}}', $locale->getText("emails.magicSession.securityPhrase"));
} else {
$message->setParam('{{securityPhrase}}', '');
}
$body = $message->render();
$smtp = $project->getAttribute('smtp', []);
@ -1111,7 +1125,8 @@ App::post('/v1/account/sessions/magic-url')
'redirect' => $url,
'agentDevice' => $agentDevice['deviceBrand'] ?? $agentDevice['deviceBrand'] ?? 'UNKNOWN',
'agentClient' => $agentClient['clientName'] ?? 'UNKNOWN',
'agentOs' => $agentOs['osName'] ?? 'UNKNOWN'
'agentOs' => $agentOs['osName'] ?? 'UNKNOWN',
'phrase' => '<strong>' . (!empty($securityPhrase) ? $securityPhrase : '') . '</strong>'
];
$queueForMails
@ -1131,6 +1146,10 @@ App::post('/v1/account/sessions/magic-url')
// Hide secret for clients
$token->setAttribute('secret', ($isPrivilegedUser || $isAppUser) ? $loginSecret : '');
if (!empty($securityPhrase)) {
$token->setAttribute('securityPhrase', $securityPhrase);
}
$response
->setStatusCode(Response::STATUS_CODE_CREATED)
->dynamic($token, Response::MODEL_TOKEN)

View file

@ -74,6 +74,7 @@ use Utopia\Queue\Connection;
use Utopia\Storage\Storage;
use Utopia\VCS\Adapter\Git\GitHub as VcsGitHub;
use Utopia\Validator\Range;
use Utopia\Validator\Hostname;
use Utopia\Validator\IP;
use Utopia\Validator\URL;
use Utopia\Validator\WhiteList;
@ -1051,6 +1052,21 @@ App::setResource('clients', function ($request, $console, $project) {
'hostname' => $request->getHostname(),
], Document::SET_TYPE_APPEND);
$hostnames = explode(',', App::getEnv('_APP_CONSOLE_HOSTNAMES', ''));
$validator = new Hostname();
foreach ($hostnames as $hostname) {
$hostname = trim($hostname);
if (!$validator->isValid($hostname)) {
continue;
}
$console->setAttribute('platforms', [
'$collection' => ID::custom('platforms'),
'type' => Origin::CLIENT_TYPE_WEB,
'name' => $hostname,
'hostname' => $hostname,
], Document::SET_TYPE_APPEND);
}
/**
* Get All verified client URLs for both console and current projects
* + Filter for duplicated entries

View file

@ -79,6 +79,7 @@ services:
- _APP_CONSOLE_WHITELIST_ROOT
- _APP_CONSOLE_WHITELIST_EMAILS
- _APP_CONSOLE_WHITELIST_IPS
- _APP_CONSOLE_HOSTNAMES
- _APP_SYSTEM_EMAIL_NAME
- _APP_SYSTEM_EMAIL_ADDRESS
- _APP_SYSTEM_SECURITY_EMAIL_ADDRESS
@ -273,7 +274,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-uploads:/storage/uploads:rw
- appwrite-cache:/storage/cache:rw
- appwrite-functions:/storage/functions:rw
@ -420,7 +421,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-config:/storage/config:rw
- appwrite-certificates:/storage/certificates:rw
environment:
@ -658,7 +659,7 @@ services:
- _APP_DB_PASS
appwrite-assistant:
image: appwrite/assistant:0.2.2
image: appwrite/assistant:0.3.0
container_name: appwrite-assistant
<<: *x-logging
restart: unless-stopped

View file

@ -202,6 +202,12 @@ if (!empty($workerIndex)) {
$workerName .= '_' . $workerIndex;
}
if (\str_starts_with($workerName, 'databases')) {
$queueName = App::getEnv('_APP_QUEUE_NAME', 'database_db_main');
} else {
$queueName = App::getEnv('_APP_QUEUE_NAME', 'v1-' . strtolower($workerName));
}
try {
/**
* Any worker can be configured with the following env vars:
@ -209,12 +215,6 @@ try {
* - _APP_WORKER_PER_CORE The number of worker processes per core (ignored if _APP_WORKERS_NUM is set)
* - _APP_QUEUE_NAME The name of the queue to read for database events
*/
if ($workerName === 'databases') {
$queueName = App::getEnv('_APP_QUEUE_NAME', 'database_db_main');
} else {
$queueName = App::getEnv('_APP_QUEUE_NAME', 'v1-' . strtolower($workerName));
}
$platform->init(Service::TYPE_WORKER, [
'workersNum' => App::getEnv('_APP_WORKERS_NUM', 1),
'connection' => $pools->get('queue')->pop()->getResource(),
@ -240,20 +240,20 @@ $worker
->inject('error')
->inject('logger')
->inject('log')
->action(function (Throwable $error, ?Logger $logger, Log $log) {
->action(function (Throwable $error, ?Logger $logger, Log $log) use ($queueName) {
$version = App::getEnv('_APP_VERSION', 'UNKNOWN');
if ($error instanceof PDOException) {
throw $error;
}
if ($logger && ($error->getCode() >= 500 || $error->getCode() === 0)) {
if ($logger) {
$log->setNamespace("appwrite-worker");
$log->setServer(\gethostname());
$log->setVersion($version);
$log->setType(Log::TYPE_ERROR);
$log->setMessage($error->getMessage());
$log->setAction('appwrite-queue-' . App::getEnv('QUEUE'));
$log->setAction('appwrite-queue-' . $queueName);
$log->addTag('verboseType', get_class($error));
$log->addTag('code', $error->getCode());
$log->addExtra('file', $error->getFile());

View file

@ -53,7 +53,7 @@ services:
DEBUG: false
TESTING: true
VERSION: dev
ports:
ports:
- 9501:80
networks:
- appwrite
@ -88,7 +88,7 @@ services:
- mariadb
- redis
# - clamav
entrypoint:
entrypoint:
- php
- -e
- app/http.php
@ -100,6 +100,7 @@ services:
- _APP_CONSOLE_WHITELIST_ROOT
- _APP_CONSOLE_WHITELIST_EMAILS
- _APP_CONSOLE_WHITELIST_IPS
- _APP_CONSOLE_HOSTNAMES
- _APP_SYSTEM_EMAIL_NAME
- _APP_SYSTEM_EMAIL_ADDRESS
- _APP_SYSTEM_SECURITY_EMAIL_ADDRESS
@ -197,7 +198,7 @@ services:
container_name: appwrite-realtime
image: appwrite-dev
restart: unless-stopped
ports:
ports:
- 9505:80
labels:
- "traefik.enable=true"
@ -312,7 +313,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-uploads:/storage/uploads:rw
- appwrite-cache:/storage/cache:rw
- appwrite-functions:/storage/functions:rw
@ -366,7 +367,7 @@ services:
image: appwrite-dev
networks:
- appwrite
volumes:
volumes:
- ./app:/usr/src/code/app
- ./src:/usr/src/code/src
depends_on:
@ -465,7 +466,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-config:/storage/config:rw
- appwrite-certificates:/storage/certificates:rw
- ./app:/usr/src/code/app
@ -726,7 +727,7 @@ services:
appwrite-assistant:
container_name: appwrite-assistant
image: appwrite/assistant:0.2.2
image: appwrite/assistant:0.3.0
networks:
- appwrite
environment:
@ -759,7 +760,7 @@ services:
- _APP_REDIS_USER
- _APP_REDIS_PASS
- _APP_MIXPANEL_TOKEN
appwrite-hamster-scheduler:
entrypoint: hamster
<<: *x-logging
@ -1010,7 +1011,7 @@ services:
# - './debug:/tmp'
# ports:
# - '3001:80'
graphql-explorer:
container_name: appwrite-graphql-explorer
image: appwrite/altair:0.3.0

View file

@ -0,0 +1,20 @@
<?php
namespace Appwrite\Auth;
class SecurityPhrase
{
public static function generate(): string
{
$adjectives = ["Abundant", "Adaptable", "Adventurous", "Affectionate", "Agile", "Amiable", "Amazing", "Ambitious", "Amicable", "Amusing", "Astonishing", "Attentive", "Authentic", "Awesome", "Balanced", "Beautiful", "Bold", "Brave", "Bright", "Bubbly", "Calm", "Capable", "Charismatic", "Charming", "Cheerful", "Clever", "Colorful", "Compassionate", "Confident", "Cooperative", "Courageous", "Courteous", "Creative", "Curious", "Dazzling", "Dedicated", "Delightful", "Determined", "Diligent", "Dynamic", "Easygoing", "Effervescent", "Efficient", "Elegant", "Empathetic", "Energetic", "Enthusiastic", "Exuberant", "Faithful", "Fantastic", "Fearless", "Flexible", "Friendly", "Fun-loving", "Generous", "Gentle", "Genuine", "Graceful", "Gracious", "Happy", "Hardworking", "Harmonious", "Helpful", "Honest", "Hopeful", "Humble", "Imaginative", "Impressive", "Incredible", "Inspiring", "Intelligent", "Joyful", "Kind", "Knowledgeable", "Lively", "Lovable", "Lovely", "Loyal", "Majestic", "Magnificent", "Mindful", "Modest", "Passionate", "Patient", "Peaceful", "Perseverant", "Playful", "Polite", "Positive", "Powerful", "Practical", "Precious", "Proactive", "Productive", "Punctual", "Quick-witted", "Radiant", "Reliable", "Resilient", "Resourceful", "Respectful", "Responsible", "Sensitive", "Serene", "Sincere", "Skillful", "Soothing", "Spirited", "Splendid", "Steadfast", "Strong", "Supportive", "Sweet", "Talented", "Thankful", "Thoughtful", "Thriving", "Tranquil", "Trustworthy", "Upbeat", "Versatile", "Vibrant", "Vigilant", "Warmhearted", "Welcoming", "Wholesome", "Witty", "Wonderful", "Zealous"];
$nouns = ["apple", "banana", "cat", "dog", "elephant", "fish", "guitar", "hat", "ice cream", "jacket", "kangaroo", "lemon", "moon", "notebook", "orange", "piano", "quilt", "rabbit", "sun", "tree", "umbrella", "violin", "watermelon", "xylophone", "yogurt", "zebra", "airplane", "ball", "cloud", "diamond", "eagle", "fire", "giraffe", "hammer", "island", "jellyfish", "kiwi", "lamp", "mango", "needle", "ocean", "pear", "quasar", "rose", "star", "turtle", "unicorn", "volcano", "whale", "xylograph", "yarn", "zephyr", "ant", "book", "candle", "door", "envelope", "feather", "globe", "harp", "insect", "jar", "kite", "lighthouse", "magnet", "necklace", "owl", "puzzle", "queen", "rainbow", "sailboat", "telescope", "umbrella", "vase", "wallet", "xylograph", "yacht", "zeppelin", "accordion", "brush", "chocolate", "dolphin", "easel", "fountain", "globe", "hairbrush", "iceberg", "jigsaw", "kettle", "leopard", "marble", "nutmeg", "obstacle", "penguin", "quiver", "raccoon", "sphinx", "trampoline", "utensil", "velvet", "wagon", "xerox", "yodel", "zipper"];
$adjective = $adjectives[array_rand($adjectives)];
$noun = $nouns[array_rand($nouns)];
$phrase = "{$adjective} {$noun}";
return $phrase;
}
}

View file

@ -22,7 +22,7 @@ class DevGenerateTranslations extends Action
{
$this
->desc('Generate translations in all languages')
->param('dry-run', true, new Boolean(true), 'If action should do a dry run. Dry run does not write into files', true)
->param('dry-run', 'true', new Boolean(true), 'If action should do a dry run. Dry run does not write into files', true)
->param('api-key', '', new Text(256), 'Open AI API key. Only used during non-dry runs to generate translations.', true)
->callback(fn ($dryRun, $apiKey) => $this->action($dryRun, $apiKey));
}
@ -52,6 +52,12 @@ class DevGenerateTranslations extends Action
$fileJson = \json_decode(\file_get_contents($dir . '/' . $file), true);
$fileKeys = \array_keys($fileJson);
// Trick to clear specific key from all translation files:
// $json = \json_decode(\file_get_contents($dir . '/' . $file), true);
// unset($json['emails.magicSession.optionUrl']);
// \file_put_contents($dir . '/' . $file, \json_encode($json, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES | 0));
// continue;
foreach ($mainKeys as $key) {
if (!(\in_array($key, $fileKeys))) {
if ($dryRun) {

View file

@ -4,7 +4,6 @@ namespace Appwrite\Platform\Workers;
use Appwrite\Event\Event;
use Appwrite\Event\Func;
use Appwrite\Event\Usage;
use Appwrite\Messaging\Adapter\Realtime;
use Appwrite\Usage\Stats;
use Appwrite\Utopia\Response\Model\Deployment;
@ -24,10 +23,10 @@ use Utopia\Database\Exception\Restricted;
use Utopia\Database\Validator\Authorization;
use Utopia\Database\Exception\Structure;
use Utopia\Database\Helpers\ID;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
use Utopia\Storage\Device\Local;
use Utopia\Storage\Storage;
use Utopia\VCS\Adapter\Git\GitHub;
class Builds extends Action
@ -52,7 +51,8 @@ class Builds extends Action
->inject('cache')
->inject('dbForProject')
->inject('getFunctionsDevice')
->callback(fn($message, Database $dbForConsole, Event $queueForEvents, Func $queueForFunctions, Stats $usage, Cache $cache, Database $dbForProject, callable $getFunctionsDevice) => $this->action($message, $dbForConsole, $queueForEvents, $queueForFunctions, $usage, $cache, $dbForProject, $getFunctionsDevice));
->inject('log')
->callback(fn($message, Database $dbForConsole, Event $queueForEvents, Func $queueForFunctions, Stats $usage, Cache $cache, Database $dbForProject, callable $getFunctionsDevice, Log $log) => $this->action($message, $dbForConsole, $queueForEvents, $queueForFunctions, $usage, $cache, $dbForProject, $getFunctionsDevice, $log));
}
/**
@ -64,10 +64,11 @@ class Builds extends Action
* @param Cache $cache
* @param Database $dbForProject
* @param callable $getFunctionsDevice
* @param Log $log
* @return void
* @throws \Utopia\Database\Exception
*/
public function action(Message $message, Database $dbForConsole, Event $queueForEvents, Func $queueForFunctions, Stats $usage, Cache $cache, Database $dbForProject, callable $getFunctionsDevice): void
public function action(Message $message, Database $dbForConsole, Event $queueForEvents, Func $queueForFunctions, Stats $usage, Cache $cache, Database $dbForProject, callable $getFunctionsDevice, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -81,12 +82,15 @@ class Builds extends Action
$deployment = new Document($payload['deployment'] ?? []);
$template = new Document($payload['template'] ?? []);
$log->addTag('projectId', $project->getId());
$log->addTag('type', $type);
switch ($type) {
case BUILD_TYPE_DEPLOYMENT:
case BUILD_TYPE_RETRY:
Console::info('Creating build for deployment: ' . $deployment->getId());
$github = new GitHub($cache);
$this->buildDeployment($getFunctionsDevice, $queueForFunctions, $queueForEvents, $usage, $dbForConsole, $dbForProject, $github, $project, $resource, $deployment, $template);
$this->buildDeployment($getFunctionsDevice, $queueForFunctions, $queueForEvents, $usage, $dbForConsole, $dbForProject, $github, $project, $resource, $deployment, $template, $log);
break;
default:
@ -106,20 +110,27 @@ class Builds extends Action
* @param Document $function
* @param Document $deployment
* @param Document $template
* @param Log $log
* @return void
* @throws \Utopia\Database\Exception
* @throws Exception
*/
protected function buildDeployment(callable $getFunctionsDevice, Func $queueForFunctions, Event $queueForEvents, Stats $usage, Database $dbForConsole, Database $dbForProject, GitHub $github, Document $project, Document $function, Document $deployment, Document $template): void
protected function buildDeployment(callable $getFunctionsDevice, Func $queueForFunctions, Event $queueForEvents, Stats $usage, Database $dbForConsole, Database $dbForProject, GitHub $github, Document $project, Document $function, Document $deployment, Document $template, Log $log): void
{
$executor = new Executor(App::getEnv('_APP_EXECUTOR_HOST'));
$function = $dbForProject->getDocument('functions', $function->getId());
$functionId = $function->getId();
$log->addTag('functionId', $function->getId());
$function = $dbForProject->getDocument('functions', $functionId);
if ($function->isEmpty()) {
throw new Exception('Function not found', 404);
}
$deployment = $dbForProject->getDocument('deployments', $deployment->getId());
$deploymentId = $deployment->getId();
$log->addTag('deploymentId', $deploymentId);
$deployment = $dbForProject->getDocument('deployments', $deploymentId);
if ($deployment->isEmpty()) {
throw new Exception('Deployment not found', 404);
}
@ -501,10 +512,7 @@ class Builds extends Action
$build->setAttribute('endTime', $endTime);
$build->setAttribute('duration', \intval(\ceil($durationEnd - $durationStart)));
$build->setAttribute('status', 'failed');
$build->setAttribute('logs', $th->getMessage());
Console::error($th->getMessage());
Console::error($th->getFile() . ':' . $th->getLine());
Console::error($th->getTraceAsString());
$build->setAttribute('logs', $th->getMessage() . "\n" . $th->getFile() . ':' . $th->getLine() . "\n" . $th->getTraceAsString());
if ($isVcsEnabled) {
$this->runGitAction('failed', $github, $providerCommitHash, $owner, $repositoryName, $project, $function, $deployment->getId(), $dbForProject, $dbForConsole);

View file

@ -23,6 +23,7 @@ use Utopia\Database\Helpers\ID;
use Utopia\Database\Query;
use Utopia\Domains\Domain;
use Utopia\Locale\Locale;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
@ -45,7 +46,8 @@ class Certificates extends Action
->inject('queueForMails')
->inject('queueForEvents')
->inject('queueForFunctions')
->callback(fn(Message $message, Database $dbForConsole, Mail $queueForMails, Event $queueForEvents, Func $queueForFunctions) => $this->action($message, $dbForConsole, $queueForMails, $queueForEvents, $queueForFunctions));
->inject('log')
->callback(fn(Message $message, Database $dbForConsole, Mail $queueForMails, Event $queueForEvents, Func $queueForFunctions, Log $log) => $this->action($message, $dbForConsole, $queueForMails, $queueForEvents, $queueForFunctions, $log));
}
/**
@ -54,11 +56,12 @@ class Certificates extends Action
* @param Mail $queueForMails
* @param Event $queueForEvents
* @param Func $queueForFunctions
* @param Log $log
* @return void
* @throws Throwable
* @throws \Utopia\Database\Exception
*/
public function action(Message $message, Database $dbForConsole, Mail $queueForMails, Event $queueForEvents, Func $queueForFunctions): void
public function action(Message $message, Database $dbForConsole, Mail $queueForMails, Event $queueForEvents, Func $queueForFunctions, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -70,6 +73,8 @@ class Certificates extends Action
$domain = new Domain($document->getAttribute('domain', ''));
$skipRenewCheck = $payload['skipRenewCheck'] ?? false;
$log->addTag('domain', $domain->get());
$this->execute($domain, $dbForConsole, $queueForMails, $queueForEvents, $queueForFunctions, $skipRenewCheck);
}

View file

@ -4,7 +4,6 @@ namespace Appwrite\Platform\Workers;
use Appwrite\Event\Event;
use Appwrite\Messaging\Adapter\Realtime;
use Appwrite\Utopia\Response\Model\Platform;
use Exception;
use Utopia\Audit\Audit;
use Utopia\CLI\Console;
@ -16,6 +15,7 @@ use Utopia\Database\Exception\Restricted;
use Utopia\Database\Exception\Structure;
use Utopia\Database\Exception as DatabaseException;
use Utopia\Database\Query;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
@ -36,17 +36,19 @@ class Databases extends Action
->inject('message')
->inject('dbForConsole')
->inject('dbForProject')
->callback(fn($message, $dbForConsole, $dbForProject) => $this->action($message, $dbForConsole, $dbForProject));
->inject('log')
->callback(fn(Message $message, Database $dbForConsole, Database $dbForProject, Log $log) => $this->action($message, $dbForConsole, $dbForProject, $log));
}
/**
* @param Message $message
* @param Database $dbForConsole
* @param Database $dbForProject
* @param Log $log
* @return void
* @throws \Exception
*/
public function action(Message $message, Database $dbForConsole, Database $dbForProject): void
public function action(Message $message, Database $dbForConsole, Database $dbForProject, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -60,18 +62,23 @@ class Databases extends Action
$document = new Document($payload['document'] ?? []);
$database = new Document($payload['database'] ?? []);
$log->addTag('projectId', $project->getId());
$log->addTag('type', $type);
if ($database->isEmpty()) {
throw new Exception('Missing database');
}
match (strval($type)) {
$log->addTag('databaseId', $database->getId());
match (\strval($type)) {
DATABASE_TYPE_DELETE_DATABASE => $this->deleteDatabase($database, $project, $dbForProject),
DATABASE_TYPE_DELETE_COLLECTION => $this->deleteCollection($database, $collection, $project, $dbForProject),
DATABASE_TYPE_CREATE_ATTRIBUTE => $this->createAttribute($database, $collection, $document, $project, $dbForConsole, $dbForProject),
DATABASE_TYPE_DELETE_ATTRIBUTE => $this->deleteAttribute($database, $collection, $document, $project, $dbForConsole, $dbForProject),
DATABASE_TYPE_CREATE_INDEX => $this->createIndex($database, $collection, $document, $project, $dbForConsole, $dbForProject),
DATABASE_TYPE_DELETE_INDEX => $this->deleteIndex($database, $collection, $document, $project, $dbForConsole, $dbForProject),
default => Console::error('No database operation for type: ' . $type),
default => throw new \Exception('No database operation for type: ' . \strval($type)),
};
}
@ -159,6 +166,7 @@ class Databases extends Action
$dbForProject->updateDocument('attributes', $attribute->getId(), $attribute->setAttribute('status', 'available'));
} catch (\Exception $e) {
// TODO: Send non DatabaseExceptions to Sentry
Console::error($e->getMessage());
if ($e instanceof DatabaseException) {
@ -168,6 +176,7 @@ class Databases extends Action
}
}
$dbForProject->updateDocument(
'attributes',
$attribute->getId(),
@ -261,6 +270,7 @@ class Databases extends Action
$dbForProject->deleteDocument('attributes', $relatedAttribute->getId());
}
} catch (\Exception $e) {
// TODO: Send non DatabaseExceptions to Sentry
Console::error($e->getMessage());
if ($e instanceof DatabaseException) {
@ -388,6 +398,7 @@ class Databases extends Action
}
$dbForProject->updateDocument('indexes', $index->getId(), $index->setAttribute('status', 'available'));
} catch (\Exception $e) {
// TODO: Send non DatabaseExceptions to Sentry
Console::error($e->getMessage());
if ($e instanceof DatabaseException) {
@ -445,6 +456,7 @@ class Databases extends Action
$dbForProject->deleteDocument('indexes', $index->getId());
$index->setAttribute('status', 'deleted');
} catch (\Exception $e) {
// TODO: Send non DatabaseExceptions to Sentry
Console::error($e->getMessage());
if ($e instanceof DatabaseException) {
@ -581,7 +593,7 @@ class Databases extends Action
$callback($document);
}
} else {
Console::error('Failed to delete document: ' . $document->getId());
Console::warning('Failed to delete document: ' . $document->getId());
}
$count++;
}

View file

@ -21,6 +21,7 @@ use Utopia\Database\Exception\Conflict;
use Utopia\Database\Exception\Restricted;
use Utopia\Database\Exception\Structure;
use Utopia\Database\Query;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
use Utopia\Storage\Device;
@ -46,14 +47,15 @@ class Deletes extends Action
->inject('getFunctionsDevice')
->inject('getBuildsDevice')
->inject('getCacheDevice')
->callback(fn ($message, $dbForConsole, callable $getProjectDB, callable $getFilesDevice, callable $getFunctionsDevice, callable $getBuildsDevice, callable $getCacheDevice) => $this->action($message, $dbForConsole, $getProjectDB, $getFilesDevice, $getFunctionsDevice, $getBuildsDevice, $getCacheDevice));
->inject('log')
->callback(fn ($message, $dbForConsole, callable $getProjectDB, callable $getFilesDevice, callable $getFunctionsDevice, callable $getBuildsDevice, callable $getCacheDevice, Log $log) => $this->action($message, $dbForConsole, $getProjectDB, $getFilesDevice, $getFunctionsDevice, $getBuildsDevice, $getCacheDevice, $log));
}
/**
* @throws Exception
* @throws Throwable
*/
public function action(Message $message, Database $dbForConsole, callable $getProjectDB, callable $getFilesDevice, callable $getFunctionsDevice, callable $getBuildsDevice, callable $getCacheDevice): void
public function action(Message $message, Database $dbForConsole, callable $getProjectDB, callable $getFilesDevice, callable $getFunctionsDevice, callable $getBuildsDevice, callable $getCacheDevice, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -68,7 +70,10 @@ class Deletes extends Action
$document = new Document($payload['document'] ?? []);
$project = new Document($payload['project'] ?? []);
switch (strval($type)) {
$log->addTag('projectId', $project->getId());
$log->addTag('type', $type);
switch (\strval($type)) {
case DELETE_TYPE_DOCUMENT:
switch ($document->getCollection()) {
case DELETE_TYPE_DATABASES:
@ -154,7 +159,7 @@ class Deletes extends Action
$this->deleteTopic($project, $getProjectDB, $document);
break;
default:
Console::error('No delete operation for type: ' . $type);
throw new \Exception('No delete operation for type: ' . \strval($type));
break;
}
}

View file

@ -90,6 +90,10 @@ class Functions extends Action
return;
}
$log->addTag('functionId', $function->getId());
$log->addTag('projectId', $project->getId());
$log->addTag('type', $type);
if (!empty($events)) {
$limit = 30;
$sum = 30;
@ -236,15 +240,14 @@ class Functions extends Action
string $eventData = null,
string $executionId = null,
): void {
$user ??= new Document();
$functionId = $function->getId();
$deploymentId = $function->getAttribute('deployment', '');
$user ??= new Document();
$functionId = $function->getId();
$deploymentId = $function->getAttribute('deployment', '');
$log->addTag('functionId', $functionId);
$log->addTag('projectId', $project->getId());
$log->addTag('deploymentId', $deploymentId);
/** Check if deployment exists */
$deployment = $dbForProject->getDocument('deployments', $deploymentId);
/** Check if deployment exists */
$deployment = $dbForProject->getDocument('deployments', $deploymentId);
if ($deployment->getAttribute('resourceId') !== $functionId) {
throw new Exception('Deployment not found. Create deployment before trying to execute a function');
@ -254,8 +257,12 @@ class Functions extends Action
throw new Exception('Deployment not found. Create deployment before trying to execute a function');
}
/** Check if build has exists */
$build = $dbForProject->getDocument('builds', $deployment->getAttribute('buildId', ''));
$buildId = $deployment->getAttribute('buildId', '');
$log->addTag('buildId', $buildId);
/** Check if build has exists */
$build = $dbForProject->getDocument('builds', $buildId);
if ($build->isEmpty()) {
throw new Exception('Build not found');
}
@ -264,7 +271,7 @@ class Functions extends Action
throw new Exception('Build not ready');
}
/** Check if runtime is supported */
/** Check if runtime is supported */
$version = $function->getAttribute('version', 'v2');
$runtimes = Config::getParam($version === 'v2' ? 'runtimes-v2' : 'runtimes', []);

View file

@ -7,7 +7,7 @@ use Exception;
use PHPMailer\PHPMailer\PHPMailer;
use Swoole\Runtime;
use Utopia\App;
use Utopia\CLI\Console;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
use Utopia\Registry\Registry;
@ -28,17 +28,19 @@ class Mails extends Action
->desc('Mails worker')
->inject('message')
->inject('register')
->callback(fn($message, $register) => $this->action($message, $register));
->inject('log')
->callback(fn(Message $message, Registry $register, Log $log) => $this->action($message, $register, $log));
}
/**
* @param Message $message
* @param Registry $register
* @param Log $log
* @throws \PHPMailer\PHPMailer\Exception
* @return void
* @throws Exception
*/
public function action(Message $message, Registry $register): void
public function action(Message $message, Registry $register, Log $log): void
{
Runtime::setHookFlags(SWOOLE_HOOK_ALL ^ SWOOLE_HOOK_TCP);
$payload = $message->getPayload() ?? [];
@ -50,10 +52,11 @@ class Mails extends Action
$smtp = $payload['smtp'];
if (empty($smtp) && empty(App::getEnv('_APP_SMTP_HOST'))) {
Console::info('Skipped mail processing. No SMTP configuration has been set.');
return;
throw new Exception('Skipped mail processing. No SMTP configuration has been set.');
}
$log->addTag('type', empty($smtp) ? 'cloud' : 'smtp');
$recipient = $payload['recipient'];
$subject = $payload['subject'];
$variables = $payload['variables'];

View file

@ -7,6 +7,7 @@ use Utopia\App;
use Utopia\CLI\Console;
use Utopia\Database\Helpers\ID;
use Utopia\DSN\DSN;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
use Utopia\Database\Database;
@ -48,28 +49,29 @@ class Messaging extends Action
$this
->desc('Messaging worker')
->inject('message')
->inject('log')
->inject('dbForProject')
->callback(fn(Message $message, Database $dbForProject) => $this->action($message, $dbForProject));
->callback(fn(Message $message, Log $log, Database $dbForProject) => $this->action($message, $log, $dbForProject));
}
/**
* @param Message $message
* @param Log $log
* @param Database $dbForProject
* @return void
* @throws Exception
*/
public function action(Message $message, Database $dbForProject): void
public function action(Message $message, Log $log, Database $dbForProject): void
{
$payload = $message->getPayload() ?? [];
if (empty($payload)) {
Console::error('Payload not found.');
return;
throw new \Exception('Payload not found.');
}
if (!\is_null($payload['message']) && !\is_null($payload['recipients'])) {
if ($payload['providerType'] === MESSAGE_TYPE_SMS) {
$this->processInternalSMSMessage(new Document($payload['message']), $payload['recipients']);
$this->processInternalSMSMessage($log, new Document($payload['message']), $payload['recipients']);
}
} else {
$message = $dbForProject->getDocument('messages', $payload['messageId']);
@ -248,11 +250,10 @@ class Messaging extends Action
$dbForProject->updateDocument('messages', $message->getId(), $message);
}
private function processInternalSMSMessage(Document $message, array $recipients): void
private function processInternalSMSMessage(Log $log, Document $message, array $recipients): void
{
if (empty(App::getEnv('_APP_SMS_PROVIDER')) || empty(App::getEnv('_APP_SMS_FROM'))) {
Console::info('Skipped SMS processing. No Phone configuration has been set.');
return;
throw new \Exception('Skipped SMS processing. No Phone configuration has been set.');
}
$smsDSN = new DSN(App::getEnv('_APP_SMS_PROVIDER'));
@ -260,6 +261,8 @@ class Messaging extends Action
$password = $smsDSN->getPassword();
$user = $smsDSN->getUser();
$log->addTag('type', $host);
$from = App::getEnv('_APP_SMS_FROM');
$provider = new Document([
@ -311,7 +314,7 @@ class Messaging extends Action
try {
$adapter->send($data);
} catch (\Exception $e) {
Console::error('Failed sending to targets ' . $batchIndex + 1 . '-' . \count($batch) . ' with error: ' . $e->getMessage());
Console::error('Failed sending to targets ' . $batchIndex + 1 . '-' . \count($batch) . ' with error: ' . $e->getMessage()); // TODO: Find a way to log into Sentry
}
};
}, $batches));

View file

@ -17,6 +17,7 @@ use Appwrite\Role;
use Utopia\CLI\Console;
use Utopia\Database\Database;
use Utopia\Database\Helpers\ID;
use Utopia\Logger\Log;
use Utopia\Migration\Destinations\Appwrite as DestinationsAppwrite;
use Utopia\Migration\Resource;
use Utopia\Migration\Source;
@ -46,17 +47,19 @@ class Migrations extends Action
->inject('message')
->inject('dbForProject')
->inject('dbForConsole')
->callback(fn(Message $message, Database $dbForProject, Database $dbForConsole) => $this->action($message, $dbForProject, $dbForConsole));
->inject('log')
->callback(fn(Message $message, Database $dbForProject, Database $dbForConsole, Log $log) => $this->action($message, $dbForProject, $dbForConsole, $log));
}
/**
* @param Message $message
* @param Database $dbForProject
* @param Database $dbForConsole
* @param Log $log
* @return void
* @throws Exception
*/
public function action(Message $message, Database $dbForProject, Database $dbForConsole): void
public function action(Message $message, Database $dbForProject, Database $dbForConsole, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -82,7 +85,9 @@ class Migrations extends Action
return;
}
$this->processMigration($project, $migration);
$log->addTag('projectId', $project->getId());
$this->processMigration($project, $migration, $log);
}
/**
@ -228,6 +233,7 @@ class Migrations extends Action
/**
* @param Document $project
* @param Document $migration
* @param Log $log
* @return void
* @throws Authorization
* @throws Conflict
@ -235,7 +241,7 @@ class Migrations extends Action
* @throws Structure
* @throws \Utopia\Database\Exception
*/
protected function processMigration(Document $project, Document $migration): void
protected function processMigration(Document $project, Document $migration, Log $log): void
{
/**
* @var Document $migrationDocument
@ -252,6 +258,8 @@ class Migrations extends Action
$migrationDocument->setAttribute('status', 'processing');
$this->updateMigrationDocument($migrationDocument, $projectDocument);
$log->addTag('type', $migrationDocument->getAttribute('source'));
$source = $this->processSource($migrationDocument->getAttribute('source'), $migrationDocument->getAttribute('credentials'));
$source->report();

View file

@ -10,6 +10,7 @@ use Utopia\App;
use Utopia\Database\Document;
use Utopia\Database\Database;
use Utopia\Locale\Locale;
use Utopia\Logger\Log;
use Utopia\Platform\Action;
use Utopia\Queue\Message;
@ -34,17 +35,19 @@ class Webhooks extends Action
->inject('message')
->inject('dbForConsole')
->inject('queueForMails')
->callback(fn ($message, Database $dbForConsole, Mail $queueForMails) => $this->action($message, $dbForConsole, $queueForMails));
->inject('log')
->callback(fn (Message $message, Database $dbForConsole, Mail $queueForMails, Log $log) => $this->action($message, $dbForConsole, $queueForMails, $log));
}
/**
* @param Message $message
* @param Database $dbForConsole
* @param Mail $queueForMails
* @param Log $log
* @return void
* @throws Exception
*/
public function action(Message $message, Database $dbForConsole, Mail $queueForMails): void
public function action(Message $message, Database $dbForConsole, Mail $queueForMails, Log $log): void
{
$payload = $message->getPayload() ?? [];
@ -57,6 +60,8 @@ class Webhooks extends Action
$project = new Document($payload['project']);
$user = new Document($payload['user'] ?? []);
$log->addTag('projectId', $project->getId());
foreach ($project->getAttribute('webhooks', []) as $webhook) {
if (array_intersect($webhook->getAttribute('events', []), $events)) {
$this->execute($events, $webhookPayload, $webhook, $user, $project, $dbForConsole, $queueForMails);

View file

@ -40,6 +40,12 @@ class Token extends Model
'default' => '',
'example' => self::TYPE_DATETIME_EXAMPLE,
])
->addRule('securityPhrase', [
'type' => self::TYPE_STRING,
'description' => 'Security phrase of a token. Empty if security phrase was not requested when creating a token. It includes randomly generated phrase which is also sent in the external resource such as email.',
'default' => '',
'example' => 'Golden Fox',
])
;
}

View file

@ -171,4 +171,50 @@ class HTTPTest extends Scope
$this->assertEquals(200, $response['headers']['status-code']);
}
public function testCors()
{
/**
* Test for SUCCESS
*/
$endpoint = '/v1/projects'; // Can be any non-404 route
$response = $this->client->call(Client::METHOD_GET, $endpoint);
$this->assertEquals('http://localhost', $response['headers']['access-control-allow-origin']);
$response = $this->client->call(Client::METHOD_GET, $endpoint, [
'origin' => 'http://localhost',
]);
$this->assertEquals('http://localhost', $response['headers']['access-control-allow-origin']);
$response = $this->client->call(Client::METHOD_GET, $endpoint, [
'origin' => 'http://appwrite.io',
]);
$this->assertEquals('http://appwrite.io', $response['headers']['access-control-allow-origin']);
$response = $this->client->call(Client::METHOD_GET, $endpoint, [
'origin' => 'https://appwrite.io',
]);
$this->assertEquals('https://appwrite.io', $response['headers']['access-control-allow-origin']);
$response = $this->client->call(Client::METHOD_GET, $endpoint, [
'origin' => 'http://cloud.appwrite.io',
]);
$this->assertEquals('http://cloud.appwrite.io', $response['headers']['access-control-allow-origin']);
/**
* Test for FAILURE
*/
$response = $this->client->call(Client::METHOD_GET, $endpoint, [
'origin' => 'http://google.com',
]);
$this->assertEquals('http://localhost', $response['headers']['access-control-allow-origin']);
}
}

View file

@ -1353,6 +1353,7 @@ trait AccountBase
$this->assertEquals(201, $response['headers']['status-code']);
$this->assertNotEmpty($response['body']['$id']);
$this->assertEmpty($response['body']['secret']);
$this->assertEmpty($response['body']['securityPhrase']);
$this->assertEquals(true, (new DatetimeValidator())->isValid($response['body']['expire']));
$userId = $response['body']['userId'];
@ -1360,6 +1361,7 @@ trait AccountBase
$lastEmail = $this->getLastEmail();
$this->assertEquals($email, $lastEmail['to'][0]['address']);
$this->assertEquals($this->getProject()['name'] . ' Login', $lastEmail['subject']);
$this->assertStringNotContainsStringIgnoringCase('security phrase', $lastEmail['text']);
$token = substr($lastEmail['text'], strpos($lastEmail['text'], '&secret=', 0) + 8, 64);
@ -1412,6 +1414,23 @@ trait AccountBase
$this->assertEquals(400, $response['headers']['status-code']);
$response = $this->client->call(Client::METHOD_POST, '/account/sessions/magic-url', array_merge([
'origin' => 'http://localhost',
'content-type' => 'application/json',
'x-appwrite-project' => $this->getProject()['$id'],
]), [
'userId' => ID::unique(),
'email' => $email,
'securityPhrase' => true
]);
$this->assertEquals(201, $response['headers']['status-code']);
$this->assertNotEmpty($response['body']['$id']);
$this->assertNotEmpty($response['body']['securityPhrase']);
$lastEmail = $this->getLastEmail();
$this->assertStringContainsStringIgnoringCase($response['body']['securityPhrase'], $lastEmail['text']);
$data['token'] = $token;
$data['id'] = $userId;
$data['email'] = $email;