Newer
Older
function render_host_link(data) {
// render funtion to create link to Host view page
if ( data === null ) {
return data;
}
var url = $SCRIPT_ROOT + "/network/hosts/view/" + data;
return '<a href="'+ url + '">' + data + '</a>';
}
if( $("#hostForm").length || $("#editHostForm").length ) {
var hostVarsEditor = CodeMirror.fromTextArea(ansible_vars, {
lineNumbers: true,
mode: "yaml"
});
hostVarsEditor.setSize(null, 120);
var handle = cmResize(hostVarsEditor, {
minHeight: 120,
resizableWidth: false,
resizableHeight: true,
});
function set_default_ip() {
// Retrieve the first available IP for the selected network
// and update the IP field
var network_id = $("#network_id").val();
$.getJSON(
$SCRIPT_ROOT + "/network/_retrieve_first_available_ip/" + network_id,
$("#ip").val(json.data);
// Select the IOC tag by default depending on the device type
function update_default_tags(device_type) {
var ioc_device_types = ["PhysicalMachine", "VirtualMachine", "MicroTCA", "VME"];
var is_ioc_selected = $.inArray(device_type, ioc_device_types) > -1;
$("#tags option").filter(function() {
return this.text == "IOC";
}).prop("selected", is_ioc_selected).change();
}
// And check / uncheck random_mac checkbox
// and update default tags
function update_device_type_attributes() {
var device_type = $("#device_type_id option:selected").text();
if( device_type.startsWith("Virtual") ) {
$("#random_mac").prop("checked", true).change();
} else {
$("#random_mac").prop("checked", false).change();
update_default_tags(device_type);
// If random_mac is checked, generate a random address
// Empty the field otherwise
function fill_mac_address() {
if( $("#random_mac").prop("checked") ) {
$.getJSON(
$SCRIPT_ROOT + "/network/_generate_random_mac",
function(json) {
$("#mac_address").val(json.data.mac);
$("#mac_address").prop("readonly", true);
}
);
} else {
$("#mac_address").val("");
$("#mac_address").prop("readonly", false);
}
}
// Set the default IP on first page load for:
// - register new host
// - add interface
// Do NOT replace the IP on edit interface page load!
// (we have to keep the existing IP)
// Do NOT replace the IP if the form was submitted and an error was raised
// (we should display the same value that was submitted)
if( ($("#hostForm").length || $("#interfaceForm").length) && ! $("input").hasClass("is-invalid") ) {
// Set the default IP when changing network
$("#network_id").on('change', function() {
// On register host first page load
if( $("#hostForm").length ) {
$("#device_type_id").on('change', function() {
update_device_type_attributes();
// The interface name field is hidden in the create host form
// because it should be forced to the hostname
// Do that when submitting the form
$("#hostForm").submit(function(event) {
var hostname = $("#name").val();
$("#interface_name").val(hostname);
});
// Fill MAC address on page load
if( $("#random_mac").length ) {
fill_mac_address();
}
// Fill or clear MAC address depending on random_mac checkbox
$("#random_mac").on('change', function() {
fill_mac_address();
});
// Force the first interface to have the hostname as name
// This only applies to the hostForm (not when editing or adding interfaces)
$("#hostForm input[name=interface_name]").prop("readonly", true);
var hosts_table = $("#hosts_table").DataTable({
dom: "<'row'<'col-sm-12 col-md-6'l><'col-sm-12 col-md-3 text-right'><'col-sm-12 col-md-3'f>>" +
"<'row'<'col-sm-12'tr>>" +
"<'row'<'col-sm-12 col-md-5'i><'col-sm-12 col-md-7'p>>",
"ajax": {
"url": $SCRIPT_ROOT + "/network/_retrieve_hosts",
"type": "POST"
"processing": true,
"serverSide": true,
"searchDelay": 500,
"orderMulti": false,
"aaSorting": [],
"pagingType": "full_numbers",
"pageLength": 20,
"lengthMenu": [[20, 50, 100], [20, 50, 100]],
"columns": [
{ data: 'name',
render: function(data, type, row) {
return render_host_link(data);
},
{ data: 'device_type' },
{ data: 'description',
orderable: false },
{ data: 'interfaces.0.ip',
defaultContent: "",
orderable: false },
{ data: 'interfaces.0.network',
defaultContent: "",
orderable: false }
if( $("#hosts_table").length ) {
new $.fn.dataTable.Buttons(hosts_table, {
buttons: [
{
text: 'Reset',
className: "btn-outline-secondary",
action: function ( e, dt, node, conf ) {
dt.state.clear();
dt.search('').order([]).draw();
}
}
]
});
hosts_table.buttons().container().appendTo("#hosts_table_wrapper .col-md-3:eq(0)");
}