Compare commits

...

2 commits

Author SHA1 Message Date
Felix Buehler
f1b9c9edca flake: update
Some checks failed
/ Build Nix targets (push) Has been cancelled
2025-05-28 21:55:33 +02:00
Felix Buehler
6d3a814015 service/homer: simplify 2025-05-28 20:48:17 +02:00
3 changed files with 45 additions and 47 deletions

18
flake.lock generated
View file

@ -7,11 +7,11 @@
]
},
"locked": {
"lastModified": 1747742835,
"narHash": "sha256-kYL4GCwwznsypvsnA20oyvW8zB/Dvn6K5G/tgMjVMT4=",
"lastModified": 1748225455,
"narHash": "sha256-AzlJCKaM4wbEyEpV3I/PUq5mHnib2ryEy32c+qfj6xk=",
"owner": "nix-community",
"repo": "disko",
"rev": "df522e787fdffc4f32ed3e1fca9ed0968a384d62",
"rev": "a894f2811e1ee8d10c50560551e50d6ab3c392ba",
"type": "github"
},
"original": {
@ -242,11 +242,11 @@
},
"nixpkgs": {
"locked": {
"lastModified": 1747953325,
"narHash": "sha256-y2ZtlIlNTuVJUZCqzZAhIw5rrKP4DOSklev6c8PyCkQ=",
"lastModified": 1748302896,
"narHash": "sha256-ixMT0a8mM091vSswlTORZj93WQAJsRNmEvqLL+qwTFM=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "55d1f923c480dadce40f5231feb472e81b0bab48",
"rev": "7848cd8c982f7740edf76ddb3b43d234cb80fc4d",
"type": "github"
},
"original": {
@ -296,11 +296,11 @@
},
"nixpkgs-unstable": {
"locked": {
"lastModified": 1747744144,
"narHash": "sha256-W7lqHp0qZiENCDwUZ5EX/lNhxjMdNapFnbErcbnP11Q=",
"lastModified": 1748370509,
"narHash": "sha256-QlL8slIgc16W5UaI3w7xHQEP+Qmv/6vSNTpoZrrSlbk=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "2795c506fe8fb7b03c36ccb51f75b6df0ab2553f",
"rev": "4faa5f5321320e49a78ae7848582f684d64783e9",
"type": "github"
},
"original": {

View file

@ -105,39 +105,46 @@
config =
let
cfg = config.webapps;
appsWithName = builtins.filter (app: app.dashboard.name != null) (lib.attrValues cfg.apps);
in
{
lib.webapps.homerServices =
lib.webapps.homerServices = lib.forEach cfg.dashboardCategories (
category:
let
apps = builtins.filter (a: a.dashboard.name != null) (lib.attrValues cfg.apps);
catTag = category.tag;
catApps = lib.sort (a: b: a.dashboard.name < b.dashboard.name) (
builtins.filter (
app:
let
cat = app.dashboard.category;
in
(cat != null && cat == catTag) || (cat == null && catTag == "misc")
) appsWithName
);
in
lib.forEach cfg.dashboardCategories (
cat:
let
catApps = lib.sort (a: b: a.dashboard.name < b.dashboard.name) (
builtins.filter (
a:
a.dashboard.category != null && a.dashboard.category == cat.tag
|| a.dashboard.category == null && cat.tag == "misc"
) apps
);
in
{
inherit (cat) name;
items = lib.forEach catApps (a: {
inherit (a.dashboard)
{
inherit (category) name;
items = lib.forEach catApps (
app:
let
dash = app.dashboard;
in
{
inherit (dash)
method
name
type
url
;
icon = lib.optionalString (a.dashboard.icon != null) "fas fa-${a.dashboard.icon}";
icon = lib.optionalString (dash.icon != null) "fas fa-${dash.icon}";
target = "_blank";
});
}
);
my.services.blackbox.http_endpoints =
lib.mapAttrsToList (_key: value: value.dashboard.url) config.webapps.apps
++ [ "https://${config.networking.domain}/" ];
}
);
}
);
my.services.blackbox.http_endpoints = lib.mapAttrsToList (_: app: app.dashboard.url) cfg.apps ++ [
"https://${config.networking.domain}/"
];
};
}

View file

@ -10,10 +10,8 @@ let
inherit (config.networking) domain;
homeConfig = {
title = "Dashboard";
header = false;
footer = false;
connectivityCheck = true;
columns = "auto";
services = config.lib.webapps.homerServices;
};
@ -26,18 +24,11 @@ in
};
config = lib.mkIf cfg.enable {
# TODO: 25.05 use stable
services.caddy.virtualHosts.${domain} = {
extraConfig = ''
import common
root * ${pkgs.unstable.homer}
file_server
handle_path /assets/config.yml {
root * ${pkgs.writeText "homerConfig.yml" (builtins.toJSON homeConfig)}
file_server
}
'';
useACMEHost = domain;
services.homer = {
enable = true;
virtualHost.caddy.enable = true;
virtualHost.domain = domain;
settings = homeConfig;
};
webapps = {