1
0
Fork 0
mirror of synced 2024-06-26 10:10:57 +12:00

Merge remote-tracking branch 'origin/1.5.x' into feat-improve-logging

This commit is contained in:
Matej Bačo 2024-01-11 10:22:50 +00:00
commit ed28bb9295
116 changed files with 3048 additions and 1534 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

@ -75,8 +75,32 @@ jobs:
- name: Run Unit Tests
run: docker compose exec appwrite test /usr/src/code/tests/unit
e2e_test:
name: E2E Test
e2e_general_test:
name: E2E General Test
runs-on: ubuntu-latest
needs: setup
steps:
- name: checkout
uses: actions/checkout@v3
- name: Load Cache
uses: actions/cache@v3
with:
key: ${{ env.CACHE_KEY }}
path: /tmp/${{ env.IMAGE }}.tar
fail-on-cache-miss: true
- name: Load and Start Appwrite
run: |
docker load --input /tmp/${{ env.IMAGE }}.tar
docker compose up -d
sleep 10
- name: Run General Tests
run: docker compose exec -T appwrite test /usr/src/code/tests/e2e/General --debug
e2e_service_test:
name: E2E Service Test
runs-on: ubuntu-latest
needs: setup
strategy:
@ -120,4 +144,4 @@ jobs:
sleep 10
- name: Run ${{matrix.service}} Tests
run: docker compose exec -T appwrite test /usr/src/code/tests/e2e/Services/${{matrix.service}} --debug
run: docker compose exec -T appwrite test /usr/src/code/tests/e2e/Services/${{matrix.service}} --debug

2
.gitmodules vendored
View file

@ -1,4 +1,4 @@
[submodule "app/console"]
path = app/console
url = https://github.com/appwrite/console
branch = 3.2.15
branch = 3.2.16

View file

@ -71,6 +71,9 @@ RUN mkdir -p /storage/uploads && \
chown -Rf www-data.www-data /storage/functions && chmod -Rf 0755 /storage/functions && \
chown -Rf www-data.www-data /storage/debug && chmod -Rf 0755 /storage/debug
# Development Executables
RUN chmod +x /usr/local/bin/dev-generate-translations
# Executables
RUN chmod +x /usr/local/bin/doctor && \
chmod +x /usr/local/bin/maintenance && \

View file

@ -8,13 +8,13 @@
href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Poppins:wght@500;600&display=swap"
rel="stylesheet">
<style>
a { color:currentColor; }
a { color:currentColor; word-break: break-all; }
body {
padding: 32px;
color: #616B7C;
font-size: 15px;
font-family: 'Inter', sans-serif;
line-height: 15px;
line-height: 150%;
}
table {
@ -52,7 +52,7 @@
<body style="direction: {{direction}}">
<div style="max-width:650px; word-wrap: break-word; overflow-wrap: break-word;
word-break: break-all; margin:0 auto;">
word-break: normal; margin:0 auto;">
<table style="margin-top: 32px">
<tr>
<td>

View file

@ -0,0 +1,20 @@
<p>{{hello}}</p>
<p>{{optionButton}}</p>
<table border="0" cellspacing="0" cellpadding="0" style="padding-top: 10px; padding-bottom: 10px; display: inline-block;">
<tr>
<td align="center" style="border-radius: 8px; background-color: #19191D;">
<a rel="noopener" target="_blank" href="{{redirect}}" style="font-size: 14px; font-family: Inter; color: #ffffff; text-decoration: none; border-radius: 8px; padding: 9px 14px; border: 1px solid #19191D; display: inline-block;">{{buttonText}}</a>
</td>
</tr>
</table>
<p>{{optionUrl}}</p>
<a href="{{redirect}}" target="_blank" style="font-size: 12px; line-height: 100%;">{{redirect}}</a>
<p>{{clientInfo}}</p>
<p style="margin-bottom: 0px;">{{thanks}}</p>
<p style="margin-top: 0px;">{{signature}}</p>

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Noord-Amerika",
"continents.oc": "Oseanië",
"continents.sa": "Suid-Amerika"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "أوروبا",
"continents.na": "امريكا الشمالية",
"continents.oc": "أوقيانوسيا",
"continents.sa": "امريكا الجنوبية"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ইউৰোপ",
"continents.na": "উত্তৰ আমেৰিকা",
"continents.oc": "ওচেনিয়া",
"continents.sa": "দক্ষিণ আমেৰিকা"
"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."
}

View file

@ -221,5 +221,22 @@
"countries.ye": "Yəmən",
"countries.za": "Cənubi Afrika",
"countries.zm": "Zambiya",
"countries.zw": "Zimbabve"
}
"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",
"emails.certificate.body": "Sizin '{{domain}}' domeniniz üçün sertifikat yaradıla bilmədi. Bu, {{attempt}} cəhd idi, və uğursuzluğa səbəb olan: {{error}}",
"emails.certificate.footer": "Əvvəlki sertifikatınız ilk uğursuzluqdan sonra 30 gün müddətinə keçərlidir. Bu halın araşdırılmasını yüksək dərəcədə tövsiyə edirik, əks halda domeniniz etibarlı SSL rabitəsiz qalacaq.",
"emails.certificate.thanks": "Təşəkkür edirəm",
"emails.certificate.signature": "{{project}} komandası",
"continents.af": "Afrika",
"continents.an": "Antarktida",
"continents.as": "Asiya",
"continents.eu": "Avropa",
"continents.na": "Şimali Amerika",
"continents.oc": "Okeaniya",
"continents.sa": "Cənubi Amerika"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Еўропа",
"continents.na": "Паўночная Амерыка",
"continents.oc": "Акіянія",
"continents.sa": "Паўднёвая Амерыка"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Европа",
"continents.na": "Северна Америка",
"continents.oc": "Океания",
"continents.sa": "Южна Америка"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "यूरोप",
"continents.na": "उत्तरी अमेरिका",
"continents.oc": "ओशिनिया",
"continents.sa": "दक्षिण अमेरिका"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ইউরোপ",
"continents.na": "উত্তর আমেরিকা",
"continents.oc": "ওশেনিয়া",
"continents.sa": "দক্ষিণ আমেরিকা"
}
"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}} টিম"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Sjeverna Amerika",
"continents.oc": "Okeanija",
"continents.sa": "Južna Amerika"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Amèrica del Nord",
"continents.oc": "Oceania",
"continents.sa": "Amèrica del Sud"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Evropa",
"continents.na": "Severní Amerika",
"continents.oc": "Oceánie",
"continents.sa": "Jižní Amerika"
"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}}"
}

View file

@ -1,5 +1,5 @@
{
"settings.inspire": "\"Kunsten at være klog er kunsten at vide, hvad man skal overse.\"",
"settings.inspire": "\"Kunsten at være klog er kunsten at vide, hvad man skal overse.\"",
"settings.locale": "da",
"settings.direction": "ltr",
"emails.sender": "%s Team",
@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nordamerica",
"continents.oc": "Oceanien",
"continents.sa": "Sydamerica"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nordamerika",
"continents.oc": "Ozeanien",
"continents.sa": "Südamerika"
}
"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"
}

View file

@ -25,7 +25,7 @@
"emails.invitation.hello": "Γεια σου",
"emails.invitation.body": "Αυτό το email στάλθηκε επειδή ο/η {{owner}} θέλει να σας προσκαλέσει να γίνετε μέλος της ομάδας {{team}} του {{project}}.",
"emails.invitation.footer": "Εάν δεν ενδιαφέρεστε, μπορείτε να αγνοήσετε αυτό το μήνυμα.",
"emails.invitation.thanks": "Ευχαριστούμε",
"emails.invitation.thanks": "Ευχαριστούμε",
"emails.invitation.signature": "Η ομάδα του {{project}}",
"locale.country.unknown": "Άγνωστο",
"countries.af": "Αφγανιστάν",
@ -228,5 +228,15 @@
"continents.eu": "Ευρώπη",
"continents.na": "Βόρεια Αμερική",
"continents.oc": "Ωκεανία",
"continents.sa": "Νότια Αμερική"
}
"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}}"
}

View file

@ -9,11 +9,13 @@
"emails.verification.footer": "If you didnt ask to verify this address, you can ignore this message.",
"emails.verification.thanks": "Thanks",
"emails.verification.signature": "{{project}} team",
"emails.magicSession.subject": "Login",
"emails.magicSession.hello": "Hey,",
"emails.magicSession.body": "Follow this link to login.",
"emails.magicSession.footer": "If you didnt ask to login using this email, you can ignore this message.",
"emails.magicSession.thanks": "Thanks",
"emails.magicSession.subject": "{{project}} Login",
"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.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.thanks": "Thanks,",
"emails.magicSession.signature": "{{project}} team",
"emails.recovery.subject": "Password Reset",
"emails.recovery.hello": "Hello {{user}}",

View file

@ -1,32 +1,32 @@
{
"settings.locale": "eo",
"settings.direction": "ltr",
"emails.sender": "Teamo %s",
"emails.verification.subject": "Konta Konfirmo",
"emails.verification.hello": "Saluton {{user}}",
"emails.verification.body": "Alklaku ĉi tiun ligon por kontroli vian retpoŝtan adreson.",
"emails.verification.footer": "Se vi ne petis ĉi tiun konfirmon de ĉi tiu retpoŝto, vi povas ignori ĉi tiun mesaĝon.",
"emails.verification.thanks": "Dankegon.",
"emails.verification.signature": "Teamo {{project}}",
"emails.magicSession.subject": "Login",
"emails.magicSession.hello": "Saluton,",
"emails.magicSession.body": "Alklaku ĉi tiun ligon por eniri.",
"emails.magicSession.footer": "Se vi ne petis ĉi tiun konfirmon de ĉi tiu retpoŝto, vi povas ignori ĉi tiun mesaĝon.",
"emails.magicSession.thanks": "Dankegon",
"emails.magicSession.signature": "Teamo {{project}}",
"emails.recovery.subject": "Parsvorta Restarigo",
"emails.recovery.hello": "Saluton {{user}}",
"emails.recovery.body": "Alklaku ĉi tiun ligon por reagordi vian pasvorton. {{project}}",
"emails.recovery.footer": "Se vi ne petis reagordi vian pasvorton, vi povas ignori ĉi tiun mesaĝon.",
"emails.recovery.thanks": "Dankegon",
"emails.recovery.signature": "Teamo {{project}}",
"emails.invitation.subject": "Invito al la Teamo %s em %s",
"emails.invitation.hello": "Dankegon",
"emails.invitation.body": "Ĉi tiu retpoŝto estis sendita ĉar la {{owner}} volas inviti vin fariĝi membro de la Teamo {{team}} en {{project}}.",
"emails.invitation.footer": "Se vi ne interesiĝas, vi povas ignori ĉi tiun mesaĝon.",
"emails.invitation.thanks": "Dankegon",
"emails.invitation.signature": "Teamo {{project}}",
"locale.country.unknown": "Unknown",
{
"settings.locale": "eo",
"settings.direction": "ltr",
"emails.sender": "Teamo %s",
"emails.verification.subject": "Konta Konfirmo",
"emails.verification.hello": "Saluton {{user}}",
"emails.verification.body": "Alklaku ĉi tiun ligon por kontroli vian retpoŝtan adreson.",
"emails.verification.footer": "Se vi ne petis ĉi tiun konfirmon de ĉi tiu retpoŝto, vi povas ignori ĉi tiun mesaĝon.",
"emails.verification.thanks": "Dankegon.",
"emails.verification.signature": "Teamo {{project}}",
"emails.magicSession.subject": "Login",
"emails.magicSession.hello": "Saluton,",
"emails.magicSession.body": "Alklaku ĉi tiun ligon por eniri.",
"emails.magicSession.footer": "Se vi ne petis ĉi tiun konfirmon de ĉi tiu retpoŝto, vi povas ignori ĉi tiun mesaĝon.",
"emails.magicSession.thanks": "Dankegon",
"emails.magicSession.signature": "Teamo {{project}}",
"emails.recovery.subject": "Parsvorta Restarigo",
"emails.recovery.hello": "Saluton {{user}}",
"emails.recovery.body": "Alklaku ĉi tiun ligon por reagordi vian pasvorton. {{project}}",
"emails.recovery.footer": "Se vi ne petis reagordi vian pasvorton, vi povas ignori ĉi tiun mesaĝon.",
"emails.recovery.thanks": "Dankegon",
"emails.recovery.signature": "Teamo {{project}}",
"emails.invitation.subject": "Invito al la Teamo %s em %s",
"emails.invitation.hello": "Dankegon",
"emails.invitation.body": "Ĉi tiu retpoŝto estis sendita ĉar la {{owner}} volas inviti vin fariĝi membro de la Teamo {{team}} en {{project}}.",
"emails.invitation.footer": "Se vi ne interesiĝas, vi povas ignori ĉi tiun mesaĝon.",
"emails.invitation.thanks": "Dankegon",
"emails.invitation.signature": "Teamo {{project}}",
"locale.country.unknown": "Unknown",
"countries.af": "Afghanistan",
"countries.ao": "Angola",
"countries.al": "Albania",
@ -227,5 +227,16 @@
"continents.eu": "Europe",
"continents.na": "North America",
"continents.oc": "Oceania",
"continents.sa": "South America"
}
"continents.sa": "South America",
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "América del Norte",
"continents.oc": "Oceanía",
"continents.sa": "América del Sur"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "اروپا",
"continents.na": "آمریکای شمالی",
"continents.oc": "اقیانوسیه",
"continents.sa": "آمریکای جنوبی"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Eurooppa",
"continents.na": "Pohjois Amerikka",
"continents.oc": "Oceania",
"continents.sa": "Etelä Amerikka"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Norðuramerika",
"continents.oc": "Kyrrahavsoyggjarnar",
"continents.sa": "Suðuramerika"
"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"
}

View file

@ -234,5 +234,9 @@
"continents.eu": "Europe",
"continents.na": "Amérique du Nord",
"continents.oc": "Océanie",
"continents.sa": "Amérique du Sud"
}
"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é."
}

View file

@ -23,7 +23,7 @@
"emails.recovery.signature": "{{project}} foireann",
"emails.invitation.subject": "Cuireadh do %s foireann ag %s",
"emails.invitation.hello": "Haigh",
"emails.invitation.body": "Seoladh an ríomhphost seo chugat mar ba mhaith le {{owner}} cuireadh a thabhairt duit bheith mar bhall den fhoireann {{team}} ag obair ar {{project}}.",
"emails.invitation.body": "Seoladh an ríomhphost seo chugat mar ba mhaith le {{owner}} cuireadh a thabhairt duit bheith mar bhall den fhoireann {{team}} ag obair ar {{project}}.",
"emails.invitation.footer": "Is cuma leat? Déan neamhaird den teachtaireacht seo.",
"emails.invitation.thanks": "Go raibh maith agat",
"emails.invitation.signature": "{{project}} foireann",
@ -228,5 +228,15 @@
"continents.eu": "An Eoraip",
"continents.na": "Meiriceá Thuaidh",
"continents.oc": "An Aigéine",
"continents.sa": "Meiriceá Theas"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "યુરોપ",
"continents.na": "ઉત્તર અમેરિકા",
"continents.oc": "ઓશનિયા",
"continents.sa": "દક્ષિણ અમેરિકા"
"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": "પ્રોજેક્ટ ટીમ"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "אירופה",
"continents.na": "צפון אמריקה",
"continents.oc": "אוקיאניה",
"continents.sa": "דרום אמריקה"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "यूरोप",
"continents.na": "उत्तरी अमेरिका",
"continents.oc": "ओशिनिया",
"continents.sa": "दक्षिण अमेरिका"
}
"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}} टीम"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Sjeverna Amerika",
"continents.oc": "Oceanija",
"continents.sa": "Južna Amerika"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Európa",
"continents.na": "Észak-Amerika",
"continents.oc": "Óceánia",
"continents.sa": "Dél-Amerika"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Եվրոպա",
"continents.na": "Հյուսիսային Ամերիկա",
"continents.oc": "Օկեանիա",
"continents.sa": "Հարավային Ամերիկա"
"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}} թիմ"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Eropa",
"continents.na": "Amerika Utara",
"continents.oc": "Oseania",
"continents.sa": "Amerika Selatan"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Evrópa",
"continents.na": "Norður Ameríka",
"continents.oc": "Eyjaálfu",
"continents.sa": "Suður Ameríka"
"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ð"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nord America",
"continents.oc": "Oceania",
"continents.sa": "Sud America"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ヨーロッパ",
"continents.na": "北米",
"continents.oc": "オセアニア",
"continents.sa": "南アメリカ"
}
"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}} チーム"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Eropa",
"continents.na": "Amérika Lor",
"continents.oc": "Oseania",
"continents.sa": "Amérika Kidul"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "អឺរ៉ុប",
"continents.na": "អាមេរិកខាងជើង",
"continents.oc": "អូសេអានី",
"continents.sa": "អាមេរិកខាងត្បូង"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ಯುರೋಪ್",
"continents.na": "ಉತ್ತರ ಅಮೆರಿಕ",
"continents.oc": "ಓಷಿಯಾನಿಯಾ",
"continents.sa": "ದಕ್ಷಿಣ ಅಮೆರಿಕಾ"
"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": "ತಂಡ"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "유럽",
"continents.na": "북아메리카",
"continents.oc": "오세아니아",
"continents.sa": "남아메리카"
"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}} 팀"
}

View file

