pandorafms/pandora_console/include/class/Heatmap.class.php

1600 lines
54 KiB
PHP
Raw Normal View History

2022-02-11 14:50:57 +01:00
<?php
2023-03-24 14:11:08 +01:00
2022-02-11 14:50:57 +01:00
/**
* Heatmap class.
*
* @category Heatmap
* @package Pandora FMS
* @subpackage Community
* @version 1.0.0
* @license See below
*
* ______ ___ _______ _______ ________
2023-06-08 12:42:10 +02:00
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
2022-02-11 14:50:57 +01:00
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
*
* ============================================================================
2023-06-08 11:53:13 +02:00
* Copyright (c) 2005-2023 Pandora FMS
2023-06-08 13:19:01 +02:00
* Please see https://pandorafms.com/community/ for full contribution list
2022-02-11 14:50:57 +01:00
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation for version 2.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* ============================================================================
*/
2023-02-21 15:06:15 +01:00
namespace PandoraFMS;
2023-03-24 14:11:08 +01:00
use PandoraFMS\Enterprise\Metaconsole\Node;
2022-02-11 14:50:57 +01:00
class Heatmap
{
/**
* Heatmap type.
*
* @var integer
*/
protected $type = null;
/**
* Heatmap filter.
*
* @var array
*/
protected $filter = null;
/**
* Allowed methods to be called using AJAX request.
*
* @var array
*/
protected $AJAXMethods = [
'showHeatmap',
'updateHeatmap',
'getDataJson',
];
/**
* Heatmap random id.
*
* @var string
*/
protected $randomId = null;
/**
* Heatmap refresh.
*
* @var integer
*/
protected $refresh = null;
2022-02-25 09:41:32 +01:00
/**
* Heatmap width.
*
* @var integer
*/
protected $width = null;
/**
* Heatmap height.
*
* @var integer
*/
protected $height = null;
/**
* Heatmap search.
*
* @var string
*/
protected $search = null;
2022-03-07 13:11:54 +01:00
/**
* Heatmap group.
*
* @var integer
*/
protected $group = null;
2023-02-26 18:10:58 +01:00
/**
2023-05-11 12:05:00 +02:00
* Heatmap dashboard.
2023-02-26 18:10:58 +01:00
*
* @var boolean
*/
protected $dashboard = null;
2023-05-11 12:05:00 +02:00
/**
* Public hash.
*
* @var boolean
*/
protected $hash = null;
/**
* Public user.
*
* @var boolean
*/
protected $publicUser = null;
2022-02-11 14:50:57 +01:00
/**
* Constructor function
*
2023-02-26 18:10:58 +01:00
* @param integer $type Heatmap type.
* @param array $filter Heatmap filter.
* @param string $randomId Heatmap random id.
* @param integer $refresh Heatmap refresh.
* @param integer $width Width.
* @param integer $height Height.
* @param string $search Heatmap search.
* @param integer $group Heatmap group.
* @param boolean $dashboard Dashboard widget.
2022-02-11 14:50:57 +01:00
*/
public function __construct(
int $type=0,
array $filter=[],
string $randomId=null,
2022-03-31 09:46:30 +02:00
int $refresh=300,
2022-02-25 09:41:32 +01:00
int $width=0,
int $height=0,
2022-03-07 13:11:54 +01:00
string $search=null,
2023-02-26 18:10:58 +01:00
int $group=1,
2023-05-11 12:05:00 +02:00
bool $dashboard=false,
string $hash='',
string $publicUser=''
2022-02-11 14:50:57 +01:00
) {
$this->type = $type;
$this->filter = $filter;
(empty($randomId) === true) ? $this->randomId = uniqid() : $this->randomId = $randomId;
$this->refresh = $refresh;
2022-02-25 09:41:32 +01:00
$this->width = $width;
$this->height = $height;
$this->search = $search;
2022-03-07 13:11:54 +01:00
$this->group = $group;
2023-02-26 18:10:58 +01:00
$this->dashboard = $dashboard;
2023-05-11 12:05:00 +02:00
$this->hash = $hash;
$this->publicUser = $publicUser;
2022-02-11 14:50:57 +01:00
}
/**
2022-02-25 09:41:32 +01:00
* Run.
2022-02-11 14:50:57 +01:00
*
* @return void
*/
public function run()
{
ui_require_css_file('heatmap');
$settings = [
2022-10-14 13:53:05 +02:00
'type' => 'GET',
2022-02-11 14:50:57 +01:00
'dataType' => 'html',
'url' => ui_get_full_url(
'ajax.php',
false,
false,
false
),
'data' => [
2023-05-11 12:05:00 +02:00
'page' => 'operation/heatmap',
'method' => 'showHeatmap',
'randomId' => $this->randomId,
'type' => $this->type,
'filter' => $this->filter,
'refresh' => $this->refresh,
'search' => $this->search,
'group' => $this->group,
'dashboard' => (int) $this->dashboard,
'auth_hash' => $this->hash,
'auth_class' => 'PandoraFMS\Dashboard\Manager',
'id_user' => $this->publicUser,
2022-02-11 14:50:57 +01:00
],
];
2023-03-14 12:47:10 +01:00
$style_dashboard = '';
if ($this->dashboard === true) {
$style_dashboard = 'min-height: 0px';
}
echo '<div id="div_'.$this->randomId.'" class="mainDiv" style="width: 100%;height: 100%;'.$style_dashboard.'">';
2022-02-11 14:50:57 +01:00
?>
2023-03-24 14:11:08 +01:00
<script type="text/javascript">
$(document).ready(function() {
const randomId = '<?php echo $this->randomId; ?>';
const refresh = '<?php echo $this->refresh; ?>';
const dashboard = '<?php echo $this->dashboard; ?>';
let setting = <?php echo json_encode($settings); ?>;
setting['data']['height'] = $(`#div_${randomId}`).height() + 10;
setting['data']['width'] = $(`#div_${randomId}`).width();
if (dashboard === '1') {
setting['data']['width'] -= 10;
setting['data']['height'] -= 10;
}
var totalModules = 0;
// Initial charge.
$.ajax({
type: setting.type,
dataType: setting.dataType,
url: setting.url,
data: setting.data,
success: function(data) {
$(`#div_${randomId}`).append(data);
totalModules = $('rect').length;
let cont = 0;
while (cont < Math.ceil(totalModules / 10)) {
oneSquare(getRandomInteger(1, 10), getRandomInteger(100, 900));
cont++;
}
2023-03-14 12:47:10 +01:00
}
2023-03-24 14:11:08 +01:00
});
2023-03-14 12:47:10 +01:00
2023-03-24 14:11:08 +01:00
function getRandomInteger(min, max) {
return Math.floor(Math.random() * max) + min;
}
2022-10-14 13:53:05 +02:00
2023-03-24 14:11:08 +01:00
function oneSquare(solid, time) {
var randomPoint = getRandomInteger(1, totalModules);
let target = $(`#${randomId}_${randomPoint}`);
setTimeout(function() {
let class_name = target.attr('class');
if (typeof class_name !== 'undefined') {
class_name = class_name.split(' ')[0];
const newClassName = class_name.split('_')[0];
target.removeClass(`${class_name} hover`);
target.addClass(`${newClassName}_${solid} hover`);
oneSquare(getRandomInteger(1, 10), getRandomInteger(100, 900));
2022-10-14 13:53:05 +02:00
}
2023-03-24 14:11:08 +01:00
}, time);
}
2022-10-14 13:53:05 +02:00
2023-03-24 14:11:08 +01:00
// Refresh.
setInterval(
function() {
refreshMap();
},
(refresh * 1000)
);
2022-02-11 14:50:57 +01:00
2023-03-24 14:11:08 +01:00
function refreshMap() {
$.ajax({
type: 'GET',
url: '<?php echo ui_get_full_url('ajax.php', false, false, false); ?>',
data: {
page: "operation/heatmap",
method: 'getDataJson',
randomId: randomId,
type: setting['data']['type'],
refresh: setting['data']['refresh'],
filter: setting['data']['filter'],
search: setting['data']['search'],
group: setting['data']['group']
2022-02-11 14:50:57 +01:00
},
2023-03-24 14:11:08 +01:00
dataType: 'json',
success: function(data) {
const total = Object.keys(data).length;
if (total === $(`#svg_${randomId} rect`).length) {
// Object to array.
let lista = Object.values(data);
// randomly sort.
lista = lista.sort(function() {
return Math.random() - 0.5
});
let countPerSecond = total / refresh;
if (countPerSecond < 1) {
countPerSecond = 1;
}
2022-02-11 14:50:57 +01:00
2023-03-24 14:11:08 +01:00
let cont = 0;
let limit = countPerSecond - 1;
const timer = setInterval(
2022-10-14 13:53:05 +02:00
function() {
while (cont <= limit) {
if (typeof lista[cont] !== 'undefined') {
const rect = document.getElementsByName(`${lista[cont]['id']}`);
$(`#${rect[0].id}`).removeClass();
$(`#${rect[0].id}`).addClass(`${lista[cont]['status']} hover`);
2022-02-25 09:41:32 +01:00
}
2022-10-14 13:53:05 +02:00
cont++;
}
limit = limit + countPerSecond;
},
1000
);
2022-02-25 09:41:32 +01:00
2023-03-24 14:11:08 +01:00
setTimeout(
function() {
clearInterval(timer);
},
(refresh * 1000)
);
} else {
location.reload();
2022-02-25 09:41:32 +01:00
}
2023-03-24 14:11:08 +01:00
}
});
}
});
</script>
2022-02-11 14:50:57 +01:00
<?php
echo '</div>';
}
/**
* Setter for filter
*
* @param array $filter Filter.
*
* @return void
*/
public function setFilter(array $filter)
{
$this->filter = $filter;
}
/**
* Setter for type
*
* @param integer $type Type.
*
* @return void
*/
public function setType(int $type)
{
$this->type = $type;
}
/**
* Setter for refresh
*
* @param integer $refresh Refresh.
*
* @return void
*/
public function setRefresh(int $refresh)
{
$this->refresh = $refresh;
}
2022-02-25 09:41:32 +01:00
/**
* Getter for randomId
*
* @return string
*/
public function getRandomId()
{
return $this->randomId;
}
2022-02-11 14:50:57 +01:00
/**
* Get all agents
*
* @return array
*/
protected function getAllAgents()
{
2023-03-14 12:47:10 +01:00
global $config;
2022-02-25 09:41:32 +01:00
$filter['disabled'] = 0;
2022-03-07 13:11:54 +01:00
$alias = '';
2022-02-25 09:41:32 +01:00
if (empty($this->search) === false) {
2022-03-07 13:11:54 +01:00
$alias = ' AND alias LIKE "%'.$this->search.'%"';
2022-02-25 09:41:32 +01:00
}
2023-03-14 12:47:10 +01:00
$id_user_groups = '';
if (users_is_admin() === false) {
$user_groups = array_keys(users_get_groups($config['user'], 'AR', false));
if (empty($user_groups) === false) {
$id_user_groups = ' AND id_grupo IN ('.implode(',', $user_groups).')';
}
}
2022-03-07 13:11:54 +01:00
$id_grupo = '';
2023-03-14 12:52:44 +01:00
if (empty($this->filter) === false && empty(current($this->filter)) === false) {
2022-03-30 10:21:30 +02:00
$id_grupo = ' AND id_grupo IN ('.implode(',', $this->filter).')';
2022-02-25 09:41:32 +01:00
}
2022-02-11 14:50:57 +01:00
// All agents.
2022-03-07 13:11:54 +01:00
$sql = sprintf(
2022-10-17 10:32:28 +02:00
'SELECT DISTINCT id_agente as id,alias,id_grupo,normal_count,warning_count,critical_count,
unknown_count,notinit_count,total_count,fired_count,
(SELECT last_status_change FROM tagente_estado WHERE id_agente = tagente.id_agente
ORDER BY last_status_change DESC LIMIT 1) AS last_status_change
2023-03-14 12:47:10 +01:00
FROM tagente WHERE `disabled` = 0 %s %s %s ORDER BY id_grupo,id_agente ASC',
2022-03-07 13:11:54 +01:00
$alias,
2023-03-14 12:47:10 +01:00
$id_user_groups,
2022-03-07 13:11:54 +01:00
$id_grupo
2022-02-11 14:50:57 +01:00
);
$agents = [];
2023-03-24 14:11:08 +01:00
if (is_metaconsole() === true) {
$nodes = metaconsole_get_connections();
$cont = 0;
foreach ($nodes as $node) {
try {
$nd = new Node($node['id']);
$nd->connect();
$result = db_get_all_rows_sql($sql);
// Agent status.
foreach ($result as $agent) {
if ($agent['total_count'] === 0 || $agent['total_count'] === $agent['notinit_count']) {
$status = 'notinit';
} else if ($agent['critical_count'] > 0) {
$status = 'critical';
} else if ($agent['warning_count'] > 0) {
$status = 'warning';
} else if ($agent['unknown_count'] > 0) {
$status = 'unknown';
} else {
$status = 'normal';
}
if ($agent['last_status_change'] != 0) {
$seconds = (time() - $agent['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
}
2022-02-11 14:50:57 +01:00
2023-03-24 14:11:08 +01:00
$agents[$cont] = $agent;
$agents[$cont]['status'] = $status;
$agents[$cont]['server'] = $node['id'];
++$cont;
}
} catch (\Exception $e) {
$nd->disconnect();
$agents = [];
} finally {
$nd->disconnect();
2022-03-07 13:11:54 +01:00
}
}
2023-03-24 14:11:08 +01:00
} else {
$result = db_get_all_rows_sql($sql);
// Agent status.
foreach ($result as $key => $agent) {
if ($agent['total_count'] === 0 || $agent['total_count'] === $agent['notinit_count']) {
$status = 'notinit';
} else if ($agent['critical_count'] > 0) {
$status = 'critical';
} else if ($agent['warning_count'] > 0) {
$status = 'warning';
} else if ($agent['unknown_count'] > 0) {
$status = 'unknown';
} else {
$status = 'normal';
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
if ($agent['last_status_change'] != 0) {
$seconds = (time() - $agent['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
}
$agents[$key] = $agent;
$agents[$key]['status'] = $status;
}
2022-02-11 14:50:57 +01:00
}
2022-03-07 13:11:54 +01:00
return $agents;
}
/**
* Get all modules
*
* @return array
*/
protected function getAllModulesByGroup()
{
2023-03-14 12:47:10 +01:00
global $config;
2022-03-07 13:11:54 +01:00
$filter_group = '';
2023-11-13 10:42:25 +01:00
if (empty($this->filter) === false && current($this->filter) != -1
&& implode(',', $this->filter) !== ''
) {
2022-03-30 10:21:30 +02:00
$filter_group = 'AND am.id_module_group IN ('.implode(',', $this->filter).')';
2023-11-13 10:42:25 +01:00
} else {
return false;
2022-02-11 14:50:57 +01:00
}
2022-03-07 13:11:54 +01:00
$filter_name = '';
if (empty($this->search) === false) {
$filter_name = 'AND nombre LIKE "%'.$this->search.'%"';
}
2023-03-14 12:47:10 +01:00
$id_user_groups = '';
if (users_is_admin() === false) {
$user_groups = array_keys(users_get_groups($config['user'], 'AR', false));
if (empty($user_groups) === false) {
$id_user_groups = sprintf(
'INNER JOIN tagente a ON a.id_agente = ae.id_agente
AND a.id_grupo IN (%s)',
implode(',', $user_groups)
);
}
}
2022-03-07 13:11:54 +01:00
// All modules.
$sql = sprintf(
2022-10-17 10:32:28 +02:00
'SELECT am.id_agente_modulo AS id, ae.estado AS `status`, am.id_module_group AS id_grupo,
ae.last_status_change FROM tagente_modulo am
2022-03-07 13:11:54 +01:00
INNER JOIN tagente_estado ae ON am.id_agente_modulo = ae.id_agente_modulo
2023-03-14 12:47:10 +01:00
%s
2022-03-07 13:11:54 +01:00
WHERE am.disabled = 0 %s %s GROUP BY am.id_module_group, am.id_agente_modulo',
2023-03-14 12:47:10 +01:00
$id_user_groups,
2022-03-07 13:11:54 +01:00
$filter_group,
$filter_name
);
2023-03-24 14:11:08 +01:00
if (is_metaconsole() === true) {
$nodes = metaconsole_get_connections();
$cont = 0;
$result = [];
foreach ($nodes as $node) {
try {
$nd = new Node($node['id']);
$nd->connect();
$modules = db_get_all_rows_sql($sql);
// Module status.
foreach ($modules as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
$result[$cont] = $module;
$result[$cont]['status'] = $status;
$result[$cont]['server'] = $node['id'];
++$cont;
}
} catch (\Exception $e) {
$nd->disconnect();
} finally {
$nd->disconnect();
}
2022-03-07 13:11:54 +01:00
}
2023-03-24 14:11:08 +01:00
} else {
$result = db_get_all_rows_sql($sql);
// Module status.
foreach ($result as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
2022-03-07 13:11:54 +01:00
}
2023-03-24 14:11:08 +01:00
$result[$key]['status'] = $status;
}
2022-03-07 13:11:54 +01:00
}
return $result;
}
/**
* Get all modules
*
* @return array
*/
protected function getAllModulesByTag()
{
2023-03-14 12:47:10 +01:00
global $config;
2022-03-07 13:11:54 +01:00
$filter_tag = '';
if (empty($this->filter) === false && $this->filter[0] !== '0') {
2022-03-30 10:21:30 +02:00
$tags = implode(',', $this->filter);
$filter_tag .= ' AND tm.id_tag IN ('.$tags.')';
2022-03-07 13:11:54 +01:00
}
$filter_name = '';
if (empty($this->search) === false) {
$filter_name = 'AND nombre LIKE "%'.$this->search.'%"';
}
2023-03-14 12:47:10 +01:00
$id_user_groups = '';
if (users_is_admin() === false) {
$user_groups = array_keys(users_get_groups($config['user'], 'AR', false));
if (empty($user_groups) === false) {
$id_user_groups = sprintf(
'INNER JOIN tagente a ON a.id_agente = ae.id_agente
AND a.id_grupo IN (%s)',
implode(',', $user_groups)
);
}
}
2022-03-07 13:11:54 +01:00
// All modules.
$sql = sprintf(
2022-10-17 10:32:28 +02:00
'SELECT ae.id_agente_modulo AS id, ae.estado AS `status`, tm.id_tag AS id_grupo,
ae.last_status_change FROM tagente_estado ae
2023-03-14 12:47:10 +01:00
%s
2022-03-07 13:11:54 +01:00
INNER JOIN ttag_module tm ON tm.id_agente_modulo = ae.id_agente_modulo
2023-03-24 14:11:08 +01:00
WHERE 1=1 %s %s GROUP BY ae.id_agente_modulo',
2023-03-14 12:47:10 +01:00
$id_user_groups,
2022-03-07 13:11:54 +01:00
$filter_tag,
$filter_name
);
2023-03-24 14:11:08 +01:00
if (is_metaconsole() === true) {
$nodes = metaconsole_get_connections();
$result = [];
$cont = 0;
foreach ($nodes as $node) {
try {
$nd = new Node($node['id']);
$nd->connect();
$modules = db_get_all_rows_sql($sql);
// Module status.
foreach ($modules as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
$result[$cont] = $module;
$result[$cont]['status'] = $status;
$result[$cont]['server'] = $node['id'];
++$cont;
}
} catch (\Exception $e) {
$nd->disconnect();
} finally {
$nd->disconnect();
}
2022-03-07 13:11:54 +01:00
}
2023-03-24 14:11:08 +01:00
} else {
$result = db_get_all_rows_sql($sql);
// Module status.
foreach ($result as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-03-07 13:11:54 +01:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
2022-03-07 13:11:54 +01:00
}
2023-03-24 14:11:08 +01:00
$result[$key]['status'] = $status;
}
2022-03-07 13:11:54 +01:00
}
return $result;
}
2022-10-14 13:53:05 +02:00
/**
* Get all modules group by agents
*
* @return array
*/
protected function getAllModulesByAgents()
{
2023-03-14 12:47:10 +01:00
global $config;
2022-10-14 13:53:05 +02:00
$filter_name = '';
if (empty($this->search) === false) {
$filter_name = 'AND nombre LIKE "%'.$this->search.'%"';
}
2023-03-14 12:47:10 +01:00
$id_user_groups = '';
if (users_is_admin() === false) {
$user_groups = array_keys(users_get_groups($config['user'], 'AR', false));
if (empty($user_groups) === false) {
2023-04-04 15:14:10 +02:00
if (empty($this->filter) === false && empty(current($this->filter)) === false) {
$user_groups = array_intersect($this->filter, $user_groups);
$id_user_groups = sprintf(
'INNER JOIN tagente a ON a.id_agente = ae.id_agente
AND a.id_grupo IN (%s)',
implode(',', $user_groups)
);
} else {
$id_user_groups = sprintf(
'INNER JOIN tagente a ON a.id_agente = ae.id_agente
AND a.id_grupo IN (%s)',
implode(',', $user_groups)
);
}
}
} else {
if (empty($this->filter) === false && empty(current($this->filter)) === false) {
2023-03-14 12:47:10 +01:00
$id_user_groups = sprintf(
'INNER JOIN tagente a ON a.id_agente = ae.id_agente
AND a.id_grupo IN (%s)',
2023-04-04 15:14:10 +02:00
implode(',', $this->filter)
2023-03-14 12:47:10 +01:00
);
}
}
2022-10-14 13:53:05 +02:00
// All modules.
$sql = sprintf(
2022-10-17 10:32:28 +02:00
'SELECT am.id_agente_modulo AS id, ae.estado AS `status`, am.id_agente AS id_grupo,
ae.last_status_change FROM tagente_modulo am
2022-10-14 13:53:05 +02:00
INNER JOIN tagente_estado ae ON am.id_agente_modulo = ae.id_agente_modulo
2023-03-14 12:47:10 +01:00
%s
2022-10-14 13:53:05 +02:00
WHERE am.disabled = 0 %s GROUP BY ae.id_agente_modulo ORDER BY id_grupo',
2023-03-14 12:47:10 +01:00
$id_user_groups,
2022-10-14 13:53:05 +02:00
$filter_name
);
2023-03-24 14:11:08 +01:00
if (is_metaconsole() === true) {
$result = [];
$nodes = metaconsole_get_connections();
$cont = 0;
foreach ($nodes as $node) {
try {
$nd = new Node($node['id']);
$nd->connect();
$modules = db_get_all_rows_sql($sql);
// Module status.
foreach ($modules as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-10-14 13:53:05 +02:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
}
2022-10-14 13:53:05 +02:00
2023-03-24 14:11:08 +01:00
$result[$cont] = $module;
$result[$cont]['status'] = $status;
$result[$cont]['server'] = $node['id'];
++$cont;
}
} catch (\Exception $e) {
$nd->disconnect();
$result = [];
} finally {
$nd->disconnect();
}
2022-10-14 13:53:05 +02:00
}
2023-03-24 14:11:08 +01:00
} else {
$result = db_get_all_rows_sql($sql);
// Module status.
foreach ($result as $key => $module) {
$status = '';
switch ($module['status']) {
case AGENT_MODULE_STATUS_CRITICAL_BAD:
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
case 1:
case 100:
$status = 'critical';
break;
case AGENT_MODULE_STATUS_NORMAL:
case AGENT_MODULE_STATUS_NORMAL_ALERT:
case 0:
case 300:
$status = 'normal';
break;
case AGENT_MODULE_STATUS_WARNING:
case AGENT_MODULE_STATUS_WARNING_ALERT:
case 2:
case 200:
$status = 'warning';
break;
default:
case AGENT_MODULE_STATUS_UNKNOWN:
case 3:
$status = 'unknown';
break;
case AGENT_MODULE_STATUS_NO_DATA:
2023-03-24 14:11:08 +01:00
case AGENT_MODULE_STATUS_NOT_INIT:
case 5:
$status = 'notinit';
break;
}
2022-10-14 13:53:05 +02:00
2023-03-24 14:11:08 +01:00
if ($module['last_status_change'] != 0) {
$seconds = (time() - $module['last_status_change']);
if ($seconds >= SECONDS_1DAY) {
$status .= '_10';
} else if ($seconds >= 77760) {
$status .= '_9';
} else if ($seconds >= 69120) {
$status .= '_8';
} else if ($seconds >= 60480) {
$status .= '_7';
} else if ($seconds >= 51840) {
$status .= '_6';
} else if ($seconds >= 43200) {
$status .= '_5';
} else if ($seconds >= 34560) {
$status .= '_4';
} else if ($seconds >= 25920) {
$status .= '_3';
} else if ($seconds >= 17280) {
$status .= '_2';
} else if ($seconds >= 8640) {
$status .= '_1';
}
2022-10-14 13:53:05 +02:00
}
2023-03-24 14:11:08 +01:00
$result[$key]['status'] = $status;
}
2022-10-14 13:53:05 +02:00
}
return $result;
}
2022-03-07 13:11:54 +01:00
/**
* GetData
*
* @return array
*/
public function getData()
{
switch ($this->type) {
2022-10-14 13:53:05 +02:00
case 3:
$data = $this->getAllModulesByAgents();
break;
2022-03-07 13:11:54 +01:00
case 2:
$data = $this->getAllModulesByGroup();
break;
case 1:
$data = $this->getAllModulesByTag();
break;
case 0:
default:
$data = $this->getAllAgents();
break;
}
return $data;
2022-02-11 14:50:57 +01:00
}
/**
* GetDataJson
*
* @return json
*/
public function getDataJson()
{
2022-03-07 13:11:54 +01:00
$return = $this->getData();
2022-02-11 14:50:57 +01:00
echo json_encode($return);
2022-02-25 09:41:32 +01:00
return '';
2022-02-11 14:50:57 +01:00
}
/**
2022-02-25 09:41:32 +01:00
* Get class by status
2022-02-11 14:50:57 +01:00
*
* @param integer $status Status.
*
* @return string
*/
protected function statusColour(int $status)
{
switch ($status) {
case AGENT_STATUS_CRITICAL:
$return = 'critical';
break;
case AGENT_STATUS_WARNING:
$return = 'warning';
break;
case AGENT_STATUS_UNKNOWN:
$return = 'unknown';
break;
case AGENT_STATUS_NOT_INIT:
$return = 'notinit';
break;
case AGENT_STATUS_NORMAL:
default:
$return = 'normal';
break;
}
return $return;
}
/**
* Get max. number of y-axis
*
2022-02-25 09:41:32 +01:00
* @param integer $total Total.
* @param float $relation Aspect relation.
2022-02-11 14:50:57 +01:00
*
* @return integer
*/
2022-02-25 09:41:32 +01:00
protected function getYAxis(int $total, float $relation)
2022-02-11 14:50:57 +01:00
{
2022-02-25 09:41:32 +01:00
$yAxis = sqrt(($total / $relation));
return $yAxis;
2022-02-11 14:50:57 +01:00
}
/**
* Checks if target method is available to be called using AJAX.
*
* @param string $method Target method.
*
* @return boolean True allowed, false not.
*/
2023-03-24 14:11:08 +01:00
public function ajaxMethod(string $method): bool
2022-02-11 14:50:57 +01:00
{
return in_array($method, $this->AJAXMethods);
}
/**
* ShowHeatmap
*
* @return void
*/
public function showHeatmap()
{
2022-03-07 13:11:54 +01:00
$result = $this->getData();
2022-02-11 14:50:57 +01:00
2022-03-30 10:21:30 +02:00
if (empty($result) === true) {
echo '<div style="position: absolute; top:70px; left:20px">'.__('No data found').'</div>';
return;
}
2022-02-25 09:41:32 +01:00
2022-03-30 10:21:30 +02:00
$count_result = count($result);
$scale = ($this->width / $this->height);
$Yaxis = $this->getYAxis($count_result, $scale);
2023-10-04 15:42:19 +02:00
$Yaxis_font_scale = $Yaxis;
2022-03-30 10:21:30 +02:00
if ($count_result <= 3) {
$Xaxis = $count_result;
$Yaxis = 1;
} else {
$Xaxis = (int) ceil($Yaxis * $scale);
$Yaxis = ceil($Yaxis);
}
2022-02-25 09:41:32 +01:00
2022-02-11 14:50:57 +01:00
$viewBox = sprintf(
'0 0 %d %d',
$Xaxis,
$Yaxis
);
2022-03-07 13:11:54 +01:00
echo '<svg id="svg_'.$this->randomId.'" width="'.$this->width.'"
2022-02-25 09:41:32 +01:00
height="'.$this->height.'" viewBox="'.$viewBox.'">';
2022-02-11 14:50:57 +01:00
2022-02-25 09:41:32 +01:00
$groups = [];
2022-02-11 14:50:57 +01:00
$contX = 0;
$contY = 0;
2022-10-14 13:53:05 +02:00
$cont = 1;
2022-02-25 09:41:32 +01:00
foreach ($result as $value) {
2023-03-24 14:11:08 +01:00
$name = $value['id'];
if (empty($value['server']) === false) {
$name .= '|'.$value['server'];
}
2022-10-14 13:53:05 +02:00
echo '<rect id="'.$this->randomId.'_'.$cont.'" class="'.$value['status'].' hover"
2023-03-24 14:11:08 +01:00
width="1" height="1" x ="'.$contX.' "y="'.$contY.'" name="'.$name.'" />';
2022-02-11 14:50:57 +01:00
2022-02-25 09:41:32 +01:00
$contX++;
if ($contX >= $Xaxis) {
$contY++;
$contX = 0;
}
if (empty($groups[$value['id_grupo']]) === true) {
$groups[$value['id_grupo']] = 1;
} else {
$groups[$value['id_grupo']] += 1;
}
2022-10-14 13:53:05 +02:00
$cont++;
2022-02-25 09:41:32 +01:00
}
?>
2023-03-24 14:11:08 +01:00
<script type="text/javascript">
$('rect').click(function() {
const type = <?php echo $this->type; ?>;
const name = $(`#${this.id}`).attr("name");
const id = name.split('|')[0];
const server = name.split('|')[1];
2023-04-04 15:14:10 +02:00
let height = 400;
let width = 530;
switch (type) {
case 0:
height = 670;
width = 460;
break;
case 2:
case 3:
height = 450;
width = 460;
break;
default:
break;
}
2023-03-24 14:11:08 +01:00
$("#info_dialog").dialog({
resizable: true,
draggable: true,
modal: true,
closeOnEscape: true,
2023-04-04 15:14:10 +02:00
height: height,
width: width,
2023-03-24 14:11:08 +01:00
title: '<?php echo __('Info'); ?>',
open: function() {
$.ajax({
type: 'GET',
url: '<?php echo ui_get_full_url('ajax.php', false, false, false); ?>',
data: {
page: "include/ajax/heatmap.ajax",
getInfo: 1,
type: type,
id: id,
id_server: server,
},
dataType: 'html',
success: function(data) {
$('#info_dialog').empty();
$('#info_dialog').append(data);
}
});
},
2022-02-25 09:41:32 +01:00
});
2023-03-24 14:11:08 +01:00
});
</script>
2022-02-25 09:41:32 +01:00
<?php
2023-03-14 12:47:10 +01:00
if (count($groups) > 1 && $this->group === 1 && $this->dashboard === false) {
2022-03-07 13:11:54 +01:00
$x_back = 0;
$y_back = 0;
2023-10-04 15:42:19 +02:00
$x_text_correction = 0.08;
2022-03-07 13:11:54 +01:00
2023-04-05 12:25:33 +02:00
if ($count_result <= 10) {
2023-10-04 15:42:19 +02:00
$fontSize = 0.2;
2022-03-30 10:21:30 +02:00
$stroke = 'small-stroke';
2023-04-05 12:25:33 +02:00
} else if ($count_result > 10 && $count_result <= 100) {
2023-10-04 15:42:19 +02:00
$fontSize = 0.18;
2023-04-05 12:25:33 +02:00
$stroke = 'tiny-stroke';
} else if ($count_result > 100 && $count_result <= 1000) {
2023-10-04 15:42:19 +02:00
$fontSize = 0.16;
2023-04-05 12:25:33 +02:00
$stroke = 'medium-stroke';
} else if ($count_result > 1000 && $count_result <= 10000) {
2023-10-04 15:42:19 +02:00
$fontSize = 0.14;
2022-03-30 10:21:30 +02:00
$stroke = 'big-stroke';
2023-04-05 12:25:33 +02:00
} else {
2023-10-04 15:42:19 +02:00
$fontSize = 0.12;
2023-04-05 12:25:33 +02:00
$stroke = 'huge-stroke';
2022-03-30 10:21:30 +02:00
}
echo '<polyline points="0,0 '.$Xaxis.',0" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
foreach ($groups as $key => $group) {
$name = '';
switch ($this->type) {
2022-10-14 13:53:05 +02:00
case 3:
$name = agents_get_alias($key);
break;
2022-03-07 13:11:54 +01:00
case 2:
$name = modules_get_modulegroup_name($key);
break;
case 1:
$name = tags_get_name($key);
break;
case 0:
default:
$name = groups_get_name($key);
break;
}
2022-02-25 09:41:32 +01:00
2022-03-07 13:11:54 +01:00
if (($x_back + $group) <= $Xaxis) {
$x_position = ($x_back + $group);
$y_position = $y_back;
2022-02-25 09:41:32 +01:00
2022-03-07 13:11:54 +01:00
if ($y_back === 0 && $x_back === 0) {
$points = sprintf(
'%d,%d %d,%d',
$x_back,
$y_back,
$x_back,
($y_back + 1)
);
2022-02-25 09:41:32 +01:00
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-02-25 09:41:32 +01:00
}
$points = sprintf(
2022-03-07 13:11:54 +01:00
'%d,%d %d,%d %d,%d',
$x_back,
2022-02-25 09:41:32 +01:00
($y_position + 1),
$x_position,
2022-03-07 13:11:54 +01:00
($y_position + 1),
$x_position,
$y_back
2022-02-25 09:41:32 +01:00
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-02-25 09:41:32 +01:00
2022-03-07 13:11:54 +01:00
// Name.
2023-04-05 12:25:33 +02:00
echo '<text x="'.((($x_position - $x_back) / 2) + $x_back - $x_text_correction).'" y="'.($y_position + 1 - 0.01).'"
2023-10-04 15:42:19 +02:00
style="font-size: '.($fontSize * $Yaxis_font_scale).'%">'.$name.'</text>';
2022-02-25 09:41:32 +01:00
2022-03-07 13:11:54 +01:00
$x_back = $x_position;
if ($x_position === $Xaxis) {
$points = sprintf(
'%d,%d %d,%d',
$x_position,
$y_back,
$x_position,
($y_back + 1)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
$y_back++;
$x_back = 0;
}
} else {
$round = (int) floor(($x_back + $group) / $Xaxis);
$y_position = ($round + $y_back);
if ($round === 1) {
// One line.
$x_position = (($x_back + $group) - $Xaxis);
if ($x_position <= $x_back) {
// Bottom line.
$points = sprintf(
'%d,%d %d,%d',
$x_back,
$y_position,
$Xaxis,
($y_position)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
}
// Bottom of last line.
$points = sprintf(
'%d,%d %d,%d',
0,
($y_position + 1),
$x_position,
($y_position + 1)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
// Name.
2023-04-05 12:25:33 +02:00
echo '<text x="'.(($x_position) / 2 - $x_text_correction).'" y="'.($y_position + 1 - 0.01).'"
2023-10-04 15:42:19 +02:00
style="font-size: '.($fontSize * $Yaxis_font_scale).'%">'.$name.'</text>';
2022-03-07 13:11:54 +01:00
// Bottom-right of last line.
$points = sprintf(
'%d,%d %d,%d',
$x_position,
($y_position),
$x_position,
($y_position + 1)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
if ($x_position > $x_back) {
// Bottom-top of last line.
$points = sprintf(
'%d,%d %d,%d',
$x_position,
($y_position),
$Xaxis,
($y_position)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
}
} else {
// Two or more lines.
$x_position = (($x_back + $group) - ($Xaxis * $round));
if ($x_position === 0) {
$x_position = $Xaxis;
}
// Bottom of last line.
$points = sprintf(
'%d,%d %d,%d',
0,
($y_position + 1),
$x_position,
($y_position + 1)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
// Bottom-right of last line.
$points = sprintf(
'%d,%d %d,%d',
$x_position,
($y_position),
$x_position,
($y_position + 1)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
// Name.
2023-04-05 12:25:33 +02:00
echo '<text x="'.(($x_position) / 2 - $x_text_correction).'" y="'.($y_position + 1 - 0.02).'"
2023-10-04 15:42:19 +02:00
style="font-size: '.($fontSize * $Yaxis_font_scale).'%">'.$name.'</text>';
2022-03-07 13:11:54 +01:00
// Bottom-top of last line.
$points = sprintf(
'%d,%d %d,%d',
$x_position,
($y_position),
$Xaxis,
($y_position)
);
2022-03-30 10:21:30 +02:00
echo '<polyline points="'.$points.'" class="polyline '.$stroke.'" />';
2022-03-07 13:11:54 +01:00
}
if ($x_position === $Xaxis) {
$x_position = 0;
}
$x_back = $x_position;
$y_back = $y_position;
}
2022-02-11 14:50:57 +01:00
}
}
echo '</svg>';
2022-02-25 09:41:32 +01:00
// Dialog.
2023-03-14 12:47:10 +01:00
echo '<div id="info_dialog"></div>';
2022-02-11 14:50:57 +01:00
}
}