Compare commits

...

86 Commits

Author SHA1 Message Date
8902db0ae4 Remove console.log 2025-03-30 07:02:54 +08:00
cdbf7f1843 Init 2025-03-30 06:58:07 +08:00
c62b91682e Switch back to npm (#766) 2025-03-29 16:17:49 +08:00
970a826d5a Translations update from Kuma Weblate (#641) 2025-03-29 15:58:35 +08:00
86c7dfdb5b Translated using Weblate (Hungarian)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/hu/
2025-03-29 07:17:30 +00:00
6c357fb603 Translated using Weblate (Turkish)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/tr/
2025-03-29 07:17:30 +00:00
90255f05cb Translated using Weblate (Danish)
Currently translated at 95.3% (124 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/da/
2025-03-29 07:17:30 +00:00
c40c463788 Translated using Weblate (Indonesian)
Currently translated at 92.3% (120 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/id/
2025-03-29 07:17:30 +00:00
9fedd8790d Translated using Weblate (Hungarian)
Currently translated at 99.2% (129 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/hu/
2025-03-29 07:17:30 +00:00
65c719d95d Translated using Weblate (Romanian)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ro/
2025-03-29 07:17:30 +00:00
fb349e06b1 Translated using Weblate (Portuguese (Brazil))
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/pt_BR/
2025-03-29 07:17:30 +00:00
322f4ccee8 Translated using Weblate (Czech)
Currently translated at 97.6% (127 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/cs/
2025-03-29 07:17:30 +00:00
38d424d8bc Translated using Weblate (Chinese (Simplified))
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/zh_Hans/
2025-03-29 07:17:30 +00:00
4438adc04a Translated using Weblate (Chinese (Traditional))
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/zh_Hant/
2025-03-29 07:17:30 +00:00
053ea3643c Translated using Weblate (Irish)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ga/
2025-03-29 07:17:30 +00:00
b7b1435d62 Translated using Weblate (Spanish)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/es/
2025-03-29 07:17:30 +00:00
9830bc345a Translated using Weblate (German)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/de/
2025-03-29 07:17:30 +00:00
9d8fbf1af2 Translated using Weblate (Swedish)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/sv/
2025-03-29 07:17:30 +00:00
fb366cbf24 Translated using Weblate (German)
Currently translated at 99.2% (129 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/de/
2025-03-29 07:17:30 +00:00
fd3e4910e2 Translated using Weblate (Polish)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/pl/
2025-03-29 07:17:30 +00:00
6c0d8da11e Translated using Weblate (Czech)
Currently translated at 76.9% (100 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/cs/
2025-03-29 07:17:30 +00:00
a2f96913c2 Translated using Weblate (Japanese)
Currently translated at 97.6% (127 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ja/
2025-03-29 07:17:29 +00:00
40fc0ebb06 Translated using Weblate (Ukrainian)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/uk/
2025-03-29 07:17:29 +00:00
be562ce66e Translated using Weblate (French)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/fr/
2025-03-29 07:17:29 +00:00
3fff0dbd51 Translated using Weblate (Bulgarian)
Currently translated at 100.0% (130 of 130 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/bg/
2025-03-29 07:17:29 +00:00
71e773ae9f Fix: configs.content syntax not supported despite being valid in Docker Compose 2.23.1+ (#740)
Co-authored-by: Louis Lam <louislam@users.noreply.github.com>
2025-03-29 15:17:25 +08:00
74e9efd471 Update dependencies 2025-03-29 15:14:25 +08:00
d451e06e84 Update dependencies 2025-01-04 18:14:17 +08:00
a65a9f5549 fix bug 176: preserve YAML comments when reordering items by matching… (#685) 2024-12-31 15:43:17 +08:00
9b73e44cd9 Remove useless scrollbar (#642) 2024-12-31 15:41:15 +08:00
81818a19d1 Update dependencies 2024-12-26 16:22:24 +08:00
1372bd2ce1 Remove the tsx workaround as it had been fixed in upstream 2024-12-26 16:22:08 +08:00
01906205f0 1.5.x (#636) 2024-10-14 14:20:34 +08:00
28337c5430 Add ARMv7 for CI 2024-10-14 14:14:52 +08:00
5baf48db63 Also update ci's node version to 22 2024-10-14 00:53:24 +08:00
b2c8fdab75 Add Translation keys (#506) 2024-10-14 00:51:59 +08:00
e12525fa42 Pin node-pty-prebuilt-multiarch 2024-10-13 21:11:38 +08:00
3e3f67c6b7 Update css for terminal 2024-10-13 21:11:20 +08:00
020faa49d2 Merge branch 'master' into 1.5.X 2024-10-13 20:43:58 +08:00
df95d7ce9d Translations update from Kuma Weblate (#396) 2024-10-13 20:41:38 +08:00
7a2524c542 Translated using Weblate (Hungarian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/hu/
2024-10-13 12:40:45 +00:00
6ceaa70cdd Translated using Weblate (German)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/de/
2024-10-13 12:40:45 +00:00
caea8996da Translated using Weblate (Hungarian)
Currently translated at 99.1% (113 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/hu/
2024-10-13 12:40:45 +00:00
39e3d5a07c Translated using Weblate (Ukrainian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/uk/
2024-10-13 12:40:45 +00:00
723afb5bc2 Translated using Weblate (Italian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/it/
2024-10-13 12:40:45 +00:00
3b3b3a7940 Translated using Weblate (Belarusian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/be/
2024-10-13 12:40:45 +00:00
f9309a0650 Added translation using Weblate (Belarusian) 2024-10-13 12:40:45 +00:00
54c2be7abe Translated using Weblate (Dutch)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/nl/
2024-10-13 12:40:45 +00:00
48db1c73a8 Translated using Weblate (Polish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/pl/
2024-10-13 12:40:45 +00:00
88f696d9b1 Translated using Weblate (Slovenian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/sl/
2024-10-13 12:40:45 +00:00
f80cfca64b Translated using Weblate (Catalan)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ca/
2024-10-13 12:40:45 +00:00
1ddd70791a Translated using Weblate (Turkish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/tr/
2024-10-13 12:40:45 +00:00
5f01347d2f Translated using Weblate (Arabic)
Currently translated at 96.4% (110 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ar/
2024-10-13 12:40:45 +00:00
04c9a8669d Translated using Weblate (Hungarian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/hu/
2024-10-13 12:40:45 +00:00
91b7c18c52 Translated using Weblate (Spanish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/es/
2024-10-13 12:40:45 +00:00
9cef4ad9ee Translated using Weblate (Irish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ga/
2024-10-13 12:40:45 +00:00
e7dd099f17 Added translation using Weblate (Irish) 2024-10-13 12:40:45 +00:00
d27fd2919b Translated using Weblate (Danish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/da/
2024-10-13 12:40:45 +00:00
e2f5796470 Translated using Weblate (Portuguese)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/pt/
2024-10-13 12:40:45 +00:00
88f26f53c5 Translated using Weblate (Portuguese (Brazil))
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/pt_BR/
2024-10-13 12:40:45 +00:00
ccd9d96227 Translated using Weblate (Thai)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/th/
2024-10-13 12:40:45 +00:00
a8dcfe4ccd Translated using Weblate (Norwegian Bokmål)
Currently translated at 27.1% (31 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/nb_NO/
2024-10-13 12:40:45 +00:00
941ec0056a Translated using Weblate (Indonesian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/id/
2024-10-13 12:40:45 +00:00
1bb6f2532c Translated using Weblate (Thai)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/th/
2024-10-13 12:40:45 +00:00
6fb24adc66 Translated using Weblate (Swedish)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/sv/
2024-10-13 12:40:45 +00:00
c4fe952121 Translated using Weblate (Arabic)
Currently translated at 92.9% (106 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ar/
2024-10-13 12:40:45 +00:00
59bfe79c40 Added translation using Weblate (Norwegian Bokmål) 2024-10-13 12:40:45 +00:00
9e89f49e38 Fixed: An agent do not disconnect correctly after removed (#617) 2024-10-13 20:40:40 +08:00
19beb02b1e Update to Node.js 22 from 18, as the upstream cpu 100% issues has been fixed. 2024-10-13 20:36:04 +08:00
9dd68372c2 Update dependencies 2024-10-13 20:20:47 +08:00
109222f024 fix default compose version obsolete (#507) 2024-05-01 11:20:13 +08:00
5ad42a6dab docker compose version is obsolete (#473) 2024-04-20 12:47:20 +08:00
74c8baef93 Update json-yaml-validate to latest version (#446) 2024-03-13 16:28:02 +08:00
c7ea2f9ee9 Added Irish language (#425) 2024-02-12 13:08:14 +08:00
4a9173f5dc Update to 1.4.2 2024-01-22 00:54:58 +08:00
3d641090c0 Translations update from Kuma Weblate (#381) 2024-01-22 00:52:35 +08:00
32527100a0 Translated using Weblate (Japanese)
Currently translated at 95.6% (109 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ja/
2024-01-21 16:51:02 +00:00
30c69583a7 Translated using Weblate (Chinese (Simplified))
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/zh_Hans/
2024-01-21 16:51:02 +00:00
69cbe16745 Translated using Weblate (Korean)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ko/
2024-01-21 16:51:01 +00:00
f5df9a777c Translated using Weblate (Urdu)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ur/
2024-01-19 18:56:15 +00:00
c33a469972 Translated using Weblate (Ukrainian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/uk/
2024-01-18 18:16:31 +00:00
f667467091 Translated using Weblate (Russian)
Currently translated at 96.4% (110 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/ru/
2024-01-18 18:16:31 +00:00
2ff27b4073 Translated using Weblate (French)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/fr/
2024-01-18 18:16:28 +00:00
8ad6702932 Translated using Weblate (German)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/de/
2024-01-18 18:16:28 +00:00
6a7d7b5e43 Translated using Weblate (Bulgarian)
Currently translated at 100.0% (114 of 114 strings)

Translation: Dockge/dockge
Translate-URL: https://weblate.kuma.pet/projects/dockge/dockge/bg/
2024-01-18 18:16:28 +00:00
66747b7a73 Workaround fix for tsx issue (#380) 2024-01-19 02:13:43 +08:00
62 changed files with 11472 additions and 5938 deletions

View File

@ -14,50 +14,31 @@ jobs:
ci: ci:
strategy: strategy:
matrix: matrix:
os: [ubuntu-latest, windows-latest, macos-latest, ARM64] os: [ubuntu-latest, windows-latest, macos-latest, ARM, ARM64]
node: [18.17.1] # Can be changed node: [22] # Can be changed
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
steps: steps:
- name: Checkout Code - name: Checkout Code
run: | # Mainly for Windows
git config --global core.autocrlf false
git config --global core.eol lf
uses: actions/checkout@v4 uses: actions/checkout@v4
- run: git config --global core.autocrlf false # Mainly for Windows
- uses: actions/checkout@v3
- name: Setup Node.js - name: Setup Node.js
uses: actions/setup-node@v3 uses: actions/setup-node@v3
with: with:
node-version: ${{matrix.node}} node-version: ${{matrix.node}}
- uses: pnpm/action-setup@v2
name: Install pnpm
with:
version: 8
run_install: false
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies - name: Install dependencies
run: pnpm install run: npm install
- name: Lint - name: Lint
run: pnpm run lint run: npm run lint
- name: Check Typescript - name: Check Typescript
run: pnpm run check-ts run: npm run check-ts
- name: Build - name: Build
run: pnpm run build:frontend run: npm run build:frontend
# more things can be add later like tests etc.. # more things can be add later like tests etc..

View File

@ -16,27 +16,5 @@ jobs:
steps: steps:
- uses: actions/checkout@v3 - uses: actions/checkout@v3
- uses: pnpm/action-setup@v2
name: Install pnpm
with:
version: 8
run_install: false
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v3
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies
run: pnpm install
- name: Close Incorrect Issue - name: Close Incorrect Issue
run: node extra/close-incorrect-issue.js ${{ secrets.GITHUB_TOKEN }} ${{ github.event.issue.number }} ${{ github.event.issue.user.login }} run: node extra/close-incorrect-issue.js ${{ secrets.GITHUB_TOKEN }} ${{ github.event.issue.number }} ${{ github.event.issue.user.login }}

View File

@ -17,11 +17,11 @@ jobs:
json-yaml-validate: json-yaml-validate:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v3 - uses: actions/checkout@v4
- name: json-yaml-validate - name: json-yaml-validate
id: json-yaml-validate id: json-yaml-validate
uses: GrantBirki/json-yaml-validate@v1.3.0 uses: GrantBirki/json-yaml-validate@v2.6.1
with: with:
comment: "false" # enable comment mode comment: "false" # enable comment mode
exclude_file: ".github/config/exclude.txt" # gitignore style file for exclusions exclude_file: ".github/config/exclude.txt" # gitignore style file for exclusions

View File

@ -58,8 +58,7 @@ I personally do not like something that requires so many configurations before y
## Tools ## Tools
- [`Node.js`](https://nodejs.org/) >= 20 - [`Node.js`](https://nodejs.org/) >= 22.14.0
- [`pnpm`](https://pnpm.io/)
- [`git`](https://git-scm.com/) - [`git`](https://git-scm.com/)
- IDE that supports [`ESLint`](https://eslint.org/) and EditorConfig (I am using [`IntelliJ IDEA`](https://www.jetbrains.com/idea/)) - IDE that supports [`ESLint`](https://eslint.org/) and EditorConfig (I am using [`IntelliJ IDEA`](https://www.jetbrains.com/idea/))
- A SQLite GUI tool (f.ex. [`SQLite Expert Personal`](https://www.sqliteexpert.com/download.html) or [`DBeaver Community`](https://dbeaver.io/download/)) - A SQLite GUI tool (f.ex. [`SQLite Expert Personal`](https://www.sqliteexpert.com/download.html) or [`DBeaver Community`](https://dbeaver.io/download/))
@ -67,14 +66,14 @@ I personally do not like something that requires so many configurations before y
## Install Dependencies for Development ## Install Dependencies for Development
```bash ```bash
pnpm install npm install
``` ```
## Dev Server ## Dev Server
``` ```
pnpm run dev:frontend npm run dev:frontend
pnpm run dev:backend npm run dev:backend
``` ```
## Backend Dev Server ## Backend Dev Server
@ -94,7 +93,7 @@ You can use Vue.js devtools Chrome extension for debugging.
### Build the frontend ### Build the frontend
```bash ```bash
pnpm run build npm run build
``` ```
## Database Migration ## Database Migration
@ -117,7 +116,7 @@ Both frontend and backend share the same package.json. However, the frontend dep
Should only be done by the maintainer. Should only be done by the maintainer.
```bash ```bash
pnpm update npm update
```` ````
It should update the patch release version only. It should update the patch release version only.

View File

@ -98,6 +98,8 @@ export class AgentManager {
if (bean) { if (bean) {
await R.trash(bean); await R.trash(bean);
let endpoint = bean.endpoint; let endpoint = bean.endpoint;
this.disconnect(endpoint);
this.sendAgentList();
delete this.agentSocketList[endpoint]; delete this.agentSocketList[endpoint];
} else { } else {
throw new Error("Agent not found"); throw new Error("Agent not found");

View File

@ -17,6 +17,7 @@ export class DockerSocketHandler extends AgentSocketHandler {
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Deployed", msg: "Deployed",
msgi18n: true,
}, callback); }, callback);
stack.joinCombinedTerminal(socket); stack.joinCombinedTerminal(socket);
} catch (e) { } catch (e) {
@ -30,7 +31,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await this.saveStack(server, name, composeYAML, composeENV, isAdd); await this.saveStack(server, name, composeYAML, composeENV, isAdd);
callbackResult({ callbackResult({
ok: true, ok: true,
"msg": "Saved" msg: "Saved",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
} catch (e) { } catch (e) {
@ -56,7 +58,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
server.sendStackList(); server.sendStackList();
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Deleted" msg: "Deleted",
msgi18n: true,
}, callback); }, callback);
} catch (e) { } catch (e) {
@ -94,7 +97,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
server.sendStackList(); server.sendStackList();
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Updated" msg: "Updated",
msgi18n: true,
}, callback); }, callback);
} catch (e) { } catch (e) {
callbackError(e, callback); callbackError(e, callback);
@ -114,7 +118,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await stack.start(socket); await stack.start(socket);
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Started" msg: "Started",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
@ -138,7 +143,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await stack.stop(socket); await stack.stop(socket);
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Stopped" msg: "Stopped",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
} catch (e) { } catch (e) {
@ -159,7 +165,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await stack.restart(socket); await stack.restart(socket);
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Restarted" msg: "Restarted",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
} catch (e) { } catch (e) {
@ -180,7 +187,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await stack.update(socket); await stack.update(socket);
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Updated" msg: "Updated",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
} catch (e) { } catch (e) {
@ -201,7 +209,8 @@ export class DockerSocketHandler extends AgentSocketHandler {
await stack.down(socket); await stack.down(socket);
callbackResult({ callbackResult({
ok: true, ok: true,
msg: "Downed" msg: "Downed",
msgi18n: true,
}, callback); }, callback);
server.sendStackList(); server.sendStackList();
} catch (e) { } catch (e) {

View File

@ -38,6 +38,11 @@ export class TerminalSocketHandler extends AgentSocketHandler {
try { try {
checkLogin(socket); checkLogin(socket);
// Throw an error if console is not enabled
if (!server.config.enableConsole) {
throw new ValidationError("Console is not enabled.");
}
// TODO: Reset the name here, force one main terminal for now // TODO: Reset the name here, force one main terminal for now
terminalName = "console"; terminalName = "console";
@ -66,6 +71,18 @@ export class TerminalSocketHandler extends AgentSocketHandler {
} }
}); });
// Check if MainTerminal is enabled
agentSocket.on("checkMainTerminal", async (callback) => {
try {
checkLogin(socket);
callbackResult({
ok: server.config.enableConsole,
}, callback);
} catch (e) {
callbackError(e, callback);
}
});
// Interactive Terminal for containers // Interactive Terminal for containers
agentSocket.on("interactiveTerminal", async (stackName : unknown, serviceName : unknown, shell : unknown, callback) => { agentSocket.on("interactiveTerminal", async (stackName : unknown, serviceName : unknown, shell : unknown, callback) => {
try { try {

View File

@ -136,6 +136,11 @@ export class DockgeServer {
stacksDir: { stacksDir: {
type: String, type: String,
optional: true, optional: true,
},
enableConsole: {
type: Boolean,
optional: true,
defaultValue: false,
} }
}); });
@ -149,6 +154,7 @@ export class DockgeServer {
this.config.hostname = args.hostname || process.env.DOCKGE_HOSTNAME || undefined; this.config.hostname = args.hostname || process.env.DOCKGE_HOSTNAME || undefined;
this.config.dataDir = args.dataDir || process.env.DOCKGE_DATA_DIR || "./data/"; this.config.dataDir = args.dataDir || process.env.DOCKGE_DATA_DIR || "./data/";
this.config.stacksDir = args.stacksDir || process.env.DOCKGE_STACKS_DIR || defaultStacksDir; this.config.stacksDir = args.stacksDir || process.env.DOCKGE_STACKS_DIR || defaultStacksDir;
this.config.enableConsole = args.enableConsole || process.env.DOCKGE_ENABLE_CONSOLE === "true" || false;
this.stacksDir = this.config.stacksDir; this.stacksDir = this.config.stacksDir;
log.debug("server", this.config); log.debug("server", this.config);

View File

@ -4,7 +4,6 @@ import * as pty from "@homebridge/node-pty-prebuilt-multiarch";
import { LimitQueue } from "./utils/limit-queue"; import { LimitQueue } from "./utils/limit-queue";
import { DockgeSocket } from "./util-server"; import { DockgeSocket } from "./util-server";
import { import {
allowedCommandList, allowedRawKeys,
PROGRESS_TERMINAL_ROWS, PROGRESS_TERMINAL_ROWS,
TERMINAL_COLS, TERMINAL_COLS,
TERMINAL_ROWS TERMINAL_ROWS
@ -16,7 +15,6 @@ import { log } from "./log";
* Terminal for running commands, no user interaction * Terminal for running commands, no user interaction
*/ */
export class Terminal { export class Terminal {
protected static terminalMap : Map<string, Terminal> = new Map(); protected static terminalMap : Map<string, Terminal> = new Map();
protected _ptyProcess? : pty.IPty; protected _ptyProcess? : pty.IPty;
@ -272,6 +270,11 @@ export class MainTerminal extends InteractiveTerminal {
constructor(server : DockgeServer, name : string) { constructor(server : DockgeServer, name : string) {
let shell; let shell;
// Throw an error if console is not enabled
if (!server.config.enableConsole) {
throw new Error("Console is not enabled.");
}
if (os.platform() === "win32") { if (os.platform() === "win32") {
if (commandExistsSync("pwsh.exe")) { if (commandExistsSync("pwsh.exe")) {
shell = "pwsh.exe"; shell = "pwsh.exe";
@ -285,21 +288,6 @@ export class MainTerminal extends InteractiveTerminal {
} }
public write(input : string) { public write(input : string) {
// For like Ctrl + C
if (allowedRawKeys.includes(input)) {
super.write(input);
return;
}
// Check if the command is allowed
const cmdParts = input.split(" ");
const executable = cmdParts[0].trim();
log.debug("console", "Executable: " + executable);
log.debug("console", "Executable length: " + executable.length);
if (!allowedCommandList.includes(executable)) {
throw new Error("Command not allowed.");
}
super.write(input); super.write(input);
} }
} }

View File

@ -30,6 +30,7 @@ export interface Arguments {
hostname? : string; hostname? : string;
dataDir? : string; dataDir? : string;
stacksDir? : string; stacksDir? : string;
enableConsole? : boolean;
} }
// Some config values are required // Some config values are required

View File

@ -107,17 +107,6 @@ export const COMBINED_TERMINAL_ROWS = 20;
export const ERROR_TYPE_VALIDATION = 1; export const ERROR_TYPE_VALIDATION = 1;
export const allowedCommandList : string[] = [
"docker",
"ls",
"cd",
"dir",
];
export const allowedRawKeys = [
"\u0003", // Ctrl + C
];
export const acceptedComposeFileNames = [ export const acceptedComposeFileNames = [
"compose.yaml", "compose.yaml",
"docker-compose.yaml", "docker-compose.yaml",
@ -236,42 +225,63 @@ export function copyYAMLComments(doc : Document, src : Document) {
/** /**
* Copy yaml comments from srcItems to items * Copy yaml comments from srcItems to items
* Typescript is super annoying here, so I have to use any here * Attempts to preserve comments by matching content rather than just array indices
* TODO: Since comments are belong to the array index, the comments will be lost if the order of the items is changed or removed or added.
*/ */
// eslint-disable-next-line @typescript-eslint/no-explicit-any // eslint-disable-next-line @typescript-eslint/no-explicit-any
function copyYAMLCommentsItems(items : any, srcItems : any) { function copyYAMLCommentsItems(items: any, srcItems: any) {
if (!items || !srcItems) { if (!items || !srcItems) {
return; return;
} }
// First pass - try to match items by their content
for (let i = 0; i < items.length; i++) { for (let i = 0; i < items.length; i++) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any // eslint-disable-next-line @typescript-eslint/no-explicit-any
const item : any = items[i]; const item: any = items[i];
// Try to find matching source item by content
// eslint-disable-next-line @typescript-eslint/no-explicit-any // eslint-disable-next-line @typescript-eslint/no-explicit-any
const srcItem : any = srcItems[i]; const srcIndex = srcItems.findIndex((srcItem: any) =>
JSON.stringify(srcItem.value) === JSON.stringify(item.value) &&
JSON.stringify(srcItem.key) === JSON.stringify(item.key)
);
if (!srcItem) { if (srcIndex !== -1) {
continue; // eslint-disable-next-line @typescript-eslint/no-explicit-any
} const srcItem: any = srcItems[srcIndex];
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const nextSrcItem: any = srcItems[srcIndex + 1];
if (item.key && srcItem.key) { if (item.key && srcItem.key) {
item.key.comment = srcItem.key.comment; item.key.comment = srcItem.key.comment;
item.key.commentBefore = srcItem.key.commentBefore; item.key.commentBefore = srcItem.key.commentBefore;
} }
if (srcItem.comment) { if (srcItem.comment) {
item.comment = srcItem.comment; item.comment = srcItem.comment;
} }
if (item.value && srcItem.value) { // Handle comments between array items
if (typeof item.value === "object" && typeof srcItem.value === "object") { if (nextSrcItem && nextSrcItem.commentBefore) {
item.value.comment = srcItem.value.comment; if (items[i + 1]) {
item.value.commentBefore = srcItem.value.commentBefore; items[i + 1].commentBefore = nextSrcItem.commentBefore;
}
}
if (item.value.items && srcItem.value.items) { // Handle trailing comments after array items
copyYAMLCommentsItems(item.value.items, srcItem.value.items); if (srcItem.value && srcItem.value.comment) {
if (item.value) {
item.value.comment = srcItem.value.comment;
}
}
if (item.value && srcItem.value) {
if (typeof item.value === "object" && typeof srcItem.value === "object") {
item.value.comment = srcItem.value.comment;
item.value.commentBefore = srcItem.value.commentBefore;
if (item.value.items && srcItem.value.items) {
copyYAMLCommentsItems(item.value.items, srcItem.value.items);
}
} }
} }
} }

View File

@ -1,4 +1,3 @@
version: "3.8"
services: services:
dockge: dockge:
image: louislam/dockge:1 image: louislam/dockge:1

View File

@ -1,7 +1,4 @@
# Due to the bug of #145, Node.js's version cannot be changed, unless upstream is fixed. FROM node:22-bookworm-slim
FROM node:18.17.1-bookworm-slim
ENV PNPM_HOME="/pnpm"
ENV PATH="$PNPM_HOME:$PATH"
RUN apt update && apt install --yes --no-install-recommends \ RUN apt update && apt install --yes --no-install-recommends \
curl \ curl \
ca-certificates \ ca-certificates \
@ -20,5 +17,4 @@ RUN apt update && apt install --yes --no-install-recommends \
docker-ce-cli \ docker-ce-cli \
docker-compose-plugin \ docker-compose-plugin \
&& rm -rf /var/lib/apt/lists/* \ && rm -rf /var/lib/apt/lists/* \
&& npm install pnpm -g \ && npm install -g tsx
&& pnpm install -g tsx

View File

@ -9,8 +9,8 @@ FROM louislam/dockge:build-healthcheck AS build_healthcheck
FROM louislam/dockge:base AS build FROM louislam/dockge:base AS build
WORKDIR /app WORKDIR /app
COPY --chown=node:node ./package.json ./package.json COPY --chown=node:node ./package.json ./package.json
COPY --chown=node:node ./pnpm-lock.yaml ./pnpm-lock.yaml COPY --chown=node:node ./package-lock.json ./package-lock.json
RUN --mount=type=cache,id=pnpm,target=/pnpm/store pnpm install --prod --frozen-lockfile RUN npm ci
############################################ ############################################
# ⭐ Main Image # ⭐ Main Image
@ -22,6 +22,13 @@ COPY --from=build /app/node_modules /app/node_modules
COPY --chown=node:node . . COPY --chown=node:node . .
RUN mkdir ./data RUN mkdir ./data
# It is just for safe, as by default, it is disabled in the latest Node.js now.
# Read more:
# - https://github.com/sagemathinc/cocalc/issues/6963
# - https://github.com/microsoft/node-pty/issues/630#issuecomment-1987212447
ENV UV_USE_IO_URING=0
VOLUME /app/data VOLUME /app/data
EXPOSE 5001 EXPOSE 5001
HEALTHCHECK --interval=60s --timeout=30s --start-period=60s --retries=5 CMD extra/healthcheck HEALTHCHECK --interval=60s --timeout=30s --start-period=60s --retries=5 CMD extra/healthcheck
@ -32,4 +39,4 @@ CMD ["tsx", "./backend/index.ts"]
# Mark as Nightly # Mark as Nightly
############################################ ############################################
FROM release AS nightly FROM release AS nightly
RUN pnpm run mark-as-nightly RUN npm run mark-as-nightly

View File

@ -1,4 +1,3 @@
version: "3.8"
services: services:
mariadb: mariadb:
image: mariadb:latest image: mariadb:latest

View File

@ -1,4 +1,3 @@
version: '3.8'
services: services:
nginx-proxy-manager: nginx-proxy-manager:
image: 'jc21/nginx-proxy-manager:latest' image: 'jc21/nginx-proxy-manager:latest'

View File

@ -1,4 +1,3 @@
version: '3.8'
services: services:
uptime-kuma: uptime-kuma:
image: louislam/uptime-kuma:1 image: louislam/uptime-kuma:1

View File

@ -4,7 +4,7 @@
<ul v-if="isArrayInited" class="list-group"> <ul v-if="isArrayInited" class="list-group">
<li v-for="(value, index) in array" :key="index" class="list-group-item"> <li v-for="(value, index) in array" :key="index" class="list-group-item">
<select v-model="array[index]" class="no-bg domain-input"> <select v-model="array[index]" class="no-bg domain-input">
<option value="">Select a network...</option> <option value="">{{ $t(`Select a network...`) }}</option>
<option v-for="option in options" :key="option" :value="option">{{ option }}</option> <option v-for="option in options" :key="option" :value="option">{{ option }}</option>
</select> </select>

View File

@ -116,7 +116,7 @@
</label> </label>
<div v-if="networkList.length === 0 && service.networks && service.networks.length > 0" class="text-warning mb-3"> <div v-if="networkList.length === 0 && service.networks && service.networks.length > 0" class="text-warning mb-3">
No networks available. You need to add internal networks or enable external networks in the right side first. {{ $t("NoNetworksAvailable") }}
</div> </div>
<ArraySelect name="networks" :display-name="$t('network')" placeholder="Network Name" :options="networkList" /> <ArraySelect name="networks" :display-name="$t('network')" placeholder="Network Name" :options="networkList" />
@ -127,7 +127,7 @@
<label class="form-label"> <label class="form-label">
{{ $t("dependsOn") }} {{ $t("dependsOn") }}
</label> </label>
<ArrayInput name="depends_on" :display-name="$t('dependsOn')" placeholder="Container Name" /> <ArrayInput name="depends_on" :display-name="$t('dependsOn')" :placeholder="$t(`containerName`)" />
</div> </div>
</div> </div>
</transition> </transition>

View File

@ -3,7 +3,7 @@
<h5>{{ $t("Internal Networks") }}</h5> <h5>{{ $t("Internal Networks") }}</h5>
<ul class="list-group"> <ul class="list-group">
<li v-for="(networkRow, index) in networkList" :key="index" class="list-group-item"> <li v-for="(networkRow, index) in networkList" :key="index" class="list-group-item">
<input v-model="networkRow.key" type="text" class="no-bg domain-input" placeholder="Network name..." /> <input v-model="networkRow.key" type="text" class="no-bg domain-input" :placeholder="$t(`Network name...`)" />
<font-awesome-icon icon="times" class="action remove ms-2 me-3 text-danger" @click="remove(index)" /> <font-awesome-icon icon="times" class="action remove ms-2 me-3 text-danger" @click="remove(index)" />
</li> </li>
</ul> </ul>

View File

@ -201,7 +201,6 @@ export default {
} else { } else {
this.cursorPosition++; this.cursorPosition++;
this.terminalInputBuffer += e.key; this.terminalInputBuffer += e.key;
console.log(this.terminalInputBuffer);
this.terminal.write(e.key); this.terminal.write(e.key);
} }
}); });
@ -247,13 +246,12 @@ export default {
<style scoped lang="scss"> <style scoped lang="scss">
.main-terminal { .main-terminal {
height: 100%; height: 100%;
overflow-x: scroll;
} }
</style> </style>
<style lang="scss"> <style lang="scss">
.terminal { .terminal {
padding: 10px 15px; background-color: black !important;
height: 100%; height: 100%;
} }
</style> </style>

View File

@ -47,7 +47,7 @@
<input <input
v-model="settings.primaryHostname" v-model="settings.primaryHostname"
class="form-control" class="form-control"
placeholder="(Unset: Follow current hostname)" :placeholder="$t(`CurrentHostname`)"
/> />
<button class="btn btn-outline-primary" type="button" @click="autoGetPrimaryHostname"> <button class="btn btn-outline-primary" type="button" @click="autoGetPrimaryHostname">
{{ $t("autoGet") }} {{ $t("autoGet") }}

View File

@ -31,6 +31,7 @@ const languageList = {
"vi": "Tiếng Việt", "vi": "Tiếng Việt",
"hu": "Magyar", "hu": "Magyar",
"ca": "Català", "ca": "Català",
"ga": "Gaeilge",
}; };
let messages = { let messages = {

View File

@ -35,7 +35,7 @@
"restartPolicyAlways": "دائماً", "restartPolicyAlways": "دائماً",
"restartPolicyOnFailure": "عند الفشل", "restartPolicyOnFailure": "عند الفشل",
"restartPolicyNo": "لا", "restartPolicyNo": "لا",
"environmentVariable": "متغير البيئة | متغيرات البيئة", "environmentVariable": "متغير | متغيرات",
"restartPolicy": "سياسة إعادة التشغيل", "restartPolicy": "سياسة إعادة التشغيل",
"containerName": "اسم الحاوية", "containerName": "اسم الحاوية",
"port": "منفذ | منافذ", "port": "منفذ | منافذ",
@ -98,5 +98,16 @@
"url": "رابط | روابط", "url": "رابط | روابط",
"extra": "إضافات", "extra": "إضافات",
"reverseProxyMsg1": "هل تستدخم خادم عكسي؟", "reverseProxyMsg1": "هل تستدخم خادم عكسي؟",
"connecting...": "جاري الاتصال بخادم المقبس…" "connecting...": "جاري الاتصال بخادم المقبس…",
"newUpdate": "تحديث جديد",
"currentEndpoint": "السياق: الوكيل الحالي",
"dockgeURL": "رابط Dockge (مثلا http://127.0.0.1:5001)",
"agentOnline": "متصل",
"agentOffline": "غير متصل",
"connecting": "جاري الإتصال",
"connect": "ارتبط",
"dockgeAgent": "سيرفر Dockge",
"removeAgent": "حذف الوكيل",
"removeAgentMsg": "هل انت متأكد من حذف هذا الوكيل؟",
"LongSyntaxNotSupported": "كتابة النصوص المدعومة غير المدعومة هنا. الرجاء استخدام محرر YAML."
} }

116
frontend/src/lang/be.json Normal file
View File

@ -0,0 +1,116 @@
{
"active": "акт.",
"LongSyntaxNotSupported": "Доўгі сінтаксіс тут не падтрымліваецца. Выкарыстоўвайце рэдактар YAML.",
"removeAgentMsg": "Вы ўпэўнены, што хочаце выдаліць гэтага агента?",
"languageName": "Беларуская",
"Create your admin account": "Стварыце ўліковы запіс адміністратара",
"authIncorrectCreds": "Няправільны лагін ці пароль.",
"PasswordsDoNotMatch": "Паролі не супадаюць.",
"Repeat Password": "Паўтарыце пароль",
"Create": "Стварыць",
"signedInDisp": "Аўтарызаваны як {0}",
"signedInDispDisabled": "Аўтарызацыя выключана.",
"home": "Галоўная",
"console": "Кансоль",
"registry": "Рэестр (Registry)",
"compose": "Compose",
"addFirstStackMsg": "Стварыце свой першы стэк!",
"stackName": "Назва стэка",
"deployStack": "Разгарнуць",
"deleteStack": "Выдаліць",
"stopStack": "Спыніць",
"restartStack": "Перазапусціць",
"updateStack": "Абнавіць",
"startStack": "Запусціць",
"downStack": "Спыніць і дэактываваць",
"editStack": "Рэдагаваць",
"discardStack": "Скасаваць",
"saveStackDraft": "Захаваць",
"notAvailableShort": "Н/Д",
"deleteStackMsg": "Вы ўпэўнены, што хочаце выдаліць гэты стэк?",
"stackNotManagedByDockgeMsg": "Дадзены стэк не кіруецца Dockge.",
"primaryHostname": "Імя хоста",
"general": "Агульныя",
"container": "Кантэйнер | Кантэйнеры",
"scanFolder": "Сканаваць папку стэкаў",
"dockerImage": "Вобраз",
"restartPolicyUnlessStopped": "Пакуль не будзе спынены",
"restartPolicyAlways": "Заўсёды",
"restartPolicyOnFailure": "Пры падзенні",
"restartPolicyNo": "Ніколі",
"environmentVariable": "Зменная асяроддзя | Зменныя асяроддзя",
"restartPolicy": "Палітыка рэстарту",
"containerName": "Імя кантэйнера",
"port": "Порт | Порты",
"volume": "Сховішча | Сховішчы",
"network": "Сетка | Сеткі",
"dependsOn": "Залежнасць кантэйнера | Залежнасці кантэйнера",
"addListItem": "Дадаць {0}",
"deleteContainer": "Выдаліць",
"addContainer": "Дадаць кантэйнер",
"addNetwork": "Дадаць сетку",
"disableauth.message1": "Вы ўпэўнены, што хочаце <strong>адключыць аўтэнтыфікацыю</strong>?",
"Show update if available": "Паказаць абнаўленне, калі яно даступна",
"Also check beta release": "Атрымліваць бэта-версіі",
"disableauth.message2": "Гэта прызначана для сцэнарыяў, <strong>калі вы збіраецеся выкарыстоўваць староннюю аўтэнтыфікацыю</strong> перад Dockge, напрыклад, Cloudflare Access, Authelia або іншыя механізмы аўтэнтыфікацыі.",
"passwordNotMatchMsg": "Паўторны пароль не супадае.",
"autoGet": "Аўта",
"add": "Дадаць",
"Edit": "Змяніць",
"applyToYAML": "Ужыць да YAML",
"createExternalNetwork": "Стварыць",
"addInternalNetwork": "Дадаць",
"Save": "Захаваць",
"Language": "Мова",
"Current User": "Бягучы карыстальнік",
"Change Password": "Змяніць пароль",
"Current Password": "Бягучы пароль",
"New Password": "Новы пароль",
"Repeat New Password": "Паўтарыце новы пароль",
"Update Password": "Абнавіць пароль",
"Advanced": "Пашыраныя",
"Please use this option carefully!": "Выкарыстоўвайце гэтую опцыю асцярожна!",
"Enable Auth": "Уключыць аўтэнтыфікацыю",
"Disable Auth": "Адключыць аўтэнтыфікацыю",
"I understand, please disable": "Я разумею, адключыце",
"Leave": "Пакінуць",
"Frontend Version": "Версія знешняга інтэрфейсу",
"Check Update On GitHub": "Праверыць абнаўленні на GitHub",
"Remember me": "Запомніць мяне",
"Login": "Лагін",
"Username": "Імя карыстальніка",
"Password": "Пароль",
"Settings": "Налады",
"Logout": "Выйсці",
"Lowercase only": "Толькі ніжні рэгістр",
"Convert to Compose": "Пераўтварыць у Compose",
"Docker Run": "Docker Run",
"exited": "спын.",
"inactive": "неакт.",
"Appearance": "Знешні выгляд",
"Security": "Бяспека",
"About": "Аб праграме",
"Allowed commands:": "Дазволеныя каманды:",
"Internal Networks": "Унутраныя сеткі",
"External Networks": "Знешнія сеткі",
"No External Networks": "Няма знешніх сетак",
"reverseProxyMsg1": "Выкарыстоўваеце зваротны проксі?",
"reverseProxyMsg2": "Праверце, як наладзіць яго для WebSocket",
"Cannot connect to the socket server.": "Не ўдалося падключыцца да сокет-сервера.",
"reconnecting...": "Перападключэнне…",
"connecting...": "Падключэнне да сокет-сервера…",
"url": "URL-адрас | URL-адрасы",
"extra": "Дадаткова",
"newUpdate": "Даступна абнаўленне",
"dockgeAgent": "Агент Dockge | Агенты Dockge",
"currentEndpoint": "Бягучы",
"dockgeURL": "URL-адрас Dockge (напрыклад: http://127.0.0.1:5001)",
"agentOnline": "У сетцы",
"agentOffline": "Не ў сетцы",
"connecting": "Падключэнне",
"connect": "Падключыць",
"addAgent": "Дадаць Агента",
"agentAddedSuccessfully": "Агент паспяхова дададзены.",
"agentRemovedSuccessfully": "Агент паспяхова выдалены.",
"removeAgent": "Выдаліць агента"
}

View File

@ -111,5 +111,22 @@
"removeAgentMsg": "Сигурни ли сте, че желаете да премахнете този агент?", "removeAgentMsg": "Сигурни ли сте, че желаете да премахнете този агент?",
"dockgeAgent": "Dockge агент | Dockge агенти", "dockgeAgent": "Dockge агент | Dockge агенти",
"connecting": "Свързване", "connecting": "Свързване",
"agentRemovedSuccessfully": "Агентът е премахнат успешно." "agentRemovedSuccessfully": "Агентът е премахнат успешно.",
"LongSyntaxNotSupported": "Дългият синтаксис не се поддържа тук. Моля, използвайте YAML редактора.",
"Started": "Стартиран",
"Updated": "Актуализиран",
"Deleted": "Изтрит",
"Deployed": "Внедрен",
"Stopped": "Спрян",
"Restarted": "Рестартиран",
"Switch to sh": "Превключи на \"sh\"",
"terminal": "Терминал",
"New Container Name...": "Ново име на контейнер...",
"Network name...": "Име на мрежата...",
"Select a network...": "Изберете мрежа...",
"Lost connection to the socket server. Reconnecting...": "Изгубена връзка със сокет сървъра. Повторно свързване...",
"Saved": "Запазено",
"Downed": "Свален",
"CurrentHostname": "(Не е зададено: Следвай текущото име на хост)",
"NoNetworksAvailable": "Няма налични мрежи. Първо трябва да добавите вътрешни мрежи или да активирате външни мрежи в дясната страна."
} }

View File

@ -111,5 +111,6 @@
"Please use this option carefully!": "Si us plau, utilitzeu aquesta opció amb cura!", "Please use this option carefully!": "Si us plau, utilitzeu aquesta opció amb cura!",
"Enable Auth": "Habilitar autenticació", "Enable Auth": "Habilitar autenticació",
"I understand, please disable": "Ho entenc, si us plau deshabilita", "I understand, please disable": "Ho entenc, si us plau deshabilita",
"Password": "Contrasenya" "Password": "Contrasenya",
"LongSyntaxNotSupported": "La sintaxi llarga no està suportada aquí. Si us plau, fes servir l'editor YAML."
} }

View File

@ -19,7 +19,7 @@
"restartStack": "Restartovat", "restartStack": "Restartovat",
"updateStack": "Aktualizovat", "updateStack": "Aktualizovat",
"startStack": "Spustit", "startStack": "Spustit",
"downStack": "Zastavit & Vypnout", "downStack": "Zastavit & Zneaktivnit",
"editStack": "Upravit", "editStack": "Upravit",
"discardStack": "Zahodit", "discardStack": "Zahodit",
"saveStackDraft": "Uložit", "saveStackDraft": "Uložit",
@ -97,5 +97,33 @@
"extra": "Extra", "extra": "Extra",
"reverseProxyMsg1": "Používáte Reverzní proxy server?", "reverseProxyMsg1": "Používáte Reverzní proxy server?",
"reverseProxyMsg2": "Podívat se jak to nastavit pro WebSocket", "reverseProxyMsg2": "Podívat se jak to nastavit pro WebSocket",
"Cannot connect to the socket server.": "Nelze se připojit k serveru ." "Cannot connect to the socket server.": "Nelze se připojit k serveru .",
"Lost connection to the socket server. Reconnecting...": "Ztraceno spojení se serverem. Obnovuji spojení...",
"newUpdate": "Nová aktualizace",
"dockgeAgent": "Dockge Agent | Dockge Agenti",
"agentOnline": "Online",
"connecting": "Připojování",
"agentOffline": "Offline",
"dockgeURL": "Dockge URL (např. http://127.0.0.1:5001)",
"LongSyntaxNotSupported": "Dlouhá syntaxe zde není podporována. Použijte, prosím, YAML editor.",
"connecting...": "Připojování k socket serveru…",
"connect": "Připojit",
"addAgent": "Přidat Agenta",
"agentAddedSuccessfully": "Agent byl úspěšně přidán.",
"agentRemovedSuccessfully": "Agend byl úspěšně odebrán.",
"removeAgent": "Odebrat Agenta",
"removeAgentMsg": "Opravdu chcete tohoto agenta odebrat?",
"Saved": "Uloženo",
"Deployed": "Nasazeno",
"Deleted": "Odstraněno",
"Updated": "Aktualizovat",
"Started": "Spuštěno",
"Stopped": "Zastaveno",
"Restarted": "Restartováno",
"Switch to sh": "Přepnout na sh shell",
"terminal": "Terminál",
"New Container Name...": "Název nového kontejneru...",
"Network name...": "Název sítě...",
"Select a network...": "Vyberte síť...",
"NoNetworksAvailable": "Žádná síť není dostupná. Musíte přidat interní síť nebo povolit externí sítě v pravé části."
} }

View File

@ -58,8 +58,8 @@
"Update Password": "Opdater adgangskode", "Update Password": "Opdater adgangskode",
"Advanced": "Avanceret", "Advanced": "Avanceret",
"Please use this option carefully!": "Brug venligst denne indstilling forsigtigt!", "Please use this option carefully!": "Brug venligst denne indstilling forsigtigt!",
"Enable Auth": "Aktiver godkændelse", "Enable Auth": "Aktiver godkendelse",
"Disable Auth": "Deaktiver godkændelse", "Disable Auth": "Deaktiver godkendelse",
"I understand, please disable": "Jeg forstår, venligst deaktiver", "I understand, please disable": "Jeg forstår, venligst deaktiver",
"Leave": "Forlad", "Leave": "Forlad",
"Frontend Version": "Version", "Frontend Version": "Version",
@ -72,7 +72,7 @@
"Settings": "Indstillinger", "Settings": "Indstillinger",
"Logout": "Log ud", "Logout": "Log ud",
"Convert to Compose": "Konverter til Compose", "Convert to Compose": "Konverter til Compose",
"active": "aktive", "active": "aktiv",
"exited": "forladt", "exited": "forladt",
"inactive": "inaktive", "inactive": "inaktive",
"Appearance": "Udseende", "Appearance": "Udseende",
@ -111,5 +111,16 @@
"agentAddedSuccessfully": "Agent succesfuld tilføjet.", "agentAddedSuccessfully": "Agent succesfuld tilføjet.",
"agentRemovedSuccessfully": "Agent succesfuld fjernet.", "agentRemovedSuccessfully": "Agent succesfuld fjernet.",
"removeAgent": "Fjern agent", "removeAgent": "Fjern agent",
"removeAgentMsg": "Er du sikker på at du vil fjerne denne agent?" "removeAgentMsg": "Er du sikker på at du vil fjerne denne agent?",
"LongSyntaxNotSupported": "Langt syntaks er ikke understøttet her. Forsøg venligst med YAML-editoren.",
"Saved": "Gemt",
"Deleted": "Slettet",
"Updated": "Opdateret",
"Started": "Startet",
"Stopped": "Stoppet",
"Restarted": "Genstartet",
"terminal": "Terminal",
"Network name...": "Netværksnavn...",
"Select a network...": "Vælg et netværk...",
"Deployed": "Udrullet"
} }

View File

@ -94,7 +94,7 @@
"Cannot connect to the socket server.": "Keine Verbindung zum Socket Server.", "Cannot connect to the socket server.": "Keine Verbindung zum Socket Server.",
"reverseProxyMsg1": "Wird ein Reverse Proxy genutzt?", "reverseProxyMsg1": "Wird ein Reverse Proxy genutzt?",
"reconnecting...": "Erneuter Verbindungsaufbau…", "reconnecting...": "Erneuter Verbindungsaufbau…",
"downStack": "Stopp & Inaktiv", "downStack": "Stoppen & Deaktivieren",
"extra": "Extra", "extra": "Extra",
"url": "URL / URLs", "url": "URL / URLs",
"reverseProxyMsg2": "Lerne wie dieser für WebSockets zu konfigurieren ist.", "reverseProxyMsg2": "Lerne wie dieser für WebSockets zu konfigurieren ist.",
@ -111,5 +111,22 @@
"agentAddedSuccessfully": "Agent erfolgreich hinzugefügt.", "agentAddedSuccessfully": "Agent erfolgreich hinzugefügt.",
"agentRemovedSuccessfully": "Agent erfolgreich entfernt.", "agentRemovedSuccessfully": "Agent erfolgreich entfernt.",
"removeAgent": "Agent Entfernen", "removeAgent": "Agent Entfernen",
"removeAgentMsg": "Bist Du sicher, dass Du diesen Agent entfernen möchtest?" "removeAgentMsg": "Bist Du sicher, dass Du diesen Agent entfernen möchtest?",
"LongSyntaxNotSupported": "Lange Syntax wird nicht unterstützt. Bitte verwende den YAML-Editor.",
"Lost connection to the socket server. Reconnecting...": "Verbindung zu Socket Server verloren. Verbinden...",
"Saved": "Gespeichert",
"Deleted": "Gelöscht",
"Started": "Gestartet",
"Stopped": "Gestoppt",
"Restarted": "Neugestartet",
"New Container Name...": "Neuer Container Name...",
"Network name...": "Netzwerkname...",
"Select a network...": "Netzwerk auswählen...",
"Updated": "Aktualisiert",
"Deployed": "Deployed",
"Switch to sh": "Zu sh wechseln",
"terminal": "Terminal",
"CurrentHostname": "(nicht gesetzt: verwende aktuellen Hostname)",
"Downed": "Heruntergefahren",
"NoNetworksAvailable": "Keine Netzwerke verfügbar. Du musst zunächst interne Netzwerke hinzufügen oder externe Netzwerke auf der rechten Seite aktivieren."
} }

View File

@ -95,6 +95,7 @@
"reverseProxyMsg1": "Using a Reverse Proxy?", "reverseProxyMsg1": "Using a Reverse Proxy?",
"reverseProxyMsg2": "Check how to config it for WebSocket", "reverseProxyMsg2": "Check how to config it for WebSocket",
"Cannot connect to the socket server.": "Cannot connect to the socket server.", "Cannot connect to the socket server.": "Cannot connect to the socket server.",
"Lost connection to the socket server. Reconnecting...": "Lost connection to the socket server. Reconnecting...",
"reconnecting...": "Reconnecting…", "reconnecting...": "Reconnecting…",
"connecting...": "Connecting to the socket server…", "connecting...": "Connecting to the socket server…",
"url": "URL | URLs", "url": "URL | URLs",
@ -112,5 +113,20 @@
"agentRemovedSuccessfully": "Agent removed successfully.", "agentRemovedSuccessfully": "Agent removed successfully.",
"removeAgent": "Remove Agent", "removeAgent": "Remove Agent",
"removeAgentMsg": "Are you sure you want to remove this agent?", "removeAgentMsg": "Are you sure you want to remove this agent?",
"LongSyntaxNotSupported": "Long syntax is not supported here. Please use the YAML editor." "LongSyntaxNotSupported": "Long syntax is not supported here. Please use the YAML editor.",
"Saved": "Saved",
"Deployed": "Deployed",
"Deleted": "Deleted",
"Updated": "Updated",
"Started": "Started",
"Stopped": "Stopped",
"Restarted": "Restarted",
"Downed": "Downed",
"Switch to sh": "Switch to sh",
"terminal": "Terminal",
"CurrentHostname": "(Unset: Follow current hostname)",
"New Container Name...": "New Container Name...",
"Network name...": "Network name...",
"Select a network...": "Select a network...",
"NoNetworksAvailable": "No networks available. You need to add internal networks or enable external networks in the right side first."
} }

View File

@ -1,5 +1,5 @@
{ {
"languageName": "Español", "languageName": "Inglés",
"Create your admin account": "Crea tu cuenta de administrador", "Create your admin account": "Crea tu cuenta de administrador",
"authIncorrectCreds": "Nombre de usuario o contraseña incorrectos.", "authIncorrectCreds": "Nombre de usuario o contraseña incorrectos.",
"PasswordsDoNotMatch": "Las contraseñas no coinciden.", "PasswordsDoNotMatch": "Las contraseñas no coinciden.",
@ -98,18 +98,35 @@
"Cannot connect to the socket server.": "No se puede conectar al servidor del socket.", "Cannot connect to the socket server.": "No se puede conectar al servidor del socket.",
"reconnecting...": "Reconectando…", "reconnecting...": "Reconectando…",
"connecting...": "Conectando al servidor del socket…", "connecting...": "Conectando al servidor del socket…",
"url": "URL | URLs", "url": "Dirección URL | Direcciones URLs",
"extra": "Addicional", "extra": "Addicional",
"currentEndpoint": "Corriente", "currentEndpoint": "Actual",
"dockgeURL": "URL de Dockge (ej. http://127.0.0.1:5001)", "dockgeURL": "URL de Dockge (ej. http://127.0.0.1:5001)",
"agentOnline": "Conectado", "agentOnline": "En línea",
"agentOffline": "Desconectado", "agentOffline": "Desconectado",
"connect": "Conectar", "connect": "Conectar",
"addAgent": "Añadir Agente", "addAgent": "Añadir Agente",
"agentAddedSuccessfully": "Agente añadido satisfactoriamente.", "agentAddedSuccessfully": "Agente añadido satisfactoriamente.",
"removeAgent": "Remover Agente", "removeAgent": "Eliminar Agente",
"removeAgentMsg": "Estás seguro que deseas remover este agente?", "removeAgentMsg": "¿Estás seguro que deseas eliminar este agente?",
"dockgeAgent": "Agentes Dockge", "dockgeAgent": "Agentes Dockge",
"connecting": "Conectando", "connecting": "Conectando",
"agentRemovedSuccessfully": "Agente removido satisfactoriamente." "agentRemovedSuccessfully": "Agente eliminado satisfactoriamente.",
"LongSyntaxNotSupported": "No hay soporte para la sintaxis larga. Por favor use el editor de YAML.",
"Lost connection to the socket server. Reconnecting...": "Se ha perdido la conexión con el servidor de socket. Reconectando...",
"Saved": "Guardado",
"Deployed": "Desplegado",
"Deleted": "Eliminado",
"Updated": "Actualizado",
"Started": "Arrancado",
"Stopped": "Parado",
"Restarted": "Reseteado",
"Downed": "Caído",
"Switch to sh": "Cambiar a sh",
"terminal": "Terminal",
"CurrentHostname": "(Vacío: Seguir hostname actual)",
"New Container Name...": "Nombre del nuevo Container...",
"Network name...": "Nombre de la red...",
"Select a network...": "Selecciona una red...",
"NoNetworksAvailable": "No hay redes disponibles. Primero debes agregar redes internas o habilitar redes externas en el lado derecho."
} }

View File

@ -111,5 +111,22 @@
"dockgeAgent": "Dockge Agent | Dockge Agents", "dockgeAgent": "Dockge Agent | Dockge Agents",
"currentEndpoint": "Actuel", "currentEndpoint": "Actuel",
"connect": "Connecter", "connect": "Connecter",
"removeAgentMsg": "Êtes-vous sûr de vouloir supprimer cet agent ?" "removeAgentMsg": "Êtes-vous sûr de vouloir supprimer cet agent ?",
"LongSyntaxNotSupported": "La syntaxe longue n'est pas prise en charge ici. Veuillez utiliser l'éditeur YAML.",
"Saved": "Enregistré",
"Deployed": "Déployé",
"Deleted": "Supprimé",
"Updated": "Mis à jour",
"Started": "démarrer",
"Stopped": "Arrêté",
"Restarted": "Redémarré",
"Switch to sh": "Passer à sh",
"terminal": "Terminal",
"New Container Name...": "Nouveau nom du conteneur...",
"Network name...": "Nom du réseau...",
"Select a network...": "Sélectionnez un réseau...",
"Downed": "Abattu",
"Lost connection to the socket server. Reconnecting...": "Connexion au serveur socket perdue. Reconnexion...",
"CurrentHostname": "(Non défini: suivre le nom d'hôte actuel)",
"NoNetworksAvailable": "Aucun réseau disponible. Vous devez d'abord ajouter des réseaux internes ou activer les réseaux externes sur le côté droit."
} }

132
frontend/src/lang/ga.json Normal file
View File

@ -0,0 +1,132 @@
{
"Create your admin account": "Cruthaigh do chuntas riaracháin",
"authIncorrectCreds": "Ainm úsáideora nó pasfhocal mícheart.",
"PasswordsDoNotMatch": "Níl na pasfhocail comhthráthacha.",
"Repeat Password": "Athscríobh an Pasfhocal",
"Create": "Cruthaigh",
"signedInDisp": "Sínithe isteach mar {0}",
"languageName": "Gaeilge",
"console": "Consól",
"registry": "Clárlann",
"compose": "Scríobh",
"stackName": "Ainm an Staca",
"deployStack": "Deighil",
"deleteStack": "Scrios",
"stopStack": "Stad",
"restartStack": "Atosaigh",
"updateStack": "Nuashonraigh",
"startStack": "Tosaigh",
"downStack": "Stad & Neamhghníomhach",
"editStack": "Cuir in Eagar",
"discardStack": "Caith amach",
"saveStackDraft": "Sábháil",
"deleteStackMsg": "An bhfuil tú cinnte go bhfuil tú ag iarraidh an staca seo a scriosadh?",
"primaryHostname": "Príomhainm óstáin",
"general": "Ginearálta",
"container": "Coimeádán | Coimeádáin",
"scanFolder": "Scanáil Fillteáin na dStacanna",
"dockerImage": "Íomha",
"restartPolicyUnlessStopped": "Mura Stadfar",
"restartPolicyAlways": "I gcónaí",
"restartPolicyOnFailure": "Ar theip",
"restartPolicyNo": "Níl",
"environmentVariable": "Athróg Timpeallacht | Athróga Timpeallacht",
"restartPolicy": "Polasaí Atosaigh",
"port": "Port | Portanna",
"volume": "Toirt | Toirteanna",
"network": "Líonra | Líonraí",
"dependsOn": "Spleáchas Coimeádán | Spleáchais Coimeádán",
"addListItem": "Cuir {0}",
"deleteContainer": "Scrios",
"addContainer": "Cuir Coimeádán leis",
"addNetwork": "Cuir Líonra leis",
"add": "Cuir",
"Edit": "Cuir in eagar",
"applyToYAML": "Déan iarratas ar YAML",
"createExternalNetwork": "Cruthaigh",
"disableauth.message1": "An bhfuil tú cinnte gur mhaith leat <strong>fíordheimhniú a dhíchumasú</strong>?",
"passwordNotMatchMsg": "Ní hionann an pasfhocal athfhillteach.",
"autoGet": "Faigh Uathoibríoch",
"addInternalNetwork": "Cuir",
"Save": "Sábháil",
"Language": "Teanga",
"Current User": "Úsáideoir Reatha",
"New Password": "Pasfhocal Nua",
"Current Password": "Pasfhocal Reatha",
"Change Password": "Athraigh do Phasfhocal",
"Repeat New Password": "Déan Pasfhocal Nua arís",
"Update Password": "Nuashonraigh Pasfhocal",
"Advanced": "Ardleibhéal",
"Please use this option carefully!": "Bain úsáid as an rogha seo go cúramach, le do thoil!",
"Enable Auth": "Cumasaigh Auth",
"Disable Auth": "Auth dhíchumasú",
"I understand, please disable": "Tuigim, le do thoil, múch",
"Leave": "Fág",
"Frontend Version": "Leagan Frontend",
"Check Update On GitHub": "Seiceáil an Nuashonrú ar GitHub",
"Show update if available": "Taispeáin an Nuashonrú más ar fáil",
"Also check beta release": "Seiceáil an scaoileadh beta freisin",
"Remember me": "Cuimhnigh orm",
"Login": "Logáil isteach",
"Username": "Ainm úsáideora",
"Password": "Pasfhocal",
"Logout": "Logáil Amach",
"Lowercase only": "Cás íochtair amháin",
"Convert to Compose": "Tiontaigh go Compóidh",
"Docker Run": "Docker Rith",
"exited": "scoir",
"inactive": "neamhghníomhach",
"Appearance": "Dealramh",
"Security": "Slándáil",
"About": "Maidir le",
"Allowed commands:": "Orduithe ceadaithe:",
"Internal Networks": "Líonraí Inmheánacha",
"External Networks": "Líonraí Seachtracha",
"No External Networks": "Gan Líonraí Seachtracha",
"reverseProxyMsg1": "Ag Úsáid Seachfhreastalaí Réabhlóideach?",
"reverseProxyMsg2": "Seiceáil conas é a shocraigh don WebSocket",
"Cannot connect to the socket server.": "Ní féidir ceangal a dhéanamh leis an freastalaí soicéad.",
"reconnecting...": "Ag athcheangal…",
"connecting...": "Ag nascadh leis an freastalaí soicéad…",
"url": "URL | URLanna",
"extra": "Breise",
"newUpdate": "Nuashonrú Nua",
"dockgeAgent": "Aighne Dockge | Aighnithe Dockge",
"currentEndpoint": "Reatha",
"dockgeURL": "Dockge URL (e.g. http://127.0.0.1:5001)",
"agentOnline": "Ar Líne",
"agentOffline": "As Líne",
"connecting": "Ag Nascadh",
"connect": "Ceangail",
"addAgent": "Cuir Aighne",
"agentAddedSuccessfully": "Aighne curtha leis go rathúil.",
"agentRemovedSuccessfully": "Aighne bhaint as go rathúil.",
"removeAgent": "Bain Aighne",
"removeAgentMsg": "An bhfuil tú cinnte gur mhaith leat an t-aighne seo a bhaint?",
"LongSyntaxNotSupported": "Ní thacaítear leis an níochán fada anseo. Úsáid an Eagarthóir YAML, le do thoil.",
"signedInDispDisabled": "Auth Díchumasaithe.",
"home": "Abhaile",
"addFirstStackMsg": "Scríobh do chéad stac!",
"notAvailableShort": "Níl ar Fáil",
"stackNotManagedByDockgeMsg": "Ní bhainistítear an staca seo ag Dockge.",
"containerName": "Ainm na gCoimeádán",
"disableauth.message2": "Tá sé deartha do chúinsí <strong>ina bhfuil sé beartaithe agat tríú páirtí athbhreithniú a chur i bhfeidhm</strong> os comhair Dockge cosúil le Rochtain Cloudflare, Authelia nó múnlaí deimhniú eile.",
"Settings": "Socruithe",
"active": "gníomhach",
"Lost connection to the socket server. Reconnecting...": "Ceangal caillte leis an bhfreastalaí soicéad. Ag athcheangal...",
"Saved": "Shábháil",
"Deployed": "Imlonnaithe",
"Deleted": "Scriosta",
"Updated": "Nuashonraithe",
"Started": "Thosaigh",
"Stopped": "Stopadh",
"Restarted": "Atosaigh",
"Downed": "Tugtha anuas",
"Switch to sh": "Athraigh go sh",
"terminal": "Teirminéal",
"CurrentHostname": "(Díshuiteáil: Lean an t-óstainm reatha)",
"New Container Name...": "Ainm Gabhdáin Nua...",
"Network name...": "Ainm líonra...",
"Select a network...": "Roghnaigh líonra...",
"NoNetworksAvailable": "Níl líonraí ar fáil. Ní mór duit líonraí inmheánacha a chur leis nó líonraí seachtracha a chumasú ar an taobh deas ar dtús."
}

View File

@ -47,7 +47,7 @@
"Advanced": "Fejlett", "Advanced": "Fejlett",
"Enable Auth": "Hitelesítés Bekapcsolása", "Enable Auth": "Hitelesítés Bekapcsolása",
"Disable Auth": "Hitelesítés Kikapcsolása", "Disable Auth": "Hitelesítés Kikapcsolása",
"I understand, please disable": "Megértetten, kapcsolja ki", "I understand, please disable": "Megértettem, kérem kapcsolja ki",
"Leave": "Kilépés", "Leave": "Kilépés",
"Frontend Version": "Frontend Verzió", "Frontend Version": "Frontend Verzió",
"Also check beta release": "Béta kiadás is", "Also check beta release": "Béta kiadás is",
@ -111,5 +111,22 @@
"Cannot connect to the socket server.": "A Socket csatlakozás nem elérhető.", "Cannot connect to the socket server.": "A Socket csatlakozás nem elérhető.",
"connecting...": "Csatlakozás a socket szerver-hez…", "connecting...": "Csatlakozás a socket szerver-hez…",
"url": "URL | URL-ek", "url": "URL | URL-ek",
"dockgeURL": "Dockge URL (pl. http://127.0.0.1:5001)" "dockgeURL": "Dockge URL (pl. http://127.0.0.1:5001)",
"LongSyntaxNotSupported": "A hosszú szintaxis itt nem támogatott. Használja a YAML szerkesztőt.",
"Lost connection to the socket server. Reconnecting...": "Megszakadt a kapcsolat a socket szerverrel. Újracsatlakozás...",
"Saved": "Elmentve",
"Deployed": "Telepítve",
"Deleted": "Törölve",
"Updated": "Frissítve",
"Started": "Indult",
"Stopped": "Megállítva",
"Restarted": "Újraindítva",
"Downed": "Leállított",
"Switch to sh": "Váltás shell-re",
"terminal": "Terminál",
"CurrentHostname": "(Nincs beállítva: Az aktuális gazdagépnév követése)",
"New Container Name...": "Új konténer név...",
"Network name...": "Hálózat név...",
"Select a network...": "Válasszon ki egy hálózatot...",
"NoNetworksAvailable": "Nincs elérhető hálózat. Először hozzá kell adnia belső hálózatokat, vagy engedélyeznie kell a külső hálózatokat a jobb oldalon."
} }

View File

@ -111,5 +111,12 @@
"currentEndpoint": "Sekarang", "currentEndpoint": "Sekarang",
"agentOnline": "Terhubung", "agentOnline": "Terhubung",
"agentOffline": "Terputus", "agentOffline": "Terputus",
"removeAgentMsg": "Apakah anda yakin untuk menghapus agen ini?" "removeAgentMsg": "Apakah anda yakin untuk menghapus agen ini?",
"LongSyntaxNotSupported": "Sintaks yang panjang tidak didukung di sini. Silakan gunakan editor YAML.",
"Saved": "Tersimpan",
"Deleted": "Terhapus",
"Updated": "Telah diperbaharui",
"Started": "Aplikasi dimulai",
"Stopped": "Aplikasi dihentikan",
"Restarted": "Aplikasi memuat kembali"
} }

View File

@ -95,10 +95,10 @@
"reverseProxyMsg1": "Stai usando Reverse Proxy?", "reverseProxyMsg1": "Stai usando Reverse Proxy?",
"reverseProxyMsg2": "Verifica come configurarlo per il WebSocket", "reverseProxyMsg2": "Verifica come configurarlo per il WebSocket",
"Cannot connect to the socket server.": "impossibile collegarsi al socket server", "Cannot connect to the socket server.": "impossibile collegarsi al socket server",
"connecting...": "Connessione al server socket…", "connecting...": "connettendosi al socket server…",
"extra": "Extra", "extra": "Extra",
"reconnecting...": "Riconnessione…", "reconnecting...": "Riconnessione…",
"url": "Indirizzo | Indirizzi", "url": "URL | URLs",
"newUpdate": "Nuovo aggiornamento", "newUpdate": "Nuovo aggiornamento",
"dockgeAgent": "Agente Dockge | Agenti Dockge", "dockgeAgent": "Agente Dockge | Agenti Dockge",
"currentEndpoint": "Corrente", "currentEndpoint": "Corrente",
@ -111,5 +111,6 @@
"removeAgent": "Rimuovi Agente", "removeAgent": "Rimuovi Agente",
"removeAgentMsg": "Sei sicuro di voler rimuovere questo agente?", "removeAgentMsg": "Sei sicuro di voler rimuovere questo agente?",
"addAgent": "Aggungi Agente", "addAgent": "Aggungi Agente",
"agentAddedSuccessfully": "Agente aggiunto correttamente." "agentAddedSuccessfully": "Agente aggiunto correttamente.",
"LongSyntaxNotSupported": "La sintassi lunga non è supportata qui. Utilizzare l'editor YAML."
} }

View File

@ -34,7 +34,7 @@
"primaryHostname": "主ホスト名", "primaryHostname": "主ホスト名",
"container": "コンテナ", "container": "コンテナ",
"dependsOn": "コンテナ依存関係", "dependsOn": "コンテナ依存関係",
"downStack": "停止してInactive", "downStack": "停止して非アクティブ化",
"notAvailableShort": "N/A", "notAvailableShort": "N/A",
"restartPolicyUnlessStopped": "手動で停止されるまで", "restartPolicyUnlessStopped": "手動で停止されるまで",
"restartPolicyAlways": "常時", "restartPolicyAlways": "常時",
@ -94,5 +94,36 @@
"I understand, please disable": "理解しました。無効化してください", "I understand, please disable": "理解しました。無効化してください",
"Lowercase only": "小文字のみ", "Lowercase only": "小文字のみ",
"reverseProxyMsg1": "リバースプロキシを使用していますか?", "reverseProxyMsg1": "リバースプロキシを使用していますか?",
"connecting...": "ソケットサーバーに接続中…" "connecting...": "ソケットサーバーに接続中…",
"newUpdate": "新しいバージョン",
"dockgeAgent": "Dockge エージェント",
"dockgeURL": "DockgeのURL (例: http://127.0.0.1:5001)",
"agentOnline": "オンライン",
"agentOffline": "オフライン",
"connecting": "接続中",
"connect": "接続",
"addAgent": "エージェントを追加",
"agentAddedSuccessfully": "エージェントが正常に追加されました。",
"agentRemovedSuccessfully": "エージェントは正常に削除されました。",
"removeAgent": "エージェントを削除",
"removeAgentMsg": "本当にこのエージェントを削除しますか?",
"url": "URL | URL",
"About": "Dockgeについて",
"Docker Run": "Docker Run to Compose",
"LongSyntaxNotSupported": "長い構文はここではサポートされていません。YAMLエディタを使用してください。",
"Lost connection to the socket server. Reconnecting...": "ソケットサーバーとの接続が失われました。再接続中です...",
"extra": "追加設定",
"Saved": "保存済み",
"Deployed": "デプロイ済み",
"Deleted": "削除済み",
"Updated": "アップデート済み",
"Started": "開始済み",
"Stopped": "停止済み",
"Restarted": "再起動済み",
"Switch to sh": "shに切り替え",
"terminal": "ターミナル",
"New Container Name...": "新しいコンテナ名...",
"Network name...": "ネットワーク名...",
"Select a network...": "ネットワークを選択...",
"NoNetworksAvailable": "利用可能なネットワークがありません。まず右側の内部ネットワークを追加するか、外部ネットワークを有効にする必要があります。"
} }

View File

@ -111,5 +111,6 @@
"dockgeAgent": "Dockge 에이전트", "dockgeAgent": "Dockge 에이전트",
"currentEndpoint": "현재", "currentEndpoint": "현재",
"connecting": "연결 중", "connecting": "연결 중",
"agentRemovedSuccessfully": "에이전트를 성공적으로 삭제했습니다." "agentRemovedSuccessfully": "에이전트를 성공적으로 삭제했습니다.",
"LongSyntaxNotSupported": "긴 문법은 여기서 지원되지 않습니다. YAML 에디터를 사용하세요."
} }

View File

@ -0,0 +1,34 @@
{
"Create your admin account": "Lag din administrator konto",
"authIncorrectCreds": "Brukernavn eller passord stemmer ikke.",
"PasswordsDoNotMatch": "Passord stemmer ikke.",
"Repeat Password": "Gjenta passord",
"Create": "Lag",
"signedInDisp": "Logg in som {0}",
"signedInDispDisabled": "Auth deaktivert.",
"home": "Hjem",
"console": "Konsoll",
"registry": "Register",
"compose": "Skriv",
"addFirstStackMsg": "Lag din første stack!",
"stackName": "Navn på stack",
"deployStack": "Utplassere",
"deleteStack": "Slett",
"stopStack": "Stoppe",
"restartStack": "Omstart",
"updateStack": "Oppdater",
"downStack": "Stop & Inaktiver",
"editStack": "Rediger",
"discardStack": "Kast",
"saveStackDraft": "Lagre",
"notAvailableShort": "N/A",
"deleteStackMsg": "Er du sikker på at du vil slette denne stacken?",
"stackNotManagedByDockgeMsg": "Denne stacken er ikke styrt av Dockge.",
"primaryHostname": "Primært vertsnavn",
"general": "Generell",
"container": "Container | Containers",
"scanFolder": "Skann Stacks mappe",
"dockerImage": "Bilde",
"languageName": "Engelsk",
"startStack": "Start"
}

View File

@ -100,7 +100,7 @@
"Convert to Compose": "Converteer naar compose", "Convert to Compose": "Converteer naar compose",
"External Networks": "Externe netwerken", "External Networks": "Externe netwerken",
"newUpdate": "Nieuwe update", "newUpdate": "Nieuwe update",
"dockgeAgent": "Dockge Agent | Dockge Agents", "dockgeAgent": "Dockge Agent | Dockge Agenten",
"currentEndpoint": "Huidige", "currentEndpoint": "Huidige",
"dockgeURL": "Dockge Adres (bijv. http://127.0.0.1:5001)", "dockgeURL": "Dockge Adres (bijv. http://127.0.0.1:5001)",
"agentOnline": "Online", "agentOnline": "Online",
@ -111,5 +111,6 @@
"agentAddedSuccessfully": "Agent toegevoegd.", "agentAddedSuccessfully": "Agent toegevoegd.",
"agentRemovedSuccessfully": "Agent verwijderd.", "agentRemovedSuccessfully": "Agent verwijderd.",
"removeAgent": "Verwijder agent", "removeAgent": "Verwijder agent",
"removeAgentMsg": "Weet je zeker dat je deze agent wilt verwijderen?" "removeAgentMsg": "Weet je zeker dat je deze agent wilt verwijderen?",
"LongSyntaxNotSupported": "Lange syntax wordt hier niet ondersteund. Gebruik de YAML editor."
} }

View File

@ -111,5 +111,22 @@
"connecting...": "Łączenie z socketem serwera…", "connecting...": "Łączenie z socketem serwera…",
"extra": "Ekstra", "extra": "Ekstra",
"url": "URL | URLe", "url": "URL | URLe",
"reconnecting...": "Wznawianie połączenia…" "reconnecting...": "Wznawianie połączenia…",
"LongSyntaxNotSupported": "Nieobsługiwana składnia. Użyj edytora YAML.",
"Saved": "Zapisano",
"Switch to sh": "Przełącz na sh",
"terminal": "Terminal",
"Restarted": "Zrestartowano",
"Deployed": "Wdrożono",
"Deleted": "Usunięto",
"Updated": "Zaktualizowano",
"Started": "Uruchomiono",
"Stopped": "Zatrzymano",
"Downed": "Położono",
"Lost connection to the socket server. Reconnecting...": "Utracono połączenie z socketem serwera. Ponawiam połączenie...",
"New Container Name...": "Nazwa nowego kontenera...",
"Network name...": "Nazwa sieci...",
"Select a network...": "Wybierz sieć...",
"NoNetworksAvailable": "Brak dostępnych sieci. Musisz najpierw dodać sieć wewnętrzną lub włączyć sieci zewnętrzne po prawej stronie.",
"CurrentHostname": "(Odznacze: Podążaj za aktualnym hostem)"
} }

View File

@ -111,5 +111,22 @@
"agentAddedSuccessfully": "Agente adicionado com sucesso.", "agentAddedSuccessfully": "Agente adicionado com sucesso.",
"agentRemovedSuccessfully": "Agente removido com sucesso.", "agentRemovedSuccessfully": "Agente removido com sucesso.",
"removeAgent": "Remover Agente", "removeAgent": "Remover Agente",
"removeAgentMsg": "Tem certeza de que deseja remover este agente?" "removeAgentMsg": "Tem certeza de que deseja remover este agente?",
"LongSyntaxNotSupported": "Sintaxe longa não é suportada aqui. Por favor, use o editor de YAML.",
"Lost connection to the socket server. Reconnecting...": "Conexão perdida com o servidor de socket. Reconectando...",
"Saved": "Salvo",
"Deployed": "Implantado",
"Deleted": "Excluído",
"Updated": "Alterado",
"Started": "Iniciado",
"Stopped": "Parado",
"Restarted": "Reiniciado",
"Downed": "Finalizado",
"Switch to sh": "Mudar para sh",
"terminal": "Terminal",
"CurrentHostname": "(Não definido: seguir o nome do host atual)",
"New Container Name...": "Nome do novo container...",
"Network name...": "Nome da rede...",
"Select a network...": "Selecione uma rede...",
"NoNetworksAvailable": "Nenhuma rede disponível. Você precisa adicionar redes internas ou habilitar redes externas no lado direito primeiro."
} }

View File

@ -101,15 +101,16 @@
"agentAddedSuccessfully": "Agente adicionado com sucesso.", "agentAddedSuccessfully": "Agente adicionado com sucesso.",
"agentRemovedSuccessfully": "Agente removido com sucesso.", "agentRemovedSuccessfully": "Agente removido com sucesso.",
"removeAgent": "Remover Agente", "removeAgent": "Remover Agente",
"downStack": "Parar & Inativar", "downStack": "Parar & Desativar",
"dockgeAgent": "Dockge Agente | Dockge Agentes", "dockgeAgent": "Dockge Agente | Dockge Agentes",
"connect": "Conectar", "connect": "Conectar",
"removeAgentMsg": "Tem certeza de que deseja remover este agente?", "removeAgentMsg": "Tem certeza de que deseja remover este agente?",
"reverseProxyMsg1": "Usando um Proxy Reverso?", "reverseProxyMsg1": "Usando um Proxy Reverso?",
"reverseProxyMsg2": "Verifique para configurá-lo como WebSocket", "reverseProxyMsg2": "Verifique para configurá-lo como WebSocket",
"Cannot connect to the socket server.": "Não é possível se conectar ao servidor socket.", "Cannot connect to the socket server.": "Não é possível se conectar ao servidor socket.",
"url": "URL | URLs", "url": "URL | URL's",
"extra": "Extra", "extra": "Extra",
"reconnecting...": "Reconectando…", "reconnecting...": "Reconectando…",
"connecting...": "Conectando ao servidor de socket…" "connecting...": "Conectando ao servidor de socket…",
"LongSyntaxNotSupported": "Sintaxes longas não são suportadas aqui. Por favor, utilize um editor YAML."
} }

View File

@ -86,11 +86,11 @@
"reverseProxyMsg1": "Folosești un proxy invers?", "reverseProxyMsg1": "Folosești un proxy invers?",
"reverseProxyMsg2": "Verificați cum să-l configurați pentru WebSocket", "reverseProxyMsg2": "Verificați cum să-l configurați pentru WebSocket",
"Cannot connect to the socket server.": "Nu se poate conecta la serverul socket.", "Cannot connect to the socket server.": "Nu se poate conecta la serverul socket.",
"reconnecting...": "Reconectare...", "reconnecting...": "Reconectare",
"connecting...": "Se conectează la serverul socket...", "connecting...": "Se conectează la serverul socket",
"url": "URL | URLs", "url": "URL | URLs",
"extra": "Suplimentar", "extra": "Suplimentar",
"downStack": "Opriți & Coborâți", "downStack": "Opriți & Inactiv",
"saveStackDraft": "Salvați", "saveStackDraft": "Salvați",
"restartPolicyUnlessStopped": "Dacă nu este oprit", "restartPolicyUnlessStopped": "Dacă nu este oprit",
"environmentVariable": "Variabila de mediu | Variabile de mediu", "environmentVariable": "Variabila de mediu | Variabile de mediu",
@ -98,5 +98,35 @@
"Please use this option carefully!": "Vă rugăm să utilizați această opțiune cu atenție!", "Please use this option carefully!": "Vă rugăm să utilizați această opțiune cu atenție!",
"Show update if available": "Afișează actualizarea dacă este disponibilă", "Show update if available": "Afișează actualizarea dacă este disponibilă",
"disableauth.message1": "Sigur doriți să <strong>dezactivați autentificarea</strong>?", "disableauth.message1": "Sigur doriți să <strong>dezactivați autentificarea</strong>?",
"disableauth.message2": "Este conceput pentru scenarii <strong>în care intenționați să implementați autentificarea terță</strong> în fața Dockge-lui, cum ar fi Cloudflare Access, Authelia sau alte mecanisme de autentificare." "disableauth.message2": "Este conceput pentru scenarii <strong>în care intenționați să implementați autentificarea terță</strong> în fața Dockge-lui, cum ar fi Cloudflare Access, Authelia sau alte mecanisme de autentificare.",
"newUpdate": "Actualizare nouă",
"dockgeAgent": "Agent Dockge | Agenții Dockge",
"currentEndpoint": "Actual",
"dockgeURL": "Dockge URL (de ex. http://127.0.0.1:5001)",
"agentOnline": "Online",
"agentOffline": "Offline",
"connecting": "Se conectează",
"addAgent": "Adaugă Agent",
"connect": "Conectează",
"agentRemovedSuccessfully": "Agentul a fost eliminat cu succes.",
"removeAgent": "Șterge Agentul",
"removeAgentMsg": "Ești sigur că vrei să elimini acest agent?",
"LongSyntaxNotSupported": "Sintaxa lungă nu este acceptată aici. Vă rugăm să utilizați editorul YAML.",
"agentAddedSuccessfully": "Agentul a fost adăugat cu succes.",
"Lost connection to the socket server. Reconnecting...": "S-a pierdut conexiunea cu serverul socket. Se reconectează...",
"Saved": "Salvat",
"Deployed": "Lansat",
"Deleted": "Șters",
"Updated": "Actualizat",
"Started": "Pornit",
"Stopped": "Oprit",
"Restarted": "Repornit",
"Downed": "Coborât",
"Switch to sh": "Schimbă la sh",
"terminal": "Terminal",
"CurrentHostname": "(Nesetat: Urmăriți numele de host curent)",
"New Container Name...": "Nume nou de container...",
"Network name...": "Numele rețelei...",
"Select a network...": "Selectați o rețea...",
"NoNetworksAvailable": "Nu există rețele disponibile. Mai întâi trebuie să adăugați rețele interne sau să activați rețele externe în partea dreaptă."
} }

View File

@ -1,8 +1,8 @@
{ {
"languageName": "Русский", "languageName": "Русский",
"Create your admin account": "Создайте учетку администратора", "Create your admin account": "Создайте учетную запись администратора",
"authIncorrectCreds": "Неверный логин или пароль.", "authIncorrectCreds": "Неверный логин или пароль.",
"PasswordsDoNotMatch": "Пароль не совпадает.", "PasswordsDoNotMatch": "Пароли не совпадают.",
"Repeat Password": "Повторите пароль", "Repeat Password": "Повторите пароль",
"Create": "Создать", "Create": "Создать",
"signedInDisp": "Авторизован как {0}", "signedInDisp": "Авторизован как {0}",
@ -10,7 +10,7 @@
"home": "Главная", "home": "Главная",
"console": "Консоль", "console": "Консоль",
"registry": "Реестр (Registry)", "registry": "Реестр (Registry)",
"compose": "Составить (Compose)", "compose": "Compose",
"addFirstStackMsg": "Создайте свой первый стек!", "addFirstStackMsg": "Создайте свой первый стек!",
"stackName": "Имя стека", "stackName": "Имя стека",
"deployStack": "Развернуть", "deployStack": "Развернуть",
@ -24,9 +24,9 @@
"saveStackDraft": "Сохранить", "saveStackDraft": "Сохранить",
"notAvailableShort": "Н/Д", "notAvailableShort": "Н/Д",
"deleteStackMsg": "Вы уверены что хотите удалить этот стек?", "deleteStackMsg": "Вы уверены что хотите удалить этот стек?",
"stackNotManagedByDockgeMsg": "Данный стек не обслуживается Dockge.", "stackNotManagedByDockgeMsg": "Данный стек не управляется Dockge.",
"primaryHostname": "Имя хоста", "primaryHostname": "Имя хоста",
"general": "Главное", "general": "Основные",
"container": "Контейнер | Контейнеры", "container": "Контейнер | Контейнеры",
"scanFolder": "Сканировать папку стеков", "scanFolder": "Сканировать папку стеков",
"dockerImage": "Образ", "dockerImage": "Образ",
@ -43,12 +43,12 @@
"dependsOn": "Зависимость контейнера | Зависимости контейнера", "dependsOn": "Зависимость контейнера | Зависимости контейнера",
"addListItem": "Добавить {0}", "addListItem": "Добавить {0}",
"deleteContainer": "Удалить", "deleteContainer": "Удалить",
"addContainer": "Добавить Контейнер", "addContainer": "Добавить контейнер",
"addNetwork": "Добавить Сеть", "addNetwork": "Добавить сеть",
"disableauth.message1": "Вы уверены что хотите <strong>выключить авторизацию</strong>?", "disableauth.message1": "Вы уверены что хотите <strong>отключить аутентификацию</strong>?",
"disableauth.message2": "Он предназначен для сценариев, <strong>где вы собираетесь реализовать стороннюю аутентификацию</strong> перед Dockge, например Cloudflare Access, Authelia или другие механизмы аутентификации.", "disableauth.message2": "Это предназначено для сценариев, <strong>когда Вы собираетесь использовать стороннюю аутентификацию</strong> перед Dockge, например Cloudflare Access, Authelia или другие механизмы аутентификации.",
"passwordNotMatchMsg": "Повторный пароль не совпадает.", "passwordNotMatchMsg": "Повторный пароль не совпадает.",
"autoGet": "Auto Get", "autoGet": "Авто",
"add": "Добавить", "add": "Добавить",
"Edit": "Изменить", "Edit": "Изменить",
"applyToYAML": "Применить к YAML", "applyToYAML": "Применить к YAML",
@ -62,16 +62,16 @@
"New Password": "Новый пароль", "New Password": "Новый пароль",
"Repeat New Password": "Повторите новый пароль", "Repeat New Password": "Повторите новый пароль",
"Update Password": "Обновить пароль", "Update Password": "Обновить пароль",
"Advanced": "Продвинутые опции", "Advanced": "Расширенные",
"Please use this option carefully!": "Пожалуйста, используйте эту опцию осторожно!", "Please use this option carefully!": "Пожалуйста, используйте эту опцию осторожно!",
"Enable Auth": "Включить аутентификацию", "Enable Auth": "Включить аутентификацию",
"Disable Auth": "Отключить аутентификацию", "Disable Auth": "Отключить аутентификацию",
"I understand, please disable": "Я понимаю, пожалуйста, отключите", "I understand, please disable": "Я понимаю, пожалуйста, отключите",
"Leave": "Покинуть", "Leave": "Покинуть",
"Frontend Version": "Версия внешнего интерфейса", "Frontend Version": "Версия внешнего интерфейса",
"Check Update On GitHub": "Проверьте обновление на GitHub", "Check Update On GitHub": "Проверить обновления на GitHub",
"Show update if available": "Показать обновление, если оно доступно", "Show update if available": "Показать обновление, если оно доступно",
"Also check beta release": "Также проверьте бета-версию", "Also check beta release": "Получать бета-версии",
"Remember me": "Запомнить меня", "Remember me": "Запомнить меня",
"Login": "Логин", "Login": "Логин",
"Username": "Имя пользователя", "Username": "Имя пользователя",
@ -80,10 +80,10 @@
"Logout": "Выйти", "Logout": "Выйти",
"Lowercase only": "Только нижний регистр", "Lowercase only": "Только нижний регистр",
"Convert to Compose": "Преобразовать в Compose", "Convert to Compose": "Преобразовать в Compose",
"Docker Run": "Запустить Docker", "Docker Run": "Docker Run",
"active": "активные", "active": "акт.",
"exited": "остановленные", "exited": "ост.",
"inactive": "неактивных", "inactive": "неакт.",
"Appearance": "Внешний вид", "Appearance": "Внешний вид",
"Security": "Безопасность", "Security": "Безопасность",
"About": "О продукте", "About": "О продукте",
@ -92,24 +92,25 @@
"External Networks": "Внешние сети", "External Networks": "Внешние сети",
"No External Networks": "Нет внешних сетей", "No External Networks": "Нет внешних сетей",
"downStack": "Остановить и деактивировать", "downStack": "Остановить и деактивировать",
"reverseProxyMsg1": "Использовать Реверс Прокси?", "reverseProxyMsg1": "Используете обратный прокси?",
"reconnecting...": "Переподключение…", "reconnecting...": "Переподключение…",
"Cannot connect to the socket server.": "Не удается подключиться к серверу сокетов.", "Cannot connect to the socket server.": "Не удается подключиться к сокет-серверу.",
"url": "URL адрес(а)", "url": "URL-адрес | URL-адреса",
"extra": "Дополнительно", "extra": "Дополнительно",
"reverseProxyMsg2": "Проверьте, как настроить его для WebSocket", "reverseProxyMsg2": "Проверьте, как настроить его для WebSocket",
"connecting...": "Подключение к серверу сокетов…", "connecting...": "Подключение к сокет-серверу…",
"newUpdate": "Доступно обновление", "newUpdate": "Доступно обновление",
"currentEndpoint": "Текущий", "currentEndpoint": "Текущий",
"agentOnline": "В сети", "agentOnline": "В сети",
"agentOffline": "Не в сети", "agentOffline": "Не в сети",
"connecting": "Подключение", "connecting": "Подключение",
"connect": "Подключен", "connect": "Подключить",
"addAgent": "Добавить Агента", "addAgent": "Добавить Агента",
"agentAddedSuccessfully": "Агент добавлен успешно.", "agentAddedSuccessfully": "Агент успешно добавлен.",
"removeAgent": "Удалить Агента", "removeAgent": "Удалить агента",
"removeAgentMsg": "Вы уверены, что хотите удалить этого агента?", "removeAgentMsg": "Вы уверены, что хотите удалить этого агента?",
"dockgeAgent": "Dockge Агент | Dockge Агенты", "dockgeAgent": "Агент Dockge | Агенты Dockge",
"dockgeURL": "Dockge URL (например http://127.0.0.1:5001)", "dockgeURL": "URL-адрес Dockge (например: http://127.0.0.1:5001)",
"agentRemovedSuccessfully": "Агент удален успешно." "agentRemovedSuccessfully": "Агент успешно удален.",
"LongSyntaxNotSupported": "Длинный синтаксис здесь не поддерживается. Пожалуйста, используйте редактор YAML."
} }

View File

@ -91,7 +91,7 @@
"Internal Networks": "Notranja omrežja", "Internal Networks": "Notranja omrežja",
"External Networks": "Zunanja omrežja", "External Networks": "Zunanja omrežja",
"No External Networks": "Ni zunanjih omrežij", "No External Networks": "Ni zunanjih omrežij",
"downStack": "Ustavi & Odstrani", "downStack": "Ustavi & Deaktiviraj",
"connecting...": "Povezovanje s strežnikom…", "connecting...": "Povezovanje s strežnikom…",
"reverseProxyMsg1": "Uporabljate obratni proxy?", "reverseProxyMsg1": "Uporabljate obratni proxy?",
"extra": "Dodatno", "extra": "Dodatno",
@ -99,5 +99,18 @@
"newUpdate": "Nova posodobitev", "newUpdate": "Nova posodobitev",
"reverseProxyMsg2": "Preverite, kako ga konfigurirati za WebSocket", "reverseProxyMsg2": "Preverite, kako ga konfigurirati za WebSocket",
"Cannot connect to the socket server.": "Ni mogoče vzpostaviti povezave s strežnikom vtičnic.", "Cannot connect to the socket server.": "Ni mogoče vzpostaviti povezave s strežnikom vtičnic.",
"url": "URL | URL-ji" "url": "URL | URL-ji",
"currentEndpoint": "Trenutni",
"dockgeURL": "Dockge URL (npr. http://127.0.0.1:5001)",
"agentOnline": "Aktivno",
"agentOffline": "Neaktivno",
"connecting": "Povezujem",
"connect": "Poveži",
"addAgent": "Dodaj agenta",
"dockgeAgent": "Dockge agent | Dockge agenti",
"agentAddedSuccessfully": "Agent dodan uspešno.",
"agentRemovedSuccessfully": "Agent uspešno odstranjen.",
"removeAgent": "Odstrani agent",
"removeAgentMsg": "Ali ste prepričani, da želite odstraniti agenta?",
"LongSyntaxNotSupported": "Long syntax-a ni podprta tukaj. Prosim uporabite YAML urejevalnik."
} }

View File

@ -111,5 +111,22 @@
"removeAgent": "Ta bort agent", "removeAgent": "Ta bort agent",
"removeAgentMsg": "Är du säker att du vill ta bort denna agent?", "removeAgentMsg": "Är du säker att du vill ta bort denna agent?",
"dockgeAgent": "Dockge agenter | Dockge agenter", "dockgeAgent": "Dockge agenter | Dockge agenter",
"agentAddedSuccessfully": "Agent tillagd." "agentAddedSuccessfully": "Agent tillagd.",
"LongSyntaxNotSupported": "Lång syntax stöds inte här. Använd YAML-redigeraren.",
"Lost connection to the socket server. Reconnecting...": "Tappade anslutning till socket-server. Återansluter...",
"Saved": "Sparad",
"Deployed": "Uppsatt",
"Deleted": "Borttagen",
"Updated": "Uppdaterad",
"Started": "Startad",
"Stopped": "Stoppad",
"Restarted": "Omstartad",
"Downed": "Nedstängd",
"Switch to sh": "Byt till sh",
"terminal": "Terminal",
"CurrentHostname": "(Ej angedd: Följ nuvarande värdnamn)",
"New Container Name...": "Nytt kontainernamn...",
"Network name...": "Nätverksnamn...",
"Select a network...": "Välj ett nätverk...",
"NoNetworksAvailable": "Inga nätverk tillgängliga. Du måste lägga till interna nätverk eller aktivera externa nätverk på högra sidan först."
} }

View File

@ -1,17 +1,17 @@
{ {
"languageName": "ไทย", "languageName": "อังกฤษ",
"Create your admin account": "สร้างบัญชีผู้ดูแลระบบของคุณ", "Create your admin account": "สร้างบัญชีผู้ดูแลระบบของคุณ",
"authIncorrectCreds": "ชื่อผู้ใช้หรือรหัสผ่านไม่ถูกต้อง", "authIncorrectCreds": "ชื่อผู้ใช้หรือรหัสผ่านไม่ถูกต้อง",
"PasswordsDoNotMatch": "รหัสผ่านไม่ตรงกัน", "PasswordsDoNotMatch": "รหัสผ่านไม่ตรงกัน",
"Repeat Password": "ยืนยันรหัสผ่าน", "Repeat Password": "ยืนยันรหัสผ่าน",
"Create": "สร้าง", "Create": "สร้าง",
"signedInDisp": "ลงชื่อเข้าใช้ในชื่อ {0}", "signedInDisp": "ลงชื่อเข้าใช้ในนาม {0}",
"signedInDispDisabled": "ปิดใช้งาน Auth", "signedInDispDisabled": "ปิดใช้งาน Auth",
"home": "หน้าหลักe", "home": "หน้าหลัก",
"console": "คอนโซล", "console": "คอนโซล",
"registry": "Registry", "registry": "Registry",
"compose": "Compose", "compose": "Compose",
"addFirstStackMsg": "Compose stack แรกของคุณ", "addFirstStackMsg": "Compose stack แรกของคุณ!",
"stackName": "ชื่อ Stack", "stackName": "ชื่อ Stack",
"deployStack": "ปรับใช้", "deployStack": "ปรับใช้",
"deleteStack": "ลบ", "deleteStack": "ลบ",
@ -19,7 +19,7 @@
"restartStack": "เริ่มใหม่", "restartStack": "เริ่มใหม่",
"updateStack": "อัปเดต", "updateStack": "อัปเดต",
"startStack": "เริ่มต้น", "startStack": "เริ่มต้น",
"downStack": "หยุดและปิด", "downStack": "หยุดการทำงาน",
"editStack": "แก้ไข", "editStack": "แก้ไข",
"discardStack": "ยกเลิก", "discardStack": "ยกเลิก",
"saveStackDraft": "บันทึก", "saveStackDraft": "บันทึก",
@ -98,5 +98,19 @@
"connecting...": "กำลังเชื่อมต่อกับเซิร์ฟเวอร์ socket…", "connecting...": "กำลังเชื่อมต่อกับเซิร์ฟเวอร์ socket…",
"url": "URL | URLs", "url": "URL | URLs",
"extra": "พิเศษ", "extra": "พิเศษ",
"reconnecting...": "กำลังเชื่อมต่อใหม่…" "reconnecting...": "กำลังเชื่อมต่อใหม่…",
"newUpdate": "อัปเดตใหม่",
"dockgeAgent": "เอเย่นต์ Dockge | เอเย่นต์ Dockge",
"currentEndpoint": "ปัจุบัน",
"agentOnline": "ออนไลน์",
"agentOffline": "ออฟไลน์",
"connecting": "กำลังเชื่อมต่อ",
"connect": "เชื่อมต่อ",
"addAgent": "เพิ่มเอเย่นต์",
"agentAddedSuccessfully": "เพิ่มเอเย่นต์สำเร็จ",
"agentRemovedSuccessfully": "ลบเอเย่นต์สำเร็จ",
"removeAgent": "ลบเอเย่นต์",
"removeAgentMsg": "คุณแน่ใจหรือไม่ที่จะลบเอเย่นต์นี้?",
"dockgeURL": "ลิ้งก์ Dockge (เช่น http://127.0.0.1:5001)",
"LongSyntaxNotSupported": "Syntax แบบยาสไม่รองรับที่นี่ กรุณาใช้ตัวแก้ไข YAML"
} }

View File

@ -111,5 +111,22 @@
"agentAddedSuccessfully": "Aracı başarıyla eklendi.", "agentAddedSuccessfully": "Aracı başarıyla eklendi.",
"agentRemovedSuccessfully": "Aracı başarıyla kaldırıldı.", "agentRemovedSuccessfully": "Aracı başarıyla kaldırıldı.",
"removeAgent": "Aracıyı Kaldır", "removeAgent": "Aracıyı Kaldır",
"removeAgentMsg": "Bu aracıyı kaldırmak istediğinize emin misiniz?" "removeAgentMsg": "Bu aracıyı kaldırmak istediğinize emin misiniz?",
"LongSyntaxNotSupported": "Uzun syntax burada desteklenmiyor. Lütfen YAML editörünü kullanın.",
"Lost connection to the socket server. Reconnecting...": "Soket sunucusuna bağlantı kesildi. Yeniden bağlanılıyor...",
"NoNetworksAvailable": "Kullanılabilir ağ yok. Önce dahili ağları eklemeniz veya sağ tarafta harici ağları etkinleştirmeniz gerekir.",
"Saved": "Kayıtlı",
"Deployed": "Deploy Edildi",
"Deleted": "Silindi",
"Updated": "Güncellendi",
"Started": "Başladı",
"Stopped": "Durdu",
"Restarted": "Yeniden başlatıldı",
"Downed": "Düştü",
"Switch to sh": "sh'ye çevir",
"terminal": "Terminal",
"CurrentHostname": "(Ayarlanmamış: Mevcut hostname'i takip et)",
"New Container Name...": "Yeni Konteyner Adı...",
"Network name...": "Ağ adı...",
"Select a network...": "Bir ağ seçin..."
} }

View File

@ -80,7 +80,7 @@
"Logout": "Вийти", "Logout": "Вийти",
"Lowercase only": "Тільки нижній регістр", "Lowercase only": "Тільки нижній регістр",
"Convert to Compose": "Конвертувати в Compose", "Convert to Compose": "Конвертувати в Compose",
"Docker Run": "Запустити Docker", "Docker Run": "Docker Run",
"active": "активно", "active": "активно",
"exited": "завершено", "exited": "завершено",
"inactive": "неактивно", "inactive": "неактивно",
@ -111,5 +111,22 @@
"dockgeURL": "Dockge URL (напр. http://127.0.0.1:5001)", "dockgeURL": "Dockge URL (напр. http://127.0.0.1:5001)",
"agentRemovedSuccessfully": "Агент успішно видалено.", "agentRemovedSuccessfully": "Агент успішно видалено.",
"agentAddedSuccessfully": "Агент успішно додано.", "agentAddedSuccessfully": "Агент успішно додано.",
"removeAgentMsg": "Ви впевнені, що хочете видалити цей агент?" "removeAgentMsg": "Ви впевнені, що хочете видалити цей агент?",
"LongSyntaxNotSupported": "Довгий синтаксис тут не підтримується. Будь ласка, використовуйте редактор YAML.",
"Saved": "Збережено",
"Deployed": "Розгорнуто",
"Deleted": "Видалено",
"Updated": "Оновлено",
"Started": "Запущено",
"Stopped": "Зупинено",
"Downed": "Вимкнено",
"Switch to sh": "Перемкнути на sh",
"terminal": "Термінал",
"New Container Name...": "Нова назва контейнера...",
"Network name...": "Назва мережі...",
"Select a network...": "Вибрати мережу...",
"Lost connection to the socket server. Reconnecting...": "Втрачено зв'язок з сервером сокетів. Повторне підключення...",
"Restarted": "Перезапущено",
"CurrentHostname": "(Не встановлено: використовувати поточну назву хосту)",
"NoNetworksAvailable": "Немає доступних мереж. Спочатку потрібно додати внутрішні мережі або увімкнути зовнішні мережі в правій частині."
} }

View File

@ -97,6 +97,20 @@
"connecting...": "ساکٹ سرور سے منسلک ہو رہا ہے…", "connecting...": "ساکٹ سرور سے منسلک ہو رہا ہے…",
"url": "یو آر ایل | یو آر ایل", "url": "یو آر ایل | یو آر ایل",
"extra": "اضافی", "extra": "اضافی",
"downStack": "اسٹاپ اینڈ ڈاؤن", "downStack": "روکیں اور غیر فعال",
"reverseProxyMsg2": "اسے WebSocket کے لیے ترتیب دینے کا طریقہ چیک کریں" "reverseProxyMsg2": "اسے WebSocket کے لیے ترتیب دینے کا طریقہ چیک کریں",
"newUpdate": "نئی تازہ کاری",
"dockgeAgent": "ڈاکج ایجنٹ | ڈاکج ایجنٹس",
"currentEndpoint": "کرنٹ",
"dockgeURL": "Dockge URL (جیسے http://127.0.0.1:5001)",
"agentOnline": "آن لائن",
"agentOffline": "آف لائن",
"connecting": "جڑ رہا ہے",
"connect": "جڑیں",
"addAgent": "ایجنٹ شامل کریں",
"agentAddedSuccessfully": "ایجنٹ کامیابی کے ساتھ شامل ہو گیا۔",
"agentRemovedSuccessfully": "ایجنٹ کو کامیابی سے ہٹا دیا گیا۔",
"removeAgent": "ایجنٹ کو ہٹا دیں",
"removeAgentMsg": "کیا آپ واقعی اس ایجنٹ کو ہٹانا چاہتے ہیں؟",
"LongSyntaxNotSupported": "لمبا نحو یہاں تعاون یافتہ نہیں ہے۔ براہ کرم YAML ایڈیٹر استعمال کریں۔"
} }

View File

@ -111,5 +111,22 @@
"agentRemovedSuccessfully": "代理移除成功。", "agentRemovedSuccessfully": "代理移除成功。",
"removeAgent": "移除代理", "removeAgent": "移除代理",
"removeAgentMsg": "您确定要移除此代理?", "removeAgentMsg": "您确定要移除此代理?",
"agentAddedSuccessfully": "代理添加成功。" "agentAddedSuccessfully": "代理添加成功。",
"LongSyntaxNotSupported": "此处不支持Long syntax请使用YAML编辑器。",
"Lost connection to the socket server. Reconnecting...": "已断开socket服务器连接重新连接中...",
"Saved": "已保存",
"Deployed": "已部署",
"Deleted": "已删除",
"Updated": "已更新",
"Started": "已启动",
"Stopped": "已停止",
"Restarted": "已重启",
"Switch to sh": "切换至sh",
"terminal": "终端",
"CurrentHostname": "未设置:沿用当前主机名",
"New Container Name...": "新的容器名称...",
"Network name...": "网络名称...",
"Select a network...": "选择网络...",
"NoNetworksAvailable": "网络不可用.你需要在正确的方向先添加内部网络或者启用外部网络.",
"Downed": "已宕机"
} }

View File

@ -10,7 +10,7 @@
"home": "首頁", "home": "首頁",
"console": "主控台", "console": "主控台",
"registry": "映像倉庫", "registry": "映像倉庫",
"compose": "Compose", "compose": "撰寫",
"addFirstStackMsg": "組合您的第一個堆疊!", "addFirstStackMsg": "組合您的第一個堆疊!",
"stackName": "堆疊名稱", "stackName": "堆疊名稱",
"deployStack": "部署", "deployStack": "部署",
@ -20,7 +20,7 @@
"updateStack": "更新", "updateStack": "更新",
"startStack": "啟動", "startStack": "啟動",
"editStack": "編輯", "editStack": "編輯",
"discardStack": "棄", "discardStack": "棄",
"saveStackDraft": "儲存", "saveStackDraft": "儲存",
"notAvailableShort": "不可用", "notAvailableShort": "不可用",
"deleteStackMsg": "您確定要刪除這個堆疊嗎?", "deleteStackMsg": "您確定要刪除這個堆疊嗎?",
@ -46,7 +46,7 @@
"addContainer": "新增容器", "addContainer": "新增容器",
"addNetwork": "新增網路", "addNetwork": "新增網路",
"disableauth.message1": "您確定要<strong>停用身份驗證</strong>嗎?", "disableauth.message1": "您確定要<strong>停用身份驗證</strong>嗎?",
"disableauth.message2": "該選項設計用於某些場景,<strong>例如在 Dockge 之上接入第三方認證</strong>,如 Cloudflare Access、Authelia 或其他證機制。如果您不清楚這個選項的作用,請不要停用驗證!", "disableauth.message2": "該選項設計用於某些場景,<strong>例如在 Dockge 之介接接第三方身份驗證</strong>如 Cloudflare Access、Authelia 或其他身份驗證機制。",
"passwordNotMatchMsg": "兩次輸入的密碼不一致。", "passwordNotMatchMsg": "兩次輸入的密碼不一致。",
"autoGet": "自動取得", "autoGet": "自動取得",
"add": "新增", "add": "新增",
@ -100,5 +100,33 @@
"url": "網址 | 網址", "url": "網址 | 網址",
"extra": "額外", "extra": "額外",
"newUpdate": "新版本", "newUpdate": "新版本",
"currentEndpoint": "目前" "currentEndpoint": "目前",
"dockgeURL": "Dockge URL例如http://127.0.0.1:5001",
"agentOnline": "線上",
"connecting": "正在連線",
"agentOffline": "離線",
"Lost connection to the socket server. Reconnecting...": "與伺服器斷線。正在重新連線...",
"dockgeAgent": "Dockge代理 | Dockge代理",
"Saved": "已儲存",
"Switch to sh": "切換到 sh",
"NoNetworksAvailable": "沒有可以使用的網路。您需要先在右側新增內部網路或啟用外部網路。",
"LongSyntaxNotSupported": "這裡不支援長語法。請使用 YAML 編輯器。",
"connect": "連接",
"addAgent": "新增代理",
"agentAddedSuccessfully": "代理新增成功。",
"agentRemovedSuccessfully": "代理刪除成功。",
"Deployed": "已佈署",
"Deleted": "已刪除",
"Updated": "已更新",
"Started": "開始",
"Stopped": "已停止",
"Restarted": "重新啟動",
"Downed": "斷線",
"terminal": "終端",
"CurrentHostname": "(取消設定:依據目前主機名稱)",
"New Container Name...": "新容器名稱...",
"Network name...": "網路名稱...",
"Select a network...": "選擇網路...",
"removeAgent": "刪除代理",
"removeAgentMsg": "您確定要刪除這個代理嗎?"
} }

View File

@ -203,7 +203,7 @@ export default defineComponent({
socket.on("disconnect", () => { socket.on("disconnect", () => {
console.log("disconnect"); console.log("disconnect");
this.socketIO.connectionErrorMsg = "Lost connection to the socket server. Reconnecting..."; this.socketIO.connectionErrorMsg = `${this.$t("Lost connection to the socket server. Reconnecting...")}`;
this.socketIO.connected = false; this.socketIO.connected = false;
}); });
@ -279,7 +279,6 @@ export default defineComponent({
}); });
socket.on("agentList", (res) => { socket.on("agentList", (res) => {
console.log(res);
if (res.ok) { if (res.ok) {
this.agentList = res.agentList; this.agentList = res.agentList;
} }

View File

@ -1,7 +1,7 @@
<template> <template>
<transition name="slide-fade" appear> <transition name="slide-fade" appear>
<div> <div>
<h1 v-if="isAdd" class="mb-3">Compose</h1> <h1 v-if="isAdd" class="mb-3">{{$t("compose")}}</h1>
<h1 v-else class="mb-3"> <h1 v-else class="mb-3">
<Uptime :stack="globalStack" :pill="true" /> {{ stack.name }} <Uptime :stack="globalStack" :pill="true" /> {{ stack.name }}
<span v-if="$root.agentCount > 1" class="agent-name"> <span v-if="$root.agentCount > 1" class="agent-name">
@ -112,7 +112,7 @@
<div v-if="isEditMode" class="input-group mb-3"> <div v-if="isEditMode" class="input-group mb-3">
<input <input
v-model="newContainerName" v-model="newContainerName"
placeholder="New Container Name..." :placeholder="$t(`New Container Name...`)"
class="form-control" class="form-control"
@keyup.enter="addContainer" @keyup.enter="addContainer"
/> />
@ -150,7 +150,7 @@
<!-- Combined Terminal Output --> <!-- Combined Terminal Output -->
<div v-show="!isEditMode"> <div v-show="!isEditMode">
<h4 class="mb-3">Terminal</h4> <h4 class="mb-3">{{$t("terminal")}}</h4>
<Terminal <Terminal
ref="combinedTerminal" ref="combinedTerminal"
class="mb-3 terminal" class="mb-3 terminal"
@ -158,7 +158,7 @@
:endpoint="endpoint" :endpoint="endpoint"
:rows="combinedTerminalRows" :rows="combinedTerminalRows"
:cols="combinedTerminalCols" :cols="combinedTerminalCols"
style="height: 350px;" style="height: 315px;"
></Terminal> ></Terminal>
</div> </div>
</div> </div>
@ -258,7 +258,7 @@ import { BModal } from "bootstrap-vue-next";
import NetworkInput from "../components/NetworkInput.vue"; import NetworkInput from "../components/NetworkInput.vue";
import dotenv from "dotenv"; import dotenv from "dotenv";
const template = `version: "3.8" const template = `
services: services:
nginx: nginx:
image: nginx:latest image: nginx:latest

View File

@ -1,35 +1,36 @@
<template> <template>
<transition name="slide-fade" appear> <transition name="slide-fade" appear>
<div> <div v-if="!processing">
<h1 class="mb-3">Console</h1> <h1 class="mb-3">Console</h1>
<div> <Terminal v-if="enableConsole" class="terminal" :rows="20" mode="mainTerminal" name="console" :endpoint="endpoint"></Terminal>
<p>
{{ $t("Allowed commands:") }}
<template v-for="(command, index) in allowedCommandList" :key="command">
<code>{{ command }}</code>
<!-- No comma at the end --> <div v-else class="alert alert-warning shadow-box" role="alert">
<span v-if="index !== allowedCommandList.length - 1">, </span> <h4 class="alert-heading">Console is not enabled</h4>
</template> <p>
Console is a powerful tool that allows you to execute any commands such as <code>docker</code>, <code>rm</code> within the Dockge's container in this Web UI.
</p>
<p>
It might be dangerous since this Dockge container is connecting to the host's Docker daemon. Also Dockge could be possibly taken down by commands like <code>rm -rf</code>.
</p>
<p>
If you understand the risk, you can enable it by setting <code>DOCKGE_ENABLE_CONSOLE=true</code> in the environment variables.
</p> </p>
</div> </div>
<Terminal class="terminal" :rows="20" mode="mainTerminal" name="console" :endpoint="endpoint"></Terminal>
</div> </div>
</transition> </transition>
</template> </template>
<script> <script>
import { allowedCommandList } from "../../../common/util-common";
export default { export default {
components: { components: {
}, },
data() { data() {
return { return {
allowedCommandList, processing: true,
enableConsole: false,
}; };
}, },
computed: { computed: {
@ -38,7 +39,10 @@ export default {
}, },
}, },
mounted() { mounted() {
this.$root.emitAgent(this.endpoint, "checkMainTerminal", (res) => {
this.enableConsole = res.ok;
this.processing = false;
});
}, },
methods: { methods: {

View File

@ -1,10 +1,10 @@
<template> <template>
<transition name="slide-fade" appear> <transition name="slide-fade" appear>
<div> <div>
<h1 class="mb-3">Terminal - {{ serviceName }} ({{ stackName }})</h1> <h1 class="mb-3">{{$t("terminal")}} - {{ serviceName }} ({{ stackName }})</h1>
<div class="mb-3"> <div class="mb-3">
<router-link :to="sh" class="btn btn-normal me-2">Switch to sh</router-link> <router-link :to="sh" class="btn btn-normal me-2">{{ $t("Switch to sh") }}</router-link>
</div> </div>
<Terminal class="terminal" :rows="20" mode="interactive" :name="terminalName" :stack-name="stackName" :service-name="serviceName" :shell="shell" :endpoint="endpoint"></Terminal> <Terminal class="terminal" :rows="20" mode="interactive" :name="terminalName" :stack-name="stackName" :service-name="serviceName" :shell="shell" :endpoint="endpoint"></Terminal>

View File

@ -656,13 +656,6 @@ $shadow-box-padding: 20px;
} }
} }
.main-terminal {
.xterm-viewport {
border-radius: 10px;
background-color: $dark-bg !important;
}
}
code { code {
padding: .2em .4em; padding: .2em .4em;
margin: 0; margin: 0;

10520
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,25 +1,25 @@
{ {
"name": "dockge", "name": "dockge",
"version": "1.4.0", "version": "1.4.2",
"type": "module", "type": "module",
"engines": { "engines": {
"node": ">= 18.0.0 && <= 18.17.1" "node": ">= 22.14.0"
}, },
"scripts": { "scripts": {
"fmt": "eslint \"**/*.{ts,vue}\" --fix", "fmt": "eslint \"**/*.{ts,vue}\" --fix",
"lint": "eslint \"**/*.{ts,vue}\"", "lint": "eslint \"**/*.{ts,vue}\"",
"check-ts": "tsc --noEmit", "check-ts": "tsc --noEmit",
"start": "tsx ./backend/index.ts", "start": "tsx ./backend/index.ts",
"dev": "concurrently -k -r \"wait-on tcp:5000 && pnpm run dev:backend \" \"pnpm run dev:frontend\"", "dev": "concurrently -k -r \"wait-on tcp:5000 && npm run dev:backend \" \"npm run dev:frontend\"",
"dev:backend": "cross-env NODE_ENV=development tsx watch --inspect ./backend/index.ts", "dev:backend": "cross-env NODE_ENV=development tsx watch --inspect ./backend/index.ts",
"dev:frontend": "cross-env NODE_ENV=development vite --host --config ./frontend/vite.config.ts", "dev:frontend": "cross-env NODE_ENV=development vite --host --config ./frontend/vite.config.ts",
"release-final": "tsx ./extra/test-docker.ts && tsx extra/update-version.ts && pnpm run build:frontend && npm run build:docker", "release-final": "tsx ./extra/test-docker.ts && tsx extra/update-version.ts && npm run build:frontend && npm run build:docker",
"release-beta": "tsx ./extra/test-docker.ts && tsx extra/update-version.ts && pnpm run build:frontend && npm run build:docker-beta", "release-beta": "tsx ./extra/test-docker.ts && tsx extra/update-version.ts && npm run build:frontend && npm run build:docker-beta",
"build:frontend": "vite build --config ./frontend/vite.config.ts", "build:frontend": "vite build --config ./frontend/vite.config.ts",
"build:docker-base": "docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:base -f ./docker/Base.Dockerfile . --push", "build:docker-base": "docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:base -f ./docker/Base.Dockerfile . --push",
"build:docker": "node ./extra/env2arg.js docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:latest -t louislam/dockge:1 -t louislam/dockge:$VERSION -t louislam/dockge:beta -t louislam/dockge:nightly --target release -f ./docker/Dockerfile . --push", "build:docker": "node ./extra/env2arg.js docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:latest -t louislam/dockge:1 -t louislam/dockge:$VERSION -t louislam/dockge:beta -t louislam/dockge:nightly --target release -f ./docker/Dockerfile . --push",
"build:docker-beta": "node ./extra/env2arg.js docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:beta -t louislam/dockge:$VERSION --target release -f ./docker/Dockerfile . --push", "build:docker-beta": "node ./extra/env2arg.js docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:beta -t louislam/dockge:$VERSION --target release -f ./docker/Dockerfile . --push",
"build:docker-nightly": "pnpm run build:frontend && docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:nightly --target nightly -f ./docker/Dockerfile . --push", "build:docker-nightly": "npm run build:frontend && docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:nightly --target nightly -f ./docker/Dockerfile . --push",
"build:healthcheck": "docker buildx build -f docker/BuildHealthCheck.Dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:build-healthcheck . --push", "build:healthcheck": "docker buildx build -f docker/BuildHealthCheck.Dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/dockge:build-healthcheck . --push",
"start-docker": "docker run --rm -p 5001:5001 --name dockge louislam/dockge:latest", "start-docker": "docker run --rm -p 5001:5001 --name dockge louislam/dockge:latest",
"mark-as-nightly": "tsx ./extra/mark-as-nightly.ts", "mark-as-nightly": "tsx ./extra/mark-as-nightly.ts",
@ -27,39 +27,39 @@
"reset-password": "tsx ./extra/reset-password.ts" "reset-password": "tsx ./extra/reset-password.ts"
}, },
"dependencies": { "dependencies": {
"@homebridge/node-pty-prebuilt-multiarch": "~0.11.12", "@homebridge/node-pty-prebuilt-multiarch": "0.11.14",
"@inventage/envsubst": "^0.16.0", "@inventage/envsubst": "^0.16.0",
"@louislam/sqlite3": "~15.1.6", "@louislam/sqlite3": "~15.1.6",
"bcryptjs": "~2.4.3", "bcryptjs": "~2.4.3",
"check-password-strength": "~2.0.7", "check-password-strength": "~2.0.10",
"command-exists": "~1.2.9", "command-exists": "~1.2.9",
"compare-versions": "~6.1.0", "compare-versions": "~6.1.1",
"composerize": "~1.4.1", "composerize": "~1.7.1",
"croner": "~7.0.5", "croner": "~8.1.2",
"dayjs": "~1.11.10", "dayjs": "~1.11.13",
"dotenv": "~16.3.1", "dotenv": "~16.3.2",
"express": "~4.18.2", "express": "~4.21.2",
"express-static-gzip": "~2.1.7", "express-static-gzip": "~2.1.8",
"http-graceful-shutdown": "~3.1.13", "http-graceful-shutdown": "~3.1.14",
"jsonwebtoken": "~9.0.2", "jsonwebtoken": "~9.0.2",
"jwt-decode": "~3.1.2", "jwt-decode": "~3.1.2",
"knex": "~2.5.1", "knex": "~2.5.1",
"limiter-es6-compat": "~2.1.2", "limiter-es6-compat": "~2.1.2",
"mysql2": "~3.6.5", "mysql2": "~3.12.0",
"promisify-child-process": "~4.1.2", "promisify-child-process": "~4.1.2",
"redbean-node": "~0.3.3", "redbean-node": "~0.3.3",
"semver": "^7.5.4", "semver": "^7.7.1",
"socket.io": "~4.7.2", "socket.io": "~4.8.1",
"socket.io-client": "~4.7.2", "socket.io-client": "~4.8.1",
"timezones-list": "~3.0.2", "timezones-list": "~3.0.3",
"ts-command-line-args": "~2.5.1", "ts-command-line-args": "~2.5.1",
"tsx": "~4.6.2", "tsx": "~4.19.3",
"type-fest": "~4.3.3", "type-fest": "~4.3.3",
"yaml": "~2.3.4" "yaml": "~2.3.4"
}, },
"devDependencies": { "devDependencies": {
"@actions/github": "^6.0.0", "@actions/github": "^6.0.0",
"@fontsource/jetbrains-mono": "^5.0.18", "@fontsource/jetbrains-mono": "^5.2.5",
"@fortawesome/fontawesome-svg-core": "6.4.2", "@fortawesome/fontawesome-svg-core": "6.4.2",
"@fortawesome/free-regular-svg-icons": "6.4.2", "@fortawesome/free-regular-svg-icons": "6.4.2",
"@fortawesome/free-solid-svg-icons": "6.4.2", "@fortawesome/free-solid-svg-icons": "6.4.2",
@ -68,11 +68,11 @@
"@types/bootstrap": "~5.2.10", "@types/bootstrap": "~5.2.10",
"@types/command-exists": "~1.2.3", "@types/command-exists": "~1.2.3",
"@types/express": "~4.17.21", "@types/express": "~4.17.21",
"@types/jsonwebtoken": "~9.0.5", "@types/jsonwebtoken": "~9.0.9",
"@types/semver": "^7.5.6", "@types/semver": "^7.7.0",
"@typescript-eslint/eslint-plugin": "~6.8.0", "@typescript-eslint/eslint-plugin": "~6.8.0",
"@typescript-eslint/parser": "~6.8.0", "@typescript-eslint/parser": "~6.8.0",
"@vitejs/plugin-vue": "~4.5.2", "@vitejs/plugin-vue": "~5.2.3",
"@xterm/addon-fit": "beta", "@xterm/addon-fit": "beta",
"@xterm/xterm": "beta", "@xterm/xterm": "beta",
"bootstrap": "5.3.2", "bootstrap": "5.3.2",
@ -81,19 +81,19 @@
"cross-env": "~7.0.3", "cross-env": "~7.0.3",
"eslint": "~8.50.0", "eslint": "~8.50.0",
"eslint-plugin-jsdoc": "~46.8.2", "eslint-plugin-jsdoc": "~46.8.2",
"eslint-plugin-vue": "~9.17.0", "eslint-plugin-vue": "~9.32.0",
"prismjs": "~1.29.0", "prismjs": "~1.30.0",
"sass": "~1.68.0", "sass": "~1.68.0",
"typescript": "~5.2.2", "typescript": "~5.2.2",
"unplugin-vue-components": "~0.25.2", "unplugin-vue-components": "~0.25.2",
"vite": "~5.0.10", "vite": "~5.4.15",
"vite-plugin-compression": "~0.5.1", "vite-plugin-compression": "~0.5.1",
"vue": "~3.3.13", "vue": "~3.5.13",
"vue-eslint-parser": "~9.3.2", "vue-eslint-parser": "~9.3.2",
"vue-i18n": "~9.5.0", "vue-i18n": "~10.0.6",
"vue-prism-editor": "2.0.0-alpha.2", "vue-prism-editor": "2.0.0-alpha.2",
"vue-qrcode": "~2.2.0", "vue-qrcode": "~2.2.2",
"vue-router": "~4.2.5", "vue-router": "~4.5.0",
"vue-toastification": "2.0.0-rc.5", "vue-toastification": "2.0.0-rc.5",
"wait-on": "^7.2.0", "wait-on": "^7.2.0",
"xterm-addon-web-links": "~0.9.0" "xterm-addon-web-links": "~0.9.0"

5649
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff