mirror of
https://github.com/louislam/dockge.git
synced 2025-03-13 04:44:46 +00:00
Compare commits
7 commits
db8b768b37
...
f63718b1d4
Author | SHA1 | Date | |
---|---|---|---|
|
f63718b1d4 | ||
|
a65a9f5549 | ||
|
9b73e44cd9 | ||
|
81818a19d1 | ||
|
1372bd2ce1 | ||
|
673fb8f8dd | ||
|
52ea324129 |
7 changed files with 1124 additions and 874 deletions
|
@ -294,11 +294,14 @@ export class MainTerminal extends InteractiveTerminal {
|
||||||
// Check if the command is allowed
|
// Check if the command is allowed
|
||||||
const cmdParts = input.split(" ");
|
const cmdParts = input.split(" ");
|
||||||
const executable = cmdParts[0].trim();
|
const executable = cmdParts[0].trim();
|
||||||
|
const knownOperators = ["||", "&", ";"];
|
||||||
log.debug("console", "Executable: " + executable);
|
log.debug("console", "Executable: " + executable);
|
||||||
log.debug("console", "Executable length: " + executable.length);
|
log.debug("console", "Executable length: " + executable.length);
|
||||||
|
|
||||||
if (!allowedCommandList.includes(executable)) {
|
if (!allowedCommandList.includes(executable)) {
|
||||||
throw new Error("Command not allowed.");
|
throw new Error("Command not allowed.");
|
||||||
|
} else if (knownOperators.some(operator => input.includes(operator))) {
|
||||||
|
throw new Error("Control operators are not allowed.");
|
||||||
}
|
}
|
||||||
super.write(input);
|
super.write(input);
|
||||||
}
|
}
|
||||||
|
|
|
@ -236,8 +236,7 @@ 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) {
|
||||||
|
@ -245,16 +244,23 @@ function copyYAMLCommentsItems(items : any, srcItems : any) {
|
||||||
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;
|
||||||
|
@ -265,6 +271,20 @@ function copyYAMLCommentsItems(items : any, srcItems : any) {
|
||||||
item.comment = srcItem.comment;
|
item.comment = srcItem.comment;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Handle comments between array items
|
||||||
|
if (nextSrcItem && nextSrcItem.commentBefore) {
|
||||||
|
if (items[i + 1]) {
|
||||||
|
items[i + 1].commentBefore = nextSrcItem.commentBefore;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle trailing comments after array items
|
||||||
|
if (srcItem.value && srcItem.value.comment) {
|
||||||
|
if (item.value) {
|
||||||
|
item.value.comment = srcItem.value.comment;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (item.value && srcItem.value) {
|
if (item.value && srcItem.value) {
|
||||||
if (typeof item.value === "object" && typeof srcItem.value === "object") {
|
if (typeof item.value === "object" && typeof srcItem.value === "object") {
|
||||||
item.value.comment = srcItem.value.comment;
|
item.value.comment = srcItem.value.comment;
|
||||||
|
@ -277,6 +297,7 @@ function copyYAMLCommentsItems(items : any, srcItems : any) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Possible Inputs:
|
* Possible Inputs:
|
||||||
|
|
|
@ -33,7 +33,7 @@ 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
|
||||||
ENTRYPOINT ["/usr/bin/dumb-init", "--"]
|
ENTRYPOINT ["/usr/bin/dumb-init", "--"]
|
||||||
CMD ["bash", "-c", "node ./extra/clean-tsx-tmp.js && tsx ./backend/index.ts"]
|
CMD ["tsx", "./backend/index.ts"]
|
||||||
|
|
||||||
############################################
|
############################################
|
||||||
# Mark as Nightly
|
# Mark as Nightly
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
/*
|
|
||||||
* This script is used to clean up the tmp directory.
|
|
||||||
* A workaround for https://github.com/louislam/dockge/issues/353
|
|
||||||
*/
|
|
||||||
import * as fs from "fs";
|
|
||||||
|
|
||||||
try {
|
|
||||||
fs.rmSync("/tmp/tsx-0", {
|
|
||||||
recursive: true,
|
|
||||||
});
|
|
||||||
} catch (e) {
|
|
||||||
|
|
||||||
}
|
|
|
@ -247,7 +247,6 @@ export default {
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.main-terminal {
|
.main-terminal {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
overflow-x: scroll;
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
|
|
@ -38,14 +38,14 @@
|
||||||
"croner": "~8.1.2",
|
"croner": "~8.1.2",
|
||||||
"dayjs": "~1.11.13",
|
"dayjs": "~1.11.13",
|
||||||
"dotenv": "~16.3.2",
|
"dotenv": "~16.3.2",
|
||||||
"express": "~4.21.1",
|
"express": "~4.21.2",
|
||||||
"express-static-gzip": "~2.1.8",
|
"express-static-gzip": "~2.1.8",
|
||||||
"http-graceful-shutdown": "~3.1.13",
|
"http-graceful-shutdown": "~3.1.13",
|
||||||
"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.11.3",
|
"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.6.3",
|
"semver": "^7.6.3",
|
||||||
|
@ -53,7 +53,7 @@
|
||||||
"socket.io-client": "~4.8.0",
|
"socket.io-client": "~4.8.0",
|
||||||
"timezones-list": "~3.0.3",
|
"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.2",
|
||||||
"type-fest": "~4.3.3",
|
"type-fest": "~4.3.3",
|
||||||
"yaml": "~2.3.4"
|
"yaml": "~2.3.4"
|
||||||
},
|
},
|
||||||
|
|
1910
pnpm-lock.yaml
generated
1910
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load diff
Loading…
Add table
Reference in a new issue