Project

General

Profile

Download (15.1 KB) Statistics
| Branch: | Tag: | Revision:
function computeResourceSelected(item){
var compute = $(item).val();
var attrs = attribute_hash(['architecture_id', 'compute_resource_id', 'operatingsystem_id']);
var label = $(item).children(":selected").text();
if(compute=='') { //Bare Metal
$('#mac_address').show();
$('#bmc').show();
$("#model_name").show();
$('#compute_resource').empty();
$('#vm_details').empty();
$("#compute_resource_tab").hide();
update_capabilities('build');
}
else
{
$('#mac_address').hide();
$('#bmc').hide();
$("#model_name").hide();
$("#compute_resource_tab").show();
$('#vm_details').empty();
var url = $(item).attr('data-url');
$.ajax({
type:'post',
url: url,
data: attrs,
success: function(result){
$('#compute_resource').html(result);
update_capabilities($('#capabilities').val());
}
})
}
}


function update_capabilities(capabilities){
var build = (/build/i.test(capabilities));
var image = (/image/i.test(capabilities));
if (build){
$('#manage_network').show();
$('#host_provision_method_build').click();
} else {
$('#manage_network').hide();
$('#host_provision_method_image').click();
}
if(build && image){
$('#provisioning_method').show();
}else{
$('#provisioning_method').hide();
}
$('#image_provisioning').empty();
$('#image_selection').appendTo($('#image_provisioning'));
update_provisioning_image();
}

var stop_pooling;

function submit_host(form){
var url = window.location.pathname.replace(/\/edit$|\/new$/,'');
if(/\/clone$/.test(window.location.pathname)){ url = '/hosts'; }
$('#host_submit').attr('disabled', true);
stop_pooling = false;
$("body").css("cursor", "progress");
clear_errors();
animate_progress();

$.ajax({
type:'POST',
url: url,
data: form.serialize(),
success: function(response){
if(response.redirect){
window.location.replace(response.redirect);
}
else{
$("#host-progress").hide();
$('#content').replaceWith($("#content", response));
onContentLoad();
onHostEditLoad();
}
},
error: function(response){
$('#content').html(response.responseText);
},
complete: function(){
stop_pooling = true;
$("body").css("cursor", "auto");
$('#host_submit').attr('disabled', false);
}
});
return false;
}

function clear_errors(){
$('.error').children().children('.help-inline').remove();
$('.error').removeClass('error');
$('.tab-error').removeClass('tab-error');
$('.alert-error').remove();
}

function animate_progress(){
if (stop_pooling == true) return;
setTimeout(function() {
var task_id = $('#host_progress_report_id').val();
$.get('/tasks/' + task_id, function (response){
update_progress(response);
animate_progress();
})
}, 1600);
}

function update_progress(data){
var task_list_size = $('p',data).size();
if (task_list_size == 0 || stop_pooling == true) return;

var done_tasks = $('.icon-check',data).size();
var failed_tasks = $('.icon-remove',data).size();
var $progress = $('.progress');

$("#host-progress").show();
if(failed_tasks > 0) {
$progress.removeClass('progress-success').addClass('progress-danger');
}else{
$progress.removeClass('progress-danger').addClass('progress-success');
}
$('.bar').width(done_tasks/task_list_size *$progress.width());
$('#tasks_progress').replaceWith(data);
}

function filter_puppet_classes(item){
var term = $(item).val().trim();
$('.puppetclass_group li.puppetclass.hide').addClass('hide-me');
if (term.length > 0) {
$('.puppetclass_group li.puppetclass').removeClass('filter-marker').hide();
$('.puppetclass_group li.puppetclass:not(.hide-me, .selected-marker) span:contains('+term+')').parent('li').addClass('filter-marker').show();
} else{
$('.puppetclass_group li.puppetclass:not(.hide-me, .selected-marker)').addClass('filter-marker').show();
}
var groups = $('li.filter-marker').closest('.puppetclass_group');
$('.puppetclass_group').hide();
groups.show();
}


function add_puppet_class(item){
var id = $(item).attr('data-class-id');
var type = $(item).attr('data-type');
var content = $(item).parent().clone();
content.attr('id', 'selected_puppetclass_'+ id);
content.append("<input id='" + type +"_puppetclass_ids_' name='" + type +"[puppetclass_ids][]' type='hidden' value=" +id+ ">");
content.children('span').tooltip();

var link = content.children('a');
link.attr('onclick', 'remove_puppet_class(this)');
link.attr('data-original-title', 'Click to undo adding this class');
link.removeClass('ui-icon-plus').addClass('ui-icon-minus').tooltip();

$('#selected_classes').append(content);

$("#selected_puppetclass_"+ id).show('highlight', 5000);
$("#puppetclass_"+ id).addClass('selected-marker').hide();

load_puppet_class_parameters(link);
}

