diff --git a/configs/config-demo.json b/configs/config-demo.json
index 272dcc3..a4a8b62 100644
--- a/configs/config-demo.json
+++ b/configs/config-demo.json
@@ -1,5 +1,5 @@
{
- "addr": "127.0.0.1:8080",
+ "addr": "0.0.0.0:8080",
"db-driver": "mysql",
"embed-static-files": false,
"static-files": "./web/frontend/public/",
diff --git a/internal/repository/migrations/mysql/01_init-schema.down.sql b/internal/repository/migrations/mysql/01_init-schema.down.sql
index 6627bf3..6cebe7e 100644
--- a/internal/repository/migrations/mysql/01_init-schema.down.sql
+++ b/internal/repository/migrations/mysql/01_init-schema.down.sql
@@ -13,4 +13,5 @@ DROP TABLE IF EXISTS volume_groups;
DROP TABLE IF EXISTS physical_volumes;
DROP TABLE IF EXISTS lvm_storage_issuer;
DROP TABLE IF EXISTS machine_conf;
+DROP TABLE IF EXISTS file_stash_url ;
diff --git a/internal/repository/migrations/mysql/01_init-schema.up.sql b/internal/repository/migrations/mysql/01_init-schema.up.sql
index 84d1527..9b31e24 100644
--- a/internal/repository/migrations/mysql/01_init-schema.up.sql
+++ b/internal/repository/migrations/mysql/01_init-schema.up.sql
@@ -167,3 +167,9 @@ CREATE TABLE IF NOT EXISTS machine_conf (
folder_path VARCHAR(255) ,
FOREIGN KEY (machine_serial_number) REFERENCES machines(machine_id)
);
+
+
+CREATE TABLE IF NOT EXISTS file_stash_url (
+ id INT AUTO_INCREMENT PRIMARY KEY,
+ url VARCHAR(255) NOT NULL
+);
\ No newline at end of file
diff --git a/internal/routerConfig/routes.go b/internal/routerConfig/routes.go
index 5fef63c..ac70794 100644
--- a/internal/routerConfig/routes.go
+++ b/internal/routerConfig/routes.go
@@ -45,7 +45,10 @@ var routes []Route = []Route{
{"/monitoring/node/{cluster}/{hostname}", "monitoring/node.tmpl", "Node - ClusterCockpit", false, setupNodeRoute},
{"/monitoring/analysis/{cluster}", "monitoring/analysis.tmpl", "Analysis - ClusterCockpit", true, setupAnalysisRoute},
{"/monitoring/status/{cluster}", "monitoring/status.tmpl", "Status of - ClusterCockpit", false, setupClusterRoute},
- {"/partitions/systems/{cluster}", "partitions/systems.tmpl", "Cluster - ClusterCockpit", false, setupClusterRoute},
+ {"/monitoring/partition/{cluster}", "partitions/systems.tmpl", "Cluster - ClusterCockpit", false, setupClusterRoute},
+ {"/monitoring/history/", "monitoring/history.tmpl", "Cluster - ClusterCockpit", false, setupClusterRoute},
+
+
}
diff --git a/web/frontend/package.json b/web/frontend/package.json
index cc84e1a..d516c8b 100644
--- a/web/frontend/package.json
+++ b/web/frontend/package.json
@@ -13,11 +13,13 @@
"@timohausmann/quadtree-js": "^1.2.5",
"rollup": "^3.21.0",
"rollup-plugin-css-only": "^4.3.0",
+ "rollup-plugin-livereload": "^2.0.5",
"rollup-plugin-svelte": "^7.1.4",
"svelte": "^3.58.0"
},
"dependencies": {
"@rollup/plugin-replace": "^5.0.2",
+ "@tanstack/svelte-table": "^8.12.0",
"@urql/svelte": "^4.0.1",
"chart.js": "^4.3.3",
"date-fns": "^2.30.0",
diff --git a/web/frontend/pnpm-lock.yaml b/web/frontend/pnpm-lock.yaml
index 9c52af8..7b618c2 100644
--- a/web/frontend/pnpm-lock.yaml
+++ b/web/frontend/pnpm-lock.yaml
@@ -8,6 +8,9 @@ dependencies:
'@rollup/plugin-replace':
specifier: ^5.0.2
version: 5.0.5(rollup@3.29.4)
+ '@tanstack/svelte-table':
+ specifier: ^8.12.0
+ version: 8.12.0(svelte@3.59.2)
'@urql/svelte':
specifier: ^4.0.1
version: 4.0.4(graphql@16.8.1)(svelte@3.59.2)
@@ -55,6 +58,9 @@ devDependencies:
rollup-plugin-css-only:
specifier: ^4.3.0
version: 4.5.2(rollup@3.29.4)
+ rollup-plugin-livereload:
+ specifier: ^2.0.5
+ version: 2.0.5
rollup-plugin-svelte:
specifier: ^7.1.4
version: 7.1.6(rollup@3.29.4)(svelte@3.59.2)
@@ -213,6 +219,21 @@ packages:
picomatch: 2.3.1
rollup: 3.29.4
+ /@tanstack/svelte-table@8.12.0(svelte@3.59.2):
+ resolution: {integrity: sha512-IgmCj4tVUgjQAUa895XommqNkNdlbi5K3MgcuyB7SbgRMXZXWUrz4chDSrFSseosLz+hcizXsoavmDcDm/WYwA==}
+ engines: {node: '>=12'}
+ peerDependencies:
+ svelte: ^4.0.0 || ^3.49.0
+ dependencies:
+ '@tanstack/table-core': 8.12.0
+ svelte: 3.59.2
+ dev: false
+
+ /@tanstack/table-core@8.12.0:
+ resolution: {integrity: sha512-cq/ylWVrOwixmwNXQjgZaQw1Izf7+nPxjczum7paAnMtwPg1S2qRAJU+Jb8rEBUWm69voC/zcChmePlk2hc6ug==}
+ engines: {node: '>=12'}
+ dev: false
+
/@timohausmann/quadtree-js@1.2.6:
resolution: {integrity: sha512-EoAoLMFV2JfSG8+8XD9xWJQdyvfEB5xNpiQWGD7rTDSbDQQV8IVpkm0uOIxwJZ+1uC9hHKri9GmJ5wBSUO4jfg==}
dev: true
@@ -251,16 +272,36 @@ packages:
hasBin: true
dev: true
+ /anymatch@3.1.3:
+ resolution: {integrity: sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==}
+ engines: {node: '>= 8'}
+ dependencies:
+ normalize-path: 3.0.0
+ picomatch: 2.3.1
+ dev: true
+
/balanced-match@1.0.2:
resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==}
dev: true
+ /binary-extensions@2.2.0:
+ resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==}
+ engines: {node: '>=8'}
+ dev: true
+
/brace-expansion@2.0.1:
resolution: {integrity: sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==}
dependencies:
balanced-match: 1.0.2
dev: true
+ /braces@3.0.2:
+ resolution: {integrity: sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==}
+ engines: {node: '>=8'}
+ dependencies:
+ fill-range: 7.0.1
+ dev: true
+
/buffer-from@1.1.2:
resolution: {integrity: sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==}
dev: true
@@ -277,6 +318,21 @@ packages:
'@kurkle/color': 0.3.2
dev: false
+ /chokidar@3.6.0:
+ resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==}
+ engines: {node: '>= 8.10.0'}
+ dependencies:
+ anymatch: 3.1.3
+ braces: 3.0.2
+ glob-parent: 5.1.2
+ is-binary-path: 2.1.0
+ is-glob: 4.0.3
+ normalize-path: 3.0.0
+ readdirp: 3.6.0
+ optionalDependencies:
+ fsevents: 2.3.3
+ dev: true
+
/commander@2.20.3:
resolution: {integrity: sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==}
dev: true
@@ -312,6 +368,13 @@ packages:
/estree-walker@2.0.2:
resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==}
+ /fill-range@7.0.1:
+ resolution: {integrity: sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==}
+ engines: {node: '>=8'}
+ dependencies:
+ to-regex-range: 5.0.1
+ dev: true
+
/fraction.js@4.3.4:
resolution: {integrity: sha512-pwiTgt0Q7t+GHZA4yaLjObx4vXmmdcS0iSJ19o8d/goUGgItX9UZWKWNnLHehxviD8wU2IWRsnR8cD5+yOJP2Q==}
dev: false
@@ -331,6 +394,13 @@ packages:
resolution: {integrity: sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==}
dev: true
+ /glob-parent@5.1.2:
+ resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==}
+ engines: {node: '>= 6'}
+ dependencies:
+ is-glob: 4.0.3
+ dev: true
+
/glob@8.1.0:
resolution: {integrity: sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==}
engines: {node: '>=12'}
@@ -365,6 +435,13 @@ packages:
resolution: {integrity: sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==}
dev: true
+ /is-binary-path@2.1.0:
+ resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==}
+ engines: {node: '>=8'}
+ dependencies:
+ binary-extensions: 2.2.0
+ dev: true
+
/is-builtin-module@3.2.1:
resolution: {integrity: sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A==}
engines: {node: '>=6'}
@@ -378,10 +455,27 @@ packages:
hasown: 2.0.1
dev: true
+ /is-extglob@2.1.1:
+ resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==}
+ engines: {node: '>=0.10.0'}
+ dev: true
+
+ /is-glob@4.0.3:
+ resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==}
+ engines: {node: '>=0.10.0'}
+ dependencies:
+ is-extglob: 2.1.1
+ dev: true
+
/is-module@1.0.0:
resolution: {integrity: sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==}
dev: true
+ /is-number@7.0.0:
+ resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==}
+ engines: {node: '>=0.12.0'}
+ dev: true
+
/is-reference@1.2.1:
resolution: {integrity: sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==}
dependencies:
@@ -392,6 +486,24 @@ packages:
resolution: {integrity: sha512-nO6jcEfZWQXDhOiBtG2KvKyEptz7RVbpGP4vTD2hLBdmNQSsCiicO2Ioinv6UI4y9ukqnBpy+XZ9H6uLNgJTlw==}
dev: false
+ /livereload-js@3.4.1:
+ resolution: {integrity: sha512-5MP0uUeVCec89ZbNOT/i97Mc+q3SxXmiUGhRFOTmhrGPn//uWVQdCvcLJDy64MSBR5MidFdOR7B9viumoavy6g==}
+ dev: true
+
+ /livereload@0.9.3:
+ resolution: {integrity: sha512-q7Z71n3i4X0R9xthAryBdNGVGAO2R5X+/xXpmKeuPMrteg+W2U8VusTKV3YiJbXZwKsOlFlHe+go6uSNjfxrZw==}
+ engines: {node: '>=8.0.0'}
+ hasBin: true
+ dependencies:
+ chokidar: 3.6.0
+ livereload-js: 3.4.1
+ opts: 2.0.2
+ ws: 7.5.9
+ transitivePeerDependencies:
+ - bufferutil
+ - utf-8-validate
+ dev: true
+
/magic-string@0.27.0:
resolution: {integrity: sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==}
engines: {node: '>=12'}
@@ -429,12 +541,21 @@ packages:
brace-expansion: 2.0.1
dev: true
+ /normalize-path@3.0.0:
+ resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==}
+ engines: {node: '>=0.10.0'}
+ dev: true
+
/once@1.4.0:
resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==}
dependencies:
wrappy: 1.0.2
dev: true
+ /opts@2.0.2:
+ resolution: {integrity: sha512-k41FwbcLnlgnFh69f4qdUfvDQ+5vaSDnVPFI/y5XuhKRq97EnVVneO9F1ESVCdiVu4fCS2L8usX3mU331hB7pg==}
+ dev: true
+
/path-parse@1.0.7:
resolution: {integrity: sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==}
dev: true
@@ -449,6 +570,13 @@ packages:
safe-buffer: 5.2.1
dev: true
+ /readdirp@3.6.0:
+ resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==}
+ engines: {node: '>=8.10.0'}
+ dependencies:
+ picomatch: 2.3.1
+ dev: true
+
/regenerator-runtime@0.14.1:
resolution: {integrity: sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==}
dev: false
@@ -477,6 +605,16 @@ packages:
rollup: 3.29.4
dev: true
+ /rollup-plugin-livereload@2.0.5:
+ resolution: {integrity: sha512-vqQZ/UQowTW7VoiKEM5ouNW90wE5/GZLfdWuR0ELxyKOJUIaj+uismPZZaICU4DnWPVjnpCDDxEqwU7pcKY/PA==}
+ engines: {node: '>=8.3'}
+ dependencies:
+ livereload: 0.9.3
+ transitivePeerDependencies:
+ - bufferutil
+ - utf-8-validate
+ dev: true
+
/rollup-plugin-svelte@7.1.6(rollup@3.29.4)(svelte@3.59.2):
resolution: {integrity: sha512-nVFRBpGWI2qUY1OcSiEEA/kjCY2+vAjO9BI8SzA7NRrh2GTunLd6w2EYmnMt/atgdg8GvcNjLsmZmbQs/u4SQA==}
engines: {node: '>=10'}
@@ -570,6 +708,13 @@ packages:
resolution: {integrity: sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q==}
dev: false
+ /to-regex-range@5.0.1:
+ resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==}
+ engines: {node: '>=8.0'}
+ dependencies:
+ is-number: 7.0.0
+ dev: true
+
/typed-function@4.1.1:
resolution: {integrity: sha512-Pq1DVubcvibmm8bYcMowjVnnMwPVMeh0DIdA8ad8NZY2sJgapANJmiigSUwlt+EgXxpfIv8MWrQXTIzkfYZLYQ==}
engines: {node: '>= 14'}
@@ -586,3 +731,16 @@ packages:
/wrappy@1.0.2:
resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==}
dev: true
+
+ /ws@7.5.9:
+ resolution: {integrity: sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==}
+ engines: {node: '>=8.3.0'}
+ peerDependencies:
+ bufferutil: ^4.0.1
+ utf-8-validate: ^5.0.2
+ peerDependenciesMeta:
+ bufferutil:
+ optional: true
+ utf-8-validate:
+ optional: true
+ dev: true
diff --git a/web/frontend/rollup.config.mjs b/web/frontend/rollup.config.mjs
index 6786a4d..46c1357 100644
--- a/web/frontend/rollup.config.mjs
+++ b/web/frontend/rollup.config.mjs
@@ -4,6 +4,7 @@ import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';
import terser from '@rollup/plugin-terser';
import css from 'rollup-plugin-css-only';
+import livereload from 'rollup-plugin-livereload';
// const production = !process.env.ROLLUP_WATCH;
const production = false
@@ -51,6 +52,7 @@ const entrypoint = (name, path) => ({
// we'll extract any component CSS out into
// a separate file - better for performance
css({ output: `${name}.css` }),
+ !production && livereload('public')
],
watch: {
clearScreen: false
@@ -68,5 +70,7 @@ export default [
entrypoint('analysis', 'src/analysis.entrypoint.js'),
entrypoint('status', 'src/status.entrypoint.js'),
entrypoint('config', 'src/config.entrypoint.js'),
- entrypoint('partitions', 'src/partitions.entrypoint.js')
+ entrypoint('partitions', 'src/partitions.entrypoint.js'),
+ entrypoint('history', 'src/history.entrypoint.js')
+
];
diff --git a/web/frontend/src/Config.root.svelte b/web/frontend/src/Config.root.svelte
index 6df579f..3461f98 100644
--- a/web/frontend/src/Config.root.svelte
+++ b/web/frontend/src/Config.root.svelte
@@ -1,31 +1,67 @@
-{#if isAdmin == true}
-
-
- Admin Options
-
-
-
-{/if}
-
-
-
- Plotting Options
-
-
-
+
+
+
+ Admin Options
+
+
+ {#if isAdmin == true}
+
+
+
+ {/if}
+
+
+
+ Plotting Options
+
+
+
+
+
+
+
+
+ Default Configuration
+
+
+
+
+
+ Default InfluxDB Configuration
+
+
+
+
+
+
+
+
+
+
diff --git a/web/frontend/src/Header.svelte b/web/frontend/src/Header.svelte
index e1841a7..28aca3d 100644
--- a/web/frontend/src/Header.svelte
+++ b/web/frontend/src/Header.svelte
@@ -1,186 +1,184 @@
-
-
-
- (isOpen = !isOpen)} />
- (isOpen = detail.isOpen)}
- >
-
- {#if screenSize > 1500 || screenSize < 768}
- item.requiredRole <= authlevel
- )}
- />
- {:else if screenSize > 1300}
-
- item.requiredRole <= authlevel &&
- item.menu != "Stats"
- )}
- />
-
-
-
- Stats
-
-
-
- {:else}
-
- item.requiredRole <= authlevel &&
- item.menu == "none"
- )}
- />
- {#each Array("Groups", "Stats") as menu}
-
-
- {menu}
-
-
-
- {/each}
- {/if}
-
-
-
+
+
+
+ (isOpen = !isOpen)} />
+ (isOpen = detail.isOpen)}
+ >
+
+ {#if screenSize > 1500 || screenSize < 768}
+ item.requiredRole <= authlevel)}
+ />
+ {:else if screenSize > 1300}
+ item.requiredRole <= authlevel && item.menu != "Stats"
+ )}
+ />
+
+
+
+ Stats
+
+
+
+ {:else}
+ item.requiredRole <= authlevel && item.menu == "none"
+ )}
+ />
+ {#each Array("Groups", "Stats") as menu}
+
+
+ {menu}
+
+
+
+ {/each}
+ {/if}
+
+
+
diff --git a/web/frontend/src/History.svelte b/web/frontend/src/History.svelte
new file mode 100644
index 0000000..63131e1
--- /dev/null
+++ b/web/frontend/src/History.svelte
@@ -0,0 +1,98 @@
+
+
+
+
+
+
+
+
+ History
+
+
+ History records for past connections are listed here and can be
+ sorted by clicking the column headers. To search for specific
+ records, enter a filter string and click "Search". Only records
+ which match the provided filter string will be listed.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Search
+
+
+
+
+
+
+
+
+
+
+
+ Previous
+
+ Next
+
+
+ (isOpen = !isOpen)}>
+
+ {selectedPages}
+
+
+ {#each pages as page (page)}
+ selectPage(page)}
+ >{page}
+ {/each}
+
+
+
+
+
+
+
+
+
+
diff --git a/web/frontend/src/config/admin/FileBrowser.svelte b/web/frontend/src/config/admin/FileBrowser.svelte
new file mode 100644
index 0000000..2606353
--- /dev/null
+++ b/web/frontend/src/config/admin/FileBrowser.svelte
@@ -0,0 +1,53 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/web/frontend/src/config/admin/InfluxDbConf.svelte b/web/frontend/src/config/admin/InfluxDbConf.svelte
new file mode 100644
index 0000000..f229635
--- /dev/null
+++ b/web/frontend/src/config/admin/InfluxDbConf.svelte
@@ -0,0 +1,193 @@
+
+
+
+
+
diff --git a/web/frontend/src/config/admin/InfluxModalDefault.svelte b/web/frontend/src/config/admin/InfluxModalDefault.svelte
new file mode 100644
index 0000000..e5340a3
--- /dev/null
+++ b/web/frontend/src/config/admin/InfluxModalDefault.svelte
@@ -0,0 +1,30 @@
+
+
+Show InfluxDB Configuration
+
+
+ InfluxDB Configuration
+
+
+
+
+ Close
+
+
\ No newline at end of file
diff --git a/web/frontend/src/history.entrypoint.js b/web/frontend/src/history.entrypoint.js
new file mode 100644
index 0000000..e124a1d
--- /dev/null
+++ b/web/frontend/src/history.entrypoint.js
@@ -0,0 +1,13 @@
+import {} from './header.entrypoint.js'
+import History from './History.svelte'
+
+
+new History({
+ target: document.getElementById('svelte-app'),
+ props: {
+ filterPresets: filterPresets
+ },
+ context: new Map([
+ ['cc-config', clusterCockpitConfig]
+ ])
+})
\ No newline at end of file
diff --git a/web/frontend/src/partition/SvTable.svelte b/web/frontend/src/partition/SvTable.svelte
new file mode 100644
index 0000000..689178a
--- /dev/null
+++ b/web/frontend/src/partition/SvTable.svelte
@@ -0,0 +1,36 @@
+
+
+
+
+
+
+
+ Username
+ Linux-machine
+ Usage
+ Role
+
+
+
+ {#each data as item (item.username)}
+
+ {item.username}
+ {item.linuxMachine}
+ {item.usage}
+ {item.role}
+
+ {/each}
+
+
\ No newline at end of file
diff --git a/web/templates/monitoring/history.tmpl b/web/templates/monitoring/history.tmpl
new file mode 100644
index 0000000..08995b5
--- /dev/null
+++ b/web/templates/monitoring/history.tmpl
@@ -0,0 +1,15 @@
+{{define "content"}}
+
+{{end}}
+
+{{define "stylesheets"}}
+
+{{end}}
+{{define "javascript"}}
+
+
+{{end}}