190 lines
5.1 KiB
Diff
190 lines
5.1 KiB
Diff
--- pvemanagerlib.js.orig 2022-03-17 09:08:40.000000000 -0400
|
|
+++ pvemanagerlib.js 2022-04-03 08:54:10.229689187 -0400
|
|
@@ -8068,6 +8068,7 @@
|
|
alias: ['widget.pveiScsiProviderSelector'],
|
|
comboItems: [
|
|
['comstar', 'Comstar'],
|
|
+ ['freenas', 'FreeNAS-API'],
|
|
['istgt', 'istgt'],
|
|
['iet', 'IET'],
|
|
['LIO', 'LIO'],
|
|
@@ -49636,6 +49637,7 @@
|
|
data: {
|
|
isLIO: false,
|
|
isComstar: true,
|
|
+ isFreeNAS: false,
|
|
hasWriteCacheOption: true,
|
|
},
|
|
},
|
|
@@ -49648,10 +49650,26 @@
|
|
},
|
|
},
|
|
changeISCSIProvider: function(f, newVal, oldVal) {
|
|
+ var me = this;
|
|
var vm = this.getViewModel();
|
|
vm.set('isLIO', newVal === 'LIO');
|
|
vm.set('isComstar', newVal === 'comstar');
|
|
- vm.set('hasWriteCacheOption', newVal === 'comstar' || newVal === 'istgt');
|
|
+ vm.set('isFreeNAS', newVal === 'freenas');
|
|
+ vm.set('hasWriteCacheOption', newVal === 'comstar' || newVal === 'freenas' || newVal === 'istgt');
|
|
+ if (newVal !== 'freenas') {
|
|
+ me.lookupReference('freenas_use_ssl_field').setValue(false);
|
|
+ me.lookupReference('freenas_apiv4_host_field').setValue('');
|
|
+ me.lookupReference('freenas_user_field').setValue('');
|
|
+ me.lookupReference('freenas_user_field').allowBlank = true;
|
|
+ me.lookupReference('freenas_password_field').setValue('');
|
|
+ me.lookupReference('freenas_password_field').allowBlank = true;
|
|
+ me.lookupReference('freenas_confirmpw_field').setValue('');
|
|
+ me.lookupReference('freenas_confirmpw_field').allowBlank = true;
|
|
+ } else {
|
|
+ me.lookupReference('freenas_user_field').allowBlank = false;
|
|
+ me.lookupReference('freenas_password_field').allowBlank = false;
|
|
+ me.lookupReference('freenas_confirmpw_field').allowBlank = false;
|
|
+ }
|
|
},
|
|
},
|
|
|
|
@@ -49669,6 +49687,7 @@
|
|
},
|
|
|
|
setValues: function(values) {
|
|
+ values.freenas_confirmpw = values.freenas_password;
|
|
values.writecache = values.nowritecache ? 0 : 1;
|
|
this.callParent([values]);
|
|
},
|
|
@@ -49685,7 +49704,7 @@
|
|
allowBlank: false,
|
|
},
|
|
{
|
|
- xtype: me.isCreate ? 'textfield' : 'displayfield',
|
|
+ xtype: 'textfield',
|
|
name: 'pool',
|
|
value: '',
|
|
fieldLabel: gettext('Pool'),
|
|
@@ -49695,11 +49714,11 @@
|
|
xtype: me.isCreate ? 'textfield' : 'displayfield',
|
|
name: 'blocksize',
|
|
value: '4k',
|
|
- fieldLabel: gettext('Block Size'),
|
|
+ fieldLabel: gettext('ZFS Block Size'),
|
|
allowBlank: false,
|
|
},
|
|
{
|
|
- xtype: me.isCreate ? 'textfield' : 'displayfield',
|
|
+ xtype: 'textfield',
|
|
name: 'target',
|
|
value: '',
|
|
fieldLabel: gettext('Target'),
|
|
@@ -49710,9 +49729,34 @@
|
|
name: 'comstar_tg',
|
|
value: '',
|
|
fieldLabel: gettext('Target group'),
|
|
- bind: me.isCreate ? { disabled: '{!isComstar}' } : { hidden: '{!isComstar}' },
|
|
+ bind: {
|
|
+ hidden: '{!isComstar}'
|
|
+ },
|
|
allowBlank: true,
|
|
},
|
|
+ {
|
|
+ xtype: 'proxmoxcheckbox',
|
|
+ name: 'freenas_use_ssl',
|
|
+ reference: 'freenas_use_ssl_field',
|
|
+ inputId: 'freenas_use_ssl_field',
|
|
+ checked: false,
|
|
+ bind: {
|
|
+ hidden: '{!isFreeNAS}'
|
|
+ },
|
|
+ uncheckedValue: 0,
|
|
+ fieldLabel: gettext('API use SSL'),
|
|
+ },
|
|
+ {
|
|
+ xtype: 'textfield',
|
|
+ name: 'freenas_user',
|
|
+ reference: 'freenas_user_field',
|
|
+ inputId: 'freenas_user_field',
|
|
+ value: '',
|
|
+ fieldLabel: gettext('API Username'),
|
|
+ bind: {
|
|
+ hidden: '{!isFreeNAS}'
|
|
+ },
|
|
+ },
|
|
];
|
|
|
|
me.column2 = [
|
|
@@ -49742,7 +49786,9 @@
|
|
xtype: me.isCreate ? 'textfield' : 'displayfield',
|
|
name: 'comstar_hg',
|
|
value: '',
|
|
- bind: me.isCreate ? { disabled: '{!isComstar}' } : { hidden: '{!isComstar}' },
|
|
+ bind: {
|
|
+ hidden: '{!isComstar}'
|
|
+ },
|
|
fieldLabel: gettext('Host group'),
|
|
allowBlank: true,
|
|
},
|
|
@@ -49750,9 +49796,62 @@
|
|
xtype: me.isCreate ? 'textfield' : 'displayfield',
|
|
name: 'lio_tpg',
|
|
value: '',
|
|
- bind: me.isCreate ? { disabled: '{!isLIO}' } : { hidden: '{!isLIO}' },
|
|
- allowBlank: false,
|
|
+ bind: {
|
|
+ hidden: '{!isLIO}'
|
|
+ },
|
|
fieldLabel: gettext('Target portal group'),
|
|
+ allowBlank: true
|
|
+ },
|
|
+ {
|
|
+ xtype: 'proxmoxtextfield',
|
|
+ name: 'freenas_apiv4_host',
|
|
+ reference: 'freenas_apiv4_host_field',
|
|
+ value: '',
|
|
+ editable: true,
|
|
+ emptyText: Proxmox.Utils.noneText,
|
|
+ bind: {
|
|
+ hidden: '{!isFreeNAS}'
|
|
+ },
|
|
+ fieldLabel: gettext('API IPv4 Host'),
|
|
+ },
|
|
+ {
|
|
+ xtype: 'proxmoxtextfield',
|
|
+ name: 'freenas_password',
|
|
+ reference: 'freenas_password_field',
|
|
+ inputType: me.isCreate ? '' : 'password',
|
|
+ value: '',
|
|
+ editable: true,
|
|
+ emptyText: Proxmox.Utils.noneText,
|
|
+ bind: {
|
|
+ hidden: '{!isFreeNAS}'
|
|
+ },
|
|
+ fieldLabel: gettext('API Password'),
|
|
+ change: function(f, value) {
|
|
+ if (f.rendered) {
|
|
+ f.up().down('field[name=freenas_confirmpw]').validate();
|
|
+ }
|
|
+ },
|
|
+ },
|
|
+ {
|
|
+ xtype: 'proxmoxtextfield',
|
|
+ name: 'freenas_confirmpw',
|
|
+ reference: 'freenas_confirmpw_field',
|
|
+ inputType: me.isCreate ? '' : 'password',
|
|
+ value: '',
|
|
+ editable: true,
|
|
+ submitValue: false,
|
|
+ emptyText: Proxmox.Utils.noneText,
|
|
+ bind: {
|
|
+ hidden: '{!isFreeNAS}'
|
|
+ },
|
|
+ fieldLabel: gettext('Confirm Password'),
|
|
+ validator: function(value) {
|
|
+ var pw = this.up().down('field[name=freenas_password]').getValue();
|
|
+ if (pw !== value) {
|
|
+ return "Passwords do not match!";
|
|
+ }
|
|
+ return true;
|
|
+ },
|
|
},
|
|
];
|
|
|