@ -1,232 +1,242 @@
{
"settings.inspire": "\"Ars sapiendi est ars sciendi quid negligat.\"",
"settings.locale": "la",
"settings.direction": "ltr*",
"emails.sender": "%s team",
"emails.verification.subject": "Ratio comprobatio",
"emails.verification.hello": "Salve ibi {{user}}",
"emails.verification.body": "Sequere hanc nexum ut quin inscriptionem tuum.",
"emails.verification.footer": "Si verificationem huius inscriptionis non postulasti, nuntium hunc ignorare potes.",
"emails.verification.thanks": "Gratias",
"emails.verification.signature": "{{project}} Team",
"emails.magicSession.subject": "Log in",
"emails.magicSession.hello": "Salve ibi,",
"emails.magicSession.body": "Hanc nexum cum login",
"emails.magicSession.footer": "Si verificationem huius inscriptionis non postulasti, nuntium hunc ignorare potes.",
"emails.magicSession.thanks": "Gratias",
"emails.magicSession.signature": "{{project}} team",
"emails.recovery.subject": "Recuperet password",
"emails.recovery.hello": "Salve ibi {{user}}",
"emails.recovery.body": "Sequere hanc conjunctionem ut recipias project password {{project}}",
"emails.recovery.footer": "Si tesseram tuam recuperare non petis, nuntium hunc ignorare potes",
"emails.recovery.thanks": "Gratias",
"emails.recovery.signature": "{{project}} team",
"emails.invitation.subject": "Invitatio pro %s in quadrigis %s",
"emails.invitation.hello": "Salve ibi",
"emails.invitation.body": "Haec inscriptio ad te missa est quia dominus incepto {{owner}} te invitare vult ut membrum {{team}} quadrigis fias ad {{project}}",
"emails.invitation.footer": "Si non quaero, potes hunc nuntium ignorare",
"emails.invitation.thanks": "Gratias",
"emails.invitation.signature": "{{project}} team",
"locale.country.unknown": "Ignotum",
"countries.af": "Afghanistan",
"countries.ao": "Angola",
"countries.al": "Albania",
"countries.ad": "Andorra",
"countries.ae": "Emiratos Arabes Unidos",
"countries.ar": "Argentina",
"countries.am": "Armenia",
"countries.ag": "Antigua and Barbuda",
"countries.au": "Australia",
"countries.at": "Austria",
"countries.az": "Azerbaijan",
"countries.bi": "Burundi",
"countries.be": "Belgium",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesh",
"countries.bg": "Bulgaria",
"countries.bh": "Bahrain",
"countries.bs": "Bahamas",
"countries.ba": "Bosnia and Herzegovina",
"countries.by": "Belarus",
"countries.bz": "Belize",
"countries.bo": "Bolivia",
"countries.br": "Brazil",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Central African Republic",
"countries.ca": "Canada",
"countries.ch": "Switzerland",
"countries.cl": "Chile",
"countries.cn": "China",
"countries.ci": "Ivory Coast",
"countries.cm": "Cameroon",
"countries.cd": "DR Congo",
"countries.cg": "Republic of the Congo",
"countries.co": "Colombia",
"countries.km": "Comoros",
"countries.cv": "Cape Verde",
"countries.cr": "Costa Rica",
"countries.cu": "Cuba",
"countries.cy": "Cyprus",
"countries.cz": "Czechia",
"countries.de": "Germany",
"countries.dj": "Djibouti",
"countries.dm": "Dominica",
"countries.dk": "Denmark",
"countries.do": "Republica dominicana",
"countries.dz": "Algeria",
"countries.ec": "Ecuador",
"countries.eg": "Egypt",
"countries.er": "Eritrea",
"countries.es": "Spain",
"countries.ee": "Estonia",
"countries.et": "Ethiopia",
"countries.fi": "Finland",
"countries.fj": "Fiji",
"countries.fr": "France",
"countries.fm": "Micronesia",
"countries.ga": "Gabon",
"countries.gb": "Reino Unido",
"countries.ge": "Georgia",
"countries.gh": "Ghana",
"countries.gn": "Guinea",
"countries.gm": "Gambia",
"countries.gw": "Guinea-Bissau",
"countries.gq": "Equatorial Guinea",
"countries.gr": "Greece",
"countries.gd": "Grenada",
"countries.gt": "Guatemala",
"countries.gy": "Guyana",
"countries.hn": "Honduras",
"countries.hr": "Croatia",
"countries.ht": "Haiti",
"countries.hu": "Hungary",
"countries.id": "Indonesia",
"countries.in": "India",
"countries.ie": "Ireland",
"countries.ir": "Iran",
"countries.iq": "Iraq",
"countries.is": "Iceland",
"countries.il": "Israel",
"countries.it": "Italy",
"countries.jm": "Jamaica",
"countries.jo": "Jordan",
"countries.jp": "Japan",
"countries.kz": "Kazakhstan",
"countries.ke": "Kenya",
"countries.kg": "Kyrgyzstan",
"countries.kh": "Cambodia",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts and Nevis",
"countries.kr": "South Korea",
"countries.kw": "Kuwait",
"countries.la": "Laos",
"countries.lb": "Lebanon",
"countries.lr": "Liberia",
"countries.ly": "Libya",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Lithuania",
"countries.lu": "Luxembourg",
"countries.lv": "Latvia",
"countries.ma": "Morocco",
"countries.mc": "Monaco",
"countries.md": "Moldova",
"countries.mg": "Madagascar",
"countries.mv": "Maldives",
"countries.mx": "Mexico",
"countries.mh": "Marshall Islands",
"countries.mk": "Macedonia",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Myanmar",
"countries.me": "Montenegro",
"countries.mn": "Mongolia",
"countries.mz": "Mozambique",
"countries.mr": "Mauritania",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malaysia",
"countries.na": "Namibia",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nicaragua",
"countries.nl": "Netherlands",
"countries.no": "Norway",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "New Zealand",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Philippines",
"countries.pw": "Palau",
"countries.pg": "Papua New Guinea",
"countries.pl": "Poland",
"countries.kp": "North Korea",
"countries.pt": "Portugal",
"countries.py": "Paraguay",
"countries.qa": "Qatar",
"countries.ro": "Romania",
"countries.ru": "Russia",
"countries.rw": "Rwanda",
"countries.sa": "Saudi Arabia",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapore",
"countries.sb": "Solomon Islands",
"countries.sl": "Sierra Leone",
"countries.sv": "El Salvador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbia",
"countries.ss": "South Sudan",
"countries.st": "São Tomé and Príncipe",
"countries.sr": "Suriname",
"countries.sk": "Slovakia",
"countries.si": "Slovenia",
"countries.se": "Sweden",
"countries.sz": "Swaziland",
"countries.sc": "Seychelles",
"countries.sy": "Syria",
"countries.td": "Chad",
"countries.tg": "Togo",
"countries.th": "Thailand",
"countries.tj": "Tajikistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor-Leste",
"countries.to": "Tonga",
"countries.tt": "Trinidad and Tobago",
"countries.tn": "Tunisia",
"countries.tr": "Turkey",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzania",
"countries.ug": "Uganda",
"countries.ua": "Ukraine",
"countries.uy": "Uruguay",
"countries.us": "United States",
"countries.uz": "Uzbekistan",
"countries.va": "Vatican City",
"countries.vc": "Saint Vincent and the Grenadines",
"countries.ve": "Venezuela",
"countries.vn": "Vietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Yemen",
"countries.za": "Sud-Africa",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Africa",
"continents.an": "Antarctica",
"continents.as": "Asia",
"continents.eu": "Europe",
"continents.na": "America del Norte",
"continents.oc": "Oceania",
"continents.sa": "America del Sur"
}
"settings.inspire": "\"Ars sapiendi est ars sciendi quid negligat.\"",
"settings.locale": "la",
"settings.direction": "ltr*",
"emails.sender": "%s team",
"emails.verification.subject": "Ratio comprobatio",
"emails.verification.hello": "Salve ibi {{user}}",
"emails.verification.body": "Sequere hanc nexum ut quin inscriptionem tuum.",
"emails.verification.footer": "Si verificationem huius inscriptionis non postulasti, nuntium hunc ignorare potes.",
"emails.verification.thanks": "Gratias",
"emails.verification.signature": "{{project}} Team",
"emails.magicSession.subject": "Log in",
"emails.magicSession.hello": "Salve ibi,",
"emails.magicSession.body": "Hanc nexum cum login",
"emails.magicSession.footer": "Si verificationem huius inscriptionis non postulasti, nuntium hunc ignorare potes.",
"emails.magicSession.thanks": "Gratias",
"emails.magicSession.signature": "{{project}} team",
"emails.recovery.subject": "Recuperet password",
"emails.recovery.hello": "Salve ibi {{user}}",
"emails.recovery.body": "Sequere hanc conjunctionem ut recipias project password {{project}}",
"emails.recovery.footer": "Si tesseram tuam recuperare non petis, nuntium hunc ignorare potes",
"emails.recovery.thanks": "Gratias",
"emails.recovery.signature": "{{project}} team",
"emails.invitation.subject": "Invitatio pro %s in quadrigis %s",
"emails.invitation.hello": "Salve ibi",
"emails.invitation.body": "Haec inscriptio ad te missa est quia dominus incepto {{owner}} te invitare vult ut membrum {{team}} quadrigis fias ad {{project}}",
"emails.invitation.footer": "Si non quaero, potes hunc nuntium ignorare",
"emails.invitation.thanks": "Gratias",
"emails.invitation.signature": "{{project}} team",
"locale.country.unknown": "Ignotum",
"countries.af": "Afghanistan",
"countries.ao": "Angola",
"countries.al": "Albania",
"countries.ad": "Andorra",
"countries.ae": "Emiratos Arabes Unidos",
"countries.ar": "Argentina",
"countries.am": "Armenia",
"countries.ag": "Antigua and Barbuda",
"countries.au": "Australia",
"countries.at": "Austria",
"countries.az": "Azerbaijan",
"countries.bi": "Burundi",
"countries.be": "Belgium",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesh",
"countries.bg": "Bulgaria",
"countries.bh": "Bahrain",
"countries.bs": "Bahamas",
"countries.ba": "Bosnia and Herzegovina",
"countries.by": "Belarus",
"countries.bz": "Belize",
"countries.bo": "Bolivia",
"countries.br": "Brazil",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Central African Republic",
"countries.ca": "Canada",
"countries.ch": "Switzerland",
"countries.cl": "Chile",
"countries.cn": "China",
"countries.ci": "Ivory Coast",
"countries.cm": "Cameroon",
"countries.cd": "DR Congo",
"countries.cg": "Republic of the Congo",
"countries.co": "Colombia",
"countries.km": "Comoros",
"countries.cv": "Cape Verde",
"countries.cr": "Costa Rica",
"countries.cu": "Cuba",
"countries.cy": "Cyprus",
"countries.cz": "Czechia",
"countries.de": "Germany",
"countries.dj": "Djibouti",
"countries.dm": "Dominica",
"countries.dk": "Denmark",
"countries.do": "Republica dominicana",
"countries.dz": "Algeria",
"countries.ec": "Ecuador",
"countries.eg": "Egypt",
"countries.er": "Eritrea",
"countries.es": "Spain",
"countries.ee": "Estonia",
"countries.et": "Ethiopia",
"countries.fi": "Finland",
"countries.fj": "Fiji",
"countries.fr": "France",
"countries.fm": "Micronesia",
"countries.ga": "Gabon",
"countries.gb": "Reino Unido",
"countries.ge": "Georgia",
"countries.gh": "Ghana",
"countries.gn": "Guinea",
"countries.gm": "Gambia",
"countries.gw": "Guinea-Bissau",
"countries.gq": "Equatorial Guinea",
"countries.gr": "Greece",
"countries.gd": "Grenada",
"countries.gt": "Guatemala",
"countries.gy": "Guyana",
"countries.hn": "Honduras",
"countries.hr": "Croatia",
"countries.ht": "Haiti",
"countries.hu": "Hungary",
"countries.id": "Indonesia",
"countries.in": "India",
"countries.ie": "Ireland",
"countries.ir": "Iran",
"countries.iq": "Iraq",
"countries.is": "Iceland",
"countries.il": "Israel",
"countries.it": "Italy",
"countries.jm": "Jamaica",
"countries.jo": "Jordan",
"countries.jp": "Japan",
"countries.kz": "Kazakhstan",
"countries.ke": "Kenya",
"countries.kg": "Kyrgyzstan",
"countries.kh": "Cambodia",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts and Nevis",
"countries.kr": "South Korea",
"countries.kw": "Kuwait",
"countries.la": "Laos",
"countries.lb": "Lebanon",
"countries.lr": "Liberia",
"countries.ly": "Libya",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Lithuania",
"countries.lu": "Luxembourg",
"countries.lv": "Latvia",
"countries.ma": "Morocco",
"countries.mc": "Monaco",
"countries.md": "Moldova",
"countries.mg": "Madagascar",
"countries.mv": "Maldives",
"countries.mx": "Mexico",
"countries.mh": "Marshall Islands",
"countries.mk": "Macedonia",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Myanmar",
"countries.me": "Montenegro",
"countries.mn": "Mongolia",
"countries.mz": "Mozambique",
"countries.mr": "Mauritania",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malaysia",
"countries.na": "Namibia",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nicaragua",
"countries.nl": "Netherlands",
"countries.no": "Norway",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "New Zealand",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Philippines",
"countries.pw": "Palau",
"countries.pg": "Papua New Guinea",
"countries.pl": "Poland",
"countries.kp": "North Korea",
"countries.pt": "Portugal",
"countries.py": "Paraguay",
"countries.qa": "Qatar",
"countries.ro": "Romania",
"countries.ru": "Russia",
"countries.rw": "Rwanda",
"countries.sa": "Saudi Arabia",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapore",
"countries.sb": "Solomon Islands",
"countries.sl": "Sierra Leone",
"countries.sv": "El Salvador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbia",
"countries.ss": "South Sudan",
"countries.st": "São Tomé and Príncipe",
"countries.sr": "Suriname",
"countries.sk": "Slovakia",
"countries.si": "Slovenia",
"countries.se": "Sweden",
"countries.sz": "Swaziland",
"countries.sc": "Seychelles",
"countries.sy": "Syria",
"countries.td": "Chad",
"countries.tg": "Togo",
"countries.th": "Thailand",
"countries.tj": "Tajikistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor-Leste",
"countries.to": "Tonga",
"countries.tt": "Trinidad and Tobago",
"countries.tn": "Tunisia",
"countries.tr": "Turkey",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzania",
"countries.ug": "Uganda",
"countries.ua": "Ukraine",
"countries.uy": "Uruguay",
"countries.us": "United States",
"countries.uz": "Uzbekistan",
"countries.va": "Vatican City",
"countries.vc": "Saint Vincent and the Grenadines",
"countries.ve": "Venezuela",
"countries.vn": "Vietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Yemen",
"countries.za": "Sud-Africa",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Africa",
"continents.an": "Antarctica",
"continents.as": "Asia",
"continents.eu": "Europe",
"continents.na": "America del Norte",
"continents.oc": "Oceania",
"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"
}

View file

@ -1,232 +1,242 @@
{
"settings.inspire": "\"The art of being wise is the art of knowing what to overlook.\"",
"settings.locale": "lb",
"settings.direction": "ltr",
"emails.sender": "%s Team",
"emails.verification.subject": "Kont Verifikatioun",
"emails.verification.hello": "Hey {{user}}",
"emails.verification.body": "Follegt dëse Link fir Är E -Mail Adress z'iwwerpréiwen.",
"emails.verification.footer": "Wann Dir net gefrot hutt dës Adress z'iwwerpréiwen, kënnt Dir dëse Message ignoréieren.",
"emails.verification.thanks": "Merci",
"emails.verification.signature": "{{project}} équipe",
"emails.magicSession.subject": "Login",
"emails.magicSession.hello": "Hey,",
"emails.magicSession.body": "Follegt dëse Link fir umellen.",
"emails.magicSession.footer": "Wann Dir net gefrot hutt Iech mat dëser E -Mail anzemelden, kënnt Dir dëse Message ignoréieren.",
"emails.magicSession.thanks": "Merci",
"emails.magicSession.signature": "{{project}} équipe",
"emails.recovery.subject": "Password Reset",
"emails.recovery.hello": "Hello {{user}}",
"emails.recovery.body": "Follegt dëse Link fir Äert {{project}} Passwuert zréckzesetzen.",
"emails.recovery.footer": "Wann Dir net gefrot hutt Äert Passwuert zréckzesetzen, kënnt Dir dëse Message ignoréieren.",
"emails.recovery.thanks": "Merci",
"emails.recovery.signature": "{{project}} équipe",
"emails.invitation.subject": "Invitatioun un %s équipe bei %s",
"emails.invitation.hello": "Hallo",
"emails.invitation.body": "Dës E -Mail gouf un Iech geschéckt well {{owner}} Iech invitéiere wëllt fir Member vum {{team}} Team bei {{project}} ze ginn.",
"emails.invitation.footer": "Wann Dir net interesséiert sidd, kënnt Dir dëse Message ignoréieren.",
"emails.invitation.thanks": "Merci",
"emails.invitation.signature": "{{project}} équipe",
"locale.country.unknown": "Onbekannt",
"countries.af": "Afghanistan",
"countries.ao": "Angola",
"countries.al": "Albanien",
"countries.ad": "Andorra",
"countries.ae": "Vereenegt Arabesch Emirater",
"countries.ar": "Argentinien",
"countries.am": "Armenien",
"countries.ag": "Antigua a Barbuda",
"countries.au": "Australien",
"countries.at": "Éisträich",
"countries.az": "Aserbaidschan",
"countries.bi": "Burundi",
"countries.be": "Belsch",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesch",
"countries.bg": "Bulgarien",
"countries.bh": "Bahrain",
"countries.bs": "Bahamas",
"countries.ba": "Bosnien an Herzegowina",
"countries.by": "Wäissrussland",
"countries.bz": "Belize",
"countries.bo": "Bolivien",
"countries.br": "Brasilien",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Zentralafrikanesch Republik",
"countries.ca": "Kanada",
"countries.ch": "Schwäiz",
"countries.cl": "Chile",
"countries.cn": "China",
"countries.ci": "Côte d'Ivoire",
"countries.cm": "Kamerun",
"countries.cd": "DR Congo",
"countries.cg": "Republik Kongo",
"countries.co": "Kolumbien",
"countries.km": "Komoren",
"countries.cv": "Cap Vert",
"countries.cr": "Costa Rica",
"countries.cu": "Kuba",
"countries.cy": "Zypern",
"countries.cz": "Tschechien",
"countries.de": "Däitschland",
"countries.dj": "Djibouti",
"countries.dm": "Dominica",
"countries.dk": "Dänemark",
"countries.do": "Dominikanesch Republik",
"countries.dz": "Algerien",
"countries.ec": "Ecuador",
"countries.eg": "Ägypten",
"countries.er": "Eritrea",
"countries.es": "Spuenien",
"countries.ee": "Estland",
"countries.et": "Äthiopien",
"countries.fi": "Finnland",
"countries.fj": "Fidschi",
"countries.fr": "Frankräich",
"countries.fm": "Mikronesien",
"countries.ga": "Gabon",
"countries.gb": "Vereenegt Kinnekräich",
"countries.ge": "Georgien",
"countries.gh": "Ghana",
"countries.gn": "Guinea",
"countries.gm": "Gambia",
"countries.gw": "Guinea-Bissau",
"countries.gq": "Äquatorialguinea",
"countries.gr": "Griichenland",
"countries.gd": "Granada",
"countries.gt": "Guatemala",
"countries.gy": "Guyana",
"countries.hn": "Honduras",
"countries.hr": "Kroatien",
"countries.ht": "Haïti",
"countries.hu": "Ungarn",
"countries.id": "Indonesien",
"countries.in": "Indien",
"countries.ie": "Irland",
"countries.ir": "Iran",
"countries.iq": "Irak",
"countries.is": "Island",
"countries.il": "Israel",
"countries.it": "Italien",
"countries.jm": "Jamaika",
"countries.jo": "Jordanien",
"countries.jp": "Japan",
"countries.kz": "Kazakhstan",
"countries.ke": "Kenia",
"countries.kg": "Kirgisistan",
"countries.kh": "Kambodscha",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts and Nevis",
"countries.kr": "Südkorea",
"countries.kw": "Kuwait",
"countries.la": "Laos",
"countries.lb": "Libanon",
"countries.lr": "Liberia",
"countries.ly": "Libyen",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Litauen",
"countries.lu": "Lëtzebuerg",
"countries.lv": "Lettland",
"countries.ma": "Marokko",
"countries.mc": "Monaco",
"countries.md": "Moldawien",
"countries.mg": "Madagaskar",
"countries.mv": "Malediven",
"countries.mx": "Mexiko",
"countries.mh": "Marshallinselen",
"countries.mk": "Mazedonien",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Myanmar",
"countries.me": "Montenegro",
"countries.mn": "Mongolei",
"countries.mz": "Mosambik",
"countries.mr": "Mauritanien",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malaysien",
"countries.na": "Namibien",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nicaragua",
"countries.nl": "Holland",
"countries.no": "Norwegen",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "Neiséiland",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Philippinnen",
"countries.pw": "Palau",
"countries.pg": "Papua-Neuguinea",
"countries.pl": "Polen",
"countries.kp": "Nordkorea",
"countries.pt": "Portugal",
"countries.py": "Paraguay",
"countries.qa": "Quatar",
"countries.ro": "Rumänien",
"countries.ru": "Russland",
"countries.rw": "Ruanda",
"countries.sa": "Saudi Arabien",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapur",
"countries.sb": "Solomon Inselen",
"countries.sl": "Sierra Leone",
"countries.sv": "El Salvador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbien",
"countries.ss": "Südsudan",
"countries.st": "Sao Tome a Principe",
"countries.sr": "Suriname",
"countries.sk": "Slowakei",
"countries.si": "Slowenien",
"countries.se": "Schweden",
"countries.sz": "Swasiland",
"countries.sc": "Seychellen",
"countries.sy": "Syrien",
"countries.td": "Tschad",
"countries.tg": "Goen",
"countries.th": "Thailand",
"countries.tj": "Tadjikistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor-Leste",
"countries.to": "Tonga",
"countries.tt": "Tinidad an Tobago",
"countries.tn": "Tunesien",
"countries.tr": "Tierkei",
"countries.tv": "Tuvalu",
"countries.tz": "Tansania",
"countries.ug": "Ugana",
"countries.ua": "Ukraine",
"countries.uy": "Uruguay",
"countries.us": "Vereenegt Staaten",
"countries.uz": "Usbekistan",
"countries.va": "Vatikan Stad",
"countries.vc": "Saint Vincent an d'Grenadinnen",
"countries.ve": "Venezuela",
"countries.vn": "Vietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Yemen",
"countries.za": "Südafrika",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Afrika",
"continents.an": "Antarktis",
"continents.as": "Asien",
"continents.eu": "Europa",
"continents.na": "Nordamerika",
"continents.oc": "Ozeanien",
"continents.sa": "Südamerika"
}
"settings.inspire": "\"The art of being wise is the art of knowing what to overlook.\"",
"settings.locale": "lb",
"settings.direction": "ltr",
"emails.sender": "%s Team",
"emails.verification.subject": "Kont Verifikatioun",
"emails.verification.hello": "Hey {{user}}",
"emails.verification.body": "Follegt dëse Link fir Är E -Mail Adress z'iwwerpréiwen.",
"emails.verification.footer": "Wann Dir net gefrot hutt dës Adress z'iwwerpréiwen, kënnt Dir dëse Message ignoréieren.",
"emails.verification.thanks": "Merci",
"emails.verification.signature": "{{project}} équipe",
"emails.magicSession.subject": "Login",
"emails.magicSession.hello": "Hey,",
"emails.magicSession.body": "Follegt dëse Link fir umellen.",
"emails.magicSession.footer": "Wann Dir net gefrot hutt Iech mat dëser E -Mail anzemelden, kënnt Dir dëse Message ignoréieren.",
"emails.magicSession.thanks": "Merci",
"emails.magicSession.signature": "{{project}} équipe",
"emails.recovery.subject": "Password Reset",
"emails.recovery.hello": "Hello {{user}}",
"emails.recovery.body": "Follegt dëse Link fir Äert {{project}} Passwuert zréckzesetzen.",
"emails.recovery.footer": "Wann Dir net gefrot hutt Äert Passwuert zréckzesetzen, kënnt Dir dëse Message ignoréieren.",
"emails.recovery.thanks": "Merci",
"emails.recovery.signature": "{{project}} équipe",
"emails.invitation.subject": "Invitatioun un %s équipe bei %s",
"emails.invitation.hello": "Hallo",
"emails.invitation.body": "Dës E -Mail gouf un Iech geschéckt well {{owner}} Iech invitéiere wëllt fir Member vum {{team}} Team bei {{project}} ze ginn.",
"emails.invitation.footer": "Wann Dir net interesséiert sidd, kënnt Dir dëse Message ignoréieren.",
"emails.invitation.thanks": "Merci",
"emails.invitation.signature": "{{project}} équipe",
"locale.country.unknown": "Onbekannt",
"countries.af": "Afghanistan",
"countries.ao": "Angola",
"countries.al": "Albanien",
"countries.ad": "Andorra",
"countries.ae": "Vereenegt Arabesch Emirater",
"countries.ar": "Argentinien",
"countries.am": "Armenien",
"countries.ag": "Antigua a Barbuda",
"countries.au": "Australien",
"countries.at": "Éisträich",
"countries.az": "Aserbaidschan",
"countries.bi": "Burundi",
"countries.be": "Belsch",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesch",
"countries.bg": "Bulgarien",
"countries.bh": "Bahrain",
"countries.bs": "Bahamas",
"countries.ba": "Bosnien an Herzegowina",
"countries.by": "Wäissrussland",
"countries.bz": "Belize",
"countries.bo": "Bolivien",
"countries.br": "Brasilien",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Zentralafrikanesch Republik",
"countries.ca": "Kanada",
"countries.ch": "Schwäiz",
"countries.cl": "Chile",
"countries.cn": "China",
"countries.ci": "Côte d'Ivoire",
"countries.cm": "Kamerun",
"countries.cd": "DR Congo",
"countries.cg": "Republik Kongo",
"countries.co": "Kolumbien",
"countries.km": "Komoren",
"countries.cv": "Cap Vert",
"countries.cr": "Costa Rica",
"countries.cu": "Kuba",
"countries.cy": "Zypern",
"countries.cz": "Tschechien",
"countries.de": "Däitschland",
"countries.dj": "Djibouti",
"countries.dm": "Dominica",
"countries.dk": "Dänemark",
"countries.do": "Dominikanesch Republik",
"countries.dz": "Algerien",
"countries.ec": "Ecuador",
"countries.eg": "Ägypten",
"countries.er": "Eritrea",
"countries.es": "Spuenien",
"countries.ee": "Estland",
"countries.et": "Äthiopien",
"countries.fi": "Finnland",
"countries.fj": "Fidschi",
"countries.fr": "Frankräich",
"countries.fm": "Mikronesien",
"countries.ga": "Gabon",
"countries.gb": "Vereenegt Kinnekräich",
"countries.ge": "Georgien",
"countries.gh": "Ghana",
"countries.gn": "Guinea",
"countries.gm": "Gambia",
"countries.gw": "Guinea-Bissau",
"countries.gq": "Äquatorialguinea",
"countries.gr": "Griichenland",
"countries.gd": "Granada",
"countries.gt": "Guatemala",
"countries.gy": "Guyana",
"countries.hn": "Honduras",
"countries.hr": "Kroatien",
"countries.ht": "Haïti",
"countries.hu": "Ungarn",
"countries.id": "Indonesien",
"countries.in": "Indien",
"countries.ie": "Irland",
"countries.ir": "Iran",
"countries.iq": "Irak",
"countries.is": "Island",
"countries.il": "Israel",
"countries.it": "Italien",
"countries.jm": "Jamaika",
"countries.jo": "Jordanien",
"countries.jp": "Japan",
"countries.kz": "Kazakhstan",
"countries.ke": "Kenia",
"countries.kg": "Kirgisistan",
"countries.kh": "Kambodscha",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts and Nevis",
"countries.kr": "Südkorea",
"countries.kw": "Kuwait",
"countries.la": "Laos",
"countries.lb": "Libanon",
"countries.lr": "Liberia",
"countries.ly": "Libyen",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Litauen",
"countries.lu": "Lëtzebuerg",
"countries.lv": "Lettland",
"countries.ma": "Marokko",
"countries.mc": "Monaco",
"countries.md": "Moldawien",
"countries.mg": "Madagaskar",
"countries.mv": "Malediven",
"countries.mx": "Mexiko",
"countries.mh": "Marshallinselen",
"countries.mk": "Mazedonien",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Myanmar",
"countries.me": "Montenegro",
"countries.mn": "Mongolei",
"countries.mz": "Mosambik",
"countries.mr": "Mauritanien",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malaysien",
"countries.na": "Namibien",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nicaragua",
"countries.nl": "Holland",
"countries.no": "Norwegen",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "Neiséiland",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Philippinnen",
"countries.pw": "Palau",
"countries.pg": "Papua-Neuguinea",
"countries.pl": "Polen",
"countries.kp": "Nordkorea",
"countries.pt": "Portugal",
"countries.py": "Paraguay",
"countries.qa": "Quatar",
"countries.ro": "Rumänien",
"countries.ru": "Russland",
"countries.rw": "Ruanda",
"countries.sa": "Saudi Arabien",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapur",
"countries.sb": "Solomon Inselen",
"countries.sl": "Sierra Leone",
"countries.sv": "El Salvador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbien",
"countries.ss": "Südsudan",
"countries.st": "Sao Tome a Principe",
"countries.sr": "Suriname",
"countries.sk": "Slowakei",
"countries.si": "Slowenien",
"countries.se": "Schweden",
"countries.sz": "Swasiland",
"countries.sc": "Seychellen",
"countries.sy": "Syrien",
"countries.td": "Tschad",
"countries.tg": "Goen",
"countries.th": "Thailand",
"countries.tj": "Tadjikistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor-Leste",
"countries.to": "Tonga",
"countries.tt": "Tinidad an Tobago",
"countries.tn": "Tunesien",
"countries.tr": "Tierkei",
"countries.tv": "Tuvalu",
"countries.tz": "Tansania",
"countries.ug": "Ugana",
"countries.ua": "Ukraine",
"countries.uy": "Uruguay",
"countries.us": "Vereenegt Staaten",
"countries.uz": "Usbekistan",
"countries.va": "Vatikan Stad",
"countries.vc": "Saint Vincent an d'Grenadinnen",
"countries.ve": "Venezuela",
"countries.vn": "Vietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Yemen",
"countries.za": "Südafrika",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Afrika",
"continents.an": "Antarktis",
"continents.as": "Asien",
"continents.eu": "Europa",
"continents.na": "Nordamerika",
"continents.oc": "Ozeanien",
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Šiaurės Amerika",
"continents.oc": "Okeanija",
"continents.sa": "Pietų Amerika"
}
"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"
}

