Merge branch 'offline-installer'

This commit was merged in pull request #24.
This commit is contained in:
UGA Innovation Factory
2026-01-05 15:49:19 -05:00
3 changed files with 27 additions and 23 deletions

View File

@@ -18,7 +18,7 @@ let
hostName:
let
targetConfig = self.nixosConfigurations.${hostName}.config;
targetSystem = targetConfig.system.build.toplevel;
targetSystemBuild = targetConfig.system.build;
diskoScript = targetConfig.system.build.diskoScript;
in
nixpkgs.lib.nixosSystem {
@@ -27,7 +27,7 @@ let
inherit
inputs
hostName
targetSystem
targetSystemBuild
diskoScript
;
hostPlatform = system;

View File

@@ -8,7 +8,7 @@
inputs,
hostName,
hostPlatform,
targetSystem,
targetSystemBuild,
diskoScript,
...
}:
@@ -18,7 +18,7 @@
pkgs.git
pkgs.bashInteractive
pkgs.curl
targetSystem
targetSystemBuild.toplevel
];
# Explicitly include the system closure in the ISO image to prevent any need to build or fetch
@@ -31,6 +31,12 @@
nixpkgs.hostPlatform = hostPlatform;
nix.settings.experimental-features = "nix-command flakes";
system.extraDependencies = with targetSystemBuild; [ toplevel etc bootStage2 ];
isoImage.storeContents = [ targetSystemBuild.toplevel ];
systemd.services.auto-install = {
description = "Automatic NixOS install for ${hostName}";
after = [
@@ -53,14 +59,12 @@
echo ">>> Running disko script..."
${diskoScript}
echo ">>> Running nixos-install..."
# Use only local store - don't fetch from binary cache or build
echo ">>> Setting up NixOS..."
nixos-install \
--no-root-passwd \
--root /mnt \
--system ${targetSystem} \
--option substitute false \
--option build-use-sandbox false
--system ${targetSystemBuild.toplevel} \
--no-root-passwd \
--no-channel-copy \
--substituters ""
echo ">>> Done. Rebooting."
systemctl reboot