]> git.proxmox.com Git - pve-cluster.git/blobdiff - src/PVE/SSHInfo.pm
fix #4886: SSH: pin node's host key if available
[pve-cluster.git] / src / PVE / SSHInfo.pm
index c351148cbe43e1e4166647f9b579915a2e202832..16ed85a6818f9c9262ea873759f61de067feccb9 100644 (file)
@@ -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
     ];
 }