2018-08-02 14:59:10 +02:00
|
|
|
(function () {
|
|
|
|
var numberOfPoints = 100;
|
2014-05-05 11:53:21 +02:00
|
|
|
var refresh = parseInt($('#refresh').val());
|
2018-08-02 14:59:10 +02:00
|
|
|
var incremental = $('#checkbox-incremental').is(':checked') || $('#hidden-incremental').val() == 1;
|
|
|
|
var lastIncVal = null;
|
|
|
|
var intervalRef = null;
|
|
|
|
var currentXHR = null;
|
|
|
|
|
|
|
|
var plot;
|
|
|
|
var plotOptions = {
|
|
|
|
legend: { container: $("#chartLegend") },
|
|
|
|
xaxis: {
|
|
|
|
tickFormatter: function (timestamp, axis) {
|
|
|
|
var date = new Date(timestamp * 1000);
|
|
|
|
|
|
|
|
var server_timezone_offset = get_php_value('timezone_offset');
|
|
|
|
var local_timezone_offset = date.getTimezoneOffset()*60*-1;
|
|
|
|
|
|
|
|
if (server_timezone_offset != local_timezone_offset) {
|
|
|
|
// If timezone of server and client is different, adjust the time to the server
|
|
|
|
date = new Date((timestamp + (server_timezone_offset - local_timezone_offset)) * 1000);
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
var hours = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours());
|
|
|
|
var minutes = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes());
|
|
|
|
var seconds = (date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds());
|
|
|
|
var formattedTime = hours + ':' + minutes + ':' + seconds;
|
|
|
|
return formattedTime;
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
},
|
2018-09-17 13:13:10 +02:00
|
|
|
yaxis: {
|
|
|
|
tickFormatter: function (value, axis) {
|
2018-11-07 13:57:47 +01:00
|
|
|
return shortNumber(roundToTwo(value)) ;
|
2018-09-17 13:13:10 +02:00
|
|
|
}
|
|
|
|
},
|
2018-08-02 14:59:10 +02:00
|
|
|
series: {
|
|
|
|
lines: {
|
|
|
|
lineWidth: 2,
|
|
|
|
fill: true
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
},
|
|
|
|
colors: ['#6db431']
|
|
|
|
};
|
|
|
|
|
|
|
|
function updatePlot (data) {
|
|
|
|
plot = $.plot($('.graph'), data, plotOptions);
|
|
|
|
}
|
|
|
|
|
|
|
|
function requestData () {
|
2018-08-20 09:53:11 +02:00
|
|
|
var rel_path = $("#hidden-rel_path").val();
|
2018-08-02 14:59:10 +02:00
|
|
|
|
|
|
|
currentXHR = $.ajax({
|
2018-08-20 09:53:11 +02:00
|
|
|
url: rel_path + "extensions/realtime_graphs/ajax.php",
|
2018-08-02 14:59:10 +02:00
|
|
|
type: "POST",
|
|
|
|
dataType: "json",
|
|
|
|
data: {
|
|
|
|
graph: $('#graph :selected').val(),
|
|
|
|
graph_title: $('#graph :selected').html(),
|
|
|
|
snmp_community: $('#text-snmp_community').val(),
|
|
|
|
snmp_oid: $('#text-snmp_oid').val(),
|
|
|
|
snmp_ver: $('#snmp_version :selected').val(),
|
|
|
|
snmp_address: $('#text-ip_target').val(),
|
|
|
|
refresh: refresh
|
|
|
|
},
|
|
|
|
success: function (serie) {
|
|
|
|
var timestamp = serie.data[0][0];
|
|
|
|
var data = plot.getData();
|
2016-01-27 13:08:11 +01:00
|
|
|
|
2018-08-17 13:17:27 +02:00
|
|
|
if (incremental) {
|
|
|
|
var currentVal = serie.data[0][1];
|
|
|
|
// Try to avoid the first value, cause we need at least two values to get the increment
|
|
|
|
serie.data[0][1] = lastIncVal == null ? 0 : currentVal - lastIncVal;
|
|
|
|
// Incremental is always positive
|
|
|
|
if (serie.data[0][1] < 0) serie.data[0][1] = 0;
|
|
|
|
// Store the current value to use it into the next request
|
|
|
|
lastIncVal = currentVal;
|
|
|
|
}
|
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
if (data.length === 0) {
|
|
|
|
for (i = 0; i < numberOfPoints; i++) {
|
|
|
|
var step = i * (refresh / 1000);
|
|
|
|
serie.data.unshift([timestamp - step, 0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
serie = [serie];
|
|
|
|
updatePlot(serie);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
data[0].label = serie.label;
|
|
|
|
if (data[0].data.length >= numberOfPoints) {
|
|
|
|
data[0].data.shift();
|
|
|
|
}
|
2014-05-05 11:53:21 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
data[0].data.push(serie.data[0]);
|
|
|
|
updatePlot(data);
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function startDataPooling () {
|
|
|
|
intervalRef = window.setInterval(requestData, refresh);
|
|
|
|
}
|
2014-05-05 11:53:21 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
function resetDataPooling () {
|
|
|
|
if (currentXHR !== null) currentXHR.abort();
|
|
|
|
// Stop and start the interval
|
|
|
|
window.clearInterval(intervalRef);
|
|
|
|
startDataPooling();
|
|
|
|
}
|
2014-05-05 11:53:21 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
function clearGraph () {
|
|
|
|
var data = plot.getData();
|
|
|
|
if (data.length === 0) return;
|
2014-05-05 11:53:21 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
for (i = 0; i < data[0].data.length; i ++) {
|
|
|
|
data[0].data[i][1] = 0;
|
|
|
|
}
|
|
|
|
if (incremental) lastIncVal = null;
|
|
|
|
|
|
|
|
updatePlot(data);
|
2014-05-05 11:53:21 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
resetDataPooling();
|
2017-12-05 12:13:38 +01:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
|
|
|
|
// Set the form OID to the value selected in the SNMP browser
|
|
|
|
function setOID () {
|
|
|
|
if ($('#snmp_browser_version').val() == '3') {
|
|
|
|
$('#text-snmp_oid').val($('#table1-0-1').text());
|
|
|
|
} else {
|
|
|
|
$('#text-snmp_oid').val($('#snmp_selected_oid').text());
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
|
|
|
|
// Close the SNMP browser
|
|
|
|
$('.ui-dialog-titlebar-close').trigger('click');
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
// Show the SNMP browser window
|
|
|
|
function snmpBrowserWindow () {
|
|
|
|
|
|
|
|
// Keep elements in the form and the SNMP browser synced
|
|
|
|
$('#text-target_ip').val($('#text-ip_target').val());
|
|
|
|
$('#text-community').val($('#text-snmp_community').val());
|
|
|
|
$('#snmp_browser_version').val($('#snmp_version').val());
|
|
|
|
$('#snmp3_browser_auth_user').val($('#snmp3_auth_user').val());
|
|
|
|
$('#snmp3_browser_security_level').val($('#snmp3_security_level').val());
|
|
|
|
$('#snmp3_browser_auth_method').val($('#snmp3_auth_method').val());
|
|
|
|
$('#snmp3_browser_auth_pass').val($('#snmp3_auth_pass').val());
|
|
|
|
$('#snmp3_browser_privacy_method').val($('#snmp3_privacy_method').val());
|
|
|
|
$('#snmp3_browser_privacy_pass').val($('#snmp3_privacy_pass').val());
|
|
|
|
|
|
|
|
$("#snmp_browser_container").show().dialog ({
|
|
|
|
title: '',
|
|
|
|
resizable: true,
|
|
|
|
draggable: true,
|
|
|
|
modal: true,
|
|
|
|
overlay: {
|
|
|
|
opacity: 0.5,
|
|
|
|
background: "black"
|
|
|
|
},
|
|
|
|
width: 920,
|
|
|
|
height: 500
|
|
|
|
});
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
|
2018-09-17 13:13:10 +02:00
|
|
|
function shortNumber (number) {
|
|
|
|
if (Math.round(number) != number) return number;
|
|
|
|
number = Number.parseInt(number);
|
|
|
|
if (Number.isNaN(number)) return number;
|
|
|
|
|
|
|
|
var shorts = ["", "K", "M", "G", "T", "P", "E", "Z", "Y"];
|
|
|
|
var pos = 0;
|
|
|
|
|
|
|
|
while (number >= 1000 || number <= -1000) {
|
|
|
|
pos++;
|
|
|
|
number = number / 1000;
|
|
|
|
}
|
|
|
|
|
|
|
|
return number + " " + shorts[pos];
|
|
|
|
}
|
2018-11-07 13:57:47 +01:00
|
|
|
function roundToTwo(num) {
|
|
|
|
return +(Math.round(num + "e+2") + "e-2");
|
|
|
|
}
|
2018-09-17 13:13:10 +02:00
|
|
|
|
2018-08-02 14:59:10 +02:00
|
|
|
$('#graph').change(function() {
|
|
|
|
$('form#realgraph').submit();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#refresh').change(function () {
|
|
|
|
refresh = parseInt($('#refresh').val());
|
|
|
|
resetDataPooling();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#checkbox-incremental').change(function() {
|
|
|
|
incremental = $('#checkbox-incremental').is(':checked');
|
|
|
|
clearGraph();
|
|
|
|
});
|
|
|
|
|
|
|
|
updatePlot([]);
|
|
|
|
requestData();
|
|
|
|
startDataPooling();
|
|
|
|
|
|
|
|
// Expose this functions
|
|
|
|
window.realtimeGraphs = {
|
|
|
|
clearGraph: clearGraph,
|
|
|
|
setOID: setOID,
|
|
|
|
snmpBrowserWindow: snmpBrowserWindow
|
2014-05-05 11:53:21 +02:00
|
|
|
}
|
2018-08-02 14:59:10 +02:00
|
|
|
|
|
|
|
})();
|