mirror of
https://github.com/pandorafms/pandorafms.git
synced 2025-07-29 08:45:12 +02:00
#8928 Added os quick report
This commit is contained in:
parent
13b15db341
commit
2fb2853cd1
@ -14,54 +14,190 @@
|
|||||||
// Get critical agents by using the status code in modules.
|
// Get critical agents by using the status code in modules.
|
||||||
function os_agents_critical($id_os)
|
function os_agents_critical($id_os)
|
||||||
{
|
{
|
||||||
// TODO REVIEW ORACLE AND POSTGRES
|
global $config;
|
||||||
|
|
||||||
|
$table = (is_metaconsole() === true) ? 'tmetaconsole_agent' : 'tagente';
|
||||||
|
|
||||||
|
if (users_is_admin() === true) {
|
||||||
return db_get_sql(
|
return db_get_sql(
|
||||||
"
|
sprintf(
|
||||||
SELECT COUNT(*)
|
'SELECT COUNT(*)
|
||||||
FROM tagente
|
FROM %s
|
||||||
WHERE tagente.disabled=0 AND
|
WHERE tagente.disabled=0 AND
|
||||||
critical_count>0 AND id_os=$id_os"
|
critical_count>0 AND id_os=%d',
|
||||||
|
$table,
|
||||||
|
$id_os
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
} else {
|
||||||
|
$groups = array_keys(users_get_groups($config['id_user'], 'AR', false));
|
||||||
|
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND
|
||||||
|
critical_count>0 AND
|
||||||
|
id_os=%d AND id_grupo IN (%s)',
|
||||||
|
$table,
|
||||||
|
$id_os,
|
||||||
|
implode(',', $groups)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Get ok agents by using the status code in modules.
|
// Get ok agents by using the status code in modules.
|
||||||
function os_agents_ok($id_os)
|
function os_agents_ok($id_os)
|
||||||
{
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
$table = (is_metaconsole() === true) ? 'tmetaconsole_agent' : 'tagente';
|
||||||
|
|
||||||
|
if (users_is_admin() === true) {
|
||||||
return db_get_sql(
|
return db_get_sql(
|
||||||
"
|
sprintf(
|
||||||
SELECT COUNT(*)
|
'SELECT COUNT(*)
|
||||||
FROM tagente
|
FROM %s
|
||||||
WHERE tagente.disabled=0 AND
|
WHERE tagente.disabled=0 AND
|
||||||
normal_count=total_count AND id_os=$id_os"
|
normal_count=total_count AND id_os=%d',
|
||||||
|
$table,
|
||||||
|
$id_os
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
} else {
|
||||||
|
$groups = array_keys(users_get_groups($config['id_user'], 'AR', false));
|
||||||
|
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND
|
||||||
|
normal_count=total_count AND
|
||||||
|
id_os=%d AND id_grupo IN (%s)',
|
||||||
|
$table,
|
||||||
|
$id_os,
|
||||||
|
implode(',', $groups)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Get warning agents by using the status code in modules.
|
// Get warning agents by using the status code in modules.
|
||||||
function os_agents_warning($id_os)
|
function os_agents_warning($id_os)
|
||||||
{
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
$table = (is_metaconsole() === true) ? 'tmetaconsole_agent' : 'tagente';
|
||||||
|
|
||||||
|
if (users_is_admin() === true) {
|
||||||
return db_get_sql(
|
return db_get_sql(
|
||||||
"
|
sprintf(
|
||||||
SELECT COUNT(*)
|
'SELECT COUNT(*)
|
||||||
FROM tagente
|
FROM %s
|
||||||
WHERE tagente.disabled=0 AND
|
WHERE tagente.disabled=0 AND
|
||||||
critical_count=0 AND warning_count>0 AND id_os=$id_os"
|
critical_count=0 AND warning_count>0
|
||||||
|
AND id_os=%d',
|
||||||
|
$table,
|
||||||
|
$id_os
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
} else {
|
||||||
|
$groups = array_keys(users_get_groups($config['id_user'], 'AR', false));
|
||||||
|
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND
|
||||||
|
critical_count=0 AND warning_count>0 AND
|
||||||
|
id_os=%d AND id_grupo IN (%s)',
|
||||||
|
$table,
|
||||||
|
$id_os,
|
||||||
|
implode(',', $groups)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Get unknown agents by using the status code in modules.
|
// Get unknown agents by using the status code in modules.
|
||||||
function os_agents_unknown($id_os)
|
function os_agents_unknown($id_os)
|
||||||
{
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
$table = (is_metaconsole() === true) ? 'tmetaconsole_agent' : 'tagente';
|
||||||
|
|
||||||
|
if (users_is_admin() === true) {
|
||||||
return db_get_sql(
|
return db_get_sql(
|
||||||
"
|
sprintf(
|
||||||
SELECT COUNT(*)
|
'SELECT COUNT(*)
|
||||||
FROM tagente
|
FROM %s
|
||||||
WHERE tagente.disabled=0 AND
|
WHERE tagente.disabled=0 AND
|
||||||
critical_count=0 AND warning_count=0 AND
|
critical_count=0 AND warning_count=0 AND
|
||||||
unknown_count>0 AND id_os=$id_os"
|
unknown_count>0 AND id_os=%d',
|
||||||
|
$table,
|
||||||
|
$id_os
|
||||||
|
)
|
||||||
);
|
);
|
||||||
|
} else {
|
||||||
|
$groups = array_keys(users_get_groups($config['id_user'], 'AR', false));
|
||||||
|
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND
|
||||||
|
critical_count=0 AND warning_count=0 AND
|
||||||
|
unknown_count>0 AND id_os=%d AND id_grupo IN (%s)',
|
||||||
|
$table,
|
||||||
|
$id_os,
|
||||||
|
implode(',', $groups)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get total agents
|
||||||
|
*
|
||||||
|
* @param integer $id_os OS id.
|
||||||
|
*
|
||||||
|
* @return array|boolean
|
||||||
|
*/
|
||||||
|
function os_agents_total(int $id_os)
|
||||||
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
$table = (is_metaconsole() === true) ? 'tmetaconsole_agent' : 'tagente';
|
||||||
|
|
||||||
|
if (users_is_admin() === true) {
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND id_os=%d',
|
||||||
|
$table,
|
||||||
|
$id_os
|
||||||
|
)
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$groups = array_keys(users_get_groups($config['id_user'], 'AR', false));
|
||||||
|
|
||||||
|
return db_get_sql(
|
||||||
|
sprintf(
|
||||||
|
'SELECT COUNT(*)
|
||||||
|
FROM %s
|
||||||
|
WHERE tagente.disabled=0 AND id_os=%d AND id_grupo IN (%s)',
|
||||||
|
$table,
|
||||||
|
$id_os,
|
||||||
|
implode(',', $groups)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -412,6 +412,10 @@ class Widget
|
|||||||
$className .= '\WuxWidget';
|
$className .= '\WuxWidget';
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'os_quick_report':
|
||||||
|
$className .= '\OsQuickReportWidget';
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
$className = false;
|
$className = false;
|
||||||
break;
|
break;
|
||||||
|
@ -0,0 +1,344 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Widget Tree view Pandora FMS Console
|
||||||
|
*
|
||||||
|
* @category Console Class
|
||||||
|
* @package Pandora FMS
|
||||||
|
* @subpackage Widget Tree view
|
||||||
|
* @version 1.0.0
|
||||||
|
* @license See below
|
||||||
|
*
|
||||||
|
* ______ ___ _______ _______ ________
|
||||||
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
||||||
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
||||||
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
||||||
|
*
|
||||||
|
* ============================================================================
|
||||||
|
* Copyright (c) 2005-2022 Artica Soluciones Tecnologicas
|
||||||
|
* Please see http://pandorafms.org for full contribution list
|
||||||
|
* 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.
|
||||||
|
* ============================================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace PandoraFMS\Dashboard;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OS quick report Widgets.
|
||||||
|
*/
|
||||||
|
class OsQuickReportWidget extends Widget
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Name widget.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Title widget.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $title;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Page widget;
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $page;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class name widget.
|
||||||
|
*
|
||||||
|
* @var [type]
|
||||||
|
*/
|
||||||
|
protected $className;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Values options for each widget.
|
||||||
|
*
|
||||||
|
* @var [type]
|
||||||
|
*/
|
||||||
|
protected $values;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configuration required.
|
||||||
|
*
|
||||||
|
* @var boolean
|
||||||
|
*/
|
||||||
|
protected $configurationRequired;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Error load widget.
|
||||||
|
*
|
||||||
|
* @var boolean
|
||||||
|
*/
|
||||||
|
protected $loadError;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Width.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
protected $width;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Heigth.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
protected $height;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dashboard ID.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
protected $dashboardId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cell ID.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
protected $cellId;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct.
|
||||||
|
*
|
||||||
|
* @param integer $cellId Cell ID.
|
||||||
|
* @param integer $dashboardId Dashboard ID.
|
||||||
|
* @param integer $widgetId Widget ID.
|
||||||
|
* @param integer|null $width New width.
|
||||||
|
* @param integer|null $height New height.
|
||||||
|
*/
|
||||||
|
public function __construct(
|
||||||
|
int $cellId,
|
||||||
|
int $dashboardId=0,
|
||||||
|
int $widgetId=0,
|
||||||
|
?int $width=0,
|
||||||
|
?int $height=0
|
||||||
|
) {
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
// Includes.
|
||||||
|
enterprise_include_once('/include/functions_services.php');
|
||||||
|
enterprise_include_once('/include/functions_servicemap.php');
|
||||||
|
|
||||||
|
// WARNING: Do not edit. This chunk must be in the constructor.
|
||||||
|
parent::__construct(
|
||||||
|
$cellId,
|
||||||
|
$dashboardId,
|
||||||
|
$widgetId
|
||||||
|
);
|
||||||
|
|
||||||
|
// Width.
|
||||||
|
$this->width = $width;
|
||||||
|
|
||||||
|
// Height.
|
||||||
|
$this->height = $height;
|
||||||
|
|
||||||
|
// Cell Id.
|
||||||
|
$this->cellId = $cellId;
|
||||||
|
|
||||||
|
// Widget ID.
|
||||||
|
$this->widgetId = $widgetId;
|
||||||
|
|
||||||
|
// Dashboard ID.
|
||||||
|
$this->dashboardId = $dashboardId;
|
||||||
|
|
||||||
|
// Options.
|
||||||
|
$this->values = $this->decoders($this->getOptionsWidget());
|
||||||
|
|
||||||
|
// Positions.
|
||||||
|
$this->position = $this->getPositionWidget();
|
||||||
|
|
||||||
|
// Page.
|
||||||
|
$this->page = basename(__FILE__);
|
||||||
|
|
||||||
|
// ClassName.
|
||||||
|
$class = new \ReflectionClass($this);
|
||||||
|
$this->className = $class->getShortName();
|
||||||
|
|
||||||
|
// Title.
|
||||||
|
$this->title = __('OS quick report');
|
||||||
|
|
||||||
|
// Name.
|
||||||
|
if (empty($this->name) === true) {
|
||||||
|
$this->name = 'os_quick_report';
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->overflow_scrollbars = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Decoders hack for retrocompability.
|
||||||
|
*
|
||||||
|
* @param array $decoder Values.
|
||||||
|
*
|
||||||
|
* @return array Returns the values with the correct key.
|
||||||
|
*/
|
||||||
|
public function decoders(array $decoder): array
|
||||||
|
{
|
||||||
|
$values = [];
|
||||||
|
// Retrieve global - common inputs.
|
||||||
|
$values = parent::decoders($decoder);
|
||||||
|
|
||||||
|
return $values;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates inputs for form (specific).
|
||||||
|
*
|
||||||
|
* @return array Of inputs.
|
||||||
|
*
|
||||||
|
* @throws Exception On error.
|
||||||
|
*/
|
||||||
|
public function getFormInputs(): array
|
||||||
|
{
|
||||||
|
// Retrieve global - common inputs.
|
||||||
|
$inputs = parent::getFormInputs();
|
||||||
|
|
||||||
|
return $inputs;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get Post for widget.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getPost():array
|
||||||
|
{
|
||||||
|
// Retrieve global - common inputs.
|
||||||
|
$values = parent::getPost();
|
||||||
|
|
||||||
|
return $values;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Draw widget.
|
||||||
|
*
|
||||||
|
* @return string;
|
||||||
|
*/
|
||||||
|
public function load()
|
||||||
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
$values = $this->values;
|
||||||
|
|
||||||
|
$result = [];
|
||||||
|
$os_array = os_get_os();
|
||||||
|
foreach ($os_array as $os) {
|
||||||
|
$id_os = (int) $os['id_os'];
|
||||||
|
$total = os_agents_total($id_os);
|
||||||
|
if ((int) $total === 0) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result[$id_os]['name'] = $os['name'];
|
||||||
|
$result[$id_os]['total'] = (int) $total;
|
||||||
|
$result[$id_os]['normal'] = (int) os_agents_ok($id_os);
|
||||||
|
$result[$id_os]['critical'] = (int) os_agents_critical($id_os);
|
||||||
|
$result[$id_os]['unknown'] = (int) os_agents_unknown($id_os);
|
||||||
|
}
|
||||||
|
|
||||||
|
$output = '';
|
||||||
|
if (empty($result) === false) {
|
||||||
|
$table = new \stdClass();
|
||||||
|
|
||||||
|
$table->class = 'info_table';
|
||||||
|
$table->width = '100%';
|
||||||
|
$table->cellpadding = 0;
|
||||||
|
$table->cellspacing = 0;
|
||||||
|
$table->size = [];
|
||||||
|
|
||||||
|
$table->align = [];
|
||||||
|
$table->align[0] = 'left';
|
||||||
|
$table->align[1] = 'left';
|
||||||
|
$table->align[2] = 'left';
|
||||||
|
$table->align[3] = 'left';
|
||||||
|
$table->align[4] = 'left';
|
||||||
|
$table->align[5] = 'left';
|
||||||
|
|
||||||
|
$table->head = [];
|
||||||
|
$table->head[0] = __('OS');
|
||||||
|
$table->head[1] = __('OS name');
|
||||||
|
$table->head[2] = ucfirst(__('total agents'));
|
||||||
|
$table->head[3] = ucfirst(__('normal agents'));
|
||||||
|
$table->head[4] = ucfirst(__('critical agents'));
|
||||||
|
$table->head[5] = ucfirst(__('unknown agents'));
|
||||||
|
|
||||||
|
$table->headstyle = [];
|
||||||
|
$table->headstyle[0] = 'background-color: '.$values['background'];
|
||||||
|
$table->headstyle[1] = 'background-color: '.$values['background'];
|
||||||
|
$table->headstyle[2] = 'background-color: '.$values['background'];
|
||||||
|
$table->headstyle[3] = 'background-color: '.$values['background'];
|
||||||
|
$table->headstyle[4] = 'background-color: '.$values['background'];
|
||||||
|
$table->headstyle[5] = 'background-color: '.$values['background'];
|
||||||
|
|
||||||
|
$table->style = [];
|
||||||
|
$table->style[0] = 'background-color: '.$values['background'];
|
||||||
|
$table->style[1] = 'background-color: '.$values['background'];
|
||||||
|
$table->style[2] = 'background-color: '.$values['background'];
|
||||||
|
$table->style[3] = 'background-color: '.$values['background'];
|
||||||
|
$table->style[4] = 'background-color: '.$values['background'];
|
||||||
|
$table->style[5] = 'background-color: '.$values['background'];
|
||||||
|
|
||||||
|
foreach ($result as $id => $os) {
|
||||||
|
$data = [];
|
||||||
|
|
||||||
|
$data[0] = ui_print_os_icon($id, false, true);
|
||||||
|
$data[1] = $os['name'];
|
||||||
|
$data[2] = $os['total'];
|
||||||
|
$data[3] = $os['normal'];
|
||||||
|
$data[4] = $os['critical'];
|
||||||
|
$data[5] = $os['unknown'];
|
||||||
|
|
||||||
|
$table->data[] = $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
$output = html_print_table($table, true);
|
||||||
|
} else {
|
||||||
|
$output = 'No data available';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $output;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get description.
|
||||||
|
*
|
||||||
|
* @return string.
|
||||||
|
*/
|
||||||
|
public static function getDescription()
|
||||||
|
{
|
||||||
|
return __('OS quick report');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get Name.
|
||||||
|
*
|
||||||
|
* @return string.
|
||||||
|
*/
|
||||||
|
public static function getName()
|
||||||
|
{
|
||||||
|
return 'os_quick_report';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user