Package Deluge with NixNG
Use same group for all media images
This commit is contained in:
parent
a22c34716e
commit
abb7a131bc
15 changed files with 212 additions and 22 deletions
|
@ -34,15 +34,15 @@ in {
|
|||
|
||||
environment.systemPackages = [cfg.package];
|
||||
|
||||
users.users.${cfgInit.user} = nglib.mkDefaultRec {
|
||||
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "bazarr") (nglib.mkDefaultRec {
|
||||
description = "bazarr";
|
||||
group = cfgInit.group;
|
||||
createHome = false;
|
||||
home = "/var/empty";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.bazarr;
|
||||
};
|
||||
});
|
||||
|
||||
users.groups.${cfgInit.group} = nglib.mkDefaultRec {gid = config.ids.gids.bazarr;};
|
||||
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "bazarr") (nglib.mkDefaultRec {gid = config.ids.gids.bazarr;});
|
||||
};
|
||||
}
|
||||
|
|
|
@ -7,5 +7,6 @@
|
|||
sonarr = import ./sonarr.nix;
|
||||
prowlarr = import ./prowlarr.nix;
|
||||
ids = import ./ids.nix;
|
||||
deluge = import ./deluge.nix;
|
||||
};
|
||||
}
|
||||
|
|
85
nixng-modules/deluge.nix
Normal file
85
nixng-modules/deluge.nix
Normal file
|
@ -0,0 +1,85 @@
|
|||
{
|
||||
lib,
|
||||
nglib,
|
||||
config,
|
||||
pkgs,
|
||||
...
|
||||
}: let
|
||||
cfg = config.services.deluge;
|
||||
cfgInit = config.init.services.deluged;
|
||||
in {
|
||||
options.services.deluge = {
|
||||
enable = lib.mkEnableOption "deluge";
|
||||
package = lib.mkPackageOption pkgs "deluge-2_x" {};
|
||||
|
||||
configDir = lib.mkOption {
|
||||
type = lib.types.path;
|
||||
default = "/var/lib/deluge";
|
||||
|
||||
description = ''
|
||||
Directory for Deluge's run-time configuration
|
||||
'';
|
||||
};
|
||||
|
||||
web = {
|
||||
enable = lib.mkEnableOption "Deluge web daemon";
|
||||
|
||||
port = lib.mkOption {
|
||||
type = lib.types.port;
|
||||
default = 8112;
|
||||
description = ''
|
||||
Deluge web UI port
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf cfg.enable {
|
||||
init.services = {
|
||||
deluged = {
|
||||
enabled = true;
|
||||
user = lib.mkDefault "deluge";
|
||||
group = lib.mkDefault "deluge";
|
||||
tmpfiles = with nglib.nottmpfiles.dsl; [(d cfg.configDir "-" cfgInit.user cfgInit.group _ _)];
|
||||
|
||||
script = pkgs.writeShellScript "deluged-run" ''
|
||||
# TODO: make init-level option?
|
||||
umask 0002
|
||||
${cfg.package}/bin/deluged \
|
||||
--do-not-daemonize \
|
||||
--config ${cfg.configDir}
|
||||
'';
|
||||
};
|
||||
|
||||
deluge-web = {
|
||||
enabled = cfg.web.enable;
|
||||
dependencies = ["deluged"];
|
||||
user = lib.mkDefault "deluge";
|
||||
group = lib.mkDefault "deluge";
|
||||
|
||||
script = pkgs.writeShellScript "deluge-web-run" ''
|
||||
${cfg.package}/bin/deluge-web \
|
||||
--do-not-daemonize \
|
||||
--port ${toString cfg.web.port} \
|
||||
--config ${cfg.configDir}
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
environment = {
|
||||
systemPackages = [cfg.package];
|
||||
variables.PYTHON_EGG_CACHE = "${config.users.users.${cfgInit.user}.home}/.cache";
|
||||
};
|
||||
|
||||
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "deluge") (nglib.mkDefaultRec {
|
||||
description = "deluge";
|
||||
group = cfgInit.group;
|
||||
createHome = true;
|
||||
home = "/home/deluge";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.deluge;
|
||||
});
|
||||
|
||||
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "deluge") (nglib.mkDefaultRec {gid = config.ids.gids.deluge;});
|
||||
};
|
||||
}
|
|
@ -7,15 +7,18 @@
|
|||
sonarr = 411;
|
||||
bazarr = 412;
|
||||
prowlarr = 413;
|
||||
deluge = 414;
|
||||
};
|
||||
|
||||
gids = {
|
||||
media = 51;
|
||||
radicale = 408;
|
||||
jellyseerr = 409;
|
||||
radarr = 410;
|
||||
sonarr = 411;
|
||||
bazarr = 412;
|
||||
prowlarr = 413;
|
||||
deluge = 414;
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
|
@ -34,15 +34,15 @@ in {
|
|||
|
||||
environment.systemPackages = [cfg.package];
|
||||
|
||||
users.users.${cfgInit.user} = nglib.mkDefaultRec {
|
||||
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "prowlarr") (nglib.mkDefaultRec {
|
||||
description = "prowlarr";
|
||||
group = cfgInit.group;
|
||||
createHome = false;
|
||||
home = "/var/empty";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.prowlarr;
|
||||
};
|
||||
});
|
||||
|
||||
users.groups.${cfgInit.group} = nglib.mkDefaultRec {gid = config.ids.gids.prowlarr;};
|
||||
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "prowlarr") (nglib.mkDefaultRec {gid = config.ids.gids.prowlarr;});
|
||||
};
|
||||
}
|
||||
|
|
|
@ -32,15 +32,15 @@ in {
|
|||
|
||||
environment.systemPackages = [cfg.package];
|
||||
|
||||
users.users.${cfgInit.user} = nglib.mkDefaultRec {
|
||||
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "radarr") (nglib.mkDefaultRec {
|
||||
description = "radarr";
|
||||
group = cfgInit.group;
|
||||
createHome = false;
|
||||
home = "/var/empty";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.radarr;
|
||||
};
|
||||
});
|
||||
|
||||
users.groups.${cfgInit.group} = nglib.mkDefaultRec {gid = config.ids.gids.radarr;};
|
||||
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "radarr") (nglib.mkDefaultRec {gid = config.ids.gids.radarr;});
|
||||
};
|
||||
}
|
||||
|
|
|
@ -32,15 +32,15 @@ in {
|
|||
|
||||
environment.systemPackages = [cfg.package];
|
||||
|
||||
users.users.${cfgInit.user} = nglib.mkDefaultRec {
|
||||
users.users.${cfgInit.user} = lib.mkIf (cfgInit.user == "sonarr") (nglib.mkDefaultRec {
|
||||
description = "sonarr";
|
||||
group = cfgInit.group;
|
||||
createHome = false;
|
||||
home = "/var/empty";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.sonarr;
|
||||
};
|
||||
});
|
||||
|
||||
users.groups.${cfgInit.group} = nglib.mkDefaultRec {gid = config.ids.gids.sonarr;};
|
||||
users.groups.${cfgInit.group} = lib.mkIf (cfgInit.group == "sonarr") (nglib.mkDefaultRec {gid = config.ids.gids.sonarr;});
|
||||
};
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue