public inbox for pve-devel@lists.proxmox.com
 help / color / mirror / Atom feed
From: Dominik Csapak <d.csapak@proxmox.com>
To: Proxmox VE development discussion <pve-devel@lists.proxmox.com>,
	Lukas Wagner <l.wagner@proxmox.com>
Subject: Re: [pve-devel] [PATCH v3 pve-manager 57/66] ui: allow to configure notification event -> target mapping
Date: Wed, 19 Jul 2023 14:45:13 +0200	[thread overview]
Message-ID: <93843348-c48b-d86f-da04-c5d36404aa87@proxmox.com> (raw)
In-Reply-To: <20230717150051.710464-58-l.wagner@proxmox.com>

some comments inline:

On 7/17/23 17:00, Lukas Wagner wrote:
> Signed-off-by: Lukas Wagner <l.wagner@proxmox.com>
> ---
>   www/manager6/Makefile                 |   1 +
>   www/manager6/dc/Config.js             |  12 ++
>   www/manager6/dc/NotificationEvents.js | 238 ++++++++++++++++++++++++++
>   3 files changed, 251 insertions(+)
>   create mode 100644 www/manager6/dc/NotificationEvents.js
> 
> diff --git a/www/manager6/Makefile b/www/manager6/Makefile
> index 140b20f0..452abbd4 100644
> --- a/www/manager6/Makefile
> +++ b/www/manager6/Makefile
> @@ -158,6 +158,7 @@ JSSRC= 							\
>   	dc/Health.js					\
>   	dc/Log.js					\
>   	dc/NodeView.js					\
> +	dc/NotificationEvents.js			\
>   	dc/OptionView.js				\
>   	dc/PermissionView.js				\
>   	dc/PoolEdit.js					\
> diff --git a/www/manager6/dc/Config.js b/www/manager6/dc/Config.js
> index 04ed04f0..aa025c8d 100644
> --- a/www/manager6/dc/Config.js
> +++ b/www/manager6/dc/Config.js
> @@ -317,6 +317,18 @@ Ext.define('PVE.dc.Config', {
>   	    );
>   	}
>   
> +	if (caps.dc['Sys.Audit']) {
> +	    me.items.push(
> +		{
> +		    xtype: 'pveNotificationEvents',
> +		    title: gettext('Notifications'),
> +		    onlineHelp: 'notification_events',
> +		    iconCls: 'fa fa-bell-o',
> +		    itemId: 'notifications',
> +		},
> +	    );
> +	}
> +
>   	if (caps.dc['Sys.Audit']) {
>   	    me.items.push({
>   		xtype: 'pveDcSupport',
> diff --git a/www/manager6/dc/NotificationEvents.js b/www/manager6/dc/NotificationEvents.js
> new file mode 100644
> index 00000000..8ba0a844
> --- /dev/null
> +++ b/www/manager6/dc/NotificationEvents.js
> @@ -0,0 +1,238 @@
> +Ext.define('PVE.dc.NotificationEventsPolicySelector', {
> +    alias: ['widget.pveNotificationEventsPolicySelector'],
> +    extend: 'Proxmox.form.KVComboBox',
> +    deleteEmpty: false,
> +    value: '__default__',
> +    comboItems: [
> +	['__default__', `${Proxmox.Utils.defaultText} (always)`],
> +	['always', gettext('Always')],
> +	['never', gettext('Never')],
> +    ],
> +    defaultValue: '__default__',
> +});

mhmm.. are we sure all future things that notify have 'always' as default?
maybe we should make that text configurable?

also the third time you use this, you basically change the essence of it,
namely the options to choose from (i'd argue that should be a plain
KVComboBox there, you only save 3 lines, but there is no confusion that
it's a seperate selector anymore)


> +
> +Ext.define('PVE.dc.NotificationEventsTargetSelector', {
> +    alias: ['widget.pveNotificationEventsTargetSelector'],
> +    extend: 'PVE.form.NotificationTargetSelector',
> +    fieldLabel: gettext('Notification Target'),
> +    allowBlank: true,
> +    editable: true,
> +    autoSelect: false,
> +    deleteEmpty: false,
> +    emptyText: `${Proxmox.Utils.defaultText} (${gettext("mail-to-root")})`,
> +});
> +
> +Ext.define('PVE.dc.NotificationEvents', {
> +    extend: 'Proxmox.grid.ObjectGrid',
> +    alias: ['widget.pveNotificationEvents'],
> +
> +    // Taken from OptionView.js, but adapted slightly.

what exactly was adapted? i can ofc diff it myself, but it would
be nicer to have that info either in a comment or the commit message.
also we should factor this out and reuse it in OptionView and here?
maybe just adding it to the ObjectGrid itself?
(if possible)

the code looks generic enough to be useful there

> +    addInputPanelRow: function(name, propertyName, text, opts) {
> +	let me = this;
> +
> +	opts = opts || {};
> +	me.rows = me.rows || {};
> +
> +	me.rows[name] = {
> +	    required: true,
> +	    defaultValue: opts.defaultValue,
> +	    header: text,
> +	    renderer: opts.renderer,
> +	    name: propertyName,
> +	    editor: {
> +		xtype: 'proxmoxWindowEdit',
> +		width: opts.width || 400,
> +		subject: text,
> +		onlineHelp: opts.onlineHelp,
> +		fieldDefaults: {
> +		    labelWidth: opts.labelWidth || 150,
> +		},
> +		setValues: function(values) {
> +		    let value = values[propertyName];
> +
> +		    if (opts.parseBeforeSet) {
> +			value = PVE.Parser.parsePropertyString(value);
> +		    }
> +
> +		    Ext.Array.each(this.query('inputpanel'), function(panel) {
> +			panel.setValues(value);
> +			panel.originalValue = {
> +			    ...value,
> +			};
> +		    });
> +		},
> +		url: opts.url,
> +		items: [{
> +		    xtype: 'inputpanel',
> +		    onGetValues: function(values) {
> +			let fields = this.config.items.map(field => field.name).filter(n => n);
> +
> +			for (const [key, value] of Object.entries(this.originalValue)) {
> +			    if (!fields.includes(key)) {
> +				values[key] = value;
> +			    }
> +			}
> +
> +			let value = {};
> +			if (Object.keys(values).length > 0) {
> +			    value[propertyName] = PVE.Parser.printPropertyString(values);
> +			} else {
> +			    Proxmox.Utils.assemble_field_data(value, { 'delete': propertyName });
> +			}
> +
> +			return value;
> +		    },
> +		    items: opts.items,
> +		}],
> +	    },
> +	};
> +    },
> +
> +    initComponent: function() {
> +	let me = this;
> +
> +	// Helper function for rendering the property
> +	// Needed since the actual value is always stored in the 'notify' property
> +	let render_value = (store, target_key, mode_key) => {
> +	    let value = store.getById('notify')?.get('value') ?? {};
> +	    let target = value[target_key] ?? gettext('mail-to-root');
> +	    let template;
> +
> +	    switch (value[mode_key]) {
> +		case 'always':
> +		    template = gettext('Always, notify via target \'{0}\'');
> +		    break;
> +		case 'never':
> +		    template = gettext('Never');
> +		    break;
> +		default:
> +		    template = gettext('{1} (Always), notify via target \'{0}\'');
> +		    break;
> +	    }
> +
> +	    return Ext.String.format(template, target, Proxmox.Utils.defaultText);
> +	};
> +
> +	me.addInputPanelRow('fencing', 'notify', gettext('Node Fencing'), {
> +	    renderer: (value, metaData, record, rowIndex, colIndex, store) =>
> +		render_value(store, 'target-fencing', 'fencing'),
> +	    url: "/api2/extjs/cluster/options",
> +	    items: [
> +		{
> +		    xtype: 'pveNotificationEventsPolicySelector',
> +		    name: 'fencing',
> +		    fieldLabel: gettext('Notify'),
> +		},
> +		{
> +		    xtype: 'pveNotificationEventsTargetSelector',
> +		    name: 'target-fencing',
> +		},
> +		{
> +		    xtype: 'displayfield',
> +		    userCls: 'pmx-hint',
> +		    value: gettext('Disabling notifications is not ' +
> +			'recommended for production systems!'),
> +		},
> +	    ],
> +	});
> +
> +	me.addInputPanelRow('replication', 'notify', gettext('Replication'), {
> +	    renderer: (value, metaData, record, rowIndex, colIndex, store) =>
> +		render_value(store, 'target-replication', 'replication'),
> +	    url: "/api2/extjs/cluster/options",
> +	    items: [
> +		{
> +		    xtype: 'pveNotificationEventsPolicySelector',
> +		    name: 'replication',
> +		    fieldLabel: gettext('Notify'),
> +		},
> +		{
> +		    xtype: 'pveNotificationEventsTargetSelector',
> +		    name: 'target-replication',
> +		},
> +		{
> +		    xtype: 'displayfield',
> +		    userCls: 'pmx-hint',
> +		    value: gettext('Disabling notifications is not ' +
> +			'recommended for production systems!'),
> +		},
> +	    ],
> +	});
> +
> +	me.addInputPanelRow('updates', 'notify', gettext('Package Updates'), {
> +	    renderer: (value, metaData, record, rowIndex, colIndex, store) => {
> +		value = store.getById('notify')?.get('value') ?? {};
> +		let target = value['target-package-updates'] ?? gettext('mail-to-root');
> +		let template;
> +
> +		switch (value['package-updates']) {
> +		    case 'always':
> +			template = gettext('Always, notify via \'{0}\'');
> +			break;
> +		    case 'auto':
> +			template = gettext('Automatically, notify via target \'{0}\'');

you should be able to reuse the render_value if you add this there also
it can't trigger for the others anyway?

> +			break;
> +		    case 'never':
> +			template = gettext('Never');
> +			break;
> +		    default:
> +			template = gettext('{1} (Automatically), notify via target \'{0}\'');
> +			break;
> +		}
> +
> +		return Ext.String.format(template, target, Proxmox.Utils.defaultText);
> +	    },
> +	    url: "/api2/extjs/cluster/options",
> +	    items: [
> +		{
> +		    xtype: 'pveNotificationEventsPolicySelector',

as said above i'd simply make this a KVComboBox to indicate it's
basically a seperate component

> +		    name: 'package-updates',
> +		    fieldLabel: gettext('Notify'),
> +		    comboItems: [
> +			['__default__', Proxmox.Utils.defaultText + ' (auto)'],
> +			['auto', gettext('Automatically')],
> +			['always', gettext('Always')],
> +			['never', gettext('Never')],
> +		    ],
> +		},
> +		{
> +		    xtype: 'pveNotificationEventsTargetSelector',
> +		    name: 'target-package-updates',
> +		},
> +	    ],
> +	});
> +
> +	// Hack: Also load the notify property to make it accessible
> +	// for our render functions. initComponents later hides it.
> +	me.add_text_row('notify', gettext('Notify'), {});

it should be possible to simply add it directly here with something like:

me.rows.notify = {
     visible: false,
};

?

we e.g. do something like this in dc/Optionsview and qemu/HardwareView
(the latter is a PendingObjectGrid, but still inherits from ObjectGrid)

> +
> +	me.selModel = Ext.create('Ext.selection.RowModel', {});
> +
> +	Ext.apply(me, {
> +	    tbar: [{
> +		text: gettext('Edit'),
> +		xtype: 'proxmoxButton',
> +		disabled: true,
> +		handler: () => me.run_editor(),
> +		selModel: me.selModel,
> +	    }],
> +	    url: "/api2/json/cluster/options",
> +	    editorConfig: {
> +		url: "/api2/extjs/cluster/options",
> +	    },
> +	    interval: 5000,
> +	    cwidth1: 200,
> +	    listeners: {
> +		itemdblclick: me.run_editor,
> +	    },
> +	});
> +
> +	me.callParent();
> +
> +	me.rows.notify.visible = false;
> +
> +	me.on('activate', me.rstore.startUpdate);
> +	me.on('destroy', me.rstore.stopUpdate);
> +	me.on('deactivate', me.rstore.stopUpdate);
> +    },
> +});





  reply	other threads:[~2023-07-19 12:45 UTC|newest]

Thread overview: 114+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-07-17 14:59 [pve-devel] [PATCH v3 many 00/66] fix #4156: introduce new notification system Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 01/66] add proxmox-notify crate Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 02/66] notify: preparation for the first endpoint plugin Lukas Wagner
2023-07-17 15:48   ` Maximiliano Sandoval
2023-07-18  7:19     ` Lukas Wagner
2023-07-18 10:13       ` Wolfgang Bumiller
2023-07-18 11:54   ` Wolfgang Bumiller
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 03/66] notify: preparation for the API Lukas Wagner
2023-07-18 12:02   ` Wolfgang Bumiller
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 04/66] notify: api: add API for sending notifications/testing endpoints Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 05/66] notify: add sendmail plugin Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 06/66] notify: api: add API for sendmail endpoints Lukas Wagner
2023-07-18 12:36   ` Wolfgang Bumiller
2023-07-19 11:51     ` Lukas Wagner
2023-07-19 12:09       ` Wolfgang Bumiller
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 07/66] notify: add gotify endpoint Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 08/66] notify: api: add API for gotify endpoints Lukas Wagner
2023-07-18 12:44   ` Wolfgang Bumiller
2023-07-18 13:19     ` Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 09/66] notify: add notification groups Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 10/66] notify: api: add API for groups Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 11/66] notify: add notification filter mechanism Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 12/66] notify: api: add API for filters Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 13/66] notify: add template rendering Lukas Wagner
2023-07-17 14:59 ` [pve-devel] [PATCH v3 proxmox 14/66] notify: add example for " Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 15/66] notify: add context Lukas Wagner
2023-07-18 12:57   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 16/66] notify: sendmail: allow users as recipients Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 17/66] notify: sendmail: query default author/mailfrom from context Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 18/66] notify: gotify: add proxy support Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 19/66] notify: api: allow to query entities referenced by filter/target Lukas Wagner
2023-07-18 13:02   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 20/66] notify: on deletion, check if a filter/endp. is still used by anything Lukas Wagner
2023-07-18 13:20   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 21/66] notify: ensure that filter/group/endpoint names are unique Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 22/66] notify: additional logging when sending a notification Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox 23/66] notify: add debian packaging Lukas Wagner
2023-07-18 13:25   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 24/66] add PVE::RS::Notify module Lukas Wagner
2023-07-19 10:10   ` Wolfgang Bumiller
2023-07-19 10:23     ` Wolfgang Bumiller
2023-07-19 10:37       ` Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 25/66] notify: add api for sending notifications/testing endpoints Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 26/66] notify: add api for notification groups Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 27/66] notify: add api for sendmail endpoints Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 28/66] notify: add api for gotify endpoints Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 29/66] notify: add api for notification filters Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 30/66] notify: sendmail: support the `mailto-user` parameter Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 31/66] notify: implement context for getting default author/mailfrom Lukas Wagner
2023-07-19 11:15   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 32/66] notify: add context for getting http_proxy from datacenter.cfg Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-perl-rs 33/66] notify: add wrapper for `get_referenced_entities` Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-cluster 34/66] cluster files: add notifications.cfg Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-cluster 35/66] datacenter: add APT/fencing/replication notification configuration Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-cluster 36/66] add libpve-notify-perl package Lukas Wagner
2023-07-19 12:27   ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-guest-common 37/66] vzdump: add config options for new notification backend Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-common 38/66] JSONSchema: increase maxLength of config-digest to 64 Lukas Wagner
2023-07-19 12:31   ` Wolfgang Bumiller
2023-07-19 12:41   ` Fiona Ebner
2023-07-19 12:49     ` Wolfgang Bumiller
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-ha-manager 39/66] manager: send notifications via new notification module Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 40/66] test: fix names of .PHONY targets Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 41/66] d/control: add dependency to `libpve-notify-perl` Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 42/66] vzdump: send notifications via new notification module Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 43/66] test: rename mail_test.pl to vzdump_notification_test.pl Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 44/66] api: apt: send notification via new notification module Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 45/66] api: replication: send notifications " Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 46/66] api: prepare api handler module for notification config Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 47/66] api: notification: add api routes for groups Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 48/66] api: notification: add api routes for sendmail endpoints Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 49/66] api: notification: add api routes for gotify endpoints Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 50/66] api: notification: add api routes for filters Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 51/66] api: notification: allow fetching notification targets Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 52/66] api: notification: allow to test targets Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 53/66] api: notification: disallow removing targets if they are used Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 54/66] ui: backup: allow to select notification target for jobs Lukas Wagner
2023-07-19 12:20   ` Dominik Csapak
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 55/66] ui: backup: adapt backup job details to new notification params Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 56/66] ui: backup: allow to set notification-target for one-off backups Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 57/66] ui: allow to configure notification event -> target mapping Lukas Wagner
2023-07-19 12:45   ` Dominik Csapak [this message]
2023-07-19 15:25     ` Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 58/66] ui: add notification target configuration panel Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 59/66] ui: perm path: load notification target/filter acl entries Lukas Wagner
2023-07-19 12:53   ` Dominik Csapak
2023-07-20  7:46     ` Lukas Wagner
2023-07-20  7:54       ` Dominik Csapak
2023-07-20  8:22         ` Lukas Wagner
2023-07-20  8:29           ` Fiona Ebner
2023-07-20  9:26             ` Maximiliano Sandoval
2023-07-20 15:02               ` Thomas Lamprecht
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-manager 60/66] ui: perm path: increase width of the perm path selector combobox Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-widget-toolkit 61/66] notification: add gui for sendmail notification endpoints Lukas Wagner
2023-07-19 13:25   ` Dominik Csapak
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-widget-toolkit 62/66] notification: add gui for gotify " Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-widget-toolkit 63/66] notification: add gui for notification groups Lukas Wagner
2023-07-19 13:32   ` Dominik Csapak
2023-07-20 12:31     ` Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-widget-toolkit 64/66] notification: allow to select filter for notification targets Lukas Wagner
2023-07-17 15:00 ` [pve-devel] [PATCH v3 proxmox-widget-toolkit 65/66] notification: add ui for managing notification filters Lukas Wagner
2023-07-19 13:53   ` Dominik Csapak
2023-07-17 15:00 ` [pve-devel] [PATCH v3 pve-docs 66/66] add documentation for the new notification system Lukas Wagner
2023-07-18 12:34 ` [pve-devel] [PATCH v3 many 00/66] fix #4156: introduce " Dominik Csapak
2023-07-18 13:14   ` Lukas Wagner
2023-07-18 13:58     ` Dominik Csapak
2023-07-18 14:07       ` Lukas Wagner
2023-07-18 14:37   ` Thomas Lamprecht
2023-07-19 13:13     ` Lukas Wagner
2023-07-19  8:40   ` Lukas Wagner
2023-07-19  9:54     ` Wolfgang Bumiller
2023-07-18 13:27 ` Wolfgang Bumiller
2023-07-19 12:11 ` Wolfgang Bumiller
2023-07-19 12:17   ` Lukas Wagner

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=93843348-c48b-d86f-da04-c5d36404aa87@proxmox.com \
    --to=d.csapak@proxmox.com \
    --cc=l.wagner@proxmox.com \
    --cc=pve-devel@lists.proxmox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox
Service provided by Proxmox Server Solutions GmbH | Privacy | Legal