nixfiles/presets/nixos/serverHetzner.nix
2023-09-20 16:59:45 +01:00

89 lines
1.7 KiB
Nix

{
self,
config,
modulesPath,
pkgs,
lib,
...
}: let
inherit (lib.lists) optionals;
inherit (lib.modules) mkForce;
system = pkgs.system;
container-ips = import "${self}/data/serverIPs.nix";
hostName = config.networking.hostName;
serverIPs = container-ips.${hostName};
gateway = "172.31.1.1";
netmask = "255.255.255.255";
in {
imports = [
(modulesPath + "/installer/scan/not-detected.nix")
(modulesPath + "/profiles/qemu-guest.nix")
];
systemd.services = {
systemd-networkd-wait-online.enable = mkForce false;
};
networking = {
usePredictableInterfaceNames = false;
dhcpcd.enable = false;
};
boot.initrd.kernelModules = [
"virtio_gpu"
"virtio_pci"
"virtio_net"
"virtio_scsi"
];
boot.kernelPackages = pkgs.linuxPackages_latest;
boot.kernelParams =
[
"console=tty0"
"ip=${serverIPs.ipv4}::${gateway}:${netmask}:${hostName}:enp1s0:any"
"boot.shell_on_fail"
"nohibernate"
"loglevel=4"
]
++ (lib.optionals (system == "aarch64-linux") ["console=tty" "console=ttyAMA0,115200" "console=ttyS0,115200"]);
systemd.network = {
enable = true;
networks."enp1s0" = {
name = "enp1s0";
networkConfig.DHCP = "no";
address = [
# v4
"${serverIPs.ipv4}/32"
# v6
"${serverIPs.ipv6}/64"
];
routes = [
# v4
{
routeConfig = {
Destination = "172.31.1.1";
};
}
{
routeConfig = {
Gateway = "172.31.1.1";
GatewayOnLink = true;
};
}
# v6
{
routeConfig.Gateway = "fe80::1";
}
];
};
};
}