2020-11-01 14:25:17 +00:00
|
|
|
# SPDX-FileCopyrightText: 2020 Luke Granger-Brown <depot@lukegb.com>
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2022-01-23 16:57:20 +00:00
|
|
|
{ depot, lib, pkgs, config, ... }:
|
2020-11-01 14:25:17 +00:00
|
|
|
let
|
|
|
|
inherit (depot.ops) secrets;
|
|
|
|
in {
|
2021-08-30 18:58:21 +00:00
|
|
|
imports = [
|
|
|
|
# We include this just so it sets some sysctls and firewall settings.
|
|
|
|
../lib/bgp.nix
|
|
|
|
];
|
|
|
|
|
2020-11-01 14:25:17 +00:00
|
|
|
boot.initrd.availableKernelModules = [
|
|
|
|
"sd_mod"
|
|
|
|
"ahci"
|
|
|
|
"usb_storage"
|
|
|
|
"usbhid"
|
|
|
|
];
|
|
|
|
boot.kernelParams = [ "mitigations=off" ];
|
|
|
|
|
|
|
|
fileSystems = {
|
|
|
|
"/" = {
|
|
|
|
device = "/dev/disk/by-uuid/fc964ef6-e3d0-4472-bc0e-f96f977ebf11";
|
|
|
|
fsType = "ext4";
|
|
|
|
};
|
|
|
|
"/boot" = {
|
|
|
|
device = "/dev/disk/by-uuid/AB36-5BE4";
|
|
|
|
fsType = "vfat";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-01-30 20:30:20 +00:00
|
|
|
nix.settings.max-jobs = lib.mkDefault 4;
|
2020-11-01 14:25:17 +00:00
|
|
|
|
|
|
|
# Use the systemd-boot EFI boot loader.
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
|
|
boot.loader.efi.canTouchEfiVariables = true;
|
|
|
|
|
|
|
|
# Networking!
|
|
|
|
networking = {
|
2021-08-30 18:58:21 +00:00
|
|
|
# Routing tables:
|
|
|
|
# bgp (150) -- contains default routes over WG tunnels
|
2022-01-14 19:42:06 +00:00
|
|
|
# wg-vm (151) -- contains default routes over WG tunnels
|
|
|
|
# wg-ee (152) -- contains default routes over WG tunnels
|
|
|
|
# wg-gnet (153) -- contains default routes over WG tunnels
|
|
|
|
# ee (201) -- table contains a default route via EE
|
|
|
|
# vm (202) -- table contains a default route via VM
|
|
|
|
# gnet (203) -- table contains a default route via gnetwork
|
|
|
|
# main (254) -- basically empty
|
2021-08-30 18:58:21 +00:00
|
|
|
|
2020-11-01 14:25:17 +00:00
|
|
|
hostName = "swann"; # Define your hostname.
|
2021-04-10 20:15:30 +00:00
|
|
|
domain = "int.as205479.net";
|
2020-11-01 14:25:17 +00:00
|
|
|
nameservers = ["8.8.8.8" "8.8.4.4"];
|
2022-01-14 19:42:06 +00:00
|
|
|
useNetworkd = true;
|
2020-11-01 14:25:17 +00:00
|
|
|
interfaces = {
|
2021-08-30 18:58:21 +00:00
|
|
|
lo = {
|
|
|
|
ipv4.addresses = [
|
|
|
|
{ address = "127.0.0.1"; prefixLength = 8; }
|
|
|
|
{ address = "92.118.30.254"; prefixLength = 32; }
|
2021-09-25 17:38:21 +00:00
|
|
|
{ address = "92.118.30.253"; prefixLength = 32; }
|
2021-08-30 18:58:21 +00:00
|
|
|
];
|
|
|
|
};
|
|
|
|
en-virginmedia = {
|
2020-11-01 14:25:17 +00:00
|
|
|
useDHCP = true;
|
2021-07-15 12:18:07 +00:00
|
|
|
macAddress = "e4:3a:6e:16:07:61";
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
2022-01-14 19:42:06 +00:00
|
|
|
en-gnet = {
|
|
|
|
useDHCP = true;
|
|
|
|
# Additional options configured in networkd.
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
en-ee = {
|
2022-01-14 19:42:06 +00:00
|
|
|
useDHCP = true;
|
|
|
|
# Additional options configured in networkd.
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
|
|
|
en-general = {
|
2020-11-01 14:25:17 +00:00
|
|
|
ipv4.addresses = [
|
|
|
|
{ address = "192.168.1.1"; prefixLength = 23; }
|
2021-09-30 16:07:12 +00:00
|
|
|
{ address = "92.118.30.17"; prefixLength = 28; }
|
2020-11-01 14:25:17 +00:00
|
|
|
];
|
2021-05-13 10:14:42 +00:00
|
|
|
ipv6.addresses = [
|
2021-08-30 18:58:21 +00:00
|
|
|
{ address = "2a09:a443::1"; prefixLength = 64; }
|
|
|
|
{ address = "2a09:a443:1::1"; prefixLength = 48; }
|
2021-05-13 10:14:42 +00:00
|
|
|
];
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
2021-09-25 17:38:21 +00:00
|
|
|
vl-eduroam = {
|
|
|
|
ipv4.addresses = [
|
|
|
|
{ address = "192.168.10.1"; prefixLength = 24; }
|
|
|
|
];
|
|
|
|
ipv6.addresses = [
|
|
|
|
{ address = "2a09:a443:2::1"; prefixLength = 64; }
|
|
|
|
{ address = "2a09:a443:3::1"; prefixLength = 48; }
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
vlans = {
|
|
|
|
vl-eduroam = {
|
|
|
|
id = 100;
|
|
|
|
interface = "en-general";
|
|
|
|
};
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
|
|
|
|
localCommands = let
|
|
|
|
claimedPriorities = { min = 10000; max = 10100; };
|
|
|
|
rules = [
|
|
|
|
# Route traffic to EE via WG... via EE.
|
|
|
|
{ priority = 10000; both = "fwmark 0xdead table 201"; }
|
2022-01-14 19:42:06 +00:00
|
|
|
# Route traffic to VM via WG... via VM DHCP in table 202.
|
|
|
|
{ priority = 10001; both = "fwmark 0xbeef table 202"; }
|
|
|
|
# Route traffic to GNetwork via WG... via DHCP in table 203.
|
|
|
|
{ priority = 10002; both = "fwmark 0xcafe table 203"; }
|
2021-08-30 18:58:21 +00:00
|
|
|
|
|
|
|
# Make ping work over the tunnels.
|
|
|
|
{ priority = 10010; v4 = "from 92.118.30.0 table 151"; v6 = "from 2a09:a441::1:1 table 151"; }
|
|
|
|
{ priority = 10011; v4 = "from 92.118.30.2 table 152"; v6 = "from 2a09:a441::2:1 table 152"; }
|
2022-01-14 19:42:06 +00:00
|
|
|
{ priority = 10012; v4 = "from 92.118.30.4 table 153"; v6 = "from 2a09:a441::3:1 table 153"; }
|
2021-08-30 18:58:21 +00:00
|
|
|
|
|
|
|
# Now some subset of RFC1918 via main table too.
|
|
|
|
{ priority = 10020; v4 = "to 192.168.0.0/16 table main"; }
|
|
|
|
{ priority = 10021; v4 = "to 10.0.0.0/8 table main"; }
|
|
|
|
{ priority = 10022; v4 = "to 172.16.0.0/12 table main"; }
|
|
|
|
|
|
|
|
# And the linknets...
|
|
|
|
{ priority = 10023; v4 = "to 92.118.30.0/24 table main"; }
|
|
|
|
{ priority = 10024; v6 = "to 2a09:a441::1:0/112 table main"; }
|
|
|
|
{ priority = 10025; v6 = "to 2a09:a441::2:0/112 table main"; }
|
2022-01-14 19:42:06 +00:00
|
|
|
{ priority = 10026; v6 = "to 2a09:a441::3:0/112 table main"; }
|
2021-09-03 12:40:52 +00:00
|
|
|
|
|
|
|
# add-on.ee.co.uk goes via EE.
|
|
|
|
{ priority = 10031; v4 = "to 82.192.97.153/32 table 201"; }
|
|
|
|
|
|
|
|
# Anything originating from 192.168.200.0/24 should go via EE too.
|
|
|
|
{ priority = 10032; v4 = "from 192.168.200.0/24 table 201"; }
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
# Everything else over WG.
|
2022-01-14 19:42:06 +00:00
|
|
|
{ priority = 10080; both = "table 150"; }
|
|
|
|
|
|
|
|
# Fallbacks via GNetwork, VM, EE
|
|
|
|
# Sometimes this seems to be required to get things moving, for some super unclear reason.
|
|
|
|
{ priority = 10090; both = "table 203"; }
|
|
|
|
{ priority = 10091; both = "table 202"; }
|
|
|
|
{ priority = 10092; both = "table 201"; }
|
2021-08-30 18:58:21 +00:00
|
|
|
];
|
|
|
|
clearRules = map (x: ''
|
|
|
|
ip -4 rule del priority ${toString x} >/dev/null 2>&1 || true
|
|
|
|
ip -6 rule del priority ${toString x} >/dev/null 2>&1 || true
|
|
|
|
'') (lib.range claimedPriorities.min (claimedPriorities.max - 1));
|
|
|
|
ruleToLine = { priority, v4 ? "", v6 ? "", both ? "" }:
|
|
|
|
assert (both == "" || (v4 == "" && v6 == ""));
|
|
|
|
assert priority >= claimedPriorities.min;
|
|
|
|
assert priority < claimedPriorities.max;
|
|
|
|
let
|
|
|
|
rv4 = if v4 != "" then v4 else both;
|
|
|
|
rv6 = if v6 != "" then v6 else both;
|
|
|
|
in ''
|
|
|
|
${if rv4 != "" then "ip -4 rule add ${rv4} priority ${toString priority}" else ""}
|
|
|
|
${if rv6 != "" then "ip -6 rule add ${rv6} priority ${toString priority}" else ""}
|
|
|
|
'';
|
|
|
|
addRules = map ruleToLine rules;
|
|
|
|
in ''
|
2022-03-02 00:32:31 +00:00
|
|
|
# Fix Tailscale, by adding routing rules just before the one they add at prio 5200.
|
|
|
|
ip -4 rule del priority 5196 || true
|
|
|
|
ip -4 rule del priority 5197 || true
|
|
|
|
ip -4 rule del priority 5198 || true
|
|
|
|
ip -4 rule del priority 5199 || true
|
|
|
|
ip -4 rule add from all fwmark 0x80000 lookup 150 priority 5196
|
|
|
|
ip -4 rule add from all fwmark 0x80000 lookup 151 priority 5197
|
|
|
|
ip -4 rule add from all fwmark 0x80000 lookup 152 priority 5198
|
|
|
|
ip -4 rule add from all fwmark 0x80000 lookup 153 priority 5199
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
${lib.concatStringsSep "\n" clearRules}
|
|
|
|
${lib.concatStringsSep "\n" addRules}
|
|
|
|
|
|
|
|
ip -4 route flush table 151 >/dev/null 2>&1 || true
|
|
|
|
ip -4 route add 92.118.30.0/31 dev wg-tuvok-vm table 151
|
|
|
|
ip -4 route add default via 92.118.30.1 dev wg-tuvok-vm table 151
|
|
|
|
ip -6 route flush table 151 >/dev/null 2>&1 || true
|
|
|
|
ip -6 route add 2a09:a442::1:0/112 dev wg-tuvok-vm table 151
|
|
|
|
ip -6 route add default via 2a09:a442::1:2 dev wg-tuvok-vm table 151
|
|
|
|
|
|
|
|
ip -4 route flush table 152 >/dev/null 2>&1 || true
|
2022-01-14 19:42:06 +00:00
|
|
|
ip -4 route add 92.118.30.2/31 dev wg-tuvok-ee table 152
|
2021-08-30 18:58:21 +00:00
|
|
|
ip -4 route add default via 92.118.30.3 dev wg-tuvok-ee table 152
|
|
|
|
ip -6 route flush table 152 >/dev/null 2>&1 || true
|
|
|
|
ip -6 route add 2a09:a442::2:0/112 dev wg-tuvok-ee table 152
|
|
|
|
ip -6 route add default via 2a09:a442::2:2 dev wg-tuvok-ee table 152
|
2022-01-14 19:42:06 +00:00
|
|
|
|
|
|
|
ip -4 route flush table 153 >/dev/null 2>&1 || true
|
|
|
|
ip -4 route add 92.118.30.4/31 dev wg-tuvok-gnet table 153
|
|
|
|
ip -4 route add default via 92.118.30.5 dev wg-tuvok-gnet table 153
|
|
|
|
ip -6 route flush table 153 >/dev/null 2>&1 || true
|
|
|
|
ip -6 route add 2a09:a442::3:0/112 dev wg-tuvok-gnet table 153
|
|
|
|
ip -6 route add default via 2a09:a442::3:2 dev wg-tuvok-gnet table 153
|
2021-08-30 18:58:21 +00:00
|
|
|
'';
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
2022-01-14 19:42:06 +00:00
|
|
|
systemd.network = {
|
|
|
|
enable = true;
|
|
|
|
networks."40-en-ee".dhcpV4Config.RouteTable = 201;
|
|
|
|
networks."40-en-ee".linkConfig.RequiredForOnline = "no";
|
|
|
|
networks."40-en-virginmedia".dhcpV4Config.RouteTable = 202;
|
|
|
|
networks."40-en-virginmedia".linkConfig.RequiredForOnline = "no";
|
|
|
|
networks."40-en-gnet".dhcpV4Config.RouteTable = 203;
|
|
|
|
};
|
2020-11-01 18:25:01 +00:00
|
|
|
my.ip.tailscale = "100.102.224.95";
|
2020-11-01 14:25:17 +00:00
|
|
|
services.udev.extraRules = ''
|
2021-08-30 18:58:21 +00:00
|
|
|
ATTR{address}=="e4:3a:6e:16:07:62", NAME="en-virginmedia"
|
|
|
|
ATTR{address}=="e4:3a:6e:16:07:63", NAME="en-ee"
|
2022-01-14 19:42:06 +00:00
|
|
|
ATTR{address}=="e4:3a:6e:16:07:64", NAME="en-gnet"
|
2021-08-30 18:58:21 +00:00
|
|
|
ATTR{address}=="e4:3a:6e:16:07:67", NAME="en-general"
|
2020-11-01 14:25:17 +00:00
|
|
|
'';
|
|
|
|
boot.kernel.sysctl = {
|
|
|
|
"net.ipv4.ip_forward" = "1";
|
|
|
|
"net.ipv6.conf.default.forwarding" = "1";
|
|
|
|
"net.ipv6.conf.all.forwarding" = "1";
|
2021-08-30 18:58:21 +00:00
|
|
|
"net.ipv6.conf.en-virginmedia.accept_ra" = "2";
|
2021-09-03 12:40:52 +00:00
|
|
|
"net.ipv6.conf.en-ee.accept_ra" = "2";
|
2022-01-14 19:42:06 +00:00
|
|
|
"net.ipv6.conf.en-gnet.accept_ra" = "2";
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
|
|
|
networking.nat = {
|
|
|
|
enable = true;
|
2021-08-30 18:58:21 +00:00
|
|
|
internalInterfaces = ["en-general"];
|
|
|
|
externalInterface = "en-virginmedia";
|
|
|
|
extraCommands = ''
|
2021-09-30 17:10:52 +00:00
|
|
|
# Send PS5 RTMP to totoro instead.
|
|
|
|
# See DHCP static lease.
|
|
|
|
iptables -w -t nat -A nixos-nat-pre --src 92.118.30.18 -p tcp --dport 1935 -j DNAT --to-destination 192.168.1.40
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
# NAT packets going over EE plain.
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 1 -o en-ee -j MASQUERADE
|
|
|
|
|
2022-01-14 19:42:06 +00:00
|
|
|
# NAT packets going over GNetwork plain.
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 1 -o en-gnet -j MASQUERADE
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
# SNAT packets we're sending over tunnels.
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 1 -o wg-tuvok-vm -j SNAT --to-source 92.118.30.254
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 1 -o wg-tuvok-ee -j SNAT --to-source 92.118.30.254
|
2022-01-14 19:42:06 +00:00
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 1 -o wg-tuvok-gnet -j SNAT --to-source 92.118.30.254
|
2021-09-25 17:38:21 +00:00
|
|
|
|
|
|
|
# eduroam
|
|
|
|
# > mark incoming eduroam packets
|
|
|
|
iptables -w -t nat -A nixos-nat-pre -i vl-eduroam -j MARK --set-mark 2
|
2022-01-14 19:42:06 +00:00
|
|
|
# > NAT packets going out directly.
|
2021-09-25 17:38:21 +00:00
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o en-virginmedia -j MASQUERADE
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o en-ee -j MASQUERADE
|
2022-01-14 19:42:06 +00:00
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o en-gnet -j MASQUERADE
|
2021-09-25 17:38:21 +00:00
|
|
|
# > NAT packets going over tunnels.
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o wg-tuvok-vm -j SNAT --to-source 92.118.30.253
|
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o wg-tuvok-ee -j SNAT --to-source 92.118.30.253
|
2022-01-14 19:42:06 +00:00
|
|
|
iptables -w -t nat -A nixos-nat-post -m mark --mark 2 -o wg-tuvok-gnet -j SNAT --to-source 92.118.30.253
|
2021-08-30 18:58:21 +00:00
|
|
|
'';
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
|
|
|
services.dhcpd4 = {
|
|
|
|
enable = true;
|
2021-09-25 17:38:21 +00:00
|
|
|
interfaces = ["en-general" "vl-eduroam"];
|
2020-11-01 14:25:17 +00:00
|
|
|
authoritative = true;
|
|
|
|
extraConfig = ''
|
2021-09-30 16:07:12 +00:00
|
|
|
shared-network int {
|
2020-11-01 14:25:17 +00:00
|
|
|
default-lease-time 600;
|
|
|
|
max-lease-time 3600;
|
2021-08-30 18:58:21 +00:00
|
|
|
option interface-mtu 1420; # Wireguard
|
2020-11-01 14:25:17 +00:00
|
|
|
|
2021-09-30 16:07:12 +00:00
|
|
|
subnet 192.168.1.0 netmask 255.255.255.0 {
|
|
|
|
option subnet-mask 255.255.255.0;
|
|
|
|
option routers 192.168.1.1;
|
|
|
|
option domain-name-servers 192.168.1.1;
|
|
|
|
option domain-name "house.as205479.net";
|
|
|
|
|
|
|
|
range 192.168.1.100 192.168.1.200;
|
|
|
|
}
|
|
|
|
|
|
|
|
subnet 92.118.30.16 netmask 255.255.255.240 {
|
|
|
|
option subnet-mask 255.255.255.240;
|
|
|
|
option routers 92.118.30.17;
|
|
|
|
option domain-name-servers 92.118.30.17;
|
|
|
|
option domain-name "house-ext.as205479.net";
|
|
|
|
}
|
2020-11-01 14:25:17 +00:00
|
|
|
}
|
2021-09-25 17:38:21 +00:00
|
|
|
|
|
|
|
subnet 192.168.10.0 netmask 255.255.255.0 {
|
|
|
|
option subnet-mask 255.255.255.0;
|
|
|
|
option routers 192.168.10.1;
|
|
|
|
option domain-name-servers 192.168.10.1;
|
|
|
|
option domain-name "eduroam.as205479.net";
|
|
|
|
default-lease-time 600;
|
|
|
|
max-lease-time 3600;
|
|
|
|
option interface-mtu 1420; # Wireguard
|
|
|
|
|
|
|
|
range 192.168.10.100 192.168.10.200;
|
|
|
|
}
|
2020-11-01 14:25:17 +00:00
|
|
|
'';
|
2020-11-04 14:27:19 +00:00
|
|
|
machines = [
|
|
|
|
{
|
|
|
|
hostName = "totoro";
|
|
|
|
ethernetAddress = "40:8d:5c:1f:e8:68";
|
|
|
|
ipAddress = "192.168.1.40";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
hostName = "totoro-pfsense";
|
|
|
|
ethernetAddress = "52:54:00:cf:cd:94";
|
|
|
|
ipAddress = "192.168.1.41";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
hostName = "kvm";
|
|
|
|
ethernetAddress = "00:0d:5d:1b:14:ba";
|
|
|
|
ipAddress = "192.168.1.50";
|
|
|
|
}
|
2021-07-15 11:55:10 +00:00
|
|
|
{
|
|
|
|
hostName = "printer-xerox";
|
|
|
|
ethernetAddress = "9c:93:4e:ad:1f:7b";
|
|
|
|
ipAddress = "192.168.1.51";
|
|
|
|
}
|
2021-09-30 16:07:12 +00:00
|
|
|
{
|
|
|
|
hostName = "ps5";
|
|
|
|
ethernetAddress = "bc:33:29:26:01:5c";
|
2021-09-30 17:10:52 +00:00
|
|
|
# This is used for DNAT on RTMP, above.
|
2021-09-30 16:07:12 +00:00
|
|
|
ipAddress = "92.118.30.18";
|
|
|
|
}
|
2020-11-04 14:27:19 +00:00
|
|
|
];
|
2020-11-01 14:25:17 +00:00
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
networking.wireguard = let
|
|
|
|
ifBase = {
|
|
|
|
listenPort = null;
|
|
|
|
allowedIPsAsRoutes = false;
|
|
|
|
};
|
|
|
|
peerBase = {
|
|
|
|
allowedIPs = [
|
|
|
|
"0.0.0.0/0"
|
|
|
|
"::/0"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
in {
|
|
|
|
enable = true;
|
|
|
|
interfaces.wg-tuvok-vm = ifBase // {
|
|
|
|
ips = [
|
|
|
|
"2a09:a442::1:1/112"
|
|
|
|
"92.118.30.0/31"
|
|
|
|
];
|
|
|
|
listenPort = 51820;
|
|
|
|
privateKey = secrets.wireguard.tuvok-swann.swann.privateKey;
|
|
|
|
peers = [(peerBase // {
|
|
|
|
endpoint = "92.118.28.252:51820";
|
|
|
|
publicKey = secrets.wireguard.tuvok-swann.tuvok.publicKey;
|
|
|
|
})];
|
|
|
|
postSetup = ''
|
|
|
|
wg set wg-tuvok-vm fwmark 0xbeef
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
interfaces.wg-tuvok-ee = ifBase // {
|
|
|
|
ips = [
|
|
|
|
"2a09:a442::2:1/112"
|
|
|
|
"92.118.30.2/31"
|
|
|
|
];
|
|
|
|
listenPort = 51821;
|
|
|
|
privateKey = secrets.wireguard.tuvok-swann.swann.privateKey;
|
|
|
|
peers = [(peerBase // {
|
2021-09-03 12:40:52 +00:00
|
|
|
endpoint = "[2a09:a441::f00f]:51821";
|
2021-08-30 18:58:21 +00:00
|
|
|
publicKey = secrets.wireguard.tuvok-swann.tuvok.publicKey;
|
|
|
|
})];
|
|
|
|
postSetup = ''
|
|
|
|
wg set wg-tuvok-ee fwmark 0xdead
|
|
|
|
'';
|
|
|
|
};
|
2022-01-14 19:42:06 +00:00
|
|
|
interfaces.wg-tuvok-gnet = ifBase // {
|
|
|
|
ips = [
|
|
|
|
"2a09:a442::3:1/112"
|
|
|
|
"92.118.30.4/31"
|
|
|
|
];
|
|
|
|
listenPort = 51822;
|
|
|
|
privateKey = secrets.wireguard.tuvok-swann.swann.privateKey;
|
|
|
|
peers = [(peerBase // {
|
|
|
|
endpoint = "92.118.28.252:51822";
|
|
|
|
publicKey = secrets.wireguard.tuvok-swann.tuvok.publicKey;
|
|
|
|
})];
|
|
|
|
postSetup = ''
|
|
|
|
wg set wg-tuvok-gnet fwmark 0xcafe
|
|
|
|
'';
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
2020-11-01 14:25:17 +00:00
|
|
|
|
2020-11-04 21:53:14 +00:00
|
|
|
services.unifi = {
|
|
|
|
enable = true;
|
2021-12-24 02:03:36 +00:00
|
|
|
openFirewall = false;
|
2021-05-15 19:33:13 +00:00
|
|
|
unifiPackage = depot.pkgs.unifi;
|
2020-11-04 21:53:14 +00:00
|
|
|
};
|
2020-11-06 05:02:05 +00:00
|
|
|
services.prometheus.exporters.unifi-poller = {
|
|
|
|
enable = true;
|
|
|
|
controllers = [{
|
|
|
|
url = "https://localhost:8443";
|
|
|
|
verify_ssl = false;
|
|
|
|
user = "unifipoller";
|
|
|
|
pass = pkgs.writeTextFile { name = "unifipoller-password"; text = "unifipoller"; };
|
|
|
|
}];
|
|
|
|
};
|
2020-11-04 21:53:14 +00:00
|
|
|
|
|
|
|
networking.firewall = {
|
2021-08-30 18:58:21 +00:00
|
|
|
interfaces.en-general = {
|
2020-11-04 21:53:14 +00:00
|
|
|
allowedTCPPorts = [
|
|
|
|
8080 6789 # Unifi
|
2020-11-18 01:49:44 +00:00
|
|
|
53 # DNS
|
2020-11-04 21:53:14 +00:00
|
|
|
];
|
|
|
|
allowedUDPPorts = [
|
|
|
|
3478 10001 # Unifi
|
2020-11-18 01:49:44 +00:00
|
|
|
53 # DNS
|
2020-11-04 21:53:14 +00:00
|
|
|
];
|
|
|
|
};
|
2021-09-25 17:38:21 +00:00
|
|
|
interfaces.vl-eduroam = {
|
|
|
|
allowedTCPPorts = [
|
|
|
|
53 # DNS
|
|
|
|
];
|
|
|
|
allowedUDPPorts = [
|
|
|
|
53 # DNS
|
|
|
|
];
|
|
|
|
};
|
2022-01-14 19:42:06 +00:00
|
|
|
interfaces.en-virginmedia = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
51820
|
|
|
|
];
|
|
|
|
};
|
|
|
|
interfaces.en-ee = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
51821
|
|
|
|
];
|
|
|
|
};
|
|
|
|
interfaces.en-gnet = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
51822
|
|
|
|
];
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
interfaces.wg-tuvok-ee = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
3784 # BFD
|
|
|
|
];
|
|
|
|
};
|
|
|
|
interfaces.wg-tuvok-vm = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
3784 # BFD
|
|
|
|
];
|
|
|
|
};
|
2022-01-14 19:42:06 +00:00
|
|
|
interfaces.wg-tuvok-gnet = {
|
|
|
|
allowedUDPPorts = [
|
|
|
|
3784 # BFD
|
|
|
|
];
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
extraCommands = ''
|
2021-09-25 17:38:21 +00:00
|
|
|
ip46tables -F FORWARD
|
|
|
|
|
|
|
|
ip46tables -N ts-forward || true
|
|
|
|
ip46tables -A FORWARD -j ts-forward
|
|
|
|
|
|
|
|
iptables -A FORWARD -p tcp --tcp-flags SYN,RST SYN -j TCPMSS --set-mss 1360
|
|
|
|
ip6tables -A FORWARD -p tcp --tcp-flags SYN,RST SYN -j TCPMSS --set-mss 1360
|
|
|
|
|
|
|
|
ip46tables -A FORWARD -i vl-eduroam -o wg-tuvok-ee -j ACCEPT
|
|
|
|
ip46tables -A FORWARD -i vl-eduroam -o wg-tuvok-vm -j ACCEPT
|
2022-01-14 19:42:06 +00:00
|
|
|
ip46tables -A FORWARD -i vl-eduroam -o wg-tuvok-gnet -j ACCEPT
|
2021-09-25 17:38:21 +00:00
|
|
|
ip46tables -A FORWARD -i vl-eduroam -m state --state NEW,RELATED -j REJECT
|
2021-08-30 18:58:21 +00:00
|
|
|
'';
|
2020-11-04 21:53:14 +00:00
|
|
|
};
|
|
|
|
|
2020-11-18 01:49:44 +00:00
|
|
|
services.ddclient = {
|
|
|
|
enable = false;
|
|
|
|
protocol = "cloudflare";
|
|
|
|
domains = ["home.lukegb.com"];
|
|
|
|
zone = "lukegb.com";
|
2021-12-07 19:13:04 +00:00
|
|
|
passwordFile = pkgs.writeText "cloudflare-token" secrets.cloudflareCredentials.token;
|
2020-11-18 01:49:44 +00:00
|
|
|
use = "if";
|
|
|
|
extraConfig = ''
|
2021-08-30 18:58:21 +00:00
|
|
|
if=en-virginmedia
|
2020-11-18 01:49:44 +00:00
|
|
|
daemon=0
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
systemd.services.ddclient.serviceConfig.ExecStart = let
|
|
|
|
ddclient = pkgs.perlPackages.buildPerlPackage rec {
|
|
|
|
pname = "ddclient";
|
|
|
|
version = "3.9.1";
|
|
|
|
src = pkgs.fetchFromGitHub {
|
|
|
|
owner = "ddclient";
|
|
|
|
repo = "ddclient";
|
|
|
|
rev = "11a583b003920f8e15591813598b70061d1a4654";
|
|
|
|
sha256 = "sha256:1xz09vkii3mc2jmfwx9is07i06iiryv51571vdnl4m5mdnvsmlwb";
|
|
|
|
};
|
|
|
|
outputs = [ "out" ];
|
|
|
|
doCheck = false;
|
|
|
|
buildInputs = with pkgs.perlPackages; [ IOSocketSSL DigestSHA1 DataValidateIP JSONPP ];
|
|
|
|
nativeBuildInputs = with pkgs; [ autoreconfHook makeWrapper ];
|
|
|
|
preConfigure = ''
|
|
|
|
touch Makefile.PL
|
|
|
|
'';
|
|
|
|
postInstall = ''
|
|
|
|
patchShebangs $out/bin/ddclient
|
|
|
|
wrapProgram $out/bin/ddclient \
|
|
|
|
--suffix PATH : ${lib.makeBinPath (with pkgs; [ pkgs.iproute ])} \
|
|
|
|
--prefix PERL5LIB : $PERL5LIB
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
RuntimeDirectory = "ddclient";
|
|
|
|
in lib.mkForce "${lib.getBin ddclient}/bin/ddclient -file /run/${RuntimeDirectory}/ddclient.conf";
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
ethtool
|
|
|
|
];
|
2020-11-01 14:25:17 +00:00
|
|
|
|
2020-11-18 01:49:44 +00:00
|
|
|
services.coredns = {
|
|
|
|
enable = true;
|
|
|
|
config = ''
|
|
|
|
.:53 {
|
2021-12-31 23:52:57 +00:00
|
|
|
bind 192.168.1.1 92.118.30.17 192.168.10.1 127.0.0.253 2a09:a443::1 2a09:a443:1::1 2a09:a443:2::1 2a09:a443:3::1
|
2020-11-18 01:49:44 +00:00
|
|
|
acl {
|
2021-09-30 16:07:12 +00:00
|
|
|
allow net 192.168.0.0/16 172.16.0.0/12 10.0.0.0/8 127.0.0.0/8 100.64.0.0/10 2a09:a443::/32 92.118.30.0/24
|
2020-11-18 01:49:44 +00:00
|
|
|
block
|
|
|
|
}
|
2021-05-31 23:54:07 +00:00
|
|
|
hosts /dev/null {
|
2021-09-25 17:38:21 +00:00
|
|
|
#216.239.38.120 stadia.google.com stadia.com
|
2021-05-21 15:22:34 +00:00
|
|
|
fallthrough
|
|
|
|
}
|
2020-11-18 01:49:44 +00:00
|
|
|
loadbalance
|
|
|
|
forward . tls://8.8.8.8 tls://8.8.4.4 {
|
|
|
|
tls_servername dns.google
|
|
|
|
}
|
|
|
|
cache {
|
|
|
|
success 4096
|
|
|
|
denial 1024
|
|
|
|
prefetch 512
|
|
|
|
}
|
|
|
|
prometheus :9153
|
|
|
|
errors
|
|
|
|
log
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
};
|
2020-11-18 02:02:23 +00:00
|
|
|
my.prometheus.additionalExporterPorts.coredns = 9153;
|
2020-11-18 01:49:44 +00:00
|
|
|
networking.resolvconf.extraConfig = ''
|
2021-12-31 23:52:57 +00:00
|
|
|
name_servers='127.0.0.253'
|
2020-11-18 01:49:44 +00:00
|
|
|
'';
|
|
|
|
|
2020-12-29 18:57:18 +00:00
|
|
|
services.prometheus.exporters.smokeping = {
|
|
|
|
enable = true;
|
|
|
|
hosts = [
|
|
|
|
"8.8.8.8" # Google Public DNS
|
2021-05-13 10:14:42 +00:00
|
|
|
"2001:4860:4860::8888"
|
2020-12-29 18:57:18 +00:00
|
|
|
"youtube.com" "ads.google.com" "google.com"
|
|
|
|
|
|
|
|
"1.1.1.1" # Cloudflare DNS
|
2021-05-13 10:14:42 +00:00
|
|
|
"2606:4700:4700::1111"
|
2020-12-29 18:57:18 +00:00
|
|
|
|
|
|
|
"twitter.com"
|
|
|
|
|
|
|
|
"store.steampowered.com"
|
|
|
|
"api.steampowered.com"
|
|
|
|
|
2022-01-01 01:31:56 +00:00
|
|
|
"euw1.api.riotgames.com" # League of Legends EUW
|
2020-12-29 18:57:18 +00:00
|
|
|
|
|
|
|
"eu.battle.net"
|
|
|
|
"185.60.112.157" "185.60.112.158" # Diablo 3/HotS/Hearthstone
|
|
|
|
"185.60.114.159" # Overwatch
|
2021-05-13 16:33:40 +00:00
|
|
|
|
|
|
|
# BFOB TS
|
|
|
|
"2a01:a500:85:3::2"
|
|
|
|
"37.9.61.53"
|
2022-03-03 18:44:56 +00:00
|
|
|
|
|
|
|
# lukegb01.ring.nlnog.net
|
|
|
|
"2a09:a441::13"
|
|
|
|
"92.118.28.13"
|
2020-12-29 18:57:18 +00:00
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2021-08-30 18:58:21 +00:00
|
|
|
services.bird2 = {
|
|
|
|
enable = true;
|
|
|
|
config = ''
|
|
|
|
router id 92.118.30.254;
|
|
|
|
|
|
|
|
protocol kernel {
|
|
|
|
kernel table 150;
|
|
|
|
metric 0;
|
|
|
|
ipv4 {
|
|
|
|
import none;
|
|
|
|
export all;
|
|
|
|
};
|
2021-05-13 10:14:42 +00:00
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
protocol kernel {
|
|
|
|
kernel table 150;
|
|
|
|
metric 0;
|
|
|
|
ipv6 {
|
|
|
|
import none;
|
|
|
|
export all;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
protocol device {};
|
|
|
|
|
|
|
|
protocol static export4 {
|
|
|
|
ipv4 {};
|
2022-01-15 13:32:47 +00:00
|
|
|
route 0.0.0.0/0 via 92.118.30.1 bfd {
|
|
|
|
# Virgin Media
|
2021-08-30 18:58:21 +00:00
|
|
|
preference = 100;
|
|
|
|
};
|
|
|
|
route 0.0.0.0/0 via 92.118.30.3 bfd {
|
|
|
|
# EE
|
|
|
|
preference = 10;
|
|
|
|
};
|
2022-01-15 13:32:47 +00:00
|
|
|
route 0.0.0.0/0 via 92.118.30.5 bfd {
|
|
|
|
# GNetwork
|
|
|
|
preference = 200;
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
|
|
|
protocol static export6 {
|
|
|
|
ipv6 {};
|
2022-01-15 13:32:47 +00:00
|
|
|
route ::/0 via 2a09:a442::1:2 bfd {
|
|
|
|
# Virgin Media
|
2021-08-30 18:58:21 +00:00
|
|
|
preference = 100;
|
2022-01-01 02:11:59 +00:00
|
|
|
krt_prefsrc = 2a09:a443::1;
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
|
|
|
route ::/0 via 2a09:a442::2:2 bfd {
|
|
|
|
# EE
|
|
|
|
preference = 10;
|
2022-01-01 02:11:59 +00:00
|
|
|
krt_prefsrc = 2a09:a443::1;
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
2022-01-15 13:32:47 +00:00
|
|
|
route ::/0 via 2a09:a442::3:2 bfd {
|
|
|
|
# GNetwork
|
|
|
|
preference = 200;
|
|
|
|
krt_prefsrc = 2a09:a443::1;
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
|
|
|
|
# Covering route...
|
|
|
|
route 2a09:a443::/64 via "en-general";
|
2021-09-25 17:38:21 +00:00
|
|
|
route 2a09:a443:1::/48 via "en-general";
|
|
|
|
route 2a09:a443:2::/64 via "vl-eduroam";
|
|
|
|
route 2a09:a443:3::/48 via "vl-eduroam";
|
2021-08-30 18:58:21 +00:00
|
|
|
route 2a09:a443::/32 unreachable;
|
|
|
|
};
|
|
|
|
|
|
|
|
protocol bfd {
|
|
|
|
interface "*" {
|
|
|
|
min rx interval 10ms;
|
|
|
|
min tx interval 50ms;
|
|
|
|
idle tx interval 1s;
|
|
|
|
multiplier 20;
|
|
|
|
};
|
|
|
|
neighbor 92.118.30.1;
|
|
|
|
neighbor 2a09:a442::1:2;
|
|
|
|
neighbor 92.118.30.3;
|
|
|
|
neighbor 2a09:a442::2:2;
|
2022-01-14 19:42:06 +00:00
|
|
|
neighbor 92.118.30.5;
|
|
|
|
neighbor 2a09:a442::3:2;
|
2021-08-30 18:58:21 +00:00
|
|
|
};
|
|
|
|
'';
|
2021-05-12 18:12:41 +00:00
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
|
2021-05-12 18:12:41 +00:00
|
|
|
services.radvd = {
|
2021-08-30 18:58:21 +00:00
|
|
|
enable = true;
|
2021-05-12 18:12:41 +00:00
|
|
|
config = ''
|
2021-08-30 18:58:21 +00:00
|
|
|
interface en-general {
|
2021-05-12 18:12:41 +00:00
|
|
|
AdvSendAdvert on;
|
2021-08-30 18:58:21 +00:00
|
|
|
AdvLinkMTU 1420; # Wireguard
|
|
|
|
AdvManagedFlag on;
|
|
|
|
|
|
|
|
RDNSS 2a09:a443::1 {};
|
|
|
|
DNSSL house.as205479.net {};
|
|
|
|
|
|
|
|
prefix 2a09:a443::/64 {
|
|
|
|
AdvOnLink on;
|
|
|
|
AdvAutonomous on;
|
|
|
|
};
|
|
|
|
prefix 2a09:a443:1::/48 {
|
|
|
|
AdvOnLink on;
|
|
|
|
AdvAutonomous off;
|
2021-05-12 18:12:41 +00:00
|
|
|
};
|
|
|
|
};
|
2021-09-25 17:38:21 +00:00
|
|
|
interface vl-eduroam {
|
|
|
|
AdvSendAdvert on;
|
|
|
|
AdvLinkMTU 1420; # Wireguard
|
|
|
|
AdvManagedFlag on;
|
|
|
|
|
|
|
|
RDNSS 2a09:a443:2::1 {};
|
|
|
|
DNSSL eduroam.as205479.net {};
|
|
|
|
|
|
|
|
prefix 2a09:a443:2::/64 {
|
|
|
|
AdvOnLink on;
|
|
|
|
AdvAutonomous on;
|
|
|
|
};
|
|
|
|
prefix 2a09:a443:3::/48 {
|
|
|
|
AdvOnLink on;
|
|
|
|
AdvAutonomous off;
|
|
|
|
};
|
|
|
|
};
|
2021-05-12 18:12:41 +00:00
|
|
|
'';
|
|
|
|
};
|
2021-08-30 18:58:21 +00:00
|
|
|
services.dhcpd6 = {
|
|
|
|
enable = true;
|
2021-09-25 17:38:21 +00:00
|
|
|
interfaces = ["en-general" "vl-eduroam"];
|
2021-08-30 18:58:21 +00:00
|
|
|
authoritative = true;
|
|
|
|
extraConfig = ''
|
|
|
|
subnet6 2a09:a443:1::/48 {
|
|
|
|
range6 2a09:a443:1:1::/64;
|
|
|
|
range6 2a09:a443:1:2::/64 temporary;
|
2021-12-08 02:37:12 +00:00
|
|
|
prefix6 2a09:a443:1:1000:: 2a09:a443:1:ff00:: /56;
|
2021-08-30 18:58:21 +00:00
|
|
|
|
|
|
|
option dhcp6.name-servers 2a09:a443:1::1;
|
|
|
|
option dhcp6.domain-search "house.as205479.net";
|
|
|
|
}
|
2021-09-25 17:38:21 +00:00
|
|
|
subnet6 2a09:a443:3::/48 {
|
|
|
|
range6 2a09:a443:3:1::/64;
|
|
|
|
range6 2a09:a443:3:2::/64 temporary;
|
2021-12-08 02:37:12 +00:00
|
|
|
prefix6 2a09:a443:3:1000:: 2a09:a443:3:ff00:: /56;
|
2021-09-25 17:38:21 +00:00
|
|
|
|
|
|
|
option dhcp6.name-servers 2a09:a443:3::1;
|
|
|
|
option dhcp6.domain-search "eduroam.as205479.net";
|
|
|
|
}
|
2021-08-30 18:58:21 +00:00
|
|
|
'';
|
|
|
|
};
|
2021-05-12 18:12:41 +00:00
|
|
|
|
2021-08-31 02:29:56 +00:00
|
|
|
systemd.services.prometheus-bird-exporter.serviceConfig.ExecStart = lib.mkForce ''
|
2021-08-31 02:26:50 +00:00
|
|
|
${depot.pkgs.prometheus-bird-exporter-lfty}/bin/bird_exporter \
|
|
|
|
-web.listen-address 0.0.0.0:9324 \
|
|
|
|
-bird.socket /var/run/bird.ctl \
|
|
|
|
-bird.v2=true \
|
|
|
|
-format.new=true
|
|
|
|
'';
|
|
|
|
|
2021-09-02 19:19:53 +00:00
|
|
|
systemd.services.ee-scrape-data = let
|
|
|
|
scriptFile = ./ee-scrape-data.py;
|
|
|
|
python = pkgs.python3.withPackages (pm: with pm; [
|
|
|
|
requests
|
|
|
|
beautifulsoup4
|
|
|
|
html5lib
|
|
|
|
]);
|
|
|
|
in {
|
|
|
|
enable = true;
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "oneshot";
|
|
|
|
ExecStart = "${python}/bin/python ${scriptFile} /run/prometheus-textfile-exports/ee-scrape-data.prom";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
systemd.timers.ee-scrape-data = {
|
|
|
|
enable = true;
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
timerConfig = {
|
|
|
|
OnBootSec = "2m";
|
|
|
|
OnUnitInactiveSec = "1m";
|
|
|
|
RandomizedDelaySec = "20";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2020-11-01 14:25:17 +00:00
|
|
|
system.stateVersion = "21.03";
|
|
|
|
}
|