From aa0a3bf6c9a1f52851e74183bb9765a8750005ac Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Sun, 7 Mar 2021 16:04:45 +0000 Subject: [PATCH] services: transmission: more configurable settings --- services/transmission.nix | 42 ++++++++++++++++++++++++++++----------- 1 file changed, 30 insertions(+), 12 deletions(-) diff --git a/services/transmission.nix b/services/transmission.nix index fecd7de..59100d8 100644 --- a/services/transmission.nix +++ b/services/transmission.nix @@ -9,26 +9,44 @@ let domain = config.networking.domain; webuiDomain = "transmission.${domain}"; - - transmissionRpcPort = 9091; - transmissionPeerPort = 30251; - - downloadBase = "/data/downloads/"; # NOTE: to be excluded from backups in { options.my.services.transmission = with lib; { enable = mkEnableOption "Transmission torrent client"; + username = mkOption { type = types.str; default = "Ambroisie"; example = "username"; description = "Name of the transmission RPC user"; }; + password = mkOption { type = types.str; example = "password"; description = "Password of the transmission RPC user"; }; + + downloadBase = mkOption { + type = types.str; + default = "/data/downloads/"; + example = "/var/lib/transmission/download"; + description = "Download base directory"; + }; + + privatePort = mkOption { + type = types.port; + default = 9091; + example = 8080; + description = "Internal port for webui"; + }; + + peerPort = mkOption { + type = types.port; + default = 30251; + example = 32323; + description = "Peering port"; + }; }; config = lib.mkIf cfg.enable { @@ -39,13 +57,13 @@ in downloadDirPermissions = "775"; settings = { - download-dir = "${downloadBase}/complete"; - incomplete-dir = "${downloadBase}/incomplete"; + download-dir = "${cfg.downloadBase}/complete"; + incomplete-dir = "${cfg.downloadBase}/incomplete"; - peer-port = transmissionPeerPort; + peer-port = cfg.peerPort; rpc-enabled = true; - rpc-port = transmissionRpcPort; + rpc-port = cfg.privatePort; rpc-authentication-required = true; rpc-username = cfg.username; @@ -63,12 +81,12 @@ in forceSSL = true; useACMEHost = domain; - locations."/".proxyPass = "http://localhost:${toString transmissionRpcPort}"; + locations."/".proxyPass = "http://localhost:${toString cfg.privatePort}"; }; networking.firewall = { - allowedTCPPorts = [ transmissionPeerPort ]; - allowedUDPPorts = [ transmissionPeerPort ]; + allowedTCPPorts = [ cfg.peerPort ]; + allowedUDPPorts = [ cfg.peerPort ]; }; }; }