1 { pkgs, lib, config, inputs, hosts, hostName, ... }:
7 networking.nftables.ruleset = ''
10 udp dport ${toString listenPort} counter accept comment "${wgIface}"
16 iifname ${wgIface} jump input-extra
17 iifname ${wgIface} log level warn prefix "input-extra: " counter drop
25 oifname ${wgIface} jump output-extra
26 oifname ${wgIface} log level warn prefix "output-extra: " counter drop
30 iifname ${wgIface} counter accept
34 #boot.kernel.sysctl."net.ipv4.ip_forward" = 1;
35 systemd.services."wireguard-${wgIface}".serviceConfig.LoadCredentialEncrypted =
36 [ "privateKey:${inputs.self}/hosts/${hostName}/networking/wireguard/${wgIface}/privateKey.cred" ];
37 networking.wireguard.interfaces."${wgIface}" = {
38 # publicKey: 1Iyq96rPHfyrt4B31NqKLgWzlglkMAWjA41aF279gjM=
39 privateKeyFile = "$CREDENTIALS_DIRECTORY/privateKey";
40 ips = [ "192.168.43.1/32" ];
42 socketNamespace = null;
44 interfaceNamespace = "extra";
46 ${pkgs.iproute}/bin/ip netns add extra
51 publicKey = "Ul1+GINJ/eXy7MhUQLB6wXboLUfKW32nwHd/IAGtwSk=";
52 allowedIPs = [ "192.168.43.2/32" ];
55 publicKey = "7hdI8aInfxFG0Ua1jHMDmx1RezI1q1PObFx6Kp2g5iI=";
56 allowedIPs = [ "192.168.43.3/32" ];