infra/nixos/modules/boot/luks-ssh.nix

54 lines
1.2 KiB
Nix
Raw Normal View History

2024-10-13 15:16:39 -05:00
{
config,
lib,
...
}:
with lib; let
2024-12-13 16:47:09 -06:00
baseCfg = config.gen.bootloader;
2024-10-13 15:16:39 -05:00
cfg = baseCfg.luksSsh;
in {
2024-12-13 16:47:09 -06:00
options.gen.bootloader.luksSsh = {
enable = mkEnableOption "use boot process with luks unlock over ssh";
port = mkOption {
type = types.port;
2024-10-13 15:16:39 -05:00
description = "port for ssh server to listen on";
};
hostKeys = mkOption {
type = types.listOf types.path;
2024-10-13 15:16:39 -05:00
description = "paths of host keys for the ssh server to use";
};
};
config = mkIf cfg.enable {
2024-10-13 15:16:39 -05:00
# ### Use systemd-boot ###
# boot.loader = {
# efi.canTouchEfiVariables = true;
# timeout = 2;
# systemd-boot = {
# enable = true;
# configurationLimit = 3;
# };
# };
### LUKS unlock through SSH ###
boot.initrd = {
network = {
enable = true;
flushBeforeStage2 = true;
ssh = {
enable = true;
2024-12-13 16:47:09 -06:00
authorizedKeys = import ../../keys/ssh.nix;
2024-10-13 15:16:39 -05:00
inherit (cfg) hostKeys port;
};
postCommands = ''
# Automatically ask for the password on SSH login
echo 'cryptsetup-askpass || echo "Unlock was successful; exiting SSH session" && exit 1' >> /root/.profile
'';
};
};
};
}