nix-config/hosts/nucnix/guests.nix

120 lines
3.3 KiB
Nix
Raw Normal View History

2024-12-14 21:45:46 +01:00
{
config,
stateVersion,
2024-12-21 14:06:00 +01:00
globals,
2024-12-14 21:45:46 +01:00
inputs,
lib,
minimal,
...
}:
2024-12-23 12:42:21 +01:00
let
inherit (lib)
listToAttrs
flip
nameValuePair
;
in
2024-12-14 21:45:46 +01:00
{
guests =
let
2024-12-21 14:06:00 +01:00
mkGuest =
guestName:
{
vlans ? [ "services" ],
...
}:
{
autostart = true;
zfs."/state" = {
pool = "rpool";
dataset = "local/guests/${guestName}";
};
zfs."/persist" = {
pool = "rpool";
dataset = "safe/guests/${guestName}";
};
modules = [
../../config/basic
../../config/services/${guestName}.nix
{
node.secretsDir = config.node.secretsDir + "/${guestName}";
networking.nftables.firewall.zones.untrusted.interfaces = lib.mkIf (
lib.length config.guests.${guestName}.networking.links == 1
) config.guests.${guestName}.networking.links;
systemd.network.networks = lib.mkIf (globals.services.${guestName}.ip != null) (
lib.listToAttrs (
lib.flip map vlans (
name:
lib.nameValuePair "10-mv-${name}" {
2024-12-21 14:06:00 +01:00
matchConfig.Name = "mv-${name}";
DHCP = lib.mkForce "no";
2024-12-21 14:06:00 +01:00
address = [
(lib.net.cidr.hostCidr globals.services.${guestName}.ip globals.net.vlans.${name}.cidrv4)
2024-12-21 23:32:42 +01:00
(lib.net.cidr.hostCidr globals.services.${guestName}.ip globals.net.vlans.${name}.cidrv6)
];
gateway = [
2024-12-22 19:00:21 +01:00
(lib.net.cidr.host 1 globals.net.vlans.${name}.cidrv4)
(lib.net.cidr.host 1 globals.net.vlans.${name}.cidrv6)
2024-12-21 14:06:00 +01:00
];
}
)
)
);
}
];
2024-12-14 21:45:46 +01:00
};
2024-12-23 12:42:21 +01:00
mkMicrovm =
guestName:
{
vlans ? [ "services" ],
...
}@cfg:
{
${guestName} = mkGuest guestName cfg // {
backend = "microvm";
microvm = {
system = "x86_64-linux";
2025-01-03 00:31:36 +01:00
interfaces = listToAttrs (flip map vlans (x: (nameValuePair "mv-${x}" { hostLink = "lan-${x}"; })));
2024-12-23 12:42:21 +01:00
baseMac = config.secrets.secrets.local.networking.interfaces.lan01.mac;
};
extraSpecialArgs = {
inherit (inputs.self) nodes globals;
inherit (inputs.self.pkgs.x86_64-linux) lib;
inherit inputs minimal stateVersion;
};
2024-12-14 21:45:46 +01:00
};
};
mkContainer =
guestName:
{
2024-12-21 14:06:00 +01:00
vlans ? [ "services" ],
...
}@cfg:
{
2024-12-21 14:06:00 +01:00
${guestName} = lib.mkMerge [
(mkGuest guestName cfg)
{
backend = "container";
container.macvlans = lib.flip map vlans (x: "lan-${x}:mv-${x}");
extraSpecialArgs = {
inherit (inputs.self) nodes globals;
inherit (inputs.self.pkgs.x86_64-linux) lib;
inherit inputs minimal stateVersion;
};
}
];
2024-12-14 21:45:46 +01:00
};
in
2024-12-23 12:42:21 +01:00
{ }
// mkContainer "adguardhome" { }
// mkContainer "nginx" { }
// mkMicrovm "hostapd" {
vlans = [
2025-01-02 22:04:16 +01:00
# "guests"
2024-12-23 12:42:21 +01:00
"home"
];
};
2024-12-14 21:45:46 +01:00
}