about summary refs log blame commit diff stats
path: root/modules/system/boot/default.nix
blob: 1e6fa99b02ca85ea4a055a6e9cfb702ab3e7d4dd (plain) (tree)































































































































                                                                                                              
{
  config,
  lib,
  pkgs,
  ...
}: let
  cfg = config.soispha.boot;
in {
  options.soispha.boot = {
    enable = lib.mkEnableOption "Bootloader configuration";
    # TODO: Add this option <2024-05-16>
    # enableIsoEntry = lib.mkEnableOption "an tails iso boot entry";
  };

  config = lib.mkIf cfg.enable (
    # let
    # cfg = config.boot.loader.systemd-boot;
    # inherit (config.boot.loader) efi;
    #
    # esa = n: lib.strings.escapeShellArg n;
    #
    # bootMountPoint =
    #   if cfg.xbootldrMountPoint != null
    #   then cfg.xbootldrMountPoint
    #   else efi.efiSysMountPoint;
    #
    # nixosDir = "/EFI/nixos";
    #
    # # FIXME: This system has two big problems:
    # # 1. It does not updated files, which still have the same name
    # # 2. It forgets about files, which were 'deleted' in this configuration (these just
    # #    stay on disk forever) <2024-05-11>
    # copyExtraFiles = ''
    #   echo "[systemd-boot] copying files to ${bootMountPoint}"
    #   empty_file=$(mktemp)
    #
    #   ${lib.concatStrings (lib.mapAttrsToList (n: v:
    #     /*
    #     bash
    #     */
    #     ''
    #       if ! [ -e ${esa "${bootMountPoint}/${n}"} ]; then
    #         install -Dp "${v}" ${esa "${bootMountPoint}/${n}"}
    #         install -D "$empty_file" ${esa "${bootMountPoint}/${nixosDir}/.extra-files/${n}"}
    #       fi
    #     '')
    #   cfg.extraFiles)}
    #
    #   ${lib.concatStrings (lib.mapAttrsToList (n: v:
    #     /*
    #     bash
    #     */
    #     ''
    #       # if ! [ -e ${esa "${bootMountPoint}/loader/entries/${n}"} ]; then
    #         install -Dp "${pkgs.writeText n v}" ${esa "${bootMountPoint}/loader/entries/${n}"}
    #         install -D "$empty_file" ${esa "${bootMountPoint}/${nixosDir}/.extra-files/loader/entries/${n}"}
    #       # fi
    #     '')
    #   cfg.extraEntries)}
    # '';
    # in
    {
      # FIXME: Reactviate this whole iso thing when a disko redeploy is done.
      # (and switch to tails instead of arch) <2024-05-12>
      #
      # system.activationScripts = {
      #   copyExtraFilesForBoot = copyExtraFiles;
      # };

      boot = {
        initrd = {
          kernelModules = ["nvme" "btrfs"];
        };

        kernelPackages = pkgs.linuxPackages_latest;

        lanzaboote = {
          enable = true;
          pkiBundle = "/etc/secureboot";

          settings = {
            # Disable editing the kernel command line (which could allow someone to become root)
            editor = false;
          };
        };

        loader = {
          systemd-boot = {
            # 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.
            enable = false;

            # extraEntries = {
            #   "live.conf" = ''
            #     title Archlinux Live ISO
            #     linux /live/vmlinuz-linux
            #     initrd /live/initramfs-linux.img
            #     options img_dev=${config.soispha.disks.disk} img_loop=/archlinux.iso copytoram
            #   '';
            # };
            #
            # extraFiles = let
            #   iso = import ./archlive_iso.nix {inherit pkgs;};
            # in {
            #   "archlinux.iso" = "${iso}/archlinux.iso";
            #   "live/initramfs-linux.img" = "${iso}/live/initramfs-linux.img";
            #   "live/vmlinuz-linux" = "${iso}/live/vmlinuz-linux";
            # };
          };

          grub = {
            enable = false;
            # theme = pkgs.nixos-grub2-theme;
            splashImage = ./boot_pictures/gnu.png;
            efiSupport = true;
            device = "nodev"; # only for efi
          };

          efi = {
            canTouchEfiVariables = true;
            efiSysMountPoint = "/boot";
          };
        };
      };
    }
  );
}