function remove_puppet_class(item){
var id = $(item).attr('data-class-id');
$('#puppetclass_' + id).removeClass('selected-marker').show();
$('#puppetclass_' + id).closest('.puppetclass_group').show();
$('#selected_puppetclass_' + id).children('a').tooltip('hide');
$('#selected_puppetclass_' + id).remove();
$('#puppetclass_' + id + '_params_loading').remove();
$('[id^="puppetclass_' + id + '_params\\["]').remove();
$('#params-tab').removeClass("tab-error");
if ($("#params").find('.control-group.error').length > 0) $('#params-tab').addClass('tab-error');

return false;
}

function load_puppet_class_parameters(item) {
var id = $(item).attr('data-class-id');
if ($('#puppetclass_' + id + '_params_loading').length > 0) return; // already loading
if ($('[id^="#puppetclass_' + id + '_params\\["]').length > 0) return; // already loaded

var url = $(item).attr('data-url');
var data = $("form").serialize();

if (url == undefined) return; // no parameters
var placeholder = $('<tr id="puppetclass_'+id+'_params_loading">'+
'<td colspan="5"><p><img src="/images/spinner.gif" alt="Wait" /> Loading parameters...</p></td>'+'</tr>');
$('#inherited_puppetclasses_parameters').append(placeholder);
$.ajax({
url: url,
data: data,
success: function(result, textstatus, xhr) {
var params = $(result);
placeholder.replaceWith(params);
params.find('a[rel="popover"]').popover();
if (params.find('.error').length > 0) $('#params-tab').addClass('tab-error');
}
});
}

function hostgroup_changed(element) {
var host_id = $(element).attr('data-host-id');
var url = $(element).attr('data-url');
var attrs = attribute_hash(['hostgroup_id', 'compute_resource_id', 'organization_id', 'location_id']);
if (attrs["hostgroup_id"] == undefined) attrs["hostgroup_id"] = $('#hostgroup_parent_id').attr('value');
$('#hostgroup_indicator').show();
if (!host_id){ // a new host
$.ajax({
type:'post',
url: url,
data:attrs,
complete: function(){
$('#hostgroup_indicator').hide();
$('[rel="twipsy"]').tooltip();
update_provisioning_image();
reload_params();
}
})
} else { // edit host
update_puppetclasses(element);
}
}

function organization_changed(element) {
var url = $(element).attr('data-url');
var data = $('form').serialize().replace('method=put', 'method=post');
$('#organization_indicator').show();
$.ajax({
type: 'post',
url: url,
data: data,
success: function(response) {
$('#organization_indicator').hide();
$('form').html(response);
onContentLoad();
},
complete: function(){
$('#organization_indicator').hide();
$('[rel="twipsy"]').tooltip();
}
})
}

function location_changed(element) {
var url = $(element).attr('data-url');
var data = $('form').serialize().replace('method=put', 'method=post');
$('#location_indicator').show();
$.ajax({
type: 'post',
url: url,
data: data,
success: function(response) {
$('#location_indicator').hide();
$('form').html(response);
onContentLoad();
},
complete: function(){
$('#location_indicator').hide();
$('[rel="twipsy"]').tooltip();
}
})
}

