Compare commits

..

5 commits

24 changed files with 232 additions and 13 deletions

View file

@ -67,10 +67,9 @@
domain = "grafana.${config.custom.networking.overlay.domain}";
};
gatus = {
glance = {
enable = true;
domain = "status.${config.custom.networking.overlay.domain}";
generateDefaultEndpoints = true;
domain = "home.${config.custom.networking.overlay.domain}";
};
};
};

View file

@ -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 = { };
};
}

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}

View file

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

View file

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

View file

@ -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";
};
};
};
}

View file

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

View file

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

View file

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

View file

@ -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";
};
};
};
}

View file

@ -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;
};
}

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}

View file

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

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}

View file

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

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}

View file

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

View file

@ -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";
};
};
};
}

View file

@ -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";
};
};
};
}