if the target node has already stored their SSH host key on pmxcfs, pin it and
ignore the global known hosts information.

Signed-off-by: Fabian Grünbichler <f.gruenbich...@proxmox.com>
---
 src/PVE/SSHInfo.pm | 15 ++++++++++++++-
 1 file changed, 14 insertions(+), 1 deletion(-)

diff --git a/src/PVE/SSHInfo.pm b/src/PVE/SSHInfo.pm
index c351148..fad23bf 100644
--- a/src/PVE/SSHInfo.pm
+++ b/src/PVE/SSHInfo.pm
@@ -49,11 +49,24 @@ sub get_ssh_info {
 
 sub ssh_info_to_command_base {
     my ($info, @extra_options) = @_;
+
+    my $nodename = $info->{name};
+
+    my $known_hosts_file = "/etc/pve/nodes/$nodename/ssh_known_hosts";
+    my $known_hosts_options = undef;
+    if (-f $known_hosts_file) {
+       $known_hosts_options = [
+           '-o', "UserKnownHostsFile=$known_hosts_file",
+           '-o', 'GlobalKnownHostsFile=none',
+       ];
+    } 
+
     return [
        '/usr/bin/ssh',
        '-e', 'none',
        '-o', 'BatchMode=yes',
-       '-o', 'HostKeyAlias='.$info->{name},
+       '-o', 'HostKeyAlias='.$nodename,
+       defined($known_hosts_options) ? @$known_hosts_options : (),
        @extra_options
     ];
 }
-- 
2.39.2



_______________________________________________
pve-devel mailing list
pve-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel

Reply via email to