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->align[0] = 'center';
$table->head[1] = __('Type');
$table->headclass[1] = 'f9';
$table->align[1] = 'center';
$table->head[2] = __('Event name');
$table->head[3] = __('Agent name');
$table->align[3] = 'center';
$table->head[4] = __('Source');
$table->align[4] = 'center';
$table->head[5] = __('Group');
$table->align[5] = 'center';
$table->head[6] = __('User ID');
$table->align[6] = 'center';
$table->head[7] = __('Timestamp');
$table->align[7] = 'center';
$table->head[8] = __('Action');
$table->align[8] = 'center';
$table->head[9] = print_checkbox ("allbox", "1", false, true);
$table->align[9] = 'center';
//Arrange data. We already did ACL's in the query
foreach ($result as $row) {
$data = array ();
//First pass along the class of this row
$table->rowclass[] = get_priority_class ($row["criticity"]);
// Colored box
if ($row["estado"] == 0) {
$data[0] = '
data:image/s3,"s3://crabby-images/b0a51/b0a5102f56f56d465b59143b9a2c4da3dc7c6bd1" alt="'.get_priority_name ($row["
';
} else {
$data[0] = '
data:image/s3,"s3://crabby-images/02b63/02b633b9c66c585a262f8f0021dda5fe098855ce" alt="'.get_priority_name ($row["
';
}
switch ($row["event_type"]) {
case "alert_recovered":
$data[1] = '
data:image/s3,"s3://crabby-images/b4794/b4794f8ab5ce080d022205ffba915689a8335c16" alt="'.__('Alert Recovered').'"
';
break;
case "alert_manual_validation":
$data[1] = '
data:image/s3,"s3://crabby-images/722fa/722fa8e84bc57ec2adb75cc1e0e30193fda4e725" alt="'.__('Manual Alert Validation').'"
';
break;
case "monitor_up":
$data[1] = '
data:image/s3,"s3://crabby-images/fed47/fed475a5690575046f8b3a270032084c6f8a107b" alt="'.__('Monitor Up').'"
';
break;
case "monitor_down":
$data[1] = '
data:image/s3,"s3://crabby-images/82b2a/82b2a2ee99db041b4f258d3623bb39cd4c150631" alt="'.__('Monitor Down').'"
';
break;
case "alert_fired":
$data[1] = '
data:image/s3,"s3://crabby-images/f6013/f6013c4a0fa3ae98aaf2a073f11d82613eaccb8e" alt="'.__('Alert Fired').'"
';
break;
case "system";
$data[1] = '
data:image/s3,"s3://crabby-images/62ef0/62ef05b674967509f0af0f5c5eb03acf81c67520" alt="'.__('System').'"
';
break;
case "recon_host_detected";
$data[1] = '
data:image/s3,"s3://crabby-images/bda80/bda80f8edd76c5c10bcb826906bc414957240a8e" alt="'.__('Host Detected (Recon)').'"
';
break;
case "new_agent";
$data[1] = '
data:image/s3,"s3://crabby-images/3d7f1/3d7f1a2bc64ed4a13ed0cb116f30729fdc98ed86" alt="'.__('New Agent').'"
';
break;
case "unknown":
default:
$data[1] = '
data:image/s3,"s3://crabby-images/1e1ea/1e1ea3d5c7d9ddd53f6c4f4203be8d76882d4c7e" 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/4a124/4a124e63787070ebfbe89851670fe7622c669d2c" alt=""
';
}
if ($row["id_alert_am"] != 0) {
$data[4] .= '
data:image/s3,"s3://crabby-images/f6013/f6013c4a0fa3ae98aaf2a073f11d82613eaccb8e" alt=""
';
}
if (!empty ($row["id_grupo"])) {
$data[5] = '
data:image/s3,"s3://crabby-images/39615/3961540d84db3b102da8ebaaae11e7f61c979f4e" 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/74790/747904f282a4f0b7181b8b14f9019be49796d874" alt=""
';
}
// Delete event
if (give_acl ($config["id_user"], $row["id_grupo"], "IM") == 1) {
$data[8] .= '
data:image/s3,"s3://crabby-images/d4684/d46843f1743aa3bc7a7109e9fa89b45c07d6181e" 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/56cb4/56cb43a133f3e07a242cbae89cd076f2207bc1f8" 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/ace53/ace536b044cf44499c7812c101da00d74eae45d5" alt=""
- '.__('Validated event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/30070/300702fdae73bb1bc47e771fa0c95037b4dc4f94" alt=""
- '.__('Not validated event');
echo '
';
echo '
'.__('Action').'
';
echo '
data:image/s3,"s3://crabby-images/74790/747904f282a4f0b7181b8b14f9019be49796d874" alt=""
- '.__('Validate event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/d4684/d46843f1743aa3bc7a7109e9fa89b45c07d6181e" alt=""
- '.__('Delete event');
echo '
';
echo '
data:image/s3,"s3://crabby-images/56cb4/56cb43a133f3e07a242cbae89cd076f2207bc1f8" alt=""
- '.__('Create incident');
echo '
';
?>