2019-03-20 16:31:29 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace Models\VisualConsole;
|
2020-01-07 18:07:07 +01:00
|
|
|
use Models\VisualConsole\Container as VC;
|
2019-05-27 12:10:05 +02:00
|
|
|
use Models\CachedModel;
|
2019-03-20 16:31:29 +01:00
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
/**
|
|
|
|
* Model of a generic Visual Console Item.
|
|
|
|
*/
|
2019-05-27 12:10:05 +02:00
|
|
|
class Item extends CachedModel
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Used to decide wether to use information about the linked agent or not.
|
2019-03-25 16:37:36 +01:00
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
2019-03-26 10:12:43 +01:00
|
|
|
protected static $useLinkedAgent = false;
|
2019-03-20 16:31:29 +01:00
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Used to decide wether to use information about the linked module or not.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @var boolean
|
|
|
|
*/
|
2019-03-26 10:12:43 +01:00
|
|
|
protected static $useLinkedModule = false;
|
2019-03-25 16:37:36 +01:00
|
|
|
|
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Used to decide wether to use information about
|
2019-03-25 16:37:36 +01:00
|
|
|
* the linked visual console or not.
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
2019-03-26 10:12:43 +01:00
|
|
|
protected static $useLinkedVisualConsole = false;
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-04-03 12:07:48 +02:00
|
|
|
/**
|
|
|
|
* Used to decide wether to validate, extract and encode HTML output or not.
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected static $useHtmlOutput = false;
|
|
|
|
|
2020-02-20 13:25:56 +01:00
|
|
|
/**
|
|
|
|
* Enable the cache index by user id.
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
protected static $indexCacheByUser = true;
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate the received data structure to ensure if we can extract the
|
|
|
|
* values required to build the model.
|
|
|
|
*
|
|
|
|
* @param array $data Input data.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
|
|
|
* @return void
|
2019-03-25 16:37:36 +01:00
|
|
|
*
|
|
|
|
* @throws \InvalidArgumentException If any input value is considered
|
|
|
|
* invalid.
|
|
|
|
*
|
|
|
|
* @overrides Model::validateData.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-03-20 16:31:29 +01:00
|
|
|
protected function validateData(array $data): void
|
|
|
|
{
|
|
|
|
if (isset($data['id']) === false
|
|
|
|
|| \is_numeric($data['id']) === false
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the Id property is required and should be integer'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['type']) === false
|
|
|
|
|| \is_numeric($data['type']) === false
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the Type property is required and should be integer'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['width']) === false
|
|
|
|
|| \is_numeric($data['width']) === false
|
|
|
|
|| $data['width'] < 0
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
2019-04-02 13:00:03 +02:00
|
|
|
'the width property is required and should be equal or greater than 0'
|
2019-03-20 16:31:29 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['height']) === false
|
|
|
|
|| \is_numeric($data['height']) === false
|
|
|
|
|| $data['height'] < 0
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
2019-04-02 13:00:03 +02:00
|
|
|
'the height property is required and should be equal or greater than 0'
|
2019-03-20 16:31:29 +01:00
|
|
|
);
|
|
|
|
}
|
2019-03-26 10:12:43 +01:00
|
|
|
|
|
|
|
// The item has a linked Visual Console.
|
|
|
|
if (static::$useLinkedVisualConsole === true) {
|
|
|
|
$linkedLayoutStatusType = static::notEmptyStringOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusType',
|
|
|
|
'linked_layout_status_type',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
// The types weight and service require extra data
|
|
|
|
// which should be validated.
|
|
|
|
if ($linkedLayoutStatusType === 'weight') {
|
|
|
|
$weight = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWeight',
|
|
|
|
'id_layout_linked_weight',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($weight === null || $weight < 0) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the linked layout status weight property is required and should be greater than 0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else if ($linkedLayoutStatusType === 'service') {
|
|
|
|
$wThreshold = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWarningThreshold',
|
|
|
|
'linked_layout_status_as_service_warning',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($wThreshold === null || $wThreshold < 0) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the linked layout status warning threshold property is required and should be greater than 0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$cThreshold = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeCriticalThreshold',
|
|
|
|
'linked_layout_status_as_service_critical',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($cThreshold === null || $cThreshold < 0) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the linked layout status critical threshold property is required and should be greater than 0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-04-03 12:07:48 +02:00
|
|
|
|
|
|
|
// The item uses HTML output.
|
|
|
|
if (static::$useHtmlOutput === true) {
|
2019-08-01 11:49:00 +02:00
|
|
|
if (static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['encodedHtml']),
|
|
|
|
null
|
|
|
|
) === null
|
|
|
|
&& static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['html']),
|
|
|
|
null
|
|
|
|
) === null
|
2019-04-03 12:07:48 +02:00
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the html property is required and should be a not empty string'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Returns a valid representation of the model.
|
|
|
|
*
|
|
|
|
* @param array $data Input data.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return array Data structure representing the model.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @overrides Model::decode.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-03-20 16:31:29 +01:00
|
|
|
protected function decode(array $data): array
|
|
|
|
{
|
2023-04-05 16:24:46 +02:00
|
|
|
global $config;
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
$decodedData = [
|
2019-08-05 12:58:25 +02:00
|
|
|
'id' => (int) $data['id'],
|
2020-11-12 18:25:16 +01:00
|
|
|
'colorStatus' => (string) COL_UNKNOWN,
|
2019-08-05 12:58:25 +02:00
|
|
|
'type' => (int) $data['type'],
|
|
|
|
'label' => static::extractLabel($data),
|
|
|
|
'labelPosition' => static::extractLabelPosition($data),
|
|
|
|
'isLinkEnabled' => static::extractIsLinkEnabled($data),
|
|
|
|
'isOnTop' => static::extractIsOnTop($data),
|
|
|
|
'parentId' => static::extractParentId($data),
|
|
|
|
'aclGroupId' => static::extractAclGroupId($data),
|
|
|
|
'width' => (int) $data['width'],
|
|
|
|
'height' => (int) $data['height'],
|
|
|
|
'x' => static::extractX($data),
|
|
|
|
'y' => static::extractY($data),
|
|
|
|
'cacheExpiration' => static::extractCacheExpiration($data),
|
2019-03-20 16:31:29 +01:00
|
|
|
];
|
2019-03-26 10:12:43 +01:00
|
|
|
|
2023-04-05 16:24:46 +02:00
|
|
|
if ((bool) $config['display_item_frame'] === true) {
|
|
|
|
$decodedData['alertOutline'] = static::checkLayoutAlertsRecursive($data);
|
|
|
|
}
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
if (static::$useLinkedModule === true) {
|
|
|
|
$decodedData = array_merge(
|
|
|
|
$decodedData,
|
|
|
|
static::extractLinkedModule($data)
|
|
|
|
);
|
|
|
|
} else if (static::$useLinkedAgent === true) {
|
|
|
|
$decodedData = array_merge(
|
|
|
|
$decodedData,
|
|
|
|
static::extractLinkedAgent($data)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (static::$useLinkedVisualConsole === true) {
|
|
|
|
$decodedData = array_merge(
|
|
|
|
$decodedData,
|
|
|
|
static::extractLinkedVisualConsole($data)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-04-03 12:07:48 +02:00
|
|
|
if (static::$useHtmlOutput === true) {
|
|
|
|
$decodedData['encodedHtml'] = static::extractEncodedHtml($data);
|
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
// Conditionally add the item link.
|
|
|
|
if ($decodedData['isLinkEnabled'] === true) {
|
|
|
|
$decodedData['link'] = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['link']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-03-22 15:10:14 +01:00
|
|
|
$decodedData['agentDisabled'] = static::parseBool(
|
2022-01-11 14:36:05 +01:00
|
|
|
($data['agentDisabled'] ?? false)
|
2021-03-22 15:10:14 +01:00
|
|
|
);
|
|
|
|
$decodedData['moduleDisabled'] = static::parseBool(
|
2022-01-11 14:36:05 +01:00
|
|
|
($data['moduleDisabled'] ?? false)
|
2021-03-22 15:10:14 +01:00
|
|
|
);
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
return $decodedData;
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract x y axis value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return integer Valid x axis position of the item.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractX(array $data): int
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseIntOr(
|
2019-06-11 15:26:10 +02:00
|
|
|
static::issetInArray($data, ['x', 'pos_x', 'posX', 'startX']),
|
2019-03-25 16:37:36 +01:00
|
|
|
0
|
|
|
|
);
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract a y axis value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return integer Valid y axis position of the item.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractY(array $data): int
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseIntOr(
|
2019-06-11 15:26:10 +02:00
|
|
|
static::issetInArray($data, ['y', 'pos_y', 'posY', 'startY']),
|
2019-03-25 16:37:36 +01:00
|
|
|
0
|
|
|
|
);
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract a group Id (for ACL) value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return integer Valid identifier of a group.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractAclGroupId(array $data)
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseIntOr(
|
2020-01-16 14:07:35 +01:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'element_group',
|
|
|
|
'aclGroupId',
|
|
|
|
'elementGroup',
|
|
|
|
]
|
|
|
|
),
|
2019-03-20 16:31:29 +01:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract a parent Id value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return integer Valid identifier of the item's parent.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractParentId(array $data)
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseIntOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'parentId',
|
|
|
|
'parent_item',
|
|
|
|
'parentItem',
|
|
|
|
]
|
|
|
|
),
|
2019-03-20 16:31:29 +01:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract the "is on top" switch value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return boolean If the item is on top or not.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractIsOnTop(array $data): bool
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseBool(
|
2019-06-10 13:04:52 +02:00
|
|
|
static::issetInArray($data, ['isOnTop', 'show_on_top', 'showOnTop'])
|
2019-03-20 16:31:29 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract the "is link enabled" switch value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return boolean If the item has the link enabled or not.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractIsLinkEnabled(array $data): bool
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
return static::parseBool(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'isLinkEnabled',
|
|
|
|
'enable_link',
|
|
|
|
'enableLink',
|
|
|
|
]
|
|
|
|
)
|
2019-03-20 16:31:29 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract a label value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return mixed String representing the label (not empty) or null.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractLabel(array $data)
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2020-01-15 14:28:43 +01:00
|
|
|
return static::issetInArray($data, ['label']);
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 16:37:36 +01:00
|
|
|
* Extract a label position value.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @param array $data Unknown input data structure.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @return mixed One string of up|right|left|down. down by default.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractLabelPosition(array $data): string
|
2019-03-20 16:31:29 +01:00
|
|
|
{
|
2019-03-25 16:37:36 +01:00
|
|
|
$labelPosition = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['labelPosition', 'label_position']),
|
2019-03-20 16:31:29 +01:00
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
switch ($labelPosition) {
|
|
|
|
case 'up':
|
|
|
|
case 'right':
|
|
|
|
case 'left':
|
|
|
|
return $labelPosition;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return 'down';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
/**
|
|
|
|
* Extract an agent Id value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Valid identifier of an agent.
|
|
|
|
*/
|
|
|
|
private static function extractAgentId(array $data)
|
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'agentId',
|
|
|
|
'id_agent',
|
|
|
|
'id_agente',
|
|
|
|
'idAgent',
|
|
|
|
'idAgente',
|
|
|
|
]
|
|
|
|
),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-08-05 12:58:25 +02:00
|
|
|
/**
|
|
|
|
* Extract the cache expiration value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Cache expiration time.
|
|
|
|
*/
|
|
|
|
private static function extractCacheExpiration(array $data)
|
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'cacheExpiration',
|
|
|
|
'cache_expiration',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
/**
|
|
|
|
* Extract an module Id value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Valid identifier of a module.
|
|
|
|
*/
|
|
|
|
private static function extractModuleId(array $data)
|
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
2019-04-09 16:06:59 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'moduleId',
|
|
|
|
'id_agente_modulo',
|
|
|
|
'id_modulo',
|
2019-06-10 13:04:52 +02:00
|
|
|
'idModulo',
|
|
|
|
'idAgenteModulo',
|
|
|
|
'idAgentModule',
|
2019-04-09 16:06:59 +02:00
|
|
|
]
|
|
|
|
),
|
2019-04-09 15:30:08 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract an metaconsole node Id value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Valid identifier of a metaconsole node.
|
|
|
|
*/
|
|
|
|
private static function extractMetaconsoleId(array $data)
|
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['metaconsoleId', 'id_metaconsole']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
/**
|
|
|
|
* Extract the values of a linked agent.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
2019-03-26 10:12:43 +01:00
|
|
|
* @return array Data structure of the linked agent info.
|
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @example [
|
2019-03-26 10:12:43 +01:00
|
|
|
* 'metaconsoleId' => 1,
|
|
|
|
* 'agentId' => 2,
|
|
|
|
* 'agentName' => 'Foo',
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'agentId' => 20,
|
|
|
|
* 'agentName' => 'Bar',
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'agentId' => null,
|
|
|
|
* 'agentName' => null,
|
2019-03-25 16:37:36 +01:00
|
|
|
* ]
|
|
|
|
*/
|
2019-04-03 10:27:22 +02:00
|
|
|
protected static function extractLinkedAgent(array $data): array
|
2019-03-25 16:37:36 +01:00
|
|
|
{
|
|
|
|
$agentData = [];
|
|
|
|
|
2019-04-17 15:58:07 +02:00
|
|
|
// We should add the metaconsole Id if we can.
|
2019-04-09 15:30:08 +02:00
|
|
|
$metaconsoleId = static::extractMetaconsoleId($data);
|
2019-04-17 15:58:07 +02:00
|
|
|
if ($metaconsoleId !== null && $metaconsoleId <= 0) {
|
|
|
|
$agentData['metaconsoleId'] = null;
|
2019-04-22 10:58:01 +02:00
|
|
|
} else {
|
|
|
|
$agentData['metaconsoleId'] = $metaconsoleId;
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
// The agent Id should be a valid int or a null value.
|
2019-04-09 15:30:08 +02:00
|
|
|
$agentData['agentId'] = static::extractAgentId($data);
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
// The agent name should be a valid string or a null value.
|
2019-03-25 16:37:36 +01:00
|
|
|
$agentData['agentName'] = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['agentName', 'agent_name']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
// The agent alias should be a valid string or a null value.
|
|
|
|
$agentData['agentAlias'] = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['agentAlias', 'agent_alias']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
// The agent description should be a valid string or a null value.
|
|
|
|
$agentData['agentDescription'] = static::notEmptyStringOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'agentDescription',
|
|
|
|
'agent_description',
|
|
|
|
]
|
|
|
|
),
|
2019-04-24 13:40:37 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
// The agent address should be a valid string or a null value.
|
|
|
|
$agentData['agentAddress'] = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['agentAddress', 'agent_address']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
return $agentData;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract the values of a linked module.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
2019-03-26 10:12:43 +01:00
|
|
|
* @return array Data structure of the linked module info.
|
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @example [
|
2019-03-26 10:12:43 +01:00
|
|
|
* 'metaconsoleId' => 1,
|
|
|
|
* 'agentId' => 2,
|
|
|
|
* 'agentName' => 'Foo',
|
|
|
|
* 'moduleId' => 1,
|
|
|
|
* 'moduleName' => 'cpu',
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'agentId' => 4,
|
|
|
|
* 'agentName' => 'Bar',
|
|
|
|
* 'moduleId' => null,
|
|
|
|
* 'moduleName' => null,
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'agentId' => null,
|
|
|
|
* 'agentName' => null,
|
|
|
|
* 'moduleId' => null,
|
|
|
|
* 'moduleName' => null,
|
2019-03-25 16:37:36 +01:00
|
|
|
* ]
|
|
|
|
*/
|
2019-04-03 10:27:22 +02:00
|
|
|
protected static function extractLinkedModule(array $data): array
|
2019-03-25 16:37:36 +01:00
|
|
|
{
|
|
|
|
// Initialize the data with the agent data and then expand it.
|
|
|
|
$moduleData = static::extractLinkedAgent($data);
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
// The module Id should be a valid int or a null value.
|
2019-04-09 15:30:08 +02:00
|
|
|
$moduleData['moduleId'] = static::extractModuleId($data);
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
// The module name should be a valid string or a null value.
|
2019-03-25 16:37:36 +01:00
|
|
|
$moduleData['moduleName'] = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['moduleName', 'module_name']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
// The module description should be a valid string or a null value.
|
|
|
|
$moduleData['moduleDescription'] = static::notEmptyStringOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'moduleDescription',
|
|
|
|
'module_description',
|
|
|
|
]
|
|
|
|
),
|
2019-04-24 13:40:37 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
return $moduleData;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 12:32:06 +01:00
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Extract the values of a linked visual console.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return array Data structure of the linked visual console info.
|
|
|
|
*
|
|
|
|
* @example [
|
|
|
|
* 'linkedLayoutId' => 12,
|
2019-08-01 11:49:00 +02:00
|
|
|
* 'linkedLayoutNodeId' => 2,
|
2019-03-26 10:12:43 +01:00
|
|
|
* 'linkedLayoutStatusType' => 'default',
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'linkedLayoutId' => 11,
|
2019-08-01 11:49:00 +02:00
|
|
|
* 'linkedLayoutNodeId' => null,
|
2019-03-26 10:12:43 +01:00
|
|
|
* 'linkedLayoutStatusType' => 'weight',
|
|
|
|
* 'linkedLayoutStatusTypeWeight' => 80,
|
|
|
|
* ]
|
|
|
|
* @example [
|
|
|
|
* 'linkedLayoutId' => 10,
|
2019-08-01 11:49:00 +02:00
|
|
|
* 'linkedLayoutNodeId' => 2,
|
2019-03-26 10:12:43 +01:00
|
|
|
* 'linkedLayoutStatusType' => 'service',
|
|
|
|
* 'linkedLayoutStatusTypeWarningThreshold' => 50,
|
|
|
|
* 'linkedLayoutStatusTypeCriticalThreshold' => 80,
|
|
|
|
* ]
|
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
private static function extractLinkedVisualConsole(array $data): array
|
2019-03-26 10:12:43 +01:00
|
|
|
{
|
|
|
|
$vcData = [];
|
|
|
|
|
|
|
|
// The linked vc Id should be a valid int or a null value.
|
|
|
|
$vcData['linkedLayoutId'] = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['linkedLayoutId', 'id_layout_linked']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2019-08-01 11:49:00 +02:00
|
|
|
// The linked vc's remote node Id should be a valid int or a null value.
|
|
|
|
$vcData['linkedLayoutNodeId'] = static::parseIntOr(
|
2019-03-26 10:12:43 +01:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
2019-08-01 11:49:00 +02:00
|
|
|
'linkedLayoutNodeId',
|
2019-03-26 10:12:43 +01:00
|
|
|
'linked_layout_node_id',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
// The linked vc status type should be a enum value.
|
|
|
|
$linkedLayoutStatusType = static::notEmptyStringOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusType',
|
|
|
|
'linked_layout_status_type',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
// Extract data for the calculation of the linked visual console status.
|
|
|
|
switch ($linkedLayoutStatusType) {
|
|
|
|
case 'default':
|
|
|
|
default:
|
|
|
|
$vcData['linkedLayoutStatusType'] = 'default';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'weight':
|
|
|
|
$vcData['linkedLayoutStatusType'] = 'weight';
|
|
|
|
$vcData['linkedLayoutStatusTypeWeight'] = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWeight',
|
|
|
|
'id_layout_linked_weight',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'service':
|
|
|
|
$vcData['linkedLayoutStatusType'] = 'service';
|
|
|
|
$vcData['linkedLayoutStatusTypeWarningThreshold'] = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWarningThreshold',
|
|
|
|
'linked_layout_status_as_service_warning',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
$vcData['linkedLayoutStatusTypeCriticalThreshold'] = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeCriticalThreshold',
|
|
|
|
'linked_layout_status_as_service_critical',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $vcData;
|
|
|
|
}
|
2019-04-03 12:07:48 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract a encoded HTML representation of the item.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return string The HTML representation in base64 encoding.
|
|
|
|
*/
|
|
|
|
private static function extractEncodedHtml(array $data): string
|
|
|
|
{
|
|
|
|
if (isset($data['encodedHtml']) === true) {
|
|
|
|
return $data['encodedHtml'];
|
|
|
|
} else if (isset($data['html']) === true) {
|
2019-04-25 10:30:24 +02:00
|
|
|
return base64_encode($data['html']);
|
2019-04-03 12:07:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return '';
|
|
|
|
}
|
2019-03-26 10:12:43 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch a vc item data structure from the database using a filter.
|
2019-03-25 12:32:06 +01:00
|
|
|
*
|
2022-01-12 20:46:19 +01:00
|
|
|
* @param array $filter Filter of the Visual Console Item.
|
|
|
|
* @param float $ratio Ratio resize view.
|
|
|
|
* @param float|null $widthRatio Unknown.
|
2019-03-25 12:32:06 +01:00
|
|
|
*
|
|
|
|
* @return array The Visual Console Item data structure stored into the DB.
|
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*
|
|
|
|
* @override Model::fetchDataFromDB.
|
|
|
|
*/
|
2020-03-26 12:29:38 +01:00
|
|
|
protected static function fetchDataFromDB(
|
|
|
|
array $filter,
|
2021-06-29 12:02:13 +02:00
|
|
|
?float $ratio=0,
|
|
|
|
?float $widthRatio=0
|
2020-03-26 12:29:38 +01:00
|
|
|
): array {
|
2019-04-25 10:30:24 +02:00
|
|
|
// Load side libraries.
|
|
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/functions_io.php';
|
|
|
|
|
2019-03-25 12:32:06 +01:00
|
|
|
// Due to this DB call, this function cannot be unit tested without
|
|
|
|
// a proper mock.
|
|
|
|
$row = \db_get_row_filter('tlayout_data', $filter);
|
|
|
|
|
|
|
|
if ($row === false) {
|
|
|
|
throw new \Exception('error fetching the data from the DB');
|
|
|
|
}
|
|
|
|
|
2019-04-17 12:49:42 +02:00
|
|
|
// Clean up to two levels of HTML entities.
|
|
|
|
$row = \io_safe_output(\io_safe_output($row));
|
2019-04-16 09:49:50 +02:00
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
/*
|
|
|
|
* Retrieve extra data.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// The linked module includes the agent data.
|
2019-03-26 10:12:43 +01:00
|
|
|
if (static::$useLinkedModule === true) {
|
2019-04-25 10:30:24 +02:00
|
|
|
$row = array_merge($row, static::fetchModuleDataFromDB($row));
|
2019-03-26 10:12:43 +01:00
|
|
|
} else if (static::$useLinkedAgent === true) {
|
2019-04-25 10:30:24 +02:00
|
|
|
$row = array_merge($row, static::fetchAgentDataFromDB($row));
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
// Build the item link if needed.
|
|
|
|
if (static::extractIsLinkEnabled($row) === true) {
|
|
|
|
$row['link'] = static::buildLink($row);
|
|
|
|
}
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
if ($ratio != 0) {
|
|
|
|
$row['width'] = ($row['width'] * $ratio);
|
|
|
|
$row['height'] = ($row['height'] * $ratio);
|
|
|
|
$row['pos_x'] = ($row['pos_x'] * $ratio);
|
|
|
|
$row['pos_y'] = ($row['pos_y'] * $ratio);
|
|
|
|
}
|
|
|
|
|
2021-06-29 12:02:13 +02:00
|
|
|
if ($widthRatio != 0) {
|
|
|
|
$row['width'] = ($row['width'] * $widthRatio);
|
|
|
|
$row['pos_x'] = ($row['pos_x'] * $widthRatio);
|
|
|
|
}
|
|
|
|
|
2019-03-25 12:32:06 +01:00
|
|
|
return $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-20 15:15:54 +02:00
|
|
|
/**
|
|
|
|
* Fetch a cache item data structure from the database using a filter.
|
|
|
|
*
|
|
|
|
* @param array $filter Filter of the Visual Console Item.
|
|
|
|
*
|
|
|
|
* @return array The Visual Console Item data structure stored into the DB.
|
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*
|
2019-05-27 12:10:05 +02:00
|
|
|
* @override CachedModel::fetchCachedData.
|
2019-05-20 15:15:54 +02:00
|
|
|
*/
|
|
|
|
protected static function fetchCachedData(array $filter)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
2019-05-28 10:38:58 +02:00
|
|
|
$filter = [
|
|
|
|
'vc_id' => (int) $filter['id_layout'],
|
|
|
|
'vc_item_id' => (int) $filter['id'],
|
|
|
|
'(UNIX_TIMESTAMP(`created_at`) + `expiration`) > UNIX_TIMESTAMP()'
|
|
|
|
];
|
|
|
|
|
|
|
|
if (static::$indexCacheByUser === true) {
|
|
|
|
$filter['user_id'] = $config['id_user'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = \db_get_value_filter(
|
|
|
|
'data',
|
|
|
|
'tvisual_console_elements_cache',
|
|
|
|
$filter
|
2019-05-20 15:15:54 +02:00
|
|
|
);
|
2019-05-23 10:35:03 +02:00
|
|
|
|
2019-05-27 12:10:05 +02:00
|
|
|
if ($data === false) {
|
2020-02-20 13:25:56 +01:00
|
|
|
// Invalid entry, clean it.
|
|
|
|
self::clearCachedData(
|
|
|
|
[
|
|
|
|
'vc_id' => $filter['vc_id'],
|
|
|
|
'vc_item_id' => $filter['vc_item_id'],
|
|
|
|
'user_id' => $filter['user_id'],
|
|
|
|
]
|
|
|
|
);
|
2019-05-20 15:15:54 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2019-05-27 12:10:05 +02:00
|
|
|
return json_decode(base64_decode($data), true);
|
2019-05-20 15:15:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stores the data structure obtained.
|
|
|
|
*
|
2019-05-27 12:10:05 +02:00
|
|
|
* @param array $filter Filter to save the modeled element.
|
|
|
|
* @param array $data Modeled element to save.
|
2019-05-20 15:15:54 +02:00
|
|
|
*
|
2019-05-23 10:35:03 +02:00
|
|
|
* @return boolean The modeled element data structure stored into the DB.
|
2019-05-20 15:15:54 +02:00
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*
|
2019-05-27 12:10:05 +02:00
|
|
|
* @override CachedModel::saveCachedData.
|
2019-05-20 15:15:54 +02:00
|
|
|
*/
|
|
|
|
protected static function saveCachedData(array $filter, array $data): bool
|
|
|
|
{
|
2020-02-20 13:25:56 +01:00
|
|
|
global $config;
|
|
|
|
if (static::$indexCacheByUser === true) {
|
|
|
|
$filter['user_id'] = $config['id_user'];
|
|
|
|
}
|
|
|
|
|
2019-05-27 12:10:05 +02:00
|
|
|
return \db_process_sql_insert(
|
2019-05-20 15:15:54 +02:00
|
|
|
'tvisual_console_elements_cache',
|
|
|
|
[
|
2020-02-20 13:25:56 +01:00
|
|
|
'vc_id' => $data['id_layout'],
|
|
|
|
'vc_item_id' => $data['id'],
|
2019-05-20 15:15:54 +02:00
|
|
|
'user_id' => $filter['user_id'],
|
2019-05-27 12:10:05 +02:00
|
|
|
'data' => base64_encode(json_encode($data)),
|
2020-02-20 13:25:56 +01:00
|
|
|
'expiration' => $data['cache_expiration'],
|
2019-05-20 15:15:54 +02:00
|
|
|
]
|
2019-05-27 12:10:05 +02:00
|
|
|
) > 0;
|
2019-05-20 15:15:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deletes previous data that are not useful.
|
|
|
|
*
|
|
|
|
* @param array $filter Filter to retrieve the modeled element.
|
|
|
|
*
|
|
|
|
* @return array The modeled element data structure stored into the DB.
|
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*
|
2019-05-27 12:10:05 +02:00
|
|
|
* @override CachedModel::clearCachedData.
|
2019-05-20 15:15:54 +02:00
|
|
|
*/
|
|
|
|
protected static function clearCachedData(array $filter): int
|
|
|
|
{
|
2019-05-27 12:10:05 +02:00
|
|
|
return \db_process_sql_delete(
|
|
|
|
'tvisual_console_elements_cache',
|
|
|
|
$filter
|
|
|
|
);
|
2019-05-20 15:15:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Fetch a data structure of an agent from the database using the
|
2019-03-25 16:37:36 +01:00
|
|
|
* vs item's data.
|
|
|
|
*
|
|
|
|
* @param array $itemData Visual Console Item's data structure.
|
|
|
|
*
|
2019-03-26 10:12:43 +01:00
|
|
|
* @return array The agent data structure stored into the DB.
|
|
|
|
*
|
2019-03-25 16:37:36 +01:00
|
|
|
* @throws \InvalidArgumentException When the input agent Id is invalid.
|
|
|
|
*/
|
|
|
|
protected static function fetchAgentDataFromDB(array $itemData): array
|
|
|
|
{
|
2019-07-30 14:58:01 +02:00
|
|
|
// Load side libraries.
|
|
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/functions_io.php';
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
$agentData = [];
|
|
|
|
|
|
|
|
// We should add the metaconsole Id if we can.
|
2019-04-09 15:30:08 +02:00
|
|
|
$metaconsoleId = static::extractMetaconsoleId($itemData);
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
// Can't fetch an agent with an invalid Id.
|
|
|
|
$agentId = static::extractAgentId($itemData);
|
2019-03-25 16:37:36 +01:00
|
|
|
if ($agentId === null) {
|
2021-02-25 18:56:21 +01:00
|
|
|
$agentId = 0;
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-04-17 15:39:55 +02:00
|
|
|
// Staticgraph don't need to have an agent.
|
|
|
|
if ($agentId === 0) {
|
|
|
|
return $agentData;
|
|
|
|
}
|
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true && $metaconsoleId === null) {
|
2019-04-09 15:30:08 +02:00
|
|
|
throw new \InvalidArgumentException('missing metaconsole node Id');
|
|
|
|
}
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
$agent = false;
|
2019-04-09 15:30:08 +02:00
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true) {
|
2019-04-24 13:40:37 +02:00
|
|
|
$sql = sprintf(
|
2021-03-22 15:10:14 +01:00
|
|
|
'SELECT nombre, alias, direccion, comentarios, `disabled`
|
2019-04-24 13:40:37 +02:00
|
|
|
FROM tmetaconsole_agent
|
|
|
|
WHERE id_tagente = %s and id_tmetaconsole_setup = %s',
|
|
|
|
$agentId,
|
|
|
|
$metaconsoleId
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
|
|
|
} else {
|
2019-04-24 13:40:37 +02:00
|
|
|
$sql = sprintf(
|
2021-03-22 15:10:14 +01:00
|
|
|
'SELECT nombre, alias, direccion, comentarios, `disabled`
|
2019-04-24 13:40:37 +02:00
|
|
|
FROM tagente
|
|
|
|
WHERE id_agente = %s',
|
2019-04-09 15:30:08 +02:00
|
|
|
$agentId
|
|
|
|
);
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
$agent = \db_get_row_sql($sql);
|
|
|
|
|
|
|
|
if ($agent === false) {
|
2021-03-24 12:43:51 +01:00
|
|
|
$agentData['agentDisabled'] = true;
|
2021-02-25 18:56:21 +01:00
|
|
|
return $agentData;
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-03-26 10:12:43 +01:00
|
|
|
// The agent name should be a valid string or a null value.
|
2019-04-24 13:40:37 +02:00
|
|
|
$agentData['agentName'] = $agent['nombre'];
|
|
|
|
$agentData['agentAlias'] = $agent['alias'];
|
|
|
|
$agentData['agentDescription'] = $agent['comentarios'];
|
|
|
|
$agentData['agentAddress'] = $agent['direccion'];
|
2021-03-22 15:10:14 +01:00
|
|
|
$agentData['agentDisabled'] = $agent['disabled'];
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-07-30 14:58:01 +02:00
|
|
|
return \io_safe_output($agentData);
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2019-03-26 10:12:43 +01:00
|
|
|
* Fetch a data structure of an module from the database using the
|
2019-03-25 16:37:36 +01:00
|
|
|
* vs item's data.
|
|
|
|
*
|
|
|
|
* @param array $itemData Visual Console Item's data structure.
|
|
|
|
*
|
2019-03-26 10:12:43 +01:00
|
|
|
* @return array The module data structure stored into the DB.
|
2019-03-25 16:37:36 +01:00
|
|
|
* @throws \InvalidArgumentException When the input module Id is invalid.
|
|
|
|
*/
|
2019-04-09 15:30:08 +02:00
|
|
|
protected static function fetchModuleDataFromDB(array $itemData): array
|
|
|
|
{
|
2019-07-30 14:58:01 +02:00
|
|
|
// Load side libraries.
|
|
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/functions_io.php';
|
|
|
|
|
2019-04-25 10:30:24 +02:00
|
|
|
// Load side libraries.
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true) {
|
2019-04-25 10:30:24 +02:00
|
|
|
\enterprise_include_once('include/functions_metaconsole.php');
|
|
|
|
}
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
// Initialize with the agent data.
|
|
|
|
$moduleData = static::fetchAgentDataFromDB($itemData);
|
|
|
|
|
|
|
|
// Can't fetch an module with a invalid Id.
|
2019-04-09 15:30:08 +02:00
|
|
|
$moduleId = static::extractModuleId($itemData);
|
2019-03-25 16:37:36 +01:00
|
|
|
if ($moduleId === null) {
|
2021-02-25 18:56:21 +01:00
|
|
|
$moduleId = 0;
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-04-17 15:39:55 +02:00
|
|
|
// Staticgraph don't need to have a module.
|
|
|
|
if ($moduleId === 0) {
|
|
|
|
return $moduleData;
|
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
// We should add the metaconsole Id if we can.
|
|
|
|
$metaconsoleId = static::extractMetaconsoleId($itemData);
|
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true && $metaconsoleId === null) {
|
2019-04-09 15:30:08 +02:00
|
|
|
throw new \InvalidArgumentException('missing metaconsole node Id');
|
|
|
|
}
|
|
|
|
|
|
|
|
$moduleName = false;
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
// Connect to node.
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true
|
2019-04-25 10:30:24 +02:00
|
|
|
&& \metaconsole_connect(null, $metaconsoleId) !== NOERR
|
|
|
|
) {
|
2019-04-24 13:40:37 +02:00
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'error connecting to the node'
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
2019-04-24 13:40:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$sql = sprintf(
|
2021-03-22 15:10:14 +01:00
|
|
|
'SELECT nombre, descripcion, `disabled`
|
2019-04-24 13:40:37 +02:00
|
|
|
FROM tagente_modulo
|
|
|
|
WHERE id_agente_modulo = %s',
|
|
|
|
$moduleId
|
|
|
|
);
|
|
|
|
|
|
|
|
$moduleName = \db_get_row_sql($sql);
|
2019-04-09 15:30:08 +02:00
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
// Restore connection.
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true) {
|
2019-04-09 15:30:08 +02:00
|
|
|
\metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
2019-03-25 16:37:36 +01:00
|
|
|
if ($moduleName === false) {
|
2021-03-24 12:43:51 +01:00
|
|
|
$agentData['moduleDisabled'] = true;
|
2021-02-25 18:56:21 +01:00
|
|
|
return $moduleData;
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
2019-04-24 13:40:37 +02:00
|
|
|
$moduleData['moduleName'] = $moduleName['nombre'];
|
|
|
|
$moduleData['moduleDescription'] = $moduleName['descripcion'];
|
2021-03-22 15:10:14 +01:00
|
|
|
$moduleData['moduleDisabled'] = $moduleName['disabled'];
|
2019-03-25 16:37:36 +01:00
|
|
|
|
2019-07-30 14:58:01 +02:00
|
|
|
return \io_safe_output($moduleData);
|
2019-03-25 16:37:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
/**
|
|
|
|
* Generate a link to something related with the item.
|
|
|
|
*
|
|
|
|
* @param array $data Visual Console Item's data structure.
|
|
|
|
*
|
|
|
|
* @return mixed The link or a null value.
|
|
|
|
* @throws \Exception Not really. It's controlled.
|
|
|
|
*/
|
|
|
|
protected static function buildLink(array $data)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
2020-12-22 14:40:04 +01:00
|
|
|
$mobile_navigation = false;
|
|
|
|
|
2021-05-19 10:13:25 +02:00
|
|
|
if (strstr(($_SERVER['PHP_SELF'] ?? ''), 'mobile/') !== false
|
|
|
|
|| strstr(($_SERVER['HTTP_REFERER'] ?? ''), 'mobile/') !== false
|
2020-12-22 14:40:04 +01:00
|
|
|
) {
|
|
|
|
$mobile_navigation = true;
|
|
|
|
}
|
|
|
|
|
2019-04-25 10:02:35 +02:00
|
|
|
// Load side libraries.
|
2019-04-25 14:02:30 +02:00
|
|
|
include_once $config['homedir'].'/include/functions_ui.php';
|
2021-03-24 12:43:51 +01:00
|
|
|
if (\is_metaconsole() === true) {
|
2019-04-25 10:30:24 +02:00
|
|
|
\enterprise_include_once('include/functions_metaconsole.php');
|
|
|
|
\enterprise_include_once('meta/include/functions_ui_meta.php');
|
|
|
|
}
|
2019-04-25 10:02:35 +02:00
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
$linkedVisualConsole = static::extractLinkedVisualConsole($data);
|
|
|
|
$linkedModule = static::extractLinkedModule($data);
|
|
|
|
$linkedAgent = static::extractLinkedAgent($data);
|
|
|
|
|
2019-04-29 10:45:12 +02:00
|
|
|
$baseUrl = \ui_get_full_url('index.php');
|
2020-12-22 14:40:04 +01:00
|
|
|
$mobileUrl = \ui_get_full_url('mobile/index.php');
|
2019-04-09 15:30:08 +02:00
|
|
|
|
2022-01-11 14:36:05 +01:00
|
|
|
if ((bool) ($data['agentDisabled'] ?? null) === true
|
|
|
|
|| (bool) ($data['moduleDisabled'] ?? null) === true
|
2021-03-22 15:10:14 +01:00
|
|
|
) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
if (static::$useLinkedVisualConsole === true
|
|
|
|
&& $linkedVisualConsole['linkedLayoutId'] !== null
|
|
|
|
&& $linkedVisualConsole['linkedLayoutId'] > 0
|
|
|
|
) {
|
|
|
|
// Linked Visual Console.
|
|
|
|
$vcId = $linkedVisualConsole['linkedLayoutId'];
|
|
|
|
// The layout can be from another node.
|
2019-08-01 11:49:00 +02:00
|
|
|
$linkedLayoutNodeId = $linkedVisualConsole['linkedLayoutNodeId'];
|
2019-04-09 15:30:08 +02:00
|
|
|
|
2022-02-01 17:13:13 +01:00
|
|
|
if (empty($linkedLayoutNodeId) === false && \is_metaconsole() === true) {
|
|
|
|
$db_connector = metaconsole_get_connection_by_id($linkedLayoutNodeId);
|
|
|
|
metaconsole_load_external_db($db_connector);
|
|
|
|
}
|
|
|
|
|
2020-02-11 09:45:43 +01:00
|
|
|
$visualConsole = VC::fromDB(['id' => $vcId]);
|
2022-02-01 17:13:13 +01:00
|
|
|
|
|
|
|
if (empty($linkedLayoutNodeId) === false && \is_metaconsole() === true) {
|
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
2020-02-11 09:45:43 +01:00
|
|
|
$visualConsoleData = $visualConsole->toArray();
|
|
|
|
$vcGroupId = $visualConsoleData['groupId'];
|
|
|
|
|
2022-02-01 17:13:13 +01:00
|
|
|
// Check ACL.
|
2020-02-11 09:45:43 +01:00
|
|
|
$aclRead = \check_acl($config['id_user'], $vcGroupId, 'VR');
|
|
|
|
// To build the link to another visual console
|
|
|
|
// you must have read permissions of the visual console
|
|
|
|
// with which it is linked.
|
|
|
|
if ($aclRead === 0) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (empty($linkedLayoutNodeId) === true
|
|
|
|
&& \is_metaconsole() === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* A Visual Console from this console.
|
|
|
|
* We are in a metaconsole.
|
|
|
|
*/
|
|
|
|
|
|
|
|
return $baseUrl.'?'.http_build_query(
|
|
|
|
[
|
2023-03-04 13:22:52 +01:00
|
|
|
'sec' => 'screen',
|
|
|
|
'sec2' => 'screens/screens',
|
|
|
|
'action' => 'visualmap',
|
|
|
|
'id' => $vcId,
|
|
|
|
'pure' => (int) (isset($config['pure']) === true) ? $config['pure'] : 0,
|
2019-04-09 15:30:08 +02:00
|
|
|
]
|
|
|
|
);
|
2019-08-01 11:49:00 +02:00
|
|
|
} else if (empty($linkedLayoutNodeId) === true
|
2021-03-24 12:43:51 +01:00
|
|
|
&& \is_metaconsole() === false
|
2019-04-29 10:45:12 +02:00
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* A Visual Console from this console.
|
|
|
|
* We are in a regular console.
|
|
|
|
*/
|
|
|
|
|
2020-12-22 14:40:04 +01:00
|
|
|
if ($mobile_navigation === true) {
|
|
|
|
return $mobileUrl.'?'.http_build_query(
|
|
|
|
[
|
|
|
|
'page' => 'visualmap',
|
|
|
|
'id' => $vcId,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
return $baseUrl.'?'.http_build_query(
|
|
|
|
[
|
|
|
|
'sec' => 'network',
|
|
|
|
'sec2' => 'operation/visual_console/view',
|
|
|
|
'id' => $vcId,
|
2022-07-28 14:25:31 +02:00
|
|
|
'pure' => (int) (isset($config['pure']) === true) ? $config['pure'] : 0,
|
2019-04-09 15:30:08 +02:00
|
|
|
]
|
|
|
|
);
|
2021-03-24 12:43:51 +01:00
|
|
|
} else if (\is_metaconsole() === true
|
|
|
|
&& (bool) \can_user_access_node() === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* A Visual Console from a meta node.
|
|
|
|
* We are in a metaconsole.
|
|
|
|
*/
|
|
|
|
|
|
|
|
try {
|
|
|
|
$node = \metaconsole_get_connection_by_id(
|
2019-08-01 11:49:00 +02:00
|
|
|
$linkedLayoutNodeId
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
2020-01-29 10:15:31 +01:00
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
return \ui_meta_get_node_url(
|
|
|
|
$node,
|
|
|
|
'network',
|
|
|
|
'operation/visual_console/view',
|
2020-01-29 10:15:31 +01:00
|
|
|
['id' => $vcId],
|
2019-04-09 15:30:08 +02:00
|
|
|
// No autologin from the public view.
|
2022-03-10 16:56:00 +01:00
|
|
|
!$config['public_view'],
|
|
|
|
$mobile_navigation,
|
|
|
|
[
|
|
|
|
'page' => 'visualmap',
|
|
|
|
'id' => $vcId,
|
|
|
|
]
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
2019-04-09 16:35:58 +02:00
|
|
|
} catch (\Throwable $ignored) {
|
2019-04-09 15:30:08 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (static::$useLinkedModule === true
|
|
|
|
&& $linkedModule['moduleId'] !== null
|
|
|
|
&& $linkedModule['moduleId'] > 0
|
|
|
|
) {
|
|
|
|
// Module Id.
|
|
|
|
$moduleId = $linkedModule['moduleId'];
|
|
|
|
// The module can be from another node.
|
|
|
|
$metaconsoleId = $linkedModule['metaconsoleId'];
|
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (is_metaconsole() === false
|
|
|
|
|| empty($metaconsoleId) === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* A module from this console.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Check if the module is from a service.
|
|
|
|
$serviceId = (int) \db_get_value_filter(
|
|
|
|
'custom_integer_1',
|
|
|
|
'tagente_modulo',
|
|
|
|
[
|
|
|
|
'id_agente_modulo' => $moduleId,
|
|
|
|
'prediction_module' => 1,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
if (empty($serviceId) === false) {
|
|
|
|
// A service.
|
|
|
|
$queryParams = [
|
|
|
|
'sec' => 'services',
|
|
|
|
'sec2' => 'enterprise/operation/services/services',
|
|
|
|
'id_service' => $serviceId,
|
|
|
|
];
|
|
|
|
} else {
|
|
|
|
// A regular module.
|
|
|
|
$queryParams = [
|
|
|
|
'sec' => 'view',
|
|
|
|
'sec2' => 'operation/agentes/status_monitor',
|
|
|
|
'id_module' => $moduleId,
|
|
|
|
];
|
|
|
|
|
2022-03-10 16:56:00 +01:00
|
|
|
if ($mobile_navigation === true) {
|
|
|
|
return $mobileUrl.'?'.http_build_query(
|
|
|
|
[
|
|
|
|
'page' => 'module_graph',
|
|
|
|
'id' => $moduleId,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
2020-12-22 14:40:04 +01:00
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
return $baseUrl.'?'.http_build_query($queryParams);
|
2021-03-24 12:43:51 +01:00
|
|
|
} else if (\is_metaconsole() === true
|
|
|
|
&& (bool) \can_user_access_node() === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* A module from a meta node.
|
|
|
|
* We are in a metaconsole.
|
|
|
|
*/
|
|
|
|
|
|
|
|
try {
|
|
|
|
$node = \metaconsole_get_connection_by_id(
|
|
|
|
$metaconsoleId
|
|
|
|
);
|
|
|
|
|
|
|
|
// Connect to node.
|
|
|
|
if (\metaconsole_connect($node) !== NOERR) {
|
|
|
|
// Will be catched below.
|
|
|
|
throw new \Exception(
|
|
|
|
'error connecting to the node'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if the module is a service.
|
|
|
|
$serviceId = (int) \db_get_value_filter(
|
|
|
|
'custom_integer_1',
|
|
|
|
'tagente_modulo',
|
|
|
|
[
|
|
|
|
'id_agente_modulo' => $moduleId,
|
|
|
|
'prediction_module' => 1,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
// Restore connection.
|
|
|
|
\metaconsole_restore_db();
|
|
|
|
|
|
|
|
if (empty($serviceId) === false) {
|
|
|
|
// A service.
|
|
|
|
return \ui_meta_get_node_url(
|
|
|
|
$node,
|
|
|
|
'services',
|
|
|
|
'enterprise/operation/services/services',
|
|
|
|
['id_service' => $serviceId],
|
|
|
|
// No autologin from the public view.
|
|
|
|
!$config['public_view']
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
// A regular module.
|
|
|
|
return \ui_meta_get_node_url(
|
|
|
|
$node,
|
|
|
|
'view',
|
|
|
|
'operation/agentes/status_monitor',
|
|
|
|
['id_module' => $moduleId],
|
|
|
|
// No autologin from the public view.
|
2022-07-28 14:25:31 +02:00
|
|
|
!((isset($config['public_view']) === true) ? $config['public_view'] : false),
|
2022-03-10 16:56:00 +01:00
|
|
|
$mobile_navigation,
|
|
|
|
[
|
|
|
|
'id' => $moduleId,
|
|
|
|
'page' => 'module_graph',
|
|
|
|
]
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
|
|
|
}
|
2019-04-09 16:35:58 +02:00
|
|
|
} catch (\Throwable $ignored) {
|
2019-04-09 15:30:08 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2019-04-25 14:02:30 +02:00
|
|
|
} else if ((static::$useLinkedAgent === true
|
|
|
|
|| static::$useLinkedModule === true)
|
2019-04-09 15:30:08 +02:00
|
|
|
&& $linkedAgent['agentId'] !== null
|
|
|
|
&& $linkedAgent['agentId'] > 0
|
|
|
|
) {
|
|
|
|
// Linked agent.
|
|
|
|
// Agent Id.
|
|
|
|
$agentId = $linkedAgent['agentId'];
|
|
|
|
// The agent can be from another node.
|
|
|
|
$metaconsoleId = $linkedAgent['metaconsoleId'];
|
|
|
|
|
2021-03-24 12:43:51 +01:00
|
|
|
if (is_metaconsole() === false
|
|
|
|
|| empty($metaconsoleId) === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* An agent from this console.
|
|
|
|
* We are in a regular console.
|
|
|
|
*/
|
|
|
|
|
2020-12-22 14:40:04 +01:00
|
|
|
if ($mobile_navigation === true) {
|
|
|
|
return $mobileUrl.'?'.http_build_query(
|
|
|
|
[
|
|
|
|
'page' => 'agent',
|
|
|
|
'id' => $agentId,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-04-09 15:30:08 +02:00
|
|
|
return $baseUrl.'?'.http_build_query(
|
|
|
|
[
|
|
|
|
'sec' => 'estado',
|
|
|
|
'sec2' => 'operation/agentes/ver_agente',
|
|
|
|
'id_agente' => $agentId,
|
|
|
|
]
|
|
|
|
);
|
2021-03-24 12:43:51 +01:00
|
|
|
} else if (\is_metaconsole() === true
|
|
|
|
&& (bool) \can_user_access_node() === true
|
|
|
|
) {
|
2019-04-09 15:30:08 +02:00
|
|
|
/*
|
|
|
|
* An agent from a meta node.
|
|
|
|
* We are in a metaconsole.
|
|
|
|
*/
|
|
|
|
|
|
|
|
try {
|
|
|
|
$node = \metaconsole_get_connection_by_id(
|
|
|
|
$metaconsoleId
|
|
|
|
);
|
|
|
|
return \ui_meta_get_node_url(
|
|
|
|
$node,
|
|
|
|
'estado',
|
|
|
|
'operation/agentes/ver_agente',
|
2021-03-24 12:43:51 +01:00
|
|
|
['id_agente' => $agentId],
|
2019-04-09 15:30:08 +02:00
|
|
|
// No autologin from the public view.
|
2022-03-10 16:56:00 +01:00
|
|
|
!$config['public_view'],
|
|
|
|
$mobile_navigation,
|
|
|
|
[
|
|
|
|
'id' => $agentId,
|
|
|
|
'page' => 'agent',
|
|
|
|
]
|
2019-04-09 15:30:08 +02:00
|
|
|
);
|
2019-04-09 16:35:58 +02:00
|
|
|
} catch (\Throwable $ignored) {
|
2019-04-09 15:30:08 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-06-10 13:04:52 +02:00
|
|
|
/**
|
2019-08-05 12:58:25 +02:00
|
|
|
* TODO: CRITICAL. This function contains values which belong to its
|
|
|
|
* subclasses. This function should be overrided there to add them.
|
|
|
|
*
|
2019-06-10 13:04:52 +02:00
|
|
|
* Return a valid representation of a record in database.
|
|
|
|
*
|
|
|
|
* @param array $data Input data.
|
|
|
|
*
|
|
|
|
* @return array Data structure representing a record in database.
|
2019-06-13 14:51:27 +02:00
|
|
|
*
|
|
|
|
* @overrides Model::encode.
|
2019-06-10 13:04:52 +02:00
|
|
|
*/
|
2022-01-12 20:46:19 +01:00
|
|
|
protected static function encode(array $data): array
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
$result = [];
|
|
|
|
|
2019-06-13 14:51:27 +02:00
|
|
|
$id = static::getId($data);
|
2020-01-15 14:28:43 +01:00
|
|
|
if (isset($id) === true) {
|
2019-06-10 13:04:52 +02:00
|
|
|
$result['id'] = $id;
|
|
|
|
}
|
|
|
|
|
2019-06-13 14:51:27 +02:00
|
|
|
$id_layout = static::getIdLayout($data);
|
2020-01-15 14:28:43 +01:00
|
|
|
if (isset($id_layout) === true) {
|
2019-06-10 13:04:52 +02:00
|
|
|
$result['id_layout'] = $id_layout;
|
|
|
|
}
|
|
|
|
|
|
|
|
$pos_x = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['x', 'pos_x', 'posX']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($pos_x !== null) {
|
|
|
|
$result['pos_x'] = $pos_x;
|
|
|
|
}
|
|
|
|
|
|
|
|
$pos_y = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['y', 'pos_y', 'posY']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($pos_y !== null) {
|
|
|
|
$result['pos_y'] = $pos_y;
|
|
|
|
}
|
|
|
|
|
2019-06-13 14:51:27 +02:00
|
|
|
$height = static::getHeight($data);
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($height !== null) {
|
|
|
|
$result['height'] = $height;
|
|
|
|
}
|
|
|
|
|
2019-06-13 14:51:27 +02:00
|
|
|
$width = static::getWidth($data);
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($width !== null) {
|
|
|
|
$result['width'] = $width;
|
|
|
|
}
|
|
|
|
|
|
|
|
$label = static::extractLabel($data);
|
|
|
|
if ($label !== null) {
|
|
|
|
$result['label'] = $label;
|
|
|
|
}
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
// TODO change.
|
2019-06-13 14:51:27 +02:00
|
|
|
$image = static::getImageSrc($data);
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($image !== null) {
|
|
|
|
$result['image'] = $image;
|
|
|
|
}
|
|
|
|
|
|
|
|
$type = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['type']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($type !== null) {
|
|
|
|
$result['type'] = $type;
|
|
|
|
}
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
// TODO change.
|
2019-06-10 13:04:52 +02:00
|
|
|
$period = static::parseIntOr(
|
2019-06-11 15:26:10 +02:00
|
|
|
static::issetInArray($data, ['period', 'maxTime']),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($period !== null) {
|
|
|
|
$result['period'] = $period;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_agente_modulo = static::extractModuleId($data);
|
|
|
|
if ($id_agente_modulo !== null) {
|
|
|
|
$result['id_agente_modulo'] = $id_agente_modulo;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_agent = static::extractAgentId($data);
|
|
|
|
if ($id_agent !== null) {
|
|
|
|
$result['id_agent'] = $id_agent;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_layout_linked = static::parseIntOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutId',
|
|
|
|
'id_layout_linked',
|
|
|
|
'idLayoutLinked',
|
|
|
|
]
|
|
|
|
),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($id_layout_linked !== null) {
|
|
|
|
$result['id_layout_linked'] = $id_layout_linked;
|
|
|
|
}
|
|
|
|
|
|
|
|
$parent_item = static::extractParentId($data);
|
|
|
|
if ($parent_item !== null) {
|
|
|
|
$result['parent_item'] = $parent_item;
|
|
|
|
}
|
|
|
|
|
2019-08-01 11:49:00 +02:00
|
|
|
$enable_link = static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'isLinkEnabled',
|
|
|
|
'enable_link',
|
|
|
|
'enableLink',
|
|
|
|
]
|
|
|
|
);
|
2021-03-24 12:43:51 +01:00
|
|
|
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($enable_link !== null) {
|
|
|
|
$result['enable_link'] = static::parseBool($enable_link);
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_metaconsole = static::extractMetaconsoleId($data);
|
|
|
|
if ($id_metaconsole !== null) {
|
|
|
|
$result['id_metaconsole'] = $id_metaconsole;
|
|
|
|
}
|
|
|
|
|
2020-01-16 14:07:35 +01:00
|
|
|
$element_group = static::extractAclGroupId($data);
|
|
|
|
if ($element_group !== null) {
|
|
|
|
$result['element_group'] = $element_group;
|
2019-06-10 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$label_position = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['labelPosition', 'label_position']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($label_position !== null) {
|
|
|
|
$result['label_position'] = $label_position;
|
|
|
|
}
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
// TODO change.
|
2019-06-24 18:52:39 +02:00
|
|
|
$border_color = static::getBorderColor($data);
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($border_color !== null) {
|
|
|
|
$result['border_color'] = $border_color;
|
|
|
|
}
|
|
|
|
|
2021-07-08 10:03:57 +02:00
|
|
|
$id_custom_graph = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'customGraphId',
|
|
|
|
'id_custom_graph',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($id_custom_graph !== null) {
|
|
|
|
$result['id_custom_graph'] = $id_custom_graph;
|
|
|
|
}
|
|
|
|
|
2019-06-10 13:04:52 +02:00
|
|
|
$linked_layout_node_id = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
2019-08-01 11:49:00 +02:00
|
|
|
'linkedLayoutNodeId',
|
2019-06-10 13:04:52 +02:00
|
|
|
'linked_layout_node_id',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($linked_layout_node_id !== null) {
|
|
|
|
$result['linked_layout_node_id'] = $linked_layout_node_id;
|
|
|
|
}
|
|
|
|
|
|
|
|
$linked_layout_status_type = static::notEmptyStringOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusType',
|
|
|
|
'linked_layout_status_type',
|
|
|
|
]
|
|
|
|
),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($linked_layout_status_type !== null) {
|
|
|
|
$result['linked_layout_status_type'] = $linked_layout_status_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_layout_linked_weight = static::parseIntOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWeight',
|
|
|
|
'id_layout_linked_weight',
|
|
|
|
]
|
|
|
|
),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($id_layout_linked_weight !== null) {
|
|
|
|
$result['id_layout_linked_weight'] = $id_layout_linked_weight;
|
|
|
|
}
|
|
|
|
|
|
|
|
$linked_layout_status_as_service_warning = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeWarningThreshold',
|
|
|
|
'linked_layout_status_as_service_warning',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($linked_layout_status_as_service_warning !== null) {
|
|
|
|
$result['linked_layout_status_as_service_warning'] = $linked_layout_status_as_service_warning;
|
|
|
|
}
|
|
|
|
|
|
|
|
$linked_layout_status_as_service_critical = static::parseIntOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'linkedLayoutStatusTypeCriticalThreshold',
|
|
|
|
'linked_layout_status_as_service_critical',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($linked_layout_status_as_service_critical !== null) {
|
|
|
|
$result['linked_layout_status_as_service_critical'] = $linked_layout_status_as_service_critical;
|
|
|
|
}
|
|
|
|
|
|
|
|
$element_group = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['elementGroup', 'element_group']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
if ($element_group !== null) {
|
|
|
|
$result['element_group'] = $element_group;
|
|
|
|
}
|
|
|
|
|
2019-08-01 11:49:00 +02:00
|
|
|
$show_on_top = static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'isOnTop',
|
|
|
|
'show_on_top',
|
|
|
|
'showOnTop',
|
|
|
|
]
|
|
|
|
);
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($show_on_top !== null) {
|
|
|
|
$result['show_on_top'] = static::parseBool($show_on_top);
|
|
|
|
}
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
// TODO change.
|
2019-09-18 11:49:33 +02:00
|
|
|
$show_last_value = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['showLastValueTooltip']),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
2019-09-18 11:49:33 +02:00
|
|
|
if ($show_last_value === null) {
|
|
|
|
$show_last_value = static::parseIntOr(
|
2020-01-15 17:37:24 +01:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'show_last_value',
|
|
|
|
'showLastValue',
|
|
|
|
]
|
|
|
|
),
|
2019-09-18 11:49:33 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-06-10 13:04:52 +02:00
|
|
|
if ($show_last_value !== null) {
|
2019-09-18 11:49:33 +02:00
|
|
|
if (\is_numeric($show_last_value) === true) {
|
|
|
|
$result['show_last_value'] = $show_last_value;
|
|
|
|
} else {
|
|
|
|
switch ($show_last_value) {
|
|
|
|
case 'enabled':
|
|
|
|
$result['show_last_value'] = 1;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'disabled':
|
|
|
|
$result['show_last_value'] = 2;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$result['show_last_value'] = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2019-06-10 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
2019-08-05 12:58:25 +02:00
|
|
|
$cacheExpiration = static::extractCacheExpiration($data);
|
|
|
|
if ($cacheExpiration !== null) {
|
|
|
|
$result['cache_expiration'] = $cacheExpiration;
|
2019-06-10 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract item id.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Item id. 0 by default.
|
|
|
|
*/
|
2019-06-13 14:51:27 +02:00
|
|
|
private static function getId(array $data): int
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['id', 'itemId']),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract layout id.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Item id. 0 by default.
|
|
|
|
*/
|
2019-06-13 14:51:27 +02:00
|
|
|
private static function getIdLayout(array $data): int
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['id_layout', 'idLayout', 'layoutId']),
|
|
|
|
0
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract item width.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Item width. 0 by default.
|
|
|
|
*/
|
2019-06-13 14:51:27 +02:00
|
|
|
private static function getWidth(array $data)
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
2019-06-11 15:26:10 +02:00
|
|
|
static::issetInArray($data, ['width', 'endX']),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract item height.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Item height. 0 by default.
|
|
|
|
*/
|
2019-06-13 14:51:27 +02:00
|
|
|
private static function getHeight(array $data)
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
2019-06-11 15:26:10 +02:00
|
|
|
static::issetInArray($data, ['height', 'endY']),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract a image src value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the image url (not empty) or null.
|
|
|
|
*/
|
2019-06-13 14:51:27 +02:00
|
|
|
protected static function getImageSrc(array $data)
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
2019-12-17 10:57:19 +01:00
|
|
|
$imageSrc = static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'imageSrc',
|
2023-01-19 10:37:52 +01:00
|
|
|
'image',
|
2019-12-17 10:57:19 +01:00
|
|
|
'backgroundColor',
|
|
|
|
'backgroundType',
|
|
|
|
'valueType',
|
|
|
|
]
|
2019-06-10 13:04:52 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
return $imageSrc;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract a border width value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Valid border width.
|
|
|
|
*/
|
2020-01-15 17:37:24 +01:00
|
|
|
protected static function getBorderWidth(array $data)
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['border_width', 'borderWidth']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extract a border color value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the border color (not empty) or null.
|
|
|
|
*/
|
2020-01-15 17:37:24 +01:00
|
|
|
protected static function getBorderColor(array $data)
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
|
|
|
return static::notEmptyStringOr(
|
2019-08-01 11:49:00 +02:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'borderColor',
|
|
|
|
'border_color',
|
|
|
|
'gridColor',
|
|
|
|
'color',
|
|
|
|
'legendBackgroundColor',
|
2021-06-29 12:03:49 +02:00
|
|
|
'legendColor',
|
2021-07-12 12:27:10 +02:00
|
|
|
'titleColor',
|
2021-08-03 15:46:01 +02:00
|
|
|
'moduleNameColor',
|
2019-08-01 11:49:00 +02:00
|
|
|
]
|
|
|
|
),
|
2019-06-10 13:04:52 +02:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-01-12 20:46:19 +01:00
|
|
|
/**
|
|
|
|
* Update an item in the database
|
2019-06-10 13:04:52 +02:00
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return boolean The modeled element data structure stored into the DB.
|
2019-06-13 14:51:27 +02:00
|
|
|
*
|
|
|
|
* @overrides Model::save.
|
2019-06-10 13:04:52 +02:00
|
|
|
*/
|
2019-07-31 13:23:25 +02:00
|
|
|
public function save(array $data=[]): int
|
2019-06-10 13:04:52 +02:00
|
|
|
{
|
2022-01-13 13:48:25 +01:00
|
|
|
$data = ($data ?? $this->toArray());
|
2022-01-12 20:46:19 +01:00
|
|
|
|
2019-08-01 11:49:00 +02:00
|
|
|
if (empty($data) === false) {
|
|
|
|
if (empty($data['id']) === true) {
|
2019-06-18 10:13:56 +02:00
|
|
|
// Insert.
|
2022-01-13 10:47:53 +01:00
|
|
|
$save = static::encode($data);
|
2020-01-13 09:53:00 +01:00
|
|
|
|
2019-06-18 10:13:56 +02:00
|
|
|
$result = \db_process_sql_insert('tlayout_data', $save);
|
2022-01-12 20:46:19 +01:00
|
|
|
if ($result !== false) {
|
2019-06-18 17:28:36 +02:00
|
|
|
$item = static::fromDB(['id' => $result]);
|
2019-07-31 13:23:25 +02:00
|
|
|
$item->setData($item->toArray());
|
2019-06-18 17:28:36 +02:00
|
|
|
}
|
2019-06-18 10:13:56 +02:00
|
|
|
} else {
|
|
|
|
// Update.
|
2022-01-13 10:47:53 +01:00
|
|
|
$dataModelEncode = static::encode($this->toArray());
|
2022-01-13 12:16:39 +01:00
|
|
|
// Exception colorcloud...
|
|
|
|
$dataEncode = static::encode(
|
|
|
|
array_merge($this->toArray(), $data)
|
|
|
|
);
|
2019-07-31 13:23:25 +02:00
|
|
|
|
|
|
|
$save = array_merge($dataModelEncode, $dataEncode);
|
|
|
|
|
2023-06-15 11:52:42 +02:00
|
|
|
if (!empty($save['label'])) {
|
|
|
|
$save['label'] = io_safe_output(io_safe_input(str_replace("'", "\'", $save['label'])));
|
|
|
|
}
|
|
|
|
|
2019-08-01 11:49:00 +02:00
|
|
|
$result = \db_process_sql_update(
|
|
|
|
'tlayout_data',
|
|
|
|
$save,
|
|
|
|
['id' => $save['id']]
|
|
|
|
);
|
2020-01-15 17:37:24 +01:00
|
|
|
|
2019-06-19 18:00:53 +02:00
|
|
|
// Invalidate the item's cache.
|
|
|
|
if ($result !== false && $result > 0) {
|
2019-07-16 16:27:23 +02:00
|
|
|
// TODO: Invalidate the cache with the function clearCachedData.
|
2019-08-09 15:19:35 +02:00
|
|
|
\db_process_sql_delete(
|
2019-06-19 18:00:53 +02:00
|
|
|
'tvisual_console_elements_cache',
|
|
|
|
[
|
|
|
|
'vc_item_id' => (int) $save['id'],
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2019-06-18 17:28:36 +02:00
|
|
|
$item = static::fromDB(['id' => $save['id']]);
|
|
|
|
// Update the model.
|
2021-03-24 12:43:51 +01:00
|
|
|
if (empty($item) === false) {
|
2019-06-18 17:28:36 +02:00
|
|
|
$this->setData($item->toArray());
|
|
|
|
}
|
|
|
|
}
|
2019-06-18 10:13:56 +02:00
|
|
|
}
|
2019-06-10 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
2019-07-31 13:23:25 +02:00
|
|
|
return $result;
|
2019-06-10 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-07-25 17:58:37 +02:00
|
|
|
/**
|
|
|
|
* Delete an item in the database
|
|
|
|
*
|
|
|
|
* @param integer $itemId Identifier of the Item.
|
|
|
|
*
|
|
|
|
* @return boolean The modeled element data structure stored into the DB.
|
|
|
|
*
|
|
|
|
* @overrides Model::delete.
|
|
|
|
*/
|
|
|
|
public function delete(int $itemId): bool
|
|
|
|
{
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tlayout_data',
|
|
|
|
['id' => $itemId]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($result) {
|
2019-08-01 11:49:00 +02:00
|
|
|
// TODO: Invalidate the cache with the function clearCachedData.
|
2019-07-25 17:58:37 +02:00
|
|
|
db_process_sql_delete(
|
|
|
|
'tvisual_console_elements_cache',
|
|
|
|
['vc_item_id' => $itemId]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (bool) $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-02 18:37:50 +02:00
|
|
|
/**
|
|
|
|
* Generates inputs for form (global, common).
|
|
|
|
*
|
2019-12-19 20:42:29 +01:00
|
|
|
* @param array $values Default values.
|
2019-10-02 18:37:50 +02:00
|
|
|
*
|
|
|
|
* @return array Of inputs.
|
|
|
|
*/
|
2019-12-19 20:42:29 +01:00
|
|
|
public static function getFormInputs(array $values): array
|
2019-10-02 18:37:50 +02:00
|
|
|
{
|
|
|
|
$inputs = [];
|
|
|
|
|
2019-12-19 20:42:29 +01:00
|
|
|
switch ($values['tabSelected']) {
|
2019-12-17 10:57:19 +01:00
|
|
|
case 'label':
|
2020-01-16 16:55:48 +01:00
|
|
|
$inputs[] = [
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'hidden',
|
|
|
|
'name' => 'tabLabel',
|
|
|
|
'value' => true,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2019-12-17 10:57:19 +01:00
|
|
|
// Label.
|
2020-01-09 18:05:21 +01:00
|
|
|
$inputs[] = ['label' => __('Label')];
|
|
|
|
|
2019-12-17 10:57:19 +01:00
|
|
|
$inputs[] = [
|
2020-01-09 18:05:21 +01:00
|
|
|
'id' => 'div-textarea-label',
|
2019-12-17 10:57:19 +01:00
|
|
|
'arguments' => [
|
2023-04-04 11:24:49 +02:00
|
|
|
'type' => 'textarea',
|
|
|
|
'name' => 'label',
|
|
|
|
'value' => $values['label'],
|
|
|
|
'return' => true,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
];
|
2020-01-10 13:48:07 +01:00
|
|
|
|
|
|
|
// Label Position.
|
|
|
|
$fields = [
|
|
|
|
'down' => __('Bottom'),
|
|
|
|
'up' => __('Top'),
|
|
|
|
'right' => __('Right'),
|
|
|
|
'left' => __('Left'),
|
|
|
|
];
|
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Label position'),
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'select',
|
|
|
|
'fields' => $fields,
|
|
|
|
'name' => 'labelPosition',
|
|
|
|
'selected' => $values['labelPosition'],
|
|
|
|
'return' => true,
|
|
|
|
],
|
|
|
|
];
|
2019-12-17 10:57:19 +01:00
|
|
|
break;
|
2019-10-02 18:37:50 +02:00
|
|
|
|
2019-12-17 10:57:19 +01:00
|
|
|
case 'general':
|
2020-01-07 12:00:39 +01:00
|
|
|
$inputs[] = [
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'hidden',
|
|
|
|
'name' => 'tabGeneral',
|
|
|
|
'value' => true,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2019-12-17 10:57:19 +01:00
|
|
|
// Size.
|
|
|
|
$inputs[] = [
|
|
|
|
'block_id' => 'size-item',
|
|
|
|
'class' => 'flex-row flex-start w100p',
|
|
|
|
'direct' => 1,
|
|
|
|
'block_content' => [
|
|
|
|
[
|
|
|
|
'label' => __('Size'),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'label' => __('width'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'width',
|
|
|
|
'type' => 'number',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['width'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'label' => __('height'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'height',
|
|
|
|
'type' => 'number',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['height'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Position.
|
|
|
|
$inputs[] = [
|
|
|
|
'block_id' => 'position-item',
|
|
|
|
'class' => 'flex-row flex-start w100p',
|
|
|
|
'direct' => 1,
|
|
|
|
'block_content' => [
|
|
|
|
[
|
|
|
|
'label' => __('Position'),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'label' => __('X'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'x',
|
|
|
|
'type' => 'number',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['x'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'label' => __('Y'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'y',
|
|
|
|
'type' => 'number',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['y'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2020-02-05 18:56:28 +01:00
|
|
|
if ($values['type'] !== LABEL) {
|
|
|
|
// Link enabled.
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Link enabled'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'isLinkEnabled',
|
|
|
|
'id' => 'isLinkEnabled',
|
|
|
|
'type' => 'switch',
|
|
|
|
'value' => $values['isLinkEnabled'],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
2019-12-18 17:36:01 +01:00
|
|
|
|
|
|
|
// Show on top.
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Show on top'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'isOnTop',
|
|
|
|
'id' => 'isOnTop',
|
|
|
|
'type' => 'switch',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['isOnTop'],
|
2019-12-18 17:36:01 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2019-12-17 10:57:19 +01:00
|
|
|
// Parent.
|
2020-01-07 18:07:07 +01:00
|
|
|
// Check groups can access user.
|
|
|
|
$aclUserGroups = [];
|
|
|
|
if (!\users_can_manage_group_all('AR')) {
|
|
|
|
$aclUserGroups = array_keys(
|
|
|
|
\users_get_groups(false, 'AR')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$vcItems = VC::getItemsFromDB(
|
|
|
|
$values['vCId'],
|
|
|
|
$aclUserGroups
|
|
|
|
);
|
|
|
|
|
|
|
|
$fields = [];
|
2019-12-17 10:57:19 +01:00
|
|
|
$fields[0] = __('None');
|
2020-01-07 18:07:07 +01:00
|
|
|
foreach ($vcItems as $key => $value) {
|
2020-01-13 14:19:56 +01:00
|
|
|
$text = '';
|
2020-01-07 18:07:07 +01:00
|
|
|
$data = $value->toArray();
|
|
|
|
switch ($data['type']) {
|
|
|
|
case STATIC_GRAPH:
|
|
|
|
$text = __('Static graph');
|
|
|
|
$text .= ' - ';
|
|
|
|
$text .= $data['imageSrc'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case MODULE_GRAPH:
|
|
|
|
$text = __('Module graph');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CLOCK:
|
|
|
|
$text = __('Clock');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BARS_GRAPH:
|
|
|
|
$text = __('Bars graph');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case AUTO_SLA_GRAPH:
|
2020-01-23 19:54:47 +01:00
|
|
|
$text = __('Event History Graph');
|
2020-01-07 18:07:07 +01:00
|
|
|
break;
|
|
|
|
|
|
|
|
case PERCENTILE_BAR:
|
|
|
|
$text = __('Percentile bar');
|
|
|
|
break;
|
|
|
|
|
2020-01-13 14:19:56 +01:00
|
|
|
case PERCENTILE_BUBBLE:
|
|
|
|
$text = __('Percentile bubble');
|
|
|
|
break;
|
|
|
|
|
2020-01-07 18:07:07 +01:00
|
|
|
case CIRCULAR_PROGRESS_BAR:
|
|
|
|
$text = __('Circular progress bar');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CIRCULAR_INTERIOR_PROGRESS_BAR:
|
|
|
|
$text = __('Circular progress bar (interior)');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SIMPLE_VALUE:
|
|
|
|
$text = __('Simple Value');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case LABEL:
|
|
|
|
$text = __('Label');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case GROUP_ITEM:
|
|
|
|
$text = __('Group');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case COLOR_CLOUD:
|
|
|
|
$text = __('Color cloud');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case ICON:
|
|
|
|
$text = __('Icon');
|
|
|
|
break;
|
|
|
|
|
2021-07-12 12:27:10 +02:00
|
|
|
case ODOMETER:
|
|
|
|
$text = __('Odometer');
|
|
|
|
break;
|
|
|
|
|
2021-07-16 14:16:45 +02:00
|
|
|
case BASIC_CHART:
|
|
|
|
$text = __('Basic chart');
|
|
|
|
break;
|
|
|
|
|
2020-01-07 18:07:07 +01:00
|
|
|
default:
|
2021-02-02 19:06:05 +01:00
|
|
|
// Lines could not be parents.
|
|
|
|
continue 2;
|
2020-01-07 18:07:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['agentAlias']) === true
|
|
|
|
&& empty($data['agentAlias']) === false
|
|
|
|
) {
|
|
|
|
$text .= ' ('.$data['agentAlias'].')';
|
|
|
|
}
|
|
|
|
|
2020-01-13 14:19:56 +01:00
|
|
|
if ($data['id'] !== $values['id']) {
|
|
|
|
$fields[$data['id']] = $text;
|
|
|
|
}
|
2020-01-07 18:07:07 +01:00
|
|
|
}
|
2019-12-17 10:57:19 +01:00
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Parent'),
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'select',
|
|
|
|
'fields' => $fields,
|
|
|
|
'name' => 'parentId',
|
2019-12-19 20:42:29 +01:00
|
|
|
'selected' => $values['parentId'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
2020-01-13 14:19:56 +01:00
|
|
|
'sort' => false,
|
2019-12-17 10:57:19 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Restrict access to group.
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Restrict access to group'),
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'select_groups',
|
|
|
|
'name' => 'aclGroupId',
|
|
|
|
'returnAllGroup' => true,
|
2019-12-19 20:42:29 +01:00
|
|
|
'privilege' => $values['access'],
|
|
|
|
'selected' => $values['aclGroupId'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'return' => true,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Cache expiration.
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Cache expiration'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'cacheExpiration',
|
|
|
|
'type' => 'interval',
|
2019-12-19 20:42:29 +01:00
|
|
|
'value' => $values['cacheExpiration'],
|
2019-12-17 10:57:19 +01:00
|
|
|
'nothing' => __('None'),
|
|
|
|
'nothing_value' => 0,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'specific':
|
|
|
|
// Override.
|
|
|
|
$inputs = [];
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
// Not possible.
|
|
|
|
break;
|
|
|
|
}
|
2019-10-02 18:37:50 +02:00
|
|
|
|
|
|
|
return $inputs;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
/**
|
|
|
|
* Default values.
|
|
|
|
*
|
|
|
|
* @param array $values Array values.
|
|
|
|
*
|
|
|
|
* @return array Array with default values.
|
|
|
|
*/
|
2022-01-11 14:46:57 +01:00
|
|
|
public static function getDefaultGeneralValues(array $values): array
|
2020-01-15 14:28:43 +01:00
|
|
|
{
|
2020-01-16 14:07:35 +01:00
|
|
|
global $config;
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
// Default values.
|
|
|
|
if (isset($values['x']) === false) {
|
|
|
|
$values['x'] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($values['y']) === false) {
|
|
|
|
$values['y'] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($values['parentId']) === false) {
|
|
|
|
$values['parentId'] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($values['aclGroupId']) === false) {
|
|
|
|
$values['aclGroupId'] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($values['isLinkEnabled']) === false) {
|
|
|
|
$values['isLinkEnabled'] = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($values['isOnTop']) === false) {
|
|
|
|
$values['isOnTop'] = false;
|
|
|
|
}
|
|
|
|
|
2020-01-16 14:07:35 +01:00
|
|
|
if (isset($values['cacheExpiration']) === false) {
|
|
|
|
$values['cacheExpiration'] = $config['vc_default_cache_expiration'];
|
|
|
|
}
|
|
|
|
|
2020-01-15 14:28:43 +01:00
|
|
|
return $values;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-18 17:36:01 +01:00
|
|
|
/**
|
|
|
|
* List images for Vc Icons.
|
|
|
|
*
|
2020-01-23 16:21:31 +01:00
|
|
|
* @param boolean|null $service If service item.
|
|
|
|
*
|
2019-12-18 17:36:01 +01:00
|
|
|
* @return array
|
|
|
|
*/
|
2022-01-11 14:46:57 +01:00
|
|
|
public static function getListImagesVC(?bool $service=false):array
|
2019-12-18 17:36:01 +01:00
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$result = [];
|
|
|
|
|
|
|
|
// Extract images.
|
|
|
|
$all_images = \list_files(
|
|
|
|
$config['homedir'].'/images/console/icons/',
|
|
|
|
'png',
|
|
|
|
1,
|
|
|
|
0
|
|
|
|
);
|
|
|
|
|
|
|
|
if (isset($all_images) === true && is_array($all_images) === true) {
|
|
|
|
$base_url = \ui_get_full_url(
|
|
|
|
'/images/console/icons/',
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false
|
|
|
|
);
|
|
|
|
|
2022-11-29 16:45:44 +01:00
|
|
|
$aux_images = $all_images;
|
2019-12-18 17:36:01 +01:00
|
|
|
foreach ($all_images as $image_file) {
|
|
|
|
$image_file = substr($image_file, 0, (strlen($image_file) - 4));
|
|
|
|
|
|
|
|
if (strpos($image_file, '_bad') !== false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (strpos($image_file, '_ok') !== false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (strpos($image_file, '_warning') !== false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2022-11-29 16:45:44 +01:00
|
|
|
// Check the 4 images.
|
|
|
|
$array_images = preg_grep('/'.$image_file.'(_ok|_bad|_warning)*\./', $aux_images);
|
|
|
|
if (count($array_images) >= 4) {
|
|
|
|
$result[$image_file] = $image_file;
|
|
|
|
}
|
2019-12-18 17:36:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-23 16:21:31 +01:00
|
|
|
if ($service === true) {
|
|
|
|
\array_unshift($result, ['name' => __('None')]);
|
|
|
|
}
|
|
|
|
|
2019-12-18 17:36:01 +01:00
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-07 12:00:39 +01:00
|
|
|
/**
|
|
|
|
* Get all VC except own.
|
|
|
|
*
|
|
|
|
* @param integer $id Id Visual Console.
|
|
|
|
*
|
|
|
|
* @return array Array all VCs.
|
|
|
|
*/
|
2021-02-03 12:53:05 +01:00
|
|
|
public static function getAllVisualConsole(int $id):array
|
2020-01-07 12:00:39 +01:00
|
|
|
{
|
|
|
|
// Extract all VC except own.
|
|
|
|
$result = db_get_all_rows_filter(
|
|
|
|
'tlayout',
|
|
|
|
'id != '.(int) $id,
|
|
|
|
[
|
|
|
|
'id',
|
|
|
|
'name',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
// Extract all VC for each node.
|
|
|
|
if (is_metaconsole() === true) {
|
|
|
|
enterprise_include_once('include/functions_metaconsole.php');
|
2021-02-03 12:53:05 +01:00
|
|
|
$meta_servers = (array) metaconsole_get_servers();
|
2020-01-07 12:00:39 +01:00
|
|
|
foreach ($meta_servers as $server) {
|
|
|
|
if (metaconsole_load_external_db($server) !== NOERR) {
|
|
|
|
metaconsole_restore_db();
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$node_visual_maps = db_get_all_rows_filter(
|
|
|
|
'tlayout',
|
|
|
|
[],
|
|
|
|
[
|
|
|
|
'id',
|
|
|
|
'name',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
if (isset($node_visual_maps) === true
|
|
|
|
&& is_array($node_visual_maps) === true
|
|
|
|
) {
|
|
|
|
foreach ($node_visual_maps as $node_visual_map) {
|
2020-01-28 12:44:37 +01:00
|
|
|
// ID.
|
2020-01-28 17:52:40 +01:00
|
|
|
$id = $node_visual_map['id'];
|
|
|
|
$id .= '|';
|
|
|
|
$id .= $server['id'];
|
2020-01-28 12:44:37 +01:00
|
|
|
|
2020-01-07 12:00:39 +01:00
|
|
|
// Name = vc_name - (node).
|
2020-01-28 17:52:40 +01:00
|
|
|
$name = $node_visual_map['name'];
|
|
|
|
$name .= ' - (';
|
|
|
|
$name .= $server['server_name'].')';
|
2020-01-07 12:00:39 +01:00
|
|
|
|
2020-01-28 17:52:40 +01:00
|
|
|
$result[$id] = $name;
|
2020-01-07 12:00:39 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-30 14:07:44 +01:00
|
|
|
if ($result === false || $result === '') {
|
2020-01-07 12:00:39 +01:00
|
|
|
$result = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Inputs for Linked Visual Console.
|
|
|
|
*
|
|
|
|
* @param array $values Array values item.
|
|
|
|
*
|
|
|
|
* @return array Inputs.
|
|
|
|
*/
|
2022-01-11 14:46:57 +01:00
|
|
|
public static function inputsLinkedVisualConsole(array $values):array
|
2020-01-07 12:00:39 +01:00
|
|
|
{
|
|
|
|
// LinkConsoleInputGroup.
|
|
|
|
$fields = self::getAllVisualConsole($values['vCId']);
|
2020-02-05 18:56:28 +01:00
|
|
|
|
|
|
|
if ($fields === false) {
|
|
|
|
$fields = [];
|
|
|
|
} else {
|
2021-02-03 12:53:05 +01:00
|
|
|
$rs = [];
|
|
|
|
foreach ($fields as $k => $v) {
|
|
|
|
if (isset($v['id']) === true && isset($v['name']) === true) {
|
|
|
|
// Modern environments use id-name format.
|
|
|
|
$rs[$v['id']] = $v;
|
|
|
|
} else {
|
|
|
|
// In MC environments is key-value.
|
|
|
|
$rs[$k] = $v;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$fields = $rs;
|
2020-02-05 18:56:28 +01:00
|
|
|
}
|
|
|
|
|
2020-01-07 12:00:39 +01:00
|
|
|
$getAllVisualConsoleValue = $values['linkedLayoutId'];
|
|
|
|
if (\is_metaconsole() === true) {
|
|
|
|
$getAllVisualConsoleValue = $values['linkedLayoutId'];
|
2020-01-28 12:44:37 +01:00
|
|
|
if ($values['linkedLayoutNodeId'] !== 0) {
|
|
|
|
$getAllVisualConsoleValue .= '|';
|
|
|
|
$getAllVisualConsoleValue .= $values['linkedLayoutNodeId'];
|
|
|
|
}
|
2020-01-07 12:00:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'label' => __('Linked visual console'),
|
|
|
|
'arguments' => [
|
2020-02-10 17:31:48 +01:00
|
|
|
'type' => 'select',
|
|
|
|
'fields' => $fields,
|
|
|
|
'name' => 'getAllVisualConsole',
|
|
|
|
'selected' => $getAllVisualConsoleValue,
|
|
|
|
'script' => 'linkedVisualConsoleChange()',
|
|
|
|
'return' => true,
|
|
|
|
'nothing' => __('None'),
|
|
|
|
'nothing_value' => 0,
|
2020-01-07 12:00:39 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'hidden',
|
|
|
|
'name' => 'linkedLayoutId',
|
|
|
|
'value' => $values['linkedLayoutId'],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'hidden',
|
|
|
|
'name' => 'linkedLayoutNodeId',
|
|
|
|
'value' => $values['linkedLayoutNodeId'],
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Initial hidden.
|
|
|
|
$hiddenType = true;
|
|
|
|
$hiddenWeight = true;
|
|
|
|
$hiddenCritical = true;
|
|
|
|
$hiddenWarning = true;
|
|
|
|
if (isset($values['linkedLayoutId']) === true
|
|
|
|
&& $values['linkedLayoutId'] !== 0
|
|
|
|
) {
|
|
|
|
$hiddenType = false;
|
|
|
|
if ($values['linkedLayoutStatusType'] === 'service') {
|
|
|
|
$hiddenCritical = false;
|
|
|
|
$hiddenWarning = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($values['linkedLayoutStatusType'] === 'weight') {
|
|
|
|
$hiddenWeight = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Type of the status calculation of the linked visual console.
|
|
|
|
$fields = [
|
|
|
|
'default' => __('By default'),
|
|
|
|
'weight' => __('By status weight'),
|
|
|
|
'service' => __('By critical elements'),
|
|
|
|
];
|
|
|
|
|
|
|
|
$inputs[] = [
|
|
|
|
'id' => 'li-linkedLayoutStatusType',
|
|
|
|
'hidden' => $hiddenType,
|
|
|
|
'label' => __(
|
|
|
|
'Type of the status calculation of the linked visual console'
|
|
|
|
),
|
|
|
|
'arguments' => [
|
|
|
|
'type' => 'select',
|
|
|
|
'fields' => $fields,
|
|
|
|
'name' => 'linkedLayoutStatusType',
|
|
|
|
'selected' => $values['linkedLayoutStatusType'],
|
|
|
|
'script' => 'linkedVisualConsoleTypeChange()',
|
|
|
|
'return' => true,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Linked visual console weight.
|
|
|
|
$inputs[] = [
|
|
|
|
'id' => 'li-linkedLayoutStatusTypeWeight',
|
|
|
|
'hidden' => $hiddenWeight,
|
|
|
|
'label' => __('Linked visual console weight'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'linkedLayoutStatusTypeWeight',
|
|
|
|
'type' => 'number',
|
|
|
|
'value' => $values['linkedLayoutStatusTypeWeight'],
|
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2020-01-07 12:00:39 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Critical weight.
|
|
|
|
$inputs[] = [
|
|
|
|
'id' => 'li-linkedLayoutStatusTypeCriticalThreshold',
|
|
|
|
'hidden' => $hiddenCritical,
|
|
|
|
'label' => __('Critical weight'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'linkedLayoutStatusTypeCriticalThreshold',
|
|
|
|
'type' => 'number',
|
|
|
|
'value' => $values['linkedLayoutStatusTypeCriticalThreshold'],
|
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2020-01-07 12:00:39 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
// Warning weight.
|
|
|
|
$inputs[] = [
|
|
|
|
'id' => 'li-linkedLayoutStatusTypeWarningThreshold',
|
|
|
|
'hidden' => $hiddenWarning,
|
|
|
|
'label' => __('Warning weight'),
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'linkedLayoutStatusTypeWarningThreshold',
|
|
|
|
'type' => 'number',
|
|
|
|
'value' => $values['linkedLayoutStatusTypeWarningThreshold'],
|
|
|
|
'return' => true,
|
2020-01-23 19:54:47 +01:00
|
|
|
'min' => 0,
|
2020-01-07 12:00:39 +01:00
|
|
|
],
|
|
|
|
];
|
|
|
|
|
|
|
|
return $inputs;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-07 15:43:44 +01:00
|
|
|
/**
|
|
|
|
* Return html images.
|
|
|
|
*
|
|
|
|
* @param string $image Name image.
|
|
|
|
* @param boolean|null $only Only normal image.
|
|
|
|
*
|
|
|
|
* @return string Html images.
|
|
|
|
*/
|
2020-01-10 13:48:07 +01:00
|
|
|
public static function imagesElementsVC(
|
|
|
|
string $image,
|
|
|
|
?bool $only=false
|
|
|
|
):string {
|
2020-01-07 15:43:44 +01:00
|
|
|
$images = '';
|
2020-01-23 16:21:31 +01:00
|
|
|
if ($image !== '0') {
|
|
|
|
$type_image = [''];
|
|
|
|
if ($only === false) {
|
|
|
|
$type_image = [
|
|
|
|
'bad',
|
|
|
|
'ok',
|
|
|
|
'warning',
|
|
|
|
'',
|
|
|
|
];
|
2020-01-07 15:43:44 +01:00
|
|
|
}
|
|
|
|
|
2020-01-23 16:21:31 +01:00
|
|
|
foreach ($type_image as $k => $v) {
|
|
|
|
$type = '';
|
|
|
|
if ($v !== '') {
|
|
|
|
$type = '_'.$v;
|
|
|
|
}
|
|
|
|
|
|
|
|
$images .= html_print_image(
|
|
|
|
'images/console/icons/'.$image.$type.'.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Image Vc'),
|
|
|
|
'alt' => __('Image Vc'),
|
|
|
|
'style' => 'max-width:70px; max-height:70px;',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
2020-01-07 15:43:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $images;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-13 17:13:52 +01:00
|
|
|
/**
|
|
|
|
* Return zones.
|
|
|
|
*
|
|
|
|
* @param string $zone Name zone.
|
|
|
|
*
|
|
|
|
* @return array Zones.
|
|
|
|
*/
|
|
|
|
public static function zonesVC(string $zone):array
|
|
|
|
{
|
|
|
|
$result = [];
|
|
|
|
$timezones = timezone_identifiers_list();
|
|
|
|
foreach ($timezones as $timezone) {
|
|
|
|
if (strpos($timezone, $zone) !== false) {
|
|
|
|
$result[$timezone] = $timezone;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-12-13 12:03:13 +01:00
|
|
|
/**
|
|
|
|
* Recursively check for alerts in a Visual Console item and its linked layout.
|
|
|
|
*
|
|
|
|
* @param array $item The Visual Console item to check for alerts.
|
|
|
|
* @param array $visitedLayouts A list of layouts that have already been visited to avoid circular references.
|
|
|
|
*
|
|
|
|
* @return boolean True if an alert has been found, false otherwise.
|
|
|
|
*/
|
|
|
|
public static function checkLayoutAlertsRecursive(array $item, array $visitedLayouts=[])
|
|
|
|
{
|
2022-12-13 15:25:16 +01:00
|
|
|
if (isset($item['type']) === true) {
|
|
|
|
$excludedItemTypes = [
|
|
|
|
22,
|
|
|
|
17,
|
|
|
|
18,
|
|
|
|
1,
|
|
|
|
23,
|
|
|
|
15,
|
|
|
|
14,
|
|
|
|
10,
|
|
|
|
4,
|
|
|
|
];
|
|
|
|
|
|
|
|
if (in_array($item['type'], $excludedItemTypes) === true) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-13 12:03:13 +01:00
|
|
|
$agentID = (int) $item['id_agent'];
|
|
|
|
$agentModuleID = (int) $item['id_agente_modulo'];
|
|
|
|
$linkedLayoutID = (int) $item['id_layout_linked'];
|
2022-12-13 15:25:16 +01:00
|
|
|
$metaconsoleID = (int) $item['id_metaconsole'];
|
2022-12-13 12:03:13 +01:00
|
|
|
|
|
|
|
$visitedLayouts[] = $item['id_layout'];
|
|
|
|
|
|
|
|
if ($agentModuleID !== 0 && $agentID !== 0) {
|
|
|
|
$alerts_sql = sprintf(
|
|
|
|
'SELECT talert_template_modules.id
|
|
|
|
FROM talert_template_modules
|
|
|
|
INNER JOIN tagente_modulo t2
|
|
|
|
ON talert_template_modules.id_agent_module = t2.id_agente_modulo
|
|
|
|
INNER JOIN tagente t3
|
|
|
|
ON t2.id_agente = t3.id_agente AND t3.id_agente = %d
|
|
|
|
INNER JOIN talert_templates t4
|
|
|
|
ON talert_template_modules.id_alert_template = t4.id
|
|
|
|
WHERE `id_agent_module` = %d AND talert_template_modules.times_fired > 0',
|
|
|
|
$agentID,
|
|
|
|
$agentModuleID
|
|
|
|
);
|
|
|
|
|
2022-12-13 15:25:16 +01:00
|
|
|
// Connect to node.
|
|
|
|
if (\is_metaconsole() === true
|
|
|
|
&& \metaconsole_connect(null, $metaconsoleID) !== NOERR
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'error connecting to the node'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-12-13 12:03:13 +01:00
|
|
|
$firedAlert = db_get_sql($alerts_sql);
|
|
|
|
|
2022-12-13 15:25:16 +01:00
|
|
|
// Restore connection.
|
|
|
|
if (\is_metaconsole() === true) {
|
|
|
|
\metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
2022-12-13 12:03:13 +01:00
|
|
|
// Item has a triggered alert.
|
|
|
|
if ($firedAlert !== false) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($linkedLayoutID === 0 || in_array($linkedLayoutID, $visitedLayouts) === true) {
|
|
|
|
// Item has no linked layout or it has already been visited (avoid infinite loop caused by circular references).
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$filter = ['id_layout' => $linkedLayoutID];
|
|
|
|
|
|
|
|
$linkedLayoutItems = \db_get_all_rows_filter(
|
|
|
|
'tlayout_data',
|
|
|
|
$filter,
|
|
|
|
[
|
|
|
|
'id_layout',
|
|
|
|
'id_agent',
|
|
|
|
'id_agente_modulo',
|
|
|
|
'id_layout_linked',
|
2022-12-13 15:25:16 +01:00
|
|
|
'id_metaconsole',
|
2022-12-13 12:03:13 +01:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($linkedLayoutItems === false) {
|
|
|
|
// There are no items in the linked visual console. Nothing to check.
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($linkedLayoutItems as $linkedLayoutItem) {
|
|
|
|
if (self::checkLayoutAlertsRecursive($linkedLayoutItem, $visitedLayouts)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2023-01-13 10:12:21 +01:00
|
|
|
|
|
|
|
|
2019-03-20 16:31:29 +01:00
|
|
|
}
|