2025-01-03 21:38:24 -07:00
|
|
|
{ lib, ... }:
|
|
|
|
let
|
|
|
|
services = {
|
|
|
|
jellyfin = {
|
|
|
|
hostByte = 2;
|
2025-01-06 01:13:10 -07:00
|
|
|
};
|
|
|
|
jellyseerr = {
|
|
|
|
hostByte = 3;
|
2025-01-03 21:38:24 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
in {
|
|
|
|
config = lib.mkMerge ([{
|
|
|
|
# Config always added
|
|
|
|
networking = {
|
|
|
|
nat = {
|
|
|
|
enable = true;
|
|
|
|
externalInterface = "wlp2s0";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}] ++ builtins.map (serviceName: {
|
|
|
|
# Config added per-service
|
|
|
|
containers.${serviceName} = {
|
|
|
|
privateNetwork = true;
|
|
|
|
# Give it an address of 172.30.0.X on the host-side and 172.30.1.X inside the container
|
|
|
|
# This appears to be necessary as both having addresses the same seems to cause issues
|
|
|
|
hostAddress = "172.30.0.${builtins.toString services.${serviceName}.hostByte}";
|
|
|
|
localAddress = "172.30.1.${builtins.toString services.${serviceName}.hostByte}";
|
|
|
|
};
|
|
|
|
|
|
|
|
networking = {
|
|
|
|
firewall.trustedInterfaces = [ "ve-${serviceName}" ];
|
|
|
|
nat.internalInterfaces = [ "ve-${serviceName}" ];
|
|
|
|
networkmanager.unmanaged = [ "interface-name:ve-${serviceName}" ];
|
|
|
|
};
|
|
|
|
}) (builtins.attrNames services));
|
|
|
|
}
|