]> git.proxmox.com Git - pve-manager.git/commitdiff
pve6to7: check for misconfigured content type 'none'
authorFabian Ebner <f.ebner@proxmox.com>
Mon, 21 Jun 2021 14:31:40 +0000 (16:31 +0200)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Mon, 21 Jun 2021 14:52:55 +0000 (16:52 +0200)
which will be a hard error (i.e. section will be skipped when parsing) in PVE
7.0

Signed-off-by: Fabian Ebner <f.ebner@proxmox.com>
(cherry picked from commit 1cad0c7fdf1398e08625077dfa30d53256ef475b)
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
PVE/CLI/pve6to7.pm

index 60464861f7a23d8b387ad91911cbed43191676e6..7777aa6c0ad7e7c839522e5aeebf0ce621a7c646 100644 (file)
@@ -18,6 +18,7 @@ use PVE::JSONSchema;
 use PVE::NodeConfig;
 use PVE::RPCEnvironment;
 use PVE::Storage;
+use PVE::Storage::Plugin;
 use PVE::Tools qw(run_command split_list);
 use PVE::QemuConfig;
 use PVE::QemuServer;
@@ -703,7 +704,7 @@ sub check_description_lengths {
 }
 
 sub check_storage_content {
-    log_info("Scanning for guest images on storages without images/rootdir content type..");
+    log_info("Checking storage content type configuration..");
 
     my $found;
 
@@ -714,6 +715,13 @@ sub check_storage_content {
 
        next if !PVE::Storage::storage_check_enabled($storage_cfg, $storeid, undef, 1);
 
+       my $valid_content = PVE::Storage::Plugin::valid_content_types($scfg->{type});
+
+       if (scalar(keys $scfg->{content}->%*) == 0 && !$valid_content->{none}) {
+           log_fail("storage '$storeid' does not support configured content type 'none'");
+           delete $scfg->{content}->{none}; # scan for guest images below
+       }
+
        next if $scfg->{content}->{images};
        next if $scfg->{content}->{rootdir};
 
@@ -739,7 +747,7 @@ sub check_storage_content {
        log_warn("PVE 7.0 enforces stricter content type checks. Guests referencing the above " .
            "volumes will not work until the storage configuration is fixed.");
     } else {
-       log_pass("none found");
+       log_pass("no problems found");
     }
 }