function subnet_selected(element){
var subnet_id = $(element).val();
if (subnet_id == '' || $('#host_ip').size() == 0) return;
// We do not query the proxy if the host_ip field is filled in and contains an
// IP that is in the selected subnet
var drop_text = $(element).children(":selected").text();
if (drop_text.length !=0 && drop_text.search(/^.+ \([0-9\.\/]+\)/) != -1) {
var details = drop_text.replace(/^[^(]+\(/, "").replace(")","").split("/");
if (subnet_contains(details[0], details[1], $('#host_ip').val()))
return;
}
var attrs = attribute_hash(["subnet_id", "host_mac", 'organization_id', 'location_id']);
$('#subnet_indicator').show();
$.ajax({
data: attrs,
type:'post',
url:'/subnets/freeip',
complete: function(){$('#subnet_indicator').hide()}
})
}

function subnet_contains(number, cidr, ip){
var int_ip = _to_int(ip);
var int_number = _to_int(number);
var shift = 32 - parseInt(cidr);
return (int_ip >> shift == int_number >> shift);
}

function _to_int(str){
var nibble = str.split(".");
var integer = 0;
for(var i=0;i<=3;i++){
integer = (integer * 256) + parseInt(nibble[i]);
}
return integer;
}

function domain_selected(element){
var attrs = attribute_hash(['domain_id', 'organization_id', 'location_id']);
var url = $(element).attr('data-url');
$.ajax({
data: attrs,
type:'post',
url: url,
success: function(request) {
$('#subnet_select').html(request);
reload_params();
}
})
}

function architecture_selected(element){
var attrs = attribute_hash(['architecture_id', 'organization_id', 'location_id']);
var url = $(element).attr('data-url');
$.ajax({
data: attrs,
type:'post',
url: url,
success: function(request) {
$('#os_select').html(request);
}
})
}

function os_selected(element){
var attrs = attribute_hash(['operatingsystem_id', 'organization_id', 'location_id']);
var os_id = $(element).val();
var url = $(element).attr('data-url');
$.ajax({
data: attrs,
type:'post',
url: url,
success: function(request) {
$('#media_select').html(request);
reload_params();
}
});
update_provisioning_image();
}
function update_provisioning_image(){
var compute_id = $('[id$="_compute_resource_id"]').val();
var arch_id = $('[id$="_architecture_id"]').val();
var os_id = $('[id$="_operatingsystem_id"]').val();
if((compute_id == undefined) || (compute_id == "") || (arch_id == "") || (os_id == "")) return;
var term = 'operatingsystem=' + os_id + ' architecture=' + arch_id;
var image_options = $("[id$=compute_attributes_image_id]").empty();
$.ajax({
data:'search=' + encodeURIComponent(term),
type:'get',
url:'/compute_resources/'+compute_id+'/images',
dataType: 'json',
success: function(result) {
$.each(result, function() {
image_options.append($("<option />").val(this.image.uuid).text(this.image.name));
});
if (image_options.find('option').length > 0)
image_options.attr('disabled', false);
}
})
}

function medium_selected(element){
var url = $(element).attr('data-url');
var type = $(element).attr('data-type');
var obj = (type == "hosts" ? "host" : "hostgroup");
var attrs = {};
attrs[obj] = attribute_hash(['medium_id', 'operatingsystem_id', 'architecture_id']);
attrs[obj]["use_image"] = $('*[id*=use_image]').attr('checked') == "checked";
$.ajax({
data: attrs,
type:'post',
url: url,
success: function(request) {
$('#image_details').html(request);
}
})
}

function use_image_selected(element){
var url = $(element).attr('data-url');
var type = $(element).attr('data-type');
var obj = (type == "hosts" ? "host" : "hostgroup");
var attrs = {};
attrs[obj] = attribute_hash(['medium_id', 'operatingsystem_id', 'architecture_id', 'model_id']);
attrs[obj]['use_image'] = ($(element).attr('checked') == "checked");
$.ajax({
data: attrs,
type: 'post',
url: url,
success: function(response) {
var field = $('*[id*=image_file]');
if (attrs[obj]["use_image"]) {
if (field.val() == "") field.val(response["image_file"]);
} else
field.val("");

field.attr("disabled", !attrs[obj]["use_image"]);
}
});
}

function override_param(item){
var param = $(item).closest('tr');
var n = param.find('[id^=name_]').text();
var v = param.find('[id^=value_]').val();

$('#parameters').find('.btn-success').click();
var new_param = param.closest('.tab-pane').find('[id*=host_host_parameters]:visible').last().parent();
new_param.find('[id$=_name]').val(n);
new_param.find('[id$=_value]').val(v);
mark_params_override();
}

function override_class_param(item){
var param = $(item).closest('tr[id^="puppetclass_"][id*="_params\\["][id$="\\]"]');
var id = param.attr('id').replace(/puppetclass_\d+_params\[(\d+)\]/, '$1')
var c = param.find('[data-property=class]').text();
var n = param.find('[data-property=name]').text();
var v = param.find('[data-property=value]').val();
var t = param.find('[data-property=type]').text();

$('#puppetclasses_parameters').find('.btn-success').click();
var new_param = param.closest('.tab-pane').find('[id*=host_lookup_values]:visible').last().parent();
new_param.find('[data-property=lookup_key_id]').val(id);
new_param.find('[data-property=class]').val(c);
new_param.find('[data-property=name]').val(n);
new_param.find('[data-property=value]').val(v);
new_param.find('[data-property=type]').val(t);
mark_params_override();
}

function reload_params(){
var url = $('#params-tab').attr('data-url');
var data = $("[data-submit='progress_bar']").serialize();
load_with_placeholder('inherited_parameters', url, data)

var url2 = $('#params-tab').attr('data-url2');
load_with_placeholder('inherited_puppetclasses_parameters', url2, data)
}

function load_with_placeholder(target, url, data){
var placeholder = $('<tr id="' + target + '_loading" >'+
'<td colspan="4"><p><img src="/images/spinner.gif" alt="Wait" /> Loading parameters...</p></td></tr>');
$('#' + target + ' tbody').replaceWith(placeholder);
$.ajax({
url: url,
data: data,
success:
function(result, textstatus, xhr) {
placeholder.closest('#' + target ).replaceWith($(result));
mark_params_override()
}
});
}

$(function () {
onHostEditLoad();
});

function onHostEditLoad(){
$("#host-conflicts-modal").modal({show: "true", backdrop: "static"});
$('#host-conflicts-modal').click(function(){
$('#host-conflicts-modal').modal('hide');
});
var $form = $("[data-submit='progress_bar']");
$form.on('submit', function(){
submit_host($form);
return false;
});

$('#host_provision_method_build').on('click', function(){
$('#network_provisioning').show();
$('#image_provisioning').hide();
});
$('#host_provision_method_image').on('click', function(){
$('#network_provisioning').hide();
$('#image_provisioning').show();
});

$('#image_selection').appendTo($('#image_provisioning'));
$('#params-tab').on('shown', function(){mark_params_override()});
}
(17-17/28)