Merge remote-tracking branch 'origin/master' into feat/add-gRPC-protocol
# Conflicts: # package-lock.json
This commit is contained in:
		
						commit
						f35d7c0a1a
					
				
					 45 changed files with 4627 additions and 2219 deletions
				
			
		|  | @ -1,6 +1,7 @@ | |||
| /.idea | ||||
| /node_modules | ||||
| /data | ||||
| /cypress | ||||
| /out | ||||
| /test | ||||
| /kubernetes | ||||
|  |  | |||
							
								
								
									
										16
									
								
								.github/workflows/auto-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/auto-test.yml
									
									
									
									
										vendored
									
									
								
							|  | @ -50,3 +50,19 @@ jobs: | |||
|         cache: 'npm' | ||||
|     - run: npm install | ||||
|     - run: npm run lint | ||||
| 
 | ||||
|   e2e-tests: | ||||
|     needs: [ check-linters ] | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - run: git config --global core.autocrlf false  # Mainly for Windows | ||||
|     - uses: actions/checkout@v3 | ||||
| 
 | ||||
|     - name: Use Node.js 14 | ||||
|       uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: 14 | ||||
|         cache: 'npm' | ||||
|     - run: npm install | ||||
|     - run: npm run build | ||||
|     - run: npm run cy:test | ||||
|  |  | |||
							
								
								
									
										22
									
								
								.github/workflows/stale-bot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								.github/workflows/stale-bot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | |||
| name: 'Automatically close stale issues and PRs' | ||||
| on: | ||||
|   schedule: | ||||
|     - cron: '0 0 * * *' | ||||
| #Run once a day at midnight  | ||||
| 
 | ||||
| jobs: | ||||
|   stale: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: actions/stale@v5 | ||||
|         with: | ||||
|           stale-issue-message: 'We are clearing up our old issues and your ticket has been open for 3 months with no activity. Remove stale label or comment or this will be closed in 7 days.' | ||||
|           stale-pr-message: 'We are clearing up our old Pull Requests and yours has been open for 3 months with no activity. Remove stale label or comment or this will be closed in 7 days.' | ||||
|           close-issue-message: 'This issue was closed because it has been stalled for 7 days with no activity.' | ||||
|           close-pr-message: 'This PR was closed because it has been stalled for 7 days with no activity.' | ||||
|           days-before-stale: 90 | ||||
|           days-before-close: 7 | ||||
|           exempt-issue-labels: 'News,Medium,High,discussion,bug,doc,feature-request' | ||||
|           exempt-pr-labels: 'awaiting-approval,work-in-progress,enhancement,feature-request' | ||||
|           exempt-issue-assignees: 'louislam' | ||||
|           exempt-pr-assignees: 'louislam' | ||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							|  | @ -13,3 +13,6 @@ dist-ssr | |||
| /out | ||||
| /tmp | ||||
| .env | ||||
| 
 | ||||
| cypress/videos | ||||
| cypress/screenshots | ||||
|  |  | |||
							
								
								
									
										11
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								README.md
									
									
									
									
									
								
							|  | @ -157,7 +157,14 @@ You can mention me if you ask a question on Reddit. | |||
| 
 | ||||
| ## Contribute | ||||
| 
 | ||||
| ### Beta Version | ||||
| ### Test Pull Requests | ||||
| 
 | ||||
| There are a lot of pull requests right now, but I don't have time to test them all. | ||||
| 
 | ||||
| If you want to help, you can check this: | ||||
| https://github.com/louislam/uptime-kuma/wiki/Test-Pull-Requests | ||||
| 
 | ||||
| ### Test Beta Version | ||||
| 
 | ||||
| Check out the latest beta release here: https://github.com/louislam/uptime-kuma/releases | ||||
| 
 | ||||
|  | @ -169,5 +176,5 @@ If you want to translate Uptime Kuma into your language, please read: https://gi | |||
| 
 | ||||
| Feel free to correct my grammar in this README, source code, or wiki, as my mother language is not English and my grammar is not that great. | ||||
| 
 | ||||
| ### Pull Requests | ||||
| ### Create Pull Requests | ||||
| If you want to modify Uptime Kuma, this guideline may be useful for you: https://github.com/louislam/uptime-kuma/blob/master/CONTRIBUTING.md | ||||
|  |  | |||
|  | @ -11,6 +11,9 @@ const viteCompressionFilter = /\.(js|mjs|json|css|html|svg)$/i; | |||
| 
 | ||||
| // https://vitejs.dev/config/
 | ||||
| export default defineConfig({ | ||||
|     server: { | ||||
|         port: 3000, | ||||
|     }, | ||||
|     define: { | ||||
|         "FRONTEND_VERSION": JSON.stringify(process.env.npm_package_version), | ||||
|     }, | ||||
|  |  | |||
							
								
								
									
										15
									
								
								cypress.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								cypress.config.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| import { defineConfig } from "cypress"; | ||||
| 
 | ||||
| export default defineConfig({ | ||||
|     e2e: { | ||||
|         baseUrl: "http://localhost:3002", | ||||
|         defaultCommandTimeout: 10000, | ||||
|         pageLoadTimeout: 60000, | ||||
|         viewportWidth: 1920, | ||||
|         viewportHeight: 1080, | ||||
|         specPattern: ["cypress/e2e/setup.cy.ts", "cypress/e2e/**/*.ts"], | ||||
|     }, | ||||
|     env: { | ||||
|         baseUrl: "http://localhost:3002", | ||||
|     }, | ||||
| }); | ||||
							
								
								
									
										24
									
								
								cypress/e2e/setup.cy.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								cypress/e2e/setup.cy.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | |||
| import { actor } from "../support/actors/actor"; | ||||
| import { DEFAULT_USER_DATA } from "../support/const/user-data"; | ||||
| import { DashboardPage } from "../support/pages/dasboard-page"; | ||||
| import { SetupPage } from "../support/pages/setup-page"; | ||||
| 
 | ||||
| describe("user can create a new account on setup page", () => { | ||||
|     before(() => { | ||||
|         cy.visit("/setup"); | ||||
|     }); | ||||
| 
 | ||||
|     it("user can create new account", () => { | ||||
|         cy.url().should("be.equal", SetupPage.url); | ||||
|         actor.setupTask.fillAndSubmitSetupForm( | ||||
|             DEFAULT_USER_DATA.username, | ||||
|             DEFAULT_USER_DATA.password, | ||||
|             DEFAULT_USER_DATA.password | ||||
|         ); | ||||
| 
 | ||||
|         cy.url().should("be.equal", DashboardPage.url); | ||||
|         cy.get('[role="alert"]') | ||||
|             .should("be.visible") | ||||
|             .and("contain.text", "Added Successfully."); | ||||
|     }); | ||||
| }); | ||||
							
								
								
									
										0
									
								
								cypress/plugins/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								cypress/plugins/index.js
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										8
									
								
								cypress/support/actors/actor.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								cypress/support/actors/actor.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,8 @@ | |||
| import { SetupTask } from "../tasks/setup-task"; | ||||
| 
 | ||||
| class Actor { | ||||
|     setupTask: SetupTask = new SetupTask(); | ||||
| } | ||||
| 
 | ||||
| const actor = new Actor(); | ||||
| export { actor }; | ||||
							
								
								
									
										0
									
								
								cypress/support/commands.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								cypress/support/commands.ts
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										4
									
								
								cypress/support/const/user-data.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								cypress/support/const/user-data.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,4 @@ | |||
| export const DEFAULT_USER_DATA = { | ||||
|     username: "testuser", | ||||
|     password: "testuser123", | ||||
| }; | ||||
							
								
								
									
										1
									
								
								cypress/support/e2e.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								cypress/support/e2e.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| import "./commands"; | ||||
							
								
								
									
										3
									
								
								cypress/support/pages/dasboard-page.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								cypress/support/pages/dasboard-page.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | |||
| export const DashboardPage = { | ||||
|     url: Cypress.env("baseUrl") + "/dashboard", | ||||
| }; | ||||
							
								
								
									
										7
									
								
								cypress/support/pages/setup-page.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								cypress/support/pages/setup-page.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,7 @@ | |||
| export const SetupPage = { | ||||
|     url: Cypress.env("baseUrl") + "/setup", | ||||
|     usernameInput: '[data-cy="username-input"]', | ||||
|     passWordInput: '[data-cy="password-input"]', | ||||
|     passwordRepeatInput: '[data-cy="password-repeat-input"]', | ||||
|     submitSetupForm: '[data-cy="submit-setup-form"]', | ||||
| }; | ||||
							
								
								
									
										15
									
								
								cypress/support/tasks/setup-task.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								cypress/support/tasks/setup-task.ts
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| import { SetupPage } from "../pages/setup-page"; | ||||
| 
 | ||||
| export class SetupTask { | ||||
|     fillAndSubmitSetupForm( | ||||
|         username: string, | ||||
|         password: string, | ||||
|         passwordRepeat: string | ||||
|     ) { | ||||
|         cy.get(SetupPage.usernameInput).type(username); | ||||
|         cy.get(SetupPage.passWordInput).type(password); | ||||
|         cy.get(SetupPage.passwordRepeatInput).type(passwordRepeat); | ||||
| 
 | ||||
|         cy.get(SetupPage.submitSetupForm).click(); | ||||
|     } | ||||
| } | ||||
|  | @ -24,6 +24,36 @@ CMD ["node", "server/server.js"] | |||
| FROM release AS nightly | ||||
| RUN npm run mark-as-nightly | ||||
| 
 | ||||
| # Build an image for testing pr | ||||
| FROM louislam/uptime-kuma:base-debian AS pr-test | ||||
| 
 | ||||
| WORKDIR /app | ||||
| 
 | ||||
| ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=1 | ||||
| 
 | ||||
| ## Install Git | ||||
| RUN apt update \ | ||||
|     && apt --yes --no-install-recommends install curl \ | ||||
|     && curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg \ | ||||
|     && chmod go+r /usr/share/keyrings/githubcli-archive-keyring.gpg \ | ||||
|     && echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main" | tee /etc/apt/sources.list.d/github-cli.list > /dev/null \ | ||||
|     && apt update \ | ||||
|     && apt --yes --no-install-recommends  install git | ||||
| 
 | ||||
| ## Empty the directory, because we have to clone the Git repo. | ||||
| RUN rm -rf ./* && chown node /app | ||||
| 
 | ||||
| USER node | ||||
| RUN git config --global user.email "no-reply@no-reply.com" | ||||
| RUN git config --global user.name "PR Tester" | ||||
| RUN git clone https://github.com/louislam/uptime-kuma.git . | ||||
| RUN npm ci | ||||
| 
 | ||||
| EXPOSE 3000 3001 | ||||
| VOLUME ["/app/data"] | ||||
| HEALTHCHECK --interval=60s --timeout=30s --start-period=180s --retries=5 CMD node extra/healthcheck.js | ||||
| CMD ["npm", "run", "start-pr-test"] | ||||
| 
 | ||||
| 
 | ||||
| # Upload the artifact to Github | ||||
| FROM louislam/uptime-kuma:base-debian AS upload-artifact | ||||
|  |  | |||
							
								
								
									
										33
									
								
								extra/checkout-pr.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								extra/checkout-pr.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,33 @@ | |||
| const childProcess = require("child_process"); | ||||
| 
 | ||||
| if (!process.env.UPTIME_KUMA_GH_REPO) { | ||||
|     console.error("Please set a repo to the environment variable 'UPTIME_KUMA_GH_REPO' (e.g. mhkarimi1383:goalert-notification)"); | ||||
|     process.exit(1); | ||||
| } | ||||
| 
 | ||||
| let inputArray = process.env.UPTIME_KUMA_GH_REPO.split(":"); | ||||
| 
 | ||||
| if (inputArray.length !== 2) { | ||||
|     console.error("Invalid format. Please set a repo to the environment variable 'UPTIME_KUMA_GH_REPO' (e.g. mhkarimi1383:goalert-notification)"); | ||||
| } | ||||
| 
 | ||||
| let name = inputArray[0]; | ||||
| let branch = inputArray[1]; | ||||
| 
 | ||||
| console.log("Checkout pr"); | ||||
| 
 | ||||
| // Checkout the pr
 | ||||
| let result = childProcess.spawnSync("git", [ "remote", "add", name, `https://github.com/${name}/uptime-kuma` ]); | ||||
| 
 | ||||
| console.log(result.stdout.toString()); | ||||
| console.error(result.stderr.toString()); | ||||
| 
 | ||||
| result = childProcess.spawnSync("git", [ "fetch", name, branch ]); | ||||
| 
 | ||||
| console.log(result.stdout.toString()); | ||||
| console.error(result.stderr.toString()); | ||||
| 
 | ||||
| result = childProcess.spawnSync("git", [ "checkout", branch, "--force" ]); | ||||
| 
 | ||||
| console.log(result.stdout.toString()); | ||||
| console.error(result.stderr.toString()); | ||||
							
								
								
									
										5544
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										5544
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										27
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								package.json
									
									
									
									
									
								
							|  | @ -1,6 +1,6 @@ | |||
| { | ||||
|     "name": "uptime-kuma", | ||||
|     "version": "1.18.0-beta.0", | ||||
|     "version": "1.18.0", | ||||
|     "license": "MIT", | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
|  | @ -38,8 +38,9 @@ | |||
|         "build-docker-nightly": "npm run build && docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:nightly --target nightly . --push", | ||||
|         "build-docker-nightly-alpine": "docker buildx build -f docker/dockerfile-alpine --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:nightly-alpine --target nightly . --push", | ||||
|         "build-docker-nightly-amd64": "docker buildx build -f docker/dockerfile --platform linux/amd64 -t louislam/uptime-kuma:nightly-amd64 --target nightly . --push --progress plain", | ||||
|         "build-docker-pr-test": "docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64 -t louislam/uptime-kuma:pr-test --target pr-test . --push", | ||||
|         "upload-artifacts": "docker buildx build -f docker/dockerfile --platform linux/amd64 -t louislam/uptime-kuma:upload-artifact --build-arg VERSION --build-arg GITHUB_TOKEN --target upload-artifact . --progress plain", | ||||
|         "setup": "git checkout 1.17.1 && npm ci --production && npm run download-dist", | ||||
|         "setup": "git checkout 1.18.0 && npm ci --production && npm run download-dist", | ||||
|         "download-dist": "node extra/download-dist.js", | ||||
|         "mark-as-nightly": "node extra/mark-as-nightly.js", | ||||
|         "reset-password": "node extra/reset-password.js", | ||||
|  | @ -58,7 +59,10 @@ | |||
|         "release-final": "node extra/update-version.js && npm run build-docker && node ./extra/press-any-key.js && npm run upload-artifacts && node ./extra/update-wiki-version.js", | ||||
|         "release-beta": "node extra/beta/update-version.js && npm run build && node ./extra/env2arg.js docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:$VERSION -t louislam/uptime-kuma:beta .  --target release --push && node ./extra/press-any-key.js && npm run upload-artifacts", | ||||
|         "git-remove-tag": "git tag -d", | ||||
|         "build-dist-and-restart": "npm run build && npm run start-server-dev" | ||||
|         "build-dist-and-restart": "npm run build && npm run start-server-dev", | ||||
|         "start-pr-test": "node extra/checkout-pr.js && npm install && npm run dev", | ||||
|         "cy:test": "node test/prepare-test-server.js && node server/server.js --port=3002 --data-dir=./data/test/ --e2e", | ||||
|         "cy:run": "npx cypress run --browser chrome --headless" | ||||
|     }, | ||||
|     "dependencies": { | ||||
|         "@fortawesome/fontawesome-svg-core": "~1.2.36", | ||||
|  | @ -68,7 +72,7 @@ | |||
|         "@grpc/grpc-js": "^1.6.8", | ||||
|         "@louislam/sqlite3": "~15.0.6", | ||||
|         "args-parser": "~1.3.0", | ||||
|         "axios": "~0.26.1", | ||||
|         "axios": "~0.27.0", | ||||
|         "axios-ntlm": "^1.3.0", | ||||
|         "badge-maker": "^3.3.1", | ||||
|         "bcryptjs": "~2.4.3", | ||||
|  | @ -124,8 +128,8 @@ | |||
|         "@fortawesome/vue-fontawesome": "~3.0.0-5", | ||||
|         "@popperjs/core": "~2.10.2", | ||||
|         "@types/bootstrap": "~5.1.9", | ||||
|         "@vitejs/plugin-legacy": "~1.8.2", | ||||
|         "@vitejs/plugin-vue": "~2.3.3", | ||||
|         "@vitejs/plugin-legacy": "~2.1.0", | ||||
|         "@vitejs/plugin-vue": "~3.1.0", | ||||
|         "@vue/compiler-sfc": "~3.2.36", | ||||
|         "aedes": "^0.46.3", | ||||
|         "babel-plugin-rewire": "~1.2.0", | ||||
|  | @ -135,15 +139,17 @@ | |||
|         "concurrently": "^7.1.0", | ||||
|         "core-js": "~3.18.3", | ||||
|         "cross-env": "~7.0.3", | ||||
|         "cypress": "^10.1.0", | ||||
|         "delay": "^5.0.0", | ||||
|         "dns2": "~2.0.1", | ||||
|         "eslint": "~8.14.0", | ||||
|         "eslint-plugin-vue": "~8.7.1", | ||||
|         "favico.js": "^0.3.10", | ||||
|         "jest": "~27.2.5", | ||||
|         "jest-puppeteer": "~6.0.3", | ||||
|         "postcss-html": "^1.3.1", | ||||
|         "postcss-rtlcss": "~3.4.1", | ||||
|         "postcss-scss": "~4.0.3", | ||||
|         "postcss-html": "~1.5.0", | ||||
|         "postcss-rtlcss": "~3.7.2", | ||||
|         "postcss-scss": "~4.0.4", | ||||
|         "prismjs": "^1.27.0", | ||||
|         "puppeteer": "~13.1.3", | ||||
|         "qrcode": "~1.5.0", | ||||
|  | @ -151,10 +157,11 @@ | |||
|         "sass": "~1.42.1", | ||||
|         "stylelint": "~14.7.1", | ||||
|         "stylelint-config-standard": "~25.0.0", | ||||
|         "terser": "^5.15.0", | ||||
|         "timezones-list": "~3.0.1", | ||||
|         "typescript": "~4.4.4", | ||||
|         "v-pagination-3": "~0.1.7", | ||||
|         "vite": "~2.9.9", | ||||
|         "vite": "~3.1.0", | ||||
|         "vite-plugin-compression": "^0.5.1", | ||||
|         "vue": "next", | ||||
|         "vue-chart-3": "3.0.9", | ||||
|  |  | |||
							
								
								
									
										35
									
								
								server/notification-providers/goalert.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								server/notification-providers/goalert.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| const NotificationProvider = require("./notification-provider"); | ||||
| const axios = require("axios"); | ||||
| const { UP } = require("../../src/util"); | ||||
| 
 | ||||
| class GoAlert extends NotificationProvider { | ||||
| 
 | ||||
|     name = "GoAlert"; | ||||
| 
 | ||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||
|         let okMsg = "Sent Successfully."; | ||||
|         try { | ||||
|             let closeAction = "close"; | ||||
|             let data = { | ||||
|                 summary: msg, | ||||
|             }; | ||||
|             if (heartbeatJSON != null && heartbeatJSON["status"] === UP) { | ||||
|                 data["action"] = closeAction; | ||||
|             } | ||||
|             let headers = { | ||||
|                 "Content-Type": "multipart/form-data", | ||||
|             }; | ||||
|             let config = { | ||||
|                 headers: headers | ||||
|             }; | ||||
|             let resp = await axios.post(`${notification.goAlertBaseURL}/api/v2/generic/incoming?token=${notification.goAlertToken}`, data, config); | ||||
|             return okMsg; | ||||
| 
 | ||||
|         } catch (error) { | ||||
|             let msg = (error.response.data) ? error.response.data : "Error without response"; | ||||
|             throw new Error(msg); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| module.exports = GoAlert; | ||||
|  | @ -38,6 +38,7 @@ const TechulusPush = require("./notification-providers/techulus-push"); | |||
| const Telegram = require("./notification-providers/telegram"); | ||||
| const Webhook = require("./notification-providers/webhook"); | ||||
| const WeCom = require("./notification-providers/wecom"); | ||||
| const GoAlert = require("./notification-providers/goalert"); | ||||
| 
 | ||||
| class Notification { | ||||
| 
 | ||||
|  | @ -88,6 +89,7 @@ class Notification { | |||
|             new Telegram(), | ||||
|             new Webhook(), | ||||
|             new WeCom(), | ||||
|             new GoAlert(), | ||||
|         ]; | ||||
| 
 | ||||
|         for (let item of list) { | ||||
|  |  | |||
|  | @ -136,6 +136,7 @@ router.get("/api/badge/:id/status", cache("5 minutes"), async (request, response | |||
|             const heartbeat = await Monitor.getPreviousHeartbeat(requestedMonitorId); | ||||
|             const state = overrideValue !== undefined ? overrideValue : heartbeat.status === 1; | ||||
| 
 | ||||
|             badgeValues.label = label ? label : ""; | ||||
|             badgeValues.color = state ? upColor : downColor; | ||||
|             badgeValues.message = label ?? state ? upLabel : downLabel; | ||||
|         } | ||||
|  |  | |||
|  | @ -61,7 +61,7 @@ log.info("server", "Importing this project modules"); | |||
| log.debug("server", "Importing Monitor"); | ||||
| const Monitor = require("./model/monitor"); | ||||
| log.debug("server", "Importing Settings"); | ||||
| const { getSettings, setSettings, setting, initJWTSecret, checkLogin, startUnitTest, FBSD, doubleCheckPassword } = require("./util-server"); | ||||
| const { getSettings, setSettings, setting, initJWTSecret, checkLogin, startUnitTest, FBSD, doubleCheckPassword, startE2eTests } = require("./util-server"); | ||||
| 
 | ||||
| log.debug("server", "Importing Notification"); | ||||
| const { Notification } = require("./notification"); | ||||
|  | @ -112,6 +112,7 @@ const twoFAVerifyOptions = { | |||
|  * @type {boolean} | ||||
|  */ | ||||
| const testMode = !!args["test"] || false; | ||||
| const e2eTestMode = !!args["e2e"] || false; | ||||
| 
 | ||||
| if (config.demoMode) { | ||||
|     log.info("server", "==== Demo Mode ===="); | ||||
|  | @ -1492,6 +1493,10 @@ let needSetup = false; | |||
|         if (testMode) { | ||||
|             startUnitTest(); | ||||
|         } | ||||
| 
 | ||||
|         if (e2eTestMode) { | ||||
|             startE2eTests(); | ||||
|         } | ||||
|     }); | ||||
| 
 | ||||
|     initBackgroundJobs(args); | ||||
|  |  | |||
|  | @ -575,6 +575,26 @@ exports.startUnitTest = async () => { | |||
|     }); | ||||
| }; | ||||
| 
 | ||||
