36 lines
1.2 KiB
Nix
36 lines
1.2 KiB
Nix
{ lib, config, ... }:
|
|
let
|
|
cfg = config.my.servers.homepage;
|
|
setup = import ./setup.nix { inherit lib config; };
|
|
in
|
|
{
|
|
options.my.servers.homepage = setup.mkOptions "homepage" "home" 8082;
|
|
config = lib.mkIf config.my.secureHost {
|
|
sops.secrets = lib.mkIf cfg.enable {
|
|
homepage.sopsFile = ../../secrets/homepage.yaml;
|
|
"private-ca/pem" = {
|
|
sopsFile = ../../secrets/certs.yaml;
|
|
owner = "nginx";
|
|
group = "nginx";
|
|
};
|
|
};
|
|
my.servers.homepage.certPath = config.sops.secrets."private-ca/pem".path;
|
|
services.homepage-dashboard = lib.mkIf cfg.enable {
|
|
inherit (cfg) enable;
|
|
listenPort = cfg.port;
|
|
environmentFile = config.sops.secrets.homepage.path;
|
|
settings = {
|
|
providers.openweathermap = "ca54bc3999f608a5ad6e48b9c6c002ec";
|
|
layout = import ./homepage/layout.nix;
|
|
};
|
|
widgets = import ./homepage/widgets.nix;
|
|
services = import ./homepage/services.nix { inherit lib config; };
|
|
bookmarks =
|
|
builtins.readDir ./homepage/bookmarks
|
|
|> builtins.attrNames
|
|
|> builtins.filter (file: builtins.match ".*\\.nix" file != null)
|
|
|> map (file: import ./homepage/bookmarks/${file});
|
|
};
|
|
};
|
|
}
|