View file

@ -1,232 +1,242 @@
{
"settings.inspire": "\"Māksla būt gudram ir māksla zināt, ko aizmirst.\"",
"settings.locale": "lv",
"settings.direction": "ltr",
"emails.sender": "%s komanda",
"emails.verification.subject": "Konta verifikācija",
"emails.verification.hello": "Sveicināti, {{user}}",
"emails.verification.body": "Sekojiet saitei, lai apstiprinātu savu e-pasta adresi.",
"emails.verification.footer": "Ja Jūs nepieprasījāt šīs adreses apstiprinājumu, lūdzu, ignorējiet šo ziņu.",
"emails.verification.thanks": "Paldies",
"emails.verification.signature": "{{project}} komanda",
"emails.magicSession.subject": "Ieiet",
"emails.magicSession.hello": "Sveicināti,",
"emails.magicSession.body": "Sekojiet saitei, lai ieietu.",
"emails.magicSession.footer": "Ja Jūs nepieprasījāt ieiet ar šo e-pasta adresi, lūdzu, ignorējiet šo ziņu.",
"emails.magicSession.thanks": "Paldies",
"emails.magicSession.signature": "{{project}} komanda",
"emails.recovery.subject": "Paroles atjaunināšana",
"emails.recovery.hello": "Labdien, {{user}}",
"emails.recovery.body": "Sekojiet saitei, lai atjauninātu {{project}} paroli.",
"emails.recovery.footer": "Ja Jūs nepieprasījāt paroles atjaunināšanu, lūdzu, ignorējiet šo ziņu.",
"emails.recovery.thanks": "Paldies",
"emails.recovery.signature": "{{project}} komanda",
"emails.invitation.subject": "Ielūgums piebiedroties %s komandai %s projektā.",
"emails.invitation.hello": "Labdien",
"emails.invitation.body": "Šis e-pasts tika nosūtīts Jums, jo {{owner}} vēlējās Jūs ielūgt kļūt par {{team}} komandas biedru {{project}} projektā.",
"emails.invitation.footer": "Ja Jūs neesat ieinteresēts, lūdzu, ignorējiet šo ziņu.",
"emails.invitation.thanks": "Paldies",
"emails.invitation.signature": "{{project}} komanda",
"locale.country.unknown": "Nav zināms",
"countries.af": "Afganistāna",
"countries.ao": "Angola",
"countries.al": "Albānija",
"countries.ad": "Andora",
"countries.ae": "Apvienotie Arābu Emirāti",
"countries.ar": "Argentīna",
"countries.am": "Armēnija",
"countries.ag": "Antigva un Barbuda",
"countries.au": "Austrālija",
"countries.at": "Austrija",
"countries.az": "Azerbaidžāna",
"countries.bi": "Burundi",
"countries.be": "Beļģija",
"countries.bj": "Benina",
"countries.bf": "Burkinafaso",
"countries.bd": "Bangladeša",
"countries.bg": "Bulgārija",
"countries.bh": "Bahreina",
"countries.bs": "Bahamas",
"countries.ba": "Bosnija un Hercegovina",
"countries.by": "Baltkrievija",
"countries.bz": "Beliza",
"countries.bo": "Bolīvija",
"countries.br": "Brazīlija",
"countries.bb": "Barbadosa",
"countries.bn": "Bruneja",
"countries.bt": "Butāna",
"countries.bw": "Botsvana",
"countries.cf": "Centrālāfrikas Republika",
"countries.ca": "Kanāda",
"countries.ch": "Šveice",
"countries.cl": "Čīle",
"countries.cn": "Ķīna",
"countries.ci": "Kotdivuāra",
"countries.cm": "Kamerūna",
"countries.cd": "Kongo Demokrātiskā Republika",
"countries.cg": "Kongo",
"countries.co": "Kolumbija",
"countries.km": "Komoras",
"countries.cv": "Kaboverde",
"countries.cr": "Kostarika",
"countries.cu": "Kuba",
"countries.cy": "Kipra",
"countries.cz": "Čehija",
"countries.de": "Vācija",
"countries.dj": "Džibutija",
"countries.dm": "Dominika",
"countries.dk": "Dānija",
"countries.do": "Dominikāna",
"countries.dz": "Alžīrija",
"countries.ec": "Ekvadora",
"countries.eg": "Ēģipte",
"countries.er": "Eritreja",
"countries.es": "Spānija",
"countries.ee": "Igaunija",
"countries.et": "Etiopija",
"countries.fi": "Somija",
"countries.fj": "Fidži",
"countries.fr": "Francija",
"countries.fm": "Mikronēzija",
"countries.ga": "Gabona",
"countries.gb": "Apvienotā Karaliste",
"countries.ge": "Gruzija",
"countries.gh": "Gana",
"countries.gn": "Gvineja",
"countries.gm": "Gambija",
"countries.gw": "Gvineja-Bisava",
"countries.gq": "Ekvatoriālā Gvineja",
"countries.gr": "Grieķija",
"countries.gd": "Grenada",
"countries.gt": "Gvatemala",
"countries.gy": "Gajāna",
"countries.hn": "Hondurasa",
"countries.hr": "Horvātija",
"countries.ht": "Haiti",
"countries.hu": "Ungārija",
"countries.id": "Indonēzija",
"countries.in": "Indija",
"countries.ie": "Īrija",
"countries.ir": "Irāna",
"countries.iq": "Irāka",
"countries.is": "Islande",
"countries.il": "Izraēla",
"countries.it": "Itālija",
"countries.jm": "Jamaika",
"countries.jo": "Jordānija",
"countries.jp": "Japāna",
"countries.kz": "Kazahstāna",
"countries.ke": "Kenija",
"countries.kg": "Kirgizstāna",
"countries.kh": "Kambodža",
"countries.ki": "Kiribati",
"countries.kn": "Sentkitsa un Nevisa",
"countries.kr": "Dienvidkoreja",
"countries.kw": "Kuveita",
"countries.la": "Laosa",
"countries.lb": "Libāna",
"countries.lr": "Libērija",
"countries.ly": "Lībija",
"countries.lc": "Sentlūsija",
"countries.li": "Lihtenšteina",
"countries.lk": "Šrilanka",
"countries.ls": "Lesoto",
"countries.lt": "Lietuva",
"countries.lu": "Luksemburga",
"countries.lv": "Latvija",
"countries.ma": "Maroka",
"countries.mc": "Monako",
"countries.md": "Moldova",
"countries.mg": "Madagaskara",
"countries.mv": "Maldīvija",
"countries.mx": "Meksika",
"countries.mh": "Māršala salas",
"countries.mk": "Ziemeļmaķedonijas Republika",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Mjanma",
"countries.me": "Melnkalne",
"countries.mn": "Mongolija",
"countries.mz": "Mozambika",
"countries.mr": "Mauritānija",
"countries.mu": "Maurīcija",
"countries.mw": "Malāvija",
"countries.my": "Malaizija",
"countries.na": "Namībija",
"countries.ne": "Nigēra",
"countries.ng": "Nigērija",
"countries.ni": "Nikaragva",
"countries.nl": "Nīderlande",
"countries.no": "Norvēģija",
"countries.np": "Nepāla",
"countries.nr": "Nauru",
"countries.nz": "Jaunzēlande",
"countries.om": "Omāna",
"countries.pk": "Pakistāna",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Filipīnas",
"countries.pw": "Palau",
"countries.pg": "Papua-Jaungvineja",
"countries.pl": "Polija",
"countries.kp": "Ziemeļkoreja",
"countries.pt": "Portugāle",
"countries.py": "Paragvaja",
"countries.qa": "Katara",
"countries.ro": "Rumānija",
"countries.ru": "Krievija",
"countries.rw": "Ruanda",
"countries.sa": "Saūda Arābija",
"countries.sd": "Sudāna",
"countries.sn": "Senegāla",
"countries.sg": "Singapūra",
"countries.sb": "Zālamana salas",
"countries.sl": "Sjerraleone",
"countries.sv": "Salvadora",
"countries.sm": "Sanmarīno",
"countries.so": "Somālija",
"countries.rs": "Serbija",
"countries.ss": "Dienvidsudāna",
"countries.st": "Santome un Prinsipi",
"countries.sr": "Surinama",
"countries.sk": "Slovākija",
"countries.si": "Slovēnija",
"countries.se": "Zviedrija",
"countries.sz": "Svatini",
"countries.sc": "Seišelas",
"countries.sy": "Sīrija",
"countries.td": "Čada",
"countries.tg": "Togo",
"countries.th": "Taizeme",
"countries.tj": "Tadžikistāna",
"countries.tm": "Turkmenistāna",
"countries.tl": "Austrumtimora",
"countries.to": "Tonga",
"countries.tt": "Trinidāda un Tobāgo",
"countries.tn": "Tunisija",
"countries.tr": "Turcija",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzānija",
"countries.ug": "Uganda",
"countries.ua": "Ukraina",
"countries.uy": "Urugvaja",
"countries.us": "Amerikas Savienotās Valstis",
"countries.uz": "Uzbekistāna",
"countries.va": "Vatikāns",
"countries.vc": "Sentvinsenta un Grenadīnas",
"countries.ve": "Venecuēla",
"countries.vn": "Vjetnama",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Jemena",
"countries.za": "Dienvidāfrikas Republika",
"countries.zm": "Zambija",
"countries.zw": "Zimbabve",
"continents.af": "Āfrika",
"continents.an": "Antarktīda",
"continents.as": "Āzija",
"continents.eu": "Eiropa",
"continents.na": "Ziemeļamerika",
"continents.oc": "Okeānija",
"continents.sa": "Dienvidamerika"
}
"settings.inspire": "\"Māksla būt gudram ir māksla zināt, ko aizmirst.\"",
"settings.locale": "lv",
"settings.direction": "ltr",
"emails.sender": "%s komanda",
"emails.verification.subject": "Konta verifikācija",
"emails.verification.hello": "Sveicināti, {{user}}",
"emails.verification.body": "Sekojiet saitei, lai apstiprinātu savu e-pasta adresi.",
"emails.verification.footer": "Ja Jūs nepieprasījāt šīs adreses apstiprinājumu, lūdzu, ignorējiet šo ziņu.",
"emails.verification.thanks": "Paldies",
"emails.verification.signature": "{{project}} komanda",
"emails.magicSession.subject": "Ieiet",
"emails.magicSession.hello": "Sveicināti,",
"emails.magicSession.body": "Sekojiet saitei, lai ieietu.",
"emails.magicSession.footer": "Ja Jūs nepieprasījāt ieiet ar šo e-pasta adresi, lūdzu, ignorējiet šo ziņu.",
"emails.magicSession.thanks": "Paldies",
"emails.magicSession.signature": "{{project}} komanda",
"emails.recovery.subject": "Paroles atjaunināšana",
"emails.recovery.hello": "Labdien, {{user}}",
"emails.recovery.body": "Sekojiet saitei, lai atjauninātu {{project}} paroli.",
"emails.recovery.footer": "Ja Jūs nepieprasījāt paroles atjaunināšanu, lūdzu, ignorējiet šo ziņu.",
"emails.recovery.thanks": "Paldies",
"emails.recovery.signature": "{{project}} komanda",
"emails.invitation.subject": "Ielūgums piebiedroties %s komandai %s projektā.",
"emails.invitation.hello": "Labdien",
"emails.invitation.body": "Šis e-pasts tika nosūtīts Jums, jo {{owner}} vēlējās Jūs ielūgt kļūt par {{team}} komandas biedru {{project}} projektā.",
"emails.invitation.footer": "Ja Jūs neesat ieinteresēts, lūdzu, ignorējiet šo ziņu.",
"emails.invitation.thanks": "Paldies",
"emails.invitation.signature": "{{project}} komanda",
"locale.country.unknown": "Nav zināms",
"countries.af": "Afganistāna",
"countries.ao": "Angola",
"countries.al": "Albānija",
"countries.ad": "Andora",
"countries.ae": "Apvienotie Arābu Emirāti",
"countries.ar": "Argentīna",
"countries.am": "Armēnija",
"countries.ag": "Antigva un Barbuda",
"countries.au": "Austrālija",
"countries.at": "Austrija",
"countries.az": "Azerbaidžāna",
"countries.bi": "Burundi",
"countries.be": "Beļģija",
"countries.bj": "Benina",
"countries.bf": "Burkinafaso",
"countries.bd": "Bangladeša",
"countries.bg": "Bulgārija",
"countries.bh": "Bahreina",
"countries.bs": "Bahamas",
"countries.ba": "Bosnija un Hercegovina",
"countries.by": "Baltkrievija",
"countries.bz": "Beliza",
"countries.bo": "Bolīvija",
"countries.br": "Brazīlija",
"countries.bb": "Barbadosa",
"countries.bn": "Bruneja",
"countries.bt": "Butāna",
"countries.bw": "Botsvana",
"countries.cf": "Centrālāfrikas Republika",
"countries.ca": "Kanāda",
"countries.ch": "Šveice",
"countries.cl": "Čīle",
"countries.cn": "Ķīna",
"countries.ci": "Kotdivuāra",
"countries.cm": "Kamerūna",
"countries.cd": "Kongo Demokrātiskā Republika",
"countries.cg": "Kongo",
"countries.co": "Kolumbija",
"countries.km": "Komoras",
"countries.cv": "Kaboverde",
"countries.cr": "Kostarika",
"countries.cu": "Kuba",
"countries.cy": "Kipra",
"countries.cz": "Čehija",
"countries.de": "Vācija",
"countries.dj": "Džibutija",
"countries.dm": "Dominika",
"countries.dk": "Dānija",
"countries.do": "Dominikāna",
"countries.dz": "Alžīrija",
"countries.ec": "Ekvadora",
"countries.eg": "Ēģipte",
"countries.er": "Eritreja",
"countries.es": "Spānija",
"countries.ee": "Igaunija",
"countries.et": "Etiopija",
"countries.fi": "Somija",
"countries.fj": "Fidži",
"countries.fr": "Francija",
"countries.fm": "Mikronēzija",
"countries.ga": "Gabona",
"countries.gb": "Apvienotā Karaliste",
"countries.ge": "Gruzija",
"countries.gh": "Gana",
"countries.gn": "Gvineja",
"countries.gm": "Gambija",
"countries.gw": "Gvineja-Bisava",
"countries.gq": "Ekvatoriālā Gvineja",
"countries.gr": "Grieķija",
"countries.gd": "Grenada",
"countries.gt": "Gvatemala",
"countries.gy": "Gajāna",
"countries.hn": "Hondurasa",
"countries.hr": "Horvātija",
"countries.ht": "Haiti",
"countries.hu": "Ungārija",
"countries.id": "Indonēzija",
"countries.in": "Indija",
"countries.ie": "Īrija",
"countries.ir": "Irāna",
"countries.iq": "Irāka",
"countries.is": "Islande",
"countries.il": "Izraēla",
"countries.it": "Itālija",
"countries.jm": "Jamaika",
"countries.jo": "Jordānija",
"countries.jp": "Japāna",
"countries.kz": "Kazahstāna",
"countries.ke": "Kenija",
"countries.kg": "Kirgizstāna",
"countries.kh": "Kambodža",
"countries.ki": "Kiribati",
"countries.kn": "Sentkitsa un Nevisa",
"countries.kr": "Dienvidkoreja",
"countries.kw": "Kuveita",
"countries.la": "Laosa",
"countries.lb": "Libāna",
"countries.lr": "Libērija",
"countries.ly": "Lībija",
"countries.lc": "Sentlūsija",
"countries.li": "Lihtenšteina",
"countries.lk": "Šrilanka",
"countries.ls": "Lesoto",
"countries.lt": "Lietuva",
"countries.lu": "Luksemburga",
"countries.lv": "Latvija",
"countries.ma": "Maroka",
"countries.mc": "Monako",
"countries.md": "Moldova",
"countries.mg": "Madagaskara",
"countries.mv": "Maldīvija",
"countries.mx": "Meksika",
"countries.mh": "Māršala salas",
"countries.mk": "Ziemeļmaķedonijas Republika",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Mjanma",
"countries.me": "Melnkalne",
"countries.mn": "Mongolija",
"countries.mz": "Mozambika",
"countries.mr": "Mauritānija",
"countries.mu": "Maurīcija",
"countries.mw": "Malāvija",
"countries.my": "Malaizija",
"countries.na": "Namībija",
"countries.ne": "Nigēra",
"countries.ng": "Nigērija",
"countries.ni": "Nikaragva",
"countries.nl": "Nīderlande",
"countries.no": "Norvēģija",
"countries.np": "Nepāla",
"countries.nr": "Nauru",
"countries.nz": "Jaunzēlande",
"countries.om": "Omāna",
"countries.pk": "Pakistāna",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Filipīnas",
"countries.pw": "Palau",
"countries.pg": "Papua-Jaungvineja",
"countries.pl": "Polija",
"countries.kp": "Ziemeļkoreja",
"countries.pt": "Portugāle",
"countries.py": "Paragvaja",
"countries.qa": "Katara",
"countries.ro": "Rumānija",
"countries.ru": "Krievija",
"countries.rw": "Ruanda",
"countries.sa": "Saūda Arābija",
"countries.sd": "Sudāna",
"countries.sn": "Senegāla",
"countries.sg": "Singapūra",
"countries.sb": "Zālamana salas",
"countries.sl": "Sjerraleone",
"countries.sv": "Salvadora",
"countries.sm": "Sanmarīno",
"countries.so": "Somālija",
"countries.rs": "Serbija",
"countries.ss": "Dienvidsudāna",
"countries.st": "Santome un Prinsipi",
"countries.sr": "Surinama",
"countries.sk": "Slovākija",
"countries.si": "Slovēnija",
"countries.se": "Zviedrija",
"countries.sz": "Svatini",
"countries.sc": "Seišelas",
"countries.sy": "Sīrija",
"countries.td": "Čada",
"countries.tg": "Togo",
"countries.th": "Taizeme",
"countries.tj": "Tadžikistāna",
"countries.tm": "Turkmenistāna",
"countries.tl": "Austrumtimora",
"countries.to": "Tonga",
"countries.tt": "Trinidāda un Tobāgo",
"countries.tn": "Tunisija",
"countries.tr": "Turcija",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzānija",
"countries.ug": "Uganda",
"countries.ua": "Ukraina",
"countries.uy": "Urugvaja",
"countries.us": "Amerikas Savienotās Valstis",
"countries.uz": "Uzbekistāna",
"countries.va": "Vatikāns",
"countries.vc": "Sentvinsenta un Grenadīnas",
"countries.ve": "Venecuēla",
"countries.vn": "Vjetnama",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Jemena",
"countries.za": "Dienvidāfrikas Republika",
"countries.zm": "Zambija",
"countries.zw": "Zimbabve",
"continents.af": "Āfrika",
"continents.an": "Antarktīda",
"continents.as": "Āzija",
"continents.eu": "Eiropa",
"continents.na": "Ziemeļamerika",
"continents.oc": "Okeānija",
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "യൂറോപ്പ്",
"continents.na": "വടക്കേ അമേരിക്ക",
"continents.oc": "ഓഷ്യാനിയ",
"continents.sa": "തെക്കേ അമേരിക്ക"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "यूरोप",
"continents.na": "उत्तर अमेरिका",
"continents.oc": "ओशिनिया",
"continents.sa": "दक्षिण अमेरिका"
"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}} संघ"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Eropah",
"continents.na": "Amerika Utara",
"continents.oc": "Oceania",
"continents.sa": "Amerika Selatan"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nord-Amerika",
"continents.oc": "Oseania",
"continents.sa": "Sør-Amerika"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "युरोप",
"continents.na": "उत्तर अमेरिका",
"continents.oc": "ओसिआनिया",
"continents.sa": "दक्षिण अमेरिका"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Noord Amerika",
"continents.oc": "Oceanië",
"continents.sa": "Zuid Amerika"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nord-Amerika",
"continents.oc": "Oseania",
"continents.sa": "Sør-Amerika"
}
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ଇଉରୋପ",
"continents.na": "ନର୍ଥ ଆମେରିକା",
"continents.oc": "ଓସାନିଆ",
"continents.sa": "ସାଉଥ ଆମେରିକା"
"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}} команда"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ਯੂਰਪ",
"continents.na": "ਉੱਤਰ ਅਮਰੀਕਾ",
"continents.oc": "ਓਸੀਆਨੀਆ",
"continents.sa": "ਸਾਉਥ ਅਮਰੀਕਾ"
"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}}"
}

View file

@ -1,232 +1,242 @@
{
"settings.inspire": "\"Sztuka bycia mądrym to sztuka wiedzieć, co przeoczyć.\"",
"settings.locale": "pl",
"settings.direction": "ltr",
"emails.sender": "Zespół %s",
"emails.verification.subject": "Weryfikacja konta",
"emails.verification.hello": "Cześć {{user}}",
"emails.verification.body": "Przejdź do tego linku, aby zweryfikować swój adres e-mail.",
"emails.verification.footer": "Jeśli to nie Ty prosiłeś o zweryfikowanie tego adresu, zignoruj tę wiadomość.",
"emails.verification.thanks": "Dziękujemy",
"emails.verification.signature": "Zespół {{project}}",
"emails.magicSession.subject": "Logowanie",
"emails.magicSession.hello": "Cześć,",
"emails.magicSession.body": "Kliknij w ten link, aby zalogować się.",
"emails.magicSession.footer": "Jeśli to nie Ty prosiłeś o logowanie przy użyciu tego adresu e-mail, zignoruj tę wiadomość.",
"emails.magicSession.thanks": "Dziękujemy",
"emails.magicSession.signature": "Zespół {{project}}",
"emails.recovery.subject": "Resetowanie hasła",
"emails.recovery.hello": "Cześć {{user}}",
"emails.recovery.body": "Przejdź do tego linku, aby zresetować hasło dla {{project}}.",
"emails.recovery.footer": "Jeśli to nie Ty prosiłeś o zresetowanie swojego hasła, zignoruj tę wiadomość.",
"emails.recovery.thanks": "Dziękujemy",
"emails.recovery.signature": "Zespół {{project}}",
"emails.invitation.subject": "Zaproszenie do zespołu %s w %s",
"emails.invitation.hello": "Cześć",
"emails.invitation.body": "Otrzymujesz tę wiadomość, ponieważ {{owner}} zaprasza Cię do grona członków zespołu {{team}} w projekcie {{project}}.",
"emails.invitation.footer": "Jeśli nie jesteś zainteresowany, zignoruj tę wiadomość.",
"emails.invitation.thanks": "Dziękujemy",
"emails.invitation.signature": "Zespół {{project}}",
"locale.country.unknown": "Nieznany",
"countries.af": "Afganistan",
"countries.ao": "Angola",
"countries.al": "Albania",
"countries.ad": "Andora",
"countries.ae": "Zjednoczone Emiraty Arabskie",
"countries.ar": "Argentyna",
"countries.am": "Armenia",
"countries.ag": "Antigua i Barbuda",
"countries.au": "Australia",
"countries.at": "Austria",
"countries.az": "Azerbejdżan",
"countries.bi": "Burundi",
"countries.be": "Belgia",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesz",
"countries.bg": "Bułgaria",
"countries.bh": "Bahrajn",
"countries.bs": "Bahamy",
"countries.ba": "Bośnia i Hercegowina",
"countries.by": "Białoruś",
"countries.bz": "Belize",
"countries.bo": "Boliwia",
"countries.br": "Brazylia",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Republika Środkowoafrykańska",
"countries.ca": "Kanada",
"countries.ch": "Szwajcaria",
"countries.cl": "Chile",
"countries.cn": "Chiny",
"countries.ci": "Wybrzeże Kości Słoniowej",
"countries.cm": "Kamerun",
"countries.cd": "DR Congo",
"countries.cg": "Republika Konga",
"countries.co": "Kolumbia",
"countries.km": "Komory",
"countries.cv": "Republika Zielonego Przylądka",
"countries.cr": "Kostaryka",
"countries.cu": "Kuba",
"countries.cy": "Cypr",
"countries.cz": "Czechy",
"countries.de": "Niemcy",
"countries.dj": "Dżibuti",
"countries.dm": "Dominica",
"countries.dk": "Dania",
"countries.do": "Republika Dominikańska",
"countries.dz": "Algieria",
"countries.ec": "Ekwador",
"countries.eg": "Egipt",
"countries.er": "Erytrea",
"countries.es": "Hiszpania",
"countries.ee": "Estonia",
"countries.et": "Etiopia",
"countries.fi": "Finlandia",
"countries.fj": "Fidżi",
"countries.fr": "Francja",
"countries.fm": "Mikronezja",
"countries.ga": "Gabon",
"countries.gb": "Wielka Brytania",
"countries.ge": "Georgia",
"countries.gh": "Ghana",
"countries.gn": "Gwinea",
"countries.gm": "Gambia",
"countries.gw": "Gwinea Bissau",
"countries.gq": "Gwinea Równikowa",
"countries.gr": "Grecja",
"countries.gd": "Grenada",
"countries.gt": "Gwatemala",
"countries.gy": "Gujana",
"countries.hn": "Honduras",
"countries.hr": "Chorwacja",
"countries.ht": "Haiti",
"countries.hu": "Węgry",
"countries.id": "Indonezja",
"countries.in": "Indie",
"countries.ie": "Irlandia",
"countries.ir": "Iran",
"countries.iq": "Irak",
"countries.is": "Islandia",
"countries.il": "Israel",
"countries.it": "Włochy",
"countries.jm": "Jamajka",
"countries.jo": "Jordan",
"countries.jp": "Japonia",
"countries.kz": "Kazachstan",
"countries.ke": "Kenia",
"countries.kg": "Kirgistan",
"countries.kh": "Kambodża",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts i Nevis",
"countries.kr": "Korea Południowa",
"countries.kw": "Kuwejt",
"countries.la": "Laos",
"countries.lb": "Liban",
"countries.lr": "Liberia",
"countries.ly": "Libia",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Litwa",
"countries.lu": "Luksemburg",
"countries.lv": "Łotwa",
"countries.ma": "Maroko",
"countries.mc": "Monako",
"countries.md": "Mołdawia",
"countries.mg": "Madagaskar",
"countries.mv": "Malediwy",
"countries.mx": "Meksyk",
"countries.mh": "Wyspy Marshalla",
"countries.mk": "Macedonia",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Birma",
"countries.me": "Czarnogóra",
"countries.mn": "Mongolia",
"countries.mz": "Mozambik",
"countries.mr": "Mauretania",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malezja",
"countries.na": "Namibia",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nikaragua",
"countries.nl": "Holandia",
"countries.no": "Norwegia",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "Nowa Zelandia",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Filipiny",
"countries.pw": "Palau",
"countries.pg": "Papua Nowa Gwinea",
"countries.pl": "Polska",
"countries.kp": "Korea Północna",
"countries.pt": "Portugalia",
"countries.py": "Paragwaj",
"countries.qa": "Katar",
"countries.ro": "Rumunia",
"countries.ru": "Rosja",
"countries.rw": "Rwanda",
"countries.sa": "Arabia Saudyjska",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapur",
"countries.sb": "Wyspy Salomona",
"countries.sl": "Sierra Leone",
"countries.sv": "Salwador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbia",
"countries.ss": "Sudan Południowy",
"countries.st": "Wyspy Świętego Tomasza i Książęca",
"countries.sr": "Surinam",
"countries.sk": "Słowacja",
"countries.si": "Słowenia",
"countries.se": "Szwecja",
"countries.sz": "Suazi",
"countries.sc": "Seszele",
"countries.sy": "Syria",
"countries.td": "Czad",
"countries.tg": "Togo",
"countries.th": "Tajlandia",
"countries.tj": "Tadżykistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor Wschodni",
"countries.to": "Tonga",
"countries.tt": "Trynidad i Tobago",
"countries.tn": "Tunezja",
"countries.tr": "Turcja",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzania",
"countries.ug": "Uganda",
"countries.ua": "Ukraina",
"countries.uy": "Urugwaj",
"countries.us": "Stany Zjednoczone",
"countries.uz": "Uzbekistan",
"countries.va": "Watykan",
"countries.vc": "Saint Vincent i Grenadyny",
"countries.ve": "Wenezuela",
"countries.vn": "Wietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Jemen",
"countries.za": "Republika Południowej Afryki",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Afryka",
"continents.an": "Antarktyda",
"continents.as": "Azja",
"continents.eu": "Europa",
"continents.na": "Ameryka Północna",
"continents.oc": "Oceania",
"continents.sa": "Ameryka południowa"
}
"settings.inspire": "\"Sztuka bycia mądrym to sztuka wiedzieć, co przeoczyć.\"",
"settings.locale": "pl",
"settings.direction": "ltr",
"emails.sender": "Zespół %s",
"emails.verification.subject": "Weryfikacja konta",
"emails.verification.hello": "Cześć {{user}}",
"emails.verification.body": "Przejdź do tego linku, aby zweryfikować swój adres e-mail.",
"emails.verification.footer": "Jeśli to nie Ty prosiłeś o zweryfikowanie tego adresu, zignoruj tę wiadomość.",
"emails.verification.thanks": "Dziękujemy",
"emails.verification.signature": "Zespół {{project}}",
"emails.magicSession.subject": "Logowanie",
"emails.magicSession.hello": "Cześć,",
"emails.magicSession.body": "Kliknij w ten link, aby zalogować się.",
"emails.magicSession.footer": "Jeśli to nie Ty prosiłeś o logowanie przy użyciu tego adresu e-mail, zignoruj tę wiadomość.",
"emails.magicSession.thanks": "Dziękujemy",
"emails.magicSession.signature": "Zespół {{project}}",
"emails.recovery.subject": "Resetowanie hasła",
"emails.recovery.hello": "Cześć {{user}}",
"emails.recovery.body": "Przejdź do tego linku, aby zresetować hasło dla {{project}}.",
"emails.recovery.footer": "Jeśli to nie Ty prosiłeś o zresetowanie swojego hasła, zignoruj tę wiadomość.",
"emails.recovery.thanks": "Dziękujemy",
"emails.recovery.signature": "Zespół {{project}}",
"emails.invitation.subject": "Zaproszenie do zespołu %s w %s",
"emails.invitation.hello": "Cześć",
"emails.invitation.body": "Otrzymujesz tę wiadomość, ponieważ {{owner}} zaprasza Cię do grona członków zespołu {{team}} w projekcie {{project}}.",
"emails.invitation.footer": "Jeśli nie jesteś zainteresowany, zignoruj tę wiadomość.",
"emails.invitation.thanks": "Dziękujemy",
"emails.invitation.signature": "Zespół {{project}}",
"locale.country.unknown": "Nieznany",
"countries.af": "Afganistan",
"countries.ao": "Angola",
"countries.al": "Albania",
"countries.ad": "Andora",
"countries.ae": "Zjednoczone Emiraty Arabskie",
"countries.ar": "Argentyna",
"countries.am": "Armenia",
"countries.ag": "Antigua i Barbuda",
"countries.au": "Australia",
"countries.at": "Austria",
"countries.az": "Azerbejdżan",
"countries.bi": "Burundi",
"countries.be": "Belgia",
"countries.bj": "Benin",
"countries.bf": "Burkina Faso",
"countries.bd": "Bangladesz",
"countries.bg": "Bułgaria",
"countries.bh": "Bahrajn",
"countries.bs": "Bahamy",
"countries.ba": "Bośnia i Hercegowina",
"countries.by": "Białoruś",
"countries.bz": "Belize",
"countries.bo": "Boliwia",
"countries.br": "Brazylia",
"countries.bb": "Barbados",
"countries.bn": "Brunei",
"countries.bt": "Bhutan",
"countries.bw": "Botswana",
"countries.cf": "Republika Środkowoafrykańska",
"countries.ca": "Kanada",
"countries.ch": "Szwajcaria",
"countries.cl": "Chile",
"countries.cn": "Chiny",
"countries.ci": "Wybrzeże Kości Słoniowej",
"countries.cm": "Kamerun",
"countries.cd": "DR Congo",
"countries.cg": "Republika Konga",
"countries.co": "Kolumbia",
"countries.km": "Komory",
"countries.cv": "Republika Zielonego Przylądka",
"countries.cr": "Kostaryka",
"countries.cu": "Kuba",
"countries.cy": "Cypr",
"countries.cz": "Czechy",
"countries.de": "Niemcy",
"countries.dj": "Dżibuti",
"countries.dm": "Dominica",
"countries.dk": "Dania",
"countries.do": "Republika Dominikańska",
"countries.dz": "Algieria",
"countries.ec": "Ekwador",
"countries.eg": "Egipt",
"countries.er": "Erytrea",
"countries.es": "Hiszpania",
"countries.ee": "Estonia",
"countries.et": "Etiopia",
"countries.fi": "Finlandia",
"countries.fj": "Fidżi",
"countries.fr": "Francja",
"countries.fm": "Mikronezja",
"countries.ga": "Gabon",
"countries.gb": "Wielka Brytania",
"countries.ge": "Georgia",
"countries.gh": "Ghana",
"countries.gn": "Gwinea",
"countries.gm": "Gambia",
"countries.gw": "Gwinea Bissau",
"countries.gq": "Gwinea Równikowa",
"countries.gr": "Grecja",
"countries.gd": "Grenada",
"countries.gt": "Gwatemala",
"countries.gy": "Gujana",
"countries.hn": "Honduras",
"countries.hr": "Chorwacja",
"countries.ht": "Haiti",
"countries.hu": "Węgry",
"countries.id": "Indonezja",
"countries.in": "Indie",
"countries.ie": "Irlandia",
"countries.ir": "Iran",
"countries.iq": "Irak",
"countries.is": "Islandia",
"countries.il": "Israel",
"countries.it": "Włochy",
"countries.jm": "Jamajka",
"countries.jo": "Jordan",
"countries.jp": "Japonia",
"countries.kz": "Kazachstan",
"countries.ke": "Kenia",
"countries.kg": "Kirgistan",
"countries.kh": "Kambodża",
"countries.ki": "Kiribati",
"countries.kn": "Saint Kitts i Nevis",
"countries.kr": "Korea Południowa",
"countries.kw": "Kuwejt",
"countries.la": "Laos",
"countries.lb": "Liban",
"countries.lr": "Liberia",
"countries.ly": "Libia",
"countries.lc": "Saint Lucia",
"countries.li": "Liechtenstein",
"countries.lk": "Sri Lanka",
"countries.ls": "Lesotho",
"countries.lt": "Litwa",
"countries.lu": "Luksemburg",
"countries.lv": "Łotwa",
"countries.ma": "Maroko",
"countries.mc": "Monako",
"countries.md": "Mołdawia",
"countries.mg": "Madagaskar",
"countries.mv": "Malediwy",
"countries.mx": "Meksyk",
"countries.mh": "Wyspy Marshalla",
"countries.mk": "Macedonia",
"countries.ml": "Mali",
"countries.mt": "Malta",
"countries.mm": "Birma",
"countries.me": "Czarnogóra",
"countries.mn": "Mongolia",
"countries.mz": "Mozambik",
"countries.mr": "Mauretania",
"countries.mu": "Mauritius",
"countries.mw": "Malawi",
"countries.my": "Malezja",
"countries.na": "Namibia",
"countries.ne": "Niger",
"countries.ng": "Nigeria",
"countries.ni": "Nikaragua",
"countries.nl": "Holandia",
"countries.no": "Norwegia",
"countries.np": "Nepal",
"countries.nr": "Nauru",
"countries.nz": "Nowa Zelandia",
"countries.om": "Oman",
"countries.pk": "Pakistan",
"countries.pa": "Panama",
"countries.pe": "Peru",
"countries.ph": "Filipiny",
"countries.pw": "Palau",
"countries.pg": "Papua Nowa Gwinea",
"countries.pl": "Polska",
"countries.kp": "Korea Północna",
"countries.pt": "Portugalia",
"countries.py": "Paragwaj",
"countries.qa": "Katar",
"countries.ro": "Rumunia",
"countries.ru": "Rosja",
"countries.rw": "Rwanda",
"countries.sa": "Arabia Saudyjska",
"countries.sd": "Sudan",
"countries.sn": "Senegal",
"countries.sg": "Singapur",
"countries.sb": "Wyspy Salomona",
"countries.sl": "Sierra Leone",
"countries.sv": "Salwador",
"countries.sm": "San Marino",
"countries.so": "Somalia",
"countries.rs": "Serbia",
"countries.ss": "Sudan Południowy",
"countries.st": "Wyspy Świętego Tomasza i Książęca",
"countries.sr": "Surinam",
"countries.sk": "Słowacja",
"countries.si": "Słowenia",
"countries.se": "Szwecja",
"countries.sz": "Suazi",
"countries.sc": "Seszele",
"countries.sy": "Syria",
"countries.td": "Czad",
"countries.tg": "Togo",
"countries.th": "Tajlandia",
"countries.tj": "Tadżykistan",
"countries.tm": "Turkmenistan",
"countries.tl": "Timor Wschodni",
"countries.to": "Tonga",
"countries.tt": "Trynidad i Tobago",
"countries.tn": "Tunezja",
"countries.tr": "Turcja",
"countries.tv": "Tuvalu",
"countries.tz": "Tanzania",
"countries.ug": "Uganda",
"countries.ua": "Ukraina",
"countries.uy": "Urugwaj",
"countries.us": "Stany Zjednoczone",
"countries.uz": "Uzbekistan",
"countries.va": "Watykan",
"countries.vc": "Saint Vincent i Grenadyny",
"countries.ve": "Wenezuela",
"countries.vn": "Wietnam",
"countries.vu": "Vanuatu",
"countries.ws": "Samoa",
"countries.ye": "Jemen",
"countries.za": "Republika Południowej Afryki",
"countries.zm": "Zambia",
"countries.zw": "Zimbabwe",
"continents.af": "Afryka",
"continents.an": "Antarktyda",
"continents.as": "Azja",
"continents.eu": "Europa",
"continents.na": "Ameryka Północna",
"continents.oc": "Oceania",
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "América do Norte",
"continents.oc": "Oceania",
"continents.sa": "América do Sul"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "América do Norte",
"continents.oc": "Oceânia",
"continents.sa": "América do Sul"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "America de Nord",
"continents.oc": "Oceania",
"continents.sa": "America de Sud"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Европа",
"continents.na": "Северная Америка",
"continents.oc": "Океания",
"continents.sa": "Южная Америка"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "यूरोप",
"continents.na": "उत्तरी अमेरिका",
"continents.oc": "ओशिनिया",
"continents.sa": "दक्षिण अमेरिका"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "يورپ",
"continents.na": "اتر آمريڪا",
"continents.oc": "اوشينيا",
"continents.sa": "ڏکڻ آمريڪا"
}
"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."
}