| /** Start end-to-end tests */ | ||||
| exports.startE2eTests = async () => { | ||||
|     console.log("Starting unit test..."); | ||||
|     const npm = /^win/.test(process.platform) ? "npm.cmd" : "npm"; | ||||
|     const child = childProcess.spawn(npm, [ "run", "cy:run" ]); | ||||
| 
 | ||||
|     child.stdout.on("data", (data) => { | ||||
|         console.log(data.toString()); | ||||
|     }); | ||||
| 
 | ||||
|     child.stderr.on("data", (data) => { | ||||
|         console.log(data.toString()); | ||||
|     }); | ||||
| 
 | ||||
|     child.on("close", function (code) { | ||||
|         console.log("Jest exit code: " + code); | ||||
|         process.exit(code); | ||||
|     }); | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Convert unknown string to UTF8 | ||||
|  * @param {Uint8Array} body Buffer | ||||
|  |  | |||
|  | @ -54,6 +54,15 @@ export default { | |||
|             tokenRequired: false, | ||||
|         }; | ||||
|     }, | ||||
| 
 | ||||
|     mounted() { | ||||
|         document.title += " - Login"; | ||||
|     }, | ||||
| 
 | ||||
|     unmounted() { | ||||
|         document.title = document.title.replace(" - Login", ""); | ||||
|     }, | ||||
| 
 | ||||
|     methods: { | ||||
|         /** Submit the user details and attempt to log in */ | ||||
|         submit() { | ||||
|  |  | |||
|  | @ -44,6 +44,7 @@ | |||
|                                                 :href="monitor.element.url" | ||||
|                                                 class="item-name" | ||||
|                                                 target="_blank" | ||||
|                                                 rel="noopener noreferrer" | ||||
|                                             > | ||||
|                                                 {{ monitor.element.name }} | ||||
|                                             </a> | ||||
|  |  | |||
							
								
								
									
										30
									
								
								src/components/notifications/GoAlert.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								src/components/notifications/GoAlert.vue
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,30 @@ | |||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="goalert-base-url" class="form-label">{{ $t("Base URL") }}</label> | ||||
|         <div class="input-group mb-3"> | ||||
|             <input id="goalert-base-url" v-model="$parent.notification.goAlertBaseURL" type="text" class="form-control" required> | ||||
|         </div> | ||||
|         <i18n-t tag="div" keypath="goAlertInfo" class="form-text"> | ||||
|             <a href="https://goalert.me" target="_blank">https://goalert.me</a> | ||||
|         </i18n-t> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="mb-3"> | ||||
|         <label for="goalert-token" class="form-label">{{ $t("Token") }}</label> | ||||
|         <HiddenInput id="goalert-token" v-model="$parent.notification.goAlertToken" autocomplete="one-time-code" :required="true"></HiddenInput> | ||||
| 
 | ||||
|         <div class="form-text"> | ||||
|             {{ $t("goAlertIntegrationKeyInfo") }} | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import HiddenInput from "../HiddenInput.vue"; | ||||
| 
 | ||||
| export default { | ||||
|     components: { | ||||
|         HiddenInput, | ||||
|     }, | ||||
| }; | ||||
| </script> | ||||
|  | @ -36,6 +36,7 @@ import TechulusPush from "./TechulusPush.vue"; | |||
| import Telegram from "./Telegram.vue"; | ||||
| import Webhook from "./Webhook.vue"; | ||||
| import WeCom from "./WeCom.vue"; | ||||
| import GoAlert from "./GoAlert.vue"; | ||||
| 
 | ||||
| /** | ||||
|  * Manage all notification form. | ||||
|  | @ -81,6 +82,7 @@ const NotificationFormList = { | |||
|     "telegram": Telegram, | ||||
|     "webhook": Webhook, | ||||
|     "WeCom": WeCom, | ||||
|     "GoAlert": GoAlert, | ||||
| }; | ||||
| 
 | ||||
| export default NotificationFormList; | ||||
|  |  | |||
|  | @ -1,6 +1,12 @@ | |||
| <template> | ||||
|     <div> | ||||
|         <div class="my-4"> | ||||
|             <div class="alert alert-warning" role="alert" style="border-radius: 15px;"> | ||||
|                 {{ $t("backupOutdatedWarning") }}<br /> | ||||
|                 <br /> | ||||
|                 {{ $t("backupRecommend") }} | ||||
|             </div> | ||||
| 
 | ||||
|             <h4 class="mt-4 mb-2">{{ $t("Export Backup") }}</h4> | ||||
| 
 | ||||
|             <p> | ||||
|  |  | |||
|  | @ -380,7 +380,7 @@ export default { | |||
|     deleteProxyMsg: "Сигурни ли сте, че желаете да изтриете това прокси за всички монитори?", | ||||
|     proxyDescription: "За да функционират трябва да бъдат зададени към монитор.", | ||||
|     enableProxyDescription: "Това прокси няма да има ефект върху заявките за мониторинг, докато не бъде активирано. Може да контролирате временното деактивиране на проксито от всички монитори чрез статуса на активиране.", | ||||
|     setAsDefaultProxyDescription: "Това проки ще бъде включено по подразбиране за новите монитори. Може да го изключите по отделно за всеки един монитор.", | ||||
|     setAsDefaultProxyDescription: "Това прокси ще бъде включено по подразбиране за новите монитори. Може да го изключите по отделно за всеки един монитор.", | ||||
|     "Certificate Chain": "Верига на сертификата", | ||||
|     Valid: "Валиден", | ||||
|     Invalid: "Невалиден", | ||||
|  | @ -537,4 +537,29 @@ export default { | |||
|     Workstation: "Работна станция", | ||||
|     disableCloudflaredNoAuthMsg: "Тъй като сте в режим \"No Auth mode\", парола не се изисква.", | ||||
|     wayToGetLineNotifyToken: "Може да получите токен код за достъп от {0}", | ||||
|     resendEveryXTimes: "Изпращай повторно на всеки {0} пъти", | ||||
|     resendDisabled: "Повторното изпращане е изключено", | ||||
|     "Resend Notification if Down X times consequently": "Повторно изпращане на известие, ако е недостъпен X пъти последователно", | ||||
|     "Bark Group": "Bark група", | ||||
|     "Bark Sound": "Bark звук", | ||||
|     "HTTP Headers": "HTTP хедъри", | ||||
|     "Trust Proxy": "Trust Proxy", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     RadiusSecret: "Radius таен код", | ||||
|     RadiusSecretDescription: "Споделен таен код между клиент и сървър", | ||||
|     RadiusCalledStationId: "Повиквана станция ID", | ||||
|     RadiusCalledStationIdDescription: "Идентификатор на повикваното устройство", | ||||
|     RadiusCallingStationId: "Повикваща станция ID", | ||||
|     RadiusCallingStationIdDescription: "Идентификатор на повикващото устройство", | ||||
|     "Setup Docker Host": "Настройка на Docker хост", | ||||
|     "Connection Type": "Тип свързване", | ||||
|     "Docker Daemon": "Docker демон", | ||||
|     deleteDockerHostMsg: "Сигурни ли сте, че желаете да изтриете този Docker хост за всички монитори?", | ||||
|     socket: "Сокет", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker контейнер", | ||||
|     "Container Name / ID": "Име на контейнер / ID", | ||||
|     "Docker Host": "Docker хост", | ||||
|     "Docker Hosts": "Docker хостове", | ||||
|     trustProxyDescription: "Trust 'X-Forwarded-*' headers.  Ако искате да получавате правилния IP адрес на клиента, а Uptime Kuma е зад системи като Nginx или Apache, трябва да разрешите тази опция.", | ||||
| }; | ||||
|  |  | |||
|  | @ -2,18 +2,21 @@ export default { | |||
|     languageName: "Czech", | ||||
|     checkEverySecond: "Kontrolovat každých {0} sekund", | ||||
|     retryCheckEverySecond: "Opakovat každých {0} sekund", | ||||
|     resendEveryXTimes: "Znovu zaslat {0}krát", | ||||
|     resendDisabled: "Opakované zasílání je vypnuté", | ||||
|     retriesDescription: "Maximální počet pokusů před označením služby jako nedostupné a odesláním oznámení", | ||||
|     ignoreTLSError: "Ignorovat TLS/SSL chyby na HTTPS stránkách", | ||||
|     upsideDownModeDescription: "Pomocí této možnosti změníte způsob vyhodnocování stavu. Pokud je služba dosažitelná, je NEDOSTUPNÁ.", | ||||
|     maxRedirectDescription: "Maximální počet přesměrování, která se mají následovat. Nastavením hodnoty 0 zakážete přesměrování.", | ||||
|     acceptedStatusCodesDescription: "Vyberte stavové kódy, které jsou považovány za úspěšnou odpověď.", | ||||
|     passwordNotMatchMsg: "Hesla se neshodují", | ||||
|     notificationDescription: "Pro zajištění funkčnosti oznámení je nutné je přiřadit dohledu.", | ||||
|     notificationDescription: "Pro zajištění funkčnosti oznámení je nutné jej přiřadit dohledu.", | ||||
|     keywordDescription: "Vyhledat klíčové slovo v prosté odpovědi HTML nebo JSON. Při hledání se rozlišuje velikost písmen.", | ||||
|     pauseDashboardHome: "Pozastavit", | ||||
|     deleteMonitorMsg: "Opravdu chcete odstranit tento dohled?", | ||||
|     deleteNotificationMsg: "Opravdu chcete odstranit toto oznámení pro všechny dohledy?", | ||||
|     resolverserverDescription: "Cloudflare je výchozí server. Resolver server můžete kdykoli změnit.", | ||||
|     dnsPortDescription: "Port DNS serveru. Standardně běží na portu 53. V případě potřeby jej můžete kdykoli změnit.", | ||||
|     resolverserverDescription: "Cloudflare je výchozí server. V případě potřeby můžete Resolver server kdykoli změnit.", | ||||
|     rrtypeDescription: "Vyberte typ záznamu o prostředku, který chcete monitorovat", | ||||
|     pauseMonitorMsg: "Opravdu chcete dohled pozastavit?", | ||||
|     enableDefaultNotificationDescription: "Toto oznámení bude standardně aktivní pro nové dohledy. V případě potřeby můžete oznámení stále zakázat na úrovni jednotlivých dohledů.", | ||||
|  | @ -70,7 +73,8 @@ export default { | |||
|     Port: "Port", | ||||
|     "Heartbeat Interval": "Heartbeat interval", | ||||
|     Retries: "Počet pokusů", | ||||
|     "Heartbeat Retry Interval": "Interval opakování prezenčního signálu", | ||||
|     "Heartbeat Retry Interval": "Interval opakování heartbeatu", | ||||
|     "Resend Notification if Down X times consequently": "Znovu zaslat oznámení, pokud je služba nedostupná Xkrát za sebou", | ||||
|     Advanced: "Rozšířené", | ||||
|     "Upside Down Mode": "Inverzní režim", | ||||
|     "Max. Redirects": "Max. Přesměrování", | ||||
|  | @ -195,7 +199,7 @@ export default { | |||
|     "Chat ID": "ID chatu", | ||||
|     supportTelegramChatID: "Podpora přímého chatu / skupiny / ID chatu kanálu", | ||||
|     wayToGetTelegramChatID: "ID chatu můžete získat tak, že robotovi zašlete zprávu a přejdete na tuto adresu URL, kde zobrazíte chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "YOUR BOT TOKEN HERE", | ||||
|     "YOUR BOT TOKEN HERE": "SEM ZADEJTE TOKEN VAŠEHO CHATBOTA", | ||||
|     chatIDNotFound: "ID chatu nebylo nalezeno; nejprve tomuto robotovi zašlete zprávu", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "URL adresa příspěvku", | ||||
|  | @ -241,6 +245,7 @@ export default { | |||
|     "rocket.chat": "Rocket.Chat", | ||||
|     pushover: "Pushover", | ||||
|     pushy: "Pushy", | ||||
|     PushByTechulus: "Push by Techulus", | ||||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|  | @ -301,15 +306,19 @@ export default { | |||
|     Body: "Tělo", | ||||
|     Headers: "Hlavičky", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "The request headers are not valid JSON: ", | ||||
|     BodyInvalidFormat: "The request body is not valid JSON: ", | ||||
|     HeadersInvalidFormat: "Hlaviča žádosti není platný JSON: ", | ||||
|     BodyInvalidFormat: "Text žádosti není platný JSON: ", | ||||
|     "Monitor History": "Historie dohledu", | ||||
|     clearDataOlderThan: "Historie dohledu bude uchovávána po dobu {0} dní.", | ||||
|     PasswordsDoNotMatch: "Hesla se neshodují.", | ||||
|     records: "záznamů", | ||||
|     "One record": "Jeden záznam", | ||||
|     steamApiKeyDescription: "For monitoring a Steam Game Server you need a Steam Web-API key. You can register your API key here: ", | ||||
|     steamApiKeyDescription: "Pro monitorování Steam Game Servere je nutné zadat Steam Web-API klíč. Svůj API klíč získáte na následující stránce: ", | ||||
|     "Current User": "Aktuálně přihlášený uživatel", | ||||
|     topic: "Topic", | ||||
|     topicExplanation: "MQTT topic, který chcete sledovat", | ||||
|     successMessage: "Zpráva o úspěchu", | ||||
|     successMessageExplanation: "MQTT zpráva považovaná za úspěšnou", | ||||
|     recent: "Poslední", | ||||
|     Done: "Hotovo", | ||||
|     Info: "Informace", | ||||
|  | @ -327,6 +336,8 @@ export default { | |||
|     info: "informace", | ||||
|     warning: "upozornění", | ||||
|     danger: "riziko", | ||||
|     error: "chyba", | ||||
|     critical: "kritické", | ||||
|     primary: "primární", | ||||
|     light: "světlý", | ||||
|     dark: "tmavý", | ||||
|  | @ -355,13 +366,214 @@ export default { | |||
|     serwersmsPhoneNumber: "Telefonní číslo", | ||||
|     serwersmsSenderName: "Odesílatel SMS (registrováno prostřednictvím zákaznického portálu)", | ||||
|     "stackfield": "Stackfield", | ||||
|     Customize: "Přizpůsobit", | ||||
|     "Custom Footer": "Vlastní patička", | ||||
|     "Custom CSS": "Vlastní CSS", | ||||
|     smtpDkimSettings: "Nastavení DKIM", | ||||
|     smtpDkimDesc: "Informace o použití naleznete v {0} Nodemailer DKIM.", | ||||
|     documentation: "dokumentaci", | ||||
|     smtpDkimDomain: "Název domény", | ||||
|     smtpDkimKeySelector: "Selector klíče", | ||||
|     smtpDkimKeySelector: "Selektor klíče", | ||||
|     smtpDkimPrivateKey: "Privátní klíč", | ||||
|     smtpDkimHashAlgo: "Hashovací algoritmus (volitelné)", | ||||
|     smtpDkimheaderFieldNames: "Podepisovat tyto hlavičky (volitelné)", | ||||
|     smtpDkimskipFields: "Nepodepisovat tyto hlavičky (volitelné)", | ||||
|     wayToGetPagerDutyKey: "Získat jej můžete v sekci Service -> Service Directory -> (vyberte službu) -> Integrations -> Add integration. Následně vyhledejte \"Events API V2\". Více informace naleznete na adrese {0}", | ||||
|     "Integration Key": "Integration Key", | ||||
|     "Integration URL": "Integration URL", | ||||
|     "Auto resolve or acknowledged": "Auto resolve or acknowledged", | ||||
|     "do nothing": "do nothing", | ||||
|     "auto acknowledged": "auto acknowledged", | ||||
|     "auto resolve": "auto resolve", | ||||
|     gorush: "Gorush", | ||||
|     alerta: "Alerta", | ||||
|     alertaApiEndpoint: "API Endpoint", | ||||
|     alertaEnvironment: "Prostředí", | ||||
|     alertaApiKey: "API Key", | ||||
|     alertaAlertState: "Stav upozornění", | ||||
|     alertaRecoverState: "Stav obnovení", | ||||
|     deleteStatusPageMsg: "Opravdu chcete odstranit tuto stavovou stránku?", | ||||
|     Proxies: "Proxy", | ||||
|     default: "Výchozí", | ||||
|     enabled: "Zapnuto", | ||||
|     setAsDefault: "Nastavit jako výchozí", | ||||
|     deleteProxyMsg: "Opravdu chcete odstranit tuto proxy ze všech dohledů?", | ||||
|     proxyDescription: "Pro zajištění funkčnosti musí být proxy přiřazena dohledům.", | ||||
|     enableProxyDescription: "Tato proxy neovlivní žádosti dohledu do doby, než ji aktivujete. Změnou tohoto nastavení dočasně zakážete použití proxy ve všech dohledech.", | ||||
|     setAsDefaultProxyDescription: "Tato proxy se použije pro všechny nové dohledy. V případě potřeby můžete její využívání zakázat v konkrétním dohledu.", | ||||
|     "Certificate Chain": "Řetězec certifikátu", | ||||
|     Valid: "Platný", | ||||
|     Invalid: "Neplatný", | ||||
|     AccessKeyId: "AccessKey ID", | ||||
|     SecretAccessKey: "AccessKey Secret", | ||||
|     PhoneNumbers: "PhoneNumbers", | ||||
|     TemplateCode: "TemplateCode", | ||||
|     SignName: "SignName", | ||||
|     "Sms template must contain parameters: ": "Sms template must contain parameters: ", | ||||
|     "Bark Endpoint": "Bark Endpoint", | ||||
|     "Bark Group": "Bark Group", | ||||
|     "Bark Sound": "Bark Sound", | ||||
|     WebHookUrl: "WebHookUrl", | ||||
|     SecretKey: "SecretKey", | ||||
|     "For safety, must use secret key": "Z důvodu bezpečnosti použijte secret key", | ||||
|     "Device Token": "Token zařízení", | ||||
|     Platform: "Platforma", | ||||
|     iOS: "iOS", | ||||
|     Android: "Android", | ||||
|     Huawei: "Huawei", | ||||
|     High: "Vysoký", | ||||
|     Retry: "Opakovat", | ||||
|     Topic: "Topic", | ||||
|     "WeCom Bot Key": "WeCom Bot Key", | ||||
|     "Setup Proxy": "Setup Proxy", | ||||
|     "Proxy Protocol": "Proxy Protocol", | ||||
|     "Proxy Server": "Proxy Server", | ||||
|     "Proxy server has authentication": "Proxy server vyžaduje ověření", | ||||
|     User: "Uživatel", | ||||
|     Installed: "Nainstalováno", | ||||
|     "Not installed": "Nenainstalováno", | ||||
|     Running: "Běží", | ||||
|     "Not running": "Neběží", | ||||
|     "Remove Token": "Odstranit token", | ||||
|     Start: "Spustit", | ||||
|     Stop: "Zastavit", | ||||
|     "Uptime Kuma": "Uptime Kuma", | ||||
|     "Add New Status Page": "Přidat novou stavovou stránku", | ||||
|     Slug: "Slug", | ||||
|     "Accept characters:": "Přípustné znaky:", | ||||
|     startOrEndWithOnly: "Počáteční a koncový znak může být pouze {0}", | ||||
|     "No consecutive dashes": "Nesmí se opakovat pomlčky", | ||||
|     Next: "Další", | ||||
|     "The slug is already taken. Please choose another slug.": "Slug s tímto názvem již existuje. Prosím, zadejte jiný název.", | ||||
|     "No Proxy": "Žádná proxy", | ||||
|     Authentication: "Ověření", | ||||
|     "HTTP Basic Auth": "HTTP Basic ověření", | ||||
|     "New Status Page": "Nová stavová stránka", | ||||
|     "Page Not Found": "Stránka nenalezena", | ||||
|     "Reverse Proxy": "Reverzní proxy", | ||||
|     Backup: "Záloha", | ||||
|     About: "O programu", | ||||
|     wayToGetCloudflaredURL: "(Stáhnout cloudflared z {0})", | ||||
|     cloudflareWebsite: "Webová stránka Cloudflare", | ||||
|     "Message:": "Zpráva:", | ||||
|     "Don't know how to get the token? Please read the guide:": "Nevíte jak získat? Prosím, přečtěte si tuto příručku:", | ||||
|     "The current connection may be lost if you are currently connecting via Cloudflare Tunnel. Are you sure want to stop it? Type your current password to confirm it.": "Stávající připojení mohlo být ztraceno, pokud jste připojeni prostřednictvím Cloudflare tunelu. Opravdu jej chcete zastavit? Pro potvrzení zadejte své současné heslo.", | ||||
|     "HTTP Headers": "HTTP hlavičky", | ||||
|     "Trust Proxy": "Důvěryhodná proxy", | ||||
|     "Other Software": "Jiný software", | ||||
|     "For example: nginx, Apache and Traefik.": "Například nginx, Apache nebo Traefik.", | ||||
|     "Please read": "Prosím, přečtěte si informace na adrese", | ||||
|     "Subject:": "Předmět:", | ||||
|     "Valid To:": "Platnost do:", | ||||
|     "Days Remaining:": "Počet zbývajících dní:", | ||||
|     "Issuer:": "Vydavatel:", | ||||
|     "Fingerprint:": "Otisk:", | ||||
|     "No status pages": "Žádná stavová stránka", | ||||
|     "Domain Name Expiry Notification": "Oznámení na blížící se konec platnosti doménového jména", | ||||
|     Proxy: "Proxy", | ||||
|     "Date Created": "Datum vytvoření", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     onebotHttpAddress: "OneBot HTTP adresa", | ||||
|     onebotMessageType: "Typ OneBot zprávy", | ||||
|     onebotGroupMessage: "Skupinová", | ||||
|     onebotPrivateMessage: "Soukromá", | ||||
|     onebotUserOrGroupId: "ID skupiny/uživatele", | ||||
|     onebotSafetyTips: "Z důvodu bezpečnosti je nutné zadat přístupový token", | ||||
|     "PushDeer Key": "PushDeer klíč", | ||||
|     "Footer Text": "Text v patičce", | ||||
|     "Show Powered By": "Zobrazit \"Zajišťuje\"", | ||||
|     "Domain Names": "Názvy domén", | ||||
|     signedInDisp: "Přihlášen jako {0}", | ||||
|     signedInDispDisabled: "Ověření je vypnuté.", | ||||
|     RadiusSecret: "Radius Secret", | ||||
|     RadiusSecretDescription: "Sdílený tajný klíč mezi klientem a serverem", | ||||
|     RadiusCalledStationId: "ID volaného zařízení", | ||||
|     RadiusCalledStationIdDescription: "Identifikátor volaného zařízení", | ||||
|     RadiusCallingStationId: "ID volajícího zařízení", | ||||
|     RadiusCallingStationIdDescription: "Identifikátor volajícího zařízení", | ||||
|     "Certificate Expiry Notification": "Oznámení na blížící se konec platnosti certifikátu", | ||||
|     "API Username": "API Username", | ||||
|     "API Key": "API Key", | ||||
|     "Recipient Number": "Číslo příjemce", | ||||
|     "From Name/Number": "Jméno/číslo odesílatele", | ||||
|     "Leave blank to use a shared sender number.": "Ponechte prázdné, pokud chcete použít číslo sdíleného příjemce.", | ||||
|     "Octopush API Version": "Octopush API verze", | ||||
|     "Legacy Octopush-DM": "Legacy Octopush-DM", | ||||
|     endpoint: "endpoint", | ||||
|     octopushAPIKey: "\"API key\" ze sekce HTTP API credentials na nástěnce", | ||||
|     octopushLogin: "\"Login\" ze sekce HTTP API credentials na nástěnce", | ||||
|     promosmsLogin: "API Login Name", | ||||
|     promosmsPassword: "API Password", | ||||
|     "pushoversounds pushover": "Pushover (výchozí)", | ||||
|     "pushoversounds bike": "Bike", | ||||
|     "pushoversounds bugle": "Bugle", | ||||
|     "pushoversounds cashregister": "Cash Register", | ||||
|     "pushoversounds classical": "Classical", | ||||
|     "pushoversounds cosmic": "Cosmic", | ||||
|     "pushoversounds falling": "Falling", | ||||
|     "pushoversounds gamelan": "Gamelan", | ||||
|     "pushoversounds incoming": "Incoming", | ||||
|     "pushoversounds intermission": "Intermission", | ||||
|     "pushoversounds magic": "Magic", | ||||
|     "pushoversounds mechanical": "Mechanical", | ||||
|     "pushoversounds pianobar": "Piano Bar", | ||||
|     "pushoversounds siren": "Siren", | ||||
|     "pushoversounds spacealarm": "Space Alarm", | ||||
|     "pushoversounds tugboat": "Tug Boat", | ||||
|     "pushoversounds alien": "Alien Alarm (dlouhý)", | ||||
|     "pushoversounds climb": "Climb (dlouhý)", | ||||
|     "pushoversounds persistent": "Persistent (dlouhý)", | ||||
|     "pushoversounds echo": "Pushover Echo (dlouhý)", | ||||
|     "pushoversounds updown": "Up Down (dlouhý)", | ||||
|     "pushoversounds vibrate": "Pouze vibrace", | ||||
|     "pushoversounds none": "Žádný (ticho)", | ||||
|     pushyAPIKey: "Secret API Key", | ||||
|     pushyToken: "Token zařízení", | ||||
|     "Show update if available": "Zobrazit aktualizace, pokud jsou k dispozici", | ||||
|     "Also check beta release": "Kontrolovat také dostupnost beta verzí", | ||||
|     "Using a Reverse Proxy?": "Používáte reverzní proxy??", | ||||
|     "Check how to config it for WebSocket": "Zjistěte, jak ji nakonfigurovat pro WebSockety", | ||||
|     "Steam Game Server": "Steam Game Server", | ||||
|     "Most likely causes:": "Nejčastější důvody:", | ||||
|     "The resource is no longer available.": "Zdroj již není k dispozici.", | ||||
|     "There might be a typing error in the address.": "Při zadávání adresy jste udělali chybu.", | ||||
|     "What you can try:": "Co můžete vyzkoušet:", | ||||
|     "Retype the address.": "Znovu zadat adresu.", | ||||
|     "Go back to the previous page.": "Vrátit se na předchozí stránku.", | ||||
|     "Coming Soon": "Připravujeme", | ||||
|     wayToGetClickSendSMSToken: "API Username a API Key získáte na adrese {0} .", | ||||
|     "Connection String": "Connection String", | ||||
|     Query: "Dotaz", | ||||
|     settingsCertificateExpiry: "Platnost TLS certifikátu", | ||||
|     certificationExpiryDescription: "Aktivovat oznámení nad HTTPS dohledy, pokud platnost TSL certifikátu vyprší za:", | ||||
|     "Setup Docker Host": "Nastavit Docker hostitele", | ||||
|     "Connection Type": "Typ připojení", | ||||
|     "Docker Daemon": "Docker Daemon", | ||||
|     deleteDockerHostMsg: "Opravdu chcete odstranit tohoto docker hostitele ze všech dohledů?", | ||||
|     socket: "Socket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker kontejner", | ||||
|     "Container Name / ID": "ID / název kontejneru", | ||||
|     "Docker Host": "Docker hostitel", | ||||
|     "Docker Hosts": "Docker hostitelé", | ||||
|     "ntfy Topic": "ntfy Topic", | ||||
|     "Domain": "Doména", | ||||
|     "Workstation": "Pracovní stanice", | ||||
|     disableCloudflaredNoAuthMsg: "Používáte režim bez ověření, heslo není vyžadováno.", | ||||
|     trustProxyDescription: "Důvěřovat 'X-Forwarded-*' hlavičkám. Pokud chcete získat správnou IP adresu klientů a vaše instance Uptime Kuma je schována za Nginx nebo Apache, měli byste tuto možnost zapnout.", | ||||
|     wayToGetLineNotifyToken: "Přístupový token můžete získat na adrese {0}", | ||||
|     Examples: "Příklady", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token": "Dlouhodobý přístupový token", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Pro vytvoření dlouhodobého přístupový tokenu klikněte na název svého profilu (v levém dolním rohu) a následně v dolní části stránky klikněte na tlačítko Create Token. ", | ||||
|     "Notification Service": "Oznamovací služba", | ||||
|     "default: notify all devices": "výchozí: upozornit všechny zařízení", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "Seznam dostupných oznamovacích služeb naleznete v Home Assistant v sekci \"Developer Tools > Services\", kde vyhledejte \"notification\" pro zjištění názvu zařízení.", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Automatizaci můžete volitelně aktivovat prostřednictvím Home Assistant:", | ||||
|     "Trigger type:": "Typ podmínky spuštění:", | ||||
|     "Event type:": "Typ události:", | ||||
|     "Event data:": "Data události:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Následně vyberte akci, například přepnutí scény z RGB světla na červenou.", | ||||
|     "Frontend Version": "Verze frontendu", | ||||
|     "Frontend Version do not match backend version!": "Verze frontendu neodpovídá verzi backendu!", | ||||
| }; | ||||
|  |  | |||
|  | @ -458,4 +458,122 @@ export default { | |||
|     "Domain Names": "Domainnamen", | ||||
|     signedInDisp: "Angemeldet als {0}", | ||||
|     signedInDispDisabled: "Authentifizierung deaktiviert.", | ||||
|     dnsPortDescription: "DNS server port. Standard ist 53. Der Port kann jederzeit geändert werden.", | ||||
|     topic: "Thema", | ||||
|     topicExplanation: "MQTT Thema für den monitor", | ||||
|     successMessage: "Erfolgsnachricht", | ||||
|     successMessageExplanation: "MQTT Nachricht, die als Erfolg angesehen wird", | ||||
|     error: "Fehler", | ||||
|     critical: "kritisch", | ||||
|     wayToGetPagerDutyKey: "Dieser kann unter Service -> Service Directory -> (Select a service) -> Integrations -> Add integration gefunden werden. Hier muss nach \"Events API V2\" gesucht werden. Mehr informationen {0}", | ||||
|     "Integration Key": "Schlüssel der Integration", | ||||
|     "Integration URL": "URL der Integration", | ||||
|     "Auto resolve or acknowledged": "Automatisch lösen oder bestätigen", | ||||
|     "do nothing": "nichts tun", | ||||
|     "auto acknowledged": "automatisch bestätigen", | ||||
|     "auto resolve": "automatisch lösen", | ||||
|     "Bark Group": "Bark Gruppe", | ||||
|     "Bark Sound": "Bark Klang", | ||||
|     "HTTP Headers": "HTTP Kopfzeilen", | ||||
|     "Trust Proxy": "Vertrauenswürdiger Proxy", | ||||
|     Proxy: "Proxy", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     onebotHttpAddress: "OneBot HTTP Adresse", | ||||
|     onebotMessageType: "OneBot Nachrichtentyp", | ||||
|     onebotGroupMessage: "Gruppe", | ||||
|     onebotPrivateMessage: "Privat", | ||||
|     onebotUserOrGroupId: "Gruppe/Nutzer ID", | ||||
|     onebotSafetyTips: "Zur Sicherheit ein access token setzen", | ||||
|     "PushDeer Key": "PushDeer Schlüssel", | ||||
|     RadiusSecret: "Radius Geheimnis", | ||||
|     RadiusSecretDescription: "Geteiltes Geheimnis zwischen Client und Server", | ||||
|     RadiusCalledStationId: "ID der angesprochenen Station", | ||||
|     RadiusCalledStationIdDescription: "Identifikation des angesprochenen Geräts", | ||||
|     RadiusCallingStationId: "ID der ansprechenden Station", | ||||
|     RadiusCallingStationIdDescription: "Identifikation des ansprechenden Geräts", | ||||
|     "Certificate Expiry Notification": "Benachrichtigung ablaufendes Zertifikat", | ||||
|     "API Username": "API Nutzername", | ||||
|     "API Key": "API Schlüssel", | ||||
|     "Recipient Number": "Empfängernummer", | ||||
|     "From Name/Number": "Von Name/Nummer", | ||||
|     "Leave blank to use a shared sender number.": "Leer lassen um eine geteilte Sendernummer zu nutzen.", | ||||
|     "Octopush API Version": "Octopush API Version", | ||||
|     "Legacy Octopush-DM": "Legacy Octopush-DM", | ||||
|     endpoint: "Endpunkt", | ||||
|     octopushAPIKey: "\"API Schlüssel\" der HTTP API Zugangsdaten im control panel", | ||||
|     octopushLogin: "\"Login\" der HTTP API Zugangsdaten im control panel", | ||||
|     promosmsLogin: "API Login Name", | ||||
|     promosmsPassword: "API Password", | ||||
|     "pushoversounds pushover": "Pushover (Standard)", | ||||
|     "pushoversounds bike": "Fahrrad", | ||||
|     "pushoversounds bugle": "Signalhorn", | ||||
|     "pushoversounds cashregister": "Kasse", | ||||
|     "pushoversounds classical": "Klassisch", | ||||
|     "pushoversounds cosmic": "Kosmisch", | ||||
|     "pushoversounds falling": "Abfallend", | ||||
|     "pushoversounds gamelan": "Gamelan", | ||||
|     "pushoversounds incoming": "Eingang", | ||||
|     "pushoversounds intermission": "Pause", | ||||
|     "pushoversounds magic": "Magisch", | ||||
|     "pushoversounds mechanical": "Mechanisch", | ||||
|     "pushoversounds pianobar": "Piano Bar", | ||||
|     "pushoversounds siren": "Sirene", | ||||
|     "pushoversounds spacealarm": "Space Alarm", | ||||
|     "pushoversounds tugboat": "Schlepper Horn", | ||||
|     "pushoversounds alien": "Außerirdisch (lang)", | ||||
|     "pushoversounds climb": "Ansteigende (lang)", | ||||
|     "pushoversounds persistent": "Hartnäckig (lang)", | ||||
|     "pushoversounds echo": "Pushover Echo (lang)", | ||||
|     "pushoversounds updown": "Auf und Ab (lang)", | ||||
|     "pushoversounds vibrate": "Nur vibrieren", | ||||
|     "pushoversounds none": "Nichts (Stille)", | ||||
|     pushyAPIKey: "Geheimer API Schlüssel", | ||||
|     pushyToken: "Gerätetoken", | ||||
|     "Show update if available": "Verfügbare Updates anzeigen", | ||||
|     "Also check beta release": "Auch nach beta Versionen schauen", | ||||
|     "Using a Reverse Proxy?": "Wird ein Reverse Proxy genutzt?", | ||||
|     "Check how to config it for WebSocket": "Prüfen, wie er für die Nutzung mit WebSocket konfiguriert wird", | ||||
|     "Steam Game Server": "Steam Game Server", | ||||
|     "Most likely causes:": "Wahrscheinliche Ursachen:", | ||||
|     "The resource is no longer available.": "Die Quelle ist nicht mehr verfügbar.", | ||||
|     "There might be a typing error in the address.": "Es gibt einen Tippfehler in der Adresse.", | ||||
|     "What you can try:": "Was du versuchen kannst:", | ||||
|     "Retype the address.": "Schreibe die Adresse erneut.", | ||||
|     "Go back to the previous page.": "Gehe zur vorigen Seite.", | ||||
|     "Coming Soon": "Kommt bald", | ||||
|     wayToGetClickSendSMSToken: "Du kannst einen API Nutzernamen und Schlüssel unter {0} erhalten.", | ||||
|     "Connection String": "Verbindungstext", | ||||
|     Query: "Abfrage", | ||||
|     settingsCertificateExpiry: "TLS Zertifikatsablauf", | ||||
|     certificationExpiryDescription: "HTTPS Monitore senden eine Benachrichtigung, wenn das Zertifikat abläuft in:", | ||||
|     "Setup Docker Host": "Docker Host einrichten", | ||||
|     "Connection Type": "Verbindungstyp", | ||||
|     "Docker Daemon": "Docker Daemon", | ||||
|     deleteDockerHostMsg: "Bist du sicher diesen docker host für alle Monitore zu löschen?", | ||||
|     socket: "Socket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker Container", | ||||
|     "Container Name / ID": "Container Name / ID", | ||||
|     "Docker Host": "Docker Host", | ||||
|     "Docker Hosts": "Docker Hosts", | ||||
|     "ntfy Topic": "ntfy Thema", | ||||
|     Domain: "Domain", | ||||
|     Workstation: "Workstation", | ||||
|     disableCloudflaredNoAuthMsg: "Du bist im nicht-authentifizieren modus, ein Passwort wird nicht benötigt.", | ||||
|     trustProxyDescription: "Vertraue 'X-Forwarded-*' headern. Wenn man die richtige client IP haben möchte und Uptime Kuma hinter einem Proxy wie Nginx or Apache läuft, wollte dies aktiviert werden.", | ||||
|     wayToGetLineNotifyToken: "Du kannst hier ein Token erhalten: {0}", | ||||
|     Examples: "Beispiele", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token": "Lange gültiges Access Token", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Lange gültige Access Token  können durch klicken auf den Profilnamen (unten links) und dann einen Klick auf Create Token am Ende erstellt werden. ", | ||||
|     "Notification Service": "Benachrichtigungsdienst", | ||||
|     "default: notify all devices": "standard: Alle Geräte benachrichtigen", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "Eine Liste der Benachrichtigungsdiesnte kann im Home Assistant unter \"Developer Tools > Services\" gefunden werden, wnen man nach \"notification\" sucht um den Geräte-/Telefonnamen zu finden.", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Automatisierungen können optional im Home Assistant ausgelöst werden:", | ||||
|     "Trigger type:": "Auslösertyp:", | ||||
|     "Event type:": "Ereignistyp:", | ||||
|     "Event data:": "Ereignis daten:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Dann eine Aktion wählen, zum Beispiel eine Scene wählen in der ein RGB Licht rot ist.", | ||||
|     "Frontend Version": "Frontend Version", | ||||
|     "Frontend Version do not match backend version!": "Die Frontend Version stimmt nicht mit der backend version überein!", | ||||
| }; | ||||
|  |  | |||
|  | @ -559,9 +559,29 @@ export default { | |||
|     "Docker Host": "Docker Host", | ||||
|     "Docker Hosts": "Docker Hosts", | ||||
|     "ntfy Topic": "ntfy Topic", | ||||
|     "Domain": "Domain", | ||||
|     "Workstation": "Workstation", | ||||
|     disableCloudflaredNoAuthMsg: "You are in No Auth mode, password is not require.", | ||||
|     Domain: "Domain", | ||||
|     Workstation: "Workstation", | ||||
|     disableCloudflaredNoAuthMsg: "You are in No Auth mode, a password is not required.", | ||||
|     trustProxyDescription: "Trust 'X-Forwarded-*' headers. If you want to get the correct client IP and your Uptime Kuma is behind such as Nginx or Apache, you should enable this.", | ||||
|     wayToGetLineNotifyToken: "You can get an access token from {0}", | ||||
|     Examples: "Examples", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token": "Long-Lived Access Token", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ", | ||||
|     "Notification Service": "Notification Service", | ||||
|     "default: notify all devices": "default: notify all devices", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Automations can optionally be triggered in Home Assistant:", | ||||
|     "Trigger type:": "Trigger type:", | ||||
|     "Event type:": "Event type:", | ||||
|     "Event data:": "Event data:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Then choose an action, for example switch the scene to where an RGB light is red.", | ||||
|     "Frontend Version": "Frontend Version", | ||||
|     "Frontend Version do not match backend version!": "Frontend Version do not match backend version!", | ||||
|     "Base URL": "Base URL", | ||||
|     goAlertInfo: "GoAlert is a An open source application for on-call scheduling, automated escalations and notifications (like SMS or voice calls). Automatically engage the right person, the right way, and at the right time! {0}", | ||||
|     goAlertIntegrationKeyInfo: "Get generic API integration key for the service in this format \"aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee\" usually the value of token parameter of copied URL.", | ||||
|     goAlert: "GoAlert", | ||||
|     backupOutdatedWarning: "Deprecated: Since a lot of features added and this backup feature is a bit unmaintained, it cannot generate or restore a complete backup.", | ||||
|     backupRecommend: "Please backup the volume or the data folder (./data/) directly instead.", | ||||
| }; | ||||
|  |  | |||
|  | @ -177,8 +177,16 @@ export default { | |||
|     "Add a monitor": "Ajouter une sonde", | ||||
|     "Edit Status Page": "Modifier la page de statut", | ||||
|     "Go to Dashboard": "Accéder au tableau de bord", | ||||
|     "Status Page": "Status Page", | ||||
|     "Status Pages": "Status Pages", | ||||
|     "Status Page": "Page de statut", | ||||
|     "Status Pages": "Pages de statut", | ||||
|     "New Status Page": "Ajouter page de statut", | ||||
|     "Add New Status Page": "Ajouter une page de statut", | ||||
|     "No status pages": "Aucune page de statut.", | ||||
|     "Accept characters:": "Caractères acceptés:", | ||||
|     startOrEndWithOnly: "Commence uniquement par {0}", | ||||
|     "No consecutive dashes": "Pas de double tirets", | ||||
|     Next: "Continuer", | ||||
|     "Setup Proxy": "Configuer Proxy", | ||||
|     defaultNotificationName: "Ma notification {notification} numéro ({number})", | ||||
|     here: "ici", | ||||
|     Required: "Requis", | ||||
|  | @ -236,7 +244,7 @@ export default { | |||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (Support 50+ Notification services)", | ||||
|     apprise: "Apprise (Prend en charge plus de 50 services de notification)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|  | @ -261,7 +269,7 @@ export default { | |||
|     "Read more": "En savoir plus", | ||||
|     appriseInstalled: "Apprise est installé.", | ||||
|     appriseNotInstalled: "Apprise n'est pas installé. {0}", | ||||
|     "Access Token": "Access Token", | ||||
|     "Access Token": "Token d'accès", | ||||
|     "Channel access token": "Token d'accès au canal", | ||||
|     "Line Developers Console": "Ligne console de développeurs", | ||||
|     lineDevConsoleTo: "Ligne console de développeurs - {0}", | ||||
|  | @ -309,4 +317,118 @@ export default { | |||
|     alertaApiKey: "Clé de l'API", | ||||
|     alertaAlertState: "État de l'Alerte", | ||||
|     alertaRecoverState: "État de récupération", | ||||
|     resendEveryXTimes: "Renvoyez toutes les {0} fois", | ||||
|     resendDisabled: "Renvoi désactivé", | ||||
|     dnsPortDescription: "Port du serveur DNS. La valeur par défaut est 53. Vous pouvez modifier le port à tout moment.", | ||||
|     "Resend Notification if Down X times consequently": "Renvoyer la notification a partir d'un certain temps", | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "Vous devez appeler cette URL toutes les {0} secondes.", | ||||
|     pushOptionalParams: "parametres optionnels: {0}", | ||||
|     "disableauth.message1": "Voulez-vous vraiment <strong>désactiver l'authentification</strong>?", | ||||
|     "disableauth.message2": "Il est conçu pour les scénarios <strong>où vous avez l'intention d'implémenter une authentification tierce</strong> devant Uptime Kuma, comme Cloudflare Access, Authelia ou d'autres mécanismes d'authentification.", | ||||
|     "Please use this option carefully!": "Veuillez utiliser cette option avec précaution !", | ||||
|     PushByTechulus: "Pousser par Techulus", | ||||
|     GoogleChat: "Google Chat (Google Workspace uniquement)", | ||||
|     Done: "Fait", | ||||
|     Info: "Info", | ||||
|     Security: "Sécurité", | ||||
|     "Steam API Key": "Clé API Steam", | ||||
|     "Shrink Database": "Réduire la base de données", | ||||
|     "Pick a RR-Type...": "Pick a RR-Type...", | ||||
|     "Pick Accepted Status Codes...": "Pick Accepted Status Codes...", | ||||
|     Default: "Défaut", | ||||
|     "HTTP Options": "HTTP Options", | ||||
|     "Create Incident": "Créer un incident", | ||||
|     Title: "Titre", | ||||
|     Content: "Contenu", | ||||
|     Style: "Style", | ||||
|     info: "info", | ||||
|     warning: "Attention", | ||||
|     danger: "danger", | ||||
|     error: "Erreur", | ||||
|     critical: "critique", | ||||
|     primary: "primaire", | ||||
|     light: "blanc", | ||||
|     dark: "Noir", | ||||
|     Post: "Post", | ||||
|     "Please input title and content": "Veuillez entrer le titre et le contenu", | ||||
|     Created: "Created", | ||||
|     "Last Updated": "Dernière mise à jour", | ||||
|     Unpin: "Détacher", | ||||
|     "Switch to Light Theme": "Passer au thème clair", | ||||
|     "Switch to Dark Theme": "Passer au thème sombre", | ||||
|     "Show Tags": "Voir les étiquettes", | ||||
|     "Hide Tags": "Masquer les étiquettes", | ||||
|     Description: "Description", | ||||
|     "No monitors available.": "Aucun moniteur disponible.", | ||||
|     "Add one": "En rajouter un", | ||||
|     "No Monitors": "Aucun moniteur", | ||||
|     "Untitled Group": "Groupe sans titre", | ||||
|     Services: "Services", | ||||
|     Discard: "Annuler", | ||||
|     Cancel: "Annuler", | ||||
|     shrinkDatabaseDescription: "Déclencher la base de données VACUUM pour SQLite. Si votre base de données est créée après 1.10.0, AUTO_VACUUM est déjà activé et cette action n'est pas nécessaire.", | ||||
|     serwersmsAPIUser: "Nom d'utilisateur de l'API (incl. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "Mot de passe API", | ||||
|     serwersmsPhoneNumber: "Numéro de téléphone", | ||||
|     serwersmsSenderName: "Nom de l'expéditeur du SMS (enregistré via le portail client)", | ||||
|     Customize: "Personnaliser", | ||||
|     "Custom Footer": "Pied de page personnalisé", | ||||
|     "Custom CSS": "CSS personnalisé", | ||||
|     deleteStatusPageMsg: "Voulez-vous vraiment supprimer cette page d'état ?", | ||||
|     Proxies: "Proxies", | ||||
|     default: "Défaut", | ||||
|     enabled: "Activé", | ||||
|     setAsDefault: "Définir par défaut", | ||||
|     deleteProxyMsg: "Voulez-vous vraiment supprimer ce proxy pour tous les moniteurs ?", | ||||
|     proxyDescription: "Les proxys doivent être affectés à un moniteur pour fonctionner.", | ||||
|     enableProxyDescription: "Ce proxy n'aura pas d'effet sur les demandes de moniteur tant qu'il n'est pas activé. Vous pouvez contrôler la désactivation temporaire du proxy de tous les moniteurs en fonction de l'état d'activation.", | ||||
|     setAsDefaultProxyDescription: "Ce proxy sera activé par défaut pour les nouveaux moniteurs. Vous pouvez toujours désactiver le proxy séparément pour chaque moniteur.", | ||||
|     Valid: "Valide", | ||||
|     Invalid: "Non valide", | ||||
|     User: "Utilisateur", | ||||
|     Installed: "Installé", | ||||
|     "Not installed": "Pas installé", | ||||
|     "Remove Token": "Supprimer le jeton", | ||||
|     Slug: "chemin", | ||||
|     "The slug is already taken. Please choose another slug.": "Le chemin est déjà pris. Veuillez choisir un autre chemin.", | ||||
|     Authentication: "Authentication", | ||||
|     "Page Not Found": "Page non trouvée", | ||||
|     Backup: "Sauvegarde", | ||||
|     About: "À propos de", | ||||
|     "Footer Text": "Texte de pied de page", | ||||
|     "Domain Names": "Noms de domaine", | ||||
|     signedInDisp: "Connecté en tant que {0}", | ||||
|     signedInDispDisabled: "Authentification désactivée.", | ||||
|     "Show update if available": "Afficher la mise à jour si disponible", | ||||
|     "Also check beta release": "Vérifiez également la version bêta", | ||||
|     "Steam Game Server": "Serveur de jeu Steam", | ||||
|     "Most likely causes:": "Causes les plus probables:", | ||||
|     "The resource is no longer available.": "La ressource n'est plus disponible.", | ||||
|     "There might be a typing error in the address.": "Il se peut qu'il y ait une erreur de frappe dans l'adresse.", | ||||
|     "What you can try:": "Ce que vous pouvez essayer:", | ||||
|     "Retype the address.": "Retapez l'adresse.", | ||||
|     "Go back to the previous page.": "Retournez à la page précédente.", | ||||
|     "Coming Soon": "À venir", | ||||
|     settingsCertificateExpiry: "Expiration du certificat TLS", | ||||
|     certificationExpiryDescription: "Les moniteurs HTTPS déclenchent une notification lorsque le certificat TLS expire dans:", | ||||
|     "Setup Docker Host": "Configurer l'hôte Docker", | ||||
|     "Connection Type": "Type de connexion", | ||||
|     deleteDockerHostMsg: "Voulez-vous vraiment supprimer cet hôte Docker pour tous les moniteurs ?", | ||||
|     "Container Name / ID": "Nom / ID du conteneur", | ||||
|     "Docker Host": "Hôte Docker", | ||||
|     "Docker Hosts": "Hôtes Docker", | ||||
|     Domain: "Domaine", | ||||
|     trustProxyDescription: "Faire confiance aux en-têtes 'X-Forwarded-*'. Si vous souhaitez obtenir la bonne adresse IP client et que votre Uptime Kuma est en retard, comme Nginx ou Apache, vous devez l'activer.", | ||||
|     wayToGetLineNotifyToken: "Vous pouvez obtenir un jeton d'accès auprès de {0}", | ||||
|     Examples: "Exemples", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Un jeton d'accès de longue durée peut être créé en cliquant sur le nom de votre profil (en bas à gauche) et en faisant défiler vers le bas, puis cliquez sur Créer un jeton. ", | ||||
|     "Notification Service": "Service de notifications", | ||||
|     "default: notify all devices": "par défaut: notifier tous les appareils", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "Une liste des services de notification peut être trouvée dans Home Assistant sous \"Outils de développement > Services\" recherchez \"notification\" pour trouver le nom de votre appareil/téléphone.", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Les automatisations peuvent éventuellement être déclenchées dans Home Assistant:", | ||||
|     "Trigger type:": "Type de déclencheur:", | ||||
|     "Event type:": "Type d'événement:", | ||||
|     "Event data:": "Données d'événement:", | ||||
| }; | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ export default { | |||
|     pushOptionalParams: "Neobavezni parametri: {0}", | ||||
|     Save: "Spremi", | ||||
|     Notifications: "Obavijesti", | ||||
|     "Not available, please setup.": "Obavijesti nisu dostupne, potrebno dodati novu obavijest.", | ||||
|     "Not available, please setup.": "Nije dostupno, potrebno je dodati novu stavku.", | ||||
|     "Setup Notification": "Dodaj obavijest", | ||||
|     Light: "Svijetli način", | ||||
|     Dark: "Tamni način", | ||||
|  | @ -129,7 +129,7 @@ export default { | |||
|     Export: "Izvoz", | ||||
|     Import: "Uvoz", | ||||
|     respTime: "Vrijeme odgovora (ms)", | ||||
|     notAvailableShort: "N/A", | ||||
|     notAvailableShort: "ne postoji", | ||||
|     "Default enabled": "Omogući za nove monitore", | ||||
|     "Apply on all existing monitors": "Primijeni na postojeće monitore", | ||||
|     Create: "Kreiraj", | ||||
|  | @ -375,4 +375,207 @@ export default { | |||
|     alertaAlertState: "Stanje upozorenja", | ||||
|     alertaRecoverState: "Stanje oporavka", | ||||
|     deleteStatusPageMsg: "Sigurno želite obrisati ovu statusnu stranicu?", | ||||
|     resendEveryXTimes: "Ponovno pošalji svakih {0} puta", | ||||
|     resendDisabled: "Ponovno slanje je onemogućeno", | ||||
|     dnsPortDescription: "Port DNS poslužitelja. Zadana vrijednost je 53. Moguće je promijeniti ga u svakom trenutku.", | ||||
|     "Resend Notification if Down X times consequently": "Ponovno pošalji obavijest ako je usluga nedostupna više puta zaredom", | ||||
|     topic: "Tema", | ||||
|     topicExplanation: "MQTT tema koja će se monitorirati", | ||||
|     successMessage: "Poruka o uspjehu", | ||||
|     successMessageExplanation: "MQTT poruka koja se smatra uspješnom", | ||||
|     error: "greška", | ||||
|     critical: "kritično", | ||||
|     Customize: "Customize", | ||||
|     "Custom Footer": "Prilagođeno podnožje", | ||||
|     "Custom CSS": "Prilagođeni CSS", | ||||
|     wayToGetPagerDutyKey: "Ključ možete dobiti odlaskom na \"Service -> Service Directory -> (Odabrani servis) -> Integrations -> Add integration\". Ovdje pretražite za \"Events API V2\". Više informacija {0}", | ||||
|     "Integration Key": "Ključ integracije", | ||||
|     "Integration URL": "URL integracije", | ||||
|     "Auto resolve or acknowledged": "Automatsko razrješavanje i priznavanje", | ||||
|     "do nothing": "Ne radi ništa", | ||||
|     "auto acknowledged": "Automatsko priznavanje", | ||||
|     "auto resolve": "Automatsko razrješavanje", | ||||
|     Proxies: "Proxy poslužitelji", | ||||
|     default: "Zadano", | ||||
|     enabled: "Omogućeno", | ||||
|     setAsDefault: "Postavi kao zadano", | ||||
|     deleteProxyMsg: "Sigurno želite obrisati ovaj proxy za sve monitore?", | ||||
|     proxyDescription: "Proxy poslužitelji moraju biti dodijeljni monitoru kako bi funkcionirali.", | ||||
|     enableProxyDescription: "Onemogućeni proxy poslužitelj neće imati učinak na zahtjeve monitora. Možete privremeno onemogućiti proxy poslužitelja za sve monitore.", | ||||
|     setAsDefaultProxyDescription: "Ovaj proxy poslužitelj bit će odmah omogućen za nove monitore. I dalje ga možete onemogućiti za svaki monitor zasebno.", | ||||
|     "Certificate Chain": "Lanac certifikata", | ||||
|     Valid: "Važeći", | ||||
|     Invalid: "Nevažeći", | ||||
|     AccessKeyId: "AccessKey ID", | ||||
|     SecretAccessKey: "AccessKey tajni ključ", | ||||
|     PhoneNumbers: "Telefonski brojevi", | ||||
|     TemplateCode: "Predložak koda", | ||||
|     SignName: "Potpis", | ||||
|     "Sms template must contain parameters: ": "SMS predložak mora sadržavati parametre: ", | ||||
|     "Bark Endpoint": "Bark krajnja točka (endpoint)", | ||||
|     "Bark Group": "Bark grupa", | ||||
|     "Bark Sound": "Bark zvuk", | ||||
|     WebHookUrl: "WebHookUrl", | ||||
|     SecretKey: "Tajni ključ", | ||||
|     "For safety, must use secret key": "Korištenje tajnog ključa je obavezno", | ||||
|     "Device Token": "Token uređaja", | ||||
|     Platform: "Platforma", | ||||
|     iOS: "iOS", | ||||
|     Android: "Android", | ||||
|     Huawei: "Huawei", | ||||
|     High: "Visoko", | ||||
|     Retry: "Ponovnih pokušaja", | ||||
|     Topic: "Tema", | ||||
|     "WeCom Bot Key": "WeCom ključ Bota", | ||||
|     "Setup Proxy": "Dodaj proxy poslužitelj", | ||||
|     "Proxy Protocol": "Protokol", | ||||
|     "Proxy Server": "Proxy poslužitelj", | ||||
|     "Proxy server has authentication": "Proxy poslužitelj ima autentikaciju", | ||||
|     User: "Korisnik", | ||||
|     Installed: "Instalirano", | ||||
|     "Not installed": "Nije instalirano", | ||||
|     Running: "Pokrenuto", | ||||
|     "Not running": "Nije pokrenuto", | ||||
|     "Remove Token": "Ukloni Token", | ||||
|     Start: "Pokreni", | ||||
|     Stop: "Zaustavi", | ||||
|     "Uptime Kuma": "Uptime Kuma", | ||||
|     "Add New Status Page": "Dodaj novu statusnu stranicu", | ||||
|     Slug: "Slug", | ||||
|     "Accept characters:": "Dozvoljeni znakovi:", | ||||
|     startOrEndWithOnly: "Započinje ili završava znakovima {0}", | ||||
|     "No consecutive dashes": "Bez uzastopnih povlaka", | ||||
|     Next: "Sljedeće", | ||||
|     "The slug is already taken. Please choose another slug.": "Slug je zauzet. Odaberite novi slug.", | ||||
|     "No Proxy": "Bez proxy poslužitelja", | ||||
|     Authentication: "Autentikacija", | ||||
|     "HTTP Basic Auth": "HTTP Basic Auth", | ||||
|     "New Status Page": "Dodaj statusnu stranicu", | ||||
|     "Page Not Found": "Stranica nije pronađena", | ||||
|     "Reverse Proxy": "Reverzni proxy", | ||||
|     Backup: "Sigurnosno kopiranje", | ||||
|     About: "O Uptime Kumi", | ||||
|     wayToGetCloudflaredURL: "(Preuzmite cloudflared s {0})", | ||||
|     cloudflareWebsite: "Cloudflare web stranice", | ||||
|     "Message:": "Poruka:", | ||||
|     "Don't know how to get the token? Please read the guide:": "Ne znate kako doći do tokena? Pročitajte vodič:", | ||||
|     "The current connection may be lost if you are currently connecting via Cloudflare Tunnel. Are you sure want to stop it? Type your current password to confirm it.": "Trenutna veza možda bude prekinuta jer se koristi Cloudflare tuneliranje. Sigurno želite zaustaviti? Unesite lozinku za potvrdu.", | ||||
|     "HTTP Headers": "HTTP zaglavlja", | ||||
|     "Trust Proxy": "Vjeruj proxy poslužitelju", | ||||
|     "Other Software": "Ostali programi", | ||||
|     "For example: nginx, Apache and Traefik.": "Primjerice: nginx, Apache ili Traefik.", | ||||
|     "Please read": "Molimo pročitajte", | ||||
|     "Subject:": "Predmet:", | ||||
|     "Valid To:": "Valjano do:", | ||||
|     "Days Remaining:": "Preostalo dana:", | ||||
|     "Issuer:": "Izdavatelj:", | ||||
|     "Fingerprint:": "Fingerprint:", | ||||
|     "No status pages": "Nema statusnih stranica", | ||||
|     "Domain Name Expiry Notification": "Obavijest za istek domena", | ||||
|     Proxy: "Proxy", | ||||
|     "Date Created": "Datum stvaranja", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     onebotHttpAddress: "OneBot HTTP adresa", | ||||
|     onebotMessageType: "OneBot tip poruke", | ||||
|     onebotGroupMessage: "Grupna", | ||||
|     onebotPrivateMessage: "Privatna", | ||||
|     onebotUserOrGroupId: "ID korisnika/grupe", | ||||
|     onebotSafetyTips: "Pristupni token mora biti postavljen", | ||||
|     "PushDeer Key": "PushDeer ključ", | ||||
|     "Footer Text": "Tekst podnožja", | ||||
|     "Show Powered By": "Pokaži natpis 'Pokreće...'", | ||||
|     "Domain Names": "Domene", | ||||
|     signedInDisp: "Prijavljeni ste kao {0}", | ||||
|     signedInDispDisabled: "Autentikacija onemogućena.", | ||||
|     RadiusSecret: "Radius Tajna", | ||||
|     RadiusSecretDescription: "Dijeljena Tajna između klijenta i poslužitelja", | ||||
|     RadiusCalledStationId: "Called Station ID", | ||||
|     RadiusCalledStationIdDescription: "Identifikator pozivne stanice", | ||||
|     RadiusCallingStationId: "Calling Station ID", | ||||
|     RadiusCallingStationIdDescription: "Identifikator pozivajuće stanice", | ||||
|     "Certificate Expiry Notification": "Obavijest za istek certifikata", | ||||
|     "API Username": "API korisničko ime", | ||||
|     "API Key": "API ključ", | ||||
|     "Recipient Number": "Broj primatelja", | ||||
|     "From Name/Number": "Naziv/broj pošiljatelja", | ||||
|     "Leave blank to use a shared sender number.": "Ostaviti prazno za korištenje dijeljenog broja pošiljatelja.", | ||||
|     "Octopush API Version": "Octopush verzija API-ja", | ||||
|     "Legacy Octopush-DM": "Legacy Octopush-DM", | ||||
|     endpoint: "krajnja točka (endpoint)", | ||||
|     octopushAPIKey: "\"API ključ\" iz HTTP API postavki", | ||||
|     octopushLogin: "\"Korisničko ime\" iz HTTP API postavki", | ||||
|     promosmsLogin: "API korisničko ime", | ||||
|     promosmsPassword: "API lozinka", | ||||
|     "pushoversounds pushover": "Pushover (default)", | ||||
|     "pushoversounds bike": "Bike", | ||||
|     "pushoversounds bugle": "Bugle", | ||||
|     "pushoversounds cashregister": "Cash Register", | ||||
|     "pushoversounds classical": "Classical", | ||||
|     "pushoversounds cosmic": "Cosmic", | ||||
|     "pushoversounds falling": "Falling", | ||||
|     "pushoversounds gamelan": "Gamelan", | ||||
|     "pushoversounds incoming": "Incoming", | ||||
|     "pushoversounds intermission": "Intermission", | ||||
|     "pushoversounds magic": "Magic", | ||||
|     "pushoversounds mechanical": "Mechanical", | ||||
|     "pushoversounds pianobar": "Piano Bar", | ||||
|     "pushoversounds siren": "Siren", | ||||
|     "pushoversounds spacealarm": "Space Alarm", | ||||
|     "pushoversounds tugboat": "Tug Boat", | ||||
|     "pushoversounds alien": "Alien Alarm (long)", | ||||
|     "pushoversounds climb": "Climb (long)", | ||||
|     "pushoversounds persistent": "Persistent (long)", | ||||
|     "pushoversounds echo": "Pushover Echo (long)", | ||||
|     "pushoversounds updown": "Up Down (long)", | ||||
|     "pushoversounds vibrate": "Vibrate Only", | ||||
|     "pushoversounds none": "None (silent)", | ||||
|     pushyAPIKey: "Tajni API ključ", | ||||
|     pushyToken: "Token uređaja", | ||||
|     "Show update if available": "Pokaži moguću nadogradnju", | ||||
|     "Also check beta release": "Provjeravaj i za beta izdanja", | ||||
|     "Using a Reverse Proxy?": "Koristi li se reverzni proxy?", | ||||
|     "Check how to config it for WebSocket": "Provjerite kako se konfigurira za WebSocket protokol", | ||||
|     "Steam Game Server": "Steam poslužitelj igre", | ||||
|     "Most likely causes:": "Najvjerojatniji uzroci:", | ||||
|     "The resource is no longer available.": "Resurs više nije dostupan.", | ||||
|     "There might be a typing error in the address.": "Možda je nastala greška pri upisu adrese.", | ||||
|     "What you can try:": "Što možete pokušati:", | ||||
|     "Retype the address.": "Ponovno napišite adresu.", | ||||
|     "Go back to the previous page.": "Vratite se na prethodnu stranicu.", | ||||
|     "Coming Soon": "Dolazi uskoro", | ||||
|     wayToGetClickSendSMSToken: "Možete dobiti API korisničko ime i API ključ sa {0}.", | ||||
|     "Connection String": "Tekst veze", | ||||
|     Query: "Upit", | ||||
|     settingsCertificateExpiry: "TLS istek certifikata", | ||||
|     certificationExpiryDescription: "HTTPS monitori će obavijesiti kada je istek TLS certifikata za:", | ||||
|     "Setup Docker Host": "Dodaj Docker domaćina", | ||||
|     "Connection Type": "Tip veze", | ||||
|     "Docker Daemon": "Docker daemon", | ||||
|     deleteDockerHostMsg: "Sigurno želite izbrisati ovog Docker domaćina za sve monitore?", | ||||
|     socket: "Docker socket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker kontejner", | ||||
|     "Container Name / ID": "Naziv / ID kontejnera", | ||||
|     "Docker Host": "Docker domaćin", | ||||
|     "Docker Hosts": "Docker domaćini", | ||||
|     "ntfy Topic": "ntfy tema", | ||||
|     Domain: "Domena", | ||||
|     Workstation: "Radna stanica", | ||||
|     disableCloudflaredNoAuthMsg: "Lozinka nije nužna dok je isključena autentikacija.", | ||||
|     trustProxyDescription: "Vjeruj 'X-Forwarded-*' zaglavljima. Ako želite dobiti ispravnu IP adresu klijenta i Uptime Kuma je iza reverznog proxy poslužitelja, trebate omogućiti ovo.", | ||||
|     wayToGetLineNotifyToken: "Možete dobiti pristupni token sa {0}", | ||||
|     Examples: "Primjeri", | ||||
|     "Home Assistant URL": "URL Home Assistanta", | ||||
|     "Long-Lived Access Token": "Dugotrajni pristupni token", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Dugotrajni pristupni token može se kreirati klikom na korisničko ime (dolje lijevo) u Home Assistantu, pomicanjem do dna, te klikom na 'Create Token'. ", | ||||
|     "Notification Service": "Notification Service", | ||||
|     "default: notify all devices": "zadano ponašanje: obavijesti sve uređaje", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "Popis servisa za obavijesti u Home Assistantu nalaze se pod \"Developer Tools > Services\" te pretražiti \"notification\".", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Automacije se mogu okinuti u Home Assistantu:", | ||||
|     "Trigger type:": "Tip triggera:", | ||||
|     "Event type:": "Tip eventa:", | ||||
|     "Event data:": "Podaci eventa:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Potrebno je i odabrati akciju za izvođenje na Home Assistantu.", | ||||
|     "Frontend Version": "Inačica sučelja", | ||||
|     "Frontend Version do not match backend version!": "Inačica sučelja ne odgovara poslužitelju!", | ||||
| }; | ||||
|  |  | |||
|  | @ -7,25 +7,25 @@ export default { | |||
|     upsideDownModeDescription: "Se il servizio risulta raggiungibile viene marcato come \"DOWN\".", | ||||
|     maxRedirectDescription: "Numero massimo di redirezionamenti consentito. Per disabilitare, impostare \"0\".", | ||||
|     acceptedStatusCodesDescription: "Elenco di codici di stato HTTP che sono considerati validi.", | ||||
|     passwordNotMatchMsg: "La password non coincide.", | ||||
|     passwordNotMatchMsg: "La password non corrisponde.", | ||||
|     notificationDescription: "Assegnare la notifica a uno o più oggetti monitorati per metterla in funzione.", | ||||
|     keywordDescription: "Cerca la parola chiave nella risposta in html o JSON e fai distinzione tra maiuscole e minuscole", | ||||
|     pauseDashboardHome: "In Pausa", | ||||
|     deleteMonitorMsg: "Si è certi di voler eliminare questo oggetto monitorato?", | ||||
|     deleteNotificationMsg: "Si è certi di voler eliminare questa notifica per tutti gli oggetti monitorati?", | ||||
|     resolverserverDescription: "Cloudflare è il server predefinito, è possibile cambiare il server DNS.", | ||||
|     deleteMonitorMsg: "Sei sicuro di voler eliminare questo oggetto monitorato?", | ||||
|     deleteNotificationMsg: "Sei sicuro di voler eliminare questa notifica per tutti gli oggetti monitorati?", | ||||
|     resolverserverDescription: "Cloudflare è il server predefinito ma è possibile cambiare il server DNS.", | ||||
|     rrtypeDescription: "Scegliere il tipo di RR che si vuole monitorare", | ||||
|     pauseMonitorMsg: "Si è certi di voler mettere in pausa?", | ||||
|     pauseMonitorMsg: "Sei sicuro di voler mettere in pausa?", | ||||
|     enableDefaultNotificationDescription: "Per ogni nuovo monitor questa notifica sarà abilitata di default. È comunque possibile disabilitare la notifica singolarmente.", | ||||
|     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?", | ||||
|     confirmClearStatisticsMsg: "Si è certi di voler eliminare TUTTE le statistiche?", | ||||
|     clearEventsMsg: "Sei sicuro di voler eliminare tutti gli eventi per questo servizio?", | ||||
|     clearHeartbeatsMsg: "Sei sicuro di voler eliminare tutti gli intervalli di controllo per questo servizio?", | ||||
|     confirmClearStatisticsMsg: "Sei sicuro di voler eliminare TUTTE le statistiche?", | ||||
|     importHandleDescription: "Selezionare \"Ignora esistenti\" se si vuole ignorare l'importazione dei monitor o delle notifiche con lo stesso nome. \"Sovrascrivi\" rimpiazzerà tutti i monitor e le notifiche presenti con quelli nel backup.", | ||||
|     confirmImportMsg: "Si è certi di voler importare il backup? Essere certi di aver selezionato l'opzione corretta di importazione.", | ||||
|     confirmImportMsg: "Sei sicuro di voler importare il backup? Controlla di aver selezionato l'opzione corretta di importazione.", | ||||
|     twoFAVerifyLabel: "Digita il token per verificare che l'autenticazione a due fattori funzioni correttamente:", | ||||
|     tokenValidSettingsMsg: "Il token è valido! È ora possibile salvare le impostazioni.", | ||||
|     confirmEnableTwoFAMsg: "Si è certi di voler abilitare l'autenticazione a due fattori?", | ||||
|     confirmDisableTwoFAMsg: "Si è certi di voler disabilitare l'autenticazione a due fattori?", | ||||
|     confirmEnableTwoFAMsg: "Sei sicuro di voler abilitare l'autenticazione a due fattori?", | ||||
|     confirmDisableTwoFAMsg: "Sei sicuro di voler disabilitare l'autenticazione a due fattori?", | ||||
|     Settings: "Impostazioni", | ||||
|     Dashboard: "Dashboard", | ||||
|     "New Update": "Nuovo aggiornamento disponibile!", | ||||
|  |  | |||
|  | @ -69,7 +69,7 @@ export default { | |||
|     Port: "포트", | ||||
|     "Heartbeat Interval": "하트비트 주기", | ||||
|     Retries: "재시도", | ||||
|     "Heartbeat Retry Interval": "하트비드 재시도 주기", | ||||
|     "Heartbeat Retry Interval": "하트비트 재시도 주기", | ||||
|     Advanced: "고급", | ||||
|     "Upside Down Mode": "상태 반전 모드", | ||||
|     "Max. Redirects": "최대 리다이렉트", | ||||
|  | @ -110,7 +110,7 @@ export default { | |||
|     "Remember me": "비밀번호 기억하기", | ||||
|     Login: "로그인", | ||||
|     "No Monitors, please": "모니터링이 현재 없어요,", | ||||
|     "add one": "한번 추가해보실레요?", | ||||
|     "add one": "한번 추가해보실래요?", | ||||
|     "Notification Type": "알림 종류", | ||||
|     Email: "이메일", | ||||
|     Test: "테스트", | ||||
|  |  | |||
|  | @ -206,10 +206,10 @@ export default { | |||
|     smtp: "Email (SMTP)", | ||||
|     secureOptionNone: "None / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Ignore TLS Error", | ||||
|     "From Email": "From Email", | ||||
|     emailCustomSubject: "Custom Subject", | ||||
|     "To Email": "To Email", | ||||
|     "Ignore TLS Error": "เพิกเฉยข้อผิดพลาด TLS", | ||||
|     "From Email": "จากอีเมล", | ||||
|     emailCustomSubject: "หัวข้อที่กำหนดเอง", | ||||
|     "To Email": "ถึงอีเมล", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "BCC", | ||||
|     discord: "Discord", | ||||
|  | @ -519,4 +519,62 @@ export default { | |||
|     "Coming Soon": "เร็ว ๆ นี้", | ||||
|     wayToGetClickSendSMSToken: "คุณสามารถรับ API Username และ API Key ได้จาก {0}", | ||||
|     wayToGetLineNotifyToken: "คุณสามารถรับ access token ได้จาก {0}", | ||||
|     resendEveryXTimes: "ส่งซ้ำทุก {0} ครั้ง", | ||||
|     resendDisabled: "การส่งซ้ำถูกปิดใช้งาน", | ||||
|     dnsPortDescription: "พอร์ตของเซิร์ฟเวอร์ DNS, ค่าเริ่มต้นคือ 53, คุณสามารถเปลี่ยนพอร์ตตอนไหนก็ได้", | ||||
|     "Resend Notification if Down X times consequently": "ส่งการแจ้งเตือนซ้ำถ้าออฟไลน์ครบ X ครั้ง", | ||||
|     error: "เกิดข้อผิดพลาด", | ||||
|     critical: "วิกฤต", | ||||
|     wayToGetPagerDutyKey: "คุณสามารถรับได้โดยการไปที่ Service -> Service Directory -> (Select a service) -> Integrations -> Add integration, และค้นหา \"Events API V2\", สำหรับข้อมูลเพิ่มเติม {0}", | ||||
|     "Integration Key": "Integration Key", | ||||
|     "Integration URL": "Integration URL", | ||||
|     "Auto resolve or acknowledged": "แก้ไขอัตโนมัติหรือยอมรับ", | ||||
|     "do nothing": "ไม่ทำอะไร", | ||||
|     "auto acknowledged": "ยอมรับอัตโนมัติ", | ||||
|     "auto resolve": "แก้ไขอัตโนมัติ", | ||||
|     "Bark Group": "กลุ่มที่จะประกาศ", | ||||
|     "Bark Sound": "เสียงประกาศ", | ||||
|     Authentication: "การตรวจสอบสิทธิ์", | ||||
|     "HTTP Headers": "HTTP Headers", | ||||
|     "Trust Proxy": "Trust Proxy", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     RadiusSecret: "Radius Secret", | ||||
|     RadiusSecretDescription: "แบ่งปันข้อมูลลับระหว่างผู้ใช้งานและเซิร์ฟเวอร์", | ||||
|     RadiusCalledStationId: "Called Station Id", | ||||
|     RadiusCalledStationIdDescription: "Identifier of the called device", | ||||
|     RadiusCallingStationId: "Calling Station Id", | ||||
|     RadiusCallingStationIdDescription: "Identifier of the calling device", | ||||
|     "Connection String": "Connection String", | ||||
|     Query: "Query", | ||||
|     settingsCertificateExpiry: "วันหมดอายุใบรับรอง TLS", | ||||
|     certificationExpiryDescription: "การตรวจสอบ HTTPS แจ้งเตือนใบอนุญาติ TLS จะหมดอายุใน:", | ||||
|     "Setup Docker Host": "Setup Docker Host", | ||||
|     "Connection Type": "ประเภทการเชื่อมต่อ", | ||||
|     "Docker Daemon": "Docker Daemon", | ||||
|     deleteDockerHostMsg: "คุณแน่ใจหรือไม่ที่จะลบ Docker host นี้สำหรับการมอนิเตอร์ทั้งหมด?", | ||||
|     socket: "Socket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker Container", | ||||
|     "Container Name / ID": "Container Name / ID", | ||||
|     "Docker Host": "Docker Host", | ||||
|     "Docker Hosts": "Docker Hosts", | ||||
|     "ntfy Topic": "ntfy Topic", | ||||
|     Domain: "โดเมน", | ||||
|     Workstation: "Workstation", | ||||
|     disableCloudflaredNoAuthMsg: "คุณอยู่ในโหมดไม่มีการตรวจสอบสิทธิ์, ไม่จำเป็นต้องมีรหัสผ่าน", | ||||
|     trustProxyDescription: "เชื่อ Header 'X-Forwarded-*' ถ้าคุณต้องการไอพีที่ถูกต้องและ Uptime Kuma อยู่ข้างหลัง Nginx หรือ Apache, คุณควรเปิดใช้งาน", | ||||
|     Examples: "ตัวอย่าง", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token": "Access Token แบบมีอายุ", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Access Token แบบมีอายุนานสามารถสร้างได้โดยคลิกชื่อบนโปรไฟล์ (ล่างซ้าย) และเลื่อนไปข้างล่างจากนั้นคลิก \"Create Token\"", | ||||
|     "Notification Service": "บริการแจ้งเตือน", | ||||
|     "default: notify all devices": "ค่าเริ่มต้น: แจ้งเตือนทุกอุปกรณ์", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "รายการแจ้งเตือนสามารถหาได้ใน Home Assistant ในเมนู \"Developer Tools > Services\" ค้นหา \"notification\" เพื่อหาชื่ออุปกรณ์หรือชื่อโทรศัพท์", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "สามารถเลือกสั่งงานระบบอัตโนมัติได้ใน Home Assistant:", | ||||
|     "Trigger type:": "ชนิดสิ่งกระตุ้น:", | ||||
|     "Event type:": "ชนิดกิจกรรม:", | ||||
|     "Event data:": "ข้อมูลกิจกรรม:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "จากนั้นเลือกการกระทำ, ตัวอย่าง เช่น เปลี่ยนเป็นไฟสีแดง", | ||||
|     "Frontend Version": "เวอร์ชั่น Frontend", | ||||
|     "Frontend Version do not match backend version!": "เวอร์ชั่น Frontend ไม่ตรงกับ Backend !", | ||||
| }; | ||||
|  |  | |||
|  | @ -2,6 +2,8 @@ export default { | |||
|     languageName: "Türkçe", | ||||
|     checkEverySecond: "{0} Saniyede bir kontrol et.", | ||||
|     retryCheckEverySecond: "{0} Saniyede bir dene.", | ||||
|     resendEveryXTimes: "Her {0} bir yeniden gönder", | ||||
|     resendDisabled: "Yeniden gönderme devre dışı", | ||||
|     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", | ||||
|     upsideDownModeDescription: "Servisin durumunu tersine çevirir. Servis çalışıyorsa kapalı olarak işaretler.", | ||||
|  | @ -72,6 +74,7 @@ export default { | |||
|     "Heartbeat Interval": "Servis Test Aralığı", | ||||
|     Retries: "Yeniden deneme", | ||||
|     "Heartbeat Retry Interval": "Sağlık Durumları Tekrar Deneme Sıklığı", | ||||
|     "Resend Notification if Down X times consequently": "Sonuç olarak X kez düşerse bildirimi yeniden gönder", | ||||
|     Advanced: "Gelişmiş", | ||||
|     "Upside Down Mode": "Ters/Düz Modu", | ||||
|     "Max. Redirects": "Maksimum Yönlendirme", | ||||
|  | @ -333,6 +336,8 @@ export default { | |||
|     info: "info", | ||||
|     warning: "warning", | ||||
|     danger: "danger", | ||||
|     error: "hata", | ||||
|     critical: "kritik", | ||||
|     primary: "primary", | ||||
|     light: "light", | ||||
|     dark: "dark", | ||||
|  | @ -373,6 +378,13 @@ export default { | |||
|     smtpDkimHashAlgo: "Hash Algoritması (Opsiyonel)", | ||||
|     smtpDkimheaderFieldNames: "İmzalanacak Başlık Anahtarları (Opsiyonel)", | ||||
|     smtpDkimskipFields: "İmzalamayacak Başlık Anahtarları (Opsiyonel)", | ||||
|     wayToGetPagerDutyKey: "Bunu Hizmet -> Hizmet Dizini -> (Bir hizmet seçin) -> Entegrasyonlar -> Entegrasyon ekle'ye giderek alabilirsiniz. Burada \"Events API V2\" için arama yapabilirsiniz. Daha fazla bilgi {0}", | ||||
|     "Integration Key": "Entegrasyon Anahtarı", | ||||
|     "Integration URL": "Entegrasyon URL'si", | ||||
|     "Auto resolve or acknowledged": "Otomatik çözümleme veya onaylandı", | ||||
|     "do nothing": "hiçbir şey yapma", | ||||
|     "auto acknowledged": "otomatik onaylandı", | ||||
|     "auto resolve": "otomatik çözümleme", | ||||
|     gorush: "Gorush", | ||||
|     alerta: "Alerta", | ||||
|     alertaApiEndpoint: "API Endpoint", | ||||
|  | @ -399,6 +411,8 @@ export default { | |||
|     SignName: "SignName", | ||||
|     "Sms template must contain parameters: ": "Sms şablonu parametreleri içermelidir:", | ||||
|     "Bark Endpoint": "Bark Endpoint", | ||||
|     "Bark Group": "Bark Group", | ||||
|     "Bark Sound": "Bark Sound", | ||||
|     WebHookUrl: "WebHookUrl", | ||||
|     SecretKey: "SecretKey", | ||||
|     "For safety, must use secret key": "Güvenlik için gizli anahtar kullanılmalıdır", | ||||
|  | @ -432,6 +446,7 @@ export default { | |||
|     Next: "Sonraki", | ||||
|     "The slug is already taken. Please choose another slug.": "Slug zaten alındı. Lütfen başka bir slug seçin.", | ||||
|     "No Proxy": "Proxy Yok", | ||||
|     Authentication: "Kimlik doğrulama", | ||||
|     "HTTP Basic Auth": "HTTP Temel Yetkilendirme", | ||||
|     "New Status Page": "Yeni Durum Sayfası", | ||||
|     "Page Not Found": "Sayfa bulunamadı", | ||||
|  | @ -443,6 +458,8 @@ export default { | |||
|     "Message:": "Mesaj:", | ||||
|     "Don't know how to get the token? Please read the guide:": "Tokeni nasıl alacağınızı bilmiyor musunuz? Lütfen kılavuzu okuyun:", | ||||
|     "The current connection may be lost if you are currently connecting via Cloudflare Tunnel. Are you sure want to stop it? Type your current password to confirm it.": "Halihazırda Cloudflare Tüneli üzerinden bağlanıyorsanız mevcut bağlantı kesilebilir. Durdurmak istediğinden emin misin? Onaylamak için mevcut şifrenizi yazın.", | ||||
|     "HTTP Headers": "HTTP Headers", | ||||
|     "Trust Proxy": "Trust Proxy", | ||||
|     "Other Software": "Diğer Yazılımlar", | ||||
|     "For example: nginx, Apache and Traefik.": "Örneğin: nginx, Apache ve Traefik.", | ||||
|     "Please read": "Lütfen oku", | ||||
|  | @ -455,6 +472,7 @@ export default { | |||
|     "Domain Name Expiry Notification": "Alan Adı Sona Erme Bildirimi", | ||||
|     Proxy: "Proxy", | ||||
|     "Date Created": "Tarih Oluşturuldu", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     onebotHttpAddress: "OneBot HTTP Adresi", | ||||
|     onebotMessageType: "OneBot Mesaj Türü", | ||||
|     onebotGroupMessage: "Grup", | ||||
|  | @ -467,6 +485,12 @@ export default { | |||
|     "Domain Names": "Alan isimleri", | ||||
|     signedInDisp: "{0} olarak oturum açıldı", | ||||
|     signedInDispDisabled: "Yetkilendirme Devre Dışı.", | ||||
|     RadiusSecret: "Radius Secret", | ||||
|     RadiusSecretDescription: "İstemci ve sunucu arasında paylaşılan gizli anahtar", | ||||
|     RadiusCalledStationId: "Aranan İstasyon Kimliği", | ||||
|     RadiusCalledStationIdDescription: "Aranan cihazın tanımlayıcısı", | ||||
|     RadiusCallingStationId: "Arayan İstasyon Kimliği", | ||||
|     RadiusCallingStationIdDescription: "Arayan cihazın tanımlayıcısı", | ||||
|     "Certificate Expiry Notification": "Sertifika Sona Erme Bildirimi", | ||||
|     "API Username": "API Kullanıc Adı", | ||||
|     "API Key": "API Anahtarı", | ||||
|  | @ -475,7 +499,7 @@ export default { | |||
|     "Leave blank to use a shared sender number.": "Paylaşılan bir gönderen numarası kullanmak için boş bırakın.", | ||||
|     "Octopush API Version": "Octopush API Sürümü", | ||||
|     "Legacy Octopush-DM": "Eski Octopush-DM", | ||||
|     "endpoint": "endpoint", | ||||
|     endpoint: "uç nokta", | ||||
|     octopushAPIKey: "Kontrol panelindeki HTTP API kimlik bilgilerinden \"API Key\"", | ||||
|     octopushLogin: "Kontrol panelindeki HTTP API kimlik bilgilerinden \"Login\"", | ||||
|     promosmsLogin: "API Oturum Açma Adı", | ||||
|  | @ -518,13 +542,38 @@ export default { | |||
|     "Go back to the previous page.": "Bir önceki sayfaya geri git.", | ||||
|     "Coming Soon": "Yakında gelecek", | ||||
|     wayToGetClickSendSMSToken: "API Kullanıcı Adı ve API Anahtarını {0} adresinden alabilirsiniz.", | ||||
|     error: "hata", | ||||
|     critical: "kritik", | ||||
|     wayToGetPagerDutyKey: "Bunu şuraya giderek alabilirsiniz: Servis -> Servis Dizini -> (Bir servis seçin) -> Entegrasyonlar -> Entegrasyon ekle. Burada \"Events API V2\" için arama yapabilirsiniz. Daha fazla bilgi {0}", | ||||
|     "Integration Key": "Entegrasyon Anahtarı", | ||||
|     "Integration URL": "Entegrasyon URL", | ||||
|     "Auto resolve or acknowledged": "Otomatik çözümleme veya onaylama", | ||||
|     "do nothing": "hiçbir şey yapma", | ||||
|     "auto acknowledged": "otomatik onaylama", | ||||
|     "auto resolve": "otomatik çözümleme", | ||||
|     "Connection String": "Bağlantı dizisi", | ||||
|     Query: "Sorgu", | ||||
|     settingsCertificateExpiry: "TLS Sertifikasının Geçerlilik Süresi", | ||||
|     certificationExpiryDescription: "HTTPS Monitörleri, TLS sertifikasının süresi dolduğunda bildirimi tetikler:", | ||||
|     "Setup Docker Host": "Docker Ana Bilgisayarını Kur", | ||||
|     "Connection Type": "Bağlantı türü", | ||||
|     "Docker Daemon": "Docker Daemon", | ||||
|     deleteDockerHostMsg: "Bu docker ana bilgisayarını tüm monitörler için silmek istediğinizden emin misiniz?", | ||||
|     socket: "Soket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker Konteyneri", | ||||
|     "Container Name / ID": "Konteyner Adı / Kimliği", | ||||
|     "Docker Host": "Docker Ana Bilgisayarı", | ||||
|     "Docker Hosts": "Docker Ana Bilgisayarları", | ||||
|     "ntfy Topic": "ntfy Konu", | ||||
|     "Domain": "Domain", | ||||
|     "Workstation": "İş İstasyonu", | ||||
|     disableCloudflaredNoAuthMsg: "Yetki Yok modundasınız, şifre gerekli değil.", | ||||
|     trustProxyDescription: "'X-Forwarded-*' başlıklarına güvenin. Doğru istemci IP'sini almak istiyorsanız ve Uptime Kuma'nız Nginx veya Apache'nin arkasındaysa, bunu etkinleştirmelisiniz.", | ||||
|     wayToGetLineNotifyToken: "{0} adresinden bir erişim jetonu alabilirsiniz.", | ||||
|     Examples: "Örnekler", | ||||
|     "Home Assistant URL": "Home Assistant URL", | ||||
|     "Long-Lived Access Token": "Long-Lived Erişim Anahtarı", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "Long-Lived Erişim Anahtarı, profil adınıza (sol altta) tıklayarak ve aşağıya kaydırarak ve ardından Anahtar Oluştur'a tıklayarak oluşturulabilir. ", | ||||
|     "Notification Service": "Bildirim Hizmeti", | ||||
|     "default: notify all devices": "varsayılan: tüm cihazları bilgilendir", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "Cihazınızın/telefonunuzun adını bulmak için Home Assistant'ta \"Geliştirici Araçları > Hizmetler\" \"bildirim\" araması altında bir Bildirim Hizmetleri listesi bulunabilir.", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "Otomasyonlar isteğe bağlı olarak Home Assistant'ta tetiklenebilir:", | ||||
|     "Trigger type:": "Trigger tipi:", | ||||
|     "Event type:": "Etkinlik tipi:", | ||||
|     "Event data:": "Etkinlik verileri:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "Ardından bir eylem seçin, örneğin RGB ışığının kırmızı olduğu sahneyi değiştirin.", | ||||
|     "Frontend Version": "Frontend Sürümü", | ||||
|     "Frontend Version do not match backend version!": "Frontend Sürümü, backend sürümüyle eşleşmiyor!", | ||||
| }; | ||||
|  |  | |||
|  | @ -540,6 +540,45 @@ export default { | |||
|     settingsCertificateExpiry: "TLS 证书过期通知", | ||||
|     certificationExpiryDescription: "HTTPS 监控项发现被监控目标的 TLS 证书剩余有效期少于以下天数时将发出通知:", | ||||
|     "ntfy Topic": "ntfy 主题", | ||||
|     "Domain": "域名", | ||||
|     "Workstation": "工作站", | ||||
|     Domain: "域名", | ||||
|     Workstation: "工作站", | ||||
|     resendEveryXTimes: "每 {0} 次失败则重复发送一次", | ||||
|     resendDisabled: "为 0 时禁用重复发送", | ||||
|     "Resend Notification if Down X times consequently": "连续失败时重复发送通知的间隔次数", | ||||
|     "HTTP Headers": "HTTP 头", | ||||
|     "Trust Proxy": "可信的代理类字段", | ||||
|     HomeAssistant: "Home Assistant", | ||||
|     RadiusSecret: "Radius 共享机密", | ||||
|     RadiusSecretDescription: "客户端和服务器之间共享的密钥", | ||||
|     RadiusCalledStationId: "NAS 网络访问服务器号码(Called Station Id)", | ||||
|     RadiusCalledStationIdDescription: "所访问的服务器的标识", | ||||
|     RadiusCallingStationId: "呼叫方号码(Calling Station Id)", | ||||
|     RadiusCallingStationIdDescription: "发出请求的设备的标识", | ||||
|     "Setup Docker Host": "配置 Docker 宿主信息", | ||||
|     "Connection Type": "连接方式", | ||||
|     "Docker Daemon": "Docker 守护进程", | ||||
|     deleteDockerHostMsg: "您确定您要删除此 Docker 宿主设置吗?这会影响所有 Docker 监控项", | ||||
|     socket: "Socket", | ||||
|     tcp: "TCP / HTTP", | ||||
|     "Docker Container": "Docker 容器", | ||||
|     "Container Name / ID": "容器名称 / ID", | ||||
|     "Docker Host": "Docker 宿主", | ||||
|     "Docker Hosts": "Docker 宿主", | ||||
|     disableCloudflaredNoAuthMsg: "您现在正处于 No Auth 模式,无需输入密码", | ||||
|     trustProxyDescription: "信任 'X-Forwarded-*' 头。如果您的 Uptime Kuma 是通过 Nginx 或 Apache 等反代服务对外提供访问的话,则您应当启用本功能以获取正确的客户端 IP。", | ||||
|     wayToGetLineNotifyToken: "您可以在 {0} 获取 Access token", | ||||
|     Examples: "例如", | ||||
|     "Home Assistant URL": "Home Assistant 地址", | ||||
|     "Long-Lived Access Token": "长期访问令牌", | ||||
|     "Long-Lived Access Token can be created by clicking on your profile name (bottom left) and scrolling to the bottom then click Create Token. ": "长期访问令牌可通过点击左下角您的用户名,滚动到页面底部并点击 Create Token 按钮获取。", | ||||
|     "Notification Service": "Notification Service", | ||||
|     "default: notify all devices": "默认:通知所有设备", | ||||
|     "A list of Notification Services can be found in Home Assistant under \"Developer Tools > Services\" search for \"notification\" to find your device/phone name.": "通知服务的列表可在 Home Assistant 中的 Developer Tools > Services 通过搜索您的设备或手机的名称来获得。", | ||||
|     "Automations can optionally be triggered in Home Assistant:": "可以在 Home Assistant 使用下列模板设置自动化操作的触发条件:", | ||||
|     "Trigger type:": "触发类型:", | ||||
|     "Event type:": "事件类型:", | ||||
|     "Event data:": "事件数据:", | ||||
|     "Then choose an action, for example switch the scene to where an RGB light is red.": "然后您可以选择关联操作,例如切换到 RGB 灯发出红光的场景", | ||||
|     "Frontend Version": "前端版本", | ||||
|     "Frontend Version do not match backend version!": "前端版本与后端版本不符!", | ||||
| }; | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
|                 <Tag v-for="tag in monitor.tags" :key="tag.id" :item="tag" :size="'sm'" /> | ||||
|             </div> | ||||
|             <p class="url"> | ||||
|                 <a v-if="monitor.type === 'http' || monitor.type === 'keyword' " :href="monitor.url" target="_blank">{{ monitor.url }}</a> | ||||
|                 <a v-if="monitor.type === 'http' || monitor.type === 'keyword' " :href="monitor.url" target="_blank" rel="noopener noreferrer">{{ monitor.url }}</a> | ||||
|                 <span v-if="monitor.type === 'port'">TCP Ping {{ monitor.hostname }}:{{ monitor.port }}</span> | ||||
|                 <span v-if="monitor.type === 'ping'">Ping: {{ monitor.hostname }}</span> | ||||
|                 <span v-if="monitor.type === 'keyword'"> | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| <template> | ||||
|     <div class="form-container"> | ||||
|     <div class="form-container" data-cy="setup-form"> | ||||
|         <div class="form"> | ||||
|             <form @submit.prevent="submit"> | ||||
|                 <div> | ||||
|  | @ -23,21 +23,21 @@ | |||
|                 </div> | ||||
| 
 | ||||
|                 <div class="form-floating mt-3"> | ||||
|                     <input id="floatingInput" v-model="username" type="text" class="form-control" placeholder="Username" required> | ||||
|                     <input id="floatingInput" v-model="username" type="text" class="form-control" placeholder="Username" required data-cy="username-input"> | ||||
|                     <label for="floatingInput">{{ $t("Username") }}</label> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="form-floating mt-3"> | ||||
|                     <input id="floatingPassword" v-model="password" type="password" class="form-control" placeholder="Password" required> | ||||
|                     <input id="floatingPassword" v-model="password" type="password" class="form-control" placeholder="Password" required data-cy="password-input"> | ||||
|                     <label for="floatingPassword">{{ $t("Password") }}</label> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <div class="form-floating mt-3"> | ||||
|                     <input id="repeat" v-model="repeatPassword" type="password" class="form-control" placeholder="Repeat Password" required> | ||||
|                     <input id="repeat" v-model="repeatPassword" type="password" class="form-control" placeholder="Repeat Password" required data-cy="password-repeat-input"> | ||||
|                     <label for="repeat">{{ $t("Repeat Password") }}</label> | ||||
|                 </div> | ||||
| 
 | ||||
|                 <button class="w-100 btn btn-primary mt-3" type="submit" :disabled="processing"> | ||||
|                 <button class="w-100 btn btn-primary mt-3" type="submit" :disabled="processing" data-cy="submit-setup-form"> | ||||
|                     {{ $t("Create") }} | ||||
|                 </button> | ||||
|             </form> | ||||
|  |  | |||
|  | @ -265,7 +265,7 @@ | |||
|                 <Editable v-model="config.footerText" tag="div" :contenteditable="enableEditMode" :noNL="false" class="alert-heading p-2" /> | ||||
| 
 | ||||
|                 <p v-if="config.showPoweredBy"> | ||||
|                     {{ $t("Powered by") }} <a target="_blank" href="https://github.com/louislam/uptime-kuma">{{ $t("Uptime Kuma" ) }}</a> | ||||
|                     {{ $t("Powered by") }} <a target="_blank" rel="noopener noreferrer" href="https://github.com/louislam/uptime-kuma">{{ $t("Uptime Kuma" ) }}</a> | ||||
|                 </p> | ||||
|             </footer> | ||||
|         </div> | ||||
|  |  | |||
|  | @ -11,9 +11,11 @@ | |||
|         "removeComments": false, | ||||
|         "preserveConstEnums": true, | ||||
|         "sourceMap": false, | ||||
|         "strict": true | ||||
|         "strict": true, | ||||
|         "types": ["cypress"] | ||||
|     }, | ||||
|     "files": [ | ||||
|         "./src/util.ts" | ||||
|     ] | ||||
|         "./src/util.ts", | ||||
|     ], | ||||
|     "include": ["cypress/**/*.ts"] | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue