Merge branch 'master' into notification_component
This commit is contained in:
		
						commit
						ad6fcc2f2e
					
				
					 28 changed files with 586 additions and 105 deletions
				
			
		|  | @ -2,6 +2,8 @@ | ||||||
| /dist | /dist | ||||||
| /node_modules | /node_modules | ||||||
| /data | /data | ||||||
|  | /test | ||||||
|  | /kubernetes | ||||||
| /.do | /.do | ||||||
| **/.dockerignore | **/.dockerignore | ||||||
| **/.git | **/.git | ||||||
|  |  | ||||||
							
								
								
									
										26
									
								
								dockerfile
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								dockerfile
									
									
									
									
									
								
							|  | @ -5,25 +5,26 @@ WORKDIR /app | ||||||
| # split the sqlite install here, so that it can caches the arm prebuilt | # split the sqlite install here, so that it can caches the arm prebuilt | ||||||
| # do not modify it, since we don't want to re-compile the arm prebuilt again | # do not modify it, since we don't want to re-compile the arm prebuilt again | ||||||
| RUN apt update && \ | RUN apt update && \ | ||||||
|             apt --yes install python3 python3-pip python3-dev git g++ make && \ |     apt --yes install python3 python3-pip python3-dev git g++ make && \ | ||||||
|             ln -s /usr/bin/python3 /usr/bin/python && \ |     ln -s /usr/bin/python3 /usr/bin/python && \ | ||||||
|             npm install mapbox/node-sqlite3#593c9d --build-from-source |     npm install mapbox/node-sqlite3#593c9d --build-from-source | ||||||
| 
 | 
 | ||||||
| COPY . . | COPY . . | ||||||
| RUN npm install --legacy-peer-deps && npm run build && npm prune --production | RUN npm install --legacy-peer-deps && \ | ||||||
|  |     npm run build && \ | ||||||
|  |     npm prune --production && \ | ||||||
|  |     chmod +x /app/extra/entrypoint.sh | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| FROM node:14-bullseye-slim AS release | FROM node:14-bullseye-slim AS release | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| 
 | 
 | ||||||
| # Install Apprise, | # Install Apprise, add sqlite3 cli for debugging in the future, iputils-ping for ping, util-linux for setpriv | ||||||
| # add sqlite3 cli for debugging in the future |  | ||||||
| # iputils-ping for ping |  | ||||||
| RUN apt update && \ | RUN apt update && \ | ||||||
|             apt --yes install python3 python3-pip python3-cryptography python3-six python3-yaml python3-click python3-markdown python3-requests python3-requests-oauthlib \ |     apt --yes install python3 python3-pip python3-cryptography python3-six python3-yaml python3-click python3-markdown python3-requests python3-requests-oauthlib \ | ||||||
|                 sqlite3 \ |         sqlite3 iputils-ping util-linux && \ | ||||||
|                 iputils-ping && \ |     pip3 --no-cache-dir install apprise && \ | ||||||
|             pip3 --no-cache-dir install apprise && \ |     rm -rf /var/lib/apt/lists/* | ||||||
|             rm -rf /var/lib/apt/lists/* |  | ||||||
| 
 | 
 | ||||||
| # Copy app files from build layer | # Copy app files from build layer | ||||||
| COPY --from=build /app /app | COPY --from=build /app /app | ||||||
|  | @ -31,6 +32,7 @@ COPY --from=build /app /app | ||||||
| EXPOSE 3001 | EXPOSE 3001 | ||||||
| VOLUME ["/app/data"] | VOLUME ["/app/data"] | ||||||
| HEALTHCHECK --interval=60s --timeout=30s --start-period=180s --retries=5 CMD node extra/healthcheck.js | HEALTHCHECK --interval=60s --timeout=30s --start-period=180s --retries=5 CMD node extra/healthcheck.js | ||||||
|  | ENTRYPOINT ["extra/entrypoint.sh"] | ||||||
| CMD ["node", "server/server.js"] | CMD ["node", "server/server.js"] | ||||||
| 
 | 
 | ||||||
| FROM release AS nightly | FROM release AS nightly | ||||||
|  |  | ||||||
|  | @ -4,22 +4,25 @@ WORKDIR /app | ||||||
| 
 | 
 | ||||||
| # split the sqlite install here, so that it can caches the arm prebuilt | # split the sqlite install here, so that it can caches the arm prebuilt | ||||||
| RUN apk add --no-cache --virtual .build-deps make g++ python3 python3-dev git && \ | RUN apk add --no-cache --virtual .build-deps make g++ python3 python3-dev git && \ | ||||||
|             ln -s /usr/bin/python3 /usr/bin/python && \ |     ln -s /usr/bin/python3 /usr/bin/python && \ | ||||||
|             npm install mapbox/node-sqlite3#593c9d && \ |     npm install mapbox/node-sqlite3#593c9d && \ | ||||||
|             apk del .build-deps && \ |     apk del .build-deps && \ | ||||||
|             rm -f /usr/bin/python |     rm -f /usr/bin/python | ||||||
| 
 | 
 | ||||||
| COPY . . | COPY . . | ||||||
| RUN npm install --legacy-peer-deps && npm run build && npm prune --production | RUN npm install --legacy-peer-deps && \ | ||||||
|  |     npm run build && \ | ||||||
|  |     npm prune --production && \ | ||||||
|  |     chmod +x /app/extra/entrypoint.sh | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| FROM node:14-alpine3.12 AS release | FROM node:14-alpine3.12 AS release | ||||||
| WORKDIR /app | WORKDIR /app | ||||||
| 
 | 
 | ||||||
| # Install apprise | # Install apprise, iputils for non-root ping, setpriv | ||||||
| RUN apk add --no-cache python3 py3-cryptography py3-pip py3-six py3-yaml py3-click py3-markdown py3-requests py3-requests-oauthlib && \ | RUN apk add --no-cache iputils setpriv python3 py3-cryptography py3-pip py3-six py3-yaml py3-click py3-markdown py3-requests py3-requests-oauthlib && \ | ||||||
|             pip3 --no-cache-dir install apprise && \ |     pip3 --no-cache-dir install apprise && \ | ||||||
|             rm -rf /root/.cache |     rm -rf /root/.cache | ||||||
| 
 | 
 | ||||||
| # Copy app files from build layer | # Copy app files from build layer | ||||||
| COPY --from=build /app /app | COPY --from=build /app /app | ||||||
|  | @ -27,6 +30,7 @@ COPY --from=build /app /app | ||||||
| EXPOSE 3001 | EXPOSE 3001 | ||||||
| VOLUME ["/app/data"] | VOLUME ["/app/data"] | ||||||
| HEALTHCHECK --interval=60s --timeout=30s --start-period=180s --retries=5 CMD node extra/healthcheck.js | HEALTHCHECK --interval=60s --timeout=30s --start-period=180s --retries=5 CMD node extra/healthcheck.js | ||||||
|  | ENTRYPOINT ["extra/entrypoint.sh"] | ||||||
| CMD ["node", "server/server.js"] | CMD ["node", "server/server.js"] | ||||||
| 
 | 
 | ||||||
| FROM release AS nightly | FROM release AS nightly | ||||||
|  |  | ||||||
							
								
								
									
										21
									
								
								extra/entrypoint.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								extra/entrypoint.sh
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,21 @@ | ||||||
|  | #!/usr/bin/env sh | ||||||
|  | 
 | ||||||
|  | # set -e Exit the script if an error happens | ||||||
|  | set -e | ||||||
|  | PUID=${PUID=1000} | ||||||
|  | PGID=${PGID=1000} | ||||||
|  | 
 | ||||||
|  | files_ownership () { | ||||||
|  |     # -h Changes the ownership of an encountered symbolic link and not that of the file or directory pointed to by the symbolic link. | ||||||
|  |     # -R Recursively descends the specified directories | ||||||
|  |     # -c Like verbose but report only when a change is made | ||||||
|  |     chown -hRc "$PUID":"$PGID" /app/data | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | echo "==> Performing startup jobs and maintenance tasks" | ||||||
|  | files_ownership | ||||||
|  | 
 | ||||||
|  | echo "==> Starting application with user $PUID group $PGID" | ||||||
|  | 
 | ||||||
|  | # --clear-groups Clear supplementary groups. | ||||||
|  | exec setpriv --reuid "$PUID" --regid "$PGID" --clear-groups "$@" | ||||||
|  | @ -34,6 +34,7 @@ | ||||||
|         "test-install-script-alpine3": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/alpine3.dockerfile .", |         "test-install-script-alpine3": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/alpine3.dockerfile .", | ||||||
|         "test-install-script-ubuntu": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/ubuntu.dockerfile .", |         "test-install-script-ubuntu": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/ubuntu.dockerfile .", | ||||||
|         "test-install-script-ubuntu1604": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/ubuntu1604.dockerfile .", |         "test-install-script-ubuntu1604": "npm run compile-install-script && docker build --progress plain -f test/test_install_script/ubuntu1604.dockerfile .", | ||||||
|  |         "test-nodejs16": "docker build --progress plain -f test/ubuntu-nodejs16.dockerfile .", | ||||||
|         "simple-dns-server": "node extra/simple-dns-server.js", |         "simple-dns-server": "node extra/simple-dns-server.js", | ||||||
|         "update-language-files_old": "cd extra/update-language-files && node index.js %npm_config_base_lang% && eslint ../../src/languages/**.js --fix", |         "update-language-files_old": "cd extra/update-language-files && node index.js %npm_config_base_lang% && eslint ../../src/languages/**.js --fix", | ||||||
|         "update-language-files": "cd extra/update-language-files && node index.js && eslint ../../src/languages/**.js --fix" |         "update-language-files": "cd extra/update-language-files && node index.js && eslint ../../src/languages/**.js --fix" | ||||||
|  |  | ||||||
|  | @ -55,7 +55,7 @@ | ||||||
|                             <div class="w-50 pe-2"> |                             <div class="w-50 pe-2"> | ||||||
|                                 <input v-model="newDraftTag.name" class="form-control" |                                 <input v-model="newDraftTag.name" class="form-control" | ||||||
|                                        :class="{'is-invalid': validateDraftTag.nameInvalid}" |                                        :class="{'is-invalid': validateDraftTag.nameInvalid}" | ||||||
|                                        :placeholder="$t('name')" |                                        :placeholder="$t('Name')" | ||||||
|                                        @keydown.enter.prevent="onEnter" |                                        @keydown.enter.prevent="onEnter" | ||||||
|                                 /> |                                 /> | ||||||
|                                 <div class="invalid-feedback"> |                                 <div class="invalid-feedback"> | ||||||
|  |  | ||||||
|  | @ -36,7 +36,6 @@ export default { | ||||||
|     hour: "Timer", |     hour: "Timer", | ||||||
|     "-hour": "-Timer", |     "-hour": "-Timer", | ||||||
|     checkEverySecond: "Tjek hvert {0} sekund", |     checkEverySecond: "Tjek hvert {0} sekund", | ||||||
|     "Avg.": "Gns.", |  | ||||||
|     Response: "Respons", |     Response: "Respons", | ||||||
|     Ping: "Ping", |     Ping: "Ping", | ||||||
|     "Monitor Type": "Overvåger Type", |     "Monitor Type": "Overvåger Type", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -36,7 +36,6 @@ export default { | ||||||
|     hour: "Stunde", |     hour: "Stunde", | ||||||
|     "-hour": "-Stunden", |     "-hour": "-Stunden", | ||||||
|     checkEverySecond: "Überprüfe alle {0} Sekunden", |     checkEverySecond: "Überprüfe alle {0} Sekunden", | ||||||
|     "Avg.": "Durchschn.", |  | ||||||
|     Response: "Antwortzeit", |     Response: "Antwortzeit", | ||||||
|     Ping: "Ping", |     Ping: "Ping", | ||||||
|     "Monitor Type": "Monitor Typ", |     "Monitor Type": "Monitor Typ", | ||||||
|  | @ -167,4 +166,6 @@ export default { | ||||||
|     retryCheckEverySecond: "Versuche alle {0} Sekunden", |     retryCheckEverySecond: "Versuche alle {0} Sekunden", | ||||||
|     "Import Backup": "Import Backup", |     "Import Backup": "Import Backup", | ||||||
|     "Export Backup": "Export Backup", |     "Export Backup": "Export Backup", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,7 +2,6 @@ export default { | ||||||
|     languageName: "English", |     languageName: "English", | ||||||
|     checkEverySecond: "Check every {0} seconds.", |     checkEverySecond: "Check every {0} seconds.", | ||||||
|     retryCheckEverySecond: "Retry every {0} seconds.", |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|     "Avg.": "Avg.", |  | ||||||
|     retriesDescription: "Maximum retries before the service is marked as down and a notification is sent", |     retriesDescription: "Maximum retries before the service is marked as down and a notification is sent", | ||||||
|     ignoreTLSError: "Ignore TLS/SSL error for HTTPS websites", |     ignoreTLSError: "Ignore TLS/SSL error for HTTPS websites", | ||||||
|     upsideDownModeDescription: "Flip the status upside down. If the service is reachable, it is DOWN.", |     upsideDownModeDescription: "Flip the status upside down. If the service is reachable, it is DOWN.", | ||||||
|  | @ -167,6 +166,8 @@ export default { | ||||||
|     Purple: "Purple", |     Purple: "Purple", | ||||||
|     Pink: "Pink", |     Pink: "Pink", | ||||||
|     "Search...": "Search...", |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
|     "telegram": "Telegram", |     "telegram": "Telegram", | ||||||
|     "webhook": "Webhook", |     "webhook": "Webhook", | ||||||
|     "smtp": "Email (SMTP)", |     "smtp": "Email (SMTP)", | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Español", |     languageName: "Español", | ||||||
|     checkEverySecond: "Comprobar cada {0} segundos.", |     checkEverySecond: "Comprobar cada {0} segundos.", | ||||||
|     "Avg.": "Media.", |  | ||||||
|     retriesDescription: "Número máximo de intentos antes de que el servicio se marque como CAÍDO y una notificación sea enviada.", |     retriesDescription: "Número máximo de intentos antes de que el servicio se marque como CAÍDO y una notificación sea enviada.", | ||||||
|     ignoreTLSError: "Ignorar error TLS/SSL para sitios web HTTPS", |     ignoreTLSError: "Ignorar error TLS/SSL para sitios web HTTPS", | ||||||
|     upsideDownModeDescription: "Invertir el estado. Si el servicio es alcanzable, está CAÍDO.", |     upsideDownModeDescription: "Invertir el estado. Si el servicio es alcanzable, está CAÍDO.", | ||||||
|  | @ -32,7 +31,7 @@ export default { | ||||||
|     Up: "Funcional", |     Up: "Funcional", | ||||||
|     Down: "Caído", |     Down: "Caído", | ||||||
|     Pending: "Pendiente", |     Pending: "Pendiente", | ||||||
|     Unknown: "Desconociso", |     Unknown: "Desconocido", | ||||||
|     Pause: "Pausa", |     Pause: "Pausa", | ||||||
|     Name: "Nombre", |     Name: "Nombre", | ||||||
|     Status: "Estado", |     Status: "Estado", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "eesti", |     languageName: "eesti", | ||||||
|     checkEverySecond: "Kontrolli {0} sekundilise vahega.", |     checkEverySecond: "Kontrolli {0} sekundilise vahega.", | ||||||
|     "Avg.": "≈", |  | ||||||
|     retriesDescription: "Mitu korda tuleb kontrollida, mille järel märkida 'maas' ja saata välja teavitus.", |     retriesDescription: "Mitu korda tuleb kontrollida, mille järel märkida 'maas' ja saata välja teavitus.", | ||||||
|     ignoreTLSError: "Eira TLS/SSL viga HTTPS veebisaitidel.", |     ignoreTLSError: "Eira TLS/SSL viga HTTPS veebisaitidel.", | ||||||
|     upsideDownModeDescription: "Käitle teenuse saadavust rikkena, teenuse kättesaamatust töötavaks.", |     upsideDownModeDescription: "Käitle teenuse saadavust rikkena, teenuse kättesaamatust töötavaks.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -36,7 +36,6 @@ export default { | ||||||
|     hour: "Heure", |     hour: "Heure", | ||||||
|     "-hour": "Heures", |     "-hour": "Heures", | ||||||
|     checkEverySecond: "Vérifier toutes les {0} secondes", |     checkEverySecond: "Vérifier toutes les {0} secondes", | ||||||
|     "Avg.": "Moyen", |  | ||||||
|     Response: "Temps de réponse", |     Response: "Temps de réponse", | ||||||
|     Ping: "Ping", |     Ping: "Ping", | ||||||
|     "Monitor Type": "Type de Sonde", |     "Monitor Type": "Type de Sonde", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Italiano (Italian)", |     languageName: "Italiano (Italian)", | ||||||
|     checkEverySecond: "controlla ogni {0} secondi", |     checkEverySecond: "controlla ogni {0} secondi", | ||||||
|     "Avg.": "Media", |     retryCheckEverySecond: "Riprova ogni {0} secondi.", | ||||||
|     retriesDescription: "Tentativi da fare prima che il servizio venga marcato come \"giù\" e che una notifica venga inviata.", |     retriesDescription: "Tentativi da fare prima che il servizio venga marcato come \"giù\" e che una notifica venga inviata.", | ||||||
|     ignoreTLSError: "Ignora gli errori TLS/SSL per i siti in HTTPS.", |     ignoreTLSError: "Ignora gli errori TLS/SSL per i siti in HTTPS.", | ||||||
|     upsideDownModeDescription: "Capovolgi lo stato. Se il servizio è raggiungibile viene marcato come \"GIÙ\".", |     upsideDownModeDescription: "Capovolgi lo stato. Se il servizio è raggiungibile viene marcato come \"GIÙ\".", | ||||||
|  | @ -20,6 +20,8 @@ export default { | ||||||
|     clearEventsMsg: "Si è certi di voler eliminare tutti gli eventi per questo servizio?", |     clearEventsMsg: "Si è certi di voler eliminare tutti gli eventi per questo servizio?", | ||||||
|     clearHeartbeatsMsg: "Si è certi di voler eliminare tutti gli intervalli di controllo per questo servizio?", |     clearHeartbeatsMsg: "Si è certi di voler eliminare tutti gli intervalli di controllo per questo servizio?", | ||||||
|     confirmClearStatisticsMsg: "Si è certi di voler eliminare TUTTE le statistiche?", |     confirmClearStatisticsMsg: "Si è certi di voler eliminare TUTTE le statistiche?", | ||||||
|  |     importHandleDescription: "Selezionare 'Ignora gli esistenti' si vuole ignorare l'importazione dei monitoraggi o delle notifiche con lo stesso nome. 'Sovrascrivi' eliminerà ogni monitoraggio e notifica esistente.", | ||||||
|  |     confirmImportMsg: "Si è certi di voler importare il backup? Essere certi di aver selezionato l'opzione corretta di importazione.", | ||||||
|     twoFAVerifyLabel: "Scrivi il token per verificare che l'autenticazione a due fattori funzioni", |     twoFAVerifyLabel: "Scrivi il token per verificare che l'autenticazione a due fattori funzioni", | ||||||
|     tokenValidSettingsMsg: "Il token è valido! È ora possibile salvare le impostazioni.", |     tokenValidSettingsMsg: "Il token è valido! È ora possibile salvare le impostazioni.", | ||||||
|     confirmEnableTwoFAMsg: "Si è certi di voler abilitare l'autenticazione a due fattori?", |     confirmEnableTwoFAMsg: "Si è certi di voler abilitare l'autenticazione a due fattori?", | ||||||
|  | @ -68,6 +70,7 @@ export default { | ||||||
|     Port: "Porta", |     Port: "Porta", | ||||||
|     "Heartbeat Interval": "Intervallo di controllo", |     "Heartbeat Interval": "Intervallo di controllo", | ||||||
|     Retries: "Tentativi", |     Retries: "Tentativi", | ||||||
|  |     "Heartbeat Retry Interval": "Intervallo tra un tentativo di controllo e l'altro", | ||||||
|     Advanced: "Avanzate", |     Advanced: "Avanzate", | ||||||
|     "Upside Down Mode": "Modalità capovolta", |     "Upside Down Mode": "Modalità capovolta", | ||||||
|     "Max. Redirects": "Redirezionamenti massimi", |     "Max. Redirects": "Redirezionamenti massimi", | ||||||
|  | @ -115,6 +118,8 @@ export default { | ||||||
|     "Last Result": "Ultimo risultato", |     "Last Result": "Ultimo risultato", | ||||||
|     "Create your admin account": "Crea l'account amministratore", |     "Create your admin account": "Crea l'account amministratore", | ||||||
|     "Repeat Password": "Ripeti Password", |     "Repeat Password": "Ripeti Password", | ||||||
|  |     "Import Backup": "Importa Backup", | ||||||
|  |     "Export Backup": "Esporta Backup", | ||||||
|     Export: "Esporta", |     Export: "Esporta", | ||||||
|     Import: "Importa", |     Import: "Importa", | ||||||
|     respTime: "Tempo di Risposta (ms)", |     respTime: "Tempo di Risposta (ms)", | ||||||
|  | @ -126,12 +131,16 @@ export default { | ||||||
|     Events: "Eventi", |     Events: "Eventi", | ||||||
|     Heartbeats: "Controlli", |     Heartbeats: "Controlli", | ||||||
|     "Auto Get": "Auto Get", |     "Auto Get": "Auto Get", | ||||||
|     "Also apply to existing monitors": "Also apply to existing monitors", |  | ||||||
|     backupDescription: "È possibile fare il backup di tutti i monitoraggi e di tutte le notifiche in un file JSON.", |     backupDescription: "È possibile fare il backup di tutti i monitoraggi e di tutte le notifiche in un file JSON.", | ||||||
|     backupDescription2: "P.S.: lo storico e i dati relativi agli eventi non saranno inclusi.", |     backupDescription2: "P.S.: lo storico e i dati relativi agli eventi non saranno inclusi.", | ||||||
|     backupDescription3: "Dati sensibili come i token di autenticazione saranno inclusi nel backup, tenere quindi in un luogo sicuro.", |     backupDescription3: "Dati sensibili come i token di autenticazione saranno inclusi nel backup, tenere quindi in un luogo sicuro.", | ||||||
|     alertNoFile: "Selezionare il file da importare.", |     alertNoFile: "Selezionare il file da importare.", | ||||||
|     alertWrongFileType: "Selezionare un file JSON.", |     alertWrongFileType: "Selezionare un file JSON.", | ||||||
|  |     "Clear all statistics": "Pulisci tutte le statistiche", | ||||||
|  |     "Skip existing": "Ignora gli esistenti", | ||||||
|  |     Overwrite: "Sovrascrivi", | ||||||
|  |     Options: "Opzioni", | ||||||
|  |     "Keep both": "Mantieni entrambi", | ||||||
|     "Verify Token": "Verifica Token", |     "Verify Token": "Verifica Token", | ||||||
|     "Setup 2FA": "Imposta  l'autenticazione a due fattori", |     "Setup 2FA": "Imposta  l'autenticazione a due fattori", | ||||||
|     "Enable 2FA": "Abilita  l'autenticazione a due fattori", |     "Enable 2FA": "Abilita  l'autenticazione a due fattori", | ||||||
|  | @ -142,7 +151,6 @@ export default { | ||||||
|     Inactive: "Disattivata", |     Inactive: "Disattivata", | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Mostra URI", |     "Show URI": "Mostra URI", | ||||||
|     "Clear all statistics": "Pulisci tutte le statistiche", |  | ||||||
|     Tags: "Etichette", |     Tags: "Etichette", | ||||||
|     "Add New below or Select...": "Aggiungine una oppure scegli...", |     "Add New below or Select...": "Aggiungine una oppure scegli...", | ||||||
|     "Tag with this name already exist.": "Un'etichetta con questo nome già esiste.", |     "Tag with this name already exist.": "Un'etichetta con questo nome già esiste.", | ||||||
|  | @ -158,4 +166,6 @@ export default { | ||||||
|     Purple: "Viola", |     Purple: "Viola", | ||||||
|     Pink: "Rosa", |     Pink: "Rosa", | ||||||
|     "Search...": "Cerca...", |     "Search...": "Cerca...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "日本語", |     languageName: "日本語", | ||||||
|     checkEverySecond: "{0}秒ごとにチェックします。", |     checkEverySecond: "{0}秒ごとにチェックします。", | ||||||
|     "Avg.": "平均", |  | ||||||
|     retriesDescription: "サービスがダウンとしてマークされ、通知が送信されるまでの最大リトライ数", |     retriesDescription: "サービスがダウンとしてマークされ、通知が送信されるまでの最大リトライ数", | ||||||
|     ignoreTLSError: "HTTPS ウェブサイトの TLS/SSL エラーを無視する", |     ignoreTLSError: "HTTPS ウェブサイトの TLS/SSL エラーを無視する", | ||||||
|     upsideDownModeDescription: "ステータスの扱いを逆にします。サービスに到達可能な場合は、DOWNとなる。", |     upsideDownModeDescription: "ステータスの扱いを逆にします。サービスに到達可能な場合は、DOWNとなる。", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "한국어", |     languageName: "한국어", | ||||||
|     checkEverySecond: "{0} 초마다 체크해요.", |     checkEverySecond: "{0} 초마다 체크해요.", | ||||||
|     "Avg.": "평균", |  | ||||||
|     retriesDescription: "서비스가 중단된 후 알림을 보내기 전 최대 재시도 횟수", |     retriesDescription: "서비스가 중단된 후 알림을 보내기 전 최대 재시도 횟수", | ||||||
|     ignoreTLSError: "HTTPS 웹사이트에서 TLS/SSL 에러 무시하기", |     ignoreTLSError: "HTTPS 웹사이트에서 TLS/SSL 에러 무시하기", | ||||||
|     upsideDownModeDescription: "서버 상태를 반대로 표시해요. 서버가 작동하면 오프라인으로 표시할 거에요.", |     upsideDownModeDescription: "서버 상태를 반대로 표시해요. 서버가 작동하면 오프라인으로 표시할 거에요.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Nederlands", |     languageName: "Nederlands", | ||||||
|     checkEverySecond: "Controleer elke {0} seconden.", |     checkEverySecond: "Controleer elke {0} seconden.", | ||||||
|     "Avg.": "Gem.", |  | ||||||
|     retriesDescription: "Maximum aantal nieuwe pogingen voordat de service wordt gemarkeerd als niet beschikbaar en er een melding wordt verzonden", |     retriesDescription: "Maximum aantal nieuwe pogingen voordat de service wordt gemarkeerd als niet beschikbaar en er een melding wordt verzonden", | ||||||
|     ignoreTLSError: "Negeer TLS/SSL-fout voor HTTPS-websites", |     ignoreTLSError: "Negeer TLS/SSL-fout voor HTTPS-websites", | ||||||
|     upsideDownModeDescription: "Draai de status om. Als de service bereikbaar is, is deze OFFLINE.", |     upsideDownModeDescription: "Draai de status om. Als de service bereikbaar is, is deze OFFLINE.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Toon URI", |     "Show URI": "Toon URI", | ||||||
|     "Clear all statistics": "Wis alle statistieken", |     "Clear all statistics": "Wis alle statistieken", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Polski", |     languageName: "Polski", | ||||||
|     checkEverySecond: "Sprawdzaj co {0} sekund.", |     checkEverySecond: "Sprawdzaj co {0} sekund.", | ||||||
|     "Avg.": "Średnia", |  | ||||||
|     retriesDescription: "Maksymalna liczba powtórzeń, zanim usługa zostanie oznaczona jako wyłączona i zostanie wysłane powiadomienie", |     retriesDescription: "Maksymalna liczba powtórzeń, zanim usługa zostanie oznaczona jako wyłączona i zostanie wysłane powiadomienie", | ||||||
|     ignoreTLSError: "Ignoruj błąd TLS/SSL dla stron HTTPS", |     ignoreTLSError: "Ignoruj błąd TLS/SSL dla stron HTTPS", | ||||||
|     upsideDownModeDescription: "Odwróć status do góry nogami. Jeśli usługa jest osiągalna, to jest oznaczona jako niedostępna.", |     upsideDownModeDescription: "Odwróć status do góry nogami. Jeśli usługa jest osiągalna, to jest oznaczona jako niedostępna.", | ||||||
|  | @ -110,37 +109,64 @@ export default { | ||||||
|     respTime: "Czas odp. (ms)", |     respTime: "Czas odp. (ms)", | ||||||
|     notAvailableShort: "N/A", |     notAvailableShort: "N/A", | ||||||
|     Create: "Stwórz", |     Create: "Stwórz", | ||||||
|     clearEventsMsg: "Jesteś pewien, że chcesz usunąć wszystkie monity dla tej strony?", |     clearEventsMsg: "Jesteś pewien, że chcesz usunąć wszystkie monitory dla tej strony?", | ||||||
|     clearHeartbeatsMsg: "Are you sure want to delete all heartbeats for this monitor?", |     clearHeartbeatsMsg: "Jesteś pewien, że chcesz usunąć wszystkie bicia serca dla tego monitora?", | ||||||
|     confirmClearStatisticsMsg: "Jesteś pewien, że chcesz usunąć WSZYSTKIE statystyki?", |     confirmClearStatisticsMsg: "Jesteś pewien, że chcesz usunąć WSZYSTKIE statystyki?", | ||||||
|     "Clear Data": "Usuń dane", |     "Clear Data": "Usuń dane", | ||||||
|     Events: "Wydarzenia", |     Events: "Wydarzenia", | ||||||
|     Heartbeats: "Heartbeats", |     Heartbeats: "Bicia serca", | ||||||
|     "Auto Get": "Auto Get", |     "Auto Get": "Pobierz automatycznie", | ||||||
|     enableDefaultNotificationDescription: "Dla każdego nowego monitora to powiadomienie będzie domyślnie włączone. Nadal możesz wyłączyć powiadomienia osobno dla każdego monitora.", |     enableDefaultNotificationDescription: "Dla każdego nowego monitora to powiadomienie będzie domyślnie włączone. Nadal możesz wyłączyć powiadomienia osobno dla każdego monitora.", | ||||||
|     "Default enabled": "Domyślnie włączone", |     "Default enabled": "Domyślnie włączone", | ||||||
|     "Also apply to existing monitors": "Również zastosuj do obecnych monitów", |     "Also apply to existing monitors": "Również zastosuj do obecnych monitorów", | ||||||
|     Export: "Eksport", |     Export: "Eksportuj", | ||||||
|     Import: "Import", |     Import: "Importuj", | ||||||
|     backupDescription: "Możesz wykonać kopię zapasową wszystkich monitorów i wszystkich powiadomień w pliku JSON.", |     backupDescription: "Możesz wykonać kopię zapasową wszystkich monitorów i wszystkich powiadomień do pliku JSON.", | ||||||
|     backupDescription2: "PS: Historia i dane zdarzeń nie są uwzględniane.", |     backupDescription2: "PS: Historia i dane zdarzeń nie są uwzględniane.", | ||||||
|     backupDescription3: "Poufne dane, takie jak tokeny powiadomień, są zawarte w pliku eksportu, prosimy o ostrożne przechowywanie.", |     backupDescription3: "Poufne dane, takie jak tokeny powiadomień, są zawarte w pliku eksportu, prosimy o ostrożne przechowywanie.", | ||||||
|     alertNoFile: "Proszę wybrać plik do importu.", |     alertNoFile: "Proszę wybrać plik do importu.", | ||||||
|     alertWrongFileType: "Proszę wybrać plik JSON.", |     alertWrongFileType: "Proszę wybrać plik JSON.", | ||||||
|     twoFAVerifyLabel: "Proszę podaj swój token 2FA, aby sprawdzić go", |     twoFAVerifyLabel: "Proszę podaj swój token 2FA, aby sprawdzić czy 2FA działa", | ||||||
|     tokenValidSettingsMsg: "Token jest poprawny! Możesz teraz zapisać ustawienia 2FA.", |     tokenValidSettingsMsg: "Token jest poprawny! Możesz teraz zapisać ustawienia 2FA.", | ||||||
|     confirmEnableTwoFAMsg: "Jesteś prwien że chcesz włączyć 2FA?", |     confirmEnableTwoFAMsg: "Jesteś pewien że chcesz włączyć 2FA?", | ||||||
|     confirmDisableTwoFAMsg: "Jesteś prwien że chcesz wyłączyć 2FA?", |     confirmDisableTwoFAMsg: "Jesteś pewien że chcesz wyłączyć 2FA?", | ||||||
|     "Apply on all existing monitors": "Zastosuj do wszystki obecnych monitów", |     "Apply on all existing monitors": "Zastosuj do wszystki obecnych monitorów", | ||||||
|     "Verify Token": "Weryfikuj Token", |     "Verify Token": "Weryfikuj token", | ||||||
|     "Setup 2FA": "Ustaw 2FA", |     "Setup 2FA": "Konfiguracja 2FA", | ||||||
|     "Enable 2FA": "Włącz 2FA", |     "Enable 2FA": "Włącz 2FA", | ||||||
|     "Disable 2FA": "Wyłącz 2FA", |     "Disable 2FA": "Wyłącz 2FA", | ||||||
|     "2FA Settings": "Ustawienia 2FA", |     "2FA Settings": "Ustawienia 2FA", | ||||||
|     "Two Factor Authentication": "Podwójna weryfikacja", |     "Two Factor Authentication": "Uwierzytelnienie dwuskładnikowe", | ||||||
|     Active: "Włączone", |     Active: "Włączone", | ||||||
|     Inactive: "Wyłączone", |     Inactive: "Wyłączone", | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Pokaż URI", |     "Show URI": "Pokaż URI", | ||||||
|     "Clear all statistics": "Wyczyść wszystkie statystyki", |     "Clear all statistics": "Wyczyść wszystkie statystyki", | ||||||
|  |     retryCheckEverySecond: "Ponawiaj co {0} sekund.", | ||||||
|  |     importHandleDescription: "Wybierz 'Pomiń istniejące', jeśli chcesz pominąć każdy monitor lub powiadomienie o tej samej nazwie. 'Nadpisz' spowoduje usunięcie każdego istniejącego monitora i powiadomienia.", | ||||||
|  |     confirmImportMsg: "Czy na pewno chcesz zaimportować kopię zapasową? Upewnij się, że wybrałeś właściwą opcję importu.", | ||||||
|  |     "Heartbeat Retry Interval": "Częstotliwość ponawiania bicia serca", | ||||||
|  |     "Import Backup": "Importuj kopię zapasową", | ||||||
|  |     "Export Backup": "Eksportuj kopię zapasową", | ||||||
|  |     "Skip existing": "Pomiń istniejące", | ||||||
|  |     Overwrite: "Nadpisz", | ||||||
|  |     Options: "Opcje", | ||||||
|  |     "Keep both": "Zachowaj oba", | ||||||
|  |     Tags: "Tagi", | ||||||
|  |     "Add New below or Select...": "Dodaj nowy poniżej lub wybierz...", | ||||||
|  |     "Tag with this name already exist.": "Tag o tej nazwie już istnieje.", | ||||||
|  |     "Tag with this value already exist.": "Tag o tej wartości już istnieje.", | ||||||
|  |     color: "kolor", | ||||||
|  |     "value (optional)": "wartość (opcjonalnie)", | ||||||
|  |     Gray: "Szary", | ||||||
|  |     Red: "Czerwony", | ||||||
|  |     Orange: "Pomarańczowy", | ||||||
|  |     Green: "Zielony", | ||||||
|  |     Blue: "Niebieski", | ||||||
|  |     Indigo: "Indygo", | ||||||
|  |     Purple: "Fioletowy", | ||||||
|  |     Pink: "Różowy", | ||||||
|  |     "Search...": "Szukaj...", | ||||||
|  |     "Avg. Ping": "Średni ping", | ||||||
|  |     "Avg. Response": "Średnia odpowiedź", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Русский", |     languageName: "Русский", | ||||||
|     checkEverySecond: "Проверять каждые {0} секунд.", |     checkEverySecond: "Проверять каждые {0} секунд.", | ||||||
|     "Avg.": "Средн.", |  | ||||||
|     retriesDescription: "Максимальное количество попыток перед пометкой сервиса как недоступного и отправкой уведомления", |     retriesDescription: "Максимальное количество попыток перед пометкой сервиса как недоступного и отправкой уведомления", | ||||||
|     ignoreTLSError: "Игнорировать ошибку TLS/SSL для HTTPS сайтов", |     ignoreTLSError: "Игнорировать ошибку TLS/SSL для HTTPS сайтов", | ||||||
|     upsideDownModeDescription: "Реверс статуса сервиса. Если сервис доступен, то он помечается как НЕДОСТУПНЫЙ.", |     upsideDownModeDescription: "Реверс статуса сервиса. Если сервис доступен, то он помечается как НЕДОСТУПНЫЙ.", | ||||||
|  | @ -107,40 +106,67 @@ export default { | ||||||
|     "Last Result": "Последний результат", |     "Last Result": "Последний результат", | ||||||
|     "Create your admin account": "Создайте аккаунт администратора", |     "Create your admin account": "Создайте аккаунт администратора", | ||||||
|     "Repeat Password": "Повторите пароль", |     "Repeat Password": "Повторите пароль", | ||||||
|     respTime: "Resp. Time (ms)", |     respTime: "Время ответа (мс)", | ||||||
|     notAvailableShort: "N/A", |     notAvailableShort: "Н/Д", | ||||||
|     Create: "Create", |     Create: "Создать", | ||||||
|     clearEventsMsg: "Are you sure want to delete all events for this monitor?", |     clearEventsMsg: "Вы действительно хотите удалить всю статистику событий данного монитора?", | ||||||
|     clearHeartbeatsMsg: "Are you sure want to delete all heartbeats for this monitor?", |     clearHeartbeatsMsg: "Вы действительно хотите удалить всю статистику опросов данного монитора?", | ||||||
|     confirmClearStatisticsMsg: "Are you sure want to delete ALL statistics?", |     confirmClearStatisticsMsg: "Вы действительно хотите удалить ВСЮ статистику?", | ||||||
|     "Clear Data": "Clear Data", |     "Clear Data": "Очистить статистику", | ||||||
|     Events: "Events", |     Events: "События", | ||||||
|     Heartbeats: "Heartbeats", |     Heartbeats: "Опросы", | ||||||
|     "Auto Get": "Auto Get", |     "Auto Get": "Авто-получение", | ||||||
|     enableDefaultNotificationDescription: "For every new monitor this notification will be enabled by default. You can still disable the notification separately for each monitor.", |     enableDefaultNotificationDescription: "Для каждого нового монитора это уведомление будет включено по умолчанию. Вы всё ещё можете отключить уведомления в каждом мониторе отдельно.", | ||||||
|     "Default enabled": "Default enabled", |     "Default enabled": "Использовать по умолчанию", | ||||||
|     "Also apply to existing monitors": "Also apply to existing monitors", |     "Also apply to existing monitors": "Применить к существующим мониторам", | ||||||
|     Export: "Export", |     Export: "Экспорт", | ||||||
|     Import: "Import", |     Import: "Импорт", | ||||||
|     backupDescription: "You can backup all monitors and all notifications into a JSON file.", |     backupDescription: "Вы можете сохранить резервную копию всех мониторов и уведомлений в виде JSON-файла", | ||||||
|     backupDescription2: "PS: History and event data is not included.", |     backupDescription2: "P.S.: История и события сохранены не будут.", | ||||||
|     backupDescription3: "Sensitive data such as notification tokens is included in the export file, please keep it carefully.", |     backupDescription3: "Важные данные, такие как токены уведомлений, добавляются при экспорте, поэтому храните файлы в безопасном месте.", | ||||||
|     alertNoFile: "Please select a file to import.", |     alertNoFile: "Выберите файл для импорта.", | ||||||
|     alertWrongFileType: "Please select a JSON file.", |     alertWrongFileType: "Выберите JSON-файл.", | ||||||
|     twoFAVerifyLabel: "Please type in your token to verify that 2FA is working", |     twoFAVerifyLabel: "Пожалуйста, введите свой токен, чтобы проверить работу 2FA", | ||||||
|     tokenValidSettingsMsg: "Token is valid! You can now save the 2FA settings.", |     tokenValidSettingsMsg: "Токен действителен! Теперь вы можете сохранить настройки 2FA.", | ||||||
|     confirmEnableTwoFAMsg: "Are you sure you want to enable 2FA?", |     confirmEnableTwoFAMsg: "Вы действительно хотите включить 2FA?", | ||||||
|     confirmDisableTwoFAMsg: "Are you sure you want to disable 2FA?", |     confirmDisableTwoFAMsg: "Вы действительно хотите выключить 2FA?", | ||||||
|     "Apply on all existing monitors": "Apply on all existing monitors", |     "Apply on all existing monitors": "Применить ко всем существующим мониторам", | ||||||
|     "Verify Token": "Verify Token", |     "Verify Token": "Проверить токен", | ||||||
|     "Setup 2FA": "Setup 2FA", |     "Setup 2FA": "Настройка 2FA", | ||||||
|     "Enable 2FA": "Enable 2FA", |     "Enable 2FA": "Включить 2FA", | ||||||
|     "Disable 2FA": "Disable 2FA", |     "Disable 2FA": "Выключить 2FA", | ||||||
|     "2FA Settings": "2FA Settings", |     "2FA Settings": "Настройки 2FA", | ||||||
|     "Two Factor Authentication": "Two Factor Authentication", |     "Two Factor Authentication": "Двухфакторная аутентификация", | ||||||
|     Active: "Active", |     Active: "Активно", | ||||||
|     Inactive: "Inactive", |     Inactive: "Неактивно", | ||||||
|     Token: "Token", |     Token: "Токен", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Показать URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Очистить всю статистику", | ||||||
|  |     retryCheckEverySecond: "Повторять каждые {0} секунд.", | ||||||
|  |     importHandleDescription: "Выберите 'Пропустить существующие' если вы хотите пропустить каждый монитор или уведомление с таким же именем. 'Перезаписать' удалит каждый существующий монитор или уведомление.", | ||||||
|  |     confirmImportMsg: "Вы действительно хотите восстановить резервную копию? Убедитесь, что вы выбрали подходящий вариант импорта.", | ||||||
|  |     "Heartbeat Retry Interval": "Интервал повтора опроса", | ||||||
|  |     "Import Backup": "Импорт резервной копии", | ||||||
|  |     "Export Backup": "Экспорт резервной копии", | ||||||
|  |     "Skip existing": "Пропустить существующие", | ||||||
|  |     Overwrite: "Перезаписать", | ||||||
|  |     Options: "Опции", | ||||||
|  |     "Keep both": "Оставить оба", | ||||||
|  |     Tags: "Теги", | ||||||
|  |     "Add New below or Select...": "Добавить новое ниже или выбрать...", | ||||||
|  |     "Tag with this name already exist.": "Такой тег уже существует.", | ||||||
|  |     "Tag with this value already exist.": "Тег с таким значением уже существует.", | ||||||
|  |     color: "цвет", | ||||||
|  |     "value (optional)": "значение (опционально)", | ||||||
|  |     Gray: "Серый", | ||||||
|  |     Red: "Красный", | ||||||
|  |     Orange: "Оранжевый", | ||||||
|  |     Green: "Зелёный", | ||||||
|  |     Blue: "Синий", | ||||||
|  |     Indigo: "Индиго", | ||||||
|  |     Purple: "Пурпурный", | ||||||
|  |     Pink: "Розовый", | ||||||
|  |     "Search...": "Поиск...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Srpski", |     languageName: "Srpski", | ||||||
|     checkEverySecond: "Proveri svakih {0} sekundi.", |     checkEverySecond: "Proveri svakih {0} sekundi.", | ||||||
|     "Avg.": "Prosečni", |  | ||||||
|     retriesDescription: "Maksimum pokušaja pre nego što se servis obeleži kao neaktivan i pošalje se obaveštenje.", |     retriesDescription: "Maksimum pokušaja pre nego što se servis obeleži kao neaktivan i pošalje se obaveštenje.", | ||||||
|     ignoreTLSError: "Ignoriši TLS/SSL greške za HTTPS veb stranice.", |     ignoreTLSError: "Ignoriši TLS/SSL greške za HTTPS veb stranice.", | ||||||
|     upsideDownModeDescription: "Obrnite status. Ako je servis dostupan, onda je obeležen kao neaktivan.", |     upsideDownModeDescription: "Obrnite status. Ako je servis dostupan, onda je obeležen kao neaktivan.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Српски", |     languageName: "Српски", | ||||||
|     checkEverySecond: "Провери сваких {0} секунди.", |     checkEverySecond: "Провери сваких {0} секунди.", | ||||||
|     "Avg.": "Просечни", |  | ||||||
|     retriesDescription: "Максимум покушаја пре него што се сервис обележи као неактиван и пошаље се обавештење.", |     retriesDescription: "Максимум покушаја пре него што се сервис обележи као неактиван и пошаље се обавештење.", | ||||||
|     ignoreTLSError: "Игнориши TLS/SSL грешке за HTTPS веб странице.", |     ignoreTLSError: "Игнориши TLS/SSL грешке за HTTPS веб странице.", | ||||||
|     upsideDownModeDescription: "Обрните статус. Ако је сервис доступан, онда је обележен као неактиван.", |     upsideDownModeDescription: "Обрните статус. Ако је сервис доступан, онда је обележен као неактиван.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Svenska", |     languageName: "Svenska", | ||||||
|     checkEverySecond: "Uppdatera var {0} sekund.", |     checkEverySecond: "Uppdatera var {0} sekund.", | ||||||
|     "Avg.": "Genomsnittligt", |  | ||||||
|     retriesDescription: "Max antal försök innan tjänsten markeras som nere och en notis skickas", |     retriesDescription: "Max antal försök innan tjänsten markeras som nere och en notis skickas", | ||||||
|     ignoreTLSError: "Ignorera TLS/SSL-fel för webbsidor med HTTPS", |     ignoreTLSError: "Ignorera TLS/SSL-fel för webbsidor med HTTPS", | ||||||
|     upsideDownModeDescription: "Vänd upp och ner på statusen. Om tjänsten är nåbar visas den som NERE.", |     upsideDownModeDescription: "Vänd upp och ner på statusen. Om tjänsten är nåbar visas den som NERE.", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "Türkçe", |     languageName: "Türkçe", | ||||||
|     checkEverySecond: "{0} Saniyede bir kontrol et.", |     checkEverySecond: "{0} Saniyede bir kontrol et.", | ||||||
|     "Avg.": "Ortalama", |  | ||||||
|     retriesDescription: "Servisin kapalı olarak işaretlenmeden ve bir bildirim gönderilmeden önce maksimum yeniden deneme sayısı", |     retriesDescription: "Servisin kapalı olarak işaretlenmeden ve bir bildirim gönderilmeden önce maksimum yeniden deneme sayısı", | ||||||
|     ignoreTLSError: "HTTPS web siteleri için TLS/SSL hatasını yoksay", |     ignoreTLSError: "HTTPS web siteleri için TLS/SSL hatasını yoksay", | ||||||
|     upsideDownModeDescription: "Servisin durumunu tersine çevirir. Servis çalışıyorsa kapalı olarak işaretler.", |     upsideDownModeDescription: "Servisin durumunu tersine çevirir. Servis çalışıyorsa kapalı olarak işaretler.", | ||||||
|  | @ -117,4 +116,56 @@ export default { | ||||||
|     Events: "Olaylar", |     Events: "Olaylar", | ||||||
|     Heartbeats: "Sağlık Durumları", |     Heartbeats: "Sağlık Durumları", | ||||||
|     "Auto Get": "Otomatik Al", |     "Auto Get": "Otomatik Al", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     enableDefaultNotificationDescription: "For every new monitor this notification will be enabled by default. You can still disable the notification separately for each monitor.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     twoFAVerifyLabel: "Please type in your token to verify that 2FA is working", | ||||||
|  |     tokenValidSettingsMsg: "Token is valid! You can now save the 2FA settings.", | ||||||
|  |     confirmEnableTwoFAMsg: "Are you sure you want to enable 2FA?", | ||||||
|  |     confirmDisableTwoFAMsg: "Are you sure you want to disable 2FA?", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     Export: "Export", | ||||||
|  |     Import: "Import", | ||||||
|  |     "Default enabled": "Default enabled", | ||||||
|  |     "Apply on all existing monitors": "Apply on all existing monitors", | ||||||
|  |     backupDescription: "You can backup all monitors and all notifications into a JSON file.", | ||||||
|  |     backupDescription2: "PS: History and event data is not included.", | ||||||
|  |     backupDescription3: "Sensitive data such as notification tokens is included in the export file, please keep it carefully.", | ||||||
|  |     alertNoFile: "Please select a file to import.", | ||||||
|  |     alertWrongFileType: "Please select a JSON file.", | ||||||
|  |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     "Verify Token": "Verify Token", | ||||||
|  |     "Setup 2FA": "Setup 2FA", | ||||||
|  |     "Enable 2FA": "Enable 2FA", | ||||||
|  |     "Disable 2FA": "Disable 2FA", | ||||||
|  |     "2FA Settings": "2FA Settings", | ||||||
|  |     "Two Factor Authentication": "Two Factor Authentication", | ||||||
|  |     Active: "Active", | ||||||
|  |     Inactive: "Inactive", | ||||||
|  |     Token: "Token", | ||||||
|  |     "Show URI": "Show URI", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,7 +1,6 @@ | ||||||
| export default { | export default { | ||||||
|     languageName: "简体中文", |     languageName: "简体中文", | ||||||
|     checkEverySecond: "检测频率 {0} 秒", |     checkEverySecond: "检测频率 {0} 秒", | ||||||
|     "Avg.": "平均", |  | ||||||
|     retriesDescription: "最大重试失败次数", |     retriesDescription: "最大重试失败次数", | ||||||
|     ignoreTLSError: "忽略HTTPS站点的证书错误", |     ignoreTLSError: "忽略HTTPS站点的证书错误", | ||||||
|     upsideDownModeDescription: "反向状态监控(状态码范围外为有效状态,反之为无效)", |     upsideDownModeDescription: "反向状态监控(状态码范围外为有效状态,反之为无效)", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "Show URI", |     "Show URI": "Show URI", | ||||||
|     "Clear all statistics": "Clear all Statistics", |     "Clear all statistics": "Clear all Statistics", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -36,7 +36,6 @@ export default { | ||||||
|     hour: "小時", |     hour: "小時", | ||||||
|     "-hour": "小時", |     "-hour": "小時", | ||||||
|     checkEverySecond: "每 {0} 秒檢查一次", |     checkEverySecond: "每 {0} 秒檢查一次", | ||||||
|     "Avg.": "平均", |  | ||||||
|     Response: "反應時間", |     Response: "反應時間", | ||||||
|     Ping: "反應時間", |     Ping: "反應時間", | ||||||
|     "Monitor Type": "監測器類型", |     "Monitor Type": "監測器類型", | ||||||
|  | @ -143,4 +142,31 @@ export default { | ||||||
|     Token: "Token", |     Token: "Token", | ||||||
|     "Show URI": "顯示 URI", |     "Show URI": "顯示 URI", | ||||||
|     "Clear all statistics": "清除所有歷史記錄", |     "Clear all statistics": "清除所有歷史記錄", | ||||||
|  |     retryCheckEverySecond: "Retry every {0} seconds.", | ||||||
|  |     importHandleDescription: "Choose 'Skip existing' if you want to skip every monitor or notification with the same name. 'Overwrite' will delete every existing monitor and notification.", | ||||||
|  |     confirmImportMsg: "Are you sure to import the backup? Please make sure you've selected the right import option.", | ||||||
|  |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Import Backup": "Import Backup", | ||||||
|  |     "Export Backup": "Export Backup", | ||||||
|  |     "Skip existing": "Skip existing", | ||||||
|  |     Overwrite: "Overwrite", | ||||||
|  |     Options: "Options", | ||||||
|  |     "Keep both": "Keep both", | ||||||
|  |     Tags: "Tags", | ||||||
|  |     "Add New below or Select...": "Add New below or Select...", | ||||||
|  |     "Tag with this name already exist.": "Tag with this name already exist.", | ||||||
|  |     "Tag with this value already exist.": "Tag with this value already exist.", | ||||||
|  |     color: "color", | ||||||
|  |     "value (optional)": "value (optional)", | ||||||
|  |     Gray: "Gray", | ||||||
|  |     Red: "Red", | ||||||
|  |     Orange: "Orange", | ||||||
|  |     Green: "Green", | ||||||
|  |     Blue: "Blue", | ||||||
|  |     Indigo: "Indigo", | ||||||
|  |     Purple: "Purple", | ||||||
|  |     Pink: "Pink", | ||||||
|  |     "Search...": "Search...", | ||||||
|  |     "Avg. Ping": "Avg. Ping", | ||||||
|  |     "Avg. Response": "Avg. Response", | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ | ||||||
|             <div class="shadow-box big-padding text-center stats"> |             <div class="shadow-box big-padding text-center stats"> | ||||||
|                 <div class="row"> |                 <div class="row"> | ||||||
|                     <div class="col"> |                     <div class="col"> | ||||||
|                         <h4>{{ pingTitle }}</h4> |                         <h4>{{ pingTitle() }}</h4> | ||||||
|                         <p>({{ $t("Current") }})</p> |                         <p>({{ $t("Current") }})</p> | ||||||
|                         <span class="num"> |                         <span class="num"> | ||||||
|                             <a href="#" @click.prevent="showPingChartBox = !showPingChartBox"> |                             <a href="#" @click.prevent="showPingChartBox = !showPingChartBox"> | ||||||
|  | @ -58,7 +58,7 @@ | ||||||
|                         </span> |                         </span> | ||||||
|                     </div> |                     </div> | ||||||
|                     <div class="col"> |                     <div class="col"> | ||||||
|                         <h4>{{ $t("Avg.") }} {{ pingTitle }}</h4> |                         <h4>{{ pingTitle(true) }}</h4> | ||||||
|                         <p>(24{{ $t("-hour") }})</p> |                         <p>(24{{ $t("-hour") }})</p> | ||||||
|                         <span class="num"><CountUp :value="avgPing" /></span> |                         <span class="num"><CountUp :value="avgPing" /></span> | ||||||
|                     </div> |                     </div> | ||||||
|  | @ -240,14 +240,6 @@ export default { | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|     computed: { |     computed: { | ||||||
| 
 |  | ||||||
|         pingTitle() { |  | ||||||
|             if (this.monitor.type === "http") { |  | ||||||
|                 return this.$t("Response"); |  | ||||||
|             } |  | ||||||
|             return this.$t("Ping"); |  | ||||||
|         }, |  | ||||||
| 
 |  | ||||||
|         monitor() { |         monitor() { | ||||||
|             let id = this.$route.params.id |             let id = this.$route.params.id | ||||||
|             return this.$root.monitorList[id]; |             return this.$root.monitorList[id]; | ||||||
|  | @ -378,6 +370,19 @@ export default { | ||||||
|                 } |                 } | ||||||
|             }) |             }) | ||||||
|         }, |         }, | ||||||
|  | 
 | ||||||
|  |         pingTitle(average = false) { | ||||||
|  |             let translationPrefix = "" | ||||||
|  |             if (average) { | ||||||
|  |                 translationPrefix = "Avg. " | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (this.monitor.type === "http") { | ||||||
|  |                 return this.$t(translationPrefix + "Response"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return this.$t(translationPrefix + "Ping"); | ||||||
|  |         }, | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | @ -50,7 +50,7 @@ | ||||||
|                             <!-- TCP Port / Ping / DNS only --> |                             <!-- TCP Port / Ping / DNS only --> | ||||||
|                             <div v-if="monitor.type === 'port' || monitor.type === 'ping' || monitor.type === 'dns' " class="my-3"> |                             <div v-if="monitor.type === 'port' || monitor.type === 'ping' || monitor.type === 'dns' " class="my-3"> | ||||||
|                                 <label for="hostname" class="form-label">{{ $t("Hostname") }}</label> |                                 <label for="hostname" class="form-label">{{ $t("Hostname") }}</label> | ||||||
|                                 <input id="hostname" v-model="monitor.hostname" type="text" class="form-control" required> |                                 <input id="hostname" v-model="monitor.hostname" type="text" class="form-control" :pattern="ipRegexPattern || hostnameRegexPattern" required> | ||||||
|                             </div> |                             </div> | ||||||
| 
 | 
 | ||||||
|                             <!-- For TCP Port Type --> |                             <!-- For TCP Port Type --> | ||||||
|  | @ -235,6 +235,9 @@ export default { | ||||||
|             // Source: https://digitalfortress.tech/tips/top-15-commonly-used-regex/ |             // Source: https://digitalfortress.tech/tips/top-15-commonly-used-regex/ | ||||||
|             // eslint-disable-next-line |             // eslint-disable-next-line | ||||||
|             ipRegexPattern: "((^\s*((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))\s*$)|(^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$))", |             ipRegexPattern: "((^\s*((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))\s*$)|(^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$))", | ||||||
|  |             // Source: https://stackoverflow.com/questions/106179/regular-expression-to-match-dns-hostname-or-ip-address | ||||||
|  |             // eslint-disable-next-line | ||||||
|  |             hostnameRegexPattern: "^(([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])$" | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -289,6 +289,12 @@ | ||||||
|                     <p>Utilizzare con attenzione.</p> |                     <p>Utilizzare con attenzione.</p> | ||||||
|                 </template> |                 </template> | ||||||
| 
 | 
 | ||||||
|  |                 <template v-else-if="$i18n.locale === 'ru-RU' "> | ||||||
|  |                     <p>Вы уверены, что хотите <strong>отключить авторизацию</strong>?</p> | ||||||
|  |                     <p>Это подходит для <strong>тех, у кого стоит другая авторизация</strong> перед открытием Uptime Kuma, например Cloudflare Access.</p> | ||||||
|  |                     <p>Пожалуйста, используйте с осторожностью.</p> | ||||||
|  |                 </template> | ||||||
|  | 
 | ||||||
|                 <!-- English (en) --> |                 <!-- English (en) --> | ||||||
|                 <template v-else> |                 <template v-else> | ||||||
|                     <p>Are you sure want to <strong>disable auth</strong>?</p> |                     <p>Are you sure want to <strong>disable auth</strong>?</p> | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								test/ubuntu-nodejs16.dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								test/ubuntu-nodejs16.dockerfile
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | ||||||
|  | FROM ubuntu | ||||||
|  | WORKDIR /app | ||||||
|  | RUN apt update && apt --yes install git curl | ||||||
|  | RUN curl -sL https://deb.nodesource.com/setup_16.x | bash - | ||||||
|  | RUN apt --yes install nodejs | ||||||
|  | RUN git clone https://github.com/louislam/uptime-kuma.git . | ||||||
|  | RUN npm run setup | ||||||
|  | 
 | ||||||
|  | # Option 1. Try it | ||||||
|  | RUN node server/server.js | ||||||
		Loading…
	
		Reference in a new issue