Compare commits

..

47 Commits

Author SHA1 Message Date
github-actions[bot]
8fa6454161 New Crowdin translations by GitHub Action (#3758)
Some checks failed
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Docs / Linting Checks (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2024-09-09 21:15:33 -07:00
ToXinE
e1a6acf5e6 Documentation: Fix watchtower typo (#3967) 2024-09-09 15:33:07 -07:00
shamoon
2d0beabe9a Enhancement: more reliable wg-easy widget by custom proxy, use password header (#3966)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
2024-09-09 11:40:11 -07:00
shamoon
133d2d6e02 Update package name / version, regenerate lock files 2024-09-09 11:36:31 -07:00
shamoon
da95c42279 Update tdarr.md
Some checks failed
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Docs / Linting Checks (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-09-04 16:12:13 -07:00
Wtfitsaduck
989039af81 Enhancement: support Tdarr widget auth (#3940)
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-09-04 22:59:54 +00:00
shamoon
5de0019b3d Readme tweaks
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
2024-09-03 19:07:20 -07:00
shamoon
d1e5d58e01 Add some debug logging for k8s
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
2024-09-03 14:04:44 -07:00
shamoon
0d3a57be13 Exclude index pages from search results
Some checks failed
Docs / Linting Checks (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-09-02 15:15:05 -07:00
dependabot[bot]
541aae1588 Chore(deps-dev): Bump autoprefixer from 10.4.17 to 10.4.20 (#3928)
Some checks failed
Docs / Linting Checks (push) Waiting to run
Docs / Test Build (push) Blocked by required conditions
Docs / Build & Deploy (push) Blocked by required conditions
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Bumps [autoprefixer](https://github.com/postcss/autoprefixer) from 10.4.17 to 10.4.20.
- [Release notes](https://github.com/postcss/autoprefixer/releases)
- [Changelog](https://github.com/postcss/autoprefixer/blob/main/CHANGELOG.md)
- [Commits](https://github.com/postcss/autoprefixer/compare/10.4.17...10.4.20)

---
updated-dependencies:
- dependency-name: autoprefixer
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-09-02 00:05:14 +00:00
dependabot[bot]
9d00421c73 Chore(deps-dev): Bump @tailwindcss/forms from 0.5.7 to 0.5.8 (#3925)
Bumps [@tailwindcss/forms](https://github.com/tailwindlabs/tailwindcss-forms) from 0.5.7 to 0.5.8.
- [Release notes](https://github.com/tailwindlabs/tailwindcss-forms/releases)
- [Changelog](https://github.com/tailwindlabs/tailwindcss-forms/blob/main/CHANGELOG.md)
- [Commits](https://github.com/tailwindlabs/tailwindcss-forms/compare/v0.5.7...v0.5.8)

---
updated-dependencies:
- dependency-name: "@tailwindcss/forms"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-09-01 17:03:42 -07:00
dependabot[bot]
54ed8f7a7b Chore(deps): Bump luxon from 3.4.4 to 3.5.0 (#3927)
Bumps [luxon](https://github.com/moment/luxon) from 3.4.4 to 3.5.0.
- [Changelog](https://github.com/moment/luxon/blob/master/CHANGELOG.md)
- [Commits](https://github.com/moment/luxon/compare/3.4.4...3.5.0)

---
updated-dependencies:
- dependency-name: luxon
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-09-01 17:03:28 -07:00
Mitchell
e454ff06b9 Enhancement: support more fields for zabbix widget 2024-09-01 16:02:00 -07:00
shamoon
7b94ccb01f Use logger for validate widget errors
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
2024-08-30 15:45:51 -07:00
Mitchell
44f8e9d4da Feature: Zabbix service widget (#3905)
Some checks failed
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Docs / Linting Checks (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
Co-Authored-By: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-29 12:53:10 -07:00
Bobby Driggs
4c6150a545 Feature: Technitium DNS Widget (#3904)
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-29 10:51:36 -07:00
Jacobo de Vera
e2518b37d9 Enhancement: customAPI size formatter (#3898)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-27 08:05:23 -07:00
shamoon
2fc83d275b Update .eslintrc.json 2024-08-27 08:04:36 -07:00
joncrangle
b14374f660 Chore: handle mealie API change (#3895)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-24 21:02:47 -07:00
Trevor Vance
8ff68dd6bf Documentation: fix indentation for proxmox docs. (#3885)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Docs / Linting Checks (push) Waiting to run
Docs / Test Build (push) Blocked by required conditions
Docs / Build & Deploy (push) Blocked by required conditions
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-23 20:05:02 -07:00
InsertDisc
132b8c32e5 Refactor: update RomM widget (#3886)
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-23 19:28:37 -07:00
shamoon
f2a49eaa25 Remove more version tags from compose examples
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-08-21 13:16:45 -07:00
VolumeData21
ca2a6d7664 Documentation: remove version line from readme docker compose yaml (#3882)
---------

Co-authored-by: andrew <110792083+beboprocky@users.noreply.github.com>
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-21 13:14:44 -07:00
shamoon
84db5ea13d Change: increase precision of used space in fs glances widget
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
2024-08-20 06:51:22 -07:00
shamoon
ffd465a36a Chore: update gamedig to 5.1.2 (#3876)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
2024-08-19 16:53:29 -07:00
Devedse
0d25f5789b Feature: DeveLanCacheUI service widget (#3854)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-15 23:28:53 +00:00
shamoon
ca1577166d Update getting-started.md
Some checks are pending
Docs / Linting Checks (push) Waiting to run
Docs / Test Build (push) Blocked by required conditions
Docs / Build & Deploy (push) Blocked by required conditions
2024-08-14 20:20:11 -07:00
shamoon
40b0f956ae Add resources debug
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
2024-08-14 11:57:09 -07:00
Juan Ignacio Sierra
2ee14eb94b Enhancement: support ESPHome widget authentication (#3846)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
* Added cookie support for auth on ESPHome widget

* Lint

* Use credentialedProxyHandler instead

---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-13 07:40:42 -07:00
shamoon
9ede44b12d Fix: properly handle wg-easy errors (#3849)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Also reverts #3768
2024-08-13 00:12:53 -07:00
shamoon
0dc2f2e18a Fix error simple string 2024-08-13 00:07:16 -07:00
teobogdan
2aa7a3898b Chore: update Gamedig (#3841)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Co-Authored-By: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-12 00:35:03 -07:00
shamoon
805f119a25 Fix: remove tubearchivist stats validation 2024-08-11 07:36:18 -07:00
shamoon
74f76e2656 Documentation: add resources note
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-08-09 14:31:23 -07:00
PyrokineticDarkElf
4d38222ba0 Feature: Linkwarden service widget (#3836)
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-08-09 14:19:06 -07:00
shamoon
b9b7c482d4 Fix immich version check
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
2024-08-04 21:32:35 -07:00
shamoon
1c5d9ca223 Change: handle errored truenas pools (#3815)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-08-03 17:02:38 -07:00
shamoon
8fba3eee1d Enhancement: use tubearchivist stats endpoints (#3814) 2024-08-03 16:51:44 -07:00
dependabot[bot]
0d6aabc737 Chore(deps): Bump raw-body from 2.5.2 to 3.0.0 (#3803)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Bumps [raw-body](https://github.com/stream-utils/raw-body) from 2.5.2 to 3.0.0.
- [Changelog](https://github.com/stream-utils/raw-body/blob/master/HISTORY.md)
- [Commits](https://github.com/stream-utils/raw-body/compare/2.5.2...v3.0.0)

---
updated-dependencies:
- dependency-name: raw-body
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-08-01 14:57:04 -07:00
dependabot[bot]
b124e12509 Chore(deps): Bump urbackup-server-api from 0.8.9 to 0.52.0 (#3801)
Bumps [urbackup-server-api](https://github.com/bartmichu/node-urbackup-server-api) from 0.8.9 to 0.52.0.
- [Changelog](https://github.com/bartmichu/node-urbackup-server-api/blob/main/CHANGELOG.md)
- [Commits](https://github.com/bartmichu/node-urbackup-server-api/commits)

---
updated-dependencies:
- dependency-name: urbackup-server-api
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-08-01 11:52:53 -07:00
dependabot[bot]
0a23bfe263 Chore(deps-dev): Bump eslint-plugin-prettier from 4.2.1 to 5.2.1 (#3802)
Bumps [eslint-plugin-prettier](https://github.com/prettier/eslint-plugin-prettier) from 4.2.1 to 5.2.1.
- [Release notes](https://github.com/prettier/eslint-plugin-prettier/releases)
- [Changelog](https://github.com/prettier/eslint-plugin-prettier/blob/master/CHANGELOG.md)
- [Commits](https://github.com/prettier/eslint-plugin-prettier/compare/v4.2.1...v5.2.1)

---
updated-dependencies:
- dependency-name: eslint-plugin-prettier
  dependency-type: direct:development
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-08-01 11:07:34 -07:00
dependabot[bot]
9fa38c9ba8 Chore(deps): Bump systeminformation from 5.22.7 to 5.23.2 (#3799)
Some checks are pending
Docker / Linting Checks (push) Waiting to run
Docker / Docker Build & Push (push) Blocked by required conditions
Bumps [systeminformation](https://github.com/sebhildebrandt/systeminformation) from 5.22.7 to 5.23.2.
- [Changelog](https://github.com/sebhildebrandt/systeminformation/blob/master/CHANGELOG.md)
- [Commits](https://github.com/sebhildebrandt/systeminformation/compare/v5.22.7...v5.23.2)

---
updated-dependencies:
- dependency-name: systeminformation
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-08-01 09:54:06 -07:00
shamoon
9484a9ff56 Fix: correctly decode tab names with special chars (#3797)
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
2024-07-30 20:56:26 -07:00
shamoon
ed928bfa25 Add support note
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docs / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
Docs / Test Build (push) Has been cancelled
Docs / Build & Deploy (push) Has been cancelled
2024-07-23 20:40:33 -07:00
nopoz
a996d43bbf Documentation: clarify api key usage for pfsense v1 vs v2 (#3766)
---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2024-07-23 18:57:47 -07:00
BugGeeker
6ce67b5ab8 Fix: wg-easy widget better handle api error (#3768) 2024-07-23 18:51:43 -07:00
shamoon
5d531b11e7 Fix: correct k8s job status check
Some checks failed
Docker / Linting Checks (push) Has been cancelled
Docker / Docker Build & Push (push) Has been cancelled
2024-07-18 19:10:57 -07:00
104 changed files with 8543 additions and 4881 deletions

View File

@@ -13,6 +13,12 @@
{
"newlines-between": "always"
}
],
"no-else-return": [
"error",
{
"allowElseIf": true
}
]
},
"settings": {

View File

@@ -1,4 +1,11 @@
body:
- type: markdown
attributes:
value: |
### ⚠️ Before opening a discussion:
- [Check the troubleshooting guide](https://gethomepage.dev/latest/troubleshooting/).
- [Search existing issues](https://github.com/gethomepage/homepage/search?q=&type=issues) [and discussions](https://github.com/gethomepage/homepage/search?q=&type=discussions).
- type: textarea
id: description
attributes:

View File

@@ -75,14 +75,13 @@ Please note that when using features such as widgets, Homepage can access person
Using docker compose:
```yaml
version: "3.3"
services:
homepage:
image: ghcr.io/gethomepage/homepage:latest
container_name: homepage
environment:
PUID: 1000 -- optional, your user id
PGID: 1000 -- optional, your group id
PUID: 1000 # optional, your user id
PGID: 1000 # optional, your group id
ports:
- 3000:3000
volumes:
@@ -104,7 +103,7 @@ docker run --name homepage \
ghcr.io/gethomepage/homepage:latest
```
## With Node
## From Source
First, clone the repository:
@@ -127,15 +126,9 @@ Finally, run the server in production mode:
pnpm start
```
or development mode:
```bash
pnpm dev
```
# Configuration
Please refer to the [homepage documentation](https://gethomepage.dev/) website for more information. Everything you need to know about configuring Homepage is there. Please read everything carefully before asking for help, as most questions are answered there or are simple YAML configuration issues.
Please refer to the [homepage documentation website](https://gethomepage.dev/) for more information. Everything you need to know about configuring Homepage is there. Please read everything carefully before asking for help, as most questions are answered there or are simple YAML configuration issues.
# Development
@@ -175,6 +168,10 @@ mkdocs serve # or build, to build the static site
If you have any questions, suggestions, or general issues, please start a discussion on the [Discussions](https://github.com/gethomepage/homepage/discussions) page.
## Troubleshooting
In addition to the docs, the [troubleshooting guide](https://gethomepage.dev/latest/troubleshooting/) can help reveal many basic config or network issues. If you're having a problem, it's a good place to start.
## Contributing & Contributors
Contributions are welcome! Please see the [CONTRIBUTING.md](CONTRIBUTING.md) file for more information.

View File

@@ -6,7 +6,6 @@ description: Install and run homepage from Docker
Using docker compose:
```yaml
version: "3.3"
services:
homepage:
image: ghcr.io/gethomepage/homepage:latest
@@ -27,7 +26,6 @@ _Using the docker socket directly is not the recommended method of integration a
In the docker compose example below, the environment variables `$PUID` and `$PGID` are set in a `.env` file.
```yaml
version: "3.3"
services:
homepage:
image: ghcr.io/gethomepage/homepage:latest

View File

@@ -57,6 +57,7 @@ self-hosted / open-source alternative, we ask that any widgets, etc. are develop
To ensure cohesiveness of various widgets, the following should be used as a guide for developing new widgets:
- Please only submit widgets that have been requested and have at least 10 'up-votes'. The purpose of this requirement is to avoid the addition (and maintenance) of service widgets that might only benefit a small number of users.
- Note that we reserve the right to decline widgets for projects that are very young (eg < ~1y) or those with a small reach (eg low GitHub stars). Again, this is in an effort to keep overall widget maintenance under control.
- Widgets should be only one row of blocks
- Widgets should be no more than 4 blocks wide and generally conform to the styling / design choices of other widgets
- Minimize the number of API calls

View File

@@ -79,7 +79,21 @@ By default the key is passed as an `X-API-Key` header. If you need to pass the k
### `jsonrpcProxyHandler`
A proxy handler that makes authenticated JSON-RPC requests to the specified API endpoint. Where the endpoint is the method to call.
A proxy handler that makes authenticated JSON-RPC requests to the specified API endpoint, either using username + password or an API token.
The endpoint is the method to call and queryParams are used as the parameters.
=== "component.js"
```js
import Container from "components/services/widget/container";
import useWidgetAPI from "utils/proxy/use-widget-api";
export default function Component({ service }) {
const { widget } = service;
const { data, error } = useWidgetAPI(widget, 'trigger', { "triggerids": "14062", "output": "extend", "selectFunctions": "extend" });
}
```
=== "widget.js"
@@ -93,6 +107,7 @@ A proxy handler that makes authenticated JSON-RPC requests to the specified API
mappings: {
total: { endpoint: "total" },
average: { endpoint: "average" },
trigger: { endpoint: "trigger.get" },
},
};
```
@@ -110,6 +125,16 @@ A proxy handler that makes authenticated JSON-RPC requests to the specified API
password: your-password
```
```yaml
- Your Widget:
icon: yourwidget.svg
href: https://example.com/
widget:
type: yourwidget
url: http://127.0.0.1:1337
key: your-api-token
```
### `synologyProxyHandler`
A proxy handler that makes authenticated requests to the specified Synology API endpoint. This is used exclusively for Synology DSM services.

View File

@@ -1,6 +1,8 @@
---
title: Info Widgets
description: Homepage info widgets.
search:
exclude: true
---
You can also find a list of all available info widgets in the sidebar navigation.

View File

@@ -9,6 +9,8 @@ The disk path is the path reported by `df` (Mounted On), or the mount point of t
The cpu and memory resource information are the container's usage while [glances](glances.md) displays statistics for the host machine on which it is installed.
The resources widget primarily relies on a popular tool called [systeminformation](https://systeminformation.io). Thus, any limitiations of that software apply, for example, BRTFS RAID is not supported for the disk usage. In this case users may want to use the [glances widget](glances.md) instead.
_Note: unfortunately, the package used for getting CPU temp ([systeminformation](https://systeminformation.io)) is not compatible with some setups and will not report any value(s) for CPU temp._
**Any disk you wish to access must be mounted to your container as a volume.**

View File

@@ -54,12 +54,20 @@ widget:
time: other key
color: theme # optional - defaults to "". Allowed values: `["theme", "adaptive", "black", "white"]`.
format: date # optional
- field: key
label: Number of things in array
format: size
# This (no field) will take the root of the API response, e.g. when APIs return an array:
- label: Number of items
format: size
```
Supported formats for the values are `text`, `number`, `float`, `percent`, `bytes`, `bitrate`, `date` and `relativeDate`.
Supported formats for the values are `text`, `number`, `float`, `percent`, `bytes`, `bitrate`, `size`, `date` and `relativeDate`.
The `dateStyle` and `timeStyle` options of the `date` format are passed directly to [Intl.DateTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat) and the `style` and `numeric` options of `relativeDate` are passed to [Intl.RelativeTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/RelativeTimeFormat).
The `size` format will return the length of the array or string, or the number of keys in an object. This is then formatted as `number`.
## Example
For the following JSON object from the API:

View File

@@ -0,0 +1,14 @@
---
title: DeveLanCacheUI
description: DeveLanCacheUI Widget Configuration
---
Learn more about [DeveLanCacheUI](https://github.com/devedse/DeveLanCacheUI_Backend).
```yaml
widget:
type: develancacheui
url: http://your.develancacheui_backend.host:port
```
The url should point to the DeveLanCacheUI Backend (API)

View File

@@ -16,4 +16,5 @@ To group both `offline` and `unknown` devices together, users should use the `of
widget:
type: esphome
url: http://esphome.host.or.ip:port
key: myesphomecookie # only if auth enabled, get the value from a request from the frontend e.g. `authenticated=myesphomecookie`
```

View File

@@ -1,6 +1,8 @@
---
title: Service Widgets
description: Homepage service widgets.
search:
exclude: true
---
You can also find a list of all available service widgets in the sidebar navigation.
@@ -22,6 +24,7 @@ You can also find a list of all available service widgets in the sidebar navigat
- [CrowdSec](crowdsec.md)
- [Custom API](customapi.md)
- [Deluge](deluge.md)
- [DeveLanCacheUI](develancacheui.md)
- [DiskStation](diskstation.md)
- [DownloadStation](downloadstation.md)
- [Emby](emby.md)
@@ -55,6 +58,7 @@ You can also find a list of all available service widgets in the sidebar navigat
- [Komga](komga.md)
- [Kopia](kopia.md)
- [Lidarr](lidarr.md)
- [Linkwarden](linkwarden.md)
- [Mastodon](mastodon.md)
- [Mealie](mealie.md)
- [Medusa](medusa.md)
@@ -111,6 +115,7 @@ You can also find a list of all available service widgets in the sidebar navigat
- [Syncthing Relay Server](syncthing-relay-server.md)
- [Tailscale](tailscale.md)
- [Tandoor](tandoor.md)
- [Technitium DNS](technitium.md)
- [TDarr](tdarr.md)
- [Traefik](traefik.md)
- [Transmission](transmission.md)
@@ -125,3 +130,4 @@ You can also find a list of all available service widgets in the sidebar navigat
- [WGEasy](wgeasy.md)
- [WhatsUpDocker](whatsupdocker.md)
- [xTeVe](xteve.md)
- [Zabbix](zabbix.md)

View File

@@ -0,0 +1,15 @@
---
title: Linkwarden
description: Linkwarden Widget Configuration
---
Learn more about [Linkwarden](https://linkwarden.app/).
Allowed fields: `["links", "collections", "tags"]`.
```yaml
widget:
type: linkwarden
url: http://linkwarden.host.or.ip
key: myApiKeyHere # On your Linkwarden install, go to Settings > Access Tokens. Generate a token.
```

View File

@@ -14,4 +14,5 @@ widget:
type: mealie
url: http://mealie-frontend.host.or.ip
key: mealieapitoken
version: 2 # only required if version > 1, defaults to 1
```

View File

@@ -9,7 +9,7 @@ This widget requires the installation of the [pfsense-api](https://github.com/ja
Once pfSense API is installed, you can set the API to be read-only in System > API > Settings.
There are two currently supported authentication modes: 'Local Database' and 'API Token'. For 'Local Database', use `username` and `password` with the credentials of an admin user. For 'API Token', utilize the `headers` parameter with `client_token` and `client_id` obtained from pfSense as shown below. Do not use both headers and username / password.
There are two currently supported authentication modes: 'Local Database' and 'API Key' (v2) / 'API Token' (v1). For 'Local Database', use `username` and `password` with the credentials of an admin user. The specifics of using the API key / token depend on the version of the pfSense API, see the config examples below. Do not use both headers and username / password.
The interface to monitor is defined by updating the `wan` parameter. It should be referenced as it is shown under Interfaces > Assignments in pfSense.
@@ -17,15 +17,25 @@ Load is returned instead of cpu utilization. This is a limitation in the pfSense
Allowed fields: `["load", "memory", "temp", "wanStatus", "wanIP", "disk"]` (maximum of 4)
For version 2:
```yaml
widget:
type: pfsense
url: http://pfsense.host.or.ip:port
username: user # optional, or API token
password: pass # optional, or API token
username: user # optional, or API key
password: pass # optional, or API key
headers: # optional, or username/password
Authorization: client_id client_token
X-API-Key: key
wan: igb0
version: 2 # optional, defaults to 1 for api v1
fields: ["load", "memory", "temp", "wanStatus"] # optional
```
For version 1:
```yaml
headers: # optional, or username/password
Authorization: client_id client_token # obtained from pfSense API
version: 1
```

View File

@@ -9,22 +9,22 @@ This widget shows the running and total counts of both QEMU VMs and LX Container
You will need to generate an API Token for new or an existing user. Here is an example of how to do this for a new user.
1. Navigate to the Proxmox portal, click on Datacenter
2. Expand Permissions, click on Groups
3. Click the Create button
4. Name the group something informative, like api-ro-users
5. Click on the Permissions "folder"
6. Click Add -> Group Permission
- Path: /
- Group: group from bullet 4 above
- Role: PVEAuditor
- Propagate: Checked
7. Expand Permissions, click on Users
8. Click the Add button
- User name: something informative like `api`
- Realm: Linux PAM standard authentication
- Group: group from bullet 4 above
9. Expand Permissions, click on API Tokens
1. Navigate to the Proxmox portal, click on Datacenter
2. Expand Permissions, click on Groups
3. Click the Create button
4. Name the group something informative, like api-ro-users
5. Click on the Permissions "folder"
6. Click Add -> Group Permission
- Path: /
- Group: group from bullet 4 above
- Role: PVEAuditor
- Propagate: Checked
7. Expand Permissions, click on Users
8. Click the Add button
- User name: something informative like `api`
- Realm: Linux PAM standard authentication
- Group: group from bullet 4 above
9. Expand Permissions, click on API Tokens
10. Click the Add button
- User: user from bullet 8 above
- Token ID: something informative like the application or purpose like `homepage`

View File

@@ -3,7 +3,8 @@ title: Romm
description: Romm Widget Configuration
---
Allowed fields: `["platforms", "totalRoms"]`.
Allowed fields: `["platforms", "totalRoms", "saves", "states", "screenshots", "totalfilesize"]`.
If more than (4) fields are provided, only the first (4) will be used.
```yaml
widget:
@@ -11,4 +12,5 @@ widget:
url: http://romm.host.or.ip
username: username # optional
password: password # optional
fields: ["platforms", "totalRoms", "saves", "states"] # optional - default fields shown
```

View File

@@ -11,4 +11,5 @@ Allowed fields: `["queue", "processed", "errored", "saved"]`.
widget:
type: tdarr
url: http://tdarr.host.or.ip
key: tdarrapikey # optional
```

View File

@@ -0,0 +1,26 @@
---
title: Technitium DNS Server
description: Technitium DNS Server Widget Configuration
---
Learn more about [Technitium DNS Server](https://technitium.com/dns/).
Allowed fields (up to 4): `["totalQueries","totalNoError","totalServerFailure","totalNxDomain","totalRefused","totalAuthoritative","totalRecursive","totalCached","totalBlocked","totalDropped","totalClients"]`.
Defaults to: `["totalQueries", "totalAuthoritative", "totalCached", "totalServerFailure"]`
```yaml
widget:
type: technitium
url: <url to dns server>
key: biglongapitoken
range: LastDay # optional, defaults to LastHour
```
#### API Key
This can be generated via the Technitium DNS Dashboard, and should be generated from a special API specific user.
#### Range
`range` value determines how far back of statistics to pull data for. The value comes directly from Technitium API documentation found [here](https://github.com/TechnitiumSoftware/DnsServer/blob/master/APIDOCS.md#dashboard-api-calls), defined as `"type"`. The value can be one of: `LastHour`, `LastDay`, `LastWeek`, `LastMonth`, `LastYear`.

View File

@@ -5,7 +5,7 @@ description: Tube Archivist Widget Configuration
Learn more about [Tube Archivist](https://github.com/tubearchivist/tubearchivist).
Requires API key.
You must be running at least version 0.4.4
Allowed fields: `["downloads", "videos", "channels", "playlists"]`.
@@ -13,5 +13,5 @@ Allowed fields: `["downloads", "videos", "channels", "playlists"]`.
widget:
type: tubearchivist
url: http://tubearchivist.host.or.ip
key: apikeyapikeyapikeyapikeyapikey
key: tubearchivistapikey
```

View File

@@ -5,7 +5,7 @@ description: Watchtower Widget Configuration
Learn more about [Watchtower](https://github.com/containrrr/watchtower).
To use this widget, Watchtower needs to be configured to to [enable metrics](https://containrrr.dev/watchtower/metrics/).
To use this widget, Watchtower needs to be configured to [enable metrics](https://containrrr.dev/watchtower/metrics/).
Allowed fields: `["containers_scanned", "containers_updated", "containers_failed"]`.

View File

@@ -0,0 +1,21 @@
---
title: Zabbix
description: Zabbix Widget Configuration
---
Learn more about [Zabbix](https://github.com/zabbix/zabbix). The widget supports (at least) Zibbax server version 7.0.
---
Allowed fields: `["unclassified", "information", "warning", "average", "high", "disaster"]`.
Only 4 fields can be shown at a time, with the default being: `["warning", "average", "high", "disaster"]`.
```yaml
widget:
type: zabbix
url: http://zabbix.host.or.ip/zabbix
key: your-api-key
```
See the [Zabbix documentation](https://www.zabbix.com/documentation/current/en/manual/web_interface/frontend_sections/users/api_tokens) for details on generating API tokens.

View File

@@ -80,6 +80,7 @@ nav:
- widgets/services/komga.md
- widgets/services/kopia.md
- widgets/services/lidarr.md
- widgets/services/linkwarden.md
- widgets/services/mastodon.md
- widgets/services/mealie.md
- widgets/services/medusa.md
@@ -136,6 +137,7 @@ nav:
- widgets/services/syncthing-relay-server.md
- widgets/services/tailscale.md
- widgets/services/tandoor.md
- widgets/services/technitium.md
- widgets/services/tdarr.md
- widgets/services/traefik.md
- widgets/services/transmission.md
@@ -150,6 +152,7 @@ nav:
- widgets/services/wgeasy.md
- widgets/services/whatsupdocker.md
- widgets/services/xteve.md
- widgets/services/zabbix.md
- "Information Widgets":
- widgets/info/index.md
- widgets/info/datetime.md

2716
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
{
"name": "startpage",
"version": "0.1.0",
"name": "homepage",
"version": "0.9.6",
"private": true,
"scripts": {
"dev": "next dev",
@@ -17,18 +17,18 @@
"compare-versions": "^6.1.0",
"dockerode": "^4.0.2",
"follow-redirects": "^1.15.6",
"gamedig": "^4.3.1",
"gamedig": "^5.1.2",
"i18next": "^21.10.0",
"js-yaml": "^4.1.0",
"json-rpc-2.0": "^1.7.0",
"luxon": "^3.4.4",
"luxon": "^3.5.0",
"memory-cache": "^0.2.0",
"minecraft-ping-js": "^1.0.2",
"next": "^12.3.4",
"next-i18next": "^12.1.0",
"ping": "^0.4.4",
"pretty-bytes": "^6.1.1",
"raw-body": "^2.5.2",
"raw-body": "^3.0.0",
"react": "^18.3.1",
"react-dom": "^18.2.0",
"react-i18next": "^11.18.6",
@@ -36,22 +36,22 @@
"recharts": "^2.12.6",
"rrule": "^2.8.1",
"swr": "^1.3.0",
"systeminformation": "^5.22.7",
"systeminformation": "^5.23.2",
"tough-cookie": "^4.1.3",
"urbackup-server-api": "^0.8.9",
"urbackup-server-api": "^0.52.0",
"winston": "^3.11.0",
"xml-js": "^1.6.11"
},
"devDependencies": {
"@tailwindcss/forms": "^0.5.7",
"autoprefixer": "^10.4.17",
"@tailwindcss/forms": "^0.5.8",
"autoprefixer": "^10.4.20",
"eslint": "^8.57.0",
"eslint-config-airbnb": "^19.0.4",
"eslint-config-next": "^14.2.3",
"eslint-config-prettier": "^9.1.0",
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-jsx-a11y": "^6.8.0",
"eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-prettier": "^5.2.1",
"eslint-plugin-react": "^7.34.2",
"eslint-plugin-react-hooks": "^4.6.2",
"postcss": "^8.4.38",

7016
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -226,6 +226,10 @@
"leech": "Seier",
"seed": "Vul"
},
"develancacheui": {
"cachehitbytes": "Kas Tref Grepe",
"cachemissbytes": "Kas Mis Grepe"
},
"downloadstation": {
"download": "Aflaai",
"upload": "Laai Op",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Terug"
},
"technitium": {
"totalQueries": "Navraë",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Geblok",
"totalDropped": "Dropped",
"totalClients": "Kliënte"
},
"tdarr": {
"queue": "Tou",
"processed": "Verwerk",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platform",
"totalRoms": "Totale ROMs"
"totalRoms": "Spelle",
"saves": "Beware",
"states": "Toestande",
"screenshots": "Skermskote",
"totalfilesize": "Totale Grootte"
},
"netdata": {
"warnings": "Waarskuwings",
@@ -902,8 +923,21 @@
"invalidConfiguration": "Ongeldige opstelling"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Kameras",
"uptime": "Optyd",
"version": "Weergawe"
},
"linkwarden": {
"links": "Skakels",
"collections": "Versamelings",
"tags": "Merkers"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informasie",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "في انتظار قطع الاتصال",
"connectionStatusDisconnecting": "جار قطع الاتصال",
"connectionStatusDisconnected": "غير متصل",
"connectionStatusConnected": "Connected",
"connectionStatusConnected": "متصل",
"uptime": "مدة التشغيل",
"maxDown": "أقصى حد للتنزيل",
"maxUp": "أقصى حد للتحميل",
@@ -226,6 +226,10 @@
"leech": "القرناء",
"seed": "البذور"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "التنزيل",
"upload": "التحميل",
@@ -279,9 +283,9 @@
},
"netalertx": {
"total": "المجموع",
"connected": "Connected",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
"connected": "متصل",
"new_devices": "أجهزة جديدة",
"down_alerts": "تنبيهات تعطل"
},
"pihole": {
"queries": "الاستعلامات",
@@ -319,6 +323,19 @@
"seconds": "{{number}}ث",
"ago": "منذ {{value}}"
},
"technitium": {
"totalQueries": "الاستعلامات",
"totalNoError": "تم بنجاح",
"totalServerFailure": "فشل",
"totalNxDomain": "مجالات NX",
"totalRefused": "مرفوض",
"totalAuthoritative": "موثوقة",
"totalRecursive": "عودي",
"totalCached": "مخبأ",
"totalBlocked": "محظور",
"totalDropped": "أسقطت",
"totalClients": "العملاء"
},
"tdarr": {
"queue": "إنتظار",
"processed": "معالجة",
@@ -427,7 +444,7 @@
"custom": "مُخصّص",
"visit": "زيارة",
"url": "الرابط",
"searchsuggestion": "Suggestion"
"searchsuggestion": "الإقتراحات"
},
"wmo": {
"0-day": "مشمس",
@@ -544,7 +561,7 @@
"hdhomerun": {
"channels": "القنوات",
"hd": "جودة HD",
"tunerCount": "Tuners",
"tunerCount": "التونز",
"channelNumber": "القناة",
"channelNetwork": "الشبكة",
"signalStrength": "القوة",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "المِنصات",
"totalRoms": "مجموع الروومات"
"totalRoms": "ألعاب",
"saves": "نُقَط حفظ",
"states": "حالات",
"screenshots": "لقطات شاشة",
"totalfilesize": "الحجم الكلي"
},
"netdata": {
"warnings": "تحذيرات",
@@ -846,7 +867,7 @@
},
"stash": {
"scenes": "المشاهد",
"scenesPlayed": "Scenes Played",
"scenesPlayed": "مشاهد شغلت",
"playCount": "إجمالي المشغلات",
"playDuration": "وقت المشاهدة",
"sceneSize": "حجم المشاهد",
@@ -854,7 +875,7 @@
"images": "صور",
"imageSize": "حجم الصور",
"galleries": "المعارض",
"performers": "Performers",
"performers": "ممثلين",
"studios": "استوديوهات",
"movies": "أفلام",
"tags": "التصنيفات",
@@ -863,11 +884,11 @@
"tandoor": {
"users": "المستخدمون",
"recipes": "وصفات",
"keywords": "Keywords"
"keywords": "كلمات مفتاح"
},
"homebox": {
"items": "Items",
"totalWithWarranty": "With Warranty",
"items": "عناصر",
"totalWithWarranty": "بالضمان",
"locations": "Locations",
"labels": "Labels",
"users": "المستخدمون",
@@ -878,7 +899,7 @@
"bans": "Bans"
},
"wgeasy": {
"connected": "Connected",
"connected": "متصل",
"enabled": "مفعل",
"disabled": "معطل",
"total": "المجموع"
@@ -896,14 +917,27 @@
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"loading": "تحميل",
"open": "مفتوحة - السوق الأمريكية",
"closed": "مغلقة - السوق الأمريكية",
"invalidConfiguration": "إعدادات غير صحيحة"
},
"frigate": {
"cameras": "Cameras",
"cameras": "كاميرات",
"uptime": "مدة التشغيل",
"version": "الإصدار"
},
"linkwarden": {
"links": "روابط",
"collections": "مجموعات",
"tags": "التصنيفات"
},
"zabbix": {
"unclassified": "غير مصنفة",
"information": "معلومات",
"warning": "تحذيرات",
"average": "متوسط",
"high": "عالي",
"disaster": "كارثة"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}сек",
"ago": "преди {{value}}"
},
"technitium": {
"totalQueries": "Заявки",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Блокирани",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Опашка",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Тагове"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Информация",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Sangonera",
"seed": "Llavors"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Descarregar",
"upload": "Pujada",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Fa {{value}}"
},
"technitium": {
"totalQueries": "Consultes",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloquejat",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Cua",
"processed": "Processat",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plataformes",
"totalRoms": "ROMs totals"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Avisos",
@@ -902,8 +923,21 @@
"invalidConfiguration": "Configuració no vàlida"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Càmeres",
"uptime": "Temps actiu",
"version": "Versió"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Etiquetes"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informació",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Čeká na odpojení",
"connectionStatusDisconnecting": "Odpojování",
"connectionStatusDisconnected": "Odpojeno",
"connectionStatusConnected": "Connected",
"connectionStatusConnected": "",
"uptime": "Doba spuštění",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -226,6 +226,10 @@
"leech": "Leechované",
"seed": "Seedované"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Stahování",
"upload": "Nahrávání",
@@ -279,8 +283,8 @@
},
"netalertx": {
"total": "Celkem",
"connected": "Connected",
"new_devices": "New Devices",
"connected": "",
"new_devices": "",
"down_alerts": "Down Alerts"
},
"pihole": {
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Před {{value}}"
},
"technitium": {
"totalQueries": "Dotazy",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blokováno",
"totalDropped": "Dropped",
"totalClients": "Klienti"
},
"tdarr": {
"queue": "Fronta",
"processed": "Zpracováno",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -878,7 +899,7 @@
"bans": "Bans"
},
"wgeasy": {
"connected": "Connected",
"connected": "",
"enabled": "Povoleno",
"disabled": "Zakázáno",
"total": "Celkem"
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Doba spuštění",
"version": "Verze"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informace",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Siden"
},
"technitium": {
"totalQueries": "Forespørgsler",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blokerede",
"totalDropped": "Dropped",
"totalClients": "Klienter"
},
"tdarr": {
"queue": "Kø",
"processed": "Behandlet",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforme",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Advarsler",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Oppetid",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -14,7 +14,7 @@
"date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
"months": "mo",
"months": "Mo.",
"days": "d",
"hours": "h",
"minutes": "min",
@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache-Trefferbytes",
"cachemissbytes": "Cache-Fehlbytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Vor {{value}}"
},
"technitium": {
"totalQueries": "Anfragen",
"totalNoError": "Erfolgreich",
"totalServerFailure": "Fehler",
"totalNxDomain": "NX-Domänen",
"totalRefused": "Verweigert",
"totalAuthoritative": "Autoritativ",
"totalRecursive": "Rekursiv",
"totalCached": "Im Cache",
"totalBlocked": "Blockiert",
"totalDropped": "Verworfen",
"totalClients": "Benutzer"
},
"tdarr": {
"queue": "Warteschlange",
"processed": "Verarbeitet",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plattformen",
"totalRoms": "ROMs gesamt"
"totalRoms": "Spiele",
"saves": "Spielstände",
"states": "Speicherstände",
"screenshots": "Bildschirmfotos",
"totalfilesize": "Gesamtgröße"
},
"netdata": {
"warnings": "Warnungen",
@@ -902,8 +923,21 @@
"invalidConfiguration": "Ungültige Konfiguration"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Kameras",
"uptime": "Betriebszeit",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Sammlungen",
"tags": "Schlagwörter"
},
"zabbix": {
"unclassified": "Nicht klassifiziert",
"information": "Informationen",
"warning": "Warnung",
"average": "Durchschnitt",
"high": "Hoch",
"disaster": "Katastrophe"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Λήξη",
"upload": "Μεταφόρτωση",
@@ -319,6 +323,19 @@
"seconds": "{{number}}δευτερόλεπτα",
"ago": "{{value}} πρίν"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Αποκλεισμένο",
"totalDropped": "Dropped",
"totalClients": "Πελάτες"
},
"tdarr": {
"queue": "Ουρά",
"processed": "Σε επεξεργασία",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Χρόνος Λειτουργίας",
"version": "Έκδοση"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Ετικέτες"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Πληροφορία",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Elŝuti",
"upload": "Alŝuti",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Klientoj"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informo",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -12,7 +12,7 @@
"number": "{{value, number}}",
"ms": "{{value, number}}",
"date": "{{value, date}}",
"relativeDate": "{{valor, relativaFecha}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
"months": "me",
"days": "d",
@@ -226,6 +226,10 @@
"leech": "Descargas",
"seed": "Semillas"
},
"develancacheui": {
"cachehitbytes": "Bytes encontrados en caché",
"cachemissbytes": "Bytes faltantes en caché"
},
"downloadstation": {
"download": "Descarga",
"upload": "Subida",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Hace {{value}}"
},
"technitium": {
"totalQueries": "Consultas",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloqueado",
"totalDropped": "Dropped",
"totalClients": "Clientes"
},
"tdarr": {
"queue": "En cola",
"processed": "Procesado",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plataformas",
"totalRoms": "ROMs totales"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Advertencias",
@@ -852,13 +873,13 @@
"sceneSize": "Tamaño de las escenas",
"sceneDuration": "Duración de las escenas",
"images": "Imágenes",
"imageSize": "Tamaño de imagen",
"imageSize": "Tamaño de las imágenes",
"galleries": "Galerías",
"performers": "Intérpretes",
"studios": "Estudios",
"movies": "Películas",
"tags": "Etiquetas",
"oCount": "O cuenta"
"oCount": "Cantidad de O"
},
"tandoor": {
"users": "Usuarios",
@@ -867,7 +888,7 @@
},
"homebox": {
"items": "Objetos",
"totalWithWarranty": "Con Garantía",
"totalWithWarranty": "Con garantía",
"locations": "Ubicaciones",
"labels": "Etiquetas",
"users": "Usuarios",
@@ -885,7 +906,7 @@
},
"swagdashboard": {
"proxied": "Proxy activado",
"auth": "Con Autenticación",
"auth": "Con autenticación",
"outdated": "Desactualizado",
"banned": "Baneado"
},
@@ -897,13 +918,26 @@
"stocks": {
"stocks": "Acciones",
"loading": "Cargando",
"open": "Abierto - Mercado EEUU",
"closed": "Cerrado - Mercado EEUU",
"invalidConfiguration": "Configuración no válida"
"open": "Abierto - Mercado EE. UU.",
"closed": "Cerrado - Mercado EE. UU.",
"invalidConfiguration": "Configuración inválida"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Cámaras",
"uptime": "Tiempo activo",
"version": "Versión"
},
"linkwarden": {
"links": "Enlaces",
"collections": "Colecciones",
"tags": "Etiquetas"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Información",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informazioa",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Kyselyjä",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Estetty",
"totalDropped": "Dropped",
"totalClients": "Asiakasohjelmia"
},
"tdarr": {
"queue": "Jono",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Récep.",
"upload": "Envoi",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Il y a {{value}}"
},
"technitium": {
"totalQueries": "Requêtes",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloqué",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "En attente",
"processed": "Traité",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plateformes",
"totalRoms": "Total des ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Avertissements",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Démarré depuis",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Étiquettes"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informations",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "שאילתות",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "נחסם",
"totalDropped": "Dropped",
"totalClients": "לקוחות"
},
"tdarr": {
"queue": "תור",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Korištenje tuđeg sadržaja",
"seed": "Prenošenje preuzetog sadržaja"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Preuzimanje",
"upload": "Prijenos",
@@ -319,6 +323,19 @@
"seconds": "{{number}} s",
"ago": "Prije {{value}}"
},
"technitium": {
"totalQueries": "Upiti",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blokirano",
"totalDropped": "Dropped",
"totalClients": "Klijenti"
},
"tdarr": {
"queue": "Red čekanja",
"processed": "Obrađeno",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforme",
"totalRoms": "Ukupne ROM memorije"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Upozorenja",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Vrijeme rada",
"version": "Verzija"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Oznake"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informacije",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Letöltés",
"upload": "Feltöltés",
@@ -319,6 +323,19 @@
"seconds": "{{number}}mp",
"ago": "{{value}} Ezelőtt"
},
"technitium": {
"totalQueries": "Lekérdezések",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blokkolt",
"totalDropped": "Dropped",
"totalClients": "Kliensek"
},
"tdarr": {
"queue": "Sor",
"processed": "Feldolgozott",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Felület",
"totalRoms": "Minden ROM"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Figyelmeztetések",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Üzemidő",
"version": "Verzió"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Címkék"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Információ",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Unduh",
"upload": "Unggah",
@@ -319,6 +323,19 @@
"seconds": "{{number}}d",
"ago": "{{value}} Yang Lalu"
},
"technitium": {
"totalQueries": "Kueri",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Terblokir",
"totalDropped": "Dropped",
"totalClients": "Klien"
},
"tdarr": {
"queue": "Antrian",
"processed": "Terproses",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platform",
"totalRoms": "ROM Total"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Peringatan",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Waktu Aktif",
"version": "Versi"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tag"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informasi",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "In download",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -287,7 +291,7 @@
"queries": "Richieste",
"blocked": "Bloccati",
"blocked_percent": "Bloccato %",
"gravity": "Severità"
"gravity": "Gravity"
},
"adguard": {
"queries": "Richieste",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Fa"
},
"technitium": {
"totalQueries": "Richieste",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloccati",
"totalDropped": "Dropped",
"totalClients": "Client"
},
"tdarr": {
"queue": "Coda",
"processed": "Elaborati",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Piattaforme",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Avvisi",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Tempo di attività",
"version": "Versione"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tag"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informazioni",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "リーチ",
"seed": "シード"
},
"develancacheui": {
"cachehitbytes": "キャッシュ・ヒットバイト",
"cachemissbytes": "キャッシュミスバイト"
},
"downloadstation": {
"download": "ダウンロード",
"upload": "アップロード",
@@ -319,6 +323,19 @@
"seconds": "{{number}}秒",
"ago": "{{value}} 前"
},
"technitium": {
"totalQueries": "クエリ",
"totalNoError": "成功",
"totalServerFailure": "失敗",
"totalNxDomain": "NXドメイン",
"totalRefused": "拒否",
"totalAuthoritative": "正式",
"totalRecursive": "再帰的",
"totalCached": "キャッシュ済み",
"totalBlocked": "ブロック中",
"totalDropped": "ドロップ済み",
"totalClients": "クライアント"
},
"tdarr": {
"queue": "キュー",
"processed": "処理済み",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "プラットフォーム",
"totalRoms": "ROMの合計"
"totalRoms": "ゲーム",
"saves": "保存",
"states": "状態",
"screenshots": "スクリーンショット",
"totalfilesize": "合計サイズ"
},
"netdata": {
"warnings": "警告",
@@ -884,10 +905,10 @@
"total": "合計"
},
"swagdashboard": {
"proxied": "Proxied",
"auth": "With Auth",
"outdated": "Outdated",
"banned": "Banned"
"proxied": "プロキシ済",
"auth": "認証あり",
"outdated": "最新の状態ではありません",
"banned": "禁止"
},
"myspeed": {
"ping": "Ping",
@@ -895,15 +916,28 @@
"upload": "アップロード"
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"stocks": "在庫",
"loading": "読み込み中",
"open": "オープン - 米国市場",
"closed": "クローズ - 米国市場",
"invalidConfiguration": "無効な設定"
},
"frigate": {
"cameras": "Cameras",
"cameras": "カメラ",
"uptime": "稼働時間",
"version": "バージョン"
},
"linkwarden": {
"links": "リンク",
"collections": "コレクション",
"tags": "タグ"
},
"zabbix": {
"unclassified": "Not classified",
"information": "情報",
"warning": "警告",
"average": "平均",
"high": "高い",
"disaster": "災害"
}
}

View File

@@ -110,14 +110,14 @@
"esphome": {
"offline": "중지",
"offline_alt": "중지",
"online": "Online",
"online": "온라인",
"total": "총합",
"unknown": "알 수 없음"
},
"evcc": {
"pv_power": "Production",
"battery_soc": "배터리",
"grid_power": "Grid",
"grid_power": "눈금",
"home_power": "Consumption",
"charge_power": "Charger",
"watt_hour": "Wh"
@@ -129,7 +129,7 @@
"seed": "시드"
},
"freshrss": {
"subscriptions": "Subscriptions",
"subscriptions": "구독",
"unread": "읽지 않음"
},
"fritzbox": {
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Pending Disconnect",
"connectionStatusDisconnecting": "연결을 끊는 중...",
"connectionStatusDisconnected": "연결 끊김",
"connectionStatusConnected": "Connected",
"connectionStatusConnected": "연결됨",
"uptime": "Uptime",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -161,7 +161,7 @@
},
"channelsdvrserver": {
"shows": "보기",
"recordings": "Recordings",
"recordings": "녹화",
"scheduled": "예정됨",
"passes": "Passes"
},
@@ -213,12 +213,12 @@
"seed": "시드"
},
"qnap": {
"cpuUsage": "CPU Usage",
"memUsage": "MEM Usage",
"systemTempC": "System Temp",
"cpuUsage": "CPU 사용",
"memUsage": "메모리 사용",
"systemTempC": "시스템 온도",
"poolUsage": "Pool Usage",
"volumeUsage": "Volume Usage",
"invalid": "Invalid"
"invalid": "잘못됨"
},
"deluge": {
"download": "다운로드",
@@ -226,6 +226,10 @@
"leech": "리치",
"seed": "시드"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "다운로드",
"upload": "업로드",
@@ -279,7 +283,7 @@
},
"netalertx": {
"total": "총합",
"connected": "Connected",
"connected": "연결됨",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
},
@@ -309,8 +313,8 @@
"address": "주소",
"expires": "만료",
"never": "Never",
"last_seen": "Last Seen",
"now": "Now",
"last_seen": "마지막 접속",
"now": "지금",
"years": "{{number}}년",
"weeks": "{{number}}월",
"days": "{{number}}일",
@@ -319,6 +323,19 @@
"seconds": "{{number}}초",
"ago": "{{value}} 전"
},
"technitium": {
"totalQueries": "쿼리",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "차단됨",
"totalDropped": "Dropped",
"totalClients": "클라이언트"
},
"tdarr": {
"queue": "대기열",
"processed": "처리됨",
@@ -370,7 +387,7 @@
},
"mastodon": {
"user_count": "사용자",
"status_count": "Posts",
"status_count": "게시글",
"domain_count": "Domains"
},
"medusa": {
@@ -382,11 +399,11 @@
"players": "Players",
"version": "버전",
"status": "상태",
"up": "Online",
"up": "온라인",
"down": "중지"
},
"miniflux": {
"read": "Read",
"read": "읽음",
"unread": "읽지 않음"
},
"authentik": {
@@ -398,15 +415,15 @@
"mem": "MEM",
"cpu": "CPU",
"lxc": "LXC",
"vms": "VMs"
"vms": "가상머신"
},
"glances": {
"cpu": "CPU",
"load": "부하",
"wait": "잠시만 기다리세요",
"temp": "온도",
"_temp": "Temp",
"warn": "Warn",
"_temp": "온도",
"warn": "경고",
"uptime": "가동",
"total": "총합",
"free": "남음",
@@ -414,30 +431,30 @@
"days": "d",
"hours": "h",
"crit": "Crit",
"read": "Read",
"write": "Write",
"read": "읽음",
"write": "쓰기",
"gpu": "GPU",
"mem": "Mem",
"mem": "Men",
"swap": "Swap"
},
"quicklaunch": {
"bookmark": "Bookmark",
"service": "Service",
"search": "Search",
"custom": "Custom",
"bookmark": "즐겨찾기",
"service": "서비스",
"search": "검색",
"custom": "사용자 정의",
"visit": "Visit",
"url": "URL",
"searchsuggestion": "Suggestion"
},
"wmo": {
"0-day": "Sunny",
"0-day": "화창함",
"0-night": "Clear",
"1-day": "Mainly Sunny",
"1-night": "Mainly Clear",
"2-day": "Partly Cloudy",
"2-night": "Partly Cloudy",
"3-day": "Cloudy",
"3-night": "Cloudy",
"3-day": "구름 낀",
"3-night": "구름 낀",
"45-day": "Foggy",
"45-night": "Foggy",
"48-day": "Foggy",
@@ -462,14 +479,14 @@
"66-night": "Freezing Rain",
"67-day": "Freezing Rain",
"67-night": "Freezing Rain",
"71-day": "Light Snow",
"71-night": "Light Snow",
"71-day": "약한 눈",
"71-night": "약한 눈",
"73-day": "Snow",
"73-night": "Snow",
"75-day": "Heavy Snow",
"75-night": "Heavy Snow",
"77-day": "Snow Grains",
"77-night": "Snow Grains",
"75-day": "폭설",
"75-night": "폭설",
"77-day": "싸락눈",
"77-night": "싸락눈",
"80-day": "Light Showers",
"80-night": "Light Showers",
"81-day": "Showers",
@@ -489,9 +506,9 @@
},
"homebridge": {
"available_update": "System",
"updates": "Updates",
"update_available": "Update Available",
"up_to_date": "Up to Date",
"updates": "업데이트",
"update_available": "새 업데이트 사용 가능",
"up_to_date": "최신 상태",
"child_bridges": "Child Bridges",
"child_bridges_status": "{{ok}}/{{total}}",
"up": "Up",
@@ -499,7 +516,7 @@
"down": "Down"
},
"healthchecks": {
"new": "New",
"new": "신규",
"up": "Up",
"grace": "In Grace Period",
"down": "Down",
@@ -545,13 +562,13 @@
"channels": "Channels",
"hd": "HD",
"tunerCount": "Tuners",
"channelNumber": "Channel",
"channelNetwork": "Network",
"channelNumber": "채널",
"channelNetwork": "네트워크",
"signalStrength": "Strength",
"signalQuality": "Quality",
"symbolQuality": "Quality",
"networkRate": "비트레이트",
"clientIP": "Client"
"clientIP": "클라이언트"
},
"scrutiny": {
"passed": "Passed",
@@ -559,16 +576,16 @@
"unknown": "알 수 없음"
},
"paperlessngx": {
"inbox": "Inbox",
"inbox": "받은메일함",
"total": "총합"
},
"peanut": {
"battery_charge": "Battery Charge",
"battery_charge": "배터리 충전 중",
"ups_load": "UPS Load",
"ups_status": "UPS Status",
"online": "Online",
"on_battery": "On Battery",
"low_battery": "Low Battery"
"online": "온라인",
"on_battery": "배터리 사용",
"low_battery": "배터리 부족"
},
"nextdns": {
"wait": "잠시만 기다리세요",
@@ -576,20 +593,20 @@
},
"mikrotik": {
"cpuLoad": "CPU Load",
"memoryUsed": "Memory Used",
"memoryUsed": "메모리 사용량",
"uptime": "Uptime",
"numberOfLeases": "Leases"
},
"xteve": {
"streams_all": "All Streams",
"streams_all": "모든 스트림",
"streams_active": "활성 스트림",
"streams_xepg": "XEPG Channels"
},
"opendtu": {
"yieldDay": "Today",
"absolutePower": "Power",
"relativePower": "Power %",
"limit": "Limit"
"yieldDay": "오늘",
"absolutePower": "전원",
"relativePower": "전원 %",
"limit": "제한"
},
"opnsense": {
"cpu": "CPU Load",
@@ -600,7 +617,7 @@
"moonraker": {
"printer_state": "Printer State",
"print_status": "Print Status",
"print_progress": "Progress",
"print_progress": "진행",
"layers": "Layers"
},
"octoprint": {
@@ -619,7 +636,7 @@
"wanStatus": "WAN Status",
"up": "Up",
"down": "Down",
"temp": "Temp",
"temp": "온도",
"disk": "Disk Usage",
"wanIP": "WAN IP"
},
@@ -676,7 +693,7 @@
"time": "Time"
},
"grafana": {
"dashboards": "Dashboards",
"dashboards": "대시보드",
"datasources": "Data Sources",
"totalalerts": "Total Alerts",
"alertstriggered": "Alerts Triggered"
@@ -703,7 +720,7 @@
},
"pterodactyl": {
"servers": "Servers",
"nodes": "Nodes"
"nodes": "노드"
},
"prometheus": {
"targets_up": "Targets Up",
@@ -716,15 +733,15 @@
"uptime": "Uptime"
},
"ghostfolio": {
"gross_percent_today": "Today",
"gross_percent_today": "오늘",
"gross_percent_1y": "One year",
"gross_percent_max": "All time"
},
"audiobookshelf": {
"podcasts": "Podcasts",
"books": "책",
"podcastsDuration": "Duration",
"booksDuration": "Duration"
"podcastsDuration": "지속시간",
"booksDuration": "지속시간"
},
"homeassistant": {
"people_home": "People Home",
@@ -733,7 +750,7 @@
},
"whatsupdocker": {
"monitoring": "Monitoring",
"updates": "Updates"
"updates": "업데이트"
},
"calibreweb": {
"books": "책",
@@ -766,19 +783,19 @@
},
"gamedig": {
"status": "상태",
"online": "Online",
"online": "온라인",
"offline": "중지",
"name": "Name",
"map": "Map",
"name": "이름",
"map": "지도",
"currentPlayers": "Current players",
"players": "Players",
"maxPlayers": "Max players",
"bots": "Bots",
"bots": "",
"ping": "Ping"
},
"urbackup": {
"ok": "Ok",
"errored": "Errors",
"ok": "확인",
"errored": "오류 :",
"noRecent": "Out of Date",
"totalUsed": "Used Storage"
},
@@ -786,10 +803,10 @@
"recipes": "Recipes",
"users": "사용자",
"categories": "Categories",
"tags": "Tags"
"tags": "태그"
},
"openmediavault": {
"downloading": "Downloading",
"downloading": "다운로드 중",
"total": "총합",
"running": "가동 중",
"stopped": "중지",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -840,12 +861,12 @@
"species": "Species"
},
"gitea": {
"notifications": "Notifications",
"notifications": "알림",
"issues": "Issues",
"pulls": "Pull Requests"
},
"stash": {
"scenes": "Scenes",
"scenes": "장면",
"scenesPlayed": "Scenes Played",
"playCount": "Total Plays",
"playDuration": "Time Watched",
@@ -855,18 +876,18 @@
"imageSize": "Images Size",
"galleries": "Galleries",
"performers": "Performers",
"studios": "Studios",
"studios": "스튜디오",
"movies": "영화",
"tags": "Tags",
"tags": "태그",
"oCount": "O Count"
},
"tandoor": {
"users": "사용자",
"recipes": "Recipes",
"keywords": "Keywords"
"keywords": "키워드"
},
"homebox": {
"items": "Items",
"items": "아이템",
"totalWithWarranty": "With Warranty",
"locations": "Locations",
"labels": "Labels",
@@ -878,7 +899,7 @@
"bans": "Bans"
},
"wgeasy": {
"connected": "Connected",
"connected": "연결됨",
"enabled": "활성",
"disabled": "비활성",
"total": "총합"
@@ -896,14 +917,27 @@
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"loading": "로드 중",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
},
"frigate": {
"cameras": "Cameras",
"cameras": "카메라",
"uptime": "Uptime",
"version": "버전"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "태그"
},
"zabbix": {
"unclassified": "Not classified",
"information": "정보",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Ņēmēji",
"seed": "Devēji"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Lejupielāde",
"upload": "Augšupielāde",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Rindā",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informācija",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Muat turun",
"upload": "Muat naik",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Lepas"
},
"technitium": {
"totalQueries": "Permintaan",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Disekat",
"totalDropped": "Dropped",
"totalClients": "Klien"
},
"tdarr": {
"queue": "Barisan",
"processed": "Sudah diprosess",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platform",
"totalRoms": "Jumlah ROM"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Amaran",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Masa Hidup",
"version": "Versi"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tanda nama"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informasi",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -71,8 +71,8 @@
"tx": "TX",
"mem": "GEH",
"cpu": "CPU",
"running": "Wordt uitgevoerd",
"offline": "Onbereikbaar",
"running": "Actief",
"offline": "Offline",
"error": "Fout",
"unknown": "Onbekend",
"healthy": "Gezond",
@@ -108,8 +108,8 @@
"songs": "Nummers"
},
"esphome": {
"offline": "Onbereikbaar",
"offline_alt": "Onbereikbaar",
"offline": "Offline",
"offline_alt": "Offline",
"online": "Bereikbaar",
"total": "Totaal",
"unknown": "Onbekend"
@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Delen"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -301,7 +305,7 @@
"ping": "Ping"
},
"portainer": {
"running": "Wordt uitgevoerd",
"running": "Actief",
"stopped": "Gestopt",
"total": "Totaal"
},
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Geleden"
},
"technitium": {
"totalQueries": "Verzoeken",
"totalNoError": "Geslaagd",
"totalServerFailure": "Gefaald",
"totalNxDomain": "NX Domains",
"totalRefused": "Geweigerd",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Gecached",
"totalBlocked": "Geblokkeerd",
"totalDropped": "Dropped",
"totalClients": "Cliënten"
},
"tdarr": {
"queue": "Wachtrij",
"processed": "Verwerkt",
@@ -383,7 +400,7 @@
"version": "Versie",
"status": "Status",
"up": "Bereikbaar",
"down": "Onbereikbaar"
"down": "Offline"
},
"miniflux": {
"read": "Gelezen",
@@ -767,7 +784,7 @@
"gamedig": {
"status": "Status",
"online": "Bereikbaar",
"offline": "Onbereikbaar",
"offline": "Offline",
"name": "Naam",
"map": "Kaart",
"currentPlayers": "Huidige spelers",
@@ -791,7 +808,7 @@
"openmediavault": {
"downloading": "Downloaden",
"total": "Totaal",
"running": "Wordt uitgevoerd",
"running": "Actief",
"stopped": "Gestopt",
"passed": "Geslaagd",
"failed": "Gefaald"
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platformen",
"totalRoms": "Totale ROM's"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots ",
"totalfilesize": "Totale grootte"
},
"netdata": {
"warnings": "Waarschuwingen",
@@ -886,8 +907,8 @@
"swagdashboard": {
"proxied": "Proxied",
"auth": "With Auth",
"outdated": "Outdated",
"banned": "Banned"
"outdated": "Verouderd",
"banned": "Verbannen"
},
"myspeed": {
"ping": "Ping",
@@ -895,15 +916,28 @@
"upload": "Upload"
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"stocks": "Aandelen",
"loading": "Laden",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"invalidConfiguration": "Ongeldige configuratie"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Camera's",
"uptime": "Online",
"version": "Versie"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Label"
},
"zabbix": {
"unclassified": "Niet geclassificeerd",
"information": "Informatie",
"warning": "Waarschuwingen",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Last ned",
"upload": "Opplastning",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Spørringer",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blokkert",
"totalDropped": "Dropped",
"totalClients": "Klienter"
},
"tdarr": {
"queue": "Kø",
"processed": "Behandlet",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plattformer",
"totalRoms": "Totale ROM-er"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Advarsler",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Oppetid",
"version": "Versjon"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Stikkord"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informasjon",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Oczekujące rozłączenie",
"connectionStatusDisconnecting": "Rozłączanie",
"connectionStatusDisconnected": "Rozłączono",
"connectionStatusConnected": "Connected",
"connectionStatusConnected": "Połączono",
"uptime": "Czas działania",
"maxDown": "Maks. Pobieranie",
"maxUp": "Maks. Wysyłanie",
@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Trafienia w cache'u",
"cachemissbytes": "Straty cache'u"
},
"downloadstation": {
"download": "Pobieranie",
"upload": "Wysyłanie",
@@ -279,9 +283,9 @@
},
"netalertx": {
"total": "Całkowite",
"connected": "Connected",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
"connected": "Połączono",
"new_devices": "Nowe urządzenia",
"down_alerts": "Alerty niedostępności"
},
"pihole": {
"queries": "Zapytania",
@@ -319,6 +323,19 @@
"seconds": "{{number}}sekund",
"ago": "{{value}} temu"
},
"technitium": {
"totalQueries": "Zapytania",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Zablokowane",
"totalDropped": "Dropped",
"totalClients": "Klienci"
},
"tdarr": {
"queue": "Kolejka",
"processed": "Przetworzone",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platformy",
"totalRoms": "Łącznie ROM"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Ostrzeżenia",
@@ -878,16 +899,16 @@
"bans": "Bany"
},
"wgeasy": {
"connected": "Connected",
"connected": "Połączono",
"enabled": "Włączone",
"disabled": "Wyłączone",
"total": "Całkowite"
},
"swagdashboard": {
"proxied": "Proxied",
"auth": "With Auth",
"outdated": "Outdated",
"banned": "Banned"
"proxied": "Poprzez proxy",
"auth": "Z uwietrzytelnieniem",
"outdated": "Nieaktualne",
"banned": "Zbanowano"
},
"myspeed": {
"ping": "Ping",
@@ -895,15 +916,28 @@
"upload": "Wysyłanie"
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"stocks": "Giełda",
"loading": "Wczytywanie",
"open": "Otwarte - rynek US",
"closed": "Zamknięte - rynek US",
"invalidConfiguration": "Nieprawidłowa konfiguracja"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Kamery",
"uptime": "Czas działania",
"version": "Wersja"
},
"linkwarden": {
"links": "Łącza",
"collections": "Kolekcje",
"tags": "Tagi"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informacje",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -14,7 +14,7 @@
"date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
"months": "mes",
"months": "mês",
"days": "d",
"hours": "h",
"minutes": "min",
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Desconexão pendente",
"connectionStatusDisconnecting": "Desconectando",
"connectionStatusDisconnected": "Desconectado",
"connectionStatusConnected": "Connected",
"connectionStatusConnected": "Conectado",
"uptime": "Ligado",
"maxDown": "Máx. de Descarga",
"maxUp": "Max. de Envio",
@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Semente"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Descarregar",
"upload": "Carregar",
@@ -279,9 +283,9 @@
},
"netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
"connected": "Conectado",
"new_devices": "Novos dispositivos",
"down_alerts": "Alertas de Falha"
},
"pihole": {
"queries": "Consultas",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Atrás"
},
"technitium": {
"totalQueries": "Consultas",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloqueado",
"totalDropped": "Dropped",
"totalClients": "Clientes"
},
"tdarr": {
"queue": "Fila",
"processed": "Processado",
@@ -427,7 +444,7 @@
"custom": "Personalizado",
"visit": "Visitar",
"url": "Endereço URL",
"searchsuggestion": "Suggestion"
"searchsuggestion": "Sugestão"
},
"wmo": {
"0-day": "Solarengo",
@@ -544,14 +561,14 @@
"hdhomerun": {
"channels": "Canais",
"hd": "HD",
"tunerCount": "Tuners",
"channelNumber": "Channel",
"channelNetwork": "Network",
"signalStrength": "Strength",
"signalQuality": "Quality",
"symbolQuality": "Quality",
"tunerCount": "Sintonizadores",
"channelNumber": "Canal",
"channelNetwork": "Rede",
"signalStrength": "Potência",
"signalQuality": "Qualidade",
"symbolQuality": "Qualidade",
"networkRate": "Taxa de bits",
"clientIP": "Client"
"clientIP": "Cliente"
},
"scrutiny": {
"passed": "Aprovado",
@@ -798,10 +815,10 @@
},
"openwrt": {
"uptime": "Ligado",
"cpuLoad": "CPU Load Avg (5m)",
"cpuLoad": "Carga da CPU média (5m)",
"up": "Up",
"down": "Down",
"bytesTx": "Transmitted",
"bytesTx": "Transmitido",
"bytesRx": "Recebido"
},
"uptimerobot": {
@@ -826,68 +843,72 @@
"noEventsFound": "Nenhum evento encontrado"
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"platforms": "Plataformas",
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
"criticals": "Criticals"
"warnings": "Avisos",
"criticals": "Críticos"
},
"plantit": {
"events": "Events",
"plants": "Plants",
"events": "Eventos",
"plants": "Plantas",
"photos": "Fotos",
"species": "Species"
"species": "Espécies"
},
"gitea": {
"notifications": "Notifications",
"notifications": "Notificações",
"issues": "Problemas",
"pulls": "Pull Requests"
"pulls": "Solicitar pull"
},
"stash": {
"scenes": "Scenes",
"scenesPlayed": "Scenes Played",
"playCount": "Total Plays",
"playDuration": "Time Watched",
"sceneSize": "Scenes Size",
"sceneDuration": "Scenes Duration",
"images": "Images",
"imageSize": "Images Size",
"galleries": "Galleries",
"performers": "Performers",
"studios": "Studios",
"scenes": "Cenas",
"scenesPlayed": "Cenas reproduzidas",
"playCount": "Total de Reproduções",
"playDuration": "Tempo Assistido",
"sceneSize": "Tamanho das cenas",
"sceneDuration": "Duração das cenas",
"images": "Imagens",
"imageSize": "Tamanho das imagens",
"galleries": "Galerias",
"performers": "Artistas",
"studios": "Estúdios",
"movies": "Filmes",
"tags": "Etiquetas",
"oCount": "O Count"
"oCount": "Contagem de O's"
},
"tandoor": {
"users": "Utilizadores",
"recipes": "Receitas",
"keywords": "Keywords"
"keywords": "Palavras-chave"
},
"homebox": {
"items": "Items",
"totalWithWarranty": "With Warranty",
"locations": "Locations",
"labels": "Labels",
"totalWithWarranty": "Com Garantia",
"locations": "Localizações",
"labels": "Etiquetas",
"users": "Utilizadores",
"totalValue": "Total Value"
"totalValue": "Valor Total"
},
"crowdsec": {
"alerts": "Alertas",
"bans": "Bans"
"bans": "Banidos"
},
"wgeasy": {
"connected": "Connected",
"connected": "Conectado",
"enabled": "Ativo",
"disabled": "Desabilitado",
"total": "Total"
},
"swagdashboard": {
"proxied": "Proxied",
"auth": "With Auth",
"outdated": "Outdated",
"banned": "Banned"
"proxied": "Com proxy",
"auth": "Com Autorização",
"outdated": "Desatualizado",
"banned": "Banido"
},
"myspeed": {
"ping": "Tempo de resposta",
@@ -895,15 +916,28 @@
"upload": "Carregar"
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"stocks": "Ações",
"loading": "Carregando",
"open": "Aberto - Mercado dos EUA",
"closed": "Fechado - Mercado dos EUA",
"invalidConfiguration": "Configuração inválida"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Câmaras",
"uptime": "Ligado",
"version": "Versão"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Etiquetas"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informação",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -24,16 +24,16 @@
"missing_type": "Tipo de Widget ausente: {{type}}",
"api_error": "Erros de API",
"information": "Informação",
"status": "Estado",
"status": "Status",
"url": "Endereço URL",
"raw_error": "Erro Raw",
"response_data": "Dados da Resposta"
"raw_error": "Erro Bruto",
"response_data": "Dados de Resposta"
},
"weather": {
"current": "Localização atual",
"allow": "Clicar para permitir",
"allow": "Clique para permitir",
"updating": "Atualizando",
"wait": "Por favor aguarde"
"wait": "Por favor, aguarde"
},
"search": {
"placeholder": "Pesquisar…"
@@ -50,7 +50,7 @@
"uptime": "CIMA"
},
"unifi": {
"users": "Utilizadores",
"users": "Usuários",
"uptime": "Ligado",
"days": "Dias",
"wan": "WAN",
@@ -59,20 +59,20 @@
"devices": "Dispositivos",
"lan_devices": "Dispositivos LAN",
"wlan_devices": "Dispositivos WLAN",
"lan_users": "Utilizadores LAN",
"wlan_users": "Utilizadores WLAN",
"lan_users": "Usuários de LAN",
"wlan_users": "Usuários de WLAN",
"up": "CIMA",
"down": "Desligado",
"wait": "Por favor aguarde",
"empty_data": "Status de Subsistema Desconhecido"
"wait": "Por favor, aguarde",
"empty_data": "Status do Subsistema desconhecido"
},
"docker": {
"rx": "Rx",
"tx": "Tx",
"mem": "MEM",
"cpu": "CPU",
"running": "A correr",
"offline": "Desligado",
"running": "Executando",
"offline": "Offline",
"error": "Erro",
"unknown": "Desconhecido",
"healthy": "Saudável",
@@ -108,8 +108,8 @@
"songs": "Canções"
},
"esphome": {
"offline": "Desligado",
"offline_alt": "Desligado",
"offline": "Offline",
"offline_alt": "Offline",
"online": "Disponível",
"total": "Total",
"unknown": "Desconhecido"
@@ -133,7 +133,7 @@
"unread": "Não lida"
},
"fritzbox": {
"connectionStatus": "Estado",
"connectionStatus": "Status",
"connectionStatusUnconfigured": "Não configurado",
"connectionStatusConnecting": "Conectando",
"connectionStatusAuthenticating": "Autenticando",
@@ -142,7 +142,7 @@
"connectionStatusDisconnected": "Desconectado",
"connectionStatusConnected": "Conectado",
"uptime": "Ligado",
"maxDown": "Max. Down",
"maxDown": "Tempo de inatividade máximo",
"maxUp": "Máx. Acima",
"down": "Inativo",
"up": "Ativo",
@@ -216,7 +216,7 @@
"cpuUsage": "Uso de CPU",
"memUsage": "Uso de Memória",
"systemTempC": "Temp. do Sistema",
"poolUsage": "Pool Usage",
"poolUsage": "Uso do Pool",
"volumeUsage": "Uso do volume",
"invalid": "Inválido"
},
@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Semente"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Descarregar",
"upload": "Carregar",
@@ -301,7 +305,7 @@
"ping": "Tempo de resposta"
},
"portainer": {
"running": "A correr",
"running": "Executando",
"stopped": "Parado",
"total": "Total"
},
@@ -311,14 +315,27 @@
"never": "Nunca",
"last_seen": "Visto por último",
"now": "Agora",
"years": "{{number}}y",
"weeks": "{{number}}w",
"years": "{{number}}a",
"weeks": "{{number}}s",
"days": "{{number}}d",
"hours": "{{number}}h",
"minutes": "{{number}}m",
"seconds": "{{number}}s",
"ago": "{{value}} Atrás"
},
"technitium": {
"totalQueries": "Consultas",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Bloqueado",
"totalDropped": "Dropped",
"totalClients": "Clientes"
},
"tdarr": {
"queue": "Fila",
"processed": "Processado",
@@ -369,7 +386,7 @@
"transferRate": "Taxa"
},
"mastodon": {
"user_count": "Utilizadores",
"user_count": "Usuários",
"status_count": "Postagens",
"domain_count": "Domínios"
},
@@ -381,16 +398,16 @@
"minecraft": {
"players": "Reprodutores",
"version": "Versão",
"status": "Estado",
"status": "Status",
"up": "Disponível",
"down": "Desligado"
"down": "Offline"
},
"miniflux": {
"read": "Lido",
"unread": "Não lida"
},
"authentik": {
"users": "Utilizadores",
"users": "Usuários",
"loginsLast24H": "Inícios de sessão (24h)",
"failedLoginsLast24H": "Inícios de sessão falhados (24h)"
},
@@ -403,7 +420,7 @@
"glances": {
"cpu": "CPU",
"load": "Carga",
"wait": "Por favor aguarde",
"wait": "Por favor, aguarde",
"temp": "TEMP",
"_temp": "Temperatura",
"warn": "Aviso",
@@ -504,7 +521,7 @@
"grace": "Em Período Gratuito",
"down": "Inativo",
"paused": "Pausado",
"status": "Estado",
"status": "Status",
"last_ping": "Ultimo Ping",
"never": "Nenhum ping ainda"
},
@@ -604,14 +621,14 @@
"layers": "Camadas"
},
"octoprint": {
"printer_state": "Estado",
"printer_state": "Status",
"temp_tool": "Temp. Ferramenta",
"temp_bed": "Temp. Cama",
"job_completion": "Conclusão"
},
"cloudflared": {
"origin_ip": "IP Origem",
"status": "Estado"
"status": "Status"
},
"pfsense": {
"load": "Carga Média",
@@ -630,7 +647,7 @@
"memory_usage": "Memória"
},
"immich": {
"users": "Utilizadores",
"users": "Usuários",
"photos": "Fotos",
"videos": "Vídeos",
"storage": "Armazenamento"
@@ -690,7 +707,7 @@
"numshares": "Itens compartilhados"
},
"kopia": {
"status": "Estado",
"status": "Status",
"size": "Tamanho",
"lastrun": "Ultima Execução",
"nextrun": "Próxima Execução",
@@ -753,7 +770,7 @@
},
"azuredevops": {
"result": "Resultado",
"status": "Estado",
"status": "Status",
"buildId": "ID Compilação",
"succeeded": "Bem-sucedido",
"notStarted": "Não iniciado",
@@ -765,9 +782,9 @@
"approved": "Aprovada"
},
"gamedig": {
"status": "Estado",
"status": "Status",
"online": "Disponível",
"offline": "Desligado",
"offline": "Offline",
"name": "Nome",
"map": "Mapa",
"currentPlayers": "Jogadores atuais",
@@ -784,14 +801,14 @@
},
"mealie": {
"recipes": "Receitas",
"users": "Utilizadores",
"users": "Usuários",
"categories": "Categorias",
"tags": "Marcadores"
},
"openmediavault": {
"downloading": "Baixando",
"total": "Total",
"running": "A correr",
"running": "Executando",
"stopped": "Parado",
"passed": "Aprovado",
"failed": "Falhou"
@@ -805,7 +822,7 @@
"bytesRx": "Recebido"
},
"uptimerobot": {
"status": "Estado",
"status": "Status",
"uptime": "Ligado",
"lastDown": "Última inatividade",
"downDuration": "Duração de inatividade",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Plataformas",
"totalRoms": "Total de ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Alertas",
@@ -861,7 +882,7 @@
"oCount": "Contagem 0"
},
"tandoor": {
"users": "Utilizadores",
"users": "Usuários",
"recipes": "Receitas",
"keywords": "Palavras-chave"
},
@@ -870,7 +891,7 @@
"totalWithWarranty": "Com Garantia",
"locations": "Localização",
"labels": "Rótulos",
"users": "Utilizadores",
"users": "Usuários",
"totalValue": "Valor Total"
},
"crowdsec": {
@@ -902,8 +923,21 @@
"invalidConfiguration": "Configuração Inválida"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Câmeras",
"uptime": "Ligado",
"version": "Versão"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Marcadores"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informação",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Descarcă",
"upload": "Încarcă",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Cereri",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocate",
"totalDropped": "Dropped",
"totalClients": "Clienți"
},
"tdarr": {
"queue": "Coadă",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informație",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -39,7 +39,7 @@
"placeholder": "Поиск…"
},
"resources": {
"cpu": "ЦПУ",
"cpu": "ЦП",
"mem": "ОЗУ",
"total": "Всего",
"free": "Свободно",
@@ -70,7 +70,7 @@
"rx": "RX",
"tx": "TX",
"mem": "ОЗУ",
"cpu": "ЦПУ",
"cpu": "ЦП",
"running": "Запущено",
"offline": "Не в сети",
"error": "Ошибка",
@@ -226,6 +226,10 @@
"leech": "Лич",
"seed": "Сид"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Скачивание",
"upload": "Загрузка",
@@ -319,6 +323,19 @@
"seconds": "{{number}}с",
"ago": "{{value}} назад"
},
"technitium": {
"totalQueries": "Запросы",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Заблокировано",
"totalDropped": "Dropped",
"totalClients": "Клиенты"
},
"tdarr": {
"queue": "Очередь",
"processed": "Обработано",
@@ -396,12 +413,12 @@
},
"proxmox": {
"mem": "ОЗУ",
"cpu": "ЦПУ",
"cpu": "ЦП",
"lxc": "LXC",
"vms": "Виртуальные машины"
},
"glances": {
"cpu": "ЦПУ",
"cpu": "ЦП",
"load": "Загрузка",
"wait": "Пожалуйста, подождите",
"temp": "Температура",
@@ -626,7 +643,7 @@
"proxmoxbackupserver": {
"datastore_usage": "Хранилище данных",
"failed_tasks_24h": "Неудачные задачи 24 часа",
"cpu_usage": "ЦПУ",
"cpu_usage": "ЦП",
"memory_usage": "ОЗУ"
},
"immich": {
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Платформы",
"totalRoms": "Всего ПЗУ"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Предупреждения",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Время работы",
"version": "Версия"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Теги"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Информация",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leechované",
"seed": "Seedované"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Sťahovanie",
"upload": "Nahrávanie",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "Pred {{value}}"
},
"technitium": {
"totalQueries": "Dopyty",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Zablokované",
"totalDropped": "Dropped",
"totalClients": "Klienti"
},
"tdarr": {
"queue": "V poradí",
"processed": "Spracované",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platformy",
"totalRoms": "Celkovo ROM"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Upozornenia",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Prevádzka",
"version": "Verzia"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Štítky"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Informácia",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Pijavka",
"seed": "Sejanje"
},
"develancacheui": {
"cachehitbytes": "Predpomn. zadetki",
"cachemissbytes": "Predpomn. zgrešeno"
},
"downloadstation": {
"download": "Prenos",
"upload": "Nalaganje",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} nazaj"
},
"technitium": {
"totalQueries": "Poizvedbe",
"totalNoError": "Uspeh",
"totalServerFailure": "Neuspehi",
"totalNxDomain": "NX domene",
"totalRefused": "Zavrnjeno",
"totalAuthoritative": "Avtoratitavno",
"totalRecursive": "Rekurzivno",
"totalCached": "Predpomnjeno",
"totalBlocked": "Blokirano",
"totalDropped": "Izpuščeno",
"totalClients": "Klienti"
},
"tdarr": {
"queue": "Vrsta",
"processed": "Procesiran",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforme",
"totalRoms": "Skupaj ROM-ov"
"totalRoms": "Igre",
"saves": "Shranitve",
"states": "Stanja",
"screenshots": "Posnetki zaslona",
"totalfilesize": "Skupna velikost"
},
"netdata": {
"warnings": "Opozorila",
@@ -902,8 +923,21 @@
"invalidConfiguration": "Neveljavna konfiguracija"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Kamere",
"uptime": "Čas delovanja",
"version": "Verzija"
},
"linkwarden": {
"links": "Povezave",
"collections": "Zbirke",
"tags": "Značke"
},
"zabbix": {
"unclassified": "Nerazvrščeno",
"information": "Informacija",
"warning": "Opozorilo",
"average": "Povprečno",
"high": "Visoko",
"disaster": "Katastrofa"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Förfrågningar",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blockerad",
"totalDropped": "Dropped",
"totalClients": "Klienter"
},
"tdarr": {
"queue": "Kö",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Länkar",
"collections": "Samlingar",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "ప్రశ్నలు",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "నిరోధించబడింది",
"totalDropped": "Dropped",
"totalClients": "ఖాతాదారులు"
},
"tdarr": {
"queue": "వరుస",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "ดาวน์โหลด",
"upload": "อัพโหลด",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Queue",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "ข้อมูล",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Tüketici",
"seed": "Sağlayıcı"
},
"develancacheui": {
"cachehitbytes": "Önbellek İsabetli Byte",
"cachemissbytes": "Önbellek Kaçırılan Byte"
},
"downloadstation": {
"download": "İndirme",
"upload": "Yükleme",
@@ -319,6 +323,19 @@
"seconds": "{{number}} Saniye",
"ago": "{{value}} Önce"
},
"technitium": {
"totalQueries": "Sorgular",
"totalNoError": "Başarılı",
"totalServerFailure": "Başarısızlıklar",
"totalNxDomain": "NX Alan Adları",
"totalRefused": "Reddedildi",
"totalAuthoritative": "Yetkili",
"totalRecursive": "Tekrarlamalı",
"totalCached": "Önbelleğe alındı",
"totalBlocked": "Engellenen",
"totalDropped": "Bırakıldı",
"totalClients": "Alıcılar"
},
"tdarr": {
"queue": "Kuyruk",
"processed": "İşlendi",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platformlar",
"totalRoms": "Toplam ROM'lar"
"totalRoms": "Oyunlar",
"saves": "Kayıtlar",
"states": "Durumlar",
"screenshots": "Ekran görüntüleri",
"totalfilesize": "Toplam Kapasite"
},
"netdata": {
"warnings": "Uyarılar",
@@ -902,8 +923,21 @@
"invalidConfiguration": "Geçersiz Yapılandırma"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Kameralar",
"uptime": "Çalışma Süresi",
"version": "Versiyon"
},
"linkwarden": {
"links": "Bağlantılar",
"collections": "Koleksiyonlar",
"tags": "Etiketler"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Bilgi",
"warning": "Uyarı",
"average": "Ortalama",
"high": "Yüksek",
"disaster": "Felaket"
}
}

View File

@@ -14,11 +14,11 @@
"date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
"months": "mo",
"days": "d",
"hours": "h",
"minutes": "m",
"seconds": "s"
"months": "міс",
"days": "д",
"hours": "г",
"minutes": "хв",
"seconds": "с"
},
"widget": {
"missing_type": "Відсутній тип віджета: {{type}}",
@@ -85,17 +85,17 @@
"ping": {
"error": "Помилка",
"ping": "Пінг",
"down": "Down",
"up": "Up",
"not_available": "Not Available"
"down": "Офлайн",
"up": "Онлайн",
"not_available": "Не доступний"
},
"siteMonitor": {
"http_status": "HTTP status",
"http_status": "HTTP статус",
"error": "Помилка",
"response": "Response",
"down": "Down",
"up": "Up",
"not_available": "Not Available"
"response": "Відповідь",
"down": "Офлайн",
"up": "Онлайн",
"not_available": "Не доступний"
},
"emby": {
"playing": "Відтворення",
@@ -134,21 +134,21 @@
},
"fritzbox": {
"connectionStatus": "Стан",
"connectionStatusUnconfigured": "Unconfigured",
"connectionStatusConnecting": "Connecting",
"connectionStatusAuthenticating": "Authenticating",
"connectionStatusPendingDisconnect": "Pending Disconnect",
"connectionStatusDisconnecting": "Disconnecting",
"connectionStatusDisconnected": "Disconnected",
"connectionStatusConnected": "Connected",
"connectionStatusUnconfigured": "Не налаштовано",
"connectionStatusConnecting": "Підключення",
"connectionStatusAuthenticating": "Автентифікація",
"connectionStatusPendingDisconnect": "Очікує відключення",
"connectionStatusDisconnecting": "Відключення",
"connectionStatusDisconnected": "Відключено",
"connectionStatusConnected": "З'єднано",
"uptime": "Час роботи",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
"down": "Down",
"up": "Up",
"received": "Received",
"sent": "Sent",
"externalIPAddress": "Ext. IP"
"maxDown": "Макс. зав",
"maxUp": "Макс. віддача",
"down": "Офлайн",
"up": "Онлайн",
"received": "Отримано",
"sent": "Надісл.",
"externalIPAddress": "Зовн. IP"
},
"caddy": {
"upstreams": "Потоки",
@@ -226,6 +226,10 @@
"leech": "Ліч",
"seed": "Сід"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Завантаження",
"upload": "Відправлення",
@@ -279,9 +283,9 @@
},
"netalertx": {
"total": "Усього",
"connected": "Connected",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
"connected": "З'єднано",
"new_devices": "Нові пристрої",
"down_alerts": "Спов. про падіння"
},
"pihole": {
"queries": "Запити",
@@ -319,6 +323,19 @@
"seconds": "{{number}}с",
"ago": "{{value}} тому"
},
"technitium": {
"totalQueries": "Запити",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Заблоковано",
"totalDropped": "Dropped",
"totalClients": "Клієнти"
},
"tdarr": {
"queue": "Черга",
"processed": "Обробка",
@@ -405,15 +422,15 @@
"load": "Завантаження",
"wait": "Будь ласка, зачекайте",
"temp": "Температура",
"_temp": "Temp",
"_temp": "Темп.",
"warn": "Увага",
"uptime": "Відправка",
"total": "Усього",
"free": "Вільно",
"used": "Використано",
"days": "d",
"hours": "h",
"crit": "Crit",
"days": "д",
"hours": "г",
"crit": "Крит",
"read": "Прочитано",
"write": "Написати",
"gpu": "GPU",
@@ -427,7 +444,7 @@
"custom": "Користувацький",
"visit": "Відвідайте",
"url": "URL-адреса",
"searchsuggestion": "Suggestion"
"searchsuggestion": "Пропозиція"
},
"wmo": {
"0-day": "Сонячно",
@@ -494,15 +511,15 @@
"up_to_date": "Актуально",
"child_bridges": "Дитячі мости",
"child_bridges_status": "{{ok}}/{{total}}",
"up": "Up",
"up": "Онлайн",
"pending": "В очікуванні",
"down": "Down"
"down": "Офлайн"
},
"healthchecks": {
"new": "Новий",
"up": "Up",
"up": "Онлайн",
"grace": "У пільговий період",
"down": "Down",
"down": "Офлайн",
"paused": "Призупинено",
"status": "Стан",
"last_ping": "Останній пінг",
@@ -544,14 +561,14 @@
"hdhomerun": {
"channels": "Канали",
"hd": "HD",
"tunerCount": "Tuners",
"channelNumber": "Channel",
"channelNetwork": "Network",
"signalStrength": "Strength",
"signalQuality": "Quality",
"symbolQuality": "Quality",
"tunerCount": "Тюнери",
"channelNumber": "Канал",
"channelNetwork": "Мережа",
"signalStrength": "Сила",
"signalQuality": "Якість",
"symbolQuality": "Якість",
"networkRate": "Бітрейт",
"clientIP": "Client"
"clientIP": "Клієнт"
},
"scrutiny": {
"passed": "Пройшов",
@@ -563,12 +580,12 @@
"total": "Усього"
},
"peanut": {
"battery_charge": "Battery Charge",
"ups_load": "UPS Load",
"ups_status": "UPS Status",
"battery_charge": "Заряд батареї",
"ups_load": "UPS завантаження",
"ups_status": "Статус UPS",
"online": "Онлайн",
"on_battery": "On Battery",
"low_battery": "Low Battery"
"on_battery": "Від батареї",
"low_battery": "Низький заряд"
},
"nextdns": {
"wait": "Будь ласка, зачекайте",
@@ -586,10 +603,10 @@
"streams_xepg": "Канали XEPG"
},
"opendtu": {
"yieldDay": "Today",
"absolutePower": "Power",
"relativePower": "Power %",
"limit": "Limit"
"yieldDay": "Сьогодні",
"absolutePower": "Абс. потуж.",
"relativePower": "Заряд %",
"limit": "Ліміт"
},
"opnsense": {
"cpu": "Завантаження CPU",
@@ -617,9 +634,9 @@
"load": "Середнє завантаження",
"memory": "Використання пам'яті",
"wanStatus": "Статус WAN",
"up": "Up",
"down": "Down",
"temp": "Temp",
"up": "Онлайн",
"down": "Офлайн",
"temp": "Темп.",
"disk": "Використання диска",
"wanIP": "WAN IP"
},
@@ -640,7 +657,7 @@
"down": "Неактивні сайти",
"uptime": "Час роботи",
"incident": "Інцидент",
"m": "m"
"m": "хв"
},
"atsumeru": {
"series": "Серії",
@@ -716,7 +733,7 @@
"uptime": "Час роботи"
},
"ghostfolio": {
"gross_percent_today": "Today",
"gross_percent_today": "Сьогодні",
"gross_percent_1y": "Один рік",
"gross_percent_max": "Весь час"
},
@@ -783,13 +800,13 @@
"totalUsed": "Використовувана пам'ять"
},
"mealie": {
"recipes": "Recipes",
"recipes": "Отримувачі",
"users": "Користувачі",
"categories": "Категорії",
"tags": "Tags"
"tags": "Теги"
},
"openmediavault": {
"downloading": "Downloading",
"downloading": "Завантаження",
"total": "Усього",
"running": "Запущено",
"stopped": "Зупинено",
@@ -799,10 +816,10 @@
"openwrt": {
"uptime": "Час роботи",
"cpuLoad": "CPU Load Avg (5m)",
"up": "Up",
"down": "Down",
"up": "Онлайн",
"down": "Офлайн",
"bytesTx": "Transmitted",
"bytesRx": "Received"
"bytesRx": "Отримано"
},
"uptimerobot": {
"status": "Стан",
@@ -813,9 +830,9 @@
"sitesDown": "Неактивні сайти",
"paused": "Призупинено",
"notyetchecked": "Not Yet Checked",
"up": "Up",
"up": "Онлайн",
"seemsdown": "Seems Down",
"down": "Down",
"down": "Офлайн",
"unknown": "Невідомий"
},
"calendar": {
@@ -827,10 +844,14 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
"warnings": "Попередження",
"criticals": "Criticals"
},
"plantit": {
@@ -840,7 +861,7 @@
"species": "Species"
},
"gitea": {
"notifications": "Notifications",
"notifications": "Сповіщення",
"issues": "Питання",
"pulls": "Pull Requests"
},
@@ -854,22 +875,22 @@
"images": "Images",
"imageSize": "Images Size",
"galleries": "Galleries",
"performers": "Performers",
"performers": "Виконавці",
"studios": "Studios",
"movies": "Фільми",
"tags": "Tags",
"tags": "Теги",
"oCount": "O Count"
},
"tandoor": {
"users": "Користувачі",
"recipes": "Recipes",
"keywords": "Keywords"
"recipes": "Отримувачі",
"keywords": "Ключові слова"
},
"homebox": {
"items": "Items",
"totalWithWarranty": "With Warranty",
"locations": "Locations",
"labels": "Labels",
"locations": "Місцезнаходження",
"labels": "Мітки",
"users": "Користувачі",
"totalValue": "Total Value"
},
@@ -878,7 +899,7 @@
"bans": "Bans"
},
"wgeasy": {
"connected": "Connected",
"connected": "З'єднано",
"enabled": "Увімкнено",
"disabled": "Вимкнено",
"total": "Усього"
@@ -896,14 +917,27 @@
},
"stocks": {
"stocks": "Stocks",
"loading": "Loading",
"loading": "Завантажую",
"open": "Open - US Market",
"closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration"
"invalidConfiguration": "Неприпустима конфігурація"
},
"frigate": {
"cameras": "Cameras",
"cameras": "Камери",
"uptime": "Час роботи",
"version": "Версія"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Теги"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Інформація",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "Leech",
"seed": "Seed"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "Download",
"upload": "Upload",
@@ -319,6 +323,19 @@
"seconds": "{{number}}s",
"ago": "{{value}} Ago"
},
"technitium": {
"totalQueries": "Queries",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "Blocked",
"totalDropped": "Dropped",
"totalClients": "Clients"
},
"tdarr": {
"queue": "Hàng chờ",
"processed": "Processed",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "Platforms",
"totalRoms": "Total ROMs"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "Warnings",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "Uptime",
"version": "Version"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "Tags"
},
"zabbix": {
"unclassified": "Not classified",
"information": "Information",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -226,6 +226,10 @@
"leech": "未完成下載",
"seed": "已完成下載"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "下載速率",
"upload": "上傳速率",
@@ -319,6 +323,19 @@
"seconds": "{{number}} 秒",
"ago": "{{value}} 前"
},
"technitium": {
"totalQueries": "查詢",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "封鎖",
"totalDropped": "Dropped",
"totalClients": "客戶端"
},
"tdarr": {
"queue": "隊列",
"processed": "已處理",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "平台",
"totalRoms": "總唯讀記憶體"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "警告",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "運行時間",
"version": "版本"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "標籤"
},
"zabbix": {
"unclassified": "Not classified",
"information": "資訊",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -226,6 +226,10 @@
"leech": "未完成下載",
"seed": "已完成下載"
},
"develancacheui": {
"cachehitbytes": "Cache Hit Bytes",
"cachemissbytes": "Cache Miss Bytes"
},
"downloadstation": {
"download": "下載速率",
"upload": "上傳速率",
@@ -319,6 +323,19 @@
"seconds": "{{number}} 秒",
"ago": "{{value}} 前"
},
"technitium": {
"totalQueries": "查詢",
"totalNoError": "Success",
"totalServerFailure": "Failures",
"totalNxDomain": "NX Domains",
"totalRefused": "Refused",
"totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive",
"totalCached": "Cached",
"totalBlocked": "已阻擋",
"totalDropped": "Dropped",
"totalClients": "客戶端"
},
"tdarr": {
"queue": "佇列",
"processed": "已處理",
@@ -827,7 +844,11 @@
},
"romm": {
"platforms": "平台",
"totalRoms": "總唯讀記憶體"
"totalRoms": "Games",
"saves": "Saves",
"states": "States",
"screenshots": "Screenshots",
"totalfilesize": "Total Size"
},
"netdata": {
"warnings": "警告",
@@ -905,5 +926,18 @@
"cameras": "Cameras",
"uptime": "運行時間",
"version": "版本"
},
"linkwarden": {
"links": "Links",
"collections": "Collections",
"tags": "標籤"
},
"zabbix": {
"unclassified": "Not classified",
"information": "資訊",
"warning": "Warning",
"average": "Average",
"high": "High",
"disaster": "Disaster"
}
}

View File

@@ -12,6 +12,10 @@ function displayData(data) {
export default function Error({ error }) {
const { t } = useTranslation();
if (typeof error === "string") {
error = { message: error }; // eslint-disable-line no-param-reassign
}
if (error?.data?.error) {
error = error.data.error; // eslint-disable-line no-param-reassign
}

View File

@@ -14,7 +14,7 @@ export function slugifyAndEncode(tabName) {
export default function Tab({ tab }) {
const { activeTab, setActiveTab } = useContext(TabContext);
const matchesTab = decodeURI(activeTab) === slugify(tab);
const matchesTab = decodeURIComponent(activeTab) === slugify(tab);
return (
<li

View File

@@ -48,8 +48,8 @@ export default async function handler(req, res) {
logger.error(`no pods found with namespace=${namespace} and labelSelector=${labelSelector}`);
return;
}
const someReady = pods.find((pod) => ["Completed", "Running"].includes(pod.status.phase));
const allReady = pods.every((pod) => ["Completed", "Running"].includes(pod.status.phase));
const someReady = pods.find((pod) => ["Succeeded", "Running"].includes(pod.status.phase));
const allReady = pods.every((pod) => ["Succeeded", "Running"].includes(pod.status.phase));
let status = "down";
if (allReady) {
status = "running";

View File

@@ -22,11 +22,12 @@ export default async function handler(req, res) {
.then((response) => response.body)
.catch((error) => {
logger.error("Error getting ingresses: %d %s %s", error.statusCode, error.body, error.response);
logger.debug(error);
return null;
});
if (!nodes) {
return res.status(500).send({
error: "unknown error",
error: "An error occurred while fetching nodes, check logs for more details.",
});
}
let cpuTotal = 0;

View File

@@ -1,5 +1,9 @@
import { existsSync } from "fs";
import createLogger from "utils/logger";
const logger = createLogger("resources");
const si = require("systeminformation");
export default async function handler(req, res) {
@@ -23,26 +27,31 @@ export default async function handler(req, res) {
}
const fsSize = await si.fsSize();
logger.debug("fsSize:", JSON.stringify(fsSize));
return res.status(200).json({
drive: fsSize.find((fs) => fs.mount === target) ?? fsSize.find((fs) => fs.mount === "/"),
});
}
if (type === "memory") {
const memory = await si.mem();
logger.debug("memory:", JSON.stringify(memory));
return res.status(200).json({
memory: await si.mem(),
memory,
});
}
if (type === "cputemp") {
const cputemp = await si.cpuTemperature();
logger.debug("cputemp:", JSON.stringify(cputemp));
return res.status(200).json({
cputemp: await si.cpuTemperature(),
cputemp,
});
}
if (type === "uptime") {
const timeData = await si.time();
logger.debug("timeData:", JSON.stringify(timeData));
return res.status(200).json({
uptime: timeData.uptime,
});

View File

@@ -198,6 +198,7 @@ export async function servicesFromKubernetes() {
.then((response) => response.body)
.catch((error) => {
logger.error("Error getting ingresses: %d %s %s", error.statusCode, error.body, error.response);
logger.debug(error);
return null;
});
@@ -215,6 +216,7 @@ export async function servicesFromKubernetes() {
error.body,
error.response,
);
logger.debug(error);
}
return [];
@@ -231,6 +233,7 @@ export async function servicesFromKubernetes() {
error.body,
error.response,
);
logger.debug(error);
}
return [];
@@ -300,6 +303,7 @@ export async function servicesFromKubernetes() {
constructedService = JSON.parse(substituteEnvironmentVars(JSON.stringify(constructedService)));
} catch (e) {
logger.error("Error attempting k8s environment variable substitution.");
logger.debug(e);
}
return constructedService;
@@ -402,7 +406,7 @@ export function cleanServiceGroups(groups) {
// frigate
enableRecentEvents,
// glances, pihole, pfsense
// glances, mealie, pihole, pfsense
version,
// glances
@@ -473,6 +477,9 @@ export function cleanServiceGroups(groups) {
// wgeasy
threshold,
// technitium
range,
} = cleanedService.widget;
let fieldsList = fields;
@@ -512,9 +519,6 @@ export function cleanServiceGroups(groups) {
if (type === "unifi") {
if (site) cleanedService.widget.site = site;
}
if (type === "pfsense") {
if (version) cleanedService.widget.version = version;
}
if (type === "proxmox") {
if (node) cleanedService.widget.node = node;
}
@@ -561,7 +565,7 @@ export function cleanServiceGroups(groups) {
if (snapshotHost) cleanedService.widget.snapshotHost = snapshotHost;
if (snapshotPath) cleanedService.widget.snapshotPath = snapshotPath;
}
if (["glances", "pihole"].includes(type)) {
if (["glances", "mealie", "pfsense", "pihole"].includes(type)) {
if (version) cleanedService.widget.version = version;
}
if (type === "glances") {
@@ -620,6 +624,9 @@ export function cleanServiceGroups(groups) {
if (type === "frigate") {
if (enableRecentEvents !== undefined) cleanedService.widget.enableRecentEvents = enableRecentEvents;
}
if (type === "technitium") {
if (range !== undefined) cleanedService.widget.range = range;
}
}
return cleanedService;

View File

@@ -35,9 +35,16 @@ export default async function credentialedProxyHandler(req, res, map) {
} else if (widget.type === "gotify") {
headers["X-gotify-Key"] = `${widget.key}`;
} else if (
["authentik", "cloudflared", "ghostfolio", "mealie", "tailscale", "tandoor", "pterodactyl"].includes(
widget.type,
)
[
"authentik",
"cloudflared",
"ghostfolio",
"linkwarden",
"mealie",
"tailscale",
"tandoor",
"pterodactyl",
].includes(widget.type)
) {
headers.Authorization = `Bearer ${widget.key}`;
} else if (widget.type === "truenas") {
@@ -77,6 +84,12 @@ export default async function credentialedProxyHandler(req, res, map) {
headers.Key = `${widget.key}`;
} else if (widget.type === "myspeed") {
headers.Password = `${widget.password}`;
} else if (widget.type === "esphome") {
if (widget.key) {
headers.Cookie = `authenticated=${widget.key}`;
}
} else if (widget.type === "wgeasy") {
headers.Authorization = widget.password;
} else {
headers["X-API-Key"] = `${widget.key}`;
}

View File

@@ -8,14 +8,18 @@ import widgets from "widgets/widgets";
const logger = createLogger("jsonrpcProxyHandler");
export async function sendJsonRpcRequest(url, method, params, username, password) {
export async function sendJsonRpcRequest(url, method, params, widget) {
const headers = {
"content-type": "application/json",
accept: "application/json",
};
if (username && password) {
headers.authorization = `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`;
if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
}
if (widget.key) {
headers.Authorization = `Bearer ${widget.key}`;
}
const client = new JSONRPCClient(async (rpcRequest) => {
@@ -67,6 +71,9 @@ export default async function jsonrpcProxyHandler(req, res) {
const widget = await getServiceWidget(group, service);
const api = widgets?.[widget.type]?.api;
const [, mapping] = Object.entries(widgets?.[widget.type]?.mappings).find(([, value]) => value.endpoint === method);
const params = mapping?.params ?? null;
if (!api) {
return res.status(403).json({ error: "Service does not support API calls" });
}
@@ -74,8 +81,7 @@ export default async function jsonrpcProxyHandler(req, res) {
if (widget) {
const url = formatApiCall(api, { ...widget });
// eslint-disable-next-line no-unused-vars
const [status, contentType, data] = await sendJsonRpcRequest(url, method, null, widget.username, widget.password);
const [status, , data] = await sendJsonRpcRequest(url, method, params, widget);
return res.status(status).end(data);
}
}

View File

@@ -1,5 +1,8 @@
/* eslint-disable no-console */
import widgets from "widgets/widgets";
import createLogger from "utils/logger";
const logger = createLogger("validateWidgetData");
export default function validateWidgetData(widget, endpoint, data) {
let valid = true;
@@ -33,7 +36,7 @@ export default function validateWidgetData(widget, endpoint, data) {
}
if (!valid) {
console.warn(
logger.error(
`Invalid data for widget '${widget.type}' endpoint '${endpoint}':\nExpected:${mapping?.validate}\nParse error: ${
error ?? "none"
}\nData: ${JSON.stringify(data)}`,

View File

@@ -19,6 +19,7 @@ const components = {
iframe: dynamic(() => import("./iframe/component")),
customapi: dynamic(() => import("./customapi/component")),
deluge: dynamic(() => import("./deluge/component")),
develancacheui: dynamic(() => import("./develancacheui/component")),
diskstation: dynamic(() => import("./diskstation/component")),
downloadstation: dynamic(() => import("./downloadstation/component")),
docker: dynamic(() => import("./docker/component")),
@@ -54,6 +55,7 @@ const components = {
komga: dynamic(() => import("./komga/component")),
kopia: dynamic(() => import("./kopia/component")),
lidarr: dynamic(() => import("./lidarr/component")),
linkwarden: dynamic(() => import("./linkwarden/component")),
mastodon: dynamic(() => import("./mastodon/component")),
mealie: dynamic(() => import("./mealie/component")),
medusa: dynamic(() => import("./medusa/component")),
@@ -110,6 +112,7 @@ const components = {
tailscale: dynamic(() => import("./tailscale/component")),
tandoor: dynamic(() => import("./tandoor/component")),
tautulli: dynamic(() => import("./tautulli/component")),
technitium: dynamic(() => import("./technitium/component")),
tdarr: dynamic(() => import("./tdarr/component")),
traefik: dynamic(() => import("./traefik/component")),
transmission: dynamic(() => import("./transmission/component")),
@@ -124,6 +127,7 @@ const components = {
wgeasy: dynamic(() => import("./wgeasy/component")),
whatsupdocker: dynamic(() => import("./whatsupdocker/component")),
xteve: dynamic(() => import("./xteve/component")),
zabbix: dynamic(() => import("./zabbix/component")),
};
export default components;

View File

@@ -9,6 +9,11 @@ function getValue(field, data) {
let lastField = field;
let key = "";
// Support APIs that return arrays or scalars directly.
if (typeof field === "undefined") {
return value;
}
while (typeof lastField === "object") {
key = Object.keys(lastField)[0] ?? null;
@@ -27,6 +32,16 @@ function getValue(field, data) {
return value[lastField] ?? null;
}
function getSize(data) {
if (Array.isArray(data) || typeof data === "string") {
return data.length;
} else if (typeof data === "object" && data !== null) {
return Object.keys(data).length;
}
return NaN;
}
function formatValue(t, mapping, rawValue) {
let value = rawValue;
@@ -85,6 +100,9 @@ function formatValue(t, mapping, rawValue) {
numeric: mapping?.numeric,
});
break;
case "size":
value = t("common.number", { value: getSize(value) });
break;
case "text":
default:
// nothing

View File

@@ -0,0 +1,39 @@
import { useTranslation } from "next-i18next";
import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
const { data: downloadStatsData, error: downloadStatsError } = useWidgetAPI(widget, "stats");
if (downloadStatsError) {
return <Container service={service} error={downloadStatsError} />;
}
if (!downloadStatsData) {
return (
<Container service={service}>
<Block label="develancacheui.cachehitbytes" />
<Block label="develancacheui.cachemissbytes" />
</Container>
);
}
return (
<Container service={service}>
<Block
label="develancacheui.cachehitbytes"
value={t("common.bytes", { value: downloadStatsData.totalCacheHitBytes })}
/>
<Block
label="develancacheui.cachemissbytes"
value={t("common.bytes", { value: downloadStatsData.totalCacheMissBytes })}
/>
</Container>
);
}

View File

@@ -0,0 +1,14 @@
import genericProxyHandler from "utils/proxy/handlers/generic";
const widget = {
api: "{url}/{endpoint}",
proxyHandler: genericProxyHandler,
mappings: {
stats: {
endpoint: "DownloadStats/GetTotalDownloadStats",
},
},
};
export default widget;

View File

@@ -1,8 +1,8 @@
import genericProxyHandler from "utils/proxy/handlers/generic";
import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
const widget = {
api: "{url}/ping",
proxyHandler: genericProxyHandler,
proxyHandler: credentialedProxyHandler,
};
export default widget;

View File

@@ -1,9 +1,10 @@
import { GameDig } from "gamedig";
import createLogger from "utils/logger";
import getServiceWidget from "utils/config/service-helpers";
const proxyName = "gamedigProxyHandler";
const logger = createLogger(proxyName);
const gamedig = require("gamedig");
export default async function gamedigProxyHandler(req, res) {
const { group, service } = req.query;
@@ -11,11 +12,12 @@ export default async function gamedigProxyHandler(req, res) {
const url = new URL(serviceWidget.url);
try {
const serverData = await gamedig.query({
const serverData = await GameDig.query({
type: serviceWidget.serverType,
host: url.hostname,
port: url.port,
givenPortOnly: true,
checkOldIDs: true,
});
res.status(200).send({

View File

@@ -58,7 +58,7 @@ export default function Component({ service }) {
<div className="text-xs opacity-50">
{t(diskUnits, {
value: fsData.used,
maximumFractionDigits: 0,
maximumFractionDigits: 1,
})}{" "}
{t("resources.used")}
</div>
@@ -79,7 +79,7 @@ export default function Component({ service }) {
<div className="text-xs opacity-50">
{t(diskUnits, {
value: fsData.used,
maximumFractionDigits: 0,
maximumFractionDigits: 1,
})}{" "}
{t("resources.used")}
</div>

View File

@@ -10,7 +10,8 @@ export default function Component({ service }) {
const { data: versionData, error: versionError } = useWidgetAPI(widget, "version");
// see https://github.com/gethomepage/homepage/issues/2282
const endpoint = versionData?.major >= 1 && versionData?.minor > 84 ? "statistics" : "stats";
const endpoint =
versionData?.major > 1 || (versionData?.major === 1 && versionData?.minor > 84) ? "statistics" : "stats";
const { data: immichData, error: immichError } = useWidgetAPI(widget, endpoint);
if (immichError || versionError || immichData?.statusCode === 401) {

View File

@@ -0,0 +1,55 @@
import React, { useState, useEffect } from "react";
import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
export default function Component({ service }) {
const { widget } = service;
const [stats, setStats] = useState({
totalLinks: null,
collections: { total: null },
tags: { total: null },
});
const { data: collectionsStatsData, error: collectionsStatsError } = useWidgetAPI(widget, "collections");
const { data: tagsStatsData, error: tagsStatsError } = useWidgetAPI(widget, "tags");
useEffect(() => {
if (collectionsStatsData?.response && tagsStatsData?.response) {
setStats({
// eslint-disable-next-line no-underscore-dangle
totalLinks: collectionsStatsData.response.reduce((sum, collection) => sum + (collection._count?.links || 0), 0),
collections: {
total: collectionsStatsData.response.length,
},
tags: {
total: tagsStatsData.response.length,
},
});
}
}, [collectionsStatsData, tagsStatsData]);
if (collectionsStatsError || tagsStatsError) {
return <Container service={service} error={collectionsStatsError || tagsStatsError} />;
}
if (!tagsStatsData || !collectionsStatsData) {
return (
<Container service={service}>
<Block label="linkwarden.links" />
<Block label="linkwarden.collections" />
<Block label="linkwarden.tags" />
</Container>
);
}
return (
<Container service={service}>
<Block label="linkwarden.links" value={stats.totalLinks} />
<Block label="linkwarden.collections" value={stats.collections.total} />
<Block label="linkwarden.tags" value={stats.tags.total} />
</Container>
);
}

View File

@@ -0,0 +1,17 @@
import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
const widget = {
api: "{url}/api/v1/{endpoint}",
proxyHandler: credentialedProxyHandler,
mappings: {
collections: {
endpoint: "collections",
},
tags: {
endpoint: "tags",
},
},
};
export default widget;

View File

@@ -1,17 +1,20 @@
import { useTranslation } from "next-i18next";
import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
const version = widget.version ?? 1;
const { data, error } = useWidgetAPI(widget, version === 1 ? "statisticsv1" : "statisticsv2");
const { data: mealieData, error: mealieError } = useWidgetAPI(widget);
if (mealieError || mealieData?.statusCode === 401) {
return <Container service={service} error={mealieError ?? mealieData} />;
if (error) {
return <Container service={service} error={error} />;
}
if (!mealieData) {
if (!data) {
return (
<Container service={service}>
<Block label="mealie.recipes" />
@@ -21,13 +24,12 @@ export default function Component({ service }) {
</Container>
);
}
return (
<Container service={service}>
<Block label="mealie.recipes" value={mealieData.totalRecipes} />
<Block label="mealie.users" value={mealieData.totalUsers} />
<Block label="mealie.categories" value={mealieData.totalCategories} />
<Block label="mealie.tags" value={mealieData.totalTags} />
<Block label="mealie.recipes" value={t("common.number", { value: data.totalRecipes })} />
<Block label="mealie.users" value={t("common.number", { value: data.totalUsers })} />
<Block label="mealie.categories" value={t("common.number", { value: data.totalCategories })} />
<Block label="mealie.tags" value={t("common.number", { value: data.totalTags })} />
</Container>
);
}

View File

@@ -1,8 +1,17 @@
import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
const widget = {
api: "{url}/api/groups/statistics",
api: "{url}/api/{endpoint}",
proxyHandler: credentialedProxyHandler,
mappings: {
statisticsv1: {
endpoint: "groups/statistics",
},
statisticsv2: {
endpoint: "households/statistics",
},
},
};
export default widget;

View File

@@ -4,31 +4,46 @@ import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
const ROMM_DEFAULT_FIELDS = ["platforms", "totalRoms", "saves", "states"];
const MAX_ALLOWED_FIELDS = 4;
export default function Component({ service }) {
const { widget } = service;
const { t } = useTranslation();
const { data: response, error: responseError } = useWidgetAPI(widget, "statistics");
if (responseError) {
return (
<Container service={service}>
<Block label="Error" value={responseError.message} />
</Container>
);
}
if (responseError) {
return <Container service={service} error={responseError} />;
}
if (response) {
const platforms = response.filter((x) => x.rom_count !== 0).length;
const totalRoms = response.reduce((total, stat) => total + stat.rom_count, 0);
if (!widget.fields?.length > 0) {
widget.fields = ROMM_DEFAULT_FIELDS;
} else if (widget.fields.length > MAX_ALLOWED_FIELDS) {
widget.fields = widget.fields.slice(0, MAX_ALLOWED_FIELDS);
}
if (!response) {
return (
<Container service={service}>
<Block label="romm.platforms" value={t("common.number", { value: platforms })} />
<Block label="romm.totalRoms" value={t("common.number", { value: totalRoms })} />
<Block label="romm.platforms" />
<Block label="romm.totalRoms" />
<Block label="romm.saves" />
<Block label="romm.states" />
<Block label="romm.screenshots" />
<Block label="romm.totalfilesize" />
</Container>
);
}
if (response) {
return (
<Container service={service}>
<Block label="romm.platforms" value={t("common.number", { value: response.PLATFORMS })} />
<Block label="romm.totalRoms" value={t("common.number", { value: response.ROMS })} />
<Block label="romm.saves" value={t("common.number", { value: response.SAVES })} />
<Block label="romm.states" value={t("common.number", { value: response.STATES })} />
<Block label="romm.screenshots" value={t("common.number", { value: response.SCREENSHOTS })} />
<Block label="romm.totalfilesize" value={t("common.bytes", { value: response.FILESIZE })} />
</Container>
);
}

View File

@@ -6,7 +6,7 @@ const widget = {
mappings: {
statistics: {
endpoint: "platforms",
endpoint: "stats",
},
},
};

View File

@@ -21,9 +21,13 @@ export default async function tdarrProxyHandler(req, res) {
logger.debug("Invalid or missing widget for service '%s' in group '%s'", service, group);
return res.status(400).json({ error: "Invalid proxy service type" });
}
const headers = {
"content-type": "application/json",
};
if (widget.key) {
headers["x-api-key"] = `${widget.key}`;
}
const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint: undefined, ...widget }));
const [status, contentType, data] = await httpProxy(url, {
method: "POST",
body: JSON.stringify({
@@ -33,9 +37,7 @@ export default async function tdarrProxyHandler(req, res) {
docID: "statistics",
},
}),
headers: {
"content-type": "application/json",
},
headers,
});
if (status !== 200) {

View File

@@ -0,0 +1,121 @@
import { useTranslation } from "next-i18next";
import Container from "components/services/widget/container";
import Block from "components/services/widget/block";
import useWidgetAPI from "utils/proxy/use-widget-api";
const MAX_ALLOWED_FIELDS = 4;
export const technitiumDefaultFields = ["totalQueries", "totalAuthoritative", "totalCached", "totalServerFailure"];
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
const params = {
type: widget.range ?? "LastHour",
};
const { data: statsData, error: statsError } = useWidgetAPI(widget, "stats", params);
// Default fields
if (!widget.fields?.length > 0) {
widget.fields = technitiumDefaultFields;
}
// Limits max number of displayed fields
if (widget.fields?.length > MAX_ALLOWED_FIELDS) {
widget.fields = widget.fields.slice(0, MAX_ALLOWED_FIELDS);
}
if (statsError) {
return <Container service={service} error={statsError} />;
}
if (!statsData) {
return (
<Container service={service}>
<Block label="technitium.totalQueries" />
<Block label="technitium.totalNoError" />
<Block label="technitium.totalServerFailure" />
<Block label="technitium.totalNxDomain" />
<Block label="technitium.totalRefused" />
<Block label="technitium.totalAuthoritative" />
<Block label="technitium.totalRecursive" />
<Block label="technitium.totalCached" />
<Block label="technitium.totalBlocked" />
<Block label="technitium.totalDropped" />
<Block label="technitium.totalClients" />
</Container>
);
}
function toPercent(value, total) {
return t("common.percent", {
value: !Number.isNaN(value / total) ? value / total : 0,
maximumFractionDigits: 2,
});
}
return (
<Container service={service}>
<Block label="technitium.totalQueries" value={`${t("common.number", { value: statsData.totalQueries })}`} />
<Block
label="technitium.totalNoError"
value={`${t("common.number", { value: statsData.totalNoError })} (${toPercent(
statsData.totalNoError / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalServerFailure"
value={`${t("common.number", { value: statsData.totalServerFailure })} (${toPercent(
statsData.totalServerFailure / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalNxDomain"
value={`${t("common.number", { value: statsData.totalNxDomain })} (${toPercent(
statsData.totalNxDomain / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalRefused"
value={`${t("common.number", { value: statsData.totalRefused })} (${toPercent(
statsData.totalRefused / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalAuthoritative"
value={`${t("common.number", { value: statsData.totalAuthoritative })} (${toPercent(
statsData.totalAuthoritative / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalRecursive"
value={`${t("common.number", { value: statsData.totalRecursive })} (${toPercent(
statsData.totalRecursive / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalCached"
value={`${t("common.number", { value: statsData.totalCached })} (${toPercent(
statsData.totalCached / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalBlocked"
value={`${t("common.number", { value: statsData.totalBlocked })} (${toPercent(
statsData.totalBlocked / statsData.totalQueries,
)})`}
/>
<Block
label="technitium.totalDropped"
value={`${t("common.number", { value: statsData.totalDropped })} (${toPercent(
statsData.totalDropped / statsData.totalQueries,
)})`}
/>
<Block label="technitium.totalClients" value={`${t("common.number", { value: statsData.totalClients })}`} />
</Container>
);
}

View File

@@ -0,0 +1,17 @@
import genericProxyHandler from "utils/proxy/handlers/generic";
import { asJson } from "utils/proxy/api-helpers";
const widget = {
api: "{url}/api/{endpoint}?token={key}&utc=true",
proxyHandler: genericProxyHandler,
mappings: {
stats: {
endpoint: "dashboard/stats/get",
validate: ["response", "status"],
params: ["type"],
map: (data) => asJson(data).response.stats,
},
},
};
export default widget;

View File

@@ -25,7 +25,7 @@ const widget = {
healthy: entry.healthy,
allocated: entry.allocated,
free: entry.free,
data: entry.topology.data,
data: entry.topology?.data ?? [],
})),
},
},

View File

@@ -32,16 +32,10 @@ export default function Component({ service }) {
return (
<Container service={service}>
<Block
label="tubearchivist.downloads"
value={t("common.number", { value: downloadsData?.paginate?.total_hits })}
/>
<Block label="tubearchivist.videos" value={t("common.number", { value: videosData?.paginate?.total_hits })} />
<Block label="tubearchivist.channels" value={t("common.number", { value: channelsData?.paginate?.total_hits })} />
<Block
label="tubearchivist.playlists"
value={t("common.number", { value: playlistsData?.paginate?.total_hits })}
/>
<Block label="tubearchivist.downloads" value={t("common.number", { value: downloadsData.pending ?? 0 })} />
<Block label="tubearchivist.videos" value={t("common.number", { value: videosData.doc_count ?? 0 })} />
<Block label="tubearchivist.channels" value={t("common.number", { value: channelsData.doc_count ?? 0 })} />
<Block label="tubearchivist.playlists" value={t("common.number", { value: playlistsData.doc_count ?? 0 })} />
</Container>
);
}

View File

@@ -6,20 +6,19 @@ const widget = {
mappings: {
downloads: {
endpoint: "download",
validate: ["paginate"],
endpoint: "stats/download",
},
videos: {
endpoint: "video",
validate: ["paginate"],
endpoint: "stats/video",
validate: ["doc_count"],
},
channels: {
endpoint: "channel",
validate: ["paginate"],
endpoint: "stats/channel",
validate: ["doc_count"],
},
playlists: {
endpoint: "playlist",
validate: ["paginate"],
endpoint: "stats/playlist",
validate: ["doc_count"],
},
},
};

View File

@@ -5,14 +5,14 @@ import useWidgetAPI from "utils/proxy/use-widget-api";
export default function Component({ service }) {
const { widget } = service;
const { data: infoData, error: infoError } = useWidgetAPI(widget);
const { data: infoData, error: infoError } = useWidgetAPI(widget, "client");
if (!widget.fields) {
widget.fields = ["connected", "enabled", "total"];
}
if (infoError) {
return <Container service={service} error={infoError} />;
if (infoError || infoData?.statusCode > 400) {
return <Container service={service} error={infoError ?? { message: infoData.statusMessage, data: infoData }} />;
}
if (!infoData) {

View File

@@ -1,77 +0,0 @@
import cache from "memory-cache";
import getServiceWidget from "utils/config/service-helpers";
import { formatApiCall } from "utils/proxy/api-helpers";
import { httpProxy } from "utils/proxy/http";
import widgets from "widgets/widgets";
import createLogger from "utils/logger";
const proxyName = "wgeasyProxyHandler";
const logger = createLogger(proxyName);
const sessionSIDCacheKey = `${proxyName}__sessionSID`;
async function login(widget, service) {
const url = formatApiCall(widgets[widget.type].api, { ...widget, endpoint: "session" });
const [, , , responseHeaders] = await httpProxy(url, {
method: "POST",
body: JSON.stringify({ password: widget.password }),
headers: {
"Content-Type": "application/json",
},
});
try {
let connectSidCookie = responseHeaders["set-cookie"];
if (!connectSidCookie) {
const sid = cache.get(`${sessionSIDCacheKey}.${service}`);
if (sid) {
return sid;
}
}
connectSidCookie = connectSidCookie
.find((cookie) => cookie.startsWith("connect.sid="))
.split(";")[0]
.replace("connect.sid=", "");
cache.put(`${sessionSIDCacheKey}.${service}`, connectSidCookie);
return connectSidCookie;
} catch (e) {
logger.error(`Error logging into wg-easy, error: ${e}`);
cache.del(`${sessionSIDCacheKey}.${service}`);
return null;
}
}
export default async function wgeasyProxyHandler(req, res) {
const { group, service } = req.query;
if (group && service) {
const widget = await getServiceWidget(group, service);
if (!widgets?.[widget.type]?.api) {
return res.status(403).json({ error: "Service does not support API calls" });
}
if (widget) {
let sid = cache.get(`${sessionSIDCacheKey}.${service}`);
if (!sid) {
sid = await login(widget, service);
if (!sid) {
return res.status(500).json({ error: "Failed to authenticate with Wg-Easy" });
}
}
const [, , data] = await httpProxy(
formatApiCall(widgets[widget.type].api, { ...widget, endpoint: "wireguard/client" }),
{
headers: {
"Content-Type": "application/json",
Cookie: `connect.sid=${sid}`,
},
},
);
return res.json(JSON.parse(data));
}
}
return res.status(400).json({ error: "Invalid proxy service type" });
}

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