nixos/calibre-server: Allow multiple libraries

Also add options for group and user.
This commit is contained in:
Sebastian Zivota 2020-05-15 17:53:07 +02:00
parent 6803bc6882
commit 4560d7ed70

View File

@ -9,24 +9,42 @@ let
in in
{ {
imports = [
(mkChangedOptionModule [ "services" "calibre-server" "libraryDir" ] [ "services" "calibre-server" "libraries" ]
(config:
let libraryDir = getAttrFromPath [ "services" "calibre-server" "libraryDir" ] config;
in [ libraryDir ]
)
)
];
###### interface ###### interface
options = { options = {
services.calibre-server = { services.calibre-server = {
enable = mkEnableOption "calibre-server"; enable = mkEnableOption "calibre-server";
libraryDir = mkOption { libraries = mkOption {
description = '' description = ''
The directory where the Calibre library to serve is. The directories of the libraries to serve. They must be readable for the user under which the server runs.
''; '';
type = types.path; type = types.listOf types.path;
};
user = mkOption {
description = "The user under which calibre-server runs.";
type = types.str;
default = "calibre-server";
};
group = mkOption {
description = "The group under which calibre-server runs.";
type = types.str;
default = "calibre-server";
}; };
}; };
}; };
@ -34,29 +52,34 @@ in
config = mkIf cfg.enable { config = mkIf cfg.enable {
systemd.services.calibre-server = systemd.services.calibre-server = {
{
description = "Calibre Server"; description = "Calibre Server";
after = [ "network.target" ]; after = [ "network.target" ];
wantedBy = [ "multi-user.target" ]; wantedBy = [ "multi-user.target" ];
serviceConfig = { serviceConfig = {
User = "calibre-server"; User = cfg.user;
Restart = "always"; Restart = "always";
ExecStart = "${pkgs.calibre}/bin/calibre-server ${cfg.libraryDir}"; ExecStart = "${pkgs.calibre}/bin/calibre-server ${lib.concatStringsSep " " cfg.libraries}";
}; };
}; };
environment.systemPackages = [ pkgs.calibre ]; environment.systemPackages = [ pkgs.calibre ];
users.users.calibre-server = { users.users = optionalAttrs (cfg.user == "calibre-server") {
calibre-server = {
home = "/var/lib/calibre-server";
createHome = true;
uid = config.ids.uids.calibre-server; uid = config.ids.uids.calibre-server;
group = "calibre-server"; group = cfg.group;
}; };
};
users.groups.calibre-server = { users.groups = optionalAttrs (cfg.group == "calibre-server") {
calibre-server = {
gid = config.ids.gids.calibre-server; gid = config.ids.gids.calibre-server;
}; };
};
}; };