170 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
--- pvemanagerlib-5.2-9.js	2018-10-16 07:17:21.915593478 -0400
 | 
						|
+++ pvemanagerlib.js	2018-10-21 21:52:20.781740237 -0400
 | 
						|
@@ -5597,6 +5597,7 @@
 | 
						|
     alias: ['widget.pveiScsiProviderSelector'],
 | 
						|
     comboItems: [
 | 
						|
 	['comstar', 'Comstar'],
 | 
						|
+	['freenas', 'FreeNAS-API'],
 | 
						|
 	[ 'istgt', 'istgt'],
 | 
						|
 	[ 'iet', 'IET'],
 | 
						|
 	[ 'LIO', 'LIO']
 | 
						|
@@ -28574,6 +28575,7 @@
 | 
						|
 	data: {
 | 
						|
 	    isLIO: false,
 | 
						|
 	    isComstar: true,
 | 
						|
+	    isFreeNAS: false,
 | 
						|
 	    hasWriteCacheOption: true
 | 
						|
 	}
 | 
						|
     },
 | 
						|
@@ -28586,10 +28588,19 @@
 | 
						|
 	    }
 | 
						|
 	},
 | 
						|
 	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_password_field').setValue('');
 | 
						|
+		me.lookupReference('freenas_confirmpw_field').setValue('');
 | 
						|
+	    }
 | 
						|
 	}
 | 
						|
     },
 | 
						|
 
 | 
						|
@@ -28607,6 +28618,7 @@
 | 
						|
     },
 | 
						|
 
 | 
						|
     setValues: function diff(values) {
 | 
						|
+	values.freenas_confirmpw = values.freenas_password;
 | 
						|
 	values.writecache = values.nowritecache ? 0 : 1;
 | 
						|
 	this.callParent([values]);
 | 
						|
     },
 | 
						|
@@ -28623,7 +28635,7 @@
 | 
						|
 		allowBlank: false
 | 
						|
 	    },
 | 
						|
 	    {
 | 
						|
-		xtype: me.isCreate ? 'textfield' : 'displayfield',
 | 
						|
+		xtype: 'textfield',
 | 
						|
 		name: 'pool',
 | 
						|
 		value: '',
 | 
						|
 		fieldLabel: gettext('Pool'),
 | 
						|
@@ -28637,7 +28649,7 @@
 | 
						|
 		allowBlank: false
 | 
						|
 	    },
 | 
						|
 	    {
 | 
						|
-		xtype: me.isCreate ? 'textfield' : 'displayfield',
 | 
						|
+		xtype: 'textfield',
 | 
						|
 		name: 'target',
 | 
						|
 		value: '',
 | 
						|
 		fieldLabel: gettext('Target'),
 | 
						|
@@ -28648,8 +28660,28 @@
 | 
						|
 		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: '',
 | 
						|
+		allowBlank: false,
 | 
						|
+		fieldLabel: gettext('API Username'),
 | 
						|
+		bind: { hidden: '{!isFreeNAS}' },
 | 
						|
 	    }
 | 
						|
 	];
 | 
						|
 
 | 
						|
@@ -28680,7 +28712,7 @@
 | 
						|
 		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
 | 
						|
 	    },
 | 
						|
@@ -28688,9 +28720,61 @@
 | 
						|
 		xtype: me.isCreate ? 'textfield' : 'displayfield',
 | 
						|
 		name: 'lio_tpg',
 | 
						|
 		value: '',
 | 
						|
-		bind: me.isCreate ? { disabled: '{!isLIO}' } : { hidden: '{!isLIO}' },
 | 
						|
-		allowBlank: false,
 | 
						|
-		fieldLabel: gettext('Target portal group')
 | 
						|
+		bind: { hidden: '{!isLIO}' },
 | 
						|
+		fieldLabel: gettext('Target portal group'),
 | 
						|
+		allowBlank: true
 | 
						|
+	    },
 | 
						|
+	    {
 | 
						|
+		xtype: 'proxmoxtextfield',
 | 
						|
+		name: 'freenas_apiv4_host',
 | 
						|
+		reference: 'freenas_apiv4_host_field',
 | 
						|
+		value: '',
 | 
						|
+                editable: true,
 | 
						|
+                deleteEmpty: true,
 | 
						|
+                allowBlank: true,
 | 
						|
+                emptyText: Proxmox.Utils.noneText,
 | 
						|
+		bind: { hidden: '{!isFreeNAS}' },
 | 
						|
+		fieldLabel: gettext('API IPv4 Host'),
 | 
						|
+		allowBlank: true
 | 
						|
+	    },
 | 
						|
+	    {
 | 
						|
+		xtype: 'proxmoxtextfield',
 | 
						|
+		name: 'freenas_password',
 | 
						|
+		reference: 'freenas_password_field',
 | 
						|
+                inputType: me.isCreate ? '' : 'password',
 | 
						|
+                value: '',
 | 
						|
+                editable: true,
 | 
						|
+                deleteEmpty: true,
 | 
						|
+                allowBlank: false,
 | 
						|
+                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,
 | 
						|
+                deleteEmpty: true,
 | 
						|
+                allowBlank: false,
 | 
						|
+		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;
 | 
						|
+                }
 | 
						|
 	    }
 | 
						|
 	];
 | 
						|
 
 |