diff options
Diffstat (limited to 'hosts/vidhar/network/dhcp/default.nix')
| -rw-r--r-- | hosts/vidhar/network/dhcp/default.nix | 199 |
1 files changed, 128 insertions, 71 deletions
diff --git a/hosts/vidhar/network/dhcp/default.nix b/hosts/vidhar/network/dhcp/default.nix index 4151111d..11460393 100644 --- a/hosts/vidhar/network/dhcp/default.nix +++ b/hosts/vidhar/network/dhcp/default.nix | |||
| @@ -1,9 +1,32 @@ | |||
| 1 | { flake, config, pkgs, lib, ... }: | 1 | { flake, config, pkgs, lib, sources, ... }: |
| 2 | 2 | ||
| 3 | with lib; | 3 | with lib; |
| 4 | 4 | ||
| 5 | let | 5 | let |
| 6 | nfsrootBaseUrl = "http://nfsroot.vidhar.yggdrasil"; | 6 | nfsrootBaseUrl = "http://nfsroot.vidhar.yggdrasil"; |
| 7 | tftpIp = "10.141.0.1"; | ||
| 8 | nfsIp = tftpIp; | ||
| 9 | ipxe = pkgs.ipxe.override { | ||
| 10 | additionalTargets = { | ||
| 11 | "bin-i386-efi/ipxe.efi" = "i386-ipxe.efi"; | ||
| 12 | }; | ||
| 13 | additionalOptions = [ | ||
| 14 | "NSLOOKUP_CMD" | ||
| 15 | "PING_CMD" | ||
| 16 | "CONSOLE_CMD" | ||
| 17 | ]; | ||
| 18 | embedScript = pkgs.writeText "yggdrasil.ipxe" '' | ||
| 19 | #!ipxe | ||
| 20 | |||
| 21 | cpair --background 9 1 | ||
| 22 | cpair --background 9 3 | ||
| 23 | cpair --background 9 6 | ||
| 24 | |||
| 25 | set user-class iPXE-yggdrasil | ||
| 26 | |||
| 27 | autoboot | ||
| 28 | ''; | ||
| 29 | }; | ||
| 7 | in { | 30 | in { |
| 8 | config = { | 31 | config = { |
| 9 | services.kea = { | 32 | services.kea = { |
| @@ -25,41 +48,67 @@ in { | |||
| 25 | }; | 48 | }; |
| 26 | 49 | ||
| 27 | client-classes = [ | 50 | client-classes = [ |
| 28 | { name = "eostre-ipxe"; | 51 | { name = "ipxe-eostre"; |
| 29 | test = "hexstring(pkt4.mac, ':') == '00:d8:61:79:c5:40' and option[77].hex == 'iPXE'"; | 52 | test = "hexstring(pkt4.mac, ':') == '00:d8:61:79:c5:40' and option[77].hex == 'iPXE-yggdrasil'"; |
| 30 | next-server = "10.141.0.1"; | 53 | next-server = tftpIp; |
| 31 | boot-file-name = "${nfsrootBaseUrl}/eostre.menu.ipxe"; | 54 | boot-file-name = "${nfsrootBaseUrl}/eostre.menu.ipxe"; |
| 32 | only-if-required = true; | 55 | only-if-required = true; |
| 33 | } | 56 | } |
| 34 | { name = "ipxe"; | 57 | { name = "ipxe-yggdrasil"; |
| 35 | test = "option[77].hex == 'iPXE'"; | 58 | test = "option[77].hex == 'iPXE-yggdrasil'"; |
| 36 | next-server = "10.141.0.1"; | 59 | next-server = tftpIp; |
| 37 | boot-file-name = "${nfsrootBaseUrl}/installer-x86_64-linux.menu.ipxe"; | 60 | boot-file-name = "${nfsrootBaseUrl}/installer-x86_64-linux.menu.ipxe"; |
| 38 | only-if-required = true; | 61 | only-if-required = true; |
| 39 | } | 62 | } |
| 63 | |||
| 64 | { name = "uefi-http"; | ||
| 65 | test = "option[client-system].hex == 0x0010"; | ||
| 66 | option-data = [ | ||
| 67 | { name = "vendor-class-identifier"; data = "HTTPClient"; } | ||
| 68 | ]; | ||
| 69 | boot-file-name = "${nfsrootBaseUrl}/ipxe.efi"; | ||
| 70 | only-if-required = true; | ||
| 71 | } | ||
| 72 | |||
| 73 | { name = "ipxe-uefi-64"; | ||
| 74 | test = "option[77].hex == 'iPXE' and (substring(option[60].hex,0,20) == 'PXEClient:Arch:00007' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00008' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00009')"; | ||
| 75 | boot-file-name = "${nfsrootBaseUrl}/ipxe.efi"; | ||
| 76 | only-if-required = true; | ||
| 77 | } | ||
| 78 | { name = "ipxe-uefi-32"; | ||
| 79 | test = "option[77].hex == 'iPXE' and (substring(option[60].hex,0,20) == 'PXEClient:Arch:00002' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00006')"; | ||
| 80 | boot-file-name = "${nfsrootBaseUrl}/i386-ipxe.efi"; | ||
| 81 | only-if-required = true; | ||
| 82 | } | ||
| 83 | { name = "ipxe-legacy"; | ||
| 84 | test = "option[77].hex == 'iPXE' and substring(option[60].hex,0,20) == 'PXEClient:Arch:00000'"; | ||
| 85 | boot-file-name = "${nfsrootBaseUrl}/ipxe.lkrn"; | ||
| 86 | only-if-required = true; | ||
| 87 | } | ||
| 88 | |||
| 40 | { name = "uefi-64"; | 89 | { name = "uefi-64"; |
| 41 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00007' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00008' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00009'"; | 90 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00007' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00008' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00009'"; |
| 42 | only-if-required = true; | ||
| 43 | option-data = [ | 91 | option-data = [ |
| 44 | { name = "tftp-server-name"; data = "10.141.0.1"; } | 92 | { name = "tftp-server-name"; data = tftpIp; } |
| 45 | ]; | 93 | ]; |
| 46 | boot-file-name = "ipxe.efi"; | 94 | boot-file-name = "ipxe.efi"; |
| 95 | only-if-required = true; | ||
| 47 | } | 96 | } |
| 48 | { name = "uefi-32"; | 97 | { name = "uefi-32"; |
| 49 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00002' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00006'"; | 98 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00002' or substring(option[60].hex,0,20) == 'PXEClient:Arch:00006'"; |
| 50 | only-if-required = true; | ||
| 51 | option-data = [ | 99 | option-data = [ |
| 52 | { name = "tftp-server-name"; data = "10.141.0.1"; } | 100 | { name = "tftp-server-name"; data = tftpIp; } |
| 53 | ]; | 101 | ]; |
| 54 | boot-file-name = "i386-ipxe.efi"; | 102 | boot-file-name = "i386-ipxe.efi"; |
| 103 | only-if-required = true; | ||
| 55 | } | 104 | } |
| 56 | { name = "legacy"; | 105 | { name = "legacy"; |
| 57 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00000'"; | 106 | test = "substring(option[60].hex,0,20) == 'PXEClient:Arch:00000'"; |
| 58 | only-if-required = true; | ||
| 59 | option-data = [ | 107 | option-data = [ |
| 60 | { name = "tftp-server-name"; data = "10.141.0.1"; } | 108 | { name = "tftp-server-name"; data = tftpIp; } |
| 61 | ]; | 109 | ]; |
| 62 | boot-file-name = "undionly.kpxe"; | 110 | boot-file-name = "ipxe.lkrn"; |
| 111 | only-if-required = true; | ||
| 63 | } | 112 | } |
| 64 | ]; | 113 | ]; |
| 65 | 114 | ||
| @@ -257,30 +306,31 @@ in { | |||
| 257 | pkgs.symlinkJoin { | 306 | pkgs.symlinkJoin { |
| 258 | name = "installer-${system}"; | 307 | name = "installer-${system}"; |
| 259 | paths = [ | 308 | paths = [ |
| 260 | (let | 309 | (builtins.addErrorContext "while evaluating installer-${system}-nfsroot" (let |
| 261 | installerBuild = (flake.nixosConfigurations.${"installer-${system}-nfsroot"}.extendModules { | 310 | installerBuild' = (flake.nixosConfigurations.${"installer-${system}-nfsroot"}.extendModules { |
| 262 | modules = [ | 311 | modules = [ |
| 263 | ({ ... }: { | 312 | ({ ... }: { |
| 264 | config.nfsroot.storeDevice = "10.141.0.1:nix-store"; | 313 | config.nfsroot.storeDevice = "${nfsIp}:nix-store"; |
| 265 | config.nfsroot.registrationUrl = "${nfsrootBaseUrl}/installer-${system}/registration"; | 314 | config.nfsroot.registrationUrl = "${nfsrootBaseUrl}/installer-${system}/registration"; |
| 315 | config.system.nixos.label = "installer-${system}"; | ||
| 266 | }) | 316 | }) |
| 267 | ]; | 317 | ]; |
| 268 | }).config.system.build; | 318 | }); |
| 269 | in builtins.toPath (pkgs.runCommandLocal "install-${system}" {} '' | 319 | installerBuild = installerBuild'.config.system.build; |
| 320 | in builtins.toPath (pkgs.runCommandLocal "installer-${system}" {} '' | ||
| 270 | mkdir -p $out/installer-${system} | 321 | mkdir -p $out/installer-${system} |
| 271 | install -m 0444 -t $out/installer-${system} \ | 322 | install -m 0444 -t $out/installer-${system} \ |
| 272 | ${installerBuild.initialRamdisk}/initrd \ | 323 | ${installerBuild.initialRamdisk}/initrd \ |
| 273 | ${installerBuild.kernel}/bzImage \ | 324 | ${installerBuild.kernel}/bzImage \ |
| 274 | ${installerBuild.netbootIpxeScript}/netboot.ipxe \ | 325 | ${installerBuild.netbootIpxeScript}/netboot.ipxe \ |
| 275 | ${pkgs.closureInfo { rootPaths = installerBuild.storeContents; }}/registration | 326 | ${pkgs.closureInfo { rootPaths = installerBuild.storeContents; }}/registration |
| 276 | '')) | 327 | install -m 0444 ${pkgs.writeText "installer-${system}.menu.ipxe" '' |
| 277 | (pkgs.writeTextFile { | 328 | #!ipxe |
| 278 | name = "installer-${system}.menu.ipxe"; | 329 | |
| 279 | destination = "/installer-${system}.menu.ipxe"; | ||
| 280 | text = '' | ||
| 281 | :start | 330 | :start |
| 282 | menu iPXE boot menu for installer-${system} | 331 | menu iPXE boot menu for installer-${system} |
| 283 | item installer Boot installer-${system} | 332 | item installer ${with installerBuild'; "${config.system.nixos.distroName} ${config.system.nixos.codeName} ${config.system.nixos.label} (Linux ${config.boot.kernelPackages.kernel.modDirVersion})"} |
| 333 | item memtest memtest86plus | ||
| 284 | item netboot netboot.xyz | 334 | item netboot netboot.xyz |
| 285 | item shell iPXE shell | 335 | item shell iPXE shell |
| 286 | choose --timeout 0 --default installer selected || goto shell | 336 | choose --timeout 0 --default installer selected || goto shell |
| @@ -291,29 +341,40 @@ in { | |||
| 291 | goto start | 341 | goto start |
| 292 | 342 | ||
| 293 | :installer | 343 | :installer |
| 294 | chain ${nfsrootBaseUrl}/installer-${system}/netboot.ipxe | 344 | chain installer-${system}/netboot.ipxe |
| 295 | goto start | 345 | goto start |
| 296 | 346 | ||
| 297 | :netboot | 347 | :netboot |
| 298 | chain --autofree ${nfsrootBaseUrl}/netboot.xyz.efi | 348 | iseq ''${platform} efi && chain --autofree netboot.xyz.efi || chain --autofree netboot.xyz.lkrn |
| 299 | goto start | 349 | goto start |
| 300 | ''; | 350 | |
| 301 | }) | 351 | :memtest |
| 352 | iseq ''${platform} efi && chain --autofree memtest.efi || chain --autofree memtest.bin | ||
| 353 | goto start | ||
| 354 | ''} $out/installer-${system}.menu.ipxe | ||
| 355 | ''))) | ||
| 302 | ]; | 356 | ]; |
| 303 | }) ["x86_64-linux"] | 357 | }) ["x86_64-linux"] |
| 304 | ) ++ [ | 358 | ) ++ [ |
| 305 | (pkgs.linkFarm "netbootxyz-efi" [ | 359 | (pkgs.runCommandLocal "utils" {} '' |
| 306 | { name = "netboot.xyz.efi"; path = pkgs.netbootxyz-efi; } | 360 | mkdir $out |
| 307 | ]) | 361 | install -m 0444 -t $out \ |
| 308 | (let | 362 | ${ipxe}/{ipxe.efi,i386-ipxe.efi,ipxe.lkrn} \ |
| 309 | eostreBuild = (flake.nixosConfigurations.eostre.extendModules { | 363 | ${pkgs.memtest86plus}/{memtest.efi,memtest.bin} |
| 364 | install -m 0444 ${sources.netbootxyz-efi.src} $out/netboot.xyz.efi | ||
| 365 | install -m 0444 ${sources.netbootxyz-lkrn.src} $out/netboot.xyz.lkrn | ||
| 366 | '') | ||
| 367 | (builtins.addErrorContext "while evaluating eostre" (let | ||
| 368 | eostreBuild' = (flake.nixosConfigurations.eostre.extendModules { | ||
| 310 | modules = [ | 369 | modules = [ |
| 311 | ({ ... }: { | 370 | ({ ... }: { |
| 312 | config.nfsroot.storeDevice = "10.141.0.1:nix-store"; | 371 | config.nfsroot.storeDevice = "${nfsIp}:nix-store"; |
| 313 | config.nfsroot.registrationUrl = "${nfsrootBaseUrl}/eostre/registration"; | 372 | config.nfsroot.registrationUrl = "${nfsrootBaseUrl}/eostre/registration"; |
| 373 | config.system.nixos.label = "eostre"; | ||
| 314 | }) | 374 | }) |
| 315 | ]; | 375 | ]; |
| 316 | }).config.system.build; | 376 | }); |
| 377 | eostreBuild = eostreBuild'.config.system.build; | ||
| 317 | in builtins.toPath (pkgs.runCommandLocal "eostre" {} '' | 378 | in builtins.toPath (pkgs.runCommandLocal "eostre" {} '' |
| 318 | mkdir -p $out/eostre | 379 | mkdir -p $out/eostre |
| 319 | install -m 0444 -t $out/eostre \ | 380 | install -m 0444 -t $out/eostre \ |
| @@ -321,35 +382,39 @@ in { | |||
| 321 | ${eostreBuild.kernel}/bzImage \ | 382 | ${eostreBuild.kernel}/bzImage \ |
| 322 | ${eostreBuild.netbootIpxeScript}/netboot.ipxe \ | 383 | ${eostreBuild.netbootIpxeScript}/netboot.ipxe \ |
| 323 | ${pkgs.closureInfo { rootPaths = eostreBuild.storeContents; }}/registration | 384 | ${pkgs.closureInfo { rootPaths = eostreBuild.storeContents; }}/registration |
| 324 | '')) | 385 | install -m 0444 ${pkgs.writeText "eostre.menu.ipxe" '' |
| 325 | (pkgs.writeTextFile { | 386 | #!ipxe |
| 326 | name = "eostre.menu.ipxe"; | ||
| 327 | destination = "/eostre.menu.ipxe"; | ||
| 328 | text = '' | ||
| 329 | set menu-timeout 5000 | ||
| 330 | 387 | ||
| 331 | :start | 388 | set menu-timeout 5000 |
| 332 | menu iPXE boot menu for eostre | ||
| 333 | item eostre Boot eostre | ||
| 334 | item netboot netboot.xyz | ||
| 335 | item shell iPXE shell | ||
| 336 | choose --timeout ''${menu-timeout} --default eostre selected || goto shell | ||
| 337 | goto ''${selected} | ||
| 338 | 389 | ||
| 339 | :shell | 390 | :start |
| 340 | shell | 391 | menu iPXE boot menu for eostre |
| 341 | set menu-timeout 0 | 392 | item eostre ${with eostreBuild'; "${config.system.nixos.distroName} ${config.system.nixos.codeName} ${config.system.nixos.label} (Linux ${config.boot.kernelPackages.kernel.modDirVersion})"} |
| 342 | goto start | 393 | item memtest memtest86plus |
| 394 | item netboot netboot.xyz | ||
| 395 | item shell iPXE shell | ||
| 396 | choose --timeout ''${menu-timeout} --default eostre selected || goto shell | ||
| 397 | set menu-timeout 0 | ||
| 398 | goto ''${selected} | ||
| 343 | 399 | ||
| 344 | :eostre | 400 | :shell |
| 345 | chain ${nfsrootBaseUrl}/eostre/netboot.ipxe | 401 | set menu-timeout 0 |
| 346 | goto start | 402 | shell |
| 403 | goto start | ||
| 404 | |||
| 405 | :eostre | ||
| 406 | chain eostre/netboot.ipxe | ||
| 407 | goto start | ||
| 408 | |||
| 409 | :netboot | ||
| 410 | iseq ''${platform} efi && chain --autofree netboot.xyz.efi || chain --autofree netboot.xyz.lkrn | ||
| 411 | goto start | ||
| 347 | 412 | ||
| 348 | :netboot | 413 | :memtest |
| 349 | chain --autofree ${nfsrootBaseUrl}/netboot.xyz.efi | 414 | iseq ''${platform} efi && chain --autofree memtest.efi || chain --autofree memtest.bin |
| 350 | goto start | 415 | goto start |
| 351 | ''; | 416 | ''} $out/eostre.menu.ipxe |
| 352 | }) | 417 | ''))) |
| 353 | ]; | 418 | ]; |
| 354 | }; | 419 | }; |
| 355 | }; | 420 | }; |
| @@ -360,20 +425,12 @@ in { | |||
| 360 | after = [ "network.target" ]; | 425 | after = [ "network.target" ]; |
| 361 | wantedBy = [ "multi-user.target" ]; | 426 | wantedBy = [ "multi-user.target" ]; |
| 362 | serviceConfig.ExecStart = let | 427 | serviceConfig.ExecStart = let |
| 363 | ipxe = pkgs.ipxe.override { | ||
| 364 | additionalTargets = { | ||
| 365 | "bin-i386-efi/ipxe.efi" = "i386-ipxe.efi"; | ||
| 366 | }; | ||
| 367 | additionalOptions = [ | ||
| 368 | "NSLOOKUP_CMD" | ||
| 369 | ]; | ||
| 370 | }; | ||
| 371 | tftpRoot = pkgs.runCommandLocal "netboot" {} '' | 428 | tftpRoot = pkgs.runCommandLocal "netboot" {} '' |
| 372 | mkdir -p $out | 429 | mkdir -p $out |
| 373 | install -m 0444 -t $out \ | 430 | install -m 0444 -t $out \ |
| 374 | ${ipxe}/ipxe.efi ${ipxe}/i386-ipxe.efi ${ipxe}/undionly.kpxe | 431 | ${ipxe}/{ipxe.efi,i386-ipxe.efi,ipxe.lkrn} |
| 375 | ''; | 432 | ''; |
| 376 | in "${pkgs.atftp}/sbin/atftpd --daemon --no-fork --bind-address=10.141.0.1 ${tftpRoot}"; | 433 | in "${pkgs.atftp}/sbin/atftpd --daemon --no-fork --bind-address=${tftpIp} ${tftpRoot}"; |
| 377 | }; | 434 | }; |
| 378 | }; | 435 | }; |
| 379 | } | 436 | } |