View file

@ -228,5 +228,15 @@
"continents.eu": "යුරෝපය",
"continents.na": "උතුරු ඇමරිකාව",
"continents.oc": "ඕෂනියා",
"continents.sa": "දකුණු ඇමරිකාව"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Európa",
"continents.na": "Severná Amerika",
"continents.oc": "Oceánia",
"continents.sa": "Južná Amerika"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Evropa",
"continents.na": "Severna Amerika",
"continents.oc": "Oceanija",
"continents.sa": "Južna Amerika"
"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"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europe",
"continents.na": "North America",
"continents.oc": "Oceania",
"continents.sa": "South America"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Evropë",
"continents.na": "Amerika e Veriut",
"continents.oc": "Oqeani",
"continents.sa": "Amerika e Jugut"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Nordamerika",
"continents.oc": "Oceanien",
"continents.sa": "Sydamerika"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ஐரோப்பா",
"continents.na": "வட அமெரிக்கா",
"continents.oc": "ஓசியானியா",
"continents.sa": "தென் அமெரிக்கா"
"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}} குழு"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "యూరోప్",
"continents.na": "ఉత్తర అమెరికా",
"continents.oc": "ఓషియానియా",
"continents.sa": "దక్షిణ అమెరికా"
}
"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}} జట్టు"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "ยุโรป",
"continents.na": "อเมริกาเหนือ",
"continents.oc": "โอเชียเนีย",
"continents.sa": "อเมริกาใต้"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Europa",
"continents.na": "Hilagang Amerika",
"continents.oc": "Oceania",
"continents.sa": "Timog Amerika"
"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"
}

View file

@ -3,30 +3,36 @@
"settings.locale": "tr",
"settings.direction": "ltr",
"emails.sender": "%s Takımı",
"emails.verification.subject": "",
"emails.verification.hello": "",
"emails.verification.body": "",
"emails.verification.footer": "",
"emails.verification.thanks": "",
"emails.verification.signature": "",
"emails.magicSession.subject": "",
"emails.magicSession.hello": "",
"emails.magicSession.body": "",
"emails.magicSession.footer": "",
"emails.magicSession.thanks": "",
"emails.magicSession.signature": "",
"emails.recovery.subject": "",
"emails.recovery.hello": "",
"emails.recovery.body": "",
"emails.recovery.footer": "",
"emails.recovery.thanks": "",
"emails.recovery.signature": "",
"emails.invitation.subject": "",
"emails.invitation.hello": "",
"emails.invitation.body": "",
"emails.invitation.footer": "",
"emails.invitation.thanks": "",
"emails.invitation.signature": "",
"emails.verification.subject": "Hesabını Doğrula",
"emails.verification.hello": "Merhaba {{user}}",
"emails.verification.body": "Eposta adresini doğrulamak için bu bağlantıyı kullanın.",
"emails.verification.footer": "Eğer bu eposta adresini doğrulamak isteyen siz değilseniz devam etmeyin.",
"emails.verification.thanks": "Teşekkürler",
"emails.verification.signature": "{{project}} takımı",
"emails.magicSession.subject": "Giriş",
"emails.magicSession.hello": "Merhaba,",
"emails.magicSession.body": "Giriş yapmak için tıklayın.",
"emails.magicSession.footer": "Eğer bu eposta adresini kullanarak giriş yapmak istemediyseniz devam etmeyin.",
"emails.magicSession.thanks": "Teşekkürler",
"emails.magicSession.signature": "{{project}} takımı",
"emails.recovery.subject": "Şifremi Sıfırla",
"emails.recovery.hello": "Merhaba {{user}}",
"emails.recovery.body": "{{project}} şifrenizi sıfırlamak için bu bağlantıyı kullanın.",
"emails.recovery.footer": "Eğer şifre sıfırlama talebinde bulunmadıysanız devam etmeyin.",
"emails.recovery.thanks": "Teşekkürler",
"emails.recovery.signature": "{{project}} takımı",
"emails.invitation.subject": "%s üzerinde %s Takımına Davet",
"emails.invitation.hello": "Merhaba",
"emails.invitation.body": "Bu epostayı aldınız, çünkü {{owner}} sizi {{project}} üzerinde {{team}} takımının üyesi olmaya davet etti.",
"emails.invitation.footer": "Eğer ilgilenmiyorsanız devam etmeyin.",
"emails.invitation.thanks": "Teşekkürler",
"emails.invitation.signature": "{{project}} takımı",
"emails.certificate.subject": "%s için sertifika hatası",
"emails.certificate.hello": "Merhaba",
"emails.certificate.body": "Alan adınız '{{domain}}' için sertifika oluşturulamadı. Deneme sayısı {{attempt}} ve hata sebebi: {{error}}",
"emails.certificate.footer": "Geçmiş sertifikanız ilk denemeden sonra 30 gün daha geçerli kalacaktır. Bu konuyu araştırmanızı öneriyoruz, aksi taktirde alan adınız SSL sertifikasız kalacaktır.",
"emails.certificate.thanks": "Teşekkürler",
"emails.certificate.signature": "{{project}} takımı",
"locale.country.unknown": "Bilinmeyen",
"countries.af": "Afganistan",
"countries.ao": "Angola",
@ -228,5 +234,9 @@
"continents.eu": "Avrupa",
"continents.na": "Kuzey Amerika",
"continents.oc": "Okyanusya",
"continents.sa": "Güney Amerika"
"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."
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Європа",
"continents.na": "Північна Америка",
"continents.oc": "Океанія",
"continents.sa": "Південна Америка"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "یورپ",
"continents.na": "شمالی امریکہ",
"continents.oc": "اوشینیا",
"continents.sa": "جنوبی امریکہ"
}
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "Châu Âu",
"continents.na": "Bắc Mỹ",
"continents.oc": "Châu Đại Dương",
"continents.sa": "Nam Mỹ"
"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}}"
}

View file

@ -228,5 +228,15 @@
"continents.eu": "欧洲",
"continents.na": "北美洲",
"continents.oc": "大洋洲",
"continents.sa": "南美洲"
}
"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}} 团队"
}

View file

@ -234,5 +234,9 @@
"continents.eu": "歐洲",
"continents.na": "北美洲",
"continents.oc": "大洋洲",
"continents.sa": "南美洲"
}
"continents.sa": "南美洲",
"emails.magicSession.optionButton": "點擊下方按鈕安全登入您的{{project}}帳號。該按鈕將於1小時後失效。",
"emails.magicSession.buttonText": "登入 {{project}}",
"emails.magicSession.optionUrl": "如果上面的按鈕沒有顯示,請使用以下鏈接:",
"emails.magicSession.clientInfo": "這次的登入是透過{{agentClient}}在{{agentDevice}} {{agentOs}}上請求的。如果您沒有請求這次登入,您可以放心地忽略這封電子郵件。"
}

View file

