Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
49 lines
1.1 KiB
Nix
49 lines
1.1 KiB
Nix
{
|
|
config,
|
|
pkgs,
|
|
lib,
|
|
...
|
|
}:
|
|
|
|
with lib;
|
|
|
|
{
|
|
|
|
config = mkIf config.boot.isContainer {
|
|
|
|
# Disable some features that are not useful in a container.
|
|
|
|
# containers don't have a kernel
|
|
boot.kernel.enable = false;
|
|
boot.modprobeConfig.enable = false;
|
|
|
|
console.enable = mkDefault false;
|
|
|
|
nix.optimise.automatic = mkDefault false; # the store is host managed
|
|
powerManagement.enable = mkDefault false;
|
|
documentation.nixos.enable = mkDefault false;
|
|
|
|
networking.useHostResolvConf = mkDefault true;
|
|
|
|
# Containers should be light-weight, so start sshd on demand.
|
|
services.openssh.startWhenNeeded = mkDefault true;
|
|
|
|
# containers do not need to setup devices
|
|
services.udev.enable = false;
|
|
|
|
# containers normally do not need to manage logical volumes
|
|
services.lvm.enable = lib.mkDefault false;
|
|
|
|
# Shut up warnings about not having a boot loader.
|
|
system.build.installBootLoader = lib.mkDefault "${pkgs.coreutils}/bin/true";
|
|
|
|
# Not supported in systemd-nspawn containers.
|
|
security.audit.enable = false;
|
|
|
|
# Use the host's nix-daemon.
|
|
environment.variables.NIX_REMOTE = "daemon";
|
|
|
|
};
|
|
|
|
}
|