summaryrefslogtreecommitdiff
path: root/nixos/lib.nix
diff options
context:
space:
mode:
authorMartin Fischer <martin@push-f.com>2024-12-27 19:46:21 +0100
committerMartin Fischer <martin@push-f.com>2024-12-29 08:53:09 +0100
commit8d0d4995c388062f295e6c1fb1e8c9e5c3259c52 (patch)
treebffbb5f86b0d5b1e430a0f2fe06bcc355b66193b /nixos/lib.nix
parent24a3b1a96e167b809d634878d016a729969278c0 (diff)
feat(ev): add qbittorrent
Diffstat (limited to 'nixos/lib.nix')
-rw-r--r--nixos/lib.nix20
1 files changed, 20 insertions, 0 deletions
diff --git a/nixos/lib.nix b/nixos/lib.nix
index a2d8193..7880cc7 100644
--- a/nixos/lib.nix
+++ b/nixos/lib.nix
@@ -9,4 +9,24 @@ in
unitConfig.JoinsNamespaceOf = "netns@${ns}.service";
serviceConfig.NetworkNamespacePath = "/var/run/netns/${ns}";
};
+
+ mkPortProxy = service: ns: port: {
+ description = "Forward to ${service} in network namespace ${ns}";
+ requires = ["${service}.service"];
+ after = ["${service}.service"];
+ partOf = ["${service}.service"];
+ serviceConfig = {
+ Restart = "on-failure";
+ TimeoutStopSec = 300;
+ };
+ wantedBy = ["multi-user.target"];
+ script =
+ let
+ pkgs = nixpkgs.pkgs;
+ in
+ ''
+ ${pkgs.iproute2}/bin/ip netns exec ${ns} ${pkgs.iproute2}/bin/ip link set dev lo up
+ ${pkgs.socat}/bin/socat tcp-listen:${toString port},fork,reuseaddr exec:'${pkgs.iproute2}/bin/ip netns exec ${ns} ${pkgs.socat}/bin/socat STDIO "tcp-connect:localhost:${toString port}"',nofork
+ '';
+ };
}