From 72c5a3dd5e4244050956bdb10fd90146c7484304 Mon Sep 17 00:00:00 2001 From: sanjay7178 Date: Mon, 19 Feb 2024 19:20:23 +0530 Subject: [PATCH] Update configurations and add new files --- configs/config-demo.json | 2 +- .../migrations/mysql/01_init-schema.down.sql | 1 + .../migrations/mysql/01_init-schema.up.sql | 6 + internal/routerConfig/routes.go | 5 +- web/frontend/package.json | 2 + web/frontend/pnpm-lock.yaml | 158 ++++++++ web/frontend/rollup.config.mjs | 6 +- web/frontend/src/Config.root.svelte | 84 +++-- web/frontend/src/Header.svelte | 350 +++++++++--------- web/frontend/src/History.svelte | 98 +++++ .../src/config/admin/FileBrowser.svelte | 53 +++ .../src/config/admin/InfluxDbConf.svelte | 193 ++++++++++ .../config/admin/InfluxModalDefault.svelte | 30 ++ web/frontend/src/history.entrypoint.js | 13 + web/frontend/src/partition/SvTable.svelte | 36 ++ web/templates/monitoring/history.tmpl | 15 + 16 files changed, 849 insertions(+), 203 deletions(-) create mode 100644 web/frontend/src/History.svelte create mode 100644 web/frontend/src/config/admin/FileBrowser.svelte create mode 100644 web/frontend/src/config/admin/InfluxDbConf.svelte create mode 100644 web/frontend/src/config/admin/InfluxModalDefault.svelte create mode 100644 web/frontend/src/history.entrypoint.js create mode 100644 web/frontend/src/partition/SvTable.svelte create mode 100644 web/templates/monitoring/history.tmpl 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 @@ - - ClusterCockpit Logo - - (isOpen = !isOpen)} /> - (isOpen = detail.isOpen)} - > - - - + + ClusterCockpit Logo + + (isOpen = !isOpen)} /> + (isOpen = detail.isOpen)} + > + + + 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. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ (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 @@ + + + + +
+ FileBrowser Configuration +

Current URL :

+
+ + +
+

+ + {#if displayMessage}

{message.msg}
{/if} +

+
+
\ 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 @@ + + + +
+ +
+ + +
+
+ + +
+
+ + +
+
+ + +
+ +
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+

+ + {#if displayMessage}

+ {message.msg} +
{/if} +

+
+
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 @@ + + + + + + InfluxDB Configuration + + + + + + + \ 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 @@ + + + + + + + + + + + + + + + {#each data as item (item.username)} + + + + + + + {/each} + +
UsernameLinux-machineUsageRole

{item.username}

{item.linuxMachine}{item.usage}{item.role}
\ 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}}