nixos-config/lib/gen-ssh-config.nix

28 lines
703 B
Nix
Raw Normal View History

2023-03-17 04:21:32 +00:00
lib:
nixosConfigurations:
let
sshKnownHostsTxt = builtins.toFile "known_hosts" (lib.concatMapStrings
(hostName:
let d = nixosConfigurations.${hostName}.config.deploy;
in lib.concatMapStrings (key: "${d.ssh.HostName} ${key}\n") d.sshPublicKeys
2023-03-17 04:21:32 +00:00
)
(builtins.attrNames nixosConfigurations)
);
attrsToList = lib.mapAttrsToList (n: v: "${n} ${v}");
attrsToLines = a: lib.concatLines (attrsToList a);
2023-03-17 04:21:32 +00:00
in
2023-07-07 19:34:00 +00:00
builtins.toFile "ssh-config" (
lib.concatMapStrings
(host: ''
Host ${host}
${attrsToLines nixosConfigurations.${host}.config.deploy.ssh}
'')
(builtins.attrNames nixosConfigurations) +
''
GlobalKnownHostsFile ${sshKnownHostsTxt}
''
)