1 && in_array ($ev_group, array_keys ($groups))) {
//If a group is selected and it's in the groups allowed
$sql_post = " AND id_grupo = $ev_group";
} elseif (dame_admin ($config["id_user"])) {
//Do nothing if you're admin, you get full access
$sql_post = "";
$groups[0] = __('System Events');
} else {
//Otherwise select all groups the user has rights to.
$sql_post = " AND id_grupo IN (".implode (",", array_keys ($groups)).")";
}
if ($status == 1) {
$sql_post .= " AND estado = 1";
} elseif ($status == 0) {
$sql_post .= " AND estado = 0";
}
if ($search != "")
$sql_post .= " AND evento LIKE '%$search%'";
if ($event_type != "")
$sql_post .= " AND event_type = '$event_type'";
if ($severity != -1)
$sql_post .= " AND criticity >= ".$severity;
if ($id_agent != -1)
$sql_post .= " AND id_agente = ".$id_agent;
if ($id_event != -1)
$sql_post .= " AND id_evento = ".$id_event;
$url = "index.php?sec=eventos&sec2=operation/events/events&search=$search&event_type=$event_type&severity=$severity&status=$status&ev_group=$ev_group&refr=60&id_agent=$id_agent&id_event=$id_event&pagination=$pagination";
echo "
';
} else {
echo '
'; //There is no value all to property display
}
// Table for filter controls
echo '
"; //This is the internal table
echo '
';
echo '
';
$sql = "SELECT * FROM tevento WHERE 1=1 ".$sql_post." ORDER BY utimestamp DESC LIMIT ".$offset.",".$pagination;
$result = get_db_all_rows_sql ($sql);
$sql = "SELECT COUNT(id_evento) FROM tevento WHERE 1=1 ".$sql_post;
$total_events = get_db_sql ($sql);
if (empty ($result)) {
$result = array ();
}
if (empty ($total_events)) {
$total_events = 0;
}
// Show pagination header
$offset = get_parameter ("offset", 0);
pagination ($total_events, $url."&pure=".$config["pure"], $offset, $pagination);
// If pure, table width takes more space
if ($config["pure"] != 0) {
$table->width = 765;
} else {
$table->width = 750;
}
$table->id = "eventtable";
$table->cellpadding = 4;
$table->cellspacing = 4;
$table->class = "databox";
$table->head = array ();
$table->data = array ();
$table->head[0] = '';
$table->head[1] = __('Type');
$table->headclass[1] = 'f9';
$table->head[2] = __('Event name');
//$table->headclass[2] = 'f9';
$table->head[3] = __('Agent name');
//$table->headclass[3] = 'f9';
$table->head[4] = __('Source');
//$table->headclass[4] = 'f9';
$table->head[5] = __('Group');
//$table->headclass[5] = 'f9';
$table->head[6] = __('User ID');
//$table->headclass[6] = 'f9';
$table->head[7] = __('Timestamp');
//$table->headclass[7] = 'f9';
$table->head[8] = __('Action');
//$table->headclass[8] = 'f9';
$table->head[9] = print_checkbox ("allbox", "1", false, true);
//$table->headclass[9] = 'p10';
//Arrange data. We already did ACL's in the query
foreach ($result as $row) {
$data = array ();
//First pass along the class of this row
switch ($row["criticity"]) {
case 0:
$table->rowclass[] = "datos_blue";
break;
case 1:
$table->rowclass[] = "datos_grey";
break;
case 2:
$table->rowclass[] = "datos_green";
break;
case 3:
$table->rowclass[] = "datos_yellow";
break;
case 4:
$table->rowclass[] = "datos_red";
break;
default:
$table->rowclass[] = "datos_grey";
}
// Colored box
if ($row["estado"] == 0) {
$data[0] = '
data:image/s3,"s3://crabby-images/d4cbe/d4cbef78dde93a01765d82ba4b90ec7bf2a529a4" alt="'.get_priority_name ($row["
';
} else {
$data[0] = '
data:image/s3,"s3://crabby-images/14c6d/14c6d2b4646541f67a3e172a724c849cf59ffe3b" alt="'.get_priority_name ($row["
';
}
switch ($row["event_type"]) {
case "alert_recovered":
$data[1] = '
data:image/s3,"s3://crabby-images/2593a/2593a70f068c017ac9cff4b63e242e85168cdd10" alt="'.__('Alert Recovered').'"
';
break;
case "alert_manual_validation":
$data[1] = '
data:image/s3,"s3://crabby-images/b8cf1/b8cf1fc81ad0f3851d271a0c6f7f4b9e729f22cf" alt="'.__('Manual Alert Validation').'"
';
break;
case "monitor_up":
$data[1] = '
data:image/s3,"s3://crabby-images/424d4/424d45ea0f0f148fdd283b7d4e0bcd51d3641359" alt="'.__('Monitor Up').'"
';
break;
case "monitor_down":
$data[1] = '
data:image/s3,"s3://crabby-images/58e89/58e893e9e114ef1f0ad9bb0d0ff66fb4e89a8c51" alt="'.__('Monitor Down').'"
';
break;
case "alert_fired":
$data[1] = '
data:image/s3,"s3://crabby-images/6e945/6e9451a02249ea024a7794f32123e4c2a6044162" alt="'.__('Alert Fired').'"
';
break;
case "system";
$data[1] = '
data:image/s3,"s3://crabby-images/37b84/37b8428fd14086ee03d90a497f138254851a4e7b" alt="'.__('System').'"
';
break;
case "recon_host_detected";
$data[1] = '
data:image/s3,"s3://crabby-images/21612/2161285ac8cc1bf0823d502406a63b75f266757b" alt="'.__('Host Detected (Recon)').'"
';
break;
case "new_agent";
$data[1] = '
data:image/s3,"s3://crabby-images/60b67/60b678052bcd2269e1ed322aedd51aa3d4a78ab9" alt="'.__('New Agent').'"
';
break;
case "unknown":
default:
$data[1] = '
data:image/s3,"s3://crabby-images/ff949/ff949ac97cafe0edf6e9336d5cbd26c882226b09" alt="'.__('Unknown type').': '.$row["
';
break;
}
// Event description
$data[2] = '
';
if (strlen ($row["evento"]) > 39) {
$data[2] .= substr ($row["evento"], 0, 37)."...";
} else {
$data[2] .= $row["evento"];
}
$data[2] .= '';
if ($row["event_type"] == "system") {
$data[3] = __('System');
} elseif ($row["id_agente"] > 0) {
// Agent name
$agent_name = dame_nombre_agente ($row["id_agente"]);
$data[3] = '
';
if (strlen ($agent_name) > 16) {
$data[3] .= substr ($agent_name, 0, 14)."...";
} else {
$data[3] .= $agent_name;
}
$data[3] .= '';
} else {
$data[3] = __('Alert').__('SNMP');
}
$data[4] = '';
if ($row["id_agentmodule"] != 0) {
$data[4] .= '
data:image/s3,"s3://crabby-images/f34f9/f34f91d8e7f2049c6579566eede71674ea64874b" alt=""
';
}
if ($row["id_alert_am"] != 0) {
$data[4] .= '
data:image/s3,"s3://crabby-images/6e945/6e9451a02249ea024a7794f32123e4c2a6044162" alt=""
';
}
if (!empty ($row["id_grupo"])) {
$data[5] = '
data:image/s3,"s3://crabby-images/ef9b7/ef9b70ba820adc28923a9da05843d527bc6b0568" alt="'.dame_nombre_grupo ($row["
';
} else {
$data[5] = '';
}
if (!empty ($row["estado"])) {
$data[6] = '
'.substr ($row["id_usuario"],0,8).'';
} else {
$data[6] = '';
}
//Time
$data[7] = '
'.human_time_comparation ($row["timestamp"]).'';
//Actions
$data[8] = '';
// Validate event
if (($row["estado"] == 0) and (give_acl ($config["id_user"], $row["id_grupo"], "IW") == 1)) {
$data[8] .= '
data:image/s3,"s3://crabby-images/281b4/281b44aa5ba954ac7eb384830d396ded00bfe0b5" alt=""
';
}
// Delete event
if (give_acl ($config["id_user"], $row["id_grupo"], "IM") == 1) {
$data[8] .= '
data:image/s3,"s3://crabby-images/24584/2458455bf58bbe464cd0146dcfe98392c26077e1" alt=""
';
}
// Create incident from this event
if (give_acl ($config["id_user"], $row["id_grupo"], "IW") == 1) {
$data[8] .= '
data:image/s3,"s3://crabby-images/bdcda/bdcdab9e880ecf3d27a4185dbcf1ee0c96f6cf2e" alt=""
';
}
//Checkbox
$data[9] = print_checkbox_extended ("eventid[]", $row["id_evento"], false, false, false, 'class="chk"', true);
array_push ($table->data, $data);
}
if (!empty ($table->data)) {
echo '
';
} else {
echo '
'.__('No events').'
';
}
unset ($table);
echo '
';
echo '
'.__('Status').'
';
echo '
data:image/s3,"s3://crabby-images/42480/42480af15d843990cc6e59b4b7d712b26a8f89a0" alt=""
- '.__('Validated event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/be27c/be27c5506b8a326e3419d8b9e42f05cf25704211" alt=""
- '.__('Not validated event');
echo '
';
echo '
'.__('Action').'
';
echo '
data:image/s3,"s3://crabby-images/281b4/281b44aa5ba954ac7eb384830d396ded00bfe0b5" alt=""
- '.__('Validate event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/24584/2458455bf58bbe464cd0146dcfe98392c26077e1" alt=""
- '.__('Delete event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/bdcda/bdcdab9e880ecf3d27a4185dbcf1ee0c96f6cf2e" alt=""
- '.__('Create incident');
echo '
';
?>