Merge pull request #94 from tilpner/virtual-noninteractive
kexec-installer: add virtual and noninteractive variants for smaller images
This commit is contained in:
commit
be735fd314
3 changed files with 48 additions and 4 deletions
18
flake.nix
18
flake.nix
|
@ -17,14 +17,24 @@
|
||||||
in {
|
in {
|
||||||
packages = forAllSystems (system: let
|
packages = forAllSystems (system: let
|
||||||
netboot = nixpkgs: (import (nixpkgs + "/nixos/release.nix") {}).netboot.${system};
|
netboot = nixpkgs: (import (nixpkgs + "/nixos/release.nix") {}).netboot.${system};
|
||||||
kexec-installer = nixpkgs: (nixpkgs.legacyPackages.${system}.nixos [self.nixosModules.kexec-installer]).config.system.build.kexecTarball;
|
kexec-installer = nixpkgs: modules: (nixpkgs.legacyPackages.${system}.nixos (modules ++ [self.nixosModules.kexec-installer])).config.system.build.kexecTarball;
|
||||||
in {
|
in {
|
||||||
netboot-nixos-unstable = netboot nixos-unstable;
|
netboot-nixos-unstable = netboot nixos-unstable;
|
||||||
netboot-nixos-2211 = netboot nixos-2211;
|
netboot-nixos-2211 = netboot nixos-2211;
|
||||||
kexec-installer-nixos-unstable = kexec-installer nixos-unstable;
|
kexec-installer-nixos-unstable = kexec-installer nixos-unstable [];
|
||||||
kexec-installer-nixos-2211 = kexec-installer nixos-2211;
|
kexec-installer-nixos-2211 = kexec-installer nixos-2211 [];
|
||||||
|
|
||||||
|
kexec-installer-nixos-unstable-noninteractive = kexec-installer nixos-unstable [ self.nixosModules.noninteractive ];
|
||||||
|
kexec-installer-nixos-2211-noninteractive = kexec-installer nixos-2211 [ self.nixosModules.noninteractive ];
|
||||||
|
|
||||||
|
kexec-installer-nixos-unstable-virtual-noninteractive = kexec-installer nixos-unstable [ self.nixosModules.noninteractive self.nixosModules.virtual ];
|
||||||
|
kexec-installer-nixos-2211-virtual-noninteractive = kexec-installer nixos-2211 [ self.nixosModules.noninteractive self.nixosModules.virtual ];
|
||||||
});
|
});
|
||||||
nixosModules.kexec-installer = import ./nix/kexec-installer/module.nix;
|
nixosModules = {
|
||||||
|
kexec-installer = ./nix/kexec-installer/module.nix;
|
||||||
|
noninteractive = ./nix/noninteractive.nix;
|
||||||
|
virtual = ./nix/virtual.nix;
|
||||||
|
};
|
||||||
checks.x86_64-linux = let
|
checks.x86_64-linux = let
|
||||||
pkgs = nixos-unstable.legacyPackages.x86_64-linux;
|
pkgs = nixos-unstable.legacyPackages.x86_64-linux;
|
||||||
in {
|
in {
|
||||||
|
|
29
nix/noninteractive.nix
Normal file
29
nix/noninteractive.nix
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
# This module optimizes for non-interactive deployments by remove some store paths
|
||||||
|
# which are primarily useful for interactive installations.
|
||||||
|
|
||||||
|
{ config, lib, ... }: {
|
||||||
|
disabledModules = [
|
||||||
|
# This module adds values to multiple lists (systemPackages, supportedFilesystems)
|
||||||
|
# which are impossible/unpractical to remove, so we disable the entire module.
|
||||||
|
"profiles/base.nix"
|
||||||
|
];
|
||||||
|
|
||||||
|
# among others, this prevents carrying a stdenv with gcc in the image
|
||||||
|
system.extraDependencies = lib.mkForce [];
|
||||||
|
|
||||||
|
|
||||||
|
# prevents shipping nixpkgs, unnecessary if system is evaluated externally
|
||||||
|
nix.registry = lib.mkForce {};
|
||||||
|
|
||||||
|
# would pull in nano
|
||||||
|
programs.nano.syntaxHighlight = lib.mkForce false;
|
||||||
|
|
||||||
|
# prevents nano, rsync, strace
|
||||||
|
environment.defaultPackages = lib.mkForce [];
|
||||||
|
|
||||||
|
# zfs support is accidentally disabled by excluding base.nix, re-enable it
|
||||||
|
boot = {
|
||||||
|
kernelModules = [ "zfs" ];
|
||||||
|
extraModulePackages = [ config.boot.kernelPackages.zfs ];
|
||||||
|
};
|
||||||
|
}
|
5
nix/virtual.nix
Normal file
5
nix/virtual.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
# This module optimizes for deployments to virtualized hosts.
|
||||||
|
|
||||||
|
{ lib, ... }: {
|
||||||
|
hardware.enableRedistributableFirmware = lib.mkForce false;
|
||||||
|
}
|
Loading…
Reference in a new issue