@ -362,6 +362,16 @@ return [
'beta' => false,
'mock' => false,
],
'zoho' => [
'name' => 'Zoho',
'developers' => 'https://zoho.com/accounts/protocol/oauth.html',
'icon' => 'icon-zoho',
'enabled' => true,
'sandbox' => false,
'form' => false,
'beta' => false,
'mock' => false,
],
'zoom' => [
'name' => 'Zoom',
'developers' => 'https://marketplace.zoom.us/docs/guides/auth/oauth/',

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.',

@ -1 +1 @@
Subproject commit 94e4c1a73024b0e974fbe6077674281f6e973c9d
Subproject commit 0a007a3b1b6eafc39dc19b7129f41643102f9676

View file

@ -69,7 +69,7 @@ App::post('/v1/account')
->label('abuse-limit', 10)
->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('password', '', fn ($project, $passwordsDictionary) => new PasswordDictionary($passwordsDictionary, $project->getAttribute('auths', [])['passwordDictionary'] ?? false), 'New user password. Must be at least 8 chars.', false, ['project', 'passwordsDictionary'])
->param('password', '', fn ($project, $passwordsDictionary) => new PasswordDictionary($passwordsDictionary, $project->getAttribute('auths', [])['passwordDictionary'] ?? false), 'New user password. Must be between 8 and 256 chars.', false, ['project', 'passwordsDictionary'])
->param('name', '', new Text(128), 'User name. Max length: 128 chars.', true)
->inject('request')
->inject('response')
@ -565,11 +565,19 @@ App::get('/v1/account/sessions/oauth2/:provider/redirect')
if (!$user->isEmpty()) {
$userId = $user->getId();
$identitiesWithMatchingEmail = $dbForProject->find('identities', [
$identityWithMatchingEmail = $dbForProject->findOne('identities', [
Query::equal('providerEmail', [$email]),
Query::notEqual('userId', $userId),
]);
if (!empty($identitiesWithMatchingEmail)) {
if (!empty($identityWithMatchingEmail)) {
throw new Exception(Exception::USER_ALREADY_EXISTS);
}
$userWithMatchingEmail = $dbForProject->find('users', [
Query::equal('email', [$email]),
Query::notEqual('$id', $userId),
]);
if (!empty($userWithMatchingEmail)) {
throw new Exception(Exception::USER_ALREADY_EXISTS);
}
}
@ -868,7 +876,7 @@ App::get('/v1/account/identities')
});
App::delete('/v1/account/identities/:identityId')
->desc('Delete Identity')
->desc('Delete identity')
->groups(['api', 'account'])
->label('scope', 'account')
->label('event', 'users.[userId].identities.[identityId].delete')
@ -885,7 +893,8 @@ App::delete('/v1/account/identities/:identityId')
->param('identityId', '', new UID(), 'Identity ID.')
->inject('response')
->inject('dbForProject')
->action(function (string $identityId, Response $response, Database $dbForProject) {
->inject('queueForEvents')
->action(function (string $identityId, Response $response, Database $dbForProject, Event $queueForEvents) {
$identity = $dbForProject->getDocument('identities', $identityId);
@ -895,6 +904,11 @@ App::delete('/v1/account/identities/:identityId')
$dbForProject->deleteDocument('identities', $identityId);
$queueForEvents
->setParam('userId', $identity->getAttribute('userId'))
->setParam('identityId', $identity->getId())
->setPayload($response->output($identity, Response::MODEL_IDENTITY));
return $response->noContent();
});
@ -988,7 +1002,7 @@ App::post('/v1/account/sessions/magic-url')
Authorization::skip(fn () => $dbForProject->createDocument('users', $user));
}
$loginSecret = Auth::tokenGenerator();
$loginSecret = Auth::tokenGenerator(32);
$expire = DateTime::formatTz(DateTime::addSeconds(new \DateTime(), Auth::TOKEN_EXPIRATION_CONFIRM));
$token = new Document([
@ -1025,11 +1039,19 @@ App::post('/v1/account/sessions/magic-url')
$subject = $locale->getText("emails.magicSession.subject");
$customTemplate = $project->getAttribute('templates', [])['email.magicSession-' . $locale->default] ?? [];
$message = Template::fromFile(__DIR__ . '/../../config/locale/templates/email-inner-base.tpl');
$detector = new Detector($request->getUserAgent('UNKNOWN'));
$agentOs = $detector->getOS();
$agentClient = $detector->getClient();
$agentDevice = $detector->getDevice();
$message = Template::fromFile(__DIR__ . '/../../config/locale/templates/email-magic-url.tpl');
$message
->setParam('{{body}}', $body)
->setParam('{{hello}}', $locale->getText("emails.magicSession.hello"))
->setParam('{{footer}}', $locale->getText("emails.magicSession.footer"))
->setParam('{{optionButton}}', $locale->getText("emails.magicSession.optionButton"))
->setParam('{{buttonText}}', $locale->getText("emails.magicSession.buttonText"))
->setParam('{{optionUrl}}', $locale->getText("emails.magicSession.optionUrl"))
->setParam('{{clientInfo}}', $locale->getText("emails.magicSession.clientInfo"))
->setParam('{{thanks}}', $locale->getText("emails.magicSession.thanks"))
->setParam('{{signature}}', $locale->getText("emails.magicSession.signature"));
$body = $message->render();
@ -1086,7 +1108,10 @@ App::post('/v1/account/sessions/magic-url')
'user' => '',
'team' => '',
'project' => $project->getAttribute('name'),
'redirect' => $url
'redirect' => $url,
'agentDevice' => $agentDevice['deviceBrand'] ?? $agentDevice['deviceBrand'] ?? 'UNKNOWN',
'agentClient' => $agentClient['clientName'] ?? 'UNKNOWN',
'agentOs' => $agentOs['osName'] ?? 'UNKNOWN'
];
$queueForMails
@ -2724,8 +2749,8 @@ App::put('/v1/account/recovery')
->label('abuse-key', 'url:{url},userId:{param-userId}')
->param('userId', '', new UID(), 'User ID.')
->param('secret', '', new Text(256), 'Valid reset token.')
->param('password', '', new Password(), 'New user password. Must be at least 8 chars.')
->param('passwordAgain', '', new Password(), 'Repeat new user password. Must be at least 8 chars.')
->param('password', '', fn ($project, $passwordsDictionary) => new PasswordDictionary($passwordsDictionary, $project->getAttribute('auths', [])['passwordDictionary'] ?? false), 'New user password. Must be between 8 and 256 chars.', false, ['project', 'passwordsDictionary'])
->param('passwordAgain', '', fn ($project, $passwordsDictionary) => new PasswordDictionary($passwordsDictionary, $project->getAttribute('auths', [])['passwordDictionary'] ?? false), 'Repeat new user password. Must be between 8 and 256 chars.', false, ['project', 'passwordsDictionary'])
->inject('response')
->inject('user')
->inject('dbForProject')

View file

@ -31,6 +31,7 @@ use Utopia\Database\Validator\UID;
use Utopia\Locale\Locale;
use Utopia\Validator\ArrayList;
use Utopia\Validator\Boolean;
use Utopia\Validator\Integer;
use Utopia\Validator\JSON;
use Utopia\Validator\Text;
use MaxMind\Db\Reader;
@ -54,21 +55,28 @@ App::post('/v1/messaging/providers/mailgun')
->label('sdk.response.model', Response::MODEL_PROVIDER)
->param('providerId', '', new CustomId(), 'Provider 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('name', '', new Text(128), 'Provider name.')
->param('from', '', new Email(), 'Sender email address.', true)
->param('apiKey', '', new Text(0), 'Mailgun API Key.', true)
->param('domain', '', new Text(0), 'Mailgun Domain.', true)
->param('isEuRegion', null, new Boolean(), 'Set as EU region.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('fromName', '', new Text(128), 'Sender Name.', true)
->param('fromEmail', '', new Email(), 'Sender email address.', true)
->param('replyToName', '', new Text(128), 'Name set in the reply to field for the mail. Default value is sender name. Reply to name must have reply to email as well.', true)
->param('replyToEmail', '', new Text(128), 'Email set in the reply to field for the mail. Default value is sender email. Reply to email must have reply to name as well.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, string $from, string $apiKey, string $domain, ?bool $isEuRegion, ?bool $enabled, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, string $apiKey, string $domain, ?bool $isEuRegion, ?bool $enabled, string $fromName, string $fromEmail, string $replyToName, string $replyToEmail, Event $queueForEvents, Database $dbForProject, Response $response) {
$providerId = $providerId == 'unique()' ? ID::unique() : $providerId;
$options = [];
$options = [
'fromName' => $fromName,
'fromEmail' => $fromEmail,
];
if (!empty($from)) {
$options ['from'] = $from;
if (!empty($replyToName) && !empty($replyToEmail)) {
$options['replyToName'] = $replyToName;
$options['replyToEmail'] = $replyToEmail;
}
$credentials = [];
@ -137,19 +145,26 @@ App::post('/v1/messaging/providers/sendgrid')
->label('sdk.response.model', Response::MODEL_PROVIDER)
->param('providerId', '', new CustomId(), 'Provider 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('name', '', new Text(128), 'Provider name.')
->param('from', '', new Email(), 'Sender email address.', true)
->param('apiKey', '', new Text(0), 'Sendgrid API key.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('fromName', '', new Text(128), 'Sender Name.', true)
->param('fromEmail', '', new Email(), 'Sender email address.', true)
->param('replyToName', '', new Text(128), 'Name set in the reply to field for the mail. Default value is sender name.', true)
->param('replyToEmail', '', new Text(128), 'Email set in the reply to field for the mail. Default value is sender email.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, string $from, string $apiKey, ?bool $enabled, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, string $apiKey, ?bool $enabled, string $fromName, string $fromEmail, string $replyToName, string $replyToEmail, Event $queueForEvents, Database $dbForProject, Response $response) {
$providerId = $providerId == 'unique()' ? ID::unique() : $providerId;
$options = [];
$options = [
'fromName' => $fromName,
'fromEmail' => $fromEmail,
];
if (!empty($from)) {
$options ['from'] = $from;
if (!empty($replyToName) && !empty($replyToEmail)) {
$options['replyToName'] = $replyToName;
$options['replyToEmail'] = $replyToEmail;
}
$credentials = [];
@ -221,7 +236,7 @@ App::post('/v1/messaging/providers/msg91')
$options = [];
if (!empty($from)) {
$options ['from'] = $from;
$options['from'] = $from;
}
$credentials = [];
@ -298,7 +313,7 @@ App::post('/v1/messaging/providers/telesign')
$options = [];
if (!empty($from)) {
$options ['from'] = $from;
$options['from'] = $from;
}
$credentials = [];
@ -375,7 +390,7 @@ App::post('/v1/messaging/providers/textmagic')
$options = [];
if (!empty($from)) {
$options ['from'] = $from;
$options['from'] = $from;
}
$credentials = [];
@ -452,7 +467,7 @@ App::post('/v1/messaging/providers/twilio')
$options = [];
if (!empty($from)) {
$options ['from'] = $from;
$options['from'] = $from;
}
$credentials = [];
@ -529,7 +544,7 @@ App::post('/v1/messaging/providers/vonage')
$options = [];
if (!empty($from)) {
$options ['from'] = $from;
$options['from'] = $from;
}
$credentials = [];
@ -593,21 +608,21 @@ App::post('/v1/messaging/providers/fcm')
->label('sdk.response.model', Response::MODEL_PROVIDER)
->param('providerId', '', new CustomId(), 'Provider 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('name', '', new Text(128), 'Provider name.')
->param('serverKey', '', new Text(0), 'FCM server key.', true)
->param('serviceAccountJSON', null, new JSON(), 'FCM service account JSON.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, string $serverKey, ?bool $enabled, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, ?array $serviceAccountJSON, ?bool $enabled, Event $queueForEvents, Database $dbForProject, Response $response) {
$providerId = $providerId == 'unique()' ? ID::unique() : $providerId;
$credentials = [];
if (!empty($serverKey)) {
$credentials['serverKey'] = $serverKey;
if (!\is_null($serviceAccountJSON)) {
$credentials['serviceAccountJSON'] = $serviceAccountJSON;
}
if ($enabled === true && \array_key_exists('serverKey', $credentials)) {
if ($enabled === true && \array_key_exists('serviceAccountJSON', $credentials)) {
$enabled = true;
} else {
$enabled = false;
@ -888,15 +903,18 @@ App::patch('/v1/messaging/providers/mailgun/:providerId')
->label('sdk.response.model', Response::MODEL_PROVIDER)
->param('providerId', '', new UID(), 'Provider ID.')
->param('name', '', new Text(128), 'Provider name.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('isEuRegion', null, new Boolean(), 'Set as EU region.', true)
->param('from', '', new Email(), 'Sender email address.', true)
->param('apiKey', '', new Text(0), 'Mailgun API Key.', true)
->param('domain', '', new Text(0), 'Mailgun Domain.', true)
->param('isEuRegion', null, new Boolean(), 'Set as EU region.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('fromName', '', new Text(128), 'Sender Name.', true)
->param('fromEmail', '', new Email(), 'Sender email address.', true)
->param('replyToName', '', new Text(128), 'Name set in the reply to field for the mail. Default value is sender name.', true)
->param('replyToEmail', '', new Text(128), 'Email set in the reply to field for the mail. Default value is sender email.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, ?bool $enabled, ?bool $isEuRegion, string $from, string $apiKey, string $domain, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, string $apiKey, string $domain, ?bool $isEuRegion, ?bool $enabled, string $fromName, string $fromEmail, string $replyToName, string $replyToEmail, Event $queueForEvents, Database $dbForProject, Response $response) {
$provider = $dbForProject->getDocument('providers', $providerId);
if ($provider->isEmpty()) {
@ -912,12 +930,26 @@ App::patch('/v1/messaging/providers/mailgun/:providerId')
$provider->setAttribute('name', $name);
}
if (!empty($from)) {
$provider->setAttribute('options', [
'from' => $from,
]);
$options = $provider->getAttribute('options');
if (!empty($fromName)) {
$options['fromName'] = $fromName;
}
if (!empty($fromEmail)) {
$options['fromEmail'] = $fromEmail;
}
if (!empty($replyToName)) {
$options['replyToName'] = $replyToName;
}
if (!empty($replyToEmail)) {
$options['replyToEmail'] = $replyToEmail;
}
$provider->setAttribute('options', $options);
$credentials = $provider->getAttribute('credentials');
if ($isEuRegion === true || $isEuRegion === false) {
@ -976,11 +1008,14 @@ App::patch('/v1/messaging/providers/sendgrid/:providerId')
->param('name', '', new Text(128), 'Provider name.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('apiKey', '', new Text(0), 'Sendgrid API key.', true)
->param('from', '', new Email(), 'Sender email address.', true)
->param('fromName', '', new Text(128), 'Sender Name.', true)
->param('fromEmail', '', new Email(), 'Sender email address.', true)
->param('replyToName', '', new Text(128), 'Name set in the Reply To field for the mail. Default value is Sender Name.', true)
->param('replyToEmail', '', new Text(128), 'Email set in the Reply To field for the mail. Default value is Sender Email.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, ?bool $enabled, string $apiKey, string $from, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, ?bool $enabled, string $apiKey, string $fromName, string $fromEmail, string $replyToName, string $replyToEmail, Event $queueForEvents, Database $dbForProject, Response $response) {
$provider = $dbForProject->getDocument('providers', $providerId);
if ($provider->isEmpty()) {
@ -996,12 +1031,26 @@ App::patch('/v1/messaging/providers/sendgrid/:providerId')
$provider->setAttribute('name', $name);
}
if (!empty($from)) {
$provider->setAttribute('options', [
'from' => $from,
]);
$options = $provider->getAttribute('options');
if (!empty($fromName)) {
$options['fromName'] = $fromName;
}
if (!empty($fromEmail)) {
$options['fromEmail'] = $fromEmail;
}
if (!empty($replyToName)) {
$options['replyToName'] = $replyToName;
}
if (!empty($replyToEmail)) {
$options['replyToEmail'] = $replyToEmail;
}
$provider->setAttribute('options', $options);
if (!empty($apiKey)) {
$provider->setAttribute('credentials', [
'apiKey' => $apiKey,
@ -1451,11 +1500,11 @@ App::patch('/v1/messaging/providers/fcm/:providerId')
->param('providerId', '', new UID(), 'Provider ID.')
->param('name', '', new Text(128), 'Provider name.', true)
->param('enabled', null, new Boolean(), 'Set as enabled.', true)
->param('serverKey', '', new Text(0), 'FCM Server Key.', true)
->param('serviceAccountJSON', null, new JSON(), 'FCM service account JSON.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('response')
->action(function (string $providerId, string $name, ?bool $enabled, string $serverKey, Event $queueForEvents, Database $dbForProject, Response $response) {
->action(function (string $providerId, string $name, ?bool $enabled, ?array $serviceAccountJSON, Event $queueForEvents, Database $dbForProject, Response $response) {
$provider = $dbForProject->getDocument('providers', $providerId);
if ($provider->isEmpty()) {
@ -1471,12 +1520,12 @@ App::patch('/v1/messaging/providers/fcm/:providerId')
$provider->setAttribute('name', $name);
}
if (!empty($serverKey)) {
$provider->setAttribute('credentials', ['serverKey' => $serverKey]);
if (!\is_null($serviceAccountJSON)) {
$provider->setAttribute('credentials', ['serviceAccountJSON' => $serviceAccountJSON]);
}
if ($enabled === true || $enabled === false) {
if ($enabled === true && \array_key_exists('serverKey', $provider->getAttribute('credentials'))) {
if ($enabled === true && \array_key_exists('serviceAccountJSON', $provider->getAttribute('credentials'))) {
$enabled = true;
} else {
$enabled = false;
@ -2227,9 +2276,11 @@ App::post('/v1/messaging/messages/email')
->param('messageId', '', new CustomId(), 'Message 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('subject', '', new Text(998), 'Email Subject.')
->param('content', '', new Text(64230), 'Email Content.')
->param('topics', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Targets IDs.', true)
->param('topics', [], new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('cc', [], new ArrayList(new UID()), 'Array of target IDs to be added as CC.', true)
->param('bcc', [], new ArrayList(new UID()), 'Array of target IDs to be added as BCC.', true)
->param('description', '', new Text(256), 'Description for message.', true)
->param('status', 'processing', new WhiteList(['draft', 'canceled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('html', false, new Boolean(), 'Is content of type HTML', true)
@ -2239,22 +2290,32 @@ App::post('/v1/messaging/messages/email')
->inject('project')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, string $subject, string $content, array $topics, array $users, array $targets, string $description, string $status, bool $html, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$messageId = $messageId == 'unique()' ? ID::unique() : $messageId;
->action(function (string $messageId, string $subject, string $content, array $topics, array $users, array $targets, array $cc, array $bcc, string $description, string $status, bool $html, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$messageId = $messageId == 'unique()'
? ID::unique()
: $messageId;
if (\count($topics) === 0 && \count($users) === 0 && \count($targets) === 0) {
throw new Exception(Exception::MESSAGE_MISSING_TARGET);
}
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
$mergedTargets = \array_merge($targets, $cc, $bcc);
if ($targetDocument->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
if (!empty($mergedTargets)) {
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $mergedTargets),
Query::equal('providerType', [MESSAGE_TYPE_EMAIL]),
Query::limit(\count($mergedTargets)),
]);
if (\count($foundTargets) !== \count($mergedTargets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_EMAIL);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_EMAIL) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_EMAIL . ' ' . $targetDocument->getId());
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
}
}
@ -2269,6 +2330,8 @@ App::post('/v1/messaging/messages/email')
'subject' => $subject,
'content' => $content,
'html' => $html,
'cc' => $cc,
'bcc' => $bcc,
],
'status' => $status,
]));
@ -2304,9 +2367,9 @@ App::post('/v1/messaging/messages/sms')
->label('sdk.response.model', Response::MODEL_MESSAGE)
->param('messageId', '', new CustomId(), 'Message 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('content', '', new Text(64230), 'SMS Content.')
->param('topics', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Targets IDs.', true)
->param('topics', [], new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('description', '', new Text(256), 'Description for Message.', true)
->param('status', 'processing', new WhiteList(['draft', 'canceled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('scheduledAt', null, new DatetimeValidator(requireDateInFuture: true), 'Scheduled delivery time for message in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future.', true)
@ -2316,22 +2379,28 @@ App::post('/v1/messaging/messages/sms')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, string $content, array $topics, array $users, array $targets, string $description, string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$messageId = $messageId == 'unique()' ? ID::unique() : $messageId;
$messageId = $messageId == 'unique()'
? ID::unique()
: $messageId;
if (\count($topics) === 0 && \count($users) === 0 && \count($targets) === 0) {
throw new Exception(Exception::MESSAGE_MISSING_TARGET);
}
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $targets),
Query::equal('providerType', [MESSAGE_TYPE_SMS]),
Query::limit(\count($targets)),
]);
if ($targetDocument->isEmpty()) {
if (\count($foundTargets) !== \count($targets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_SMS);
}
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_SMS) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_SMS . ' ' . $targetDocument->getId());
}
}
$message = $dbForProject->createDocument('messages', new Document([
@ -2379,9 +2448,9 @@ App::post('/v1/messaging/messages/push')
->param('messageId', '', new CustomId(), 'Message 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('title', '', new Text(256), 'Title for push notification.')
->param('body', '', new Text(64230), 'Body for push notification.')
->param('topics', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Targets IDs.', true)
->param('topics', [], new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', [], new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', [], new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('description', '', new Text(256), 'Description for Message.', true)
->param('data', null, new JSON(), 'Additional Data for push notification.', true)
->param('action', '', new Text(256), 'Action for push notification.', true)
@ -2398,22 +2467,28 @@ App::post('/v1/messaging/messages/push')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, string $title, string $body, array $topics, array $users, array $targets, string $description, ?array $data, string $action, string $icon, string $sound, string $color, string $tag, string $badge, string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$messageId = $messageId == 'unique()' ? ID::unique() : $messageId;
$messageId = $messageId == 'unique()'
? ID::unique()
: $messageId;
if (\count($topics) === 0 && \count($users) === 0 && \count($targets) === 0) {
throw new Exception(Exception::MESSAGE_MISSING_TARGET);
}
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $targets),
Query::equal('providerType', [MESSAGE_TYPE_PUSH]),
Query::limit(\count($targets)),
]);
if ($targetDocument->isEmpty()) {
if (\count($foundTargets) !== \count($targets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_PUSH);
}
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_PUSH) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_PUSH . ' ' . $targetDocument->getId());
}
}
$pushData = [];
@ -2619,21 +2694,23 @@ App::patch('/v1/messaging/messages/email/:messageId')
->label('sdk.response.type', Response::CONTENT_TYPE_JSON)
->label('sdk.response.model', Response::MODEL_MESSAGE)
->param('messageId', '', new UID(), 'Message ID.')
->param('topics', null, new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new Text(Database::LENGTH_KEY)), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new Text(Database::LENGTH_KEY)), 'List of Targets IDs.', true)
->param('subject', '', new Text(998), 'Email Subject.', true)
->param('description', '', new Text(256), 'Description for Message.', true)
->param('content', '', new Text(64230), 'Email Content.', true)
->param('status', '', new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('html', false, new Boolean(), 'Is content of type HTML', true)
->param('topics', null, new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('subject', null, new Text(998), 'Email Subject.', true)
->param('description', null, new Text(256), 'Description for Message.', true)
->param('content', null, new Text(64230), 'Email Content.', true)
->param('status', null, new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('html', null, new Boolean(), 'Is content of type HTML', true)
->param('cc', null, new ArrayList(new UID()), 'Array of target IDs to be added as CC.', true)
->param('bcc', null, new ArrayList(new UID()), 'Array of target IDs to be added as BCC.', true)
->param('scheduledAt', null, new DatetimeValidator(requireDateInFuture: true), 'Scheduled delivery time for message in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('project')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, string $subject, string $description, string $content, string $status, bool $html, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, ?string $subject, ?string $description, ?string $content, ?string $status, ?bool $html, ?array $cc, ?array $bcc, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$message = $dbForProject->getDocument('messages', $messageId);
if ($message->isEmpty()) {
@ -2644,7 +2721,7 @@ App::patch('/v1/messaging/messages/email/:messageId')
throw new Exception(Exception::MESSAGE_ALREADY_SENT);
}
if (!is_null($message->getAttribute('scheduledAt')) && $message->getAttribute('scheduledAt') < new \DateTime()) {
if (!\is_null($message->getAttribute('scheduledAt')) && $message->getAttribute('scheduledAt') < new \DateTime()) {
throw new Exception(Exception::MESSAGE_ALREADY_SCHEDULED);
}
@ -2656,43 +2733,57 @@ App::patch('/v1/messaging/messages/email/:messageId')
$message->setAttribute('users', $users);
}
if (!\is_null($targets)) {
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
if (!\is_null($targets) || !\is_null($cc) || !\is_null($bcc)) {
$mergedTargets = \array_merge(...\array_filter([$targets, $cc, $bcc]));
if ($targetDocument->isEmpty()) {
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $mergedTargets),
Query::equal('providerType', [MESSAGE_TYPE_EMAIL]),
Query::limit(\count($mergedTargets)),
]);
if (\count($foundTargets) !== \count($mergedTargets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_EMAIL);
}
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_EMAIL) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_EMAIL . ' ' . $targetDocument->getId());
}
}
$message->setAttribute('targets', $targets);
}
$data = $message->getAttribute('data');
if (!empty($subject)) {
if (!\is_null($targets)) {
$message->setAttribute('targets', $targets);
}
if (!\is_null($subject)) {
$data['subject'] = $subject;
}
if (!empty($content)) {
if (!\is_null($content)) {
$data['content'] = $content;
}
if (!empty($html)) {
if (!\is_null($html)) {
$data['html'] = $html;
}
if (!\is_null($cc)) {
$data['cc'] = $cc;
}
if (!\is_null($bcc)) {
$data['bcc'] = $bcc;
}
$message->setAttribute('data', $data);
if (!empty($description)) {
if (!\is_null($description)) {
$message->setAttribute('description', $description);
}
if (!empty($status)) {
if (!\is_null($status)) {
$message->setAttribute('status', $status);
}
@ -2731,19 +2822,19 @@ App::patch('/v1/messaging/messages/sms/:messageId')
->label('sdk.response.type', Response::CONTENT_TYPE_JSON)
->label('sdk.response.model', Response::MODEL_MESSAGE)
->param('messageId', '', new UID(), 'Message ID.')
->param('topics', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of Targets IDs.', true)
->param('description', '', new Text(256), 'Description for Message.', true)
->param('content', '', new Text(64230), 'Email Content.', true)
->param('status', '', new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('topics', null, new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('description', null, new Text(256), 'Description for Message.', true)
->param('content', null, new Text(64230), 'Email Content.', true)
->param('status', null, new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('scheduledAt', null, new DatetimeValidator(requireDateInFuture: true), 'Scheduled delivery time for message in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('project')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, string $description, string $content, string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, ?string $description, ?string $content, ?string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$message = $dbForProject->getDocument('messages', $messageId);
if ($message->isEmpty()) {
@ -2767,16 +2858,20 @@ App::patch('/v1/messaging/messages/sms/:messageId')
}
if (!\is_null($targets)) {
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $targets),
Query::equal('providerType', [MESSAGE_TYPE_SMS]),
Query::limit(\count($targets)),
]);
if ($targetDocument->isEmpty()) {
if (\count($foundTargets) !== \count($targets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_SMS);
}
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_SMS) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_SMS . ' ' . $targetDocument->getId());
}
}
$message->setAttribute('targets', $targets);
@ -2784,17 +2879,17 @@ App::patch('/v1/messaging/messages/sms/:messageId')
$data = $message->getAttribute('data');
if (!empty($content)) {
if (!\is_null($content)) {
$data['content'] = $content;
}
$message->setAttribute('data', $data);
if (!empty($status)) {
if (!\is_null($status)) {
$message->setAttribute('status', $status);
}
if (!empty($description)) {
if (!\is_null($description)) {
$message->setAttribute('description', $description);
}
@ -2833,27 +2928,27 @@ App::patch('/v1/messaging/messages/push/:messageId')
->label('sdk.response.type', Response::CONTENT_TYPE_JSON)
->label('sdk.response.model', Response::MODEL_MESSAGE)
->param('messageId', '', new UID(), 'Message ID.')
->param('topics', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new Text(Database::LENGTH_KEY), 1), 'List of Targets IDs.', true)
->param('description', '', new Text(256), 'Description for Message.', true)
->param('title', '', new Text(256), 'Title for push notification.', true)
->param('body', '', new Text(64230), 'Body for push notification.', true)
->param('topics', null, new ArrayList(new UID()), 'List of Topic IDs.', true)
->param('users', null, new ArrayList(new UID()), 'List of User IDs.', true)
->param('targets', null, new ArrayList(new UID()), 'List of Targets IDs.', true)
->param('description', null, new Text(256), 'Description for Message.', true)
->param('title', null, new Text(256), 'Title for push notification.', true)
->param('body', null, new Text(64230), 'Body for push notification.', true)
->param('data', null, new JSON(), 'Additional Data for push notification.', true)
->param('action', '', new Text(256), 'Action for push notification.', true)
->param('icon', '', new Text(256), 'Icon for push notification. Available only for Android and Web Platform.', true)
->param('sound', '', new Text(256), 'Sound for push notification. Available only for Android and IOS Platform.', true)
->param('color', '', new Text(256), 'Color for push notification. Available only for Android Platform.', true)
->param('tag', '', new Text(256), 'Tag for push notification. Available only for Android Platform.', true)
->param('badge', '', new Text(256), 'Badge for push notification. Available only for IOS Platform.', true)
->param('status', '', new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft or cancelled or processing.', true)
->param('action', null, new Text(256), 'Action for push notification.', true)
->param('icon', null, new Text(256), 'Icon for push notification. Available only for Android and Web platforms.', true)
->param('sound', null, new Text(256), 'Sound for push notification. Available only for Android and iOS platforms.', true)
->param('color', null, new Text(256), 'Color for push notification. Available only for Android platforms.', true)
->param('tag', null, new Text(256), 'Tag for push notification. Available only for Android platforms.', true)
->param('badge', null, new Integer(), 'Badge for push notification. Available only for iOS platforms.', true)
->param('status', null, new WhiteList(['draft', 'cancelled', 'processing']), 'Message Status. Value must be either draft, cancelled, or processing.', true)
->param('scheduledAt', null, new DatetimeValidator(requireDateInFuture: true), 'Scheduled delivery time for message in [ISO 8601](https://www.iso.org/iso-8601-date-and-time-format.html) format. DateTime value must be in future.', true)
->inject('queueForEvents')
->inject('dbForProject')
->inject('project')
->inject('queueForMessaging')
->inject('response')
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, string $description, string $title, string $body, ?array $data, string $action, string $icon, string $sound, string $color, string $tag, string $badge, string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
->action(function (string $messageId, ?array $topics, ?array $users, ?array $targets, ?string $description, ?string $title, ?string $body, ?array $data, ?string $action, ?string $icon, ?string $sound, ?string $color, ?string $tag, ?int $badge, ?string $status, ?string $scheduledAt, Event $queueForEvents, Database $dbForProject, Document $project, Messaging $queueForMessaging, Response $response) {
$message = $dbForProject->getDocument('messages', $messageId);
if ($message->isEmpty()) {
@ -2877,16 +2972,20 @@ App::patch('/v1/messaging/messages/push/:messageId')
}
if (!\is_null($targets)) {
foreach ($targets as $target) {
$targetDocument = $dbForProject->getDocument('targets', $target);
$foundTargets = $dbForProject->find('targets', [
Query::equal('$id', $targets),
Query::equal('providerType', [MESSAGE_TYPE_PUSH]),
Query::limit(\count($targets)),
]);
if ($targetDocument->isEmpty()) {
if (\count($foundTargets) !== \count($targets)) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_PUSH);
}
foreach ($foundTargets as $target) {
if ($target->isEmpty()) {
throw new Exception(Exception::USER_TARGET_NOT_FOUND);
}
if ($targetDocument->getAttribute('providerType') !== MESSAGE_TYPE_PUSH) {
throw new Exception(Exception::MESSAGE_TARGET_NOT_PUSH . ' ' . $targetDocument->getId());
}
}
$message->setAttribute('targets', $targets);
@ -2894,53 +2993,53 @@ App::patch('/v1/messaging/messages/push/:messageId')
$pushData = $message->getAttribute('data');
if ($title) {
if (!\is_null($title)) {
$pushData['title'] = $title;
}
if ($body) {
if (!\is_null($body)) {
$pushData['body'] = $body;
}
if (!is_null($data)) {
if (!\is_null($data)) {
$pushData['data'] = $data;
}
if ($action) {
if (!\is_null($action)) {
$pushData['action'] = $action;
}
if ($icon) {
if (!\is_null($icon)) {
$pushData['icon'] = $icon;
}
if ($sound) {
if (!\is_null($sound)) {
$pushData['sound'] = $sound;
}
if ($color) {
if (!\is_null($color)) {
$pushData['color'] = $color;
}
if ($tag) {
if (!\is_null($tag)) {
$pushData['tag'] = $tag;
}
if ($badge) {
if (!\is_null($badge)) {
$pushData['badge'] = $badge;
}
$message->setAttribute('data', $pushData);
if (!empty($status)) {
if (!\is_null($status)) {
$message->setAttribute('status', $status);
}
if (!empty($description)) {
if (!\is_null($description)) {
$message->setAttribute('description', $description);
}
if (!is_null($scheduledAt)) {
if (!\is_null($scheduledAt)) {
$message->setAttribute('scheduledAt', $scheduledAt);
}

View file

@ -44,6 +44,7 @@ use Utopia\Validator\Text;
use Utopia\Validator\WhiteList;
use Utopia\DSN\DSN;
use Utopia\Swoole\Request;
use Utopia\Storage\Compression\Compression;
App::post('/v1/storage/buckets')
->desc('Create bucket')
@ -67,7 +68,7 @@ App::post('/v1/storage/buckets')
->param('enabled', true, new Boolean(true), 'Is bucket enabled? When set to \'disabled\', users cannot access the files in this bucket but Server SDKs with and API key can still access the bucket. No files are lost when this is toggled.', true)
->param('maximumFileSize', (int) App::getEnv('_APP_STORAGE_LIMIT', 0), new Range(1, (int) App::getEnv('_APP_STORAGE_LIMIT', 0)), 'Maximum file size allowed in bytes. Maximum allowed value is ' . Storage::human(App::getEnv('_APP_STORAGE_LIMIT', 0), 0) . '.', true)
->param('allowedFileExtensions', [], new ArrayList(new Text(64), APP_LIMIT_ARRAY_PARAMS_SIZE), 'Allowed file extensions. Maximum of ' . APP_LIMIT_ARRAY_PARAMS_SIZE . ' extensions are allowed, each 64 characters long.', true)
->param('compression', COMPRESSION_TYPE_NONE, new WhiteList([COMPRESSION_TYPE_NONE, COMPRESSION_TYPE_GZIP, COMPRESSION_TYPE_ZSTD]), 'Compression algorithm choosen for compression. Can be one of ' . COMPRESSION_TYPE_NONE . ', [' . COMPRESSION_TYPE_GZIP . '](https://en.wikipedia.org/wiki/Gzip), or [' . COMPRESSION_TYPE_ZSTD . '](https://en.wikipedia.org/wiki/Zstd), For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' compression is skipped even if it\'s enabled', true)
->param('compression', Compression::NONE, new WhiteList([Compression::NONE, Compression::GZIP, Compression::ZSTD]), 'Compression algorithm choosen for compression. Can be one of ' . Compression::NONE . ', [' . Compression::GZIP . '](https://en.wikipedia.org/wiki/Gzip), or [' . Compression::ZSTD . '](https://en.wikipedia.org/wiki/Zstd), For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' compression is skipped even if it\'s enabled', true)
->param('encryption', true, new Boolean(true), 'Is encryption enabled? For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' encryption is skipped even if it\'s enabled', true)
->param('antivirus', true, new Boolean(true), 'Is virus scanning enabled? For file size above ' . Storage::human(APP_LIMIT_ANTIVIRUS, 0) . ' AntiVirus scanning is skipped even if it\'s enabled', true)
->inject('response')
@ -241,7 +242,7 @@ App::put('/v1/storage/buckets/:bucketId')
->param('enabled', true, new Boolean(true), 'Is bucket enabled? When set to \'disabled\', users cannot access the files in this bucket but Server SDKs with and API key can still access the bucket. No files are lost when this is toggled.', true)
->param('maximumFileSize', null, new Range(1, (int) App::getEnv('_APP_STORAGE_LIMIT', 0)), 'Maximum file size allowed in bytes. Maximum allowed value is ' . Storage::human((int)App::getEnv('_APP_STORAGE_LIMIT', 0), 0) . '.', true)
->param('allowedFileExtensions', [], new ArrayList(new Text(64), APP_LIMIT_ARRAY_PARAMS_SIZE), 'Allowed file extensions. Maximum of ' . APP_LIMIT_ARRAY_PARAMS_SIZE . ' extensions are allowed, each 64 characters long.', true)
->param('compression', COMPRESSION_TYPE_NONE, new WhiteList([COMPRESSION_TYPE_NONE, COMPRESSION_TYPE_GZIP, COMPRESSION_TYPE_ZSTD]), 'Compression algorithm choosen for compression. Can be one of ' . COMPRESSION_TYPE_NONE . ', [' . COMPRESSION_TYPE_GZIP . '](https://en.wikipedia.org/wiki/Gzip), or [' . COMPRESSION_TYPE_ZSTD . '](https://en.wikipedia.org/wiki/Zstd), For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' compression is skipped even if it\'s enabled', true)
->param('compression', Compression::NONE, new WhiteList([Compression::NONE, Compression::GZIP, Compression::ZSTD]), 'Compression algorithm choosen for compression. Can be one of ' . Compression::NONE . ', [' . Compression::GZIP . '](https://en.wikipedia.org/wiki/Gzip), or [' . Compression::ZSTD . '](https://en.wikipedia.org/wiki/Zstd), For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' compression is skipped even if it\'s enabled', true)
->param('encryption', true, new Boolean(true), 'Is encryption enabled? For file size above ' . Storage::human(APP_STORAGE_READ_BUFFER, 0) . ' encryption is skipped even if it\'s enabled', true)
->param('antivirus', true, new Boolean(true), 'Is virus scanning enabled? For file size above ' . Storage::human(APP_LIMIT_ANTIVIRUS, 0) . ' AntiVirus scanning is skipped even if it\'s enabled', true)
->inject('response')
@ -538,19 +539,24 @@ App::post('/v1/storage/buckets/:bucketId/files')
$fileHash = $deviceFiles->getFileHash($path); // Get file hash before compression and encryption
$data = '';
// Compression
$algorithm = $bucket->getAttribute('compression', COMPRESSION_TYPE_NONE);
if ($fileSize <= APP_STORAGE_READ_BUFFER && $algorithm != COMPRESSION_TYPE_NONE) {
$algorithm = $bucket->getAttribute('compression', Compression::NONE);
if ($fileSize <= APP_STORAGE_READ_BUFFER && $algorithm != Compression::NONE) {
$data = $deviceFiles->read($path);
switch ($algorithm) {
case COMPRESSION_TYPE_ZSTD:
case Compression::ZSTD:
$compressor = new Zstd();
break;
case COMPRESSION_TYPE_GZIP:
case Compression::GZIP:
default:
$compressor = new GZIP();
break;
}
$data = $compressor->compress($data);
} else {
// reset the algorithm to none as we do not compress the file
// if file size exceedes the APP_STORAGE_READ_BUFFER
// regardless the bucket compression algoorithm
$algorithm = Compression::NONE;
}
if ($bucket->getAttribute('encryption', true) && $fileSize <= APP_STORAGE_READ_BUFFER) {
@ -622,7 +628,17 @@ App::post('/v1/storage/buckets/:bucketId/files')
->setAttribute('metadata', $metadata)
->setAttribute('chunksUploaded', $chunksUploaded);
$file = $dbForProject->updateDocument('bucket_' . $bucket->getInternalId(), $fileId, $file);
/**
* Validate create permission and skip authorization in updateDocument
* Without this, the file creation will fail when user doesn't have update permission
* However as with chunk upload even if we are updating, we are essentially creating a file
* adding it's new chunk so we validate create permission instead of update
*/
$validator = new Authorization(Database::PERMISSION_CREATE);
if (!$validator->isValid($bucket->getCreate())) {
throw new Exception(Exception::USER_UNAUTHORIZED);
}
$file = Authorization::skip(fn() => $dbForProject->updateDocument('bucket_' . $bucket->getInternalId(), $fileId, $file));
}
} catch (AuthorizationException) {
throw new Exception(Exception::USER_UNAUTHORIZED);
@ -659,7 +675,17 @@ App::post('/v1/storage/buckets/:bucketId/files')
->setAttribute('chunksUploaded', $chunksUploaded)
->setAttribute('metadata', $metadata);
$file = $dbForProject->updateDocument('bucket_' . $bucket->getInternalId(), $fileId, $file);
/**
* Validate create permission and skip authorization in updateDocument
* Without this, the file creation will fail when user doesn't have update permission
* However as with chunk upload even if we are updating, we are essentially creating a file
* adding it's new chunk so we validate create permission instead of update
*/
$validator = new Authorization(Database::PERMISSION_CREATE);
if (!$validator->isValid($bucket->getCreate())) {
throw new Exception(Exception::USER_UNAUTHORIZED);
}
$file = Authorization::skip(fn() => $dbForProject->updateDocument('bucket_' . $bucket->getInternalId(), $fileId, $file));
}
} catch (AuthorizationException) {
throw new Exception(Exception::USER_UNAUTHORIZED);
@ -872,14 +898,6 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/preview')
throw new Exception(Exception::USER_UNAUTHORIZED);
}
if ((\strpos($request->getAccept(), 'image/webp') === false) && ('webp' === $output)) { // Fallback webp to jpeg when no browser support
$output = 'jpg';
}
$inputs = Config::getParam('storage-inputs');
$outputs = Config::getParam('storage-outputs');
$fileLogos = Config::getParam('storage-logos');
if ($fileSecurity && !$valid) {
$file = $dbForProject->getDocument('bucket_' . $bucket->getInternalId(), $fileId);
} else {
@ -890,9 +908,17 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/preview')
throw new Exception(Exception::STORAGE_FILE_NOT_FOUND);
}
if ((\strpos($request->getAccept(), 'image/webp') === false) && ('webp' === $output)) { // Fallback webp to jpeg when no browser support
$output = 'jpg';
}
$inputs = Config::getParam('storage-inputs');
$outputs = Config::getParam('storage-outputs');
$fileLogos = Config::getParam('storage-logos');
$path = $file->getAttribute('path');
$type = \strtolower(\pathinfo($path, PATHINFO_EXTENSION));
$algorithm = $file->getAttribute('algorithm', 'none');
$algorithm = $file->getAttribute('algorithm', Compression::NONE);
$cipher = $file->getAttribute('openSSLCipher');
$mime = $file->getAttribute('mimeType');
if (!\in_array($mime, $inputs) || $file->getAttribute('sizeActual') > (int) App::getEnv('_APP_STORAGE_PREVIEW_LIMIT', 20000000)) {
@ -903,7 +929,7 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/preview')
$path = $fileLogos['default_image'];
}
$algorithm = 'none';
$algorithm = Compression::NONE;
$cipher = null;
$background = (empty($background)) ? 'eceff1' : $background;
$type = \strtolower(\pathinfo($path, PATHINFO_EXTENSION));
@ -915,12 +941,17 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/preview')
}
if (empty($output)) {
// when file extension is provided but it's not one of our
// supported outputs we fallback to `jpg`
if (!empty($type) && !array_key_exists($type, $outputs)) {
$type = 'jpg';
}
// when file extension is not provided and the mime type is not one of our supported outputs
// we fallback to `jpg` output format
$output = empty($type) ? (array_search($mime, $outputs) ?? 'jpg') : $type;
}
$source = $deviceFiles->read($path);
if (!empty($cipher)) { // Decrypt
@ -935,11 +966,11 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/preview')
}
switch ($algorithm) {
case 'zstd':
case Compression::ZSTD:
$compressor = new Zstd();
$source = $compressor->decompress($source);
break;
case 'gzip':
case Compression::GZIP:
$compressor = new GZIP();
$source = $compressor->decompress($source);
break;
@ -1080,15 +1111,15 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/download')
);
}
switch ($file->getAttribute('algorithm', 'none')) {
case 'zstd':
switch ($file->getAttribute('algorithm', Compression::NONE)) {
case Compression::ZSTD:
if (empty($source)) {
$source = $deviceFiles->read($path);
}
$compressor = new Zstd();
$source = $compressor->decompress($source);
break;
case 'gzip':
case Compression::GZIP:
if (empty($source)) {
$source = $deviceFiles->read($path);
}
@ -1231,15 +1262,15 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/view')
);
}
switch ($file->getAttribute('algorithm', 'none')) {
case 'zstd':
switch ($file->getAttribute('algorithm', Compression::NONE)) {
case Compression::ZSTD:
if (empty($source)) {
$source = $deviceFiles->read($path);
}
$compressor = new Zstd();
$source = $compressor->decompress($source);
break;
case 'gzip':
case Compression::GZIP:
if (empty($source)) {
$source = $deviceFiles->read($path);
}
@ -1253,10 +1284,12 @@ App::get('/v1/storage/buckets/:bucketId/files/:fileId/view')
$response->send(substr($source, $start, ($end - $start + 1)));
}
$response->send($source);
return;
}
if (!empty($rangeHeader)) {
$response->send($deviceFiles->read($path, $start, ($end - $start + 1)));
return;
}
$size = $deviceFiles->getFileSize($path);

View file

@ -1598,7 +1598,7 @@ App::delete('/v1/users/:userId/targets/:targetId')
});
App::delete('/v1/users/identities/:identityId')
->desc('Delete Identity')
->desc('Delete identity')
->groups(['api', 'users'])
->label('event', 'users.[userId].identities.[identityId].delete')
->label('scope', 'users.write')
@ -1614,7 +1614,8 @@ App::delete('/v1/users/identities/:identityId')
->param('identityId', '', new UID(), 'Identity ID.')
->inject('response')
->inject('dbForProject')
->action(function (string $identityId, Response $response, Database $dbForProject) {
->inject('queueForEvents')
->action(function (string $identityId, Response $response, Database $dbForProject, Event $queueForEvents) {
$identity = $dbForProject->getDocument('identities', $identityId);
@ -1624,6 +1625,11 @@ App::delete('/v1/users/identities/:identityId')
$dbForProject->deleteDocument('identities', $identityId);
$queueForEvents
->setParam('userId', $identity->getAttribute('userId'))
->setParam('identityId', $identity->getId())
->setPayload($response->output($identity, Response::MODEL_IDENTITY));
return $response->noContent();
});

View file

@ -556,6 +556,22 @@ App::shutdown()
->setParam('project.{scope}.network.outbound', $response->getSize())
->submit();
}
/**
* Update user last activity
*/
if (!$user->isEmpty()) {
$accessedAt = $user->getAttribute('accessedAt', '');
if (DateTime::formatTz(DateTime::addSeconds(new \DateTime(), -APP_USER_ACCCESS)) > $accessedAt) {
$user->setAttribute('accessedAt', DateTime::now());
if (APP_MODE_ADMIN !== $mode) {
$dbForProject->updateDocument('users', $user->getId(), $user);
} else {
$dbForConsole->updateDocument('users', $user->getId(), $user);
}
}
}
});
App::init()

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;
@ -170,10 +171,6 @@ const DELETE_TYPE_CACHE_BY_TIMESTAMP = 'cacheByTimeStamp';
const DELETE_TYPE_CACHE_BY_RESOURCE = 'cacheByResource';
const DELETE_TYPE_SCHEDULES = 'schedules';
const DELETE_TYPE_TOPIC = 'topic';
// Compression type
const COMPRESSION_TYPE_NONE = 'none';
const COMPRESSION_TYPE_GZIP = 'gzip';
const COMPRESSION_TYPE_ZSTD = 'zstd';
// Mail Types
const MAIL_TYPE_VERIFICATION = 'verification';
const MAIL_TYPE_MAGIC_SESSION = 'magicSession';
@ -1048,6 +1045,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

@ -277,7 +277,7 @@ $worker
$worker->workerStart()
->action(function () use ($workerName) {
Console::info("Worker $workerName started");
Console::info("Worker $workerName started");
});
$worker->start();

3
bin/dev-generate-translations Executable file
View file

@ -0,0 +1,3 @@
#!/bin/sh
php /usr/src/code/app/cli.php dev-generate-translations $@

View file

@ -56,7 +56,7 @@
"utopia-php/image": "0.5.*",
"utopia-php/locale": "0.4.*",
"utopia-php/logger": "0.3.*",
"utopia-php/messaging": "0.2.*",
"utopia-php/messaging": "0.8.*",
"utopia-php/migration": "0.3.*",
"utopia-php/orchestration": "0.9.*",
"utopia-php/platform": "0.5.*",
@ -90,7 +90,8 @@
"phpunit/phpunit": "9.5.20",
"squizlabs/php_codesniffer": "^3.7",
"swoole/ide-helper": "5.0.2",
"textalk/websocket": "1.5.7"
"textalk/websocket": "1.5.7",
"utopia-php/fetch": "0.1.*"
},
"provide": {
"ext-phpiredis": "*"

211
composer.lock generated
View file

@ -4,7 +4,7 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
"content-hash": "7041499af2e7b23795d8ef82c9d7a072",
"content-hash": "0922b311842c222911fce1ae3e3b352e",
"packages": [
{
"name": "adhocore/jwt",
@ -277,16 +277,16 @@
},
{
"name": "chillerlan/php-settings-container",
"version": "2.1.4",
"version": "2.1.5",
"source": {
"type": "git",
"url": "https://github.com/chillerlan/php-settings-container.git",
"reference": "1beb7df3c14346d4344b0b2e12f6f9a74feabd4a"
"reference": "f705310389264c3578fdd9ffb15aa2cd6d91772e"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/chillerlan/php-settings-container/zipball/1beb7df3c14346d4344b0b2e12f6f9a74feabd4a",
"reference": "1beb7df3c14346d4344b0b2e12f6f9a74feabd4a",
"url": "https://api.github.com/repos/chillerlan/php-settings-container/zipball/f705310389264c3578fdd9ffb15aa2cd6d91772e",
"reference": "f705310389264c3578fdd9ffb15aa2cd6d91772e",
"shasum": ""
},
"require": {
@ -294,8 +294,10 @@
"php": "^7.4 || ^8.0"
},
"require-dev": {
"phan/phan": "^5.3",
"phpunit/phpunit": "^9.5"
"phan/phan": "^5.4",
"phpcsstandards/php_codesniffer": "^3.8",
"phpmd/phpmd": "^2.13",
"phpunit/phpunit": "^9.6"
},
"type": "library",
"autoload": {
@ -337,7 +339,7 @@
"type": "ko_fi"
}
],
"time": "2022-07-05T22:32:14+00:00"
"time": "2024-01-05T23:20:55+00:00"
},
{
"name": "dragonmantank/cron-expression",
@ -1906,16 +1908,16 @@
},
{
"name": "utopia-php/database",
"version": "0.45.2",
"version": "0.45.3",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/database.git",
"reference": "dc789f2c1fd8b5ee07ff883e11c9ad7970824788"
"reference": "33b4e9a4a6c29f6bb7e108e134b283d585955789"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/database/zipball/dc789f2c1fd8b5ee07ff883e11c9ad7970824788",
"reference": "dc789f2c1fd8b5ee07ff883e11c9ad7970824788",
"url": "https://api.github.com/repos/utopia-php/database/zipball/33b4e9a4a6c29f6bb7e108e134b283d585955789",
"reference": "33b4e9a4a6c29f6bb7e108e134b283d585955789",
"shasum": ""
},
"require": {
@ -1956,9 +1958,9 @@
],
"support": {
"issues": "https://github.com/utopia-php/database/issues",
"source": "https://github.com/utopia-php/database/tree/0.45.2"
"source": "https://github.com/utopia-php/database/tree/0.45.3"
},
"time": "2023-11-15T03:38:47+00:00"
"time": "2023-12-28T11:12:26+00:00"
},
{
"name": "utopia-php/domains",
@ -2072,12 +2074,12 @@
"version": "0.31.1",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/framework.git",
"url": "https://github.com/utopia-php/http.git",
"reference": "e50d2d16f4bc31319043f3f6d3dbea36c6fd6b68"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/framework/zipball/e50d2d16f4bc31319043f3f6d3dbea36c6fd6b68",
"url": "https://api.github.com/repos/utopia-php/http/zipball/e50d2d16f4bc31319043f3f6d3dbea36c6fd6b68",
"reference": "e50d2d16f4bc31319043f3f6d3dbea36c6fd6b68",
"shasum": ""
},
@ -2107,8 +2109,8 @@
"upf"
],
"support": {
"issues": "https://github.com/utopia-php/framework/issues",
"source": "https://github.com/utopia-php/framework/tree/0.31.1"
"issues": "https://github.com/utopia-php/http/issues",
"source": "https://github.com/utopia-php/http/tree/0.31.1"
},
"time": "2023-12-08T18:47:29+00:00"
},
@ -2270,26 +2272,28 @@
},
{
"name": "utopia-php/messaging",
"version": "0.2.0",
"version": "0.8.0",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/messaging.git",
"reference": "2d0f474a106bb1da285f85e105c29b46085d3a43"
"reference": "64eca3faf02a79831f219d4f3ae05cd278a88b4b"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/messaging/zipball/2d0f474a106bb1da285f85e105c29b46085d3a43",
"reference": "2d0f474a106bb1da285f85e105c29b46085d3a43",
"url": "https://api.github.com/repos/utopia-php/messaging/zipball/64eca3faf02a79831f219d4f3ae05cd278a88b4b",
"reference": "64eca3faf02a79831f219d4f3ae05cd278a88b4b",
"shasum": ""
},
"require": {
"ext-curl": "*",
"ext-openssl": "*",
"php": ">=8.0.0"
},
"require-dev": {
"laravel/pint": "^1.2",
"laravel/pint": "1.13.*",
"phpmailer/phpmailer": "6.8.*",
"phpunit/phpunit": "9.6.*"
"phpstan/phpstan": "1.10.*",
"phpunit/phpunit": "9.6.10"
},
"type": "library",
"autoload": {
@ -2312,9 +2316,9 @@
],
"support": {
"issues": "https://github.com/utopia-php/messaging/issues",
"source": "https://github.com/utopia-php/messaging/tree/0.2.0"
"source": "https://github.com/utopia-php/messaging/tree/0.8.0"
},
"time": "2023-09-14T20:48:42+00:00"
"time": "2023-12-15T06:44:08+00:00"
},
{
"name": "utopia-php/migration",
@ -2476,16 +2480,16 @@
},
{
"name": "utopia-php/platform",
"version": "0.5.0",
"version": "0.5.1",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/platform.git",
"reference": "229a7b1fa1f39afd1532f7a515326a6afc222a26"
"reference": "3eceef0b6593fe0f7d2efd36d40402a395a4c285"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/platform/zipball/229a7b1fa1f39afd1532f7a515326a6afc222a26",
"reference": "229a7b1fa1f39afd1532f7a515326a6afc222a26",
"url": "https://api.github.com/repos/utopia-php/platform/zipball/3eceef0b6593fe0f7d2efd36d40402a395a4c285",
"reference": "3eceef0b6593fe0f7d2efd36d40402a395a4c285",
"shasum": ""
},
"require": {
@ -2493,7 +2497,7 @@
"ext-redis": "*",
"php": ">=8.0",
"utopia-php/cli": "0.15.*",
"utopia-php/framework": "0.31.*"
"utopia-php/framework": "0.*.*"
},
"require-dev": {
"laravel/pint": "1.2.*",
@ -2519,9 +2523,9 @@
],
"support": {
"issues": "https://github.com/utopia-php/platform/issues",
"source": "https://github.com/utopia-php/platform/tree/0.5.0"
"source": "https://github.com/utopia-php/platform/tree/0.5.1"
},
"time": "2023-10-16T20:28:49+00:00"
"time": "2023-12-26T16:14:41+00:00"
},
{
"name": "utopia-php/pools",
@ -2742,16 +2746,16 @@
},
{
"name": "utopia-php/storage",
"version": "0.18.1",
"version": "0.18.3",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/storage.git",
"reference": "983e6dee137012f9f57f126d3c79aab54e4e8824"
"reference": "faa0279519ac14f3501e8b138e0865ad9d12bff6"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/storage/zipball/983e6dee137012f9f57f126d3c79aab54e4e8824",
"reference": "983e6dee137012f9f57f126d3c79aab54e4e8824",
"url": "https://api.github.com/repos/utopia-php/storage/zipball/faa0279519ac14f3501e8b138e0865ad9d12bff6",
"reference": "faa0279519ac14f3501e8b138e0865ad9d12bff6",
"shasum": ""
},
"require": {
@ -2791,9 +2795,9 @@
],
"support": {
"issues": "https://github.com/utopia-php/storage/issues",
"source": "https://github.com/utopia-php/storage/tree/0.18.1"
"source": "https://github.com/utopia-php/storage/tree/0.18.3"
},
"time": "2023-10-24T14:44:19+00:00"
"time": "2023-12-31T11:45:12+00:00"
},
{
"name": "utopia-php/swoole",
@ -2904,23 +2908,23 @@
},
{
"name": "utopia-php/vcs",
"version": "0.6.2",
"version": "0.6.4",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/vcs.git",
"reference": "f135291b87cb45335fc6608722e7f89894bc33ee"
"reference": "b2595a50a4897a8c88319240810055b7a96efd6d"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/vcs/zipball/f135291b87cb45335fc6608722e7f89894bc33ee",
"reference": "f135291b87cb45335fc6608722e7f89894bc33ee",
"url": "https://api.github.com/repos/utopia-php/vcs/zipball/b2595a50a4897a8c88319240810055b7a96efd6d",
"reference": "b2595a50a4897a8c88319240810055b7a96efd6d",
"shasum": ""
},
"require": {
"adhocore/jwt": "^1.1",
"php": ">=8.0",
"utopia-php/cache": "^0.8.0",
"utopia-php/framework": "0.31.*"
"utopia-php/framework": "0.*.*"
},
"require-dev": {
"laravel/pint": "1.2.*",
@ -2947,9 +2951,9 @@
],
"support": {
"issues": "https://github.com/utopia-php/vcs/issues",
"source": "https://github.com/utopia-php/vcs/tree/0.6.2"
"source": "https://github.com/utopia-php/vcs/tree/0.6.4"
},
"time": "2023-11-08T15:36:03+00:00"
"time": "2023-12-26T15:38:19+00:00"
},
{
"name": "utopia-php/websocket",
@ -3487,25 +3491,27 @@
},
{
"name": "nikic/php-parser",
"version": "v4.17.1",
"version": "v5.0.0",
"source": {
"type": "git",
"url": "https://github.com/nikic/PHP-Parser.git",
"reference": "a6303e50c90c355c7eeee2c4a8b27fe8dc8fef1d"
"reference": "4a21235f7e56e713259a6f76bf4b5ea08502b9dc"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/a6303e50c90c355c7eeee2c4a8b27fe8dc8fef1d",
"reference": "a6303e50c90c355c7eeee2c4a8b27fe8dc8fef1d",
"url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/4a21235f7e56e713259a6f76bf4b5ea08502b9dc",
"reference": "4a21235f7e56e713259a6f76bf4b5ea08502b9dc",
"shasum": ""
},
"require": {
"ext-ctype": "*",
"ext-json": "*",
"ext-tokenizer": "*",
"php": ">=7.0"
"php": ">=7.4"
},
"require-dev": {
"ircmaxell/php-yacc": "^0.0.7",
"phpunit/phpunit": "^6.5 || ^7.0 || ^8.0 || ^9.0"
"phpunit/phpunit": "^7.0 || ^8.0 || ^9.0"
},
"bin": [
"bin/php-parse"
@ -3513,7 +3519,7 @@
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "4.9-dev"
"dev-master": "5.0-dev"
}
},
"autoload": {
@ -3537,9 +3543,9 @@
],
"support": {
"issues": "https://github.com/nikic/PHP-Parser/issues",
"source": "https://github.com/nikic/PHP-Parser/tree/v4.17.1"
"source": "https://github.com/nikic/PHP-Parser/tree/v5.0.0"
},
"time": "2023-08-13T19:53:39+00:00"
"time": "2024-01-07T17:17:35+00:00"
},
{
"name": "phar-io/manifest",
@ -3891,16 +3897,16 @@
},
{
"name": "phpstan/phpdoc-parser",
"version": "1.24.4",
"version": "1.25.0",
"source": {
"type": "git",
"url": "https://github.com/phpstan/phpdoc-parser.git",
"reference": "6bd0c26f3786cd9b7c359675cb789e35a8e07496"
"reference": "bd84b629c8de41aa2ae82c067c955e06f1b00240"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/6bd0c26f3786cd9b7c359675cb789e35a8e07496",
"reference": "6bd0c26f3786cd9b7c359675cb789e35a8e07496",
"url": "https://api.github.com/repos/phpstan/phpdoc-parser/zipball/bd84b629c8de41aa2ae82c067c955e06f1b00240",
"reference": "bd84b629c8de41aa2ae82c067c955e06f1b00240",
"shasum": ""
},
"require": {
@ -3932,29 +3938,29 @@
"description": "PHPDoc parser with support for nullable, intersection and generic types",
"support": {
"issues": "https://github.com/phpstan/phpdoc-parser/issues",
"source": "https://github.com/phpstan/phpdoc-parser/tree/1.24.4"
"source": "https://github.com/phpstan/phpdoc-parser/tree/1.25.0"
},
"time": "2023-11-26T18:29:22+00:00"
"time": "2024-01-04T17:06:16+00:00"
},
{
"name": "phpunit/php-code-coverage",
"version": "9.2.29",
"version": "9.2.30",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/php-code-coverage.git",
"reference": "6a3a87ac2bbe33b25042753df8195ba4aa534c76"
"reference": "ca2bd87d2f9215904682a9cb9bb37dda98e76089"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/6a3a87ac2bbe33b25042753df8195ba4aa534c76",
"reference": "6a3a87ac2bbe33b25042753df8195ba4aa534c76",
"url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/ca2bd87d2f9215904682a9cb9bb37dda98e76089",
"reference": "ca2bd87d2f9215904682a9cb9bb37dda98e76089",
"shasum": ""
},
"require": {
"ext-dom": "*",
"ext-libxml": "*",
"ext-xmlwriter": "*",
"nikic/php-parser": "^4.15",
"nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3",
"phpunit/php-file-iterator": "^3.0.3",
"phpunit/php-text-template": "^2.0.2",
@ -4004,7 +4010,7 @@
"support": {
"issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
"security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy",
"source": "https://github.com/sebastianbergmann/php-code-coverage/tree/9.2.29"
"source": "https://github.com/sebastianbergmann/php-code-coverage/tree/9.2.30"
},
"funding": [
{
@ -4012,7 +4018,7 @@
"type": "github"
}
],
"time": "2023-09-19T04:57:46+00:00"
"time": "2023-12-22T06:47:57+00:00"
},
{
"name": "phpunit/php-file-iterator",
@ -4651,20 +4657,20 @@
},
{
"name": "sebastian/complexity",
"version": "2.0.2",
"version": "2.0.3",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/complexity.git",
"reference": "739b35e53379900cc9ac327b2147867b8b6efd88"
"reference": "25f207c40d62b8b7aa32f5ab026c53561964053a"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/739b35e53379900cc9ac327b2147867b8b6efd88",
"reference": "739b35e53379900cc9ac327b2147867b8b6efd88",
"url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/25f207c40d62b8b7aa32f5ab026c53561964053a",
"reference": "25f207c40d62b8b7aa32f5ab026c53561964053a",
"shasum": ""
},
"require": {
"nikic/php-parser": "^4.7",
"nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3"
},
"require-dev": {
@ -4696,7 +4702,7 @@
"homepage": "https://github.com/sebastianbergmann/complexity",
"support": {
"issues": "https://github.com/sebastianbergmann/complexity/issues",
"source": "https://github.com/sebastianbergmann/complexity/tree/2.0.2"
"source": "https://github.com/sebastianbergmann/complexity/tree/2.0.3"
},
"funding": [
{
@ -4704,7 +4710,7 @@
"type": "github"
}
],
"time": "2020-10-26T15:52:27+00:00"
"time": "2023-12-22T06:19:30+00:00"
},
{
"name": "sebastian/diff",
@ -4978,20 +4984,20 @@
},
{
"name": "sebastian/lines-of-code",
"version": "1.0.3",
"version": "1.0.4",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/lines-of-code.git",
"reference": "c1c2e997aa3146983ed888ad08b15470a2e22ecc"
"reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/c1c2e997aa3146983ed888ad08b15470a2e22ecc",
"reference": "c1c2e997aa3146983ed888ad08b15470a2e22ecc",
"url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/e1e4a170560925c26d424b6a03aed157e7dcc5c5",
"reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5",
"shasum": ""
},
"require": {
"nikic/php-parser": "^4.6",
"nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3"
},
"require-dev": {
@ -5023,7 +5029,7 @@
"homepage": "https://github.com/sebastianbergmann/lines-of-code",
"support": {
"issues": "https://github.com/sebastianbergmann/lines-of-code/issues",
"source": "https://github.com/sebastianbergmann/lines-of-code/tree/1.0.3"
"source": "https://github.com/sebastianbergmann/lines-of-code/tree/1.0.4"
},
"funding": [
{
@ -5031,7 +5037,7 @@
"type": "github"
}
],
"time": "2020-11-28T06:42:11+00:00"
"time": "2023-12-22T06:20:34+00:00"
},
{
"name": "sebastian/object-enumerator",
@ -5819,6 +5825,45 @@
}
],
"time": "2023-11-21T18:54:41+00:00"
},
{
"name": "utopia-php/fetch",
"version": "0.1.0",
"source": {
"type": "git",
"url": "https://github.com/utopia-php/fetch.git",
"reference": "2fa214b9262acd1a3583515a364da4f35929d5c5"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/utopia-php/fetch/zipball/2fa214b9262acd1a3583515a364da4f35929d5c5",
"reference": "2fa214b9262acd1a3583515a364da4f35929d5c5",
"shasum": ""
},
"require": {
"php": ">=8.0"
},
"require-dev": {
"laravel/pint": "^1.5.0",
"phpstan/phpstan": "^1.10",
"phpunit/phpunit": "^9.5"
},
"type": "library",
"autoload": {
"psr-4": {
"Utopia\\Fetch\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"description": "A simple library that provides an interface for making HTTP Requests.",
"support": {
"issues": "https://github.com/utopia-php/fetch/issues",
"source": "https://github.com/utopia-php/fetch/tree/0.1.0"
},
"time": "2023-10-10T11:58:32+00:00"
}
],
"aliases": [],
@ -5847,5 +5892,5 @@
"platform-overrides": {
"php": "8.0"
},
"plugin-api-version": "2.3.0"
"plugin-api-version": "2.6.0"
}

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"
@ -305,7 +306,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-uploads:/storage/uploads:rw
- appwrite-cache:/storage/cache:rw
- appwrite-functions:/storage/functions:rw
@ -359,7 +360,7 @@ services:
image: appwrite-dev
networks:
- appwrite
volumes:
volumes:
- ./app:/usr/src/code/app
- ./src:/usr/src/code/src
depends_on:
@ -458,7 +459,7 @@ services:
depends_on:
- redis
- mariadb
volumes:
volumes:
- appwrite-config:/storage/config:rw
- appwrite-certificates:/storage/certificates:rw
- ./app:/usr/src/code/app
@ -719,7 +720,7 @@ services:
appwrite-assistant:
container_name: appwrite-assistant
image: appwrite/assistant:0.2.2
image: appwrite/assistant:0.3.0
networks:
- appwrite
environment:
@ -752,7 +753,7 @@ services:
- _APP_REDIS_USER
- _APP_REDIS_PASS
- _APP_MIXPANEL_TOKEN
appwrite-hamster-scheduler:
entrypoint: hamster
<<: *x-logging
@ -1003,7 +1004,7 @@ services:
# - './debug:/tmp'
# ports:
# - '3001:80'
graphql-explorer:
container_name: appwrite-graphql-explorer
image: appwrite/altair:0.3.0

View file

@ -67,7 +67,7 @@ class Auth
public const TOKEN_EXPIRATION_LOGIN_LONG = 31536000; /* 1 year */
public const TOKEN_EXPIRATION_LOGIN_SHORT = 3600; /* 1 hour */
public const TOKEN_EXPIRATION_RECOVERY = 3600; /* 1 hour */
public const TOKEN_EXPIRATION_CONFIRM = 3600 * 24 * 7; /* 7 days */
public const TOKEN_EXPIRATION_CONFIRM = 3600 * 1; /* 1 hour */
public const TOKEN_EXPIRATION_PHONE = 60 * 15; /* 15 minutes */
/**

View file

@ -0,0 +1,163 @@
<?php
namespace Appwrite\Auth\OAuth2;
use Appwrite\Auth\OAuth2;
// Reference Material
// https://zoho.com/accounts/protocol/oauth.html
class Zoho extends OAuth2
{
/**
* @var string
*/
private string $endpoint = 'https://accounts.zoho.com';
/**
* @var array
*/
protected array $scopes = [
'email',
'profile',
];
/**
* @var array
*/
protected array $user = [];
/**
* @var array
*/
protected array $tokens = [];
/**
* @return string
*/
public function getName(): string
{
return 'zoho';
}
/**
* @return string
*/
public function getLoginURL(): string
{
$url = $this->endpoint . '/oauth/v2/auth?' .
\http_build_query([
'response_type' => 'code',
'client_id' => $this->appID,
'state' => \json_encode($this->state),
'redirect_uri' => $this->callback,
'scope' => \implode(' ', $this->getScopes())
]);
return $url;
}
/**
* @param string $code
*
* @return array
*/
protected function getTokens(string $code): array
{
if (empty($this->tokens)) {
$this->tokens = \json_decode($this->request(
'POST',
$this->endpoint . '/oauth/v2/token',
["Content-Type: application/x-www-form-urlencoded"],
\http_build_query([
'grant_type' => 'authorization_code',
"client_id" => $this->appID,
"client_secret" => $this->appSecret,
"redirect_uri" => $this->callback,
'code' => $code,
'scope' => \implode(' ', $this->getScopes()),
])
), true);
$this->user = (isset($this->tokens['id_token'])) ? \explode('.', $this->tokens['id_token']) : [0 => '', 1 => ''];
$this->user = (isset($this->user[1])) ? \json_decode(\base64_decode($this->user[1]), true) : [];
}
return $this->tokens;
}
/**
* @param string $refreshToken
*
* @return array
*/
public function refreshTokens(string $refreshToken): array
{
$this->tokens = \json_decode($this->request(
'POST',
$this->endpoint . '/oauth/v2/token',
['Content-Type: application/x-www-form-urlencoded'],
\http_build_query([
'grant_type' => 'refresh_token',
'refresh_token' => $refreshToken,
'client_id' => $this->appID,
'client_secret' => $this->appSecret,
])
), true);
if (empty($this->tokens['refresh_token'])) {
$this->tokens['refresh_token'] = $refreshToken;
}
$this->user = (isset($this->tokens['id_token'])) ? \explode('.', $this->tokens['id_token']) : [0 => '', 1 => ''];
$this->user = (isset($this->user[1])) ? \json_decode(\base64_decode($this->user[1]), true) : [];
return $this->tokens;
}
/**
* @param string $accessToken
*
* @return string
*/
public function getUserID(string $accessToken): string
{
return $this->user['sub'] ?? '';
}
/**
* @param string $accessToken
*
* @return string
*/
public function getUserEmail(string $accessToken): string
{
return $this->user['email'] ?? '';
}
/**
* @param string $accessToken
*
* @return bool
*/
public function isEmailVerified(string $accessToken): bool
{
if ($this->user['email_verified'] ?? false) {
return true;
}
return false;
}
/**
* @param string $accessToken
*
* @return string
*/
public function getUserName(string $accessToken): string
{
return $this->user['name'] ?? '';
}
}

View file

@ -20,7 +20,7 @@ class Password extends Validator
*/
public function getDescription(): string
{
return 'Password must be at least 8 characters';
return 'Password must be between 8 and 256 characters long.';
}
/**
@ -40,6 +40,10 @@ class Password extends Validator
return false;
}
if (\strlen($value) > 256) {
return false;
}
return true;
}

View file

@ -27,7 +27,7 @@ class PasswordDictionary extends Password
*/
public function getDescription(): string
{
return 'Password must be at least 8 characters and should not be one of the commonly used password.';
return 'Password must be between 8 and 265 characters long, and should not be one of the commonly used password.';
}
/**

View file

@ -0,0 +1,27 @@
<?php
namespace Appwrite\Enum;
enum MessageStatus: string
{
/**
* Message that is not ready to be sent
*/
case Draft = 'draft';
/**
* Scheduled to be sent for a later time
*/
case Scheduled = 'scheduled';
/**
* Picked up by the worker and starting to send
*/
case Processing = 'processing';
/**
* Sent without errors
*/
case Sent = 'sent';
/**
* Sent with some errors
*/
case Failed = 'failed';
}

View file

@ -19,6 +19,7 @@ use Appwrite\Platform\Tasks\VolumeSync;
use Appwrite\Platform\Tasks\CalcTierStats;
use Appwrite\Platform\Tasks\Upgrade;
use Appwrite\Platform\Tasks\DeleteOrphanedProjects;
use Appwrite\Platform\Tasks\DevGenerateTranslations;
use Appwrite\Platform\Tasks\GetMigrationStats;
use Appwrite\Platform\Tasks\PatchRecreateRepositoriesDocuments;
@ -46,6 +47,7 @@ class Tasks extends Service
->addAction(DeleteOrphanedProjects::getName(), new DeleteOrphanedProjects())
->addAction(PatchRecreateRepositoriesDocuments::getName(), new PatchRecreateRepositoriesDocuments())
->addAction(GetMigrationStats::getName(), new GetMigrationStats())
->addAction(DevGenerateTranslations::getName(), new DevGenerateTranslations())
;
}

View file

@ -0,0 +1,103 @@
<?php
namespace Appwrite\Platform\Tasks;
use Exception;
use Utopia\CLI\Console;
use Utopia\Fetch\Client;
use Utopia\Platform\Action;
use Utopia\Validator\Boolean;
use Utopia\Validator\Text;
class DevGenerateTranslations extends Action
{
private string $apiKey = '';
public static function getName(): string
{
return 'dev-generate-translations';
}
public function __construct()
{
$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('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));
}
public function action(bool|string $dryRun, string $apiKey): void
{
$dryRun = \strval($dryRun) === 'true';
Console::info("Started");
if (!$dryRun && empty($apiKey)) {
Console::error("Please specify --api-key='OPEN_AI_API_KEY' or run with --dry-run");
return;
}
$this->apiKey = $apiKey;
$dir = __DIR__ . '/../../../../app/config/locale/translations';
$mainFile = 'en.json';
$mainJson = \json_decode(\file_get_contents($dir . '/' . $mainFile), true);
$mainKeys = \array_keys($mainJson);
$files = array_diff(scandir($dir), array('.', '..', $mainFile));
foreach ($files as $file) {
$fileJson = \json_decode(\file_get_contents($dir . '/' . $file), true);
$fileKeys = \array_keys($fileJson);
foreach ($mainKeys as $key) {
if (!(\in_array($key, $fileKeys))) {
if ($dryRun) {
Console::warning("{$file} missing translation for {$key}");
} else {
$language = \explode('.', $file)[0];
$translation = $this->generateTranslation($language, $mainJson[$key]);
$json = \json_decode(\file_get_contents($dir . '/' . $file), true);
$json[$key] = $translation;
\file_put_contents($dir . '/' . $file, \json_encode($json, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES | 0));
Console::success("Generated {$key} for {$language}");
}
}
}
}
Console::info("Done");
}
private function generateTranslation(string $targetLanguage, string $enTranslation): string
{
$response = Client::fetch('https://api.openai.com/v1/chat/completions', [
'content-type' => Client::CONTENT_TYPE_APPLICATION_JSON,
'Authorization' => 'Bearer ' . $this->apiKey
], Client::METHOD_POST, [
'model' => 'gpt-4-1106-preview', // https://platform.openai.com/docs/models/gpt-4-and-gpt-4-turbo
'messages' => [
[
'role' => 'system',
'content' => "Please translate the message user provides from English language to target language. Target language is language of country with country code {$targetLanguage}. Do not translate text inside {{ and }} placeholders. Provide only translated text."
],
[
'role' => 'user',
'content' => $enTranslation
]
]
], [], 60);
$body = \json_decode($response->getBody(), true);
if ($response->getStatusCode() >= 400) {
throw new Exception($response->getBody() . ' with status code ' . $response->getStatusCode() . ' for language ' . $targetLanguage . ' and message ' . $enTranslation);
}
return $body['choices'][0]['message']['content'];
}
}

Some files were not shown because too many files have changed in this diff Show more