On 9/23/19 10:50 AM, Dominik Csapak wrote:
> otherwise a user with only VM.Config.HWType cannot
> delete a 'pending' usbX: spice or serial: socket option
> 
> Signed-off-by: Dominik Csapak <d.csa...@proxmox.com>
> ---
>  PVE/API2/Qemu.pm | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> diff --git a/PVE/API2/Qemu.pm b/PVE/API2/Qemu.pm
> index 3355c8b..5814f94 100644
> --- a/PVE/API2/Qemu.pm
> +++ b/PVE/API2/Qemu.pm
> @@ -1202,7 +1202,7 @@ my $update_vm_api  = sub {
>                   PVE::QemuServer::vmconfig_delete_pending_option($conf, 
> $opt, $force);
>                   PVE::QemuConfig->write_config($vmid, $conf);
>               } elsif ($opt =~ m/^serial\d+$/) {
> -                 if ($conf->{$opt} eq 'socket') {
> +                 if ($conf->{$opt} eq 'socket' || (!$conf->{$opt} && 
> $conf->{pending}->{$opt} eq 'socket')) {
>                       $rpcenv->check_vm_perm($authuser, $vmid, undef, 
> ['VM.Config.HWType']);
>                   } elsif ($authuser ne 'root@pam') {
>                       die "only root can delete '$opt' config for real 
> devices\n";
> @@ -1210,7 +1210,7 @@ my $update_vm_api  = sub {
>                   PVE::QemuServer::vmconfig_delete_pending_option($conf, 
> $opt, $force);
>                   PVE::QemuConfig->write_config($vmid, $conf);
>               } elsif ($opt =~ m/^usb\d+$/) {
> -                 if ($conf->{$opt} =~ m/spice/) {
> +                 if ($conf->{$opt} =~ m/spice/ || (!$conf->{$opt} && 
> $conf->{pending}->{$opt} =~ m/spice/)) {
>                       $rpcenv->check_vm_perm($authuser, $vmid, undef, 
> ['VM.Config.HWType']);
>                   } elsif ($authuser ne 'root@pam') {
>                       die "only root can delete '$opt' config for real 
> devices\n";
> 

I'll get:
> Use of uninitialized value in pattern match (m//) at 
> /usr/share/perl5/PVE/API2/Qemu.pm line 1213.

This was an issue before your patch (but from an older patch of yours), as
the if branch was hit the same way.

I followed up with a patch introducing a $val variable which is the config
option, or the pending option as fallback. So then we can check only that
single variable and make the if/else conditions a bit easier to read..
and it solves this issue as we've the invariant that either (config or pending)
option is defined here.

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

Reply via email to