2024-11-16 19:00:06 +05:30
|
|
|
{ lib, config, ... }:
|
|
|
|
let
|
|
|
|
wireguard-peers = import ../shared/wireguard-peers.nix;
|
|
|
|
in
|
|
|
|
{
|
2024-07-07 00:24:05 +05:30
|
|
|
sops.secrets = {
|
|
|
|
"wireguard/rico2/pk" = {
|
|
|
|
mode = "400";
|
|
|
|
owner = config.users.users.root.name;
|
|
|
|
group = config.users.users.root.group;
|
|
|
|
};
|
2024-11-16 19:00:06 +05:30
|
|
|
};
|
|
|
|
|
|
|
|
systemd = {
|
|
|
|
network = {
|
|
|
|
enable = true;
|
|
|
|
wait-online.enable = false;
|
|
|
|
networks = {
|
|
|
|
"41-ether" = {
|
|
|
|
enable = true;
|
|
|
|
matchConfig = {
|
|
|
|
Type = "ether";
|
|
|
|
Name = "e*";
|
|
|
|
};
|
|
|
|
networkConfig = {
|
|
|
|
DHCP = "yes";
|
|
|
|
IPv4Forwarding = "yes";
|
|
|
|
};
|
|
|
|
dhcpV4Config = {
|
|
|
|
UseDomains = true;
|
|
|
|
};
|
|
|
|
linkConfig = {
|
|
|
|
RequiredForOnline = "yes";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2024-06-29 17:52:32 +05:30
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-11-16 19:00:06 +05:30
|
|
|
services.resolved = {
|
2024-06-29 17:52:32 +05:30
|
|
|
enable = true;
|
2024-11-16 19:00:06 +05:30
|
|
|
domains = [ "~." ];
|
|
|
|
fallbackDns = [ ];
|
|
|
|
};
|
|
|
|
|
|
|
|
networking = {
|
|
|
|
useDHCP = lib.mkDefault false;
|
|
|
|
nameservers = [
|
|
|
|
"10.10.10.11"
|
|
|
|
"10.10.10.12"
|
2024-07-07 00:24:05 +05:30
|
|
|
];
|
2024-11-16 19:00:06 +05:30
|
|
|
useNetworkd = true;
|
|
|
|
firewall = {
|
|
|
|
allowedUDPPorts = [ 51832 ];
|
|
|
|
trustedInterfaces = [ "Homelab" ];
|
|
|
|
};
|
|
|
|
wg-quick = {
|
|
|
|
interfaces = {
|
|
|
|
Homelab = {
|
|
|
|
listenPort = 51832;
|
|
|
|
privateKeyFile = config.sops.secrets."wireguard/rico2/pk".path;
|
|
|
|
address = [
|
|
|
|
"10.10.10.12/24"
|
|
|
|
];
|
|
|
|
dns = [ "10.10.10.11" "10.10.10.12" ];
|
|
|
|
peers = with wireguard-peers; [
|
|
|
|
(bifrost // { persistentKeepalive = 20; })
|
|
|
|
rico0
|
|
|
|
rico1
|
|
|
|
wynne
|
|
|
|
layne
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2024-06-29 17:52:32 +05:30
|
|
|
};
|
|
|
|
}
|