1 { pkgs, lib, config, hostName, inputs, ... }:
3 inherit (config.services) transmission;
4 inherit (config.users) users;
5 inherit (config.security) gnupg;
7 wg-intra-peers = import (inputs.julm-nix + "/nixos/profiles/wireguard/wg-intra/peers.nix");
10 users.groups.transmission.members = [
14 services.netns.namespaces.${netns}.nftables = ''
17 meta l4proto { udp, tcp } \
18 th dport ${toString transmission.settings.peer-port} \
19 counter accept comment "transmission"
22 skuid ${transmission.user} counter accept comment "transmission"
26 #users.groups.keys.members = [ transmission.user ];
27 security.gnupg.secrets."transmission/settings.json" = {
28 user = transmission.user;
29 systemdConfig.before = [ "transmission.service" ];
30 systemdConfig.wantedBy = [ "transmission.service" ];
32 fileSystems."/var/lib/transmission" = {
33 device = "${hostName}/var/torrents";
36 systemd.services.transmission = {
38 "netns-${netns}.service"
42 "netns-${netns}.service"
46 unitConfig.JoinsNamespaceOf = ["netns-${netns}.service"];
47 serviceConfig.BindReadOnlyPaths = ["/etc/netns/${netns}/resolv.conf:/etc/resolv.conf"];
48 serviceConfig.PrivateNetwork = true;
49 #serviceConfig.NetworkNamespacePath = "/var/run/netns/${netns}";
51 systemd.sockets.proxy-to-transmission = {
52 wantedBy = ["sockets.target"];
53 listenStreams = ["${wg-intra-peers.${hostName}.ipv4}:9091"];
54 socketConfig.FreeBind = true;
56 systemd.services.proxy-to-transmission = {
57 requires = ["transmission.service"];
58 after = ["transmission.service" "proxy-to-transmission.socket"];
59 unitConfig.JoinsNamespaceOf = ["netns-${netns}.service"];
61 ExecStart = "${pkgs.systemd}/lib/systemd/systemd-socket-proxyd 127.0.0.1:9091";
62 PrivateNetwork = true;
66 systemd.services.stop-transmission = {
67 serviceConfig.Type = "oneshot";
68 unitConfig.Conflicts = ["transmission.service"];
69 startAt = "06..19:0,15,30,45:00";
72 services.transmission = {
74 performanceNetParameters = true;
75 credentialsFile = gnupg.secrets."transmission/settings.json".path;
78 download-dir = "/var/lib/transmission/downloaded";
79 incomplete-dir = "/var/lib/transmission/.incoming";
80 incomplete-dir-enabled = true;
81 watch-dir = "/var/lib/transmission/.torrents";
82 watch-dir-enabled = true;
83 trash-original-torrent-files = false;
85 umask = 7; # 007 octal, in decimal!
86 download-queue-enabled = true;
87 download-queue-size = 5;
88 peer-id-ttl-hours = 6;
89 peer-limit-global = 1000;
90 peer-limit-per-torrent = 100;
93 peer-port-random-on-start = false;
98 port-forwarding-enabled = true;
99 scrape-paused-torrents-enabled = false;
100 peer-socket-tos = "lowcost";
101 queue-stalled-enabled = true;
102 queue-stalled-minutes = 30;
103 speed-limit-down-enabled = false;
105 speed-limit-up-enabled = true;
106 alt-speed-enabled = true;
107 alt-speed-time-enabled = true;
108 alt-speed-down = 1000;
110 alt-speed-time-day = 127; # all days. 65; # weekend only
111 alt-speed-time-begin = 360; # 06h00 local time
112 alt-speed-time-end = 1260; # 21h00 local time
114 ratio-limit-enabled = true;
117 rpc-bind-address = "127.0.0.1";
119 rpc-whitelist = "127.0.0.1,${wg-intra-peers.${hostName}.ipv4}/24";
120 rpc-whitelist-enabled = true;
121 rpc-host-whitelist = "localhost,${hostName}.wg";
122 rpc-host-whitelist-enabled = true;
123 rpc-authentication-required = true;