2017-11-27 16:29:32 +01:00
|
|
|
var refreshTimer = null;
|
|
|
|
var isFetching = null;
|
2017-11-28 10:36:38 +01:00
|
|
|
var storedEvents = new Array();
|
|
|
|
var notVisited = {};
|
2012-09-11 18:09:43 +02:00
|
|
|
|
|
|
|
$(window).load(function() {
|
|
|
|
initilise();
|
2017-11-27 16:29:32 +01:00
|
|
|
// Wait some ms to throw main function
|
|
|
|
var delay = setTimeout(main, 100);
|
|
|
|
resetInterval();
|
2012-09-11 18:09:43 +02:00
|
|
|
});
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
function fetchEvents() {
|
|
|
|
return storedEvents;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-28 10:36:38 +01:00
|
|
|
function fetchNotVisited() {
|
|
|
|
return notVisited;
|
|
|
|
}
|
|
|
|
|
|
|
|
function removeNotVisited(eventId) {
|
|
|
|
if (notVisited[eventId] === true) delete notVisited[eventId];
|
|
|
|
}
|
2012-09-11 18:09:43 +02:00
|
|
|
|
|
|
|
function main() {
|
2017-11-27 16:29:32 +01:00
|
|
|
|
|
|
|
chrome.runtime.sendMessage({text: "FETCH_EVENTS"});
|
|
|
|
// Do not fetch if is fetching now
|
|
|
|
if (isFetching) return;
|
|
|
|
isFetching = true;
|
|
|
|
|
|
|
|
var feedUrl = localStorage["ip_address"]+'/include/api.php?op=get&op2=events&return_type=csv&apipass='+localStorage["api_pass"]+'&user='+localStorage["user_name"]+'&pass='+localStorage["pass"];
|
2012-09-11 18:09:43 +02:00
|
|
|
req = new XMLHttpRequest();
|
|
|
|
req.onload = handleResponse;
|
|
|
|
req.onerror = handleError;
|
|
|
|
req.open("GET", feedUrl, true);
|
|
|
|
req.send(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleError() {
|
2017-11-27 16:29:32 +01:00
|
|
|
chrome.runtime.sendMessage({text: "FETCH_EVENTS_URL_ERROR"});
|
|
|
|
isFetching = false;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function handleResponse() {
|
|
|
|
var doc = req.responseText;
|
|
|
|
if (doc=="auth error") {
|
2017-11-27 16:29:32 +01:00
|
|
|
chrome.runtime.sendMessage({text: "FETCH_EVENTS_URL_ERROR"});
|
|
|
|
} else {
|
|
|
|
var n = doc.search("404 Not Found");
|
|
|
|
if (n>0) {
|
|
|
|
chrome.runtime.sendMessage({text: "FETCH_EVENTS_DATA_ERROR"});
|
|
|
|
} else {
|
2012-09-11 18:09:43 +02:00
|
|
|
getEvents(doc);
|
2017-11-27 16:29:32 +01:00
|
|
|
chrome.runtime.sendMessage({text: "FETCH_EVENTS_SUCCESS"});
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
}
|
2017-11-27 16:29:32 +01:00
|
|
|
isFetching = false;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function getEvents(reply){
|
2017-11-27 16:29:32 +01:00
|
|
|
var fetchedEvents = parseReplyEvents(reply);
|
|
|
|
|
|
|
|
// If there is no events requested, mark all as visited
|
|
|
|
if (storedEvents.length == 0) {
|
2017-11-28 10:36:38 +01:00
|
|
|
notVisited = {};
|
2017-11-27 16:29:32 +01:00
|
|
|
storedEvents = fetchedEvents;
|
|
|
|
return;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
// Discriminate the new events
|
|
|
|
newEvents=fetchNewEvents(fetchedEvents,storedEvents);
|
2017-11-28 10:36:38 +01:00
|
|
|
var newNotVisited = {};
|
|
|
|
var notVisitedCount = 0;
|
2017-11-27 16:29:32 +01:00
|
|
|
|
2017-11-28 10:36:38 +01:00
|
|
|
// Check if popup is displayed to make some actions
|
2017-11-27 19:14:31 +01:00
|
|
|
var views = chrome.extension.getViews({ type: "popup" });
|
2017-11-28 10:36:38 +01:00
|
|
|
for(var k=0;k<newEvents.length;k++){
|
|
|
|
newNotVisited[newEvents[k]['id']] = true;
|
|
|
|
if (views.length == 0) {
|
|
|
|
notVisitedCount++;
|
2017-11-27 19:14:31 +01:00
|
|
|
displayNotification (newEvents[k])
|
|
|
|
alertsSound(newEvents[k]);
|
|
|
|
}
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-28 10:36:38 +01:00
|
|
|
// Make that the old events marked as not visited remains with the
|
|
|
|
// same status
|
|
|
|
for(var k=0;k<fetchedEvents.length;k++){
|
|
|
|
if (notVisited[fetchedEvents[k]['id']] === true) {
|
|
|
|
newNotVisited[fetchedEvents[k]['id']] = true;
|
|
|
|
notVisitedCount++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
notVisited = newNotVisited;
|
2012-09-11 18:09:43 +02:00
|
|
|
|
2017-11-28 10:36:38 +01:00
|
|
|
// Update the number
|
|
|
|
localStorage["new_events"] = (views.length == 0) ? notVisitedCount : 0;
|
2017-11-27 16:29:32 +01:00
|
|
|
updateBadge();
|
2017-11-28 10:36:38 +01:00
|
|
|
|
|
|
|
// Store the requested events
|
|
|
|
storedEvents = fetchedEvents;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
function updateBadge() {
|
|
|
|
if (localStorage["new_events"] != 0) {
|
|
|
|
chrome.browserAction.setBadgeBackgroundColor({color:[0,200,0,255]});
|
|
|
|
chrome.browserAction.setBadgeText({ text: localStorage["new_events"] });
|
|
|
|
} else {
|
|
|
|
chrome.browserAction.setBadgeText({ text: "" });
|
|
|
|
}
|
|
|
|
}
|
2012-09-11 18:09:43 +02:00
|
|
|
|
|
|
|
function fetchNewEvents(A,B){
|
|
|
|
var arrDiff = new Array();
|
|
|
|
for(var i = 0; i < A.length; i++) {
|
|
|
|
var id = false;
|
|
|
|
for(var j = 0; j < B.length; j++) {
|
2017-11-27 16:29:32 +01:00
|
|
|
if(A[i]['id'] == B[j]['id']) {
|
2012-09-11 18:09:43 +02:00
|
|
|
id = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!id) {
|
|
|
|
arrDiff.push(A[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return arrDiff;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
function parseReplyEvents (reply) {
|
|
|
|
|
2017-11-27 17:52:11 +01:00
|
|
|
// Split the API response
|
2017-11-27 16:29:32 +01:00
|
|
|
var e_array = reply.split("\n");
|
|
|
|
|
|
|
|
// Form a properly object
|
|
|
|
var fetchedEvents=new Array();
|
|
|
|
for(var i=0;i<e_array.length;i++){
|
|
|
|
// Avoid to parse empty lines
|
|
|
|
if (e_array[i].length == 0) continue;
|
2017-11-27 19:14:31 +01:00
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
var event=e_array[i].split(";");
|
|
|
|
fetchedEvents.push({
|
|
|
|
'id' : event[0],
|
|
|
|
'agent_name' : event[1],
|
2017-11-27 17:52:11 +01:00
|
|
|
'agent' : event[2],
|
|
|
|
'date' : event[5],
|
|
|
|
'title' : event[6],
|
2017-11-27 16:29:32 +01:00
|
|
|
'module' : event[9],
|
|
|
|
'type' : event[14],
|
|
|
|
'source' : event[17],
|
2017-11-27 17:52:11 +01:00
|
|
|
'severity' : event[28],
|
2017-11-27 16:29:32 +01:00
|
|
|
'visited' : false
|
|
|
|
});
|
|
|
|
}
|
|
|
|
// Return the events
|
|
|
|
return fetchedEvents;
|
|
|
|
}
|
|
|
|
|
|
|
|
function alertsSound(pEvent){
|
|
|
|
if(localStorage["sound_alert"]!="on"){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (pEvent['severity']) {
|
|
|
|
case "Critical":
|
2012-09-11 18:09:43 +02:00
|
|
|
playSound(localStorage["critical"]);
|
2017-11-27 16:29:32 +01:00
|
|
|
break;
|
|
|
|
case "Informational":
|
2017-11-27 17:52:11 +01:00
|
|
|
playSound(localStorage["informational"]);
|
2017-11-27 16:29:32 +01:00
|
|
|
break;
|
|
|
|
case "Maintenance":
|
2012-09-11 18:09:43 +02:00
|
|
|
playSound(localStorage["maintenance"]);
|
2017-11-27 16:29:32 +01:00
|
|
|
break;
|
|
|
|
case "Normal":
|
2012-09-11 18:09:43 +02:00
|
|
|
playSound(localStorage["normal"]);
|
2017-11-27 16:29:32 +01:00
|
|
|
break;
|
|
|
|
case "Warning":
|
2012-09-11 18:09:43 +02:00
|
|
|
playSound(localStorage["warning"]);
|
2017-11-27 16:29:32 +01:00
|
|
|
break;
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
function displayNotification (pEvent) {
|
|
|
|
|
|
|
|
// Check if the user is okay to get some notification
|
|
|
|
if (Notification.permission === "granted") {
|
|
|
|
// If it's okay create a notification
|
|
|
|
getNotification(pEvent);
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
// Otherwise, we need to ask the user for permission
|
|
|
|
// Note, Chrome does not implement the permission static property
|
|
|
|
// So we have to check for NOT 'denied' instead of 'default'
|
|
|
|
else if (Notification.permission !== 'denied') {
|
|
|
|
Notification.requestPermission(function (permission) {
|
|
|
|
// Whatever the user answers, we make sure we store the information
|
|
|
|
if(!('permission' in Notification)) {
|
|
|
|
Notification.permission = permission;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the user is okay, let's create a notification
|
|
|
|
if (permission === "granted") getNotification(pEvent);
|
|
|
|
});
|
|
|
|
}
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
function getNotification(pEvent){
|
|
|
|
|
|
|
|
// Build the event text
|
|
|
|
var even = pEvent['type'];
|
|
|
|
if (pEvent['source'] != '') even += " : " + pEvent['source'];
|
|
|
|
even += ". Event occured at " + pEvent['date'];
|
|
|
|
if(pEvent['module'] != 0) even += " in the module with Id "+ pEvent['module'];
|
|
|
|
even += ".";
|
|
|
|
|
|
|
|
var url = (pEvent['agent']=="")
|
|
|
|
? localStorage["ip_address"]+"/index.php?sec=eventos&sec2=operation/events/events"
|
|
|
|
: localStorage["ip_address"]+"/index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=" + pEvent['agent'];
|
|
|
|
|
|
|
|
var notification = new Notification(
|
|
|
|
pEvent['title'],
|
|
|
|
{
|
|
|
|
body: even,
|
|
|
|
icon: "images/icon.png"
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
// Add the link
|
|
|
|
notification.onclick = function (event) {
|
|
|
|
event.preventDefault();
|
|
|
|
window.open(url, '_blank');
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
2017-11-27 16:29:32 +01:00
|
|
|
|
|
|
|
// Close notification after 10 secs
|
|
|
|
setTimeout(function() {notification.close()}, 10000);
|
|
|
|
}
|
|
|
|
|
|
|
|
function resetInterval () {
|
|
|
|
if (refreshTimer) clearInterval(refreshTimer);
|
|
|
|
refreshTimer = setInterval(main, localStorage["refresh"]*1000);
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function initilise(){
|
|
|
|
|
2017-11-27 16:29:32 +01:00
|
|
|
if (isFetching == null) isFetching = false;
|
|
|
|
if(localStorage["ip_address"]==undefined){
|
|
|
|
localStorage["ip_address"]="http://firefly.artica.es/pandora_demo";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["api_pass"]==undefined){
|
|
|
|
localStorage["api_pass"]="doreik0";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["user_name"]==undefined){
|
|
|
|
localStorage["user_name"]="demo";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["pass"]==undefined){
|
|
|
|
localStorage["pass"]="demo";
|
|
|
|
}
|
|
|
|
if(localStorage["critical"]==null){
|
|
|
|
localStorage["critical"]="11";
|
|
|
|
}
|
|
|
|
if(localStorage["informational"]==null){
|
|
|
|
localStorage["informational"]="1";
|
|
|
|
}
|
|
|
|
if(localStorage["maintenance"]==null){
|
|
|
|
localStorage["maintenance"]="10";
|
|
|
|
}
|
|
|
|
if(localStorage["normal"]==null){
|
|
|
|
localStorage["normal"]="6";
|
|
|
|
}
|
|
|
|
if(localStorage["warning"]==null){
|
|
|
|
localStorage["warning"]="2";
|
|
|
|
}
|
|
|
|
if(localStorage["events"]==null){
|
|
|
|
localStorage["events"]=20;
|
|
|
|
}
|
|
|
|
if(localStorage["refresh"]==null){
|
|
|
|
localStorage["refresh"]="10";
|
|
|
|
}
|
|
|
|
if(localStorage["ip_address"]==null){
|
|
|
|
localStorage["ip_address"]="http://firefly.artica.es/pandora_demo";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["api_pass"]==null){
|
|
|
|
localStorage["api_pass"]="doreik0";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["user_name"]==null){
|
|
|
|
localStorage["user_name"]="demo";
|
|
|
|
}
|
|
|
|
|
|
|
|
if(localStorage["pass"]==null){
|
|
|
|
localStorage["pass"]="demo";
|
|
|
|
}
|
|
|
|
if(localStorage["sound_alert"]==null){
|
|
|
|
localStorage["sound_alert"]="on";
|
|
|
|
}
|
|
|
|
if(localStorage["changed"]==null){
|
|
|
|
localStorage["changed"]="false";
|
|
|
|
}
|
|
|
|
if(localStorage["new_events"]==null){
|
|
|
|
localStorage["new_events"]=parseInt(localStorage["events"]);
|
|
|
|
}
|
|
|
|
if(localStorage["error"]==null) {
|
|
|
|
localStorage["error"] = true;
|
|
|
|
}
|
2012-09-11 18:09:43 +02:00
|
|
|
}
|