From 3abf299cd659606b1885072e47d2c4eac966c510 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 21:37:16 +0100 Subject: [PATCH 01/18] glance: Init module --- hosts/srv-core/configuration.nix | 5 +++++ modules/nixos/web-services/glance.nix | 30 +++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) create mode 100644 modules/nixos/web-services/glance.nix diff --git a/hosts/srv-core/configuration.nix b/hosts/srv-core/configuration.nix index 962334b..80844ff 100644 --- a/hosts/srv-core/configuration.nix +++ b/hosts/srv-core/configuration.nix @@ -72,6 +72,11 @@ domain = "status.${config.custom.networking.overlay.domain}"; generateDefaultEndpoints = true; }; + + glance = { + enable = true; + domain = "home.${config.custom.networking.overlay.domain}"; + }; }; }; } diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix new file mode 100644 index 0000000..2767d46 --- /dev/null +++ b/modules/nixos/web-services/glance.nix @@ -0,0 +1,30 @@ +{ config, lib, ... }: +let + cfg = config.custom.web-services.glance; +in +{ + options.custom.web-services.glance = { + enable = lib.mkEnableOption ""; + domain = lib.mkOption { + type = lib.types.nonEmptyStr; + default = ""; + }; + port = lib.mkOption { + type = lib.types.port; + default = 63958; + }; + }; + + config = lib.mkIf cfg.enable { + services.glance = { + enable = true; + settings = { + inherit (cfg) port; + + #pages + }; + }; + + custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + }; +} From 81cb5c27236532759a79861b9d80e9797ea68bda Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 21:53:25 +0100 Subject: [PATCH 02/18] glance: Add services --- modules/nixos/web-services/glance.nix | 34 +++++++++++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 2767d46..6102223 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -1,4 +1,9 @@ -{ config, lib, ... }: +{ + config, + lib, + allHosts, + ... +}: let cfg = config.custom.web-services.glance; in @@ -21,7 +26,32 @@ in settings = { inherit (cfg) port; - #pages + pages = lib.singleton { + name = "Services"; + columns = [ + { + size = "full"; + widgets = [ + { + type = "monitor"; + cache = "1m"; + title = "Services"; + sites = + allHosts + |> lib.attrValues ( + host: + host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain) + ) + |> lib.concatLists + |> lib.map (domain: { + title = domain; + url = domain; + }); + } + ]; + } + ]; + }; }; }; From cb0d7c716c47ef70cd2714d125624cf82a650504 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 21:55:59 +0100 Subject: [PATCH 03/18] glance: Fix syntax --- modules/nixos/web-services/glance.nix | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 6102223..3add716 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -38,7 +38,8 @@ in title = "Services"; sites = allHosts - |> lib.attrValues ( + |> lib.attrValues + |> lib.map ( host: host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain) ) From db4bd23286b73358ce5b32c3a9b523476a567990 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 22:00:59 +0100 Subject: [PATCH 04/18] glance: Fix port --- modules/nixos/web-services/glance.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 3add716..ffd4513 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -24,7 +24,7 @@ in services.glance = { enable = true; settings = { - inherit (cfg) port; + server.port = cfg.port; pages = lib.singleton { name = "Services"; From 2d9a779fb19b2b076a5c54024bf77ebce470d31c Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 22:03:33 +0100 Subject: [PATCH 05/18] glance: Fix url --- modules/nixos/web-services/glance.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index ffd4513..22c4328 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -46,7 +46,7 @@ in |> lib.concatLists |> lib.map (domain: { title = domain; - url = domain; + url = "https://${domain}"; }); } ]; From 8c549955c2188f86c75021f0a590e14f1421e373 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 22:25:57 +0100 Subject: [PATCH 06/18] glance: Group services by host --- modules/nixos/web-services/glance.nix | 31 ++++++++++++++------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 22c4328..2dfc8ed 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -28,30 +28,31 @@ in pages = lib.singleton { name = "Services"; - columns = [ - { - size = "full"; - widgets = [ + columns = lib.singleton { + size = "full"; + widgets = + allHosts + |> lib.attrValues + |> lib.map (host: { + hostName = host.config.networking.hostName; + domains = + host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain); + }) + |> lib.map ( + { hostName, domains }: { type = "monitor"; cache = "1m"; - title = "Services"; + title = "Services - ${hostName}"; sites = - allHosts - |> lib.attrValues - |> lib.map ( - host: - host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain) - ) - |> lib.concatLists + domains |> lib.map (domain: { title = domain; url = "https://${domain}"; }); } - ]; - } - ]; + ); + }; }; }; }; From 5cfb73e183bde3a843151110aa4b12decbf95f6a Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 22:44:43 +0100 Subject: [PATCH 07/18] glance: Only display hosts that have services --- modules/nixos/web-services/glance.nix | 1 + 1 file changed, 1 insertion(+) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 2dfc8ed..7655562 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -38,6 +38,7 @@ in domains = host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain); }) + |> lib.filter ({ domains, ... }: domains != [ ]) |> lib.map ( { hostName, domains }: { From 5cf56036d76b4713fcfb8c73bc1a082b75b9d7ac Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:10:08 +0100 Subject: [PATCH 08/18] glance: Improve services --- modules/nixos/meta/services.nix | 27 +++++++++++++++++++ modules/nixos/services/alertmanager.nix | 9 ++++++- modules/nixos/services/prometheus.nix | 5 ++++ modules/nixos/web-services/actualbudget.nix | 5 ++++ modules/nixos/web-services/atuin.nix | 5 ++++ modules/nixos/web-services/filebrowser.nix | 5 ++++ modules/nixos/web-services/forgejo.nix | 5 ++++ modules/nixos/web-services/freshrss.nix | 5 ++++ modules/nixos/web-services/gatus.nix | 5 ++++ modules/nixos/web-services/glance.nix | 23 ++++++++-------- modules/nixos/web-services/grafana.nix | 9 ++++++- modules/nixos/web-services/it-tools.nix | 9 ++++++- modules/nixos/web-services/karakeep.nix | 5 ++++ .../nixos/web-services/networking-toolbox.nix | 9 ++++++- modules/nixos/web-services/ntfy.nix | 9 ++++++- modules/nixos/web-services/outline.nix | 5 ++++ modules/nixos/web-services/personal-blog.nix | 9 ++++++- modules/nixos/web-services/privatebin.nix | 9 ++++++- modules/nixos/web-services/radicale.nix | 5 ++++ modules/nixos/web-services/screego.nix | 9 ++++++- modules/nixos/web-services/stirling-pdf.nix | 9 ++++++- 21 files changed, 161 insertions(+), 20 deletions(-) create mode 100644 modules/nixos/meta/services.nix diff --git a/modules/nixos/meta/services.nix b/modules/nixos/meta/services.nix new file mode 100644 index 0000000..e67e39f --- /dev/null +++ b/modules/nixos/meta/services.nix @@ -0,0 +1,27 @@ +{ lib, ... }: +{ + options.custom.meta.services = lib.mkOption { + type = lib.types.attrsOf ( + lib.types.submodule ( + { name, ... }: + { + options = { + name = lib.mkOption { + type = lib.types.nonEmptyStr; + default = name; + }; + url = lib.mkOption { + type = lib.types.nonEmptyStr; + default = "https://${name}"; + }; + icon = lib.mkOption { + type = lib.types.nonEmptyStr; + default = ""; + }; + }; + } + ) + ); + default = { }; + }; +} diff --git a/modules/nixos/services/alertmanager.nix b/modules/nixos/services/alertmanager.nix index 4a2dcd8..5ada57d 100644 --- a/modules/nixos/services/alertmanager.nix +++ b/modules/nixos/services/alertmanager.nix @@ -98,6 +98,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Alertmanager"; + icon = "di:alertmanager"; + }; + }; }; } diff --git a/modules/nixos/services/prometheus.nix b/modules/nixos/services/prometheus.nix index 7409dea..621d784 100644 --- a/modules/nixos/services/prometheus.nix +++ b/modules/nixos/services/prometheus.nix @@ -125,6 +125,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ "/var/lib/${config.services.prometheus.stateDir}" ]; + + meta.services.${cfg.domain} = { + name = "Prometheus"; + icon = "sh:prometheus"; + }; }; }; } diff --git a/modules/nixos/web-services/actualbudget.nix b/modules/nixos/web-services/actualbudget.nix index fc80e34..c416d9c 100644 --- a/modules/nixos/web-services/actualbudget.nix +++ b/modules/nixos/web-services/actualbudget.nix @@ -52,6 +52,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "Actual Budget"; + icon = "sh:actual-budget"; + }; }; }; } diff --git a/modules/nixos/web-services/atuin.nix b/modules/nixos/web-services/atuin.nix index 79bf168..0f559a8 100644 --- a/modules/nixos/web-services/atuin.nix +++ b/modules/nixos/web-services/atuin.nix @@ -47,6 +47,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "Atuin"; + icon = "sh:atuin"; + }; }; }; } diff --git a/modules/nixos/web-services/filebrowser.nix b/modules/nixos/web-services/filebrowser.nix index c7d1821..7bbea0a 100644 --- a/modules/nixos/web-services/filebrowser.nix +++ b/modules/nixos/web-services/filebrowser.nix @@ -48,6 +48,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "File Browser"; + icon = "sh:filebrowser"; + }; }; }; } diff --git a/modules/nixos/web-services/forgejo.nix b/modules/nixos/web-services/forgejo.nix index f657248..57f546d 100644 --- a/modules/nixos/web-services/forgejo.nix +++ b/modules/nixos/web-services/forgejo.nix @@ -83,6 +83,11 @@ in }; persistence.directories = [ config.services.forgejo.stateDir ]; + + meta.services.${cfg.domain} = { + name = "Forgejo"; + icon = "sh:forgejo"; + }; }; }; } diff --git a/modules/nixos/web-services/freshrss.nix b/modules/nixos/web-services/freshrss.nix index acae4e2..bc0d591 100644 --- a/modules/nixos/web-services/freshrss.nix +++ b/modules/nixos/web-services/freshrss.nix @@ -49,6 +49,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "FreshRSS"; + icon = "sh:freshrss"; + }; }; }; } diff --git a/modules/nixos/web-services/gatus.nix b/modules/nixos/web-services/gatus.nix index 199c9a5..2e8a486 100644 --- a/modules/nixos/web-services/gatus.nix +++ b/modules/nixos/web-services/gatus.nix @@ -210,6 +210,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "Gatus"; + icon = "sh:gatus"; + }; }; }; } diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index 7655562..c057b24 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -35,22 +35,16 @@ in |> lib.attrValues |> lib.map (host: { hostName = host.config.networking.hostName; - domains = - host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain); + services = host.config.custom.meta.services |> lib.attrValues; }) - |> lib.filter ({ domains, ... }: domains != [ ]) + |> lib.filter ({ services, ... }: services != [ ]) |> lib.map ( - { hostName, domains }: + { hostName, services }: { type = "monitor"; cache = "1m"; title = "Services - ${hostName}"; - sites = - domains - |> lib.map (domain: { - title = domain; - url = "https://${domain}"; - }); + sites = services; } ); }; @@ -58,6 +52,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Glance"; + icon = "sh:glance"; + }; + }; }; } diff --git a/modules/nixos/web-services/grafana.nix b/modules/nixos/web-services/grafana.nix index 96913ec..74399c8 100644 --- a/modules/nixos/web-services/grafana.nix +++ b/modules/nixos/web-services/grafana.nix @@ -85,6 +85,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Grafana"; + icon = "sh:grafana"; + }; + }; }; } diff --git a/modules/nixos/web-services/it-tools.nix b/modules/nixos/web-services/it-tools.nix index 00b2a02..857d59d 100644 --- a/modules/nixos/web-services/it-tools.nix +++ b/modules/nixos/web-services/it-tools.nix @@ -17,6 +17,13 @@ in }; config = lib.mkIf cfg.enable { - custom.services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib"; + custom = { + services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib"; + + meta.services.${cfg.domain} = { + name = "IT-Tools"; + icon = "sh:it-tools"; + }; + }; }; } diff --git a/modules/nixos/web-services/karakeep.nix b/modules/nixos/web-services/karakeep.nix index 19d1449..5bfa705 100644 --- a/modules/nixos/web-services/karakeep.nix +++ b/modules/nixos/web-services/karakeep.nix @@ -57,6 +57,11 @@ in "/var/lib/karakeep" "/var/lib/meilisearch" ]; + + meta.services.${cfg.domain} = { + name = "Karakeep"; + icon = "sh:karakeep"; + }; }; }; } diff --git a/modules/nixos/web-services/networking-toolbox.nix b/modules/nixos/web-services/networking-toolbox.nix index 96a2e41..9015b29 100644 --- a/modules/nixos/web-services/networking-toolbox.nix +++ b/modules/nixos/web-services/networking-toolbox.nix @@ -22,6 +22,13 @@ in pull = "newer"; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Networking Toolbox"; + icon = "sh:networking-toolbox"; + }; + }; }; } diff --git a/modules/nixos/web-services/ntfy.nix b/modules/nixos/web-services/ntfy.nix index 9cc9dd1..19d604e 100644 --- a/modules/nixos/web-services/ntfy.nix +++ b/modules/nixos/web-services/ntfy.nix @@ -26,6 +26,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "ntfy"; + icon = "sh:ntfy"; + }; + }; }; } diff --git a/modules/nixos/web-services/outline.nix b/modules/nixos/web-services/outline.nix index fb662c6..4da49f9 100644 --- a/modules/nixos/web-services/outline.nix +++ b/modules/nixos/web-services/outline.nix @@ -85,6 +85,11 @@ in dataDir config.services.postgresql.dataDir ]; + + meta.services.${cfg.domain} = { + name = "Outline"; + icon = "sh:outline"; + }; }; }; } diff --git a/modules/nixos/web-services/personal-blog.nix b/modules/nixos/web-services/personal-blog.nix index 1930a2d..bd02150 100644 --- a/modules/nixos/web-services/personal-blog.nix +++ b/modules/nixos/web-services/personal-blog.nix @@ -27,6 +27,13 @@ in script = "nix build github:SebastianStork/blog --out-link ${dataDir} --refresh"; }; - custom.services.caddy.virtualHosts.${cfg.domain}.files = dataDir; + custom = { + services.caddy.virtualHosts.${cfg.domain}.files = dataDir; + + meta.services.${cfg.domain} = { + name = "Blog"; + icon = "sh:ghost"; + }; + }; }; } diff --git a/modules/nixos/web-services/privatebin.nix b/modules/nixos/web-services/privatebin.nix index 7285fa9..7e9fcf0 100644 --- a/modules/nixos/web-services/privatebin.nix +++ b/modules/nixos/web-services/privatebin.nix @@ -37,6 +37,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "PrivateBin"; + icon = "sh:privatebin"; + }; + }; }; } diff --git a/modules/nixos/web-services/radicale.nix b/modules/nixos/web-services/radicale.nix index 7489834..c2021aa 100644 --- a/modules/nixos/web-services/radicale.nix +++ b/modules/nixos/web-services/radicale.nix @@ -109,6 +109,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + name = "Radicale"; + icon = "sh:radicale"; + }; }; }; } diff --git a/modules/nixos/web-services/screego.nix b/modules/nixos/web-services/screego.nix index 7a1d554..fb50c30 100644 --- a/modules/nixos/web-services/screego.nix +++ b/modules/nixos/web-services/screego.nix @@ -26,6 +26,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Screego"; + icon = "sh:screego"; + }; + }; }; } diff --git a/modules/nixos/web-services/stirling-pdf.nix b/modules/nixos/web-services/stirling-pdf.nix index a0efb72..3d5bf5f 100644 --- a/modules/nixos/web-services/stirling-pdf.nix +++ b/modules/nixos/web-services/stirling-pdf.nix @@ -40,6 +40,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + name = "Stirling PDF"; + icon = "sh:stirling-pdf"; + }; + }; }; } From e15485a60eaad89a3c71ba6bea4d725ee4b5291a Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:14:19 +0100 Subject: [PATCH 09/18] glane: Fix titles --- modules/nixos/web-services/glance.nix | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix index c057b24..42de319 100644 --- a/modules/nixos/web-services/glance.nix +++ b/modules/nixos/web-services/glance.nix @@ -44,7 +44,19 @@ in type = "monitor"; cache = "1m"; title = "Services - ${hostName}"; - sites = services; + sites = + services + |> lib.map ( + { + name, + url, + icon, + }: + { + title = name; + inherit url icon; + } + ); } ); }; From b3a1a8bb4169c2dcb601d156bfc18ce4e0068e9e Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:23:47 +0100 Subject: [PATCH 10/18] glance: Fine tune icons --- modules/nixos/services/alertmanager.nix | 2 +- modules/nixos/web-services/filebrowser.nix | 2 +- modules/nixos/web-services/personal-blog.nix | 2 +- modules/nixos/web-services/screego.nix | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/modules/nixos/services/alertmanager.nix b/modules/nixos/services/alertmanager.nix index 5ada57d..105b830 100644 --- a/modules/nixos/services/alertmanager.nix +++ b/modules/nixos/services/alertmanager.nix @@ -103,7 +103,7 @@ in meta.services.${cfg.domain} = { name = "Alertmanager"; - icon = "di:alertmanager"; + icon = "sh:alertmanager"; }; }; }; diff --git a/modules/nixos/web-services/filebrowser.nix b/modules/nixos/web-services/filebrowser.nix index 7bbea0a..e22d440 100644 --- a/modules/nixos/web-services/filebrowser.nix +++ b/modules/nixos/web-services/filebrowser.nix @@ -51,7 +51,7 @@ in meta.services.${cfg.domain} = { name = "File Browser"; - icon = "sh:filebrowser"; + icon = "sh:file-browser"; }; }; }; diff --git a/modules/nixos/web-services/personal-blog.nix b/modules/nixos/web-services/personal-blog.nix index bd02150..a07cd0c 100644 --- a/modules/nixos/web-services/personal-blog.nix +++ b/modules/nixos/web-services/personal-blog.nix @@ -32,7 +32,7 @@ in meta.services.${cfg.domain} = { name = "Blog"; - icon = "sh:ghost"; + icon = "sh:zola"; }; }; }; diff --git a/modules/nixos/web-services/screego.nix b/modules/nixos/web-services/screego.nix index fb50c30..ffac102 100644 --- a/modules/nixos/web-services/screego.nix +++ b/modules/nixos/web-services/screego.nix @@ -31,7 +31,7 @@ in meta.services.${cfg.domain} = { name = "Screego"; - icon = "sh:screego"; + icon = "mdi:projector-screen-outline"; }; }; }; From 7163a31175e7523ef09923ec81c2c263b3aeb7a6 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:24:58 +0100 Subject: [PATCH 11/18] glance: Fix alertmanager icon --- modules/nixos/services/alertmanager.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/nixos/services/alertmanager.nix b/modules/nixos/services/alertmanager.nix index 105b830..3281dd4 100644 --- a/modules/nixos/services/alertmanager.nix +++ b/modules/nixos/services/alertmanager.nix @@ -103,7 +103,7 @@ in meta.services.${cfg.domain} = { name = "Alertmanager"; - icon = "sh:alertmanager"; + icon = "sh:prometheus"; }; }; }; From 8fe5ef9e76eae3389556fe8dcd77e71220c177e7 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:30:50 +0100 Subject: [PATCH 12/18] glance: Add alloy and syncthing --- modules/nixos/services/alloy.nix | 9 ++++++++- modules/nixos/services/syncthing.nix | 5 +++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/modules/nixos/services/alloy.nix b/modules/nixos/services/alloy.nix index e22a3c5..6bcb8cb 100644 --- a/modules/nixos/services/alloy.nix +++ b/modules/nixos/services/alloy.nix @@ -128,6 +128,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port; + + meta.services.${cfg.domain} = lib.mkIf (cfg.domain != null) { + name = "Alloy"; + icon = "sh:alloy"; + }; + }; }; } diff --git a/modules/nixos/services/syncthing.nix b/modules/nixos/services/syncthing.nix index 9427643..d6c15bf 100644 --- a/modules/nixos/services/syncthing.nix +++ b/modules/nixos/services/syncthing.nix @@ -170,6 +170,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = lib.mkIf (cfg.gui.domain != null) { + name = "Syncthing"; + icon = "sh:syncthing"; + }; }; }; } From f38cb764e0cf851f551a8a563ecdc022f1abd465 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Mon, 9 Mar 2026 23:32:17 +0100 Subject: [PATCH 13/18] glance: Fix syncthing --- modules/nixos/services/syncthing.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/nixos/services/syncthing.nix b/modules/nixos/services/syncthing.nix index d6c15bf..2a898b8 100644 --- a/modules/nixos/services/syncthing.nix +++ b/modules/nixos/services/syncthing.nix @@ -171,7 +171,7 @@ in persistence.directories = [ dataDir ]; - meta.services.${cfg.domain} = lib.mkIf (cfg.gui.domain != null) { + meta.services.${cfg.gui.domain} = lib.mkIf (cfg.gui.domain != null) { name = "Syncthing"; icon = "sh:syncthing"; }; From b26751a5fbef67d47f36d6c1b17907b8161c61e4 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Tue, 10 Mar 2026 00:01:36 +0100 Subject: [PATCH 14/18] meta/services: Init module --- modules/nixos/meta/services.nix | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 modules/nixos/meta/services.nix diff --git a/modules/nixos/meta/services.nix b/modules/nixos/meta/services.nix new file mode 100644 index 0000000..fee970a --- /dev/null +++ b/modules/nixos/meta/services.nix @@ -0,0 +1,27 @@ +{ lib, ... }: +{ + options.custom.meta.services = lib.mkOption { + type = lib.types.attrsOf ( + lib.types.submodule ( + { name, ... }: + { + options = { + title = lib.mkOption { + type = lib.types.nonEmptyStr; + default = name; + }; + url = lib.mkOption { + type = lib.types.nonEmptyStr; + default = "https://${name}"; + }; + icon = lib.mkOption { + type = lib.types.nonEmptyStr; + default = ""; + }; + }; + } + ) + ); + default = { }; + }; +} From fe5113d4762fc0f478d6c09cfd6bdeda254a0606 Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Tue, 10 Mar 2026 00:03:03 +0100 Subject: [PATCH 15/18] services, web-services: Populate `meta.services` attribute set --- modules/nixos/services/alertmanager.nix | 9 ++++++++- modules/nixos/services/alloy.nix | 9 ++++++++- modules/nixos/services/prometheus.nix | 5 +++++ modules/nixos/services/syncthing.nix | 5 +++++ modules/nixos/web-services/actualbudget.nix | 5 +++++ modules/nixos/web-services/atuin.nix | 5 +++++ modules/nixos/web-services/filebrowser.nix | 5 +++++ modules/nixos/web-services/forgejo.nix | 5 +++++ modules/nixos/web-services/freshrss.nix | 5 +++++ modules/nixos/web-services/gatus.nix | 5 +++++ modules/nixos/web-services/grafana.nix | 9 ++++++++- modules/nixos/web-services/it-tools.nix | 9 ++++++++- modules/nixos/web-services/karakeep.nix | 5 +++++ modules/nixos/web-services/networking-toolbox.nix | 9 ++++++++- modules/nixos/web-services/ntfy.nix | 9 ++++++++- modules/nixos/web-services/outline.nix | 5 +++++ modules/nixos/web-services/personal-blog.nix | 9 ++++++++- modules/nixos/web-services/privatebin.nix | 9 ++++++++- modules/nixos/web-services/radicale.nix | 5 +++++ modules/nixos/web-services/screego.nix | 9 ++++++++- modules/nixos/web-services/stirling-pdf.nix | 9 ++++++++- 21 files changed, 135 insertions(+), 10 deletions(-) diff --git a/modules/nixos/services/alertmanager.nix b/modules/nixos/services/alertmanager.nix index 4a2dcd8..977b3a5 100644 --- a/modules/nixos/services/alertmanager.nix +++ b/modules/nixos/services/alertmanager.nix @@ -98,6 +98,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "Alertmanager"; + icon = "sh:prometheus"; + }; + }; }; } diff --git a/modules/nixos/services/alloy.nix b/modules/nixos/services/alloy.nix index e22a3c5..24543d4 100644 --- a/modules/nixos/services/alloy.nix +++ b/modules/nixos/services/alloy.nix @@ -128,6 +128,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port; + + meta.services.${cfg.domain} = lib.mkIf (cfg.domain != null) { + title = "Alloy"; + icon = "sh:grafana-alloy"; + }; + }; }; } diff --git a/modules/nixos/services/prometheus.nix b/modules/nixos/services/prometheus.nix index 7409dea..5139fe8 100644 --- a/modules/nixos/services/prometheus.nix +++ b/modules/nixos/services/prometheus.nix @@ -125,6 +125,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ "/var/lib/${config.services.prometheus.stateDir}" ]; + + meta.services.${cfg.domain} = { + title = "Prometheus"; + icon = "sh:prometheus"; + }; }; }; } diff --git a/modules/nixos/services/syncthing.nix b/modules/nixos/services/syncthing.nix index 9427643..27703c0 100644 --- a/modules/nixos/services/syncthing.nix +++ b/modules/nixos/services/syncthing.nix @@ -170,6 +170,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.gui.domain} = lib.mkIf (cfg.gui.domain != null) { + title = "Syncthing"; + icon = "sh:syncthing"; + }; }; }; } diff --git a/modules/nixos/web-services/actualbudget.nix b/modules/nixos/web-services/actualbudget.nix index fc80e34..ec1a616 100644 --- a/modules/nixos/web-services/actualbudget.nix +++ b/modules/nixos/web-services/actualbudget.nix @@ -52,6 +52,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "Actual Budget"; + icon = "sh:actual-budget"; + }; }; }; } diff --git a/modules/nixos/web-services/atuin.nix b/modules/nixos/web-services/atuin.nix index 79bf168..f655aae 100644 --- a/modules/nixos/web-services/atuin.nix +++ b/modules/nixos/web-services/atuin.nix @@ -47,6 +47,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "Atuin"; + icon = "sh:atuin"; + }; }; }; } diff --git a/modules/nixos/web-services/filebrowser.nix b/modules/nixos/web-services/filebrowser.nix index c7d1821..0683e7c 100644 --- a/modules/nixos/web-services/filebrowser.nix +++ b/modules/nixos/web-services/filebrowser.nix @@ -48,6 +48,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "File Browser"; + icon = "sh:file-browser"; + }; }; }; } diff --git a/modules/nixos/web-services/forgejo.nix b/modules/nixos/web-services/forgejo.nix index f657248..4a2083a 100644 --- a/modules/nixos/web-services/forgejo.nix +++ b/modules/nixos/web-services/forgejo.nix @@ -83,6 +83,11 @@ in }; persistence.directories = [ config.services.forgejo.stateDir ]; + + meta.services.${cfg.domain} = { + title = "Forgejo"; + icon = "sh:forgejo"; + }; }; }; } diff --git a/modules/nixos/web-services/freshrss.nix b/modules/nixos/web-services/freshrss.nix index acae4e2..bb749e6 100644 --- a/modules/nixos/web-services/freshrss.nix +++ b/modules/nixos/web-services/freshrss.nix @@ -49,6 +49,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "FreshRSS"; + icon = "sh:freshrss"; + }; }; }; } diff --git a/modules/nixos/web-services/gatus.nix b/modules/nixos/web-services/gatus.nix index 199c9a5..c1e049e 100644 --- a/modules/nixos/web-services/gatus.nix +++ b/modules/nixos/web-services/gatus.nix @@ -210,6 +210,11 @@ in services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "Gatus"; + icon = "sh:gatus"; + }; }; }; } diff --git a/modules/nixos/web-services/grafana.nix b/modules/nixos/web-services/grafana.nix index 96913ec..e3c3909 100644 --- a/modules/nixos/web-services/grafana.nix +++ b/modules/nixos/web-services/grafana.nix @@ -85,6 +85,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "Grafana"; + icon = "sh:grafana"; + }; + }; }; } diff --git a/modules/nixos/web-services/it-tools.nix b/modules/nixos/web-services/it-tools.nix index 00b2a02..6ad12a2 100644 --- a/modules/nixos/web-services/it-tools.nix +++ b/modules/nixos/web-services/it-tools.nix @@ -17,6 +17,13 @@ in }; config = lib.mkIf cfg.enable { - custom.services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib"; + custom = { + services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib"; + + meta.services.${cfg.domain} = { + title = "IT-Tools"; + icon = "sh:it-tools"; + }; + }; }; } diff --git a/modules/nixos/web-services/karakeep.nix b/modules/nixos/web-services/karakeep.nix index 19d1449..a796faf 100644 --- a/modules/nixos/web-services/karakeep.nix +++ b/modules/nixos/web-services/karakeep.nix @@ -57,6 +57,11 @@ in "/var/lib/karakeep" "/var/lib/meilisearch" ]; + + meta.services.${cfg.domain} = { + title = "Karakeep"; + icon = "sh:karakeep"; + }; }; }; } diff --git a/modules/nixos/web-services/networking-toolbox.nix b/modules/nixos/web-services/networking-toolbox.nix index 96a2e41..fee4ba3 100644 --- a/modules/nixos/web-services/networking-toolbox.nix +++ b/modules/nixos/web-services/networking-toolbox.nix @@ -22,6 +22,13 @@ in pull = "newer"; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "Networking Toolbox"; + icon = "sh:networking-toolbox"; + }; + }; }; } diff --git a/modules/nixos/web-services/ntfy.nix b/modules/nixos/web-services/ntfy.nix index 9cc9dd1..5067d4f 100644 --- a/modules/nixos/web-services/ntfy.nix +++ b/modules/nixos/web-services/ntfy.nix @@ -26,6 +26,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "ntfy"; + icon = "sh:ntfy"; + }; + }; }; } diff --git a/modules/nixos/web-services/outline.nix b/modules/nixos/web-services/outline.nix index fb662c6..767c0e5 100644 --- a/modules/nixos/web-services/outline.nix +++ b/modules/nixos/web-services/outline.nix @@ -85,6 +85,11 @@ in dataDir config.services.postgresql.dataDir ]; + + meta.services.${cfg.domain} = { + title = "Outline"; + icon = "sh:outline"; + }; }; }; } diff --git a/modules/nixos/web-services/personal-blog.nix b/modules/nixos/web-services/personal-blog.nix index 1930a2d..18e37b8 100644 --- a/modules/nixos/web-services/personal-blog.nix +++ b/modules/nixos/web-services/personal-blog.nix @@ -27,6 +27,13 @@ in script = "nix build github:SebastianStork/blog --out-link ${dataDir} --refresh"; }; - custom.services.caddy.virtualHosts.${cfg.domain}.files = dataDir; + custom = { + services.caddy.virtualHosts.${cfg.domain}.files = dataDir; + + meta.services.${cfg.domain} = { + title = "Blog"; + icon = "sh:hugo"; + }; + }; }; } diff --git a/modules/nixos/web-services/privatebin.nix b/modules/nixos/web-services/privatebin.nix index 7285fa9..a708bb6 100644 --- a/modules/nixos/web-services/privatebin.nix +++ b/modules/nixos/web-services/privatebin.nix @@ -37,6 +37,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "PrivateBin"; + icon = "sh:privatebin"; + }; + }; }; } diff --git a/modules/nixos/web-services/radicale.nix b/modules/nixos/web-services/radicale.nix index 7489834..ab87975 100644 --- a/modules/nixos/web-services/radicale.nix +++ b/modules/nixos/web-services/radicale.nix @@ -109,6 +109,11 @@ in }; persistence.directories = [ dataDir ]; + + meta.services.${cfg.domain} = { + title = "Radicale"; + icon = "sh:radicale"; + }; }; }; } diff --git a/modules/nixos/web-services/screego.nix b/modules/nixos/web-services/screego.nix index 7a1d554..1f8d820 100644 --- a/modules/nixos/web-services/screego.nix +++ b/modules/nixos/web-services/screego.nix @@ -26,6 +26,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "Screego"; + icon = "mdi:projector-screen-outline"; + }; + }; }; } diff --git a/modules/nixos/web-services/stirling-pdf.nix b/modules/nixos/web-services/stirling-pdf.nix index a0efb72..97382e4 100644 --- a/modules/nixos/web-services/stirling-pdf.nix +++ b/modules/nixos/web-services/stirling-pdf.nix @@ -40,6 +40,13 @@ in }; }; - custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + custom = { + services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + + meta.services.${cfg.domain} = { + title = "Stirling PDF"; + icon = "sh:stirling-pdf"; + }; + }; }; } From 7fb596cdeb6be01829aff01c224aa8128c0ba58c Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Tue, 10 Mar 2026 00:03:12 +0100 Subject: [PATCH 16/18] glance: Init module --- modules/nixos/web-services/glance.nix | 68 +++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 modules/nixos/web-services/glance.nix diff --git a/modules/nixos/web-services/glance.nix b/modules/nixos/web-services/glance.nix new file mode 100644 index 0000000..498e91c --- /dev/null +++ b/modules/nixos/web-services/glance.nix @@ -0,0 +1,68 @@ +{ + config, + lib, + allHosts, + ... +}: +let + cfg = config.custom.web-services.glance; + + servicesWidgets = + allHosts + |> lib.attrValues + |> lib.map (host: { + hostName = host.config.networking.hostName; + services = host.config.custom.meta.services |> lib.attrValues; + }) + |> lib.filter ({ services, ... }: services != [ ]) + |> lib.map ( + { hostName, services }: + { + type = "monitor"; + cache = "1m"; + title = "Services - ${hostName}"; + sites = services; + } + ); +in +{ + options.custom.web-services.glance = { + enable = lib.mkEnableOption ""; + domain = lib.mkOption { + type = lib.types.nonEmptyStr; + default = ""; + }; + port = lib.mkOption { + type = lib.types.port; + default = 63958; + }; + }; + + config = lib.mkIf cfg.enable { + services.glance = { + enable = true; + + settings = { + server.port = cfg.port; + + pages = lib.singleton { + name = "Home"; + center-vertically = true; + + columns = lib.singleton { + size = "full"; + widgets = + lib.singleton { + type = "search"; + search-engine = "google"; + autofocus = true; + } + ++ servicesWidgets; + }; + }; + }; + }; + + custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; + }; +} From 1ad5ce0ca080fd6515b78b301a2bc34ce9caec5c Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Tue, 10 Mar 2026 00:05:38 +0100 Subject: [PATCH 17/18] srv-core: Enable glance --- hosts/srv-core/configuration.nix | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/hosts/srv-core/configuration.nix b/hosts/srv-core/configuration.nix index 962334b..80844ff 100644 --- a/hosts/srv-core/configuration.nix +++ b/hosts/srv-core/configuration.nix @@ -72,6 +72,11 @@ domain = "status.${config.custom.networking.overlay.domain}"; generateDefaultEndpoints = true; }; + + glance = { + enable = true; + domain = "home.${config.custom.networking.overlay.domain}"; + }; }; }; } From 993b931b00d8c48f5d9aae387528997da428cdaa Mon Sep 17 00:00:00 2001 From: SebastianStork Date: Tue, 10 Mar 2026 00:06:00 +0100 Subject: [PATCH 18/18] srv-core: Disable gatus --- hosts/srv-core/configuration.nix | 6 ------ 1 file changed, 6 deletions(-) diff --git a/hosts/srv-core/configuration.nix b/hosts/srv-core/configuration.nix index 80844ff..1f34570 100644 --- a/hosts/srv-core/configuration.nix +++ b/hosts/srv-core/configuration.nix @@ -67,12 +67,6 @@ domain = "grafana.${config.custom.networking.overlay.domain}"; }; - gatus = { - enable = true; - domain = "status.${config.custom.networking.overlay.domain}"; - generateDefaultEndpoints = true; - }; - glance = { enable = true; domain = "home.${config.custom.networking.overlay.domain}";