this now takes into account the 'not_allowed_nodes' hash we get from the
api call. With that, we can now limit the 'local_resources' check for
online vms only, as for offline guests, the 'unavailable-resources' hash
already includes mapped devices that don't exist on the target node.

This now also includes unavailable storages on target nodes.

Signed-off-by: Dominik Csapak <d.csa...@proxmox.com>
---
 PVE/API2/Nodes.pm | 14 +++++++++++++-
 1 file changed, 13 insertions(+), 1 deletion(-)

diff --git a/PVE/API2/Nodes.pm b/PVE/API2/Nodes.pm
index fb4fd4d6..882d7301 100644
--- a/PVE/API2/Nodes.pm
+++ b/PVE/API2/Nodes.pm
@@ -2255,11 +2255,23 @@ my $create_migrate_worker = sub {
            $invalidConditions .= join(', ', map { $_->{volid} } 
@{$preconditions->{local_disks}});
        }
 
-       if (@{$preconditions->{local_resources}}) {
+       if ($online && scalar($preconditions->{local_resources}->@*)) {
            $invalidConditions .= "\n  Has local resources: ";
            $invalidConditions .= join(', ', 
@{$preconditions->{local_resources}});
        }
 
+       if (my $not_allowed_nodes = $preconditions->{not_allowed_nodes}) {
+           if (my $unavail_storages = 
$not_allowed_nodes->{$target}->{unavailable_storages}) {
+               $invalidConditions .= "\n  Has unavailable storages: ";
+               $invalidConditions .= join(', ', $unavail_storages->@*);
+           }
+
+           if (my $unavail_resources = 
$not_allowed_nodes->{$target}->{'unavailable-resources'}) {
+               $invalidConditions .= "\n  Has unavailable resources ";
+               $invalidConditions .= join(', ', $unavail_resources->@*);
+           }
+       }
+
        if ($invalidConditions && $invalidConditions ne '') {
            print STDERR "skip VM $vmid - precondition check failed:";
            die "$invalidConditions\n";
-- 
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