3
0
Fork 0
forked from mirrors/nixpkgs

Merge pull request #56062 from elseym/jackett-module

jackett module: add more options and refactor
This commit is contained in:
Elis Hirwing 2019-02-20 09:14:36 +01:00 committed by GitHub
commit f342be2c06
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -4,11 +4,36 @@ with lib;
let let
cfg = config.services.jackett; cfg = config.services.jackett;
in in
{ {
options = { options = {
services.jackett = { services.jackett = {
enable = mkEnableOption "Jackett"; enable = mkEnableOption "Jackett";
dataDir = mkOption {
type = types.str;
default = "/var/lib/jackett/.config/Jackett";
description = "The directory where Jackett stores its data files.";
};
openFirewall = mkOption {
type = types.bool;
default = false;
description = "Open ports in the firewall for the Jackett web interface.";
};
user = mkOption {
type = types.str;
default = "jackett";
description = "User account under which Jackett runs.";
};
group = mkOption {
type = types.str;
default = "jackett";
description = "Group under which Jackett runs.";
};
}; };
}; };
@ -18,30 +43,38 @@ in
after = [ "network.target" ]; after = [ "network.target" ];
wantedBy = [ "multi-user.target" ]; wantedBy = [ "multi-user.target" ];
preStart = '' preStart = ''
test -d /var/lib/jackett/ || { test -d ${cfg.dataDir} || {
echo "Creating jackett data directory in /var/lib/jackett/" echo "Creating jackett data directory in ${cfg.dataDir}"
mkdir -p /var/lib/jackett/ mkdir -p ${cfg.dataDir}
} }
chown -R jackett:jackett /var/lib/jackett/ chown -R ${cfg.user}:${cfg.group} ${cfg.dataDir}
chmod 0700 /var/lib/jackett/ chmod 0700 ${cfg.dataDir}
''; '';
serviceConfig = { serviceConfig = {
Type = "simple"; Type = "simple";
User = "jackett"; User = cfg.user;
Group = "jackett"; Group = cfg.group;
PermissionsStartOnly = "true"; PermissionsStartOnly = "true";
ExecStart = "${pkgs.jackett}/bin/Jackett"; ExecStart = "${pkgs.jackett}/bin/Jackett --NoUpdates --DataFolder '${cfg.dataDir}'";
Restart = "on-failure"; Restart = "on-failure";
}; };
}; };
users.users.jackett = { networking.firewall = mkIf cfg.openFirewall {
uid = config.ids.uids.jackett; allowedTCPPorts = [ 9117 ];
home = "/var/lib/jackett";
group = "jackett";
}; };
users.groups.jackett.gid = config.ids.gids.jackett;
users.users = mkIf (cfg.user == "jackett") {
jackett = {
group = cfg.group;
home = cfg.dataDir;
uid = config.ids.uids.jackett;
};
};
users.groups = mkIf (cfg.group == "jackett") {
jackett.gid = config.ids.gids.jackett;
};
}; };
} }