1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-12 09:17:41 +03:00

Merge branch 'master' of git.opennebula.org:one

This commit is contained in:
Ruben S. Montero 2014-02-07 19:20:39 +01:00
commit 85db3f0c21
6 changed files with 277 additions and 103 deletions

View File

@ -99,9 +99,8 @@ module OpenNebulaJSON
super(params['hard']) super(params['hard'])
end end
def migrate(params=Hash.new, live=false, enforce=false) def migrate(params=Hash.new, live=false)
# TODO add enforce parameter super(params['host_id'], live, params['enforce'])
super(params['host_id'], live)
end end
def save_as(params=Hash.new) def save_as(params=Hash.new)

View File

@ -709,12 +709,12 @@ var OpenNebula = {
"deploy",action_obj); "deploy",action_obj);
}, },
"livemigrate": function(params){ "livemigrate": function(params){
var action_obj = {"host_id": params.data.extra_param}; var action_obj = params.data.extra_param;
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource, OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
"livemigrate",action_obj); "livemigrate",action_obj);
}, },
"migrate": function(params){ "migrate": function(params){
var action_obj = {"host_id": params.data.extra_param}; var action_obj = params.data.extra_param;
OpenNebula.Action.simple_action(params,OpenNebula.VM.resource, OpenNebula.Action.simple_action(params,OpenNebula.VM.resource,
"migrate",action_obj); "migrate",action_obj);
}, },

View File

@ -213,6 +213,17 @@ var settings_update_password = '<div class="panel">\
<div class=""></div>\ <div class=""></div>\
</div>\ </div>\
</div>\ </div>\
<div class="row centered">\
<div class="four columns">\
<label class="inline right" for="confirm_password">'+tr("Confirm Password")+':</label>\
</div>\
<div class="seven columns">\
<input type="password" name="confirm_password" id="confirm_password" />\
</div>\
<div class="one columns">\
<div class=""></div>\
</div>\
</div>\
<hr>\ <hr>\
<div class="form_buttons">\ <div class="form_buttons">\
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\ <button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
@ -256,12 +267,18 @@ function setupUpdatePassword() {
$('#settings_update_password_form',dialog).submit(function(){ $('#settings_update_password_form',dialog).submit(function(){
var pw=$('#new_password',this).val(); var pw=$('#new_password',this).val();
var confirm_password=$('#confirm_password',this).val();
if (!pw.length){ if (!pw.length){
notifyError(tr("Fill in a new password")); notifyError(tr("Fill in a new password"));
return false; return false;
} }
if (pw !== confirm_password){
notifyError(tr("Password does not match"));
return false;
}
Sunstone.runAction("UserSettings.passwd",[-1],pw); Sunstone.runAction("UserSettings.passwd",[-1],pw);
$('#settings_update_password',dialogs_context).trigger("reveal:close") $('#settings_update_password',dialogs_context).trigger("reveal:close")
return false; return false;

View File

@ -172,6 +172,17 @@ var update_pw_tmpl = '<div class="panel">\
<div class=""></div>\ <div class=""></div>\
</div>\ </div>\
</div>\ </div>\
<div class="row centered">\
<div class="four columns">\
<label class="inline right" for="confirm_password">'+tr("Confirm Password")+':</label>\
</div>\
<div class="seven columns">\
<input type="password" name="confirm_password" id="confirm_password" />\
</div>\
<div class="one columns">\
<div class=""></div>\
</div>\
</div>\
<hr>\ <hr>\
<div class="form_buttons">\ <div class="form_buttons">\
<button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\ <button class="button radius right success" id="update_pw_submit" type="submit" value="User.update">'+tr("Change")+'</button>\
@ -870,12 +881,18 @@ function setupUpdatePasswordDialog(){
$('#update_user_pw_form',dialog).submit(function(){ $('#update_user_pw_form',dialog).submit(function(){
var pw=$('#new_password',this).val(); var pw=$('#new_password',this).val();
var confirm_password=$('#confirm_password',this).val();
if (!pw.length){ if (!pw.length){
notifyError(tr("Fill in a new password")); notifyError(tr("Fill in a new password"));
return false; return false;
} }
if (pw !== confirm_password){
notifyError(tr("Password does not match"));
return false;
}
Sunstone.runAction("User.passwd",getSelectedNodes(dataTable_users),pw); Sunstone.runAction("User.passwd",getSelectedNodes(dataTable_users),pw);
$update_pw_dialog.trigger("reveal:close") $update_pw_dialog.trigger("reveal:close")
return false; return false;

View File

@ -389,10 +389,103 @@ var deploy_vm_tmpl ='\
</form>\ </form>\
</div>'; </div>';
var migrate_vm_tmpl ='\
<div class="panel">\
<h3>\
<small id="migrate_vm_header">'+tr("Migrate Virtual Machine")+'</small>\
</h3>\
</div>\
<div class="reveal-body">\
<form id="migrate_vm_form" action="">\
<div id="current_hosts_of_vms" class="row">\
</div>\
<br><br>\
<div class="row">\
<fieldset>\
<legend>'+tr("Select a Host")+'</legend>\
<div class="row collapse">\
<div class="seven columns">\
<button id="refresh_migrate_hosts_table_button_class" type="button" class="button small radius secondary"><i class="icon-refresh" /></button>\
</div>\
<div class="five columns">\
<input id="migrate_hosts_table_search" type="text" placeholder="'+tr("Search")+'"/>\
</div>\
</div>\
<table id="migrate_datatable_hosts" class="datatable twelve">\
<thead>\
<tr>\
<th></th>\
<th>' + tr("ID") + '</th>\
<th>' + tr("Name") + '</th>\
<th>' + tr("Cluster") + '</th>\
<th>' + tr("RVMs") + '</th>\
<th>' + tr("Real CPU") + '</th>\
<th>' + tr("Allocated CPU") + '</th>\
<th>' + tr("Real MEM") + '</th>\
<th>' + tr("Allocated MEM") + '</th>\
<th>' + tr("Status") + '</th>\
<th>' + tr("IM MAD") + '</th>\
<th>' + tr("VM MAD") + '</th>\
<th>' + tr("Last monitored on") + '</th>\
</tr>\
</thead>\
<tbody id="tbodyhosts">\
</tbody>\
</table>\
<div class="row hidden">\
<div class="four columns">\
<label class="right inline" for="HOST_ID">'+tr("HOST_ID")+':</label>\
</div>\
<div class="six columns">\
<input type="text" id="HOST_ID" name="HOST_ID"/>\
</div>\
<div class="two columns">\
<div class="tip">\
</div>\
</div>\
</div>\
<br>\
<div id="selected_host" class="vm_param kvm_opt xen_opt vmware_opt">\
<span id="select_host" class="radius secondary label">'+tr("Please select a Host from the list")+'</span>\
<span id="host_selected" class="radius secondary label hidden">'+tr("You selected the following Host:")+'</span>\
<span class="radius label" type="text" id="HOST_NAME" name="host"></span>\
</div>\
</fieldset>\
</div>\
<br>\
<br>\
<div class="show_hide" id="advanced_toggle">\
<h4><small><i class=" icon-caret-down"/> '+tr("Advanced options")+'<a id="" class="icon_left" href="#"></a></small></h4>\
</div>\
<div id="advanced_migrate" class="row advanced">\
<div class="row">\
<div class="three columns">\
<label class="inline right" for="vm_id">'+tr("Enforce")+':</label>\
</div>\
<div class="two columns">\
<input type="checkbox" name="enforce" id="enforce"/>\
</div>\
<div class="one columns pull-seven tip">'
+ tr("If it is set to true, the host capacity will be checked. This will only affect oneadmin requests, regular users resize requests will always be enforced") +
'</div>\
</div>\
</div>\
<div class="form_buttons reveal-footer">\
<hr>\
<div class="form_buttons">\
<button class="button radius right success" id="migrate_vm_proceed" value="VM.migrate">'+tr("Migrate")+'</button>\
<button class="close-reveal-modal button secondary radius" type="button" value="close">' + tr("Close") + '</button>\
</div>\
</div>\
<a class="close-reveal-modal">&#215;</a>\
</form>\
</div>';
var vmachine_list_json = {}; var vmachine_list_json = {};
var dataTable_vMachines; var dataTable_vMachines;
var $create_vm_dialog; var $create_vm_dialog;
var $deploy_vm_dialog; var $deploy_vm_dialog;
var $migrate_vm_dialog;
var $vnc_dialog; var $vnc_dialog;
var rfb; var rfb;
@ -472,19 +565,31 @@ var vm_actions = {
}, },
"VM.migrate" : { "VM.migrate" : {
type: "multiple", type: "custom",
call: function(){
popUpMigrateVMDialog(false);
}
},
"VM.migrate_action" : {
type: "single",
call: OpenNebula.VM.migrate, call: OpenNebula.VM.migrate,
callback: vmShow, callback: vmShow,
elements: function() { return getSelectedNodes(dataTable_vMachines); },
error: onError, error: onError,
notify: true notify: true
}, },
"VM.migrate_live" : { "VM.migrate_live" : {
type: "multiple", type: "custom",
call: function(){
popUpMigrateVMDialog(true);
}
},
"VM.migrate_live_action" : {
type: "single",
call: OpenNebula.VM.livemigrate, call: OpenNebula.VM.livemigrate,
callback: vmShow, callback: vmShow,
elements: vmElements,
error: onError, error: onError,
notify: true notify: true
}, },
@ -953,20 +1058,18 @@ var vm_buttons = {
condition: mustBeAdmin condition: mustBeAdmin
}, },
"VM.migrate" : { "VM.migrate" : {
type: "confirm_with_select", type: "action",
text: tr("Migrate"), text: tr("Migrate"),
tip: tr("This will migrate the selected VMs to the chosen host"), tip: tr("This will migrate the selected VMs to the chosen host"),
layout: "vmsplanification_buttons", layout: "vmsplanification_buttons",
select: hosts_sel,
condition: mustBeAdmin condition: mustBeAdmin
}, },
"VM.migrate_live" : { "VM.migrate_live" : {
type: "confirm_with_select", type: "action",
text: tr("Migrate") + ' <span class="label secondary radius">live</span>', text: tr("Migrate") + ' <span class="label secondary radius">live</span>',
tip: tr("This will live-migrate the selected VMs to the chosen host"), tip: tr("This will live-migrate the selected VMs to the chosen host"),
layout: "vmsplanification_buttons", layout: "vmsplanification_buttons",
select: hosts_sel,
condition: mustBeAdmin condition: mustBeAdmin
}, },
"VM.hold" : { "VM.hold" : {
@ -3354,6 +3457,107 @@ function setupDeployVMDialog(){
}); });
} }
function setupMigrateVMDialog(live){
dialogs_context.append('<div id="migrate_vm_dialog"></div>');
//Insert HTML in place
$migrate_vm_dialog = $('#migrate_vm_dialog')
var dialog = $migrate_vm_dialog;
dialog.html(migrate_vm_tmpl);
dialog.addClass("reveal-modal large max-height");
var dataTable_migrate_hosts = $('#migrate_datatable_hosts', dialog).dataTable({
"iDisplayLength": 4,
"bAutoWidth":false,
"sDom" : '<"H">t<"F"p>',
"aoColumnDefs": [
{ "bSortable": false, "aTargets": ["check",5,6,7,8] },
{ "sWidth": "35px", "aTargets": [0] }, //check, ID, RVMS, Status,
{ "bVisible": false, "aTargets": [3,5,7,10,11,12]}
],
"fnDrawCallback": function(oSettings) {
var nodes = this.fnGetNodes();
$.each(nodes, function(){
if ($(this).find("td:eq(0)").html() == $('#HOST_ID', dialog).val()) {
$("td", this).addClass('markrow');
$('input.check_item', this).attr('checked','checked');
}
})
}
});
$('tbody input.check_item:checked',dataTable_vMachines).each(function(){
var data = dataTable_vMachines.fnGetData( $(this).closest('tr')[0] );
$("#current_hosts_of_vms").append('<span class="radius secondary label">'+tr("VM")+' ['+$(this).val() + '] ' + tr("is currently running on Host") + ' [' + data[8] + ']</span><br>')
});
// Retrieve the images to fill the datatable
update_datatable_template_hosts(dataTable_migrate_hosts);
$('#migrate_hosts_table_search', dialog).keyup(function(){
dataTable_migrate_hosts.fnFilter( $(this).val() );
})
$('#migrate_datatable_hosts tbody', dialog).delegate("tr", "click", function(e){
var aData = dataTable_migrate_hosts.fnGetData(this);
$("td.markrow", dataTable_migrate_hosts).removeClass('markrow');
$('tbody input.check_item', dataTable_migrate_hosts).removeAttr('checked');
$('#host_selected', dialog).show();
$('#select_host', dialog).hide();
$('.alert-box', dialog).hide();
$("td", this).addClass('markrow');
$('input.check_item', this).attr('checked','checked');
$('#HOST_NAME', dialog).text(aData[2]);
$('#HOST_ID', dialog).val(aData[1]);
return true;
});
$("#refresh_migrate_hosts_table_button_class").die();
$("#refresh_migrate_hosts_table_button_class").live('click', function(){
update_datatable_template_hosts($('#migrate_datatable_hosts').dataTable());
});
$('#advanced_migrate', dialog).hide();
$('#advanced_toggle',dialog).click(function(){
$('#advanced_migrate',dialog).toggle();
return false;
});
setupTips(dialog);
$('#migrate_vm_form',dialog).submit(function(){
var extra_info = {};
if ($('#HOST_ID', dialog).val()) {
extra_info['host_id'] = $('#HOST_ID', dialog).val();
} else {
notifyError(tr("You have not selected a host"));
return false;
}
extra_info['enforce'] = $("#enforce", this).is(":checked") ? true : false
//notifySubmit("Template.instantiate",template_id, extra_msg);
$.each(getSelectedNodes(dataTable_vMachines), function(index, elem) {
console.log(elem)
if (live) {
console.log("live")
Sunstone.runAction("VM.migrate_live_action", elem, extra_info);
} else {
console.log("migrate")
Sunstone.runAction("VM.migrate_action", elem, extra_info);
}
});
$migrate_vm_dialog.trigger("reveal:close")
return false;
});
}
// Open creation dialog // Open creation dialog
function popUpDeployVMDialog(){ function popUpDeployVMDialog(){
setupDeployVMDialog(); setupDeployVMDialog();
@ -3361,6 +3565,11 @@ function popUpDeployVMDialog(){
} }
// Open creation dialog
function popUpMigrateVMDialog(live){
setupMigrateVMDialog(live);
$migrate_vm_dialog.reveal();
}
//Prepares autorefresh //Prepares autorefresh

View File

@ -867,70 +867,6 @@ function insertButtonsInTab(tab_name, panel_name, panel_buttons, custom_context)
//another containing a list of actions that can be folded/unfolded. //another containing a list of actions that can be folded/unfolded.
function initListButtons(){ function initListButtons(){
// //for each multi_action select
// $('.multi_action_slct',main_tabs_context).each(function(){
// //prepare replacement buttons
// var buttonset = $('<div style="display:inline-block;" class="top_button"></div');
// var button1 = $('<button class="last_action_button action_button confirm_button confirm_with_select_button" value="">'+tr("Previous action")+'</button>')//.button();
// button1.attr('disabled','disabled');
// var button2 = $('<button class="list_button" value="">See more</button>')
// //.button({
// // text:false,
// // icons: { primary: "ui-icon-triangle-1-s" }
// //});
// // buttonset.append(button1);
// // buttonset.append(button2);
// // buttonset.buttonset();
////
// //prepare list
// var options = $('option', $(this));
// var list = $('<ul class="action_list"></ul>');
// $.each(options,function(){
// var classes = $(this).attr('class');
// var item = $('<li></li>');
// var a = $('<a href="#" class="'+classes+'" value="'+$(this).val()+'">'+$(this).text()+'</a>');
// a.val($(this).val());
// item.html(a);
// list.append(item);
// });
// list.css({
// "display":"none"
// });
//
// $(this).before(buttonset);
// $(this).parents('.action_blocks').append(list);
// $(this).remove();
//
// });
//
// //below the listeners for events on these buttons and list
//
// //enable run the last action button
// //$('.action_list li a',main_tabs_context).click(function(){
// // //enable run last action button
// // var prev_action_button = $('.last_action_button',$(this).parents('.action_blocks'));
// // prev_action_button.val($(this).val());
// // prev_action_button.removeClass("confirm_with_select_button");
// // prev_action_button.removeClass("confirm_button");
// // prev_action_button.removeClass("action_button");
// // prev_action_button.addClass($(this).attr('class'));
// // prev_action_button.button("option","label",$(this).text());
// // prev_action_button.button("enable");
// // $(this).parents('ul').hide("blind",100);
// // //return false;
// //});
//
// //Show the list of actions in place
// $('.list_button',main_tabs_context).click(function(){
// $('.action_list',$(this).parents('.action_blocks')).css({
// "left": $(this).prev().position().left,
// "top": $(this).prev().position().top+13,
// "width": $(this).parent().outerWidth()-11
// });
// //100ms animation time
// $('.action_list',$(this).parents('.action_blocks')).toggle("blind",100);
// return false;
// });
} }
//Prepares the standard confirm dialogs //Prepares the standard confirm dialogs
@ -947,6 +883,11 @@ function setupConfirmDialogs(){
</div>\ </div>\
<form action="">\ <form action="">\
<div id="confirm_tip">'+tr("You have to confirm this action.")+'</div>\ <div id="confirm_tip">'+tr("You have to confirm this action.")+'</div>\
<br />\
<div class="row">\
<span id="confirm_action" class="radius secondary label"></span><br>\
<span id="confirm_ids" class="radius secondary label"></span><br><br>\
</div>\
<br />\ <br />\
<div id="question">'+tr("Do you want to proceed?")+'</div>\ <div id="question">'+tr("Do you want to proceed?")+'</div>\
<br />\ <br />\
@ -958,27 +899,14 @@ function setupConfirmDialogs(){
<a class="close-reveal-modal">&#215;</a>\ <a class="close-reveal-modal">&#215;</a>\
</form>'); </form>');
//prepare the jquery dialog
//dialog.dialog({
// resizable:false,
// modal:true,
// width:300,
// heigth:200,
// autoOpen:false
//});
dialog.addClass("reveal-modal"); dialog.addClass("reveal-modal");
//enhace the button look
//$('button',dialog).button();
dialogs_context.append('<div id="confirm_with_select_dialog" title=\"'+tr("Confirmation of action")+'\"></div>'); dialogs_context.append('<div id="confirm_with_select_dialog" title=\"'+tr("Confirmation of action")+'\"></div>');
dialog = $('div#confirm_with_select_dialog',dialogs_context); dialog = $('div#confirm_with_select_dialog',dialogs_context);
dialog.html( dialog.html(
'<div class="panel">\ '<div class="panel">\
<h3>\ <h3>\
<small>'+tr("Confirm")+'</small>\ <small>'+tr("Confirm")+'</small><br><br>\
</h3>\ </h3>\
</div>\ </div>\
<form action="">\ <form action="">\
@ -989,6 +917,9 @@ function setupConfirmDialogs(){
<select style="margin: 10px 0;" id="confirm_select">\ <select style="margin: 10px 0;" id="confirm_select">\
</select>\ </select>\
</div>\ </div>\
<div class="row">\
<span id="confirm_action" class="radius secondary label"></span><br>\
<span id="confirm_ids" class="radius secondary label"></span>\
</div>\ </div>\
<hr>\ <hr>\
<div class="form_buttons">\ <div class="form_buttons">\
@ -998,18 +929,8 @@ function setupConfirmDialogs(){
<a class="close-reveal-modal">&#215;</a>\ <a class="close-reveal-modal">&#215;</a>\
</form>'); </form>');
//prepare the jquery dialog
//dialog.dialog({
// resizable:false,
// modal:true,
// width:300,
// heigth:300,
// autoOpen:false
//});
dialog.addClass("reveal-modal") dialog.addClass("reveal-modal")
//$('button',dialog).button();
//when we proceed with a "confirm with select" we need to //when we proceed with a "confirm with select" we need to
//find out if we are running an action with a parametre on a datatable //find out if we are running an action with a parametre on a datatable
//items or if its just an action //items or if its just an action
@ -1063,6 +984,11 @@ function popUpConfirmDialog(target_elem){
$('button#confirm_proceed',dialog).val(value); $('button#confirm_proceed',dialog).val(value);
var action = SunstoneCfg["actions"][value];
if (action.elements()) {
$("#confirm_action").html(tr("Action: ") + value)
$("#confirm_ids").html(tr("Selected resources: ") + action.elements().join(', '))
}
$('div#confirm_tip',dialog).text(tip); $('div#confirm_tip',dialog).text(tip);
dialog.reveal(); dialog.reveal();
@ -1087,6 +1013,12 @@ function popUpConfirmWithSelectDialog(target_elem){
$('select#confirm_select',dialog).html(select_var); $('select#confirm_select',dialog).html(select_var);
$('div#confirm_with_select_tip',dialog).text(tip); $('div#confirm_with_select_tip',dialog).text(tip);
var action = SunstoneCfg["actions"][value];
if (action.elements()) {
$("#confirm_action").html(tr("Action: ") + value)
$("#confirm_ids").html(tr("Selected resources: ") + action.elements().join(', '))
}
$('button#confirm_with_select_proceed',dialog).val(value); $('button#confirm_with_select_proceed',dialog).val(value);
dialog.reveal(); dialog.reveal();
} }