2
0
mirror of https://github.com/xcat2/xcat-core.git synced 2025-10-26 08:55:24 +00:00

Added input verification. Fixed add vSwitch option.

git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/branches/2.8@15159 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
phamt
2013-02-12 22:15:52 +00:00
parent 8253aee359
commit 711b13383f
2 changed files with 310 additions and 244 deletions

View File

@@ -1994,7 +1994,7 @@ function openAddScsi2SystemDialog(hcp) {
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
var devNum = $('<div><label>FCP device:</label><input type="text" name="devNum" maxlength="4" title="The SCSI disk device number"/></div>');
var devNo = $('<div><label>FCP device:</label><input type="text" name="devNo" maxlength="4" title="The SCSI disk device number"/></div>');
var devPathLabel = $('<label>Device paths:</label>');
var devPathCount = 1;
var pathDiv = $('<div class="devPath" style="margin-left:125px;"></div>');
@@ -2003,10 +2003,10 @@ function openAddScsi2SystemDialog(hcp) {
var devPathTable = $('<table style="margin-left:140px;"></table>');
var devPathHeader = $('<thead class="ui-widget-header"> <th></th><th>FCP Device</th> <th>WWPN</th> <th>LUN</th></thead>');
// Adjust header width
devPathHeader.find('th').css( {
devPathHeader.find('th').css({
'width' : '120px'
});
devPathHeader.find('th').eq(0).css( {
devPathHeader.find('th').eq(0).css({
'width' : '20px'
});
var devPathBody = $('<tbody></tbody>');
@@ -2121,7 +2121,7 @@ function openAddScsi2SystemDialog(hcp) {
'<option selected value="no">No</option>' +
'<option value="yes">Yes</option>' +
'</select></div>');
addS2SForm.append(system, devNum, devPathDiv, option, persist);
addS2SForm.append(system, devNo, devPathDiv, option, persist);
// Generate tooltips
addS2SForm.find('div input[title],select[title]').tooltip({
@@ -2171,42 +2171,53 @@ function openAddScsi2SystemDialog(hcp) {
// Remove any warning messages
$(this).find('.ui-state-error').remove();
var system = $(this).find('input[name=system]').val();
var num = $(this).find('input[name=devNum]').val();
var system = $(this).find('select[name=system]').val();
var devNo = $(this).find('input[name=devNo]').val();
var pathArray = "";
$('.devPath').each(function(index) {
pathArray += $(this).find('input[name=fcpDevNum]').val() + ' ';
pathArray += $(this).find('input[name=fcpWwpn]').val() + ' ';
pathArray += $(this).find('input[name=fcpLun]').val() + '; ';
pathArray += $(this).find('input[name=fcpDevNum]').val() + ',';
pathArray += $(this).find('input[name=fcpWwpn]').val() + ',';
pathArray += $(this).find('input[name=fcpLun]').val() + ';';
});
path_Array = pathArray + "'";
var option = $(this).find('select[name=option]').val();
var persist = $(this).find('select[name=persist]').val();
// If inputs are not complete, show warning message
if (!system || !num || !pathArray || !option || !persist) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : "--addscsi||" + num + "||" + pathArray + "||" + option + "||" + persist,
msg : dialogId
},
success : updateResourceDialog
});
var ready = true;
var args = new Array('select[name=system]', 'input[name=devNum]', 'select[name=option]', 'select[name=persist]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
}
// Show warning message
if (!ready || !pathArray) {
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
return;
}
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : "--addscsi||" + devNo + "||'" + pathArray + "'||" + option + "||" + persist,
msg : dialogId
},
success : updateResourceDialog
});
},
"Cancel": function() {
$(this).dialog( "close" );
@@ -2283,34 +2294,46 @@ function openRemoveScsiDialog(hcp) {
$(this).find('.ui-state-error').remove();
// Get inputs
var system = $(this).find('input[name=system]').val();
var system = $(this).find('select[name=system]').val();
var devnum = $(this).find('input[name=devNum]').val();
var persist = $(this).find('select[name=persist]').val();
// If inputs are not complete, show warning message
if (!system || !devnum) {
var warn = createWarnBar('Please provide a value for each missing field.');
var ready = true;
var args = new Array('select[name=system]', 'input[name=devNum]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
}
if (!ready) {
// Show warning message
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
} else {
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : "--removescsi;" + devnum + ";" + persist,
msg : dialogId
},
return;
}
success : updateResourceDialog
});
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : "--removescsi;" + devnum + ";" + persist,
msg : dialogId
},
} // End of else
success : updateResourceDialog
});
},
"Cancel": function() {
$(this).dialog( "close" );
@@ -2578,7 +2601,7 @@ function openAddNicDialog(node, hcp) {
$(this).dialog( "close" );
} // End of else
},
"Cancel": function(){
"Cancel": function() {
$(this).dialog( "close" );
}
}
@@ -2606,8 +2629,8 @@ function openAddVswitchVlanDialog(hcp) {
var typeFS = $('<fieldset></fieldset>').hide();
var typeLegend = $('<legend>Network</legend>');
typeFS.append(typeLegend);
addVswitchForm.append(info, netFS, typeFS);
var netAttr = $('<div style="display: inline-table; vertical-align: middle;"></div>');
netFS.append($('<div style="display: inline-table; vertical-align: middle;"><img src="images/provision/network.png"></img></div>'));
netFS.append(netAttr);
@@ -2622,120 +2645,94 @@ function openAddVswitchVlanDialog(hcp) {
netAttr.append(networkTypeDiv);
var system = $('<div><label>z/VM system:</label></div>');
var systemSelect = $('<select name="hcp" title="The System z hardware control point (zHCP) responsible for managing the z/VM system"></select>');
var systemSelect = $('<select name="system" title="The z/VM system name"></select>');
system.append(systemSelect);
netAttr.append(system);
// Obtain mapping for zHCP to zVM system
var hcp2zvm = new Object();
hcp2zvm = getHcpZvmHash();
systemSelect.append($('<option value=""></option>'));
for (var hcp in hcp2zvm) {
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
var typeAttr = $('<div style="display: inline-table; vertical-align: middle;"></div>');
typeFS.append($('<div style="display: inline-table; vertical-align: middle;"><img src="images/provision/preferences_network.png"></img></div>'));
typeFS.append(typeAttr);
// Create vSwitch parameters
var vswitchOptions = $('<div name=vswitchOptions style="height:300px;"></div>').hide();
var vswitchOptions = $('<div name=vswitchOptions></div>').hide();
vswitchOptions.append($('<div><label>Switch name:</label><input type="text" name="switchName" title="The name of the virtual switch segment"/></div>'));
vswitchOptions.append($('<div><label>Device address:</label><input type="text" name="deviceAddress" title="The real device address of a real OSA-Express QDIO device used to create the switch to the virtual adapter"/></div>'));
vswitchOptions.append($('<div><label>Port name:</label><input type="text" name="portName" title="The name used to identify the OSA Expanded adapter"/></div>'));
vswitchOptions.append($('<div><label>Controller name:</label><input type="text" name="controllerName" title="The userid controlling the real device"/></div>'));
vswitchOptions.append($('<div><label>Connection:</label><select name="connection" title="The real device connection">' +
'<option></option>' +
// Create an advanced link to configure optional network settings
var advancedLnk = $('<div><label><a style="color: blue; cursor: pointer;">Advanced</a></label></div>');
vswitchOptions.append(advancedLnk);
var advanced = $('<div style="margin-left: 20px;"></div>').hide();
vswitchOptions.append(advanced);
// Show IP address and hostname inputs on-click
advancedLnk.click(function() {
advanced.toggle();
});
advanced.append($('<div><label>Connection:</label><select name="connection" title="The real device connection">' +
'<option value="0">Unspecified</option>' +
'<option value="1">Activate real device connection</option>' +
'<option value="2">Do not activate real device connection</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>QDIO buffer size:</label><input type="text" name="queueMemoryLimit" maxlength="1" title="A number between 1 and 8 specifying the QDIO buffer size in megabytes. If unspecified, the default is 8."/></div>'));
vswitchOptions.append($('<div><label>Routing:</label><select name="routingValue" title="Specifies whether the OSA-Express QDIO device will act as a router to the virtual switch">' +
'<option></option>' +
advanced.append($('<div><label>QDIO buffer size:</label><input type="text" name="queueMemoryLimit" maxlength="1" value="8" title="A number between 1 and 8 specifying the QDIO buffer size in megabytes. If unspecified, the default is 8."/></div>'));
advanced.append($('<div><label>Routing:</label><select name="routingValue" title="Specifies whether the OSA-Express QDIO device will act as a router to the virtual switch">' +
'<option value="0">Unspecified</option>' +
'<option value="1">NONROUTER</option>' +
'<option value="2">PRIROUTER</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>Transport:</label><select name="transportType" title="Specifies the transport mechanism to be used for the virtual switch">' +
'<option></option>' +
advanced.append($('<div><label>Transport:</label><select name="transportType" title="Specifies the transport mechanism to be used for the virtual switch">' +
'<option value="0">Unspecified</option>' +
'<option value="1">IP</option>' +
'<option value="2">ETHERNET</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>VLAN ID:</label><input type="text" name="vlanId" title="Specifies the VLAN ID"/></div>'));
vswitchOptions.append($('<div><label>Port type:</label><select name="portType" title="Specifies the port type">' +
'<option></option>' +
advanced.append($('<div><label>VLAN ID:</label><input type="text" name="vlanId" value="-1" title="Specifies the VLAN ID"/></div>'));
advanced.append($('<div><label>Port type:</label><select name="portType" title="Specifies the port type">' +
'<option value="0">Unspecified</option>' +
'<option value="1">ACCESS</option>' +
'<option value="2">TRUNK</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>Update sysconfig:</label><select name="updateSysConfig" title="Specifies whether to add the virtual switch definition to the system configuration file">' +
'<option></option>' +
advanced.append($('<div><label>Update sysconfig:</label><select name="updateSysConfig" title="Specifies whether to add the virtual switch definition to the system configuration file">' +
'<option value="0">Unspecified</option>' +
'<option value="1">Create virtual switch</option>' +
'<option value="2">Create virtual switch and add definition to system configuration</option>' +
'<option value="3">Add virtual switch definition to system configuration</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>GVRP:</label><select name="gvrp" title="GVRP will run only on 802.1Q trunk ports and is used primarily to prune traffic from VLANs that does not need to be passed between trunking switches">' +
'<option></option>' +
advanced.append($('<div><label>GVRP:</label><select name="gvrp" title="GVRP will run only on 802.1Q trunk ports and is used primarily to prune traffic from VLANs that does not need to be passed between trunking switches">' +
'<option value="0">Unspecified</option>' +
'<option value="1">GVRP</option>' +
'<option value="2">NOGVRP</option>' +
'</select></div>'));
vswitchOptions.append($('<div><label>Native VLAN ID:</label><input type="text" name="nativeVlanId" title="The native VLAN ID"/></div>'));
advanced.append($('<div><label>Native VLAN ID:</label><input type="text" name="nativeVlanId" value="-1" title="The native VLAN ID"/></div>'));
// Create VLAN parameters
var vlanOptions = $('<div name=vlanOptions></div>').hide();
vlanOptions.append($('<div><label>Name:</label><input type="text" name="vlanName" title="The name of the guest LAN segment to be created"/></div>'));
vlanOptions.append($('<div><label>Owner:</label><input type="text" name="vlanOwner" title="The virtual image owning the guest LAN segment to be created"/></div>'));
vlanOptions.append($('<div><label>Type:</label><select name="vlanType" title="The type of guest LAN segment">' +
'<option value=""></option>' +
'<option value="1">Unrestricted HiperSockets NIC</option>' +
'<option value="2">Unrestricted QDIO NIC</option>' +
'<option value="3">Restricted HiperSockets NIC</option>' +
'<option value="4">Restricted QDIO NIC</option>' +
'</select></div>'));
vlanOptions.append($('<div><label>Transport:</label><select name="vlanTransport" title="The transport mechanism to be used for guest LANs and virtual switches">' +
'<option value=""></option>' +
'<option value="0">Unspecified</option>' +
'<option value="1">IP</option>' +
'<option value="2">Ethernet</option>' +
'</select></div>'));
typeAttr.append(vswitchOptions, vlanOptions);
// Get zVM host names
if (!$.cookie('zvms')) {
$.ajax({
url : 'lib/cmd.php',
dataType : 'json',
async: false,
data : {
cmd : 'webportal',
tgt : '',
args : 'lszvm',
msg : ''
},
success : function(data) {
setzVMCookies(data);
}
});
}
var zvms = $.cookie('zvms').split(',');
var hcp2zvm = new Object();
var args, zvm, iHcp, tmp;
for (var i in zvms) {
args = zvms[i].split(':');
zvm = args[0].toLowerCase();
if (args[1].indexOf('.') != -1) {
tmp = args[1].split('.');
iHcp = tmp[0];
} else {
iHcp = args[1];
}
hcp2zvm[iHcp] = zvm;
}
// Append options for z/VM system
for (var hcp in hcp2zvm) {
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
networkType.change(function() {
typeFS.show();
if ($(this).val() == "vswitch") {
@@ -2789,12 +2786,12 @@ function openAddVswitchVlanDialog(hcp) {
$(this).find('.ui-state-error').remove();
var networkType = $(this).find('select[name=networkType]').val();
if (networkType == "vswitch") {
if (networkType == "vswitch") {
var networkArgs = "--addvswitch;";
var hcp = $(this).find('select[name=hcp]').val();
var system = $(this).find('select[name=system]').val();
var switchName = $(this).find('input[name=switchName]').val();
var deviceAddress = $(this).find('input[name=deviceAddress]').val();
var portName = $(this).find('input[name=portName]').val();
var portName = switchName;
var controllerName = $(this).find('input[name=controllerName]').val();
var connection = $(this).find('select[name=connection]').val();
var queueMemoryLimit = $(this).find('input[name=queueMemoryLimit]').val();
@@ -2806,6 +2803,25 @@ function openAddVswitchVlanDialog(hcp) {
var gvrp = $(this).find('select[name=gvrp]').val();
var nativeVlanId = $(this).find('input[name=nativeVlanId]').val();
// If inputs are not complete, show warning message
var ready = true;
var args = new Array('select[name=system]', 'input[name=switchName]', 'input[name=deviceAddress]', 'input[name=controllerName]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
}
// Show warning message
if (!ready) {
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
return;
}
if (switchName)
networkArgs += switchName + ";";
if (deviceAddress)
@@ -2813,9 +2829,11 @@ function openAddVswitchVlanDialog(hcp) {
if (portName)
networkArgs += portName + ";";
if (controllerName)
networkArgs += controllerName + ";";
networkArgs += controllerName + ";";
// Optional parameters
if (connection)
networkArgs += connection + ";";
networkArgs += connection + ";";
if (queueMemoryLimit)
networkArgs += queueMemoryLimit + ";";
if (routingValue)
@@ -2844,7 +2862,7 @@ function openAddVswitchVlanDialog(hcp) {
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : hcp,
tgt : system,
args : networkArgs,
msg : dialogId
},
@@ -2853,38 +2871,59 @@ function openAddVswitchVlanDialog(hcp) {
});
} else if (networkType == "vlan") {
var networkArgs = "--addvlan;";
var hcp = $(this).find('select[name=hcp]').val();
var system = $(this).find('select[name=system]').val();
var vlanName = $(this).find('input[name=vlanName]').val();
var vlanOwner = $(this).find('input[name=vlanOwner]').val();
var vlanType = $(this).find('select[name=vlanType]').val();
var vlanTransport = $(this).find('select[name=vlanTransport]').val();
if (!vlanName || !vlanOwner || !vlanType || !vlanTransport) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
networkArgs += vlanName + ";";
networkArgs += vlanOwner + ";";
networkArgs += vlanType + ";";
networkArgs += vlanTransport;
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax({
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : hcp,
args : networkArgs,
msg : dialogId
},
success : updateResourceDialog
});
// If inputs are not complete, show warning message
var ready = true;
var args = new Array('select[name=system]', 'input[name=vlanName]', 'input[name=vlanOwner]', 'select[name=vlanType]', 'select[name=vlanTransport]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
}
// Show warning message
if (!ready) {
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
return;
}
// Ethernet Hipersockets are not supported
if (vlanTransport == "2") {
var warn = createWarnBar('Ethernet Hipersockets are not supported');
warn.prependTo($(this));
return;
}
networkArgs += vlanName + ";";
networkArgs += vlanOwner + ";";
networkArgs += vlanType + ";";
networkArgs += vlanTransport;
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax({
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : networkArgs,
msg : dialogId
},
success : updateResourceDialog
});
} // End of else if
},
"Cancel": function() {
@@ -3304,7 +3343,7 @@ function loadDiskPoolTable(data) {
for (var i = 2; i < tmp.length; i++) {
tmp[i] = jQuery.trim(tmp[i]);
var diskAttrs = tmp[i].split(' ');
dTable.fnAddData( [ '<input type="checkbox" name="' + hcp + ";" + diskAttrs[0] + '"/>', hcp2zvm[hcp], pool, stat, diskAttrs[0], diskAttrs[1], diskAttrs[2], diskAttrs[3] ]);
dTable.fnAddData( [ '<input type="checkbox" name="' + hcp2zvm[hcp] + ";" + diskAttrs[0] + '"/>', hcp2zvm[hcp], pool, stat, diskAttrs[0], diskAttrs[1], diskAttrs[2], diskAttrs[3] ]);
}
// Create actions menu
@@ -3477,7 +3516,7 @@ function loadZfcpPoolTable(data) {
for ( var i = 2; i < tmp.length; i++) {
tmp[i] = jQuery.trim(tmp[i]);
var diskAttrs = tmp[i].split(',');
var key = hcp + '-' + pool + '-' + diskAttrs[2];
var key = hcp2zvm[hcp] + '-' + pool + '-' + diskAttrs[2];
dTable.fnAddData( [ '<input type="checkbox" name="' + key + '"/>', hcp2zvm[hcp], pool, diskAttrs[0], diskAttrs[1], diskAttrs[2], diskAttrs[3], diskAttrs[4], diskAttrs[5], diskAttrs[6], diskAttrs[7] ]);
}
}
@@ -3608,21 +3647,21 @@ function openRemoveDiskFromPoolDialog(disks2remove) {
+ '</select>');
action.append(actionSelect);
var hcp = $('<div><label>z/VM system:</label></div>');
var hcpSelect = $('<select name="hcp" title="The z/VM system name"></select>');
hcp.append(hcpSelect);
var system = $('<div><label>z/VM system:</label></div>');
var systemSelect = $('<select name="system" title="The z/VM system name"></select>');
system.append(systemSelect);
// Set region input based on those selected on table (if any)
var region = $('<div><label>Volume name:</label><input type="text" name="region" value="' + tgtVol + '" title="The DASD volume label"/></div>');
var group = $('<div><label>Group name:</label><input type="text" name="group" title="The name of the group from which the volume will be removed"/></div>');
deleteDiskForm.append(action, hcp, region, group);
deleteDiskForm.append(action, system, region, group);
// Append options for hardware control points
hcpSelect.append($('<option value=""></option>'));
systemSelect.append($('<option value=""></option>'));
for (var hcp in hcp2zvm) {
hcpSelect.append($('<option value="' + hcp + '">' + hcp2zvm[hcp] + '</option>'));
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
hcpSelect.val(tgtHcp);
systemSelect.val(tgtHcp);
actionSelect.change(function() {
if ($(this).val() == '1' || $(this).val() == '3') {
@@ -3674,12 +3713,12 @@ function openRemoveDiskFromPoolDialog(disks2remove) {
// Get inputs
var action = $(this).find('select[name=action]').val();
var hcp = $(this).find('select[name=hcp]').val();
var system = $(this).find('select[name=system]').val();
var region = $(this).find('input[name=region]').val();
var group = $(this).find('input[name=group]').val();
// If inputs are not complete, show warning message
if (!action || !hcp) {
if (!action || !system) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
@@ -3699,8 +3738,8 @@ function openRemoveDiskFromPoolDialog(disks2remove) {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chvm',
tgt : hcp,
cmd : 'chhypervisor',
tgt : system,
args : '--removediskfrompool;' + action + ';' + args,
msg : dialogId
},
@@ -3739,17 +3778,17 @@ function openAddDisk2PoolDialog() {
+ '</select>');
action.append(actionSelect);
var hcp = $('<div><label>z/VM system:</label></div>');
var hcpSelect = $('<select name="hcp" title="The z/VM system name"></select>');
hcp.append(hcpSelect);
var system = $('<div><label>z/VM system:</label></div>');
var systemSelect = $('<select name="system" title="The z/VM system name"></select>');
system.append(systemSelect);
var volume = $('<div><label>Volume name:</label><input type="text" name="volume" title="The DASD volume label"/></div>');
var group = $('<div><label>Group name:</label><input type="text" name="group" title="The name of the group to which the volume is assigned"/></div>');
addDiskForm.append(action, hcp, volume, group);
addDiskForm.append(action, system, volume, group);
// Append options for hardware control points
hcpSelect.append($('<option value=""></option>'));
systemSelect.append($('<option value=""></option>'));
for (var hcp in hcp2zvm) {
hcpSelect.append($('<option value="' + hcp + '">' + hcp2zvm[hcp] + '</option>'));
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
actionSelect.change(function() {
@@ -3796,12 +3835,12 @@ function openAddDisk2PoolDialog() {
// Get inputs
var action = $(this).find('select[name=action]').val();
var hcp = $(this).find('select[name=hcp]').val();
var system = $(this).find('select[name=system]').val();
var volume = $(this).find('input[name=volume]').val();
var group = $(this).find('input[name=group]').val();
// If inputs are not complete, show warning message
if (!action || !hcp || !group) {
if (!action || !system || !group) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
@@ -3821,8 +3860,8 @@ function openAddDisk2PoolDialog() {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chvm',
tgt : hcp,
cmd : 'chhypervisor',
tgt : system,
args : '--adddisk2pool;' + action + ';' + args,
msg : dialogId
},
@@ -3877,21 +3916,21 @@ function openRemoveZfcpFromPoolDialog(devices2remove) {
var info = createInfoBar('Remove a zFCP device that is defined in a zFCP pool.');
deleteDiskForm.append(info);
var hcp = $('<div><label>z/VM system:</label></div>');
var hcpSelect = $('<select name="hcp" title="The z/VM system name"></select>');
hcp.append(hcpSelect);
var system = $('<div><label>z/VM system:</label></div>');
var systemSelect = $('<select name="system" title="The z/VM system name"></select>');
system.append(systemSelect);
var pool = $('<div><label>zFCP pool:</label><input type="text" name="zfcpPool" value="' + tgtPool + '" title="The pool where the disk resides"/></div>');
var unitNo = $('<div><label>Unit number:</label><input type="text" name="zfcpUnitNo" value="' + tgtUnitNo + '" title="The hexadecimal digits representing the 8-byte logical unit number of the FCP-I/O device"/></div>');
var portName = $('<div><label>Port name:</label><input type="text" name="zfcpPortName" title="Optional. The hexadecimal digits designating the 8-byte fibre channel port name of the FCP-I/O device"/></div>');
deleteDiskForm.append(hcp, pool, unitNo, portName);
deleteDiskForm.append(system, pool, unitNo, portName);
// Append options for hardware control points
hcpSelect.append($('<option value=""></option>'));
systemSelect.append($('<option value=""></option>'));
for (var hcp in hcp2zvm) {
hcpSelect.append($('<option value="' + hcp + '">' + hcp2zvm[hcp] + '</option>'));
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
hcpSelect.val(tgtHcp);
systemSelect.val(tgtHcp);
// Generate tooltips
deleteDiskForm.find('div input[title],select[title]').tooltip({
@@ -3927,38 +3966,51 @@ function openRemoveZfcpFromPoolDialog(devices2remove) {
// Remove any warning messages
$(this).find('.ui-state-error').remove();
var hcp = $(this).find('select[name=hcp]').val();
var system = $(this).find('select[name=system]').val();
var pool = $(this).find('input[name=zfcpPool]').val();
var unitNo = $(this).find('input[name=zfcpUnitNo]').val();
var portName = $(this).find('input[name=zfcpPortName]').val();
// If inputs are not complete, show warning message
if (!hcp || !pool || !unitNo) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
var args = '--removezfcpfrompool;' + pool + ';' + unitNo;
if (portName) {
args += ';' + portName;
var ready = true;
var args = new Array('select[name=system]', 'input[name=zfcpPool]', 'input[name=zfcpUnitNo]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
$.ajax({
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chvm',
tgt : hcp,
args : args,
msg : dialogId
},
success : updateResourceDialog
});
}
if (!ready) {
// Show warning message
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
return;
}
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
var args = '--removezfcpfrompool;' + pool + ';' + unitNo;
if (portName) {
args += ';' + portName;
}
$.ajax({
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : system,
args : args,
msg : dialogId
},
success : updateResourceDialog
});
},
"Cancel": function() {
$(this).dialog( "close" );
@@ -3981,9 +4033,9 @@ function openAddZfcp2PoolDialog() {
var hcp2zvm = new Object();
hcp2zvm = getHcpZvmHash();
var hcp = $('<div><label>z/VM system:</label></div>');
var hcpSelect = $('<select name="hcp" title="The z/VM system name"></select>');
hcp.append(hcpSelect);
var system = $('<div><label>z/VM system:</label></div>');
var systemSelect = $('<select name="system" title="The z/VM system name"></select>');
system.append(systemSelect);
var pool = $('<div><label>zFCP pool:</label><input type="text" name="zfcpPool" title="The pool where the disk is to be assigned"/></div>');
var status = $('<div><label>Status:</label><select name="zfcpStatus" title="The status of the SCSI disk">'
@@ -3995,13 +4047,13 @@ function openAddZfcp2PoolDialog() {
var size = $('<div><label>Size:</label><input type="text" name="zfcpSize" title="The size of the disk to be added. The size can be in G or M. For example, 2G or 2048M."/></div>');
var range = $('<div><label>Range:</label><input type="text" name="zfcpRange" title="The range of the dedicated FCP device channels where this device can be connected to"/></div>');
var owner = $('<div><label>Owner:</label><input type="text" name="zfcpOwner" title="Optional. The node that currently owns this SCSI device."/></div>');
addDiskForm.append(hcp, pool, status, portName, unitNo, size, range, owner);
addDiskForm.append(system, pool, status, portName, unitNo, size, range, owner);
// Create a array for hardware control points
hcpSelect.append($('<option value=""></option>'));
systemSelect.append($('<option value=""></option>'));
// Append options for hardware control points
for (var hcp in hcp2zvm) {
hcpSelect.append($('<option value="' + hcp + '">' + hcp2zvm[hcp] + '</option>'));
systemSelect.append($('<option value="' + hcp2zvm[hcp] + '">' + hcp2zvm[hcp] + '</option>'));
}
// Generate tooltips
@@ -4038,7 +4090,7 @@ function openAddZfcp2PoolDialog() {
// Delete any warning messages
$(this).find('.ui-state-error').remove();
var tgtHcp = $(this).find('select[name=hcp]').val();
var tgtSystem = $(this).find('select[name=system]').val();
var tgtPool = $(this).find('input[name=zfcpPool]').val();
var tgtStatus = $(this).find('select[name=zfcpStatus]').val();
var tgtPortName = $(this).find('input[name=zfcpPortName]').val();
@@ -4051,30 +4103,43 @@ function openAddZfcp2PoolDialog() {
if ($(this).find('input[name=zfcpOwner]').val()) {
tgtOwner = $(this).find('input[name=zfcpOwner]').val();
}
// If inputs are not complete, show warning message
if (!tgtHcp || !tgtPool || !tgtStatus || !tgtPortName || !tgtUnitNo || !tgtSize) {
var warn = createWarnBar('Please provide a value for each missing field.');
warn.prependTo($(this));
} else {
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chvm',
tgt : tgtHcp,
args : '--addzfcp2pool||' + tgtPool + '||' + tgtStatus + '||"' + tgtPortName + '"||' + tgtUnitNo + '||' + tgtSize + '||' + tgtRange + '||' + tgtOwner,
msg : dialogId
},
success : updateResourceDialog
});
var ready = true;
var args = new Array('select[name=system]', 'input[name=zfcpPool]', 'select[name=zfcpStatus]', 'input[name=zfcpPortName]', 'input[name=zfcpUnitNo]');
for (var i in args) {
if (!$(this).find(args[i]).val()) {
$(this).find(args[i]).css('border', 'solid #FF0000 1px');
ready = false;
} else {
$(this).find(args[i]).css('border', 'solid #BDBDBD 1px');
}
}
if (!ready) {
// Show warning message
var warn = createWarnBar('Please provide a value for each required field.');
warn.prependTo($(this));
return;
}
// Change dialog buttons
$(this).dialog('option', 'buttons', {
'Close': function() {$(this).dialog("close");}
});
$.ajax( {
url : 'lib/cmd.php',
dataType : 'json',
data : {
cmd : 'chhypervisor',
tgt : tgtSystem,
args : '--addzfcp2pool||' + tgtPool + '||' + tgtStatus + '||"' + tgtPortName + '"||' + tgtUnitNo + '||' + tgtSize + '||' + tgtRange + '||' + tgtOwner,
msg : dialogId
},
success : updateResourceDialog
});
},
"Cancel": function() {
$(this).dialog( "close" );

View File

@@ -6037,7 +6037,6 @@ sub changeHypervisor {
# Add an ECKD disk to a running z/VM system
$out = `ssh $::SUDOER\@$hcp "$::SUDO $::DIR/smcli System_Disk_Add -T $hcpUserId -k $devNo"`;
$out = xCAT::zvmUtils->appendHostname( $node, $out );
}
# addscsi [dev_no] [dev_path] [option] [persist]
@@ -6107,17 +6106,22 @@ sub changeHypervisor {
$out .= `ssh $::SUDOER\@$hcp "$::SUDO $::DIR/smcli Virtual_Network_LAN_Create -T $hcpUserId -n $name -o $owner -t $type -p $transport"`;
}
# addvswitch [name] [osa_dev_addr] [osa_exp_adapter] [controller] [connect (0, 1, or 2)] [memory_queue] [router] [transport] [vlan_id] [port_type] [update] [gvrp] [native_vlan]
# addvswitch [name] [osa_dev_addr] [port_name] [controller] [connect (0, 1, or 2)] [memory_queue] [router] [transport] [vlan_id] [port_type] [update] [gvrp] [native_vlan]
elsif ( $args->[0] eq "--addvswitch" ) {
my $i;
my $argStr = "";
my $argsSize = @{$args};
if ($argsSize < 5) {
xCAT::zvmUtils->printLn( $callback, "$node: (Error) Wrong number of parameters" );
return;
}
my @options = ("", "-n", "-r", "-a", "-i", "-c", "-q", "-e", "-t", "-v", "-p", "-u", "-G", "-V");
foreach $i ( 1 .. $argsSize ) {
if ( $args->[$i] ) {
# Prepend options prefix to argument
$argStr .= "$options[$i] $args->[$i] ";
$argStr .= "$options[$i] $args->[$i] ";
}
}
@@ -6167,13 +6171,7 @@ sub changeHypervisor {
# Create pool directory
$out = `ssh $::SUDOER\@$hcp "$::SUDO mkdir -p $::ZFCPPOOL"`;
}
if (!(`ssh $::SUDOER\@$hcp "$::SUDO test -e $::ZFCPPOOL/$pool.conf && echo Exists"`)) {
# Create pool configuration file
$out = xCAT::zvmUtils->rExecute($::SUDOER, $hcp, "echo '#status,wwpn,lun,size,range,owner,channel,tag' > $::ZFCPPOOL/$pool.conf");
xCAT::zvmUtils->printLn( $callback, "$node: New zFCP device pool $pool created" );
}
# Change the file owner if using a sudoer
if ($::SUDOER ne "root") {
my $priv = xCAT::zvmUtils->trimStr(`ssh $::SUDOER\@$hcp "$::SUDO stat -c \"%G:%U\" /var/opt/zhcp"`);
@@ -6181,6 +6179,12 @@ sub changeHypervisor {
`ssh $::SUDOER\@$hcp "$::SUDO chown -R $::SUDOER:users /var/opt/zhcp"`;
}
}
if (!(`ssh $::SUDOER\@$hcp "$::SUDO test -e $::ZFCPPOOL/$pool.conf && echo Exists"`)) {
# Create pool configuration file
$out = `ssh $::SUDOER\@$hcp "$::SUDO echo '#status,wwpn,lun,size,range,owner,channel,tag' > $::ZFCPPOOL/$pool.conf"`;
xCAT::zvmUtils->printLn( $callback, "$node: New zFCP device pool $pool created" );
}
# Do not update if the LUN already exists
if (`ssh $::SUDOER\@$hcp "$::SUDO cat $::ZFCPPOOL/$pool.conf" | grep $lun`) {
@@ -6241,7 +6245,6 @@ sub changeHypervisor {
# Delete a real SCSI disk
$out = `ssh $::SUDOER\@$hcp "$::SUDO $::DIR/smcli System_SCSI_Disk_Delete -T $hcpUserId -k $devNo -k $persist"`;
$out = xCAT::zvmUtils->appendHostname( $node, $out );
}
# removevlan [name] [owner]
@@ -6251,7 +6254,6 @@ sub changeHypervisor {
# Delete a virtual network
$out = `ssh $hcp "$::DIR/smcli Virtual_Network_LAN_Delete -T $hcpUserId -n $name -o $owner"`;
$out = xCAT::zvmUtils->appendHostname( $node, $out );
}
# removevswitch [name]
@@ -6260,7 +6262,6 @@ sub changeHypervisor {
# Delete a VSWITCH
$out = `ssh $hcp "$::DIR/smcli Virtual_Network_Vswitch_Delete -T $hcpUserId -n $name"`;
$out = xCAT::zvmUtils->appendHostname( $node, $out );
}
# removezfcpfrompool [pool] [lun] [wwpn (optional)]