mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-11-04 05:12:30 +00:00 
			
		
		
		
	git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@10502 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
		
			
				
	
	
		
			767 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			767 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var provisionClock;
 | 
						|
 | 
						|
/**
 | 
						|
 * Create nodes datatable for a given group
 | 
						|
 * 
 | 
						|
 * @param group
 | 
						|
 *            Group name
 | 
						|
 * @param outId
 | 
						|
 *            Division ID to append datatable
 | 
						|
 * @return Nodes datatable
 | 
						|
 */
 | 
						|
function createNodesDatatable(group, outId) {
 | 
						|
	// Get group nodes
 | 
						|
	$.ajax( {
 | 
						|
		url : 'lib/cmd.php',
 | 
						|
		dataType : 'json',
 | 
						|
		data : {
 | 
						|
			cmd : 'lsdef',
 | 
						|
			tgt : '',
 | 
						|
			args : group,
 | 
						|
			msg : outId
 | 
						|
		},
 | 
						|
 | 
						|
		/**
 | 
						|
		 * Create nodes datatable
 | 
						|
		 * 
 | 
						|
		 * @param data
 | 
						|
		 *            Data returned from HTTP request
 | 
						|
		 * @return Nothing
 | 
						|
		 */
 | 
						|
		success : function(data) {
 | 
						|
			// Data returned
 | 
						|
    		var rsp = data.rsp;
 | 
						|
    
 | 
						|
    		// Get output ID
 | 
						|
    		var outId = data.msg;
 | 
						|
    		// Get datatable ID
 | 
						|
    		var dTableId = outId.replace('DIV', '');
 | 
						|
    
 | 
						|
    		// Node attributes hash
 | 
						|
    		var attrs = new Object();
 | 
						|
    		// Node attributes
 | 
						|
    		var headers = new Object();
 | 
						|
    
 | 
						|
    		// Clear nodes datatable division
 | 
						|
    		$('#' + outId).empty();
 | 
						|
    
 | 
						|
    		// Create nodes datatable
 | 
						|
    		var node, args;
 | 
						|
    		for ( var i in rsp) {
 | 
						|
    			// Get node
 | 
						|
    			var pos = rsp[i].indexOf('Object name:');
 | 
						|
    			if (pos > -1) {
 | 
						|
    				var temp = rsp[i].split(': ');
 | 
						|
    				node = jQuery.trim(temp[1]);
 | 
						|
    
 | 
						|
    				// Create a hash for the node attributes
 | 
						|
    				attrs[node] = new Object();
 | 
						|
    				i++;
 | 
						|
    			}
 | 
						|
    
 | 
						|
    			// Get key and value
 | 
						|
    			args = rsp[i].split('=');
 | 
						|
    			var key = jQuery.trim(args[0]);
 | 
						|
    			var val = jQuery.trim(args[1]);
 | 
						|
    
 | 
						|
    			// Create hash table
 | 
						|
    			attrs[node][key] = val;
 | 
						|
    			headers[key] = 1;
 | 
						|
    		}
 | 
						|
    
 | 
						|
    		// Sort headers
 | 
						|
    		var sorted = new Array();
 | 
						|
    		for ( var key in headers) {
 | 
						|
    			sorted.push(key);
 | 
						|
    		}
 | 
						|
    		sorted.sort();
 | 
						|
    
 | 
						|
    		// Add column for check box and node
 | 
						|
    		sorted.unshift('<input type="checkbox" onclick="selectAllCheckbox(event, $(this))">', 'node');
 | 
						|
    
 | 
						|
    		// Create nodes datatable
 | 
						|
    		var dTable = new DataTable(dTableId);
 | 
						|
    		dTable.init(sorted);
 | 
						|
    
 | 
						|
    		// Go through each node
 | 
						|
    		for ( var node in attrs) {
 | 
						|
    			// Create a row
 | 
						|
    			var row = new Array();
 | 
						|
    			// Create a check box
 | 
						|
    			var checkBx = '<input type="checkbox" name="' + node + '"/>';
 | 
						|
    			row.push(checkBx, node);
 | 
						|
    
 | 
						|
    			// Go through each header
 | 
						|
    			for ( var i = 2; i < sorted.length; i++) {
 | 
						|
    				// Add node attributes to the row
 | 
						|
    				var key = sorted[i];
 | 
						|
    				var val = attrs[node][key];
 | 
						|
    				if (val) {
 | 
						|
    					row.push(val);
 | 
						|
    				} else {
 | 
						|
    					row.push('');
 | 
						|
    				}
 | 
						|
    			}
 | 
						|
    
 | 
						|
    			// Add row to table
 | 
						|
    			dTable.add(row);
 | 
						|
    		}
 | 
						|
    
 | 
						|
    		$('#' + outId).append(dTable.object());
 | 
						|
    		$('#' + dTableId).dataTable();
 | 
						|
    	} // End of function(data)
 | 
						|
	});
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provision existing node division
 | 
						|
 * 
 | 
						|
 * @param plugin
 | 
						|
 * 			  Plugin name to create division for
 | 
						|
 * @param inst
 | 
						|
 *            Provision tab instance
 | 
						|
 * @return Provision existing node division
 | 
						|
 */
 | 
						|
function createProvisionExisting(plugin, inst) {
 | 
						|
	// Create provision existing division and hide it
 | 
						|
	var provExisting = $('<div></div>').hide();
 | 
						|
 | 
						|
	// Create group input
 | 
						|
	var group = $('<div></div>');
 | 
						|
	var groupLabel = $('<label for="provType">Group:</label>');
 | 
						|
	group.append(groupLabel);
 | 
						|
 | 
						|
	// Turn on auto complete for group
 | 
						|
	var dTableDivId = plugin + 'NodesDatatableDIV' + inst;	// Division ID where nodes datatable will be appended
 | 
						|
	var groupNames = $.cookie('groups');
 | 
						|
	if (groupNames) {
 | 
						|
		// Split group names into an array
 | 
						|
		var tmp = groupNames.split(',');
 | 
						|
 | 
						|
		// Create drop down for groups
 | 
						|
		var groupSelect = $('<select></select>');
 | 
						|
		groupSelect.append('<option></option>');
 | 
						|
		for ( var i in tmp) {
 | 
						|
			// Add group into drop down
 | 
						|
			var opt = $('<option value="' + tmp[i] + '">' + tmp[i] + '</option>');
 | 
						|
			groupSelect.append(opt);
 | 
						|
		}
 | 
						|
		group.append(groupSelect);
 | 
						|
 | 
						|
		// Create node datatable
 | 
						|
		groupSelect.change(function() {
 | 
						|
			// Get group selected
 | 
						|
			var thisGroup = $(this).val();
 | 
						|
			// If a valid group is selected
 | 
						|
			if (thisGroup) {
 | 
						|
				createNodesDatatable(thisGroup, dTableDivId);
 | 
						|
			} // End of if (thisGroup)
 | 
						|
		});
 | 
						|
	} else {
 | 
						|
		// If no groups are cookied
 | 
						|
		var groupInput = $('<input type="text" name="group"/>');
 | 
						|
		group.append(groupInput);
 | 
						|
	}
 | 
						|
	provExisting.append(group);
 | 
						|
 | 
						|
	// Create node input
 | 
						|
	var node = $('<div></div>');
 | 
						|
	var nodeLabel = $('<label for="nodeName">Nodes:</label>');
 | 
						|
	var nodeDatatable = $('<div class="indent" id="' + dTableDivId + '"><p>Select a group to view its nodes</p></div>');
 | 
						|
	node.append(nodeLabel);
 | 
						|
	node.append(nodeDatatable);
 | 
						|
	provExisting.append(node);
 | 
						|
 | 
						|
	// Create boot method drop down
 | 
						|
	var method = $('<div></div>');
 | 
						|
	var methodLabel = $('<label for="method">Boot method:</label>');
 | 
						|
	var methodSelect = $('<select id="bootMethod" name="bootMethod"></select>');
 | 
						|
	methodSelect.append('<option value="boot">boot</option>'
 | 
						|
		+ '<option value="install">install</option>'
 | 
						|
		+ '<option value="iscsiboot">iscsiboot</option>'
 | 
						|
		+ '<option value="netboot">netboot</option>'
 | 
						|
		+ '<option value="statelite">statelite</option>'
 | 
						|
	);
 | 
						|
	method.append(methodLabel);
 | 
						|
	method.append(methodSelect);
 | 
						|
	provExisting.append(method);
 | 
						|
 | 
						|
	// Create boot type drop down
 | 
						|
	var type = $('<div></div>');
 | 
						|
	var typeLabel = $('<label for="type">Boot type:</label>');
 | 
						|
	var typeSelect = $('<select id="bootType" name="bootType"></select>');
 | 
						|
	typeSelect.append('<option value="pxe">pxe</option>'
 | 
						|
		+ '<option value="iscsiboot">yaboot</option>'
 | 
						|
		+ '<option value="zvm">zvm</option>'
 | 
						|
	);
 | 
						|
	type.append(typeLabel);
 | 
						|
	type.append(typeSelect);
 | 
						|
	provExisting.append(type);
 | 
						|
 | 
						|
	// Create operating system input
 | 
						|
	var os = $('<div></div>');
 | 
						|
	var osLabel = $('<label for="os">Operating system:</label>');
 | 
						|
	var osInput = $('<input type="text" name="os"/>');
 | 
						|
	osInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('osvers');		
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	os.append(osLabel);
 | 
						|
	os.append(osInput);
 | 
						|
	provExisting.append(os);
 | 
						|
 | 
						|
	// Create architecture input
 | 
						|
	var arch = $('<div></div>');
 | 
						|
	var archLabel = $('<label for="arch">Architecture:</label>');
 | 
						|
	var archInput = $('<input type="text" name="arch"/>');
 | 
						|
	archInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('osarchs');
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	arch.append(archLabel);
 | 
						|
	arch.append(archInput);
 | 
						|
	provExisting.append(arch);
 | 
						|
 | 
						|
	// Create profile input
 | 
						|
	var profile = $('<div></div>');
 | 
						|
	var profileLabel = $('<label for="profile">Profile:</label>');
 | 
						|
	var profileInput = $('<input type="text" name="profile"/>');
 | 
						|
	profileInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('profiles');
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	profile.append(profileLabel);
 | 
						|
	profile.append(profileInput);
 | 
						|
	provExisting.append(profile);
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Provision existing
 | 
						|
	 */
 | 
						|
	var provisionBtn = createButton('Provision');
 | 
						|
	provisionBtn.bind('click', function(event) {
 | 
						|
		// TODO Insert provision code here
 | 
						|
		openDialog('info', 'Under construction');
 | 
						|
	});
 | 
						|
	provExisting.append(provisionBtn);
 | 
						|
 | 
						|
	return provExisting;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provision new node division
 | 
						|
 * 
 | 
						|
 * @param inst
 | 
						|
 *            Provision tab instance
 | 
						|
 * @return Provision new node division
 | 
						|
 */
 | 
						|
function createProvisionNew(plugin, inst) {
 | 
						|
	// Create provision new node division
 | 
						|
	var provNew = $('<div></div>');
 | 
						|
 | 
						|
	// Create node input
 | 
						|
	var nodeName = $('<div><label for="nodeName">Node:</label><input type="text" name="nodeName"/></div>');
 | 
						|
	provNew.append(nodeName);
 | 
						|
 | 
						|
	// Create group input
 | 
						|
	var group = $('<div></div>');
 | 
						|
	var groupLabel = $('<label for="group">Group:</label>');
 | 
						|
	var groupInput = $('<input type="text" name="group"/>');
 | 
						|
	groupInput.one('focus', function() {
 | 
						|
		var groupNames = $.cookie('groups');
 | 
						|
		if (groupNames) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: groupNames.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	group.append(groupLabel);
 | 
						|
	group.append(groupInput);
 | 
						|
	provNew.append(group);
 | 
						|
 | 
						|
	// Create boot method drop down
 | 
						|
	var method = $('<div></div>');
 | 
						|
	var methodLabel = $('<label for="method">Boot method:</label>');
 | 
						|
	var methodSelect = $('<select id="bootMethod" name="bootMethod"></select>');
 | 
						|
	methodSelect.append('<option value="boot">boot</option>'
 | 
						|
		+ '<option value="install">install</option>'
 | 
						|
		+ '<option value="iscsiboot">iscsiboot</option>'
 | 
						|
		+ '<option value="netboot">netboot</option>'
 | 
						|
		+ '<option value="statelite">statelite</option>'
 | 
						|
	);
 | 
						|
	method.append(methodLabel);
 | 
						|
	method.append(methodSelect);
 | 
						|
	provNew.append(method);
 | 
						|
 | 
						|
	// Create boot type drop down
 | 
						|
	var type = $('<div></div>');
 | 
						|
	var typeLabel = $('<label for="type">Boot type:</label>');
 | 
						|
	var typeSelect = $('<select id="bootType" name="bootType"></select>');
 | 
						|
	typeSelect.append('<option value="install">pxe</option>'
 | 
						|
		+ '<option value="iscsiboot">yaboot</option>'
 | 
						|
		+ '<option value="zvm">zvm</option>'
 | 
						|
	);
 | 
						|
	type.append(typeLabel);
 | 
						|
	type.append(typeSelect);
 | 
						|
	provNew.append(type);
 | 
						|
 | 
						|
	// Create operating system input
 | 
						|
	var os = $('<div></div>');
 | 
						|
	var osLabel = $('<label for="os">Operating system:</label>');
 | 
						|
	var osInput = $('<input type="text" name="os"/>');
 | 
						|
	osInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('osvers');
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	os.append(osLabel);
 | 
						|
	os.append(osInput);
 | 
						|
	provNew.append(os);
 | 
						|
 | 
						|
	// Create architecture input
 | 
						|
	var arch = $('<div></div>');
 | 
						|
	var archLabel = $('<label for="arch">Architecture:</label>');
 | 
						|
	var archInput = $('<input type="text" name="arch"/>');
 | 
						|
	archInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('osarchs');
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	arch.append(archLabel);
 | 
						|
	arch.append(archInput);
 | 
						|
	provNew.append(arch);
 | 
						|
 | 
						|
	// Create profile input
 | 
						|
	var profile = $('<div></div>');
 | 
						|
	var profileLabel = $('<label for="profile">Profile:</label>');
 | 
						|
	var profileInput = $('<input type="text" name="profile"/>');
 | 
						|
	profileInput.one('focus', function() {
 | 
						|
		var tmp = $.cookie('profiles');
 | 
						|
		if (tmp) {
 | 
						|
			// Turn on auto complete
 | 
						|
			$(this).autocomplete({
 | 
						|
				source: tmp.split(',')
 | 
						|
			});
 | 
						|
		}
 | 
						|
	});
 | 
						|
	profile.append(profileLabel);
 | 
						|
	profile.append(profileInput);
 | 
						|
	provNew.append(profile);
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Provision new node
 | 
						|
	 */
 | 
						|
	var provisionBtn = createButton('Provision');
 | 
						|
	provisionBtn.bind('click', function(event) {
 | 
						|
		// TODO Insert provision code here
 | 
						|
		openDialog('info', 'Under construction');
 | 
						|
	});
 | 
						|
	provNew.append(provisionBtn);
 | 
						|
 | 
						|
	return provNew;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provision node division
 | 
						|
 * 
 | 
						|
 * @param plugin
 | 
						|
 * 			  Plugin name to create division for
 | 
						|
 * @param container
 | 
						|
 *            Container to hold provisioning form
 | 
						|
 * @return Nothing
 | 
						|
 */
 | 
						|
function createProvision(plugin, container){
 | 
						|
	// Group, nodes, arch
 | 
						|
    if ('quick' == plugin) {
 | 
						|
        container.append(createProvWithUrl());
 | 
						|
    } else {
 | 
						|
        container.append(createProvNoUrl(plugin));
 | 
						|
        container.find('#' + plugin + 'group').bind('change', function() {
 | 
						|
            var pluginName = $(this).attr('id').replace('group', '');
 | 
						|
            $('#' + pluginName + 'SelectNodesTable').html('<img src="images/loader.gif"></img>');
 | 
						|
            createNodesArea($(this).val(), pluginName + 'SelectNodesTable');
 | 
						|
        });
 | 
						|
    }
 | 
						|
    
 | 
						|
    // Advanced options
 | 
						|
    container.append('<div id="advoption"></div>');
 | 
						|
    
 | 
						|
    // Add provision button
 | 
						|
    var provisionBtn = createButton('Provision');
 | 
						|
    provisionBtn.bind('click', function(){
 | 
						|
        var plugin = $(this).parent().parent().attr('id').replace('ProvisionTab', '');
 | 
						|
        quickProvision(plugin);
 | 
						|
    });
 | 
						|
    provisionBtn.hide();
 | 
						|
    container.append(provisionBtn);
 | 
						|
    
 | 
						|
    // Bind image select to change event
 | 
						|
    container.find('#' + plugin + 'image').bind('change', function(){
 | 
						|
        var temp = $(this).attr('id');
 | 
						|
        temp = temp.replace('image', '');
 | 
						|
        $('#' + temp + 'ProvisionTab #advoption').html('<img src="images/loader.gif"></img>');
 | 
						|
        provAdvOption($(this).val(), temp);
 | 
						|
    });
 | 
						|
    
 | 
						|
    $.ajax({
 | 
						|
        url : 'lib/cmd.php',
 | 
						|
        dataType : 'json',
 | 
						|
        data : {
 | 
						|
            cmd : 'lsdef',
 | 
						|
            tgt : '',
 | 
						|
            args : '-t;osimage',
 | 
						|
            msg : plugin
 | 
						|
        },
 | 
						|
 | 
						|
        success : function(data){
 | 
						|
            var containerId = data.msg + 'ProvisionTab';
 | 
						|
            var i = 0;
 | 
						|
            var imageName = 0;
 | 
						|
            var position = 0;
 | 
						|
            var imageSelect = $('#' + containerId + ' #' + data.msg + 'image');
 | 
						|
            $('#' + containerId + ' img').remove();
 | 
						|
            if (!data.rsp.length) {
 | 
						|
                $('#' + containerId).prepend(createWarnBar('Please run copycds and genimage in provision page before continuing!'));
 | 
						|
                return;
 | 
						|
            }
 | 
						|
            
 | 
						|
            for (i in data.rsp) {
 | 
						|
                imageName = data.rsp[i];
 | 
						|
                position = imageName.indexOf(' ');
 | 
						|
                imageName = imageName.substr(0, position);
 | 
						|
                
 | 
						|
                imageSelect.append($('<option value="' + imageName + '">' + imageName + '</option>'));
 | 
						|
            }
 | 
						|
            
 | 
						|
            // Trigger select change event
 | 
						|
            imageSelect.trigger('change');
 | 
						|
            // Show provision button
 | 
						|
            $('#' + containerId + ' button').show();
 | 
						|
        }
 | 
						|
    });
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provision node division using URL
 | 
						|
 * 
 | 
						|
 * @returns Provisiong node division
 | 
						|
 */
 | 
						|
function createProvWithUrl(){
 | 
						|
    var queryStr = window.location.search;
 | 
						|
    var argArray = queryStr.substr(1).split('&');
 | 
						|
    var tempHash = new Object();
 | 
						|
    var i = 0;
 | 
						|
    var tempArray;
 | 
						|
    
 | 
						|
    var provHtml = '';
 | 
						|
    
 | 
						|
    var master = '';
 | 
						|
    var tftpserver = '';
 | 
						|
    var nfsserver = '';    
 | 
						|
    for (i = 0; i < argArray.length; i++) {
 | 
						|
        tempArray = argArray[i].split('=');
 | 
						|
        tempHash[tempArray[0]] = tempArray[1];
 | 
						|
    }
 | 
						|
    
 | 
						|
    provHtml += '<div><label>Nodes:</label><input type="text" disabled="disabled" value="' + tempHash['nodes'] + '"></div>';
 | 
						|
    provHtml += '<div><label>Architecture:</label><input type="text" disabled="disabled" value="' + tempHash['arch'] + '"></div>';
 | 
						|
    provHtml += '<div><label>Image:</label><select id="quickimage"></select><img src="images/loader.gif"></img></div>' +
 | 
						|
    		   '<div><label>Install NIC:</label><input value="mac"/></div>' +
 | 
						|
    		   '<div><label>Primary NIC:</label><input value="mac"/></div>' ;
 | 
						|
    
 | 
						|
    if (tempHash['master']) {
 | 
						|
    	master = tempHash['master'];
 | 
						|
    }
 | 
						|
    
 | 
						|
    if (tempHash['nfsserver']) {
 | 
						|
    	nfsserver = tempHash['nfsserver'];
 | 
						|
    }
 | 
						|
    
 | 
						|
    if (tempHash['tftpserver']) {
 | 
						|
    	tftpserver = tempHash['tftpserver'];
 | 
						|
    }
 | 
						|
    
 | 
						|
    provHtml += '<div><label>xCAT master:</label><input type="text" value="' + master + '"></div>';
 | 
						|
    provHtml += '<div><label>TFTP server:</label><input type="text" value="' + tftpserver + '"></div>';
 | 
						|
    provHtml += '<div><label>NFS server:</label><input type="text" value="' + nfsserver + '"></div>';
 | 
						|
    
 | 
						|
    return provHtml;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provision node division without using URL
 | 
						|
 * 
 | 
						|
 * @param plugin
 | 
						|
 * 			  Plugin name to create division for
 | 
						|
 * @returns {String}
 | 
						|
 */
 | 
						|
function createProvNoUrl(plugin){
 | 
						|
    // Select group
 | 
						|
    var groupHtml = '<div><label>Group:</label>';
 | 
						|
    var groupNames = $.cookie('groups');
 | 
						|
    if (groupNames) {
 | 
						|
        groupHtml += '<select id="' + plugin + 'group"><option></option>';
 | 
						|
        var temp = groupNames.split(',');
 | 
						|
        for (var i in temp) {
 | 
						|
            groupHtml += '<option value="' + temp[i] + '">' + temp[i] + '</option>';
 | 
						|
        }
 | 
						|
        groupHtml += '</select>';
 | 
						|
    } 
 | 
						|
    groupHtml += '</div>';
 | 
						|
 | 
						|
    // Select nodes
 | 
						|
    var nodesHtml = '<div><label>Nodes:</label><div id="' + plugin + 'SelectNodesTable" style="display: inline-block; width:700px; overflow-y:auto;">Select a group to view its nodes</div></div>';
 | 
						|
 | 
						|
    // Select architecture
 | 
						|
    var archHtml = '<div><label>Architecture:</label>';
 | 
						|
    var archName = $.cookie('osarchs');
 | 
						|
    if (archName) {
 | 
						|
        archHtml += '<select id="arch">';
 | 
						|
        var temp = archName.split(',');
 | 
						|
        for (var i in temp) {
 | 
						|
            archHtml += '<option value="' + temp[i] + '">' + temp[i] + '</option>';
 | 
						|
        }
 | 
						|
        archHtml += '</select>';
 | 
						|
    } else {
 | 
						|
        archHtml += '<input type="text" id="arch">';
 | 
						|
    }
 | 
						|
    archHtml += '</div>';
 | 
						|
 | 
						|
    // Add static input part
 | 
						|
    var staticHtml = '<div><label>Image:</label><select id="' + plugin + 'image"></select><img src="images/loader.gif"></img></div>' +
 | 
						|
    		 '<div><label>Install NIC:</label><input value="mac"/></div>' +
 | 
						|
    		 '<div><label>Primary NIC:</label><input value="mac"/></div>' +
 | 
						|
    		 '<div><label>xCAT Master:</label><input/></div>' +
 | 
						|
    		 '<div><label>TFTP Server:</label><input/></div>' +
 | 
						|
    		 '<div><label>NFS Server:</label><input/></div>';
 | 
						|
    return groupHtml + nodesHtml + archHtml + staticHtml;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Get needed fields for provsioning and send command to server 
 | 
						|
 * 
 | 
						|
 * @param plugin
 | 
						|
 * 			  Plugin name of platform to provision
 | 
						|
 * @return Nothing
 | 
						|
 */
 | 
						|
function quickProvision(plugin){
 | 
						|
    var errorMessage = '';
 | 
						|
    var argsArray = new Array();
 | 
						|
    var nodesName = '';
 | 
						|
    var provisionArg = '';
 | 
						|
    var provisionFrame;
 | 
						|
    var imageName = '';
 | 
						|
    var url = '';
 | 
						|
    var softwareArg = '';
 | 
						|
    var containerId = plugin + 'ProvisionTab';
 | 
						|
    $('#' + containerId + ' .ui-state-error').remove();
 | 
						|
    
 | 
						|
    $('#' + containerId + ' input[type!="checkbox"]').each(function() {
 | 
						|
        if (!$(this).val()) {
 | 
						|
            errorMessage = 'You are missing some inputs!';
 | 
						|
            return false;
 | 
						|
        } else {
 | 
						|
            argsArray.push($(this).val());
 | 
						|
        }
 | 
						|
    });
 | 
						|
    
 | 
						|
    if (errorMessage) {
 | 
						|
        $('#' + containerId).prepend('<p class="ui-state-error">' + errorMessage + '</p>');
 | 
						|
        return;
 | 
						|
    }
 | 
						|
    
 | 
						|
    // If jumped from nodes page, get node names 
 | 
						|
    if ('quick' == plugin) {
 | 
						|
        nodesName = argsArray.shift();
 | 
						|
    }
 | 
						|
    // Select platform, get node names from table checkbox
 | 
						|
    else {
 | 
						|
        // Should unshift the arch type
 | 
						|
        argsArray.unshift($('#' + containerId + ' #arch').val());
 | 
						|
        nodesName = getCheckedByObj($('#' + containerId + ' #' + plugin + 'SelectNodesTable'));
 | 
						|
    }
 | 
						|
    
 | 
						|
    if (!nodesName) {
 | 
						|
        $('#' + containerId).prepend('<p class="ui-state-error">Please select a node</p>');
 | 
						|
        return;
 | 
						|
    }
 | 
						|
    
 | 
						|
    softwareArg = getCheckedByObj($('#' + containerId + ' #advoption'));
 | 
						|
    imageName = $('#' + containerId + ' #'  + plugin + 'image').val();
 | 
						|
    provisionArg = argsArray.join(',');
 | 
						|
    
 | 
						|
    url = 'lib/cmd.php?cmd=webrun&tgt=&args=provision;' + nodesName + ';' + imageName + ';' + 
 | 
						|
          provisionArg + ';' + softwareArg + '&msg=&opts=flush';
 | 
						|
    
 | 
						|
    // Show output
 | 
						|
    var deployDia = $('<div id="deployDia"></div>');
 | 
						|
    deployDia.append(createLoader()).append('<br/>');
 | 
						|
    deployDia.append('<iframe id="provisionFrame" width="95%" height="90%" src="' + url + '"></iframe>');
 | 
						|
    deployDia.dialog({
 | 
						|
        modal: true,
 | 
						|
        width: 600,
 | 
						|
        height: 480,
 | 
						|
        title:'Provision return',
 | 
						|
        close: function(){$(this).remove();},
 | 
						|
        buttons: {
 | 
						|
            Close : function(){$(this).dialog('close');}
 | 
						|
        }
 | 
						|
    });
 | 
						|
 | 
						|
    provisionStopCheck();
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Create provisioning advance option
 | 
						|
 * 
 | 
						|
 * @param imagename
 | 
						|
 * 			Image name
 | 
						|
 * @param plugin
 | 
						|
 * 			Plugin name of platform to provision
 | 
						|
 * @return Nothing
 | 
						|
 */
 | 
						|
function provAdvOption(imagename, plugin) {
 | 
						|
    $.ajax({
 | 
						|
        url : 'lib/cmd.php',
 | 
						|
        dataType : 'json',
 | 
						|
        data : {
 | 
						|
            cmd : 'lsdef',
 | 
						|
            tgt : '',
 | 
						|
            args : '-t;osimage;' + imagename + ';-i;osname,provmethod',
 | 
						|
            msg : plugin
 | 
						|
        },
 | 
						|
 | 
						|
        success : function(data) {
 | 
						|
            var containerId = data.msg + 'ProvisionTab';
 | 
						|
            var i = 0;
 | 
						|
            var osName = '';
 | 
						|
            var provMethod = '';
 | 
						|
            var tempStr = '';
 | 
						|
            var position = 0;
 | 
						|
            for (i = 0; i < data.rsp.length; i++) {
 | 
						|
                tempStr = data.rsp[i];
 | 
						|
                if (tempStr.indexOf('osname') != -1) {
 | 
						|
                    position = tempStr.indexOf('=');
 | 
						|
                    osName = tempStr.substr(position + 1);
 | 
						|
                }
 | 
						|
                
 | 
						|
                if (tempStr.indexOf('provmethod') != -1) {
 | 
						|
                    position = tempStr.indexOf('=');
 | 
						|
                    provMethod = tempStr.substr(position + 1);
 | 
						|
                }
 | 
						|
            }
 | 
						|
            
 | 
						|
            $('#' + containerId + ' #advoption').empty();
 | 
						|
            if ('aix' == osName.toLowerCase()) {
 | 
						|
                return;
 | 
						|
            }
 | 
						|
            
 | 
						|
            if ('install' == provMethod){
 | 
						|
                $('#' + containerId + ' #advoption').html('<input type="checkbox" checked="checked" name="ganglia">Install Ganglia.');
 | 
						|
            }
 | 
						|
        }
 | 
						|
    });
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Refresh nodes area base on group selected
 | 
						|
 * 
 | 
						|
 * @param groupName
 | 
						|
 * 			Group name
 | 
						|
 * @param areaId
 | 
						|
 * 			Area ID to refresh
 | 
						|
 * @return Nothing
 | 
						|
 */
 | 
						|
function createNodesArea(groupName, areaId) {
 | 
						|
    // Get group nodes
 | 
						|
    $.ajax({
 | 
						|
        url : 'lib/cmd.php',
 | 
						|
        dataType : 'json',
 | 
						|
        data : {
 | 
						|
            cmd : 'nodels',
 | 
						|
            tgt : groupName,
 | 
						|
            args : '',
 | 
						|
            msg : areaId
 | 
						|
        },
 | 
						|
 | 
						|
        success : function(data) {
 | 
						|
            var areaObj = $('#' + data.msg);
 | 
						|
            var nodes = data.rsp;
 | 
						|
            var index;
 | 
						|
            var nodesHtml = '<table><thead><tr><th><input type="checkbox" onclick="selectAllCheckbox(event, $(this))"></th>';
 | 
						|
            nodesHtml += '<th>Node</th></tr></thead><tbody>';
 | 
						|
            for (index in nodes) {
 | 
						|
                var node = nodes[index][0];
 | 
						|
                if (!node) {
 | 
						|
                    continue;
 | 
						|
                }
 | 
						|
                nodesHtml += '<tr><td><input type="checkbox" name="' + node + '"/></td><td>' + node + '</td></tr>';
 | 
						|
            }
 | 
						|
            nodesHtml += '</tbody></table>';
 | 
						|
            
 | 
						|
            areaObj.empty().append(nodesHtml);
 | 
						|
            if (index > 10) {
 | 
						|
                areaObj.css('height', '300px');
 | 
						|
            } else {
 | 
						|
                areaObj.css('height', 'auto');
 | 
						|
            }
 | 
						|
        } // End of function(data)
 | 
						|
    });
 | 
						|
}
 | 
						|
 | 
						|
function provisionStopCheck(){
 | 
						|
    var content = $('#provisionFrame').contents().find('body').text();
 | 
						|
    if (content.indexOf('provision stop') != -1) {
 | 
						|
        $('#deployDia img').remove();
 | 
						|
        clearTimeout(provisionClock);
 | 
						|
    } else {
 | 
						|
        provisionClock = setTimeout('provisionStopCheck()', 5000);
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Get select element names
 | 
						|
 * 
 | 
						|
 * @param obj
 | 
						|
 * 			Object to get selected element names
 | 
						|
 * @return Nodes name seperate by a comma
 | 
						|
 */
 | 
						|
function getCheckedByObj(obj) {
 | 
						|
    var str = '';
 | 
						|
    
 | 
						|
    // Get nodes that were checked
 | 
						|
    obj.find('input:checked').each(function() {
 | 
						|
        if ($(this).attr('name')) {
 | 
						|
            str += $(this).attr('name') + ',';
 | 
						|
        }
 | 
						|
    });
 | 
						|
 | 
						|
    if (str) {
 | 
						|
        str = str.substr(0, str.length - 1);
 | 
						|
    }
 | 
						|
 | 
						|
    return str;
 | 
						|
} |