NixOS/modules/servers/kavita.nix
2024-11-06 01:55:23 -06:00

33 lines
935 B
Nix

{ lib, config, ... }:
let
cfg = config.my.servers.kavita;
setup = import ./setup.nix { inherit lib config; };
in
{
options.my.servers.kavita = setup.mkOptions "kavita" "library" config.services.kavita.settings.Port;
config = {
networking.firewall.allowedTCPPorts = lib.mkIf (!cfg.isLocal) [ cfg.port ];
sops.secrets.kavita-token = lib.mkIf cfg.enable {
owner = config.users.users.kavita.name;
inherit (config.users.users.kavita) group;
};
users.users.kavita = lib.mkIf cfg.enable {
isSystemUser = true;
group = "kavita";
extraGroups = [
"users"
"piracy"
];
};
services = {
kavita = lib.mkIf cfg.enable {
enable = true;
tokenKeyFile = config.sops.secrets.kavita-token.path;
};
nginx.virtualHosts."${cfg.host}" = lib.mkIf cfg.enableProxy (
setup.proxyReverse cfg.hostName cfg.port // { }
);
};
};
}