feat: server management (Feature 1)

This commit is contained in:
Hitonabi
2026-06-20 21:34:14 +02:00
parent 8800dd4558
commit 04bac7e13e
2 changed files with 75 additions and 8 deletions
+52 -8
View File
@@ -1,24 +1,68 @@
// maintenance.js — Wartungs-Karte: Container aktualisieren + alle Modelle entladen.
// Spaeter waechst hier das Server-Management an (Roadmap Feature 1).
import { api } from "../core/api.js";
import { $, toast } from "../core/ui.js";
import { track } from "./jobs.js";
function refreshSoon() { document.dispatchEvent(new Event("mc:refresh")); }
function mount() {
$("#wartung").innerHTML = `
<div class="card-h"><h3>Wartung</h3></div>
<div class="card-h"><h3>Dienste & Applikation</h3></div>
<div class="btn-row" style="margin-bottom:20px">
<button id="w-restart-swap">llama-swap neustarten</button>
<button id="w-restart-mc">Mission Control neustarten</button>
</div>
<div class="btn-row">
<button id="w-update">Container aktualisieren</button>
<button id="w-unload" class="danger">Alles aus dem Speicher</button>
<button id="w-unload" class="ghost">Modelle entladen</button>
</div>
<div class="hint" style="margin-top:12px; margin-bottom:32px">
Dienste starten via passwortlosem Sudo neu.
</div>
<div class="card-h"><h3>Betriebssystem (Bosgame)</h3></div>
<div class="btn-row">
<button id="w-os-update">OS-Updates installieren (apt update)</button>
<button id="w-reboot" class="danger">Server Reboot</button>
</div>
<div class="hint" style="margin-top:12px">
Update-Befehl wird per <span class="mono-sm">MC_UPDATE_CMD</span> gesetzt.
Server-Steuerung (Dienste, OS-Updates, Reboot) folgt als eigener Bereich.
Für tiefe Eingriffe fragt das Dashboard einmalig das sudo-Passwort ab.
</div>`;
$("#w-restart-swap").addEventListener("click", () => restartService("llama-swap"));
$("#w-restart-mc").addEventListener("click", () => restartService("mission-control"));
$("#w-update").addEventListener("click", update);
$("#w-unload").addEventListener("click", unloadAll);
$("#w-os-update").addEventListener("click", osUpdate);
$("#w-reboot").addEventListener("click", rebootServer);
}
async function restartService(name) {
try {
await api("/api/service/" + name + "/restart", { method: "POST" });
toast("Neustart ausgelöst: " + name);
setTimeout(refreshSoon, 2000);
} catch (e) { toast(e.message, true); }
}
async function osUpdate() {
const pwd = window.prompt("Bitte sudo Passwort eingeben (für apt-get update & upgrade):");
if (!pwd) return;
try {
const r = await api("/api/os-update", { method: "POST", body: JSON.stringify({ password: pwd }) });
toast("OS-Update gestartet.");
track(r.job_id);
} catch (e) { toast(e.message, true); }
}
async function rebootServer() {
if (!window.confirm("ACHTUNG: Server wird komplett neu gestartet. Fortfahren?")) return;
const pwd = window.prompt("Bitte sudo Passwort eingeben (für reboot):");
if (!pwd) return;
try {
await api("/api/reboot", { method: "POST", body: JSON.stringify({ password: pwd }) });
toast("Reboot ausgelöst. UI ist gleich offline.");
} catch (e) { toast(e.message, true); }
}
async function update() {
@@ -33,7 +77,7 @@ async function unloadAll() {
try {
await api("/api/unload", { method: "POST" });
toast("Alle Modelle entladen.");
setTimeout(() => document.dispatchEvent(new Event("mc:refresh")), 600);
setTimeout(refreshSoon, 600);
} catch (e) { toast(e.message, true); }
}