# Torrent and usenet meta-indexers { config, lib, ... }: let cfg = config.my.services.indexers; jackettPort = 9117; nzbhydraPort = 5076; prowlarrPort = 9696; in { options.my.services.indexers = with lib; { jackett.enable = mkEnableOption "Jackett torrent meta-indexer"; nzbhydra.enable = mkEnableOption "NZBHydra2 usenet meta-indexer"; prowlarr.enable = mkEnableOption "Prowlarr torrent & usenet meta-indexer"; }; config = lib.mkMerge [ (lib.mkIf cfg.jackett.enable { services.jackett = { enable = true; }; # Jackett wants to eat *all* my RAM if left to its own devices systemd.services.jackett = { serviceConfig = { MemoryHigh = "15%"; MemoryMax = "25%"; }; }; my.services.nginx.virtualHosts = { jackett = { port = jackettPort; }; }; my.system.persist.directories = [ config.services.jackett.dataDir ]; }) (lib.mkIf cfg.nzbhydra.enable { services.nzbhydra2 = { enable = true; }; my.services.nginx.virtualHosts = { nzbhydra = { port = nzbhydraPort; }; }; my.system.persist.directories = [ config.services.nzbhydra2.dataDir ]; }) (lib.mkIf cfg.prowlarr.enable { services.prowlarr = { enable = true; }; my.services.nginx.virtualHosts = { prowlarr = { port = prowlarrPort; }; }; my.system.persist.directories = [ "/var/lib/prowlarr" ]; services.fail2ban.jails = { prowlarr = '' enabled = true filter = prowlarr action = iptables-allports ''; }; environment.etc = { "fail2ban/filter.d/prowlarr.conf".text = '' [Definition] failregex = ^.*\|Warn\|Auth\|Auth-Failure ip <HOST> username .*$ journalmatch = _SYSTEMD_UNIT=prowlarr.service ''; }; }) ]; }