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;
|
2023-06-11 18:20:11 +00:00
|
|
|
in lib.concatMapStrings (key: "${d.ssh.HostName} ${key}\n") d.sshPublicKeys
|
2023-03-17 04:21:32 +00:00
|
|
|
)
|
|
|
|
(builtins.attrNames nixosConfigurations)
|
|
|
|
);
|
|
|
|
|
2023-06-11 18:20:11 +00:00
|
|
|
attrsToList = lib.mapAttrsToList (n: v: "${n} ${v}");
|
|
|
|
attrsToLines = a: lib.concatLines (attrsToList a);
|
|
|
|
|
2023-03-17 04:21:32 +00:00
|
|
|
in
|
|
|
|
builtins.toFile "ssh-config" (''
|
|
|
|
StrictHostKeyChecking yes
|
|
|
|
GlobalKnownHostsFile ${sshKnownHostsTxt}
|
|
|
|
'' +
|
|
|
|
lib.concatMapStrings
|
|
|
|
(host: ''
|
|
|
|
Host ${host}
|
2023-06-11 18:20:11 +00:00
|
|
|
${attrsToLines nixosConfigurations.${host}.config.deploy.ssh}
|
2023-03-17 04:21:32 +00:00
|
|
|
'')
|
|
|
|
(builtins.attrNames nixosConfigurations))
|