Compare commits

..

No commits in common. "f38cb764e0cf851f551a8a563ecdc022f1abd465" and "2d9a779fb19b2b076a5c54024bf77ebce470d31c" have entirely different histories.

23 changed files with 29 additions and 196 deletions

View file

@ -1,27 +0,0 @@
{ 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 = { };
};
}

View file

@ -98,13 +98,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Alertmanager";
icon = "sh:prometheus";
};
};
}; };
} }

View file

@ -128,13 +128,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = lib.mkIf (cfg.domain != null) cfg.port;
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";
};
};
}; };
} }

View file

@ -125,11 +125,6 @@ in
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
persistence.directories = [ "/var/lib/${config.services.prometheus.stateDir}" ]; persistence.directories = [ "/var/lib/${config.services.prometheus.stateDir}" ];
meta.services.${cfg.domain} = {
name = "Prometheus";
icon = "sh:prometheus";
};
}; };
}; };
} }

View file

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

View file

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

View file

@ -47,11 +47,6 @@ in
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
persistence.directories = [ dataDir ]; persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
name = "Atuin";
icon = "sh:atuin";
};
}; };
}; };
} }

View file

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

View file

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

View file

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

View file

@ -210,11 +210,6 @@ in
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port; services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
persistence.directories = [ dataDir ]; persistence.directories = [ dataDir ];
meta.services.${cfg.domain} = {
name = "Gatus";
icon = "sh:gatus";
};
}; };
}; };
} }

View file

@ -28,49 +28,34 @@ in
pages = lib.singleton { pages = lib.singleton {
name = "Services"; name = "Services";
columns = lib.singleton { columns = [
{
size = "full"; size = "full";
widgets = widgets = [
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"; type = "monitor";
cache = "1m"; cache = "1m";
title = "Services - ${hostName}"; title = "Services";
sites = sites =
services allHosts
|> lib.attrValues
|> lib.map ( |> lib.map (
{ host:
name, host.config.custom.services.caddy.virtualHosts |> lib.attrValues |> lib.map (vHost: vHost.domain)
url, )
icon, |> lib.concatLists
}: |> lib.map (domain: {
{ title = domain;
title = name; url = "https://${domain}";
inherit url icon; });
} }
); ];
} }
); ];
};
}; };
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Glance";
icon = "sh:glance";
};
};
}; };
} }

View file

@ -85,13 +85,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Grafana";
icon = "sh:grafana";
};
};
}; };
} }

View file

@ -17,13 +17,6 @@ in
}; };
config = lib.mkIf cfg.enable { config = lib.mkIf cfg.enable {
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib";
services.caddy.virtualHosts.${cfg.domain}.files = "${pkgs.it-tools}/lib";
meta.services.${cfg.domain} = {
name = "IT-Tools";
icon = "sh:it-tools";
};
};
}; };
} }

View file

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

View file

@ -22,13 +22,6 @@ in
pull = "newer"; pull = "newer";
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Networking Toolbox";
icon = "sh:networking-toolbox";
};
};
}; };
} }

View file

@ -26,13 +26,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "ntfy";
icon = "sh:ntfy";
};
};
}; };
} }

View file

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

View file

@ -27,13 +27,6 @@ in
script = "nix build github:SebastianStork/blog --out-link ${dataDir} --refresh"; script = "nix build github:SebastianStork/blog --out-link ${dataDir} --refresh";
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.files = dataDir;
services.caddy.virtualHosts.${cfg.domain}.files = dataDir;
meta.services.${cfg.domain} = {
name = "Blog";
icon = "sh:zola";
};
};
}; };
} }

View file

@ -37,13 +37,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "PrivateBin";
icon = "sh:privatebin";
};
};
}; };
} }

View file

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

View file

@ -26,13 +26,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Screego";
icon = "mdi:projector-screen-outline";
};
};
}; };
} }

View file

@ -40,13 +40,6 @@ in
}; };
}; };
custom = { custom.services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Stirling PDF";
icon = "sh:stirling-pdf";
};
};
}; };
} }