{ config, pkgs, lib, ... }: with lib; let cfg = config.services.lidarr; in { options = { services.lidarr = { enable = mkEnableOption "Lidarr"; dataDir = mkOption { type = types.str; default = "/var/lib/lidarr/.config/Lidarr"; description = lib.mdDoc "The directory where Lidarr stores its data files."; }; package = mkOption { type = types.package; default = pkgs.lidarr; defaultText = literalExpression "pkgs.lidarr"; description = lib.mdDoc "The Lidarr package to use"; }; openFirewall = mkOption { type = types.bool; default = false; description = lib.mdDoc '' Open ports in the firewall for Lidarr ''; }; user = mkOption { type = types.str; default = "lidarr"; description = lib.mdDoc '' User account under which Lidarr runs. ''; }; group = mkOption { type = types.str; default = "lidarr"; description = lib.mdDoc '' Group under which Lidarr runs. ''; }; }; }; config = mkIf cfg.enable { systemd.tmpfiles.rules = [ "d '${cfg.dataDir}' 0700 ${cfg.user} ${cfg.group} - -" ]; systemd.services.lidarr = { description = "Lidarr"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "simple"; User = cfg.user; Group = cfg.group; ExecStart = "${cfg.package}/bin/Lidarr -nobrowser -data='${cfg.dataDir}'"; Restart = "on-failure"; }; }; networking.firewall = mkIf cfg.openFirewall { allowedTCPPorts = [ 8686 ]; }; users.users = mkIf (cfg.user == "lidarr") { lidarr = { group = cfg.group; home = "/var/lib/lidarr"; uid = config.ids.uids.lidarr; }; }; users.groups = mkIf (cfg.group == "lidarr") { lidarr = { gid = config.ids.gids.lidarr; }; }; }; }