[pve-devel] applied: [PATCH v7 manager 2/3] add cmd parameter & rework query string creation

Thomas Lamprecht t.lamprecht at proxmox.com
Fri Mar 8 12:31:59 CET 2019


Am 3/6/19 um 12:29 PM schrieb Tim Marx:
> Signed-off-by: Tim Marx <t.marx at proxmox.com>
> ---
> v7 changes:
> * moved clean to Utils
> * fixed if statement logic

applied, thanks!

> 
>  www/manager6/Utils.js      | 11 +++++++++++
>  www/manager6/VNCConsole.js | 22 +++++++++++++++-------
>  2 files changed, 26 insertions(+), 7 deletions(-)
> 
> diff --git a/www/manager6/Utils.js b/www/manager6/Utils.js
> index b9fa25b7..326a2527 100644
> --- a/www/manager6/Utils.js
> +++ b/www/manager6/Utils.js
> @@ -1091,6 +1091,17 @@ Ext.define('PVE.Utils', { utilities: {
>  		return;
>  	    }
>  	}
> +    },
> +
> +    cleanEmptyObjectKeys: function (obj) {
> +	var propName;
> +	for (propName in obj) {
> +	    if (obj.hasOwnProperty(propName)) {
> +		if (obj[propName] === null || obj[propName] === undefined) {
> +		    delete obj[propName];
> +		}
> +	    }
> +	}
>      }
>  },
>  
> diff --git a/www/manager6/VNCConsole.js b/www/manager6/VNCConsole.js
> index 1438dd0c..cd8fa243 100644
> --- a/www/manager6/VNCConsole.js
> +++ b/www/manager6/VNCConsole.js
> @@ -6,7 +6,9 @@ Ext.define('PVE.noVncConsole', {
>  
>      vmid: undefined,
>  
> -    consoleType: undefined, // lxc or kvm
> +    cmd: undefined,
> +
> +    consoleType: undefined, // lxc, kvm, shell, cmd
>  
>      layout: 'fit',
>  
> @@ -14,6 +16,7 @@ Ext.define('PVE.noVncConsole', {
>  
>      border: false,
>  
> +
>      initComponent : function() {
>  	var me = this;
>  
> @@ -25,7 +28,7 @@ Ext.define('PVE.noVncConsole', {
>  	    throw "no console type specified";
>  	}
>  
> -	if (!me.vmid && me.consoleType !== 'shell') {
> +	if (!me.vmid && me.consoleType !== 'shell' && me.consoleType !== 'cmd') {
>  	    throw "no VM ID specified";
>  	}
>  
> @@ -34,15 +37,20 @@ Ext.define('PVE.noVncConsole', {
>  	var box = Ext.create('Ext.ux.IFrame', { itemid : "vncconsole" });
>  
>  	var type = me.xtermjs ? 'xtermjs' : 'novnc';
> -
>  	Ext.apply(me, {
>  	    items: box,
>  	    listeners: {
>  		activate: function() {
> -		    var url = '/?console=' + me.consoleType + '&' + type + '=1&node=' + me.nodename + '&resize=scale';
> -		    if (me.vmid) {
> -			url += '&vmid='+ me.vmid;
> -		    }
> +		    var queryDict = {
> +			console: me.consoleType, // kvm, lxc, upgrade or shell
> +			vmid: me.vmid,
> +			node: me.nodename,
> +			cmd: me.cmd,
> +			resize: 'scale'
> +		    };
> +		    queryDict[type] = 1;
> +		    PVE.Utils.cleanEmptyObjectKeys(queryDict);
> +		    var url = '/?' + Ext.Object.toQueryString(queryDict);
>  		    box.load(url);
>  		}
>  	    }
> 




More information about the pve-devel mailing list