2022-02-25 17:52:17 +01:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
2023-03-24 14:32:39 +01:00
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.deuxfleurs.remoteUnlock;
|
|
|
|
in
|
2022-02-25 17:52:17 +01:00
|
|
|
with builtins;
|
|
|
|
with pkgs.lib;
|
|
|
|
{
|
2023-03-24 14:32:39 +01:00
|
|
|
options.deuxfleurs.remoteUnlock = {
|
|
|
|
networkInterface = mkOption {
|
|
|
|
description = "Network interface to configure with static IP";
|
|
|
|
type = types.str;
|
|
|
|
};
|
|
|
|
staticIP = mkOption {
|
|
|
|
description = "IP address (with prefix length) of this node on the local network interface";
|
|
|
|
type = types.str;
|
|
|
|
};
|
|
|
|
defaultGateway = mkOption {
|
|
|
|
description = "IP address of default gateway";
|
|
|
|
type = types.str;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-02-25 17:52:17 +01:00
|
|
|
config = {
|
|
|
|
boot.initrd.availableKernelModules = [ "pps_core" "ptp" "e1000e" ];
|
|
|
|
boot.initrd.network.enable = true;
|
|
|
|
boot.initrd.network.ssh = {
|
|
|
|
enable = true;
|
2022-02-25 19:11:25 +01:00
|
|
|
port = 222;
|
2023-03-24 15:26:39 +01:00
|
|
|
authorizedKeys = concatLists (mapAttrsToList (name: user: user) config.deuxfleurs.adminAccounts);
|
2022-02-25 17:52:17 +01:00
|
|
|
hostKeys = [ "/var/lib/deuxfleurs/remote-unlock/ssh_host_ed25519_key" ];
|
|
|
|
};
|
|
|
|
boot.initrd.network.postCommands = ''
|
2023-03-24 14:32:39 +01:00
|
|
|
ip addr add ${cfg.staticIP} dev ${cfg.networkInterface}
|
|
|
|
ip link set dev ${cfg.networkInterface} up
|
|
|
|
ip route add default via ${cfg.defaultGateway} dev ${cfg.networkInterface}
|
2022-02-25 17:52:17 +01:00
|
|
|
ip a
|
|
|
|
ip route
|
2023-03-24 14:32:39 +01:00
|
|
|
ping -c 4 ${cfg.defaultGateway}
|
2022-02-25 17:52:17 +01:00
|
|
|
echo 'echo run cryptsetup-askpass to unlock drives' >> /root/.profile
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|