Add nzbget

This commit is contained in:
Pim Kunis 2025-03-23 08:28:59 +01:00
parent c70084a7b6
commit b288654567
11 changed files with 203 additions and 576 deletions

View file

@ -10,5 +10,6 @@ _: {
deluge = import ./deluge.nix;
mealie = import ./mealie.nix;
atuin = import ./atuin.nix;
nzbget = import ./nzbget.nix;
};
}

View file

@ -73,7 +73,7 @@ in {
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "deluge") (nglib.mkDefaultRec {
description = "deluge";
group = cfgInit.group;
inherit (cfgInit) group;
createHome = true;
home = "/home/deluge";
useDefaultShell = true;

View file

@ -10,6 +10,7 @@
deluge = 414;
mealie = 415;
atuin = 416;
nzbget = 417;
};
gids = {
@ -23,6 +24,7 @@
deluge = 414;
mealie = 415;
atuin = 416;
nzbget = 417;
};
};
}

49
nixng-modules/nzbget.nix Normal file
View file

@ -0,0 +1,49 @@
{
pkgs,
lib,
nglib,
config,
...
}: let
cfg = config.services.nzbget;
cfgInit = config.init.services.nzbget;
stateDir = "/home/nzbget";
configFile = "${stateDir}/nzbget.conf";
in {
options.services.nzbget = {
enable = lib.mkEnableOption "nzbget";
package = lib.mkPackageOption pkgs "nzbget" {};
};
config = lib.mkIf cfg.enable {
init.services.nzbget = {
enabled = true;
user = lib.mkDefault "nzbget";
group = lib.mkDefault "nzbget";
execStartPre = pkgs.writeShellScript "nzbget-pre.sh" ''
if [ ! -f ${configFile} ]; then
${pkgs.coreutils}/bin/install -m 0700 ${cfg.package}/share/nzbget/nzbget.conf ${configFile}
fi
'';
script = pkgs.writeShellScript "nzbget-run.sh" ''
umask 0002
${lib.getExe cfg.package} --server --configfile ${configFile}
'';
};
environment.systemPackages = with pkgs; [cfg.package unrar p7zip];
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "nzbget") (nglib.mkDefaultRec {
description = "nzbget";
inherit (cfgInit) group;
createHome = true;
home = "/home/nzbget";
useDefaultShell = true;
uid = config.ids.uids.nzbget;
});
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "nzbget") (nglib.mkDefaultRec {gid = config.ids.gids.nzbget;});
};
}