2025-04-06 22:09:17 +02:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
pkgs,
|
2025-07-19 21:51:37 +02:00
|
|
|
sources,
|
2025-04-06 22:09:17 +02:00
|
|
|
...
|
2025-07-22 20:54:09 +02:00
|
|
|
}: let
|
2025-04-06 22:09:17 +02:00
|
|
|
inherit (lib.modules) mkIf;
|
2025-05-17 23:45:38 +02:00
|
|
|
inherit (lib.options) mkEnableOption;
|
|
|
|
|
|
|
|
cfg = config.modules.system.boot.lanzaboote;
|
2025-07-22 20:54:09 +02:00
|
|
|
in {
|
2025-05-17 23:45:38 +02:00
|
|
|
options.modules.system.boot.lanzaboote.enable = mkEnableOption "Lanzaboote";
|
2025-04-06 22:09:17 +02:00
|
|
|
imports = [
|
2025-07-22 20:54:09 +02:00
|
|
|
(import sources.flake-compat {
|
|
|
|
src = sources.lanzaboote;
|
|
|
|
copySourceTreeToStore = false;
|
|
|
|
useBuiltinsFetchTree = true;
|
|
|
|
}).outputs.nixosModules.lanzaboote
|
2025-04-06 22:09:17 +02:00
|
|
|
];
|
|
|
|
|
2025-05-17 23:45:38 +02:00
|
|
|
config = mkIf cfg.enable {
|
2025-04-06 22:09:17 +02:00
|
|
|
boot = {
|
|
|
|
lanzaboote = {
|
|
|
|
enable = true;
|
|
|
|
pkiBundle = "/var/lib/sbctl";
|
|
|
|
};
|
|
|
|
|
|
|
|
# Lanzaboote currently replaces the systemd-boot module.
|
|
|
|
# This setting is usually set to true in configuration.nix
|
|
|
|
# generated at installation time. So we force it to false
|
|
|
|
# for now.
|
|
|
|
loader.systemd-boot.enable = lib.mkForce false;
|
|
|
|
};
|
|
|
|
|
2025-07-22 20:54:09 +02:00
|
|
|
environment.systemPackages = [pkgs.sbctl];
|
2025-04-06 22:09:17 +02:00
|
|
|
};
|
|
|
|
}
|