]> git.proxmox.com Git - pve-manager.git/commitdiff
ui: vzdump: remove left-overs from target/policy based notifications
authorLukas Wagner <l.wagner@proxmox.com>
Tue, 14 Nov 2023 12:59:39 +0000 (13:59 +0100)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Fri, 17 Nov 2023 15:20:03 +0000 (16:20 +0100)
Signed-off-by: Lukas Wagner <l.wagner@proxmox.com>
www/manager6/dc/Backup.js
www/manager6/form/NotificationPolicySelector.js
www/manager6/window/Backup.js

index 0c8d2d4fe2fe8636a29fdaeb86f492c97ca42d96..e1c76a1d9584c89db84447dca5a7073c8172d391 100644 (file)
@@ -36,29 +36,11 @@ Ext.define('PVE.dc.BackupEdit', {
                delete values.node;
            }
 
-           if (!isCreate) {
-               // 'mailnotification' is deprecated in favor of 'notification-policy'
-               // -> Migration to the new parameter happens in init, so we are
-               //    safe to remove the old parameter here.
-               Proxmox.Utils.assemble_field_data(values, { 'delete': 'mailnotification' });
-
-               // If sending notifications via mail, remove the current value of
-               // 'notification-target'
-               if (values['notification-mode'] === "mailto") {
-                   Proxmox.Utils.assemble_field_data(
-                       values,
-                       { 'delete': 'notification-target' },
-                   );
-               } else {
-                   // and vice versa...
-                   Proxmox.Utils.assemble_field_data(
-                       values,
-                       { 'delete': 'mailto' },
-                   );
-               }
-           }
-
-           delete values['notification-mode'];
+           // Get rid of new-old parameters for notification settings.
+           // These should only be set for those selected few who ran
+           // pve-manager from pvetest.
+           Proxmox.Utils.assemble_field_data(values, { 'delete': 'notification-policy' });
+           Proxmox.Utils.assemble_field_data(values, { 'delete': 'notification-target' });
 
            if (!values.id && isCreate) {
                values.id = 'backup-' + Ext.data.identifier.Uuid.Global.generate().slice(0, 13);
@@ -170,20 +152,14 @@ Ext.define('PVE.dc.BackupEdit', {
                    success: function(response, _options) {
                        let data = response.result.data;
 
-                       // 'mailnotification' is deprecated. Let's automatically
-                       // migrate to the compatible 'notification-policy' parameter
-                       if (data.mailnotification) {
-                           if (!data["notification-policy"]) {
-                               data["notification-policy"] = data.mailnotification;
-                           }
-
-                           delete data.mailnotification;
-                       }
-
-                       if (data['notification-target']) {
-                           data['notification-mode'] = 'notification-target';
-                       } else if (data.mailto) {
-                           data['notification-mode'] = 'mailto';
+                       // Migrate 'new'-old notification-policy back to
+                       // old-old mailnotification. Only should affect
+                       // users who used pve-manager from pvetest.
+                       // This was a remnant of notifications before the
+                       // overhaul.
+                       let policy = data['notification-policy'];
+                       if (policy === 'always' || policy === 'failure') {
+                           data.mailnotification = policy;
                        }
 
                        if (data.exclude) {
@@ -228,7 +204,6 @@ Ext.define('PVE.dc.BackupEdit', {
     viewModel: {
        data: {
            selMode: 'include',
-           notificationMode: 'notification-target',
        },
 
        formulas: {
@@ -327,44 +302,16 @@ Ext.define('PVE.dc.BackupEdit', {
                                {
                                    xtype: 'pveEmailNotificationSelector',
                                    fieldLabel: gettext('Notify'),
-                                   name: 'notification-policy',
+                                   name: 'mailnotification',
                                    cbind: {
                                        value: (get) => get('isCreate') ? 'always' : '',
                                        deleteEmpty: '{!isCreate}',
                                    },
                                },
-                               {
-                                   xtype: 'pveNotificationModeSelector',
-                                   fieldLabel: gettext('Notify via'),
-                                   name: 'notification-mode',
-                                   bind: {
-                                       value: '{notificationMode}',
-                                   },
-                               },
-                               {
-                                   xtype: 'pveNotificationTargetSelector',
-                                   fieldLabel: gettext('Notification Target'),
-                                   name: 'notification-target',
-                                   allowBlank: true,
-                                   editable: true,
-                                   autoSelect: false,
-                                   bind: {
-                                       hidden: '{mailNotificationSelected}',
-                                       disabled: '{mailNotificationSelected}',
-                                   },
-                                   cbind: {
-                                       deleteEmpty: '{!isCreate}',
-                                   },
-                               },
                                {
                                    xtype: 'textfield',
                                    fieldLabel: gettext('Send email to'),
                                    name: 'mailto',
-                                   hidden: true,
-                                   bind: {
-                                       hidden: '{!mailNotificationSelected}',
-                                       disabled: '{!mailNotificationSelected}',
-                                   },
                                },
                                {
                                    xtype: 'pveBackupCompressionSelector',
index 68087275eebd7951540c859126ffdc05db1a614c..f318ea18db717cbcb745bfcce18fad32dc484255 100644 (file)
@@ -4,6 +4,5 @@ Ext.define('PVE.form.EmailNotificationSelector', {
     comboItems: [
        ['always', gettext('Notify always')],
        ['failure', gettext('On failure only')],
-       ['never', gettext('Notify never')],
     ],
 });
index 8e6fa77ea39f16f42caf87bef2b12cc074871e9e..8d8c9ff019d72f37220fa30d4d61383cd371ada8 100644 (file)
@@ -30,32 +30,12 @@ Ext.define('PVE.window.Backup', {
            name: 'mode',
        });
 
-       let notificationTargetSelector = Ext.create('PVE.form.NotificationTargetSelector', {
-           fieldLabel: gettext('Notification target'),
-           name: 'notification-target',
-           emptyText: Proxmox.Utils.noneText,
-           hidden: true,
-       });
-
        let mailtoField = Ext.create('Ext.form.field.Text', {
            fieldLabel: gettext('Send email to'),
            name: 'mailto',
            emptyText: Proxmox.Utils.noneText,
        });
 
-       let notificationModeSelector = Ext.create('PVE.form.NotificationModeSelector', {
-           fieldLabel: gettext('Notify via'),
-           value: 'mailto',
-           name: 'notification-mode',
-           listeners: {
-               change: function(f, v) {
-                   let mailSelected = v === 'mailto';
-                   notificationTargetSelector.setHidden(mailSelected);
-                   mailtoField.setHidden(!mailSelected);
-               },
-           },
-       });
-
        const keepNames = [
            ['keep-last', gettext('Keep Last')],
            ['keep-hourly', gettext('Keep Hourly')],
@@ -127,12 +107,6 @@ Ext.define('PVE.window.Backup', {
                        success: function(response, opts) {
                            const data = response.result.data;
 
-                           if (!initialDefaults && data['notification-mode'] !== undefined) {
-                               notificationModeSelector.setValue(data['notification-mode']);
-                           }
-                           if (!initialDefaults && data['notification-channel'] !== undefined) {
-                               notificationTargetSelector.setValue(data['notification-channel']);
-                           }
                            if (!initialDefaults && data.mailto !== undefined) {
                                mailtoField.setValue(data.mailto);
                            }
@@ -202,8 +176,6 @@ Ext.define('PVE.window.Backup', {
            ],
            column2: [
                compressionSelector,
-               notificationModeSelector,
-               notificationTargetSelector,
                mailtoField,
                removeCheckbox,
            ],
@@ -280,15 +252,10 @@ Ext.define('PVE.window.Backup', {
                    remove: values.remove,
                };
 
-               if (values.mailto && values['notification-mode'] === 'mailto') {
+               if (values.mailto) {
                    params.mailto = values.mailto;
                }
 
-               if (values['notification-target'] &&
-                   values['notification-mode'] === 'notification-target') {
-                   params['notification-target'] = values['notification-target'];
-               }
-
                if (values.compress) {
                    params.compress = values.compress;
                }