Compare commits

...

2 commits

23 changed files with 77 additions and 39 deletions

View file

@ -1,18 +1,22 @@
{ lib, ... }:
{
options.custom.meta.services = lib.mkOption {
options.custom.meta.sites = lib.mkOption {
type = lib.types.attrsOf (
lib.types.submodule (
{ name, ... }:
{ name, config, ... }:
{
options = {
title = lib.mkOption {
type = lib.types.nonEmptyStr;
default = name;
};
domain = lib.mkOption {
type = lib.types.nonEmptyStr;
default = name;
};
url = lib.mkOption {
type = lib.types.nonEmptyStr;
default = "https://${name}";
default = "https://${config.domain}";
};
icon = lib.mkOption {
type = lib.types.nonEmptyStr;

View file

@ -101,7 +101,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Alertmanager";
icon = "sh:prometheus";
};

View file

@ -131,7 +131,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port;
meta.services.${cfg.domain} = lib.mkIf (cfg.domain != null) {
meta.sites.${cfg.domain} = lib.mkIf (cfg.domain != null) {
title = "Alloy";
icon = "sh:grafana-alloy";
};

View file

@ -126,7 +126,7 @@ in
persistence.directories = [ "/var/lib/${config.services.prometheus.stateDir}" ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Prometheus";
icon = "sh:prometheus";
};

View file

@ -171,7 +171,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.gui.domain} = lib.mkIf (cfg.gui.domain != null) {
meta.sites.${cfg.gui.domain} = lib.mkIf (cfg.gui.domain != null) {
title = "Syncthing";
icon = "sh:syncthing";
};

View file

@ -53,7 +53,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Actual Budget";
icon = "sh:actual-budget";
};

View file

@ -48,7 +48,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Atuin";
icon = "sh:atuin";
};

View file

@ -49,7 +49,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "File Browser";
icon = "sh:file-browser";
};

View file

@ -84,7 +84,7 @@ in
persistence.directories = [ config.services.forgejo.stateDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Forgejo";
icon = "sh:forgejo";
};

View file

@ -50,7 +50,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "FreshRSS";
icon = "sh:freshrss";
};

View file

@ -211,7 +211,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Gatus";
icon = "sh:gatus";
};

View file

@ -1,5 +1,6 @@
{
config,
self,
lib,
allHosts,
...
@ -7,23 +8,55 @@
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 }:
{
observabilityTitles = [
"Alloy"
"Prometheus"
"Alertmanager"
];
hosts = allHosts |> lib.attrValues;
applicationSites =
hosts
|> lib.concatMap (host: host.config.custom.meta.sites |> lib.attrValues)
|> lib.filter (service: !lib.elem service.title observabilityTitles)
|> lib.groupBy (
service:
service.domain |> self.lib.isPrivateDomain |> (isPrivate: if isPrivate then "Private" else "Public")
)
|> lib.mapAttrsToList (
name: value: {
type = "monitor";
cache = "1m";
title = "Services - ${hostName}";
sites = services;
title = "${name} Services";
sites = value;
}
);
)
|> (widgets: {
type = "split-column";
max-columns = 2;
inherit widgets;
})
|> lib.singleton;
observabilitySites =
hosts
|> lib.map (host: {
type = "monitor";
cache = "1m";
title = host.config.networking.hostName;
sites =
host.config.custom.meta.sites
|> lib.attrValues
|> lib.filter (service: lib.elem service.title observabilityTitles);
})
|> lib.filter ({ sites, ... }: sites != [ ])
|> (widgets: {
type = "split-column";
max-columns = widgets |> lib.length;
inherit widgets;
})
|> lib.singleton;
in
{
options.custom.web-services.glance = {
@ -57,7 +90,8 @@ in
search-engine = "google";
autofocus = true;
}
++ servicesWidgets;
++ applicationSites
++ observabilitySites;
};
};
};

View file

@ -88,7 +88,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Grafana";
icon = "sh:grafana";
};

View file

@ -20,7 +20,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib";
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "IT-Tools";
icon = "sh:it-tools";
};

View file

@ -58,7 +58,7 @@ in
"/var/lib/meilisearch"
];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Karakeep";
icon = "sh:karakeep";
};

View file

@ -25,7 +25,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Networking Toolbox";
icon = "sh:networking-toolbox";
};

View file

@ -29,7 +29,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "ntfy";
icon = "sh:ntfy";
};

View file

@ -86,7 +86,7 @@ in
config.services.postgresql.dataDir
];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Outline";
icon = "sh:outline";
};

View file

@ -30,7 +30,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.files = dataDir;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Blog";
icon = "sh:hugo";
};

View file

@ -40,7 +40,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "PrivateBin";
icon = "sh:privatebin";
};

View file

@ -110,7 +110,7 @@ in
persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Radicale";
icon = "sh:radicale";
};

View file

@ -29,7 +29,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Screego";
icon = "mdi:projector-screen-outline";
};

View file

@ -43,7 +43,7 @@ in
custom = {
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
meta.sites.${cfg.domain} = {
title = "Stirling PDF";
icon = "sh:stirling-pdf";
};