2019-03-18 12:47:39 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace Models\VisualConsole;
|
|
|
|
use Models\Model;
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
/**
|
|
|
|
* Model of a Visual Console.
|
|
|
|
*/
|
2019-03-18 12:47:39 +01:00
|
|
|
final class Container extends Model
|
|
|
|
{
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 15:19:13 +01:00
|
|
|
* Validate the received data structure to ensure if we can extract the
|
|
|
|
* values required to build the model.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 15:19:13 +01:00
|
|
|
* @param array $data Input data.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 15:19:13 +01:00
|
|
|
* @return void
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 15:19:13 +01:00
|
|
|
* @throws \InvalidArgumentException If any input value is considered
|
|
|
|
* invalid.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 15:19:13 +01:00
|
|
|
* @overrides Model::validateData.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-03-18 13:35:30 +01:00
|
|
|
protected function validateData(array $data): void
|
2019-03-18 12:47:39 +01:00
|
|
|
{
|
|
|
|
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['name']) === false
|
|
|
|
|| \is_string($data['name']) === false
|
|
|
|
|| empty($data['name']) === true
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the name property is required and should be string'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['width']) === false
|
|
|
|
|| \is_numeric($data['width']) === false
|
|
|
|
|| $data['width'] <= 0
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the width property is required and should greater than 0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($data['height']) === false
|
|
|
|
|| \is_numeric($data['height']) === false
|
|
|
|
|| $data['height'] <= 0
|
|
|
|
) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the height property is required and should greater than 0'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-04-25 10:30:24 +02:00
|
|
|
static::extractGroupId($data);
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-21 17:47:10 +01:00
|
|
|
/**
|
2019-03-25 15:19:13 +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 15:19:13 +01:00
|
|
|
* @return array Data structure representing the model.
|
2019-03-21 17:47:10 +01:00
|
|
|
*
|
2019-03-25 15:19:13 +01:00
|
|
|
* @overrides Model::decode.
|
2019-03-21 17:47:10 +01:00
|
|
|
*/
|
2019-03-18 13:35:30 +01:00
|
|
|
protected function decode(array $data): array
|
2019-03-18 12:47:39 +01:00
|
|
|
{
|
|
|
|
return [
|
2019-04-16 12:23:03 +02:00
|
|
|
'id' => (int) $data['id'],
|
|
|
|
'name' => $data['name'],
|
2019-04-25 10:30:24 +02:00
|
|
|
'groupId' => static::extractGroupId($data),
|
|
|
|
'backgroundImage' => static::extractBackgroundImage($data),
|
|
|
|
'backgroundColor' => static::extractBackgroundColor($data),
|
|
|
|
'isFavorite' => static::extractFavorite($data),
|
2021-06-29 12:02:13 +02:00
|
|
|
'autoAdjust' => static::extractAutoAdjust($data),
|
2019-04-16 12:23:03 +02:00
|
|
|
'width' => (int) $data['width'],
|
|
|
|
'height' => (int) $data['height'],
|
2019-04-25 10:30:24 +02:00
|
|
|
'backgroundURL' => static::extractBackgroundUrl($data),
|
2019-04-16 12:23:03 +02:00
|
|
|
'relationLineWidth' => (int) $data['relationLineWidth'],
|
2020-11-23 16:38:06 +01:00
|
|
|
'hash' => static::extractHash($data),
|
2022-10-13 11:03:49 +02:00
|
|
|
'maintenanceMode' => static::extractMaintenanceMode($data),
|
2023-06-08 13:54:05 +02:00
|
|
|
'gridSize' => (int) $data['grid_size'],
|
|
|
|
'gridColor' => (string) $data['grid_color'],
|
2019-03-18 12:47:39 +01:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-06-13 14:51:27 +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.
|
|
|
|
*
|
|
|
|
* @overrides Model::encode.
|
|
|
|
*/
|
2022-01-12 20:46:19 +01:00
|
|
|
protected static function encode(array $data): array
|
2019-06-13 14:51:27 +02:00
|
|
|
{
|
|
|
|
$result = [];
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Insert or update an item in the database
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return boolean The modeled element data structure stored into the DB.
|
|
|
|
*
|
|
|
|
* @overrides Model::save.
|
|
|
|
*/
|
2019-06-18 17:28:36 +02:00
|
|
|
public function save(array $data=[]): bool
|
2019-06-13 14:51:27 +02:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
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
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
/**
|
|
|
|
* Extract a group Id value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return integer Valid identifier of a group.
|
|
|
|
*
|
|
|
|
* @throws \InvalidArgumentException When a valid group Id can't be found.
|
|
|
|
*/
|
2019-04-25 10:30:24 +02:00
|
|
|
private static function extractGroupId(array $data): int
|
2019-03-18 12:47:39 +01:00
|
|
|
{
|
2019-03-25 15:19:13 +01:00
|
|
|
$groupId = static::parseIntOr(
|
|
|
|
static::issetInArray($data, ['id_group', 'groupId']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($groupId === null || $groupId < 0) {
|
|
|
|
throw new \InvalidArgumentException(
|
|
|
|
'the group Id property is required and should be integer'
|
|
|
|
);
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
return $groupId;
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-12 09:14:44 +02:00
|
|
|
/**
|
|
|
|
* Extract a image name value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the image name (not empty) or null.
|
|
|
|
*/
|
2019-04-25 10:30:24 +02:00
|
|
|
private static function extractBackgroundImage(array $data)
|
2019-04-12 09:14:44 +02:00
|
|
|
{
|
|
|
|
$backgroundImage = static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['background', 'backgroundURL']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2023-06-05 15:20:02 +02:00
|
|
|
return ($backgroundImage === 'None.png' || $backgroundImage === null) ? null : str_replace(' ', '%20', $backgroundImage);
|
2019-04-12 09:14:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
/**
|
|
|
|
* Extract a image url value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the image url (not empty) or null.
|
|
|
|
*/
|
2019-04-25 10:30:24 +02:00
|
|
|
private static function extractBackgroundUrl(array $data)
|
2019-03-18 12:47:39 +01:00
|
|
|
{
|
2019-04-12 09:51:26 +02:00
|
|
|
return static::notEmptyStringOr(
|
2019-04-12 09:14:44 +02:00
|
|
|
static::issetInArray($data, ['backgroundURL']),
|
2019-03-19 12:03:02 +01:00
|
|
|
null
|
|
|
|
);
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-11-23 16:38:06 +01:00
|
|
|
/**
|
|
|
|
* Extract a hash.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing hash (not empty) or null.
|
|
|
|
*/
|
|
|
|
private static function extractHash(array $data)
|
|
|
|
{
|
|
|
|
return static::notEmptyStringOr(
|
|
|
|
static::issetInArray($data, ['hash']),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
/**
|
|
|
|
* Extract a background color value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the color (not empty) or null.
|
|
|
|
*/
|
2019-04-25 10:30:24 +02:00
|
|
|
private static function extractBackgroundColor(array $data)
|
2019-03-18 12:47:39 +01:00
|
|
|
{
|
2019-03-25 15:19:13 +01:00
|
|
|
return static::notEmptyStringOr(
|
2019-03-25 16:36:38 +01:00
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'backgroundColor',
|
|
|
|
'background_color',
|
|
|
|
]
|
|
|
|
),
|
2019-03-19 12:03:02 +01:00
|
|
|
null
|
|
|
|
);
|
|
|
|
}
|
2019-03-18 12:47:39 +01:00
|
|
|
|
|
|
|
|
2022-10-13 11:03:49 +02:00
|
|
|
/**
|
|
|
|
* Extract a background color value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return mixed String representing the color (not empty) or null.
|
|
|
|
*/
|
|
|
|
private static function extractMaintenanceMode(array $data)
|
|
|
|
{
|
2022-10-13 17:45:44 +02:00
|
|
|
global $config;
|
2022-10-13 11:03:49 +02:00
|
|
|
$maintenance_mode = static::notEmptyStringOr(
|
|
|
|
static::issetInArray(
|
|
|
|
$data,
|
|
|
|
[
|
|
|
|
'maintenanceMode',
|
|
|
|
'maintenance_mode',
|
|
|
|
]
|
|
|
|
),
|
|
|
|
null
|
|
|
|
);
|
|
|
|
|
2022-10-13 13:44:39 +02:00
|
|
|
$result = null;
|
|
|
|
if ($maintenance_mode !== null) {
|
|
|
|
$result = json_decode($maintenance_mode, true);
|
2022-10-13 17:45:44 +02:00
|
|
|
|
|
|
|
$result['date'] = date(
|
|
|
|
$config['date_format'],
|
|
|
|
$result['timestamp']
|
|
|
|
);
|
|
|
|
|
2022-10-13 13:44:39 +02:00
|
|
|
$result['timestamp'] = human_time_description_raw(
|
|
|
|
(time() - $result['timestamp'])
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
2022-10-13 11:03:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 15:19:13 +01:00
|
|
|
/**
|
|
|
|
* Extract the "is favorite" switch value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return boolean If the item is favorite or not.
|
|
|
|
*/
|
2019-04-25 10:30:24 +02:00
|
|
|
private static function extractFavorite(array $data): bool
|
2019-03-19 12:03:02 +01:00
|
|
|
{
|
2019-03-25 15:19:13 +01:00
|
|
|
return static::parseBool(
|
2019-03-25 16:36:38 +01:00
|
|
|
static::issetInArray($data, ['is_favourite', 'isFavorite'])
|
2019-03-19 12:03:02 +01:00
|
|
|
);
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-06-29 12:02:13 +02:00
|
|
|
/**
|
|
|
|
* Extract the "auto adjust" switch value.
|
|
|
|
*
|
|
|
|
* @param array $data Unknown input data structure.
|
|
|
|
*
|
|
|
|
* @return boolean If the item is favorite or not.
|
|
|
|
*/
|
|
|
|
private static function extractAutoAdjust(array $data): bool
|
|
|
|
{
|
|
|
|
return static::parseBool(
|
|
|
|
static::issetInArray($data, ['auto_adjust', 'autoAdjust'])
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-25 12:32:06 +01:00
|
|
|
/**
|
|
|
|
* Obtain a container data structure from the database using a filter.
|
|
|
|
*
|
|
|
|
* @param array $filter Filter of the Visual Console.
|
|
|
|
*
|
|
|
|
* @return self A Visual Console Container instance.
|
|
|
|
* @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
|
|
|
) {
|
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', $filter);
|
|
|
|
|
|
|
|
if ($row === false) {
|
|
|
|
throw new \Exception('error fetching the data from the DB');
|
|
|
|
}
|
|
|
|
|
2019-04-12 10:06:53 +02:00
|
|
|
// Load side libraries.
|
|
|
|
global $config;
|
2019-04-12 12:43:52 +02:00
|
|
|
include_once $config['homedir'].'/include/functions_io.php';
|
2019-04-12 10:06:53 +02:00
|
|
|
include_once $config['homedir'].'/include/functions_ui.php';
|
|
|
|
|
2019-04-16 09:49:50 +02:00
|
|
|
// Clean HTML entities.
|
|
|
|
$row = \io_safe_output($row);
|
|
|
|
|
2019-04-16 12:23:03 +02:00
|
|
|
$row['relationLineWidth'] = (int) $config['vc_line_thickness'];
|
|
|
|
|
2019-04-12 09:51:26 +02:00
|
|
|
$backgroundUrl = static::extractBackgroundUrl($row);
|
|
|
|
$backgroundImage = static::extractBackgroundImage($row);
|
|
|
|
|
|
|
|
if ($backgroundUrl === null && $backgroundImage !== null) {
|
2019-07-24 16:36:49 +02:00
|
|
|
$row['backgroundURL'] = \ui_get_full_url(
|
2019-04-25 16:36:17 +02:00
|
|
|
'images/console/background/'.$backgroundImage,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false
|
|
|
|
);
|
2019-04-12 09:51:26 +02:00
|
|
|
}
|
|
|
|
|
2020-11-23 16:38:06 +01:00
|
|
|
$row['hash'] = md5(
|
|
|
|
$config['dbpass'].$row['id'].$config['id_user']
|
|
|
|
);
|
|
|
|
|
2023-01-23 16:47:27 +01:00
|
|
|
return $row;
|
2019-03-25 12:32:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-03 10:08:01 +02:00
|
|
|
/**
|
2019-04-08 10:30:45 +02:00
|
|
|
* Obtain a item's class.
|
2019-04-03 10:08:01 +02:00
|
|
|
*
|
2019-04-08 10:30:45 +02:00
|
|
|
* @param integer $type Type of the item of the Visual Console.
|
2019-04-03 10:08:01 +02:00
|
|
|
*
|
2019-04-08 10:30:45 +02:00
|
|
|
* @return mixed A reference to the item's class.
|
2019-04-03 10:08:01 +02:00
|
|
|
*/
|
2019-04-08 10:30:45 +02:00
|
|
|
public static function getItemClass(int $type)
|
2019-04-03 10:08:01 +02:00
|
|
|
{
|
2019-04-08 10:30:45 +02:00
|
|
|
switch ($type) {
|
|
|
|
case STATIC_GRAPH:
|
|
|
|
return Items\StaticGraph::class;
|
|
|
|
|
|
|
|
case MODULE_GRAPH:
|
|
|
|
return Items\ModuleGraph::class;
|
|
|
|
|
|
|
|
case SIMPLE_VALUE:
|
|
|
|
case SIMPLE_VALUE_MAX:
|
|
|
|
case SIMPLE_VALUE_MIN:
|
|
|
|
case SIMPLE_VALUE_AVG:
|
|
|
|
return Items\SimpleValue::class;
|
|
|
|
|
|
|
|
case PERCENTILE_BAR:
|
|
|
|
case PERCENTILE_BUBBLE:
|
|
|
|
case CIRCULAR_PROGRESS_BAR:
|
|
|
|
case CIRCULAR_INTERIOR_PROGRESS_BAR:
|
|
|
|
return Items\Percentile::class;
|
|
|
|
|
|
|
|
case LABEL:
|
|
|
|
return Items\Label::class;
|
|
|
|
|
|
|
|
case ICON:
|
|
|
|
return Items\Icon::class;
|
|
|
|
|
2019-04-12 11:24:08 +02:00
|
|
|
// Enterprise item. It may not exist.
|
2019-04-08 17:16:05 +02:00
|
|
|
case SERVICE:
|
2019-04-12 11:24:08 +02:00
|
|
|
return \class_exists('\Enterprise\Models\VisualConsole\Items\Service') ? \Enterprise\Models\VisualConsole\Items\Service::class : Item::class;
|
2019-04-08 10:30:45 +02:00
|
|
|
|
|
|
|
case GROUP_ITEM:
|
2019-04-08 17:16:05 +02:00
|
|
|
return Items\Group::class;
|
2019-04-08 10:30:45 +02:00
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case BOX_ITEM:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Items\Box::class;
|
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case LINE_ITEM:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Items\Line::class;
|
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case AUTO_SLA_GRAPH:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Items\EventsHistory::class;
|
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case DONUT_GRAPH:
|
2019-04-08 16:21:26 +02:00
|
|
|
return Items\DonutGraph::class;
|
2019-04-08 10:30:45 +02:00
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case BARS_GRAPH:
|
|
|
|
return Items\BarsGraph::class;
|
2019-04-08 10:30:45 +02:00
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case CLOCK:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Items\Clock::class;
|
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
case COLOR_CLOUD:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Items\ColorCloud::class;
|
|
|
|
|
2020-10-09 12:45:10 +02:00
|
|
|
case NETWORK_LINK:
|
|
|
|
return Items\NetworkLink::class;
|
|
|
|
|
2021-07-12 12:27:10 +02:00
|
|
|
case ODOMETER:
|
|
|
|
return Items\Odometer::class;
|
|
|
|
|
2021-07-16 14:16:45 +02:00
|
|
|
case BASIC_CHART:
|
|
|
|
return Items\BasicChart::class;
|
|
|
|
|
2019-04-08 17:16:05 +02:00
|
|
|
default:
|
2019-04-08 10:30:45 +02:00
|
|
|
return Item::class;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain a list of items which belong to the Visual Console.
|
|
|
|
*
|
2019-04-22 10:05:54 +02:00
|
|
|
* @param integer $layoutId Identifier of the Visual Console.
|
|
|
|
* @param array $groupsFilter Groups can access user.
|
2019-04-08 10:30:45 +02:00
|
|
|
*
|
|
|
|
* @return array A list of items.
|
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*/
|
2019-04-12 13:59:19 +02:00
|
|
|
public static function getItemsFromDB(
|
|
|
|
int $layoutId,
|
2020-03-26 12:29:38 +01:00
|
|
|
array $groupsFilter=[],
|
2021-06-29 12:02:13 +02:00
|
|
|
?float $ratio=0,
|
|
|
|
?float $widthRatio=0
|
2019-04-12 13:59:19 +02:00
|
|
|
): array {
|
2019-04-16 16:06:56 +02:00
|
|
|
// Default filter.
|
|
|
|
$filter = ['id_layout' => $layoutId];
|
|
|
|
$fields = [
|
2019-06-12 09:16:47 +02:00
|
|
|
'DISTINCT(id) AS id',
|
2019-04-16 16:06:56 +02:00
|
|
|
'type',
|
2019-05-20 15:15:54 +02:00
|
|
|
'cache_expiration',
|
|
|
|
'id_layout',
|
2019-04-16 16:06:56 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
// Override the filter if the groups filter is not empty.
|
|
|
|
if (count($groupsFilter) > 0) {
|
2019-04-15 15:10:58 +02:00
|
|
|
// Filter group for elements groups.
|
2019-04-17 10:05:01 +02:00
|
|
|
$filter = [];
|
2019-04-16 16:06:56 +02:00
|
|
|
$filter[] = \db_format_array_where_clause_sql(
|
|
|
|
[
|
|
|
|
'id_layout' => $layoutId,
|
|
|
|
'element_group' => $groupsFilter,
|
|
|
|
]
|
2019-04-15 15:10:58 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
// Filter groups for type groups.
|
|
|
|
// Only true condition if type is GROUP_ITEM.
|
2019-04-16 16:06:56 +02:00
|
|
|
$filter[] = '('.\db_format_array_where_clause_sql(
|
|
|
|
[
|
2019-06-12 09:16:47 +02:00
|
|
|
'id_layout' => $layoutId,
|
|
|
|
'type' => GROUP_ITEM,
|
|
|
|
'id_group' => $groupsFilter,
|
2019-04-16 16:06:56 +02:00
|
|
|
]
|
2019-04-15 15:10:58 +02:00
|
|
|
).')';
|
2019-04-12 13:59:19 +02:00
|
|
|
}
|
|
|
|
|
2019-04-15 15:10:58 +02:00
|
|
|
$rows = \db_get_all_rows_filter(
|
|
|
|
'tlayout_data',
|
|
|
|
$filter,
|
|
|
|
$fields,
|
|
|
|
'OR'
|
|
|
|
);
|
2019-04-08 10:30:45 +02:00
|
|
|
|
|
|
|
if ($rows === false) {
|
|
|
|
$rows = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$items = [];
|
|
|
|
|
|
|
|
foreach ($rows as $data) {
|
|
|
|
$itemId = (int) $data['id'];
|
2019-05-20 15:15:54 +02:00
|
|
|
$class = static::getItemClass((int) $data['type']);
|
2019-04-09 16:35:58 +02:00
|
|
|
|
|
|
|
try {
|
2021-06-29 12:02:13 +02:00
|
|
|
array_push($items, $class::fromDB($data, $ratio, $widthRatio));
|
2019-04-09 16:35:58 +02:00
|
|
|
} catch (\Throwable $e) {
|
2020-02-20 13:25:56 +01:00
|
|
|
error_log('VC[Container]: '.$e->getMessage());
|
2019-04-09 16:35:58 +02:00
|
|
|
}
|
2019-04-03 10:08:01 +02:00
|
|
|
}
|
|
|
|
|
2019-04-08 10:30:45 +02:00
|
|
|
return $items;
|
2019-04-03 10:08:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-07-08 17:51:01 +02:00
|
|
|
/**
|
2019-07-16 16:27:23 +02:00
|
|
|
* Obtain an item which belong to the Visual Console.
|
2019-07-08 17:51:01 +02:00
|
|
|
*
|
2019-07-16 16:27:23 +02:00
|
|
|
* @param integer $itemId Identifier of the Item.
|
2019-07-08 17:51:01 +02:00
|
|
|
*
|
2019-08-14 14:24:06 +02:00
|
|
|
* @return Model Item or Line.
|
2019-07-08 17:51:01 +02:00
|
|
|
* @throws \Exception When the data cannot be retrieved from the DB.
|
|
|
|
*/
|
2019-08-14 14:24:06 +02:00
|
|
|
public static function getItemFromDB(int $itemId): Model
|
2019-07-16 16:27:23 +02:00
|
|
|
{
|
2019-07-08 17:51:01 +02:00
|
|
|
// Default filter.
|
|
|
|
$filter = ['id' => $itemId];
|
|
|
|
$fields = [
|
|
|
|
'DISTINCT(id) AS id',
|
|
|
|
'type',
|
|
|
|
'cache_expiration',
|
|
|
|
'id_layout',
|
|
|
|
];
|
|
|
|
|
|
|
|
$row = \db_get_row_filter(
|
|
|
|
'tlayout_data',
|
|
|
|
$filter,
|
|
|
|
$fields,
|
|
|
|
'OR'
|
|
|
|
);
|
|
|
|
|
2022-12-16 10:38:37 +01:00
|
|
|
if ($row === false) {
|
2019-07-09 16:43:23 +02:00
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2019-07-08 17:51:01 +02:00
|
|
|
$class = static::getItemClass((int) $row['type']);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$item = $class::fromDB($row);
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
// TODO: Log this?
|
2021-02-02 18:40:55 +01:00
|
|
|
error_log(obhd($e));
|
2019-07-08 17:51:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-18 12:47:39 +01:00
|
|
|
}
|