Compare commits
2 Commits
419eccf4d0
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| c8456a0885 | |||
| add4260a9b |
@@ -2,6 +2,7 @@ import app from "ags/gtk4/app";
|
|||||||
import { Astal, Gtk } from "ags/gtk4";
|
import { Astal, Gtk } from "ags/gtk4";
|
||||||
import { execAsync } from "ags/process";
|
import { execAsync } from "ags/process";
|
||||||
import css from "./homelab.css";
|
import css from "./homelab.css";
|
||||||
|
import { writeFile } from "ags/file";
|
||||||
import GLib from "gi://GLib";
|
import GLib from "gi://GLib";
|
||||||
|
|
||||||
let hasConfig = false;
|
let hasConfig = false;
|
||||||
@@ -10,9 +11,7 @@ const CONFIG_PATH = GLib.getenv("HOMELAB_CONFIG") || `${GLib.getenv("HOME")}/.co
|
|||||||
function saveConfig(host: string, user: string, port: string) {
|
function saveConfig(host: string, user: string, port: string) {
|
||||||
const yaml = `# Homelab Configuration\ngenerated_by: Omeron\n\nserver:\n address: "${host}"\n username: "${user}"\n port: ${port}\n\ncontrol_center:\n refresh_interval: 5\n theme: "dark"\n\nfeatures:\n docker: true\n services: true\n storage: true\n network: true\n monitoring: true\n`;
|
const yaml = `# Homelab Configuration\ngenerated_by: Omeron\n\nserver:\n address: "${host}"\n username: "${user}"\n port: ${port}\n\ncontrol_center:\n refresh_interval: 5\n theme: "dark"\n\nfeatures:\n docker: true\n services: true\n storage: true\n network: true\n monitoring: true\n`;
|
||||||
try {
|
try {
|
||||||
GLib.mkdir_with_parents(GLib.path_get_dirname(CONFIG_PATH), 0o755);
|
writeFile(CONFIG_PATH, yaml);
|
||||||
const ok = GLib.file_set_contents(CONFIG_PATH, yaml);
|
|
||||||
print(`[homelab] save: dir created, write=${ok}`);
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print(`[homelab] save error: ${e}`);
|
print(`[homelab] save error: ${e}`);
|
||||||
return;
|
return;
|
||||||
@@ -1131,15 +1130,13 @@ function startRefreshTimer() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function SetupView() {
|
function SetupView() {
|
||||||
let hostEntry: Gtk.Entry | null = null;
|
let host = "";
|
||||||
let userEntry: Gtk.Entry | null = null;
|
let user = "root";
|
||||||
let portEntry: Gtk.Entry | null = null;
|
let port = "22";
|
||||||
|
|
||||||
function doSave() {
|
function doSave() {
|
||||||
if (!hostEntry || !userEntry || !portEntry) return;
|
|
||||||
const host = hostEntry.get_text();
|
|
||||||
if (!host) return;
|
if (!host) return;
|
||||||
saveConfig(host, userEntry.get_text() || "root", portEntry.get_text() || "22");
|
saveConfig(host, user || "root", port || "22");
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@@ -1149,24 +1146,24 @@ function SetupView() {
|
|||||||
<label class="subtitle" xalign={0} label="Ersteinrichtung — Serververbindung konfigurieren" />
|
<label class="subtitle" xalign={0} label="Ersteinrichtung — Serververbindung konfigurieren" />
|
||||||
</box>
|
</box>
|
||||||
<entry
|
<entry
|
||||||
setup={self => { hostEntry = self; }}
|
onChanged={self => { host = self.text || self.get_text(); }}
|
||||||
|
onActivate={doSave}
|
||||||
placeholderText="Server-Adresse (IP oder Domain)"
|
placeholderText="Server-Adresse (IP oder Domain)"
|
||||||
hexpand
|
hexpand
|
||||||
onActivate={doSave}
|
|
||||||
/>
|
/>
|
||||||
<entry
|
<entry
|
||||||
setup={self => { userEntry = self; }}
|
onChanged={self => { user = self.text || self.get_text(); }}
|
||||||
|
onActivate={doSave}
|
||||||
placeholderText="SSH-Benutzer"
|
placeholderText="SSH-Benutzer"
|
||||||
text="root"
|
text="root"
|
||||||
hexpand
|
hexpand
|
||||||
onActivate={doSave}
|
|
||||||
/>
|
/>
|
||||||
<entry
|
<entry
|
||||||
setup={self => { portEntry = self; }}
|
onChanged={self => { port = self.text || self.get_text(); }}
|
||||||
|
onActivate={doSave}
|
||||||
placeholderText="SSH-Port"
|
placeholderText="SSH-Port"
|
||||||
text="22"
|
text="22"
|
||||||
hexpand
|
hexpand
|
||||||
onActivate={doSave}
|
|
||||||
/>
|
/>
|
||||||
<button
|
<button
|
||||||
class="button primary"
|
class="button primary"
|
||||||
|
|||||||
Reference in New Issue
Block a user