[pve-devel] [PATCH pve-manager] First beta of FreeNAS storage plugin

Michael Rasmussen mir at datanom.net
Mon Jun 12 03:19:27 CEST 2017


Signed-off-by: Michael Rasmussen <mir at datanom.net>
---
 www/manager6/Makefile               |   1 +
 www/manager6/Utils.js               |   4 +-
 www/manager6/dc/StorageView.js      |  15 +++-
 www/manager6/lxc/ResourceEdit.js    |   6 +-
 www/manager6/qemu/Clone.js          |   3 +-
 www/manager6/qemu/HDEdit.js         |   3 +-
 www/manager6/qemu/HDEfi.js          |   2 +-
 www/manager6/qemu/HDMove.js         |   3 +-
 www/manager6/storage/FreeNASEdit.js | 152 ++++++++++++++++++++++++++++++++++++
 9 files changed, 180 insertions(+), 9 deletions(-)
 create mode 100644 www/manager6/storage/FreeNASEdit.js

diff --git a/www/manager6/Makefile b/www/manager6/Makefile
index 0c266ef..2a4489d 100644
--- a/www/manager6/Makefile
+++ b/www/manager6/Makefile
@@ -186,6 +186,7 @@ JSSRC= 				                 	\
 	storage/SheepdogEdit.js				\
 	storage/ZFSEdit.js				\
 	storage/ZFSPoolEdit.js				\
+	storage/FreeNASEdit.js			\
 	ha/StatusView.js				\
 	ha/Status.js					\
 	ha/GroupSelector.js				\
diff --git a/www/manager6/Utils.js b/www/manager6/Utils.js
index d1ada77..c6227d0 100644
--- a/www/manager6/Utils.js
+++ b/www/manager6/Utils.js
@@ -799,7 +799,9 @@ Ext.define('PVE.Utils', { utilities: {
 	    return 'iSCSIDirect';
 	} else if (value === 'drbd') {
 	    return 'DRBD';
-	} else {
+	} else if (value === 'freenas') {
+        return 'FreeNAS';
+    } else {
 	    return PVE.Utils.unknownText;
 	}
     },
diff --git a/www/manager6/dc/StorageView.js b/www/manager6/dc/StorageView.js
index 2940a98..c16d464 100644
--- a/www/manager6/dc/StorageView.js
+++ b/www/manager6/dc/StorageView.js
@@ -58,7 +58,9 @@ Ext.define('PVE.dc.StorageView', {
 		editor = 'PVE.storage.ZFSEdit';
 	    } else if (type === 'zfspool') {
 		editor = 'PVE.storage.ZFSPoolEdit';
-	    } else {
+	    } else if (type === 'freenas') {
+        editor = 'PVE.storage.FreeNASEdit';
+        } else {
 		return;
 	    }
 	    var win = Ext.create(editor, {
@@ -191,7 +193,16 @@ Ext.define('PVE.dc.StorageView', {
                                     win.on('destroy', reload);
                                     win.show();
                                 }
-                            }
+                            },
+                {
+                    text: PVE.Utils.format_storage_type('freenas'),
+                    iconCls: 'fa fa-fw fa-building',
+                    handler: function() {
+                        var win = Ext.create('PVE.storage.FreeNASEdit', {});
+                        win.on('destroy', reload);
+                        win.show();
+                    }
+                }
 
 /* the following type are conidered unstable
  * so we do not enable that on the GUI for now
diff --git a/www/manager6/lxc/ResourceEdit.js b/www/manager6/lxc/ResourceEdit.js
index 61a5539..8bc3e76 100644
--- a/www/manager6/lxc/ResourceEdit.js
+++ b/www/manager6/lxc/ResourceEdit.js
@@ -387,7 +387,8 @@ Ext.define('PVE.lxc.MountPointInputPanel', {
 		    }
 		    var rec = f.store.getById(value);
 		    if (rec.data.type === 'zfs' ||
-		        rec.data.type === 'zfspool') {
+		        rec.data.type === 'zfspool' ||
+                rec.data.type === 'freenas') {
 			me.quota.setDisabled(true);
 			me.quota.setValue(false);
 		    } else {
@@ -407,7 +408,8 @@ Ext.define('PVE.lxc.MountPointInputPanel', {
 			       rec.data.type === 'rbd' ||
 			       rec.data.type === 'sheepdog' ||
 			       rec.data.type === 'zfs' ||
-			       rec.data.type === 'zfspool') {
+			       rec.data.type === 'zfspool' ||
+                   rec.data.type === 'freenas') {
 			me.hdfilesel.setDisabled(true);
 			me.hdfilesel.setVisible(false);
 			me.hdsizesel.setDisabled(false);
diff --git a/www/manager6/qemu/Clone.js b/www/manager6/qemu/Clone.js
index c5dad4d..9de9777 100644
--- a/www/manager6/qemu/Clone.js
+++ b/www/manager6/qemu/Clone.js
@@ -116,7 +116,8 @@ Ext.define('PVE.window.Clone', {
 		rec.data.type === 'iscsi' ||
 		rec.data.type === 'sheepdog' ||
 		rec.data.type === 'zfs' ||
-		rec.data.type === 'zfspool'
+		rec.data.type === 'zfspool' ||
+        rec.data.type === 'freenas'
 	) {
 	    formatsel.setValue('raw');
 	    formatsel.setDisabled(true);
diff --git a/www/manager6/qemu/HDEdit.js b/www/manager6/qemu/HDEdit.js
index 0060394..6920c0d 100644
--- a/www/manager6/qemu/HDEdit.js
+++ b/www/manager6/qemu/HDEdit.js
@@ -46,7 +46,8 @@ Ext.define('PVE.qemu.HDInputPanel', {
 			       rec.data.type === 'rbd' ||
 			       rec.data.type === 'sheepdog' ||
 			       rec.data.type === 'zfs' ||
-			       rec.data.type === 'zfspool') {
+			       rec.data.type === 'zfspool' ||
+                   rec.data.type === 'freenas') {
 			me.hdfilesel.setDisabled(true);
 			me.hdfilesel.setVisible(false);
 			me.formatsel.setValue('raw');
diff --git a/www/manager6/qemu/HDEfi.js b/www/manager6/qemu/HDEfi.js
index 45c9d70..7aa9608 100644
--- a/www/manager6/qemu/HDEfi.js
+++ b/www/manager6/qemu/HDEfi.js
@@ -21,7 +21,7 @@ Ext.define('PVE.qemu.EFIDiskInputPanel', {
 		    var me = this.getView();
 		    var rec = f.store.getById(value);
 
-		    var rawArray = ['iscsi', 'lvm', 'lvmthin', 'drbd', 'rbd', 'sheepdog', 'zfs', 'zfspool'];
+		    var rawArray = ['iscsi', 'lvm', 'lvmthin', 'drbd', 'rbd', 'sheepdog', 'zfs', 'zfspool', 'freenas'];
 
 		    me.hdfilesel.setDisabled(true);
 		    me.hdfilesel.setVisible(false);
diff --git a/www/manager6/qemu/HDMove.js b/www/manager6/qemu/HDMove.js
index 745c791..4e69aa7 100644
--- a/www/manager6/qemu/HDMove.js
+++ b/www/manager6/qemu/HDMove.js
@@ -80,7 +80,8 @@ Ext.define('PVE.window.HDMove', {
 			    rec.data.type === 'rbd' ||
 			    rec.data.type === 'sheepdog' ||
 			    rec.data.type === 'zfs' ||
-			    rec.data.type === 'zfspool'
+			    rec.data.type === 'zfspool' ||
+                rec.data.type === 'freenas'
                         ) {
                             me.formatsel.setValue('raw');
                             me.formatsel.setDisabled(true);
diff --git a/www/manager6/storage/FreeNASEdit.js b/www/manager6/storage/FreeNASEdit.js
new file mode 100644
index 0000000..5cc9f28
--- /dev/null
+++ b/www/manager6/storage/FreeNASEdit.js
@@ -0,0 +1,152 @@
+Ext.define('PVE.storage.FreeNASInputPanel', {
+    extend: 'PVE.panel.InputPanel',
+
+    onGetValues: function(values) {
+	var me = this;
+
+	if (me.isCreate) {
+	    values.type = 'freenas';
+	    values.content = 'images';
+	} else {
+	    delete values.storage;
+	}
+
+	values.disable = values.enable ? 0 : 1;
+	delete values.enable;
+
+	return values;
+    },
+
+    initComponent : function() {
+	var me = this;
+
+	me.column1 = [
+	    {
+		xtype: me.isCreate ? 'textfield' : 'displayfield',
+		name: 'storage',
+		value: me.storageId || '',
+		fieldLabel: 'ID',
+		vtype: 'StorageId',
+		allowBlank: false
+	    },
+	    {
+		xtype: me.isCreate ? 'textfield' : 'displayfield',
+		name: 'portal',
+		value: '',
+		fieldLabel: gettext('Portal'),
+		allowBlank: false
+	    },
+	    {
+		xtype: me.isCreate ? 'textfield' : 'displayfield',
+		name: 'pool',
+		value: '',
+		fieldLabel: gettext('Pool'),
+		allowBlank: false
+	    },
+	    {
+		xtype: me.isCreate ? 'textfield' : 'displayfield',
+		name: 'portal_group',
+		value: '',
+		fieldLabel: gettext('Portal Group ID'),
+		allowBlank: false
+	    },
+	    {
+		xtype: me.isCreate ? 'textfield' : 'displayfield',
+		name: 'initiator_group',
+		value: '',
+		fieldLabel: gettext('Initiator Group ID'),
+		allowBlank: false
+	    },
+	];
+
+	me.column2 = [
+	    {
+		xtype: 'pvecheckbox',
+		name: 'enable',
+		checked: true,
+		uncheckedValue: 0,
+		fieldLabel: gettext('Enable')
+	    },
+/*        {
+        xtype: 'textfield',
+        name: 'blocksize',
+        emptyText: '8k',
+        fieldLabel: gettext('Block Size'),
+        allowBlank: true
+        },*/
+	    {
+		xtype: 'textfield',
+		name: 'username',
+		emptyText: 'root',
+		fieldLabel: gettext('Username'),
+		allowBlank: false
+	    },
+	    {
+		xtype: 'textfield',
+		name: 'password',
+		emptyText: '',
+        inputType: 'password',
+		fieldLabel: gettext('Password'),
+		allowBlank: false
+	    },
+	];
+
+	if (me.isCreate || me.storageId !== 'local') {
+	    me.column2.unshift({
+		xtype: 'pveNodeSelector',
+		name: 'nodes',
+		fieldLabel: gettext('Nodes'),
+		emptyText: gettext('All') + ' (' +
+		    gettext('No restrictions') +')',
+		multiSelect: true,
+		autoSelect: false
+	    });
+	}
+
+	me.callParent();
+    }
+});
+
+Ext.define('PVE.storage.FreeNASEdit', {
+    extend: 'PVE.window.Edit',
+
+    initComponent : function() {
+	var me = this;
+
+	me.isCreate = !me.storageId;
+
+	if (me.isCreate) {
+            me.url = '/api2/extjs/storage';
+            me.method = 'POST';
+        } else {
+            me.url = '/api2/extjs/storage/' + me.storageId;
+            me.method = 'PUT';
+        }
+
+	var ipanel = Ext.create('PVE.storage.FreeNASInputPanel', {
+	    isCreate: me.isCreate,
+	    storageId: me.storageId
+	});
+
+	Ext.apply(me, {
+            subject: 'FreeNAS Storage',
+	    isAdd: true,
+	    items: [ ipanel ]
+	});
+
+	me.callParent();
+
+        if (!me.isCreate) {
+            me.load({
+                success:  function(response, options) {
+                    var values = response.result.data;
+                    if (values.nodes) {
+                        values.nodes = values.nodes.split(',');
+                    }
+                    values.enable = values.disable ? 0 : 1;
+                    ipanel.setValues(values);
+                }
+            });
+        }
+    }
+});
-- 
2.1.4


----

This mail was virus scanned and spam checked before delivery.
This mail is also DKIM signed. See header dkim-signature.




More information about the pve-devel mailing list