]> git.proxmox.com Git - pve-manager.git/commitdiff
ui: firewall: refactor privilege checks and prevent double click
authorDominik Csapak <d.csapak@proxmox.com>
Wed, 7 Jun 2023 07:18:48 +0000 (09:18 +0200)
committerDominik Csapak <d.csapak@proxmox.com>
Wed, 7 Jun 2023 11:22:03 +0000 (13:22 +0200)
factor out the relevant privilege checks in a variable and reuse that,
also add the check in the run_editor (or wrap it with a check) so that
the edit windows don't open with a double click without those privileges

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
www/manager6/dc/SecurityGroups.js
www/manager6/grid/FirewallAliases.js
www/manager6/grid/FirewallOptions.js
www/manager6/grid/FirewallRules.js
www/manager6/panel/IPSet.js

index b19e370bd49f0b15d30d5b9fced34fde0879b38a..9e26b84c951f57abe6753665084adfe3630ca626 100644 (file)
@@ -101,6 +101,7 @@ Ext.define('PVE.SecurityGroupList', {
        let sm = Ext.create('Ext.selection.RowModel', {});
 
        let caps = Ext.state.Manager.get('GuiCap');
+       let canEdit = !!caps.dc['Sys.Modify'];
 
        let reload = function() {
            let oldrec = sm.getSelection()[0];
@@ -116,7 +117,7 @@ Ext.define('PVE.SecurityGroupList', {
 
        let run_editor = function() {
            let rec = sm.getSelection()[0];
-           if (!rec) {
+           if (!rec || !canEdit) {
                return;
            }
            Ext.create('PVE.SecurityGroupEdit', {
@@ -132,14 +133,14 @@ Ext.define('PVE.SecurityGroupList', {
 
        me.editBtn = new Proxmox.button.Button({
            text: gettext('Edit'),
-           enableFn: rec => !!caps.dc['Sys.Modify'],
+           enableFn: rec => canEdit,
            disabled: true,
            selModel: sm,
            handler: run_editor,
        });
        me.addBtn = new Proxmox.button.Button({
            text: gettext('Create'),
-           disabled: !caps.dc['Sys.Modify'],
+           disabled: !canEdit,
            handler: function() {
                sm.deselectAll();
                var win = Ext.create('PVE.SecurityGroupEdit', {});
@@ -151,12 +152,7 @@ Ext.define('PVE.SecurityGroupList', {
        me.removeBtn = Ext.create('Proxmox.button.StdRemoveButton', {
            selModel: sm,
            baseurl: me.base_url + '/',
-           enableFn: function(rec) {
-               if (!caps.dc['Sys.Modify']) {
-                   return false;
-               }
-               return rec && me.base_url;
-           },
+           enableFn: (rec) => canEdit && rec && me.base_url,
            callback: () => reload(),
        });
 
index b6f07334801b4338793c8131aeff0e33bfbaef2b..0fb6962eba4dde4150c94082ee59d06e92e736d7 100644 (file)
@@ -105,6 +105,7 @@ Ext.define('PVE.FirewallAliases', {
        let sm = Ext.create('Ext.selection.RowModel', {});
 
        let caps = Ext.state.Manager.get('GuiCap');
+       let canEdit = !!caps.vms['VM.Config.Network'] || !!caps.dc['Sys.Modify'] || !!caps.nodes['Sys.Modify'];
 
        let reload = function() {
            let oldrec = sm.getSelection()[0];
@@ -120,7 +121,7 @@ Ext.define('PVE.FirewallAliases', {
 
        let run_editor = function() {
            let rec = me.getSelectionModel().getSelection()[0];
-           if (!rec) {
+           if (!rec || !canEdit) {
                return;
            }
            let win = Ext.create('PVE.FirewallAliasEdit', {
@@ -135,7 +136,7 @@ Ext.define('PVE.FirewallAliases', {
            text: gettext('Edit'),
            disabled: true,
            selModel: sm,
-           enableFn: rec => !!caps.vms['VM.Config.Network'] || !!caps.dc['Sys.Modify'] || !!caps.nodes['Sys.Modify'],
+           enableFn: rec => canEdit,
            handler: run_editor,
        });
 
index 98b1d258d93eb8c068c2a23b67cc778ecb709909..0ac9979c4af3ef8dbf6724937efbf87bf2032672 100644 (file)
@@ -22,6 +22,7 @@ Ext.define('PVE.FirewallOptions', {
        }
 
        let caps = Ext.state.Manager.get('GuiCap');
+       let canEdit = caps.vms['VM.Config.Network'] || caps.dc['Sys.Modify'] || caps.nodes['Sys.Modify'];
 
        me.rows = {};
 
@@ -163,7 +164,7 @@ Ext.define('PVE.FirewallOptions', {
                return;
            }
            var rowdef = me.rows[rec.data.key];
-           if (caps.vms['VM.Config.Network'] || caps.dc['Sys.Modify'] || caps.nodes['Sys.Modify']) {
+           if (canEdit) {
                edit_btn.setDisabled(!rowdef.editor);
            }
        };
@@ -175,7 +176,7 @@ Ext.define('PVE.FirewallOptions', {
                url: '/api2/extjs/' + me.base_url,
            },
            listeners: {
-               itemdblclick: me.run_editor,
+               itemdblclick: () => { if (canEdit) { me.run_editor(); } },
                selectionchange: set_button_status,
            },
        });
index 6b3abb1ba14a23edd1605b54213a34fcc3c3884d..18075eaa60ae53e607c740030d68f1f13e510ed8 100644 (file)
@@ -569,7 +569,7 @@ Ext.define('PVE.FirewallRules', {
            }
            me.store.removeAll();
        } else {
-           if (me.caps.vms['VM.Config.Network'] || me.caps.dc['Sys.Modify'] || me.caps.nodes['Sys.Modify']) {
+           if (me.canEdit) {
                me.addBtn.setDisabled(false);
                if (me.groupBtn) {
                    me.groupBtn.setDisabled(false);
@@ -653,10 +653,11 @@ Ext.define('PVE.FirewallRules', {
        var sm = Ext.create('Ext.selection.RowModel', {});
 
        me.caps = Ext.state.Manager.get('GuiCap');
+       me.canEdit = !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'];
 
        var run_editor = function() {
            var rec = sm.getSelection()[0];
-           if (!rec) {
+           if (!rec || !me.canEdit) {
                return;
            }
            var type = rec.data.type;
@@ -685,7 +686,7 @@ Ext.define('PVE.FirewallRules', {
        me.editBtn = Ext.create('Proxmox.button.Button', {
            text: gettext('Edit'),
            disabled: true,
-           enableFn: rec => !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'],
+           enableFn: rec => me.canEdit,
            selModel: sm,
            handler: run_editor,
        });
@@ -727,7 +728,7 @@ Ext.define('PVE.FirewallRules', {
        me.copyBtn = Ext.create('Proxmox.button.Button', {
            text: gettext('Copy'),
            selModel: sm,
-           enableFn: ({ data }) => (data.type === 'in' || data.type === 'out') && (!!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify']),
+           enableFn: ({ data }) => (data.type === 'in' || data.type === 'out') && me.canEdit,
            disabled: true,
            handler: run_copy_editor,
        });
@@ -749,7 +750,7 @@ Ext.define('PVE.FirewallRules', {
        }
 
        me.removeBtn = Ext.create('Proxmox.button.StdRemoveButton', {
-           enableFn: rec => !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'],
+           enableFn: rec => me.canEdit,
            selModel: sm,
            baseurl: me.base_url + '/',
            confirmMsg: false,
index 784d0ea7c7c20c4b01d8c9377592cbfb05af037a..c449cdaa00d81e136df10513d69bcab5e37c838d 100644 (file)
@@ -43,6 +43,7 @@ Ext.define('PVE.IPSetList', {
        });
 
        var caps = Ext.state.Manager.get('GuiCap');
+       let canEdit = !!caps.vms['VM.Config.Network'] || !!caps.dc['Sys.Modify'] || !!caps.nodes['Sys.Modify'];
 
        var sm = Ext.create('Ext.selection.RowModel', {});
 
@@ -60,7 +61,7 @@ Ext.define('PVE.IPSetList', {
 
        var run_editor = function() {
            var rec = sm.getSelection()[0];
-           if (!rec) {
+           if (!rec || !canEdit) {
                return;
            }
            var win = Ext.create('Proxmox.window.Edit', {
@@ -96,7 +97,7 @@ Ext.define('PVE.IPSetList', {
        me.editBtn = new Proxmox.button.Button({
            text: gettext('Edit'),
            disabled: true,
-           enableFn: rec => !!caps.vms['VM.Config.Network'] || !!caps.dc['Sys.Modify'] || !!caps.nodes['Sys.Modify'],
+           enableFn: rec => canEdit,
            selModel: sm,
            handler: run_editor,
        });
@@ -131,7 +132,7 @@ Ext.define('PVE.IPSetList', {
        });
 
        me.removeBtn = Ext.create('Proxmox.button.StdRemoveButton', {
-           enableFn: rec => !!caps.vms['VM.Config.Network'] || !!caps.dc['Sys.Modify'] || !!caps.nodes['Sys.Modify'],
+           enableFn: rec => canEdit,
            selModel: sm,
            baseurl: me.base_url + '/',
            callback: reload,
@@ -158,7 +159,7 @@ Ext.define('PVE.IPSetList', {
            },
        });
 
-       if (!caps.vms['VM.Config.Network'] && !caps.dc['Sys.Modify'] && !caps.nodes['Sys.Modify']) {
+       if (!canEdit) {
            me.addBtn.setDisabled(true);
        }
 
@@ -276,7 +277,7 @@ Ext.define('PVE.IPSetGrid', {
            me.addBtn.setDisabled(true);
            me.store.removeAll();
        } else {
-           if (me.caps.vms['VM.Config.Network'] || me.caps.dc['Sys.Modify'] || me.caps.nodes['Sys.Modify']) {
+           if (me.canEdit) {
                me.addBtn.setDisabled(false);
            }
            me.removeBtn.baseurl = url + '/';
@@ -307,10 +308,11 @@ Ext.define('PVE.IPSetGrid', {
        var sm = Ext.create('Ext.selection.RowModel', {});
 
        me.caps = Ext.state.Manager.get('GuiCap');
+       me.canEdit = !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'];
 
        var run_editor = function() {
            var rec = sm.getSelection()[0];
-           if (!rec) {
+           if (!rec || !me.canEdit) {
                return;
            }
            var win = Ext.create('PVE.IPSetCidrEdit', {
@@ -324,7 +326,7 @@ Ext.define('PVE.IPSetGrid', {
        me.editBtn = new Proxmox.button.Button({
            text: gettext('Edit'),
            disabled: true,
-           enableFn: rec => !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'],
+           enableFn: rec => me.canEdit,
            selModel: sm,
            handler: run_editor,
        });
@@ -332,7 +334,7 @@ Ext.define('PVE.IPSetGrid', {
        me.addBtn = new Proxmox.button.Button({
            text: gettext('Add'),
            disabled: true,
-           enableFn: rec => !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'],
+           enableFn: rec => me.canEdit,
            handler: function() {
                if (!me.base_url) {
                    return;
@@ -348,7 +350,7 @@ Ext.define('PVE.IPSetGrid', {
 
        me.removeBtn = Ext.create('Proxmox.button.StdRemoveButton', {
            disabled: true,
-           enableFn: rec => !!me.caps.vms['VM.Config.Network'] || !!me.caps.dc['Sys.Modify'] || !!me.caps.nodes['Sys.Modify'],
+           enableFn: rec => me.canEdit,
            selModel: sm,
            baseurl: me.base_url + '/',
            callback: reload,