vuls: init at 0.27.0
[NixPkgs.git] / nixos / modules / services / misc / readarr.nix
blobb76a70859f75e46a66ae4fc89a8070fabc72b921
1 { config, pkgs, lib, ... }:
3 with lib;
5 let
6   cfg = config.services.readarr;
7 in
9   options = {
10     services.readarr = {
11       enable = mkEnableOption "Readarr, a Usenet/BitTorrent ebook downloader";
13       dataDir = mkOption {
14         type = types.str;
15         default = "/var/lib/readarr/";
16         description = "The directory where Readarr stores its data files.";
17       };
19       package = mkPackageOption pkgs "readarr" { };
21       openFirewall = mkOption {
22         type = types.bool;
23         default = false;
24         description = ''
25           Open ports in the firewall for Readarr
26         '';
27       };
29       user = mkOption {
30         type = types.str;
31         default = "readarr";
32         description = ''
33           User account under which Readarr runs.
34         '';
35       };
37       group = mkOption {
38         type = types.str;
39         default = "readarr";
40         description = ''
41           Group under which Readarr runs.
42         '';
43       };
44     };
45   };
47   config = mkIf cfg.enable {
48     systemd.tmpfiles.settings."10-readarr".${cfg.dataDir}.d = {
49       inherit (cfg) user group;
50       mode = "0700";
51     };
53     systemd.services.readarr = {
54       description = "Readarr";
55       after = [ "network.target" ];
56       wantedBy = [ "multi-user.target" ];
58       serviceConfig = {
59         Type = "simple";
60         User = cfg.user;
61         Group = cfg.group;
62         ExecStart = "${cfg.package}/bin/Readarr -nobrowser -data='${cfg.dataDir}'";
63         Restart = "on-failure";
64       };
65     };
67     networking.firewall = mkIf cfg.openFirewall {
68       allowedTCPPorts = [ 8787 ];
69     };
71     users.users = mkIf (cfg.user == "readarr") {
72       readarr = {
73         description = "Readarr service";
74         home = cfg.dataDir;
75         group = cfg.group;
76         isSystemUser = true;
77       };
78     };
80     users.groups = mkIf (cfg.group == "readarr") {
81       readarr = { };
82     };
83   };