Compare commits

...

4 commits

23 changed files with 54 additions and 55 deletions

View file

@ -6,7 +6,7 @@
{ name, ... }:
{
options = {
name = lib.mkOption {
title = lib.mkOption {
type = lib.types.nonEmptyStr;
default = name;
};

View file

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

View file

@ -132,8 +132,8 @@ in
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";
title = "Alloy";
icon = "sh:grafana-alloy";
};
};
};

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

@ -6,6 +6,24 @@
}:
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 = {
@ -27,38 +45,19 @@ in
server.port = cfg.port;
pages = lib.singleton {
name = "Services";
name = "Home";
center-vertically = true;
hide-desktop-navigation = true;
columns = lib.singleton {
size = "full";
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";
cache = "1m";
title = "Services - ${hostName}";
sites =
services
|> lib.map (
{
name,
url,
icon,
}:
{
title = name;
inherit url icon;
}
);
}
);
lib.singleton {
type = "search";
search-engine = "google";
autofocus = true;
}
++ servicesWidgets;
};
};
};
@ -68,7 +67,7 @@ in
services.caddy.virtualHosts.${cfg.domain}.port = cfg.port;
meta.services.${cfg.domain} = {
name = "Glance";
title = "Glance";
icon = "sh:glance";
};
};

View file

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

View file

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

View file

@ -59,7 +59,7 @@ in
];
meta.services.${cfg.domain} = {
name = "Karakeep";
title = "Karakeep";
icon = "sh:karakeep";
};
};

View file

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

View file

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

View file

@ -87,7 +87,7 @@ in
];
meta.services.${cfg.domain} = {
name = "Outline";
title = "Outline";
icon = "sh:outline";
};
};

View file

@ -31,8 +31,8 @@ in
services.caddy.virtualHosts.${cfg.domain}.files = dataDir;
meta.services.${cfg.domain} = {
name = "Blog";
icon = "sh:zola";
title = "Blog";
icon = "auto-invert sh:zola";
};
};
};

View file

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

View file

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

View file

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

View file

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