pandorafms/pandora_console/include/lib/Dashboard/Manager.php

1558 lines
39 KiB
PHP

<?php
namespace PandoraFMS\Dashboard;
use PandoraFMS\View;
use PandoraFMS\Dashboard\Cell;
use PandoraFMS\PublicLogin;
/**
* Dashboard manager.
*/
class Manager implements PublicLogin
{
/**
* Ajax controller.
*
* @var string
*/
protected $ajaxController;
/**
* User is admin.
*
* @var integer
*/
private $isAdmin;
/**
* Groups for user ACL.
*
* @var array
*/
private $groups;
/**
* Groups for user ACL string for IN clauses query.
*
* @var string
*/
private $stringGroups;
/**
* Acl write report.
*
* @var integer
*/
private $writeDashboards;
/**
* Acl manage report.
*
* @var integer
*/
private $manageDashboards;
/**
* ID dashboard
*
* @var integer
*/
private $dashboardId;
/**
* Dashboard data.
*
* @var array
*/
private $dashboardFields;
/**
* Operations delete dashboard.
*
* @var integer
*/
private $deleteDashboard;
/**
* Operations copy dashboard.
*
* @var integer
*/
private $copyDashboard;
/**
* Operations create dashboard.
*
* @var integer
*/
private $createDashboard;
/**
* Operations update dashboard.
*
* @var integer
*/
private $updateDashboard;
/**
* Cells for this dashboard.
*
* @var array
*/
private $cells;
/**
* Id Cell.
*
* @var integer
*/
private $cellId;
/**
* Id Widget.
*
* @var integer
*/
private $widgetId;
/**
* Offset.
*
* @var integer
*/
private $offset;
/**
* Slides.
*
* @var integer
*/
private $slides;
/**
* Cell Mode Slides.
*
* @var integer
*/
private $cellModeSlides;
/**
* Slides Ids.
*
* @var array
*/
private $slidesIds;
/**
* Refr.
*
* @var integer
*/
private $refr;
/**
* Public Link.
*
* @var boolean
*/
private $publicLink;
/**
* Allowed methods to be called using AJAX request.
*
* @var array
*/
public $AJAXMethods = [
'getCellsLayout',
'insertCellLayout',
'drawCell',
'drawWidget',
'saveLayout',
'deleteCell',
'drawAddWidget',
'drawConfiguration',
'drawFormDashboard',
'updateDashboard',
'saveWidgetIntoCell',
'imageIconDashboardAjax',
'formSlides',
'callWidgetMethod',
'getSizeModalConfiguration',
];
/**
* Constructor
*
* @param string $page For ajax controller.
*/
public function __construct(string $page='operation/dashboard/dashboard')
{
global $config;
// Check ACL.
$hash = get_parameter('hash', false);
$this->publicLink = false;
// Check user access.
if ($hash === false) {
check_login();
if (check_acl($config['id_user'], 0, 'RR') === 0) {
include 'general/noaccess.php';
return;
}
} else {
if (self::validatePublicHash($hash) === false) {
db_pandora_audit(
AUDIT_LOG_HACK_ATTEMPT,
'Trying to access public dashboard'
);
include 'general/noaccess.php';
exit;
}
$this->publicLink = true;
}
if (empty(get_parameter('auth_hash', '')) === false) {
$this->publicLink = true;
}
// User is admin.
$this->isAdmin = (bool) \is_user_admin($config['id_user']);
// Groups user access.
$this->groups = array_keys(
\users_get_groups(
$config['id_user'],
'RR',
true
)
);
// String groups for query.
$this->stringGroups = \io_safe_output(
implode(
', ',
array_values($this->groups)
)
);
// Urls.
$this->url = \ui_get_full_url(
'index.php?sec=reporting&sec2=operation/dashboard/dashboard'
);
$this->ajaxController = $page;
// ACL Dashboards.
$this->writeDashboards = \check_acl($config['id_user'], 0, 'RW');
$this->manageDashboards = \check_acl($config['id_user'], 0, 'RM');
// Operations Dashboards.
$this->deleteDashboard = (bool) \get_parameter('deleteDashboard', 0);
$this->copyDashboard = (bool) \get_parameter('copyDashboard', 0);
$this->createDashboard = \get_parameter('createDashboard', null);
$this->updateDashboard = \get_parameter('updateDashboard', null);
$this->slides = (int) \get_parameter('slides', 0);
$extradata = \get_parameter('extradata', '');
if (empty($extradata) === false) {
$extradata = json_decode(\io_safe_output($extradata), true);
if (isset($extradata['dashboardId']) === false) {
$extradata['dashboardId'] = null;
}
if (isset($extradata['cellId']) === false) {
$extradata['cellId'] = null;
}
if (isset($extradata['offset']) === false) {
$extradata['offset'] = null;
}
if (isset($extradata['widgetId']) === false) {
$extradata['widgetId'] = null;
}
$this->dashboardId = (int) $extradata['dashboardId'];
$this->cellId = (int) $extradata['cellId'];
$this->offset = (int) $extradata['offset'];
$this->widgetId = (int) $extradata['widgetId'];
} else {
$this->cellId = (int) \get_parameter('cellId', []);
$this->offset = (int) \get_parameter('offset', 0);
$this->dashboardId = (int) \get_parameter('dashboardId', 0);
if ($this->slides === 1) {
$this->slidesIds = (array) \get_parameter('slidesIds');
$this->cellModeSlides = (int) \get_parameter(
'cellModeSlides',
0
);
if ($this->dashboardId === 0) {
$this->dashboardId = (int) $this->slidesIds[0];
}
}
$this->widgetId = (int) \get_parameter('widgetId', 0);
}
if ($this->dashboardId !== 0) {
$this->dashboardFields = $this->get();
$this->cells = Cell::getCells($this->dashboardId);
}
$this->refr = (int) get_parameter('refr', 0);
$this->refr = (empty($this->refr) === false) ? $this->refr : $config['vc_refr'];
}
/**
* Generates a hash to authenticate in public dashboards.
*
* @param string|null $other_secret To authenticate some parts
* of public dashboards (like visual consoles or wux widgets)
* another hash is needed. Other secret avoid
* to reuse the main hash to view other components.
*
* @return string Returns a hash with the authenticaction.
*/
public static function generatePublicHash(?string $other_secret=''):string
{
global $config;
$str = $config['dbpass'];
$str .= $config['id_user'];
$str .= $other_secret;
return hash('sha256', $str);
}
/**
* Validates a hash to authenticate in public dashboards.
*
* @param string $hash Hash to be checked.
* @param string $other_secret Yo need to provide it to
* authenticate some parts of widgets.
*
* @return boolean Returns true if hash is valid.
*/
public static function validatePublicHash(
string $hash,
string $other_secret=''
):bool {
global $config;
if (isset($config['id_user']) === true) {
// Already logged in.
return true;
}
$userFromParams = false;
// Try to get id_user from parameters if it is missing.
if (isset($config['id_user']) === false) {
$userFromParams = true;
$config['id_user'] = get_parameter('id_user', false);
// It is impossible to authenticate without an id user.
if ($config['id_user'] === false) {
unset($config['id_user']);
return false;
}
} else {
$config['public_dashboard'] = false;
}
// Build a hash to check.
$hashCheck = self::generatePublicHash($other_secret);
if ($hashCheck === $hash) {
// "Log" user in.
if (session_status() !== PHP_SESSION_ACTIVE) {
session_start();
}
$_SESSION['id_usuario'] = $config['id_user'];
session_write_close();
$config['public_dashboard'] = true;
$config['force_instant_logout'] = true;
return true;
}
// Remove id user from config array if authentication has failed.
if ($userFromParams === true) {
unset($config['id_user']);
}
return false;
}
/**
* Instance Widget.
*
* @param integer|null $width Width.
* @param integer|null $height Height.
* @param integer|null $gridWidth Width Grid.
*
* @return object
*/
private function instanceWidget(
?int $width=0,
?int $height=0,
?int $gridWidth=0
):object {
global $config;
if ($this->widgetId === 0) {
$cellClass = new Cell($this->cellId, $this->dashboardId);
$dataCell = $cellClass->get();
$this->widgetId = $dataCell['id_widget'];
}
$this->cWidget = new Widget(
$this->cellId,
$this->dashboardId,
$this->widgetId
);
$widgetData = $this->cWidget->get();
// Include widget if necesary.
$urlWidget = $config['homedir'];
$urlWidget .= '/include/lib/Dashboard/Widgets/';
$urlWidget .= $widgetData['page'];
include_once $urlWidget;
$class = new \ReflectionClass($this);
$nameSpace = $class->getNamespaceName();
// Rename Old bad name class.
if ($widgetData['class_name'] === 'TopN_event_by_group') {
$widgetData['class_name'] = 'TopNEventByGroupWidget';
} else if ($widgetData['class_name'] === 'TopN_event_by_module') {
$widgetData['class_name'] = 'TopNEventByModuleWidget';
}
$className = $nameSpace.'\\'.$widgetData['class_name'];
// Hack: class_name is the name of the widget class to create.
$instance = new $className(
$this->cellId,
$this->dashboardId,
$this->widgetId,
$width,
$height,
$gridWidth,
$this->publicLink
);
return $instance;
}
/**
* Retrieve a dashboard definition.
*
* @return array dashboard data.
*/
private function get()
{
global $config;
$sql = sprintf(
'SELECT *
FROM tdashboard
WHERE id = %d',
$this->dashboardId
);
if ($this->isAdmin !== true) {
$sql = sprintf(
"SELECT *
FROM tdashboard
WHERE id = %d
AND (id_group IN (%s) AND id_user = '') OR id_user = '%s'",
$this->dashboardId,
$this->stringGroups,
$config['id_user']
);
}
$data = \db_get_row_sql($sql);
if ($data === false) {
return [];
}
return $data;
}
/**
* Insert dashboard item.
*
* @param array $data Array data Insert.
*
* @return integer
*/
public function set(array $data):int
{
global $config;
// Insert.
$result = \db_process_sql_insert(
'tdashboard',
$data
);
if ($result === false) {
$result = 0;
}
return $result;
}
/**
* Update local object attributes and updates the DB.
*
* @param array $values Values to be updated.
*
* @return array Result of set operation.
*/
public function put(array $values) : array
{
global $config;
$result = [
'error' => false,
'msg_error' => '',
'result' => 0,
];
// Update.
$res = \db_process_sql_update(
'tdashboard',
$values,
['id' => $this->dashboardId]
);
$result['result'] = $res;
if ($res === false) {
$result = [
'error' => true,
'msg_error' => $config['dbconnection']->error,
'result' => $res,
];
}
return $result;
}
/**
* Delete Dashboard.
*
* @return boolean
*/
public function delete()
{
global $config;
$result = 0;
if ($this->manageDashboards === 1) {
$result = \db_process_sql_delete(
'tdashboard',
['id' => $this->dashboardId]
);
}
// Audit.
if ($result !== 0) {
\db_pandora_audit(
AUDIT_LOG_DASHBOARD_MANAGEMENT,
'Delete dashboard #'.$this->dashboardId
);
} else {
\db_pandora_audit(
AUDIT_LOG_DASHBOARD_MANAGEMENT,
'Fail try to delete dashboard #'.$this->dashboardId
);
}
return $result;
}
/**
* Copy Dashboard and asociate widgets.
*
* @return integer
*/
public function copy():int
{
$result = true;
// Name copy change.
$name = __('Copy of %s', $this->dashboardFields['name']);
$i = 1;
while (true) {
$exists = db_get_value(
'name',
'tdashboard',
'name',
$name
);
if (empty($exists) === true) {
break;
} else {
$name = $name.' ('.$i.')';
}
$i++;
}
$values = [
'name' => $name,
'id_user' => $this->dashboardFields['id_user'],
'id_group' => $this->dashboardFields['id_group'],
'active' => $this->dashboardFields['active'],
'cells' => $this->dashboardFields['cells'],
'cells_slideshow' => $this->dashboardFields['cells_slideshow'],
];
$id = $this->set($values);
if (empty($id) === true) {
$result = 0;
} else {
$cells = Cell::getCells($this->dashboardId);
foreach ($cells as $cell) {
// Remove Id.
unset($cell['id']);
// Change Id dashboard.
$cell['id_dashboard'] = $id;
$result = db_process_sql_insert('twidget_dashboard', $cell);
if (empty($result) === true) {
$result = 0;
break;
}
}
// Clean database.
if ($result === 0) {
db_process_sql_delete(
'tdashboard',
['id' => $id]
);
db_process_sql_delete(
'twidget_dashboard',
['id_dashboard' => $id]
);
}
}
return $result;
}
/**
* Get all dashboard user can you see.
*
* @param integer $offset Offset query.
* @param integer $limit Limit query.
* @param boolean $favourite Fovorite dashboard.
* @param boolean $slideshow Slideshow Mode.
*
* @return array
*/
static public function getDashboards(
int $offset=-1,
int $limit=-1,
bool $favourite=false,
bool $slideshow=false
):array {
global $config;
$sql_limit = '';
if ($offset !== -1 && $limit !== -1) {
$sql_limit = ' LIMIT '.$offset.','.$limit;
}
$sql_where = '';
if ($favourite === true) {
$sql_where .= 'AND td.active = 1';
}
if ($slideshow === true) {
$sql_where .= 'AND td.cells_slideshow = 1';
}
// Check ACl.
if (\is_user_admin($config['id_user']) !== true) {
// Non-admin user can see dashboards of his groups and 'AR' profile.
$group_list = \users_get_groups(
$config['id_user'],
'RR',
true
);
if ($group_list === false) {
$group_list = [];
}
if (empty($group_list) === false) {
$string_groups = implode(', ', array_keys($group_list));
$string_groups = \io_safe_output($string_groups);
// Select user's dashboards.
$sql_dashboard = sprintf(
"SELECT td.id,
td.name,
td.id_user,
td.id_group,
td.active,
count(twd.id) as cells,
td.cells_slideshow
FROM tdashboard td
LEFT JOIN twidget_dashboard twd
ON td.id = twd.id_dashboard
WHERE ((td.id_group IN (%s) AND td.id_user = '') OR
td.id_user = '%s') %s
GROUP BY td.id
ORDER BY name%s",
$string_groups,
$config['id_user'],
$sql_where,
$sql_limit
);
} else {
$sql_dashboard = sprintf(
"SELECT td.id,
td.name,
td.id_user,
td.id_group,
td.active,
count(twd.id) as cells,
td.cells_slideshow
FROM tdashboard td
LEFT JOIN twidget_dashboard twd
ON td.id = twd.id_dashboard
WHERE td.id_group = 0 AND td.id_user = '%s' %s
GROUP BY td.id
ORDER BY name%s",
$config['id_user'],
$sql_where,
$sql_limit
);
}
} else {
// User admin view all dashboards.
$sql_dashboard = sprintf(
'SELECT td.id,
td.name,
td.id_user,
td.id_group,
td.active,
count(twd.id) as cells,
td.cells_slideshow
FROM tdashboard td
LEFT JOIN twidget_dashboard twd
ON td.id = twd.id_dashboard
WHERE 1=1 %s
GROUP BY td.id
ORDER BY name%s',
$sql_where,
$sql_limit
);
}
$dashboards = \db_get_all_rows_sql($sql_dashboard);
if ($favourite === true && $dashboards !== false && count($dashboards) > 0) {
$dashboards = array_map(
function ($dashboard) {
$dashboard['name'] = io_safe_input($dashboard['name']);
return $dashboard;
},
$dashboards
);
}
if ($dashboards === false) {
$dashboards = [];
}
return $dashboards;
}
/**
* Get all dashboard user can you see.
*
* @return array Return counts.
*/
static public function getDashboardsCount()
{
global $config;
if (is_user_admin($config['id_user']) !== false) {
// Non-admin user can see dashboards of his groups and 'AR' profile.
$group_list = \users_get_groups(
$config['id_user'],
'RR',
true
);
if ($group_list === false) {
$group_list = [];
}
if (empty($group_list) === false) {
$string_groups = implode(', ', array_keys($group_list));
$string_groups = io_safe_output($string_groups);
$sql_dashboard = sprintf(
"SELECT COUNT(*)
FROM tdashboard
WHERE (id_group IN (%s))",
$string_groups
);
} else {
$sql_dashboard = 'SELECT COUNT(*) FROM tdashboard WHERE id_group = 0';
}
} else {
$sql_dashboard = 'SELECT COUNT(*) FROM tdashboard';
}
$count_dashboards = db_get_all_rows_sql($sql_dashboard);
if ($count_dashboards === false) {
$count_dashboards = [];
}
return $count_dashboards[0]['COUNT(*)'];
}
/**
* Checks if target method is available to be called using AJAX.
*
* @param string $method Target method.
*
* @return boolean True allowed, false not.
*/
public function ajaxMethod(string $method):bool
{
return in_array($method, $this->AJAXMethods);
}
/**
* Init manager dashboard.
*
* @return void
*/
public function run()
{
global $config;
ui_require_css_file('modal');
ui_require_css_file('form');
if ($this->dashboardId === 0
|| $this->deleteDashboard === true
|| $this->copyDashboard === true
) {
$this->showList();
} else {
$this->drawLayout();
}
}
/**
* Draw list dashboards.
*
* @return void
*/
private function showList()
{
global $config;
$limit_sql = $config['block_size'];
$resultDelete = null;
if ($this->deleteDashboard === true) {
$resultDelete = $this->delete();
}
$resultCopy = null;
if ($this->copyDashboard === true) {
$resultCopy = $this->copy();
}
$dashboards = $this->getDashboards($this->offset, $limit_sql);
$count = $this->getDashboardsCount();
View::render(
'dashboard/list',
[
'dashboards' => $dashboards,
'count' => $count,
'offset' => $this->offset,
'urlDashboard' => $this->url,
'manageDashboards' => $this->manageDashboards,
'writeDashboards' => $this->writeDashboards,
'resultDelete' => $resultDelete,
'resultCopy' => $resultCopy,
'ajaxController' => $this->ajaxController,
'urlAjax' => \ui_get_full_url('ajax.php'),
]
);
}
/**
* Form Upadte dashboards.
*
* @return void
*/
public function drawFormDashboard()
{
View::render(
'dashboard/formDashboard',
[
'dashboardId' => $this->dashboardId,
'arrayDashboard' => $this->dashboardFields,
]
);
}
/**
* Update dashboards.
*
* @return mixed
*/
public function updateDashboard()
{
global $config;
if (check_acl($config['id_user'], 0, 'RW') === 0) {
include 'general/noaccess.php';
return;
}
$name = \get_parameter('name', '');
$private = \get_parameter_switch('private');
$id_group = \get_parameter('id_group');
$slideshow = \get_parameter_switch('slideshow');
$favourite = \get_parameter_switch('favourite');
$id_user = (empty($private) === false) ? $config['id_user'] : '';
$values = [
'name' => $name,
'id_user' => $id_user,
'id_group' => $id_group,
'cells_slideshow' => $slideshow,
'active' => $favourite,
];
if ($this->dashboardId === 0) {
$this->dashboardId = $this->set($values);
$res = $this->dashboardId;
if ($res !== false) {
// Create Initial Widget.
$values = [
'x' => '0',
'y' => '0',
'width' => '4',
'height' => '4',
];
$cellClass = new Cell($values, $this->dashboardId);
$dataCell = $cellClass->get();
}
$type = '&createDashboard=1';
$type .= '&cellIdCreate='.$dataCell['id'];
} else {
$res = $this->put($values);
}
$result = [
'error' => ($res === false) ? 1 : 0,
'error_mesage' => __('Error create or update dashboard'),
'url' => $this->url.$type,
'dashboardId' => $this->dashboardId,
];
echo json_encode($result);
}
/**
* Draw layout.
*
* @return mixed
*/
public function drawLayout()
{
global $config;
$dashboards = $this->getDashboards();
$dashboards = array_reduce(
$dashboards,
function ($carry, $item) {
$carry[$item['id']] = $item['name'];
return $carry;
},
[]
);
// Header.
if ($this->slides === 0) {
if ((bool) \is_metaconsole() === true) {
open_meta_frame();
}
View::render(
'dashboard/header',
[
'dashboards' => $dashboards,
'ajaxController' => $this->ajaxController,
'dashboardId' => $this->dashboardId,
'refr' => $this->refr,
'url' => $this->url,
'dashboardName' => $this->dashboardFields['name'],
'hash' => self::generatePublicHash(),
'publicLink' => $this->publicLink,
'dashboardGroup' => $this->dashboardFields['id_group'],
]
);
} else {
View::render(
'dashboard/slides',
[
'dashboard' => $this->dashboardFields,
'ajaxController' => $this->ajaxController,
'dashboardId' => $this->dashboardId,
'refr' => $this->refr,
'url' => $this->url,
'dashboardName' => $this->dashboardFields['name'],
'slides' => $this->slides,
'slidesIds' => $this->slidesIds,
'cells' => $this->cells,
'cellModeSlides' => $this->cellModeSlides,
'cellId' => ($this->cellId === 0) ? $this->cells[0]['id'] : $this->cellId,
'dashboardGroup' => $this->dashboardFields['id_group'],
]
);
}
if (isset($config['public_dashboard']) === false) {
$config['public_dashboard'] = false;
}
// View.
if ($this->slides === 0 || $this->cellModeSlides === 0) {
View::render(
'dashboard/layout',
[
'ajaxController' => $this->ajaxController,
'dashboardId' => $this->dashboardId,
'url' => \ui_get_full_url('ajax.php'),
'createDashboard' => $this->createDashboard,
'updateDashboard' => $this->updateDashboard,
'cellIdCreate' => \get_parameter('cellIdCreate', 0),
'class' => (($config['public_dashboard'] === true) ? quotemeta(__CLASS__) : ''),
'hash' => (($config['public_dashboard'] === true) ? self::generatePublicHash() : ''),
]
);
} else {
$this->cellId = ($this->cellId === 0) ? $this->cells[0]['id'] : $this->cellId;
$cellClass = new Cell($this->cellId, $this->dashboardId);
$cellData = $cellClass->get();
$instance = '';
if ((int) $cellData['id_widget'] !== 0 || $this->widgetId !== 0) {
$settings = [
'page' => $this->ajaxController,
'url' => \ui_get_full_url('ajax.php'),
'dashboardId' => $this->dashboardId,
'widgetId' => $cellData['id_widget'],
'cellId' => $this->cellId,
];
}
View::render(
'dashboard/slidesWidget',
[
'options' => \json_decode($cellData['options'], true),
'settings' => $settings,
]
);
}
// Js countdown for mode slice.
View::render(
'dashboard/jsLayout',
['dashboardId' => $this->dashboardId]
);
if ((bool) \is_metaconsole() === true
&& $this->slides === 0
) {
close_meta_frame();
}
return null;
}
/**
* Get cells for layout draw
*
* @return void
*/
public function getCellsLayout()
{
global $config;
$result = [];
$cells = $this->cells;
if ($cells === false) {
$cells = [];
}
if (empty($cells) === false) {
$result = array_reduce(
$cells,
function ($carry, $item) {
$carry[$item['order']]['id'] = $item['id'];
$carry[$item['order']]['position'] = $item['position'];
$carry[$item['order']]['widgetId'] = $item['id_widget'];
return $carry;
},
[]
);
}
echo json_encode($result);
}
/**
* Insert new cell layout.
*
* @return void
*/
public function insertCellLayout():void
{
global $config;
$position = [
'x' => 0,
'y' => 0,
'width' => 4,
'height' => 4,
];
$cellClass = new Cell($position, $this->dashboardId);
$dataCell = $cellClass->get();
$result = ['cellId' => $dataCell['id']];
echo json_encode($result);
}
/**
* Draw Cell.
*
* @return mixed
*/
public function drawCell()
{
global $config;
$redraw = (bool) \get_parameter('redraw', 0);
$cellClass = new Cell($this->cellId, $this->dashboardId);
$cellData = $cellClass->get();
if ((int) $cellData['id_widget'] !== 0 || $this->widgetId !== 0) {
if ((int) $cellData['id_widget'] === 0 && $this->widgetId !== 0) {
// Insert in cell widget ID.
$res = $cellClass->put([], $this->widgetId);
if ($res === 1) {
$cellData['id_widget'] = $this->widgetId;
}
}
$instance = $this->instanceWidget();
$cellData['options'] = $instance->decoders(
$instance->getOptionsWidget()
);
if (isset($cellData['options']['title']) === false) {
$cellData['options']['title'] = $instance->getDescription();
}
$cellData['options'] = json_encode($cellData['options']);
}
View::render(
'dashboard/cell',
[
'redraw' => $redraw,
'cellData' => $cellData,
'manageDashboards' => $this->manageDashboards,
]
);
return null;
}
/**
* Draw widget.
*
* @return mixed
*/
public function drawWidget()
{
$newWidth = (int) \get_parameter('newWidth', 0);
$newHeight = (int) \get_parameter('newHeight', 0);
$gridWidth = (int) \get_parameter('gridWidth', 0);
$cellClass = new Cell($this->cellId, $this->dashboardId);
$cellData = $cellClass->get();
$instance = '';
if ((int) $cellData['id_widget'] !== 0 || $this->widgetId !== 0) {
$instance = $this->instanceWidget(
$newWidth,
$newHeight,
$gridWidth
);
}
View::render(
'dashboard/widget',
[
'widgetId' => $this->widgetId,
'cellData' => $cellData,
'instance' => $instance,
]
);
return null;
}
/**
* Save layout.
* Update, Insert and delete widgets.
* More important order.
*
* @return mixed
*/
public function saveLayout()
{
global $config;
$items = \get_parameter('items', []);
// Class Dashboard.
if (empty($items) === false) {
// Order for position Y and X.
usort(
$items,
function ($a, $b) {
// First order by position `y`.
// if `y` is the same order by position `x`.
$retval = ($a['y'] <=> $b['y']);
if ($retval === 0) {
$retval = ($a['x'] <=> $b['x']);
}
return $retval;
}
);
$result = false;
foreach ($items as $order => $item) {
$item['order'] = $order;
$id = $item['id'];
unset($item['id']);
// Update cells.
$cellClass = new Cell($id, $this->dashboardId);
$result = $cellClass->put($item);
if ($result === false) {
return false;
}
}
}
echo json_encode($result);
}
/**
* Ajax layout delete Cell.
*
* @return void
*/
public function deleteCell():void
{
global $config;
$res = 0;
if ($this->cellId !== 0) {
// Remove cells.
$cellClass = new Cell($this->cellId, $this->dashboardId);
$res = $cellClass->delete();
}
$result = ['result' => $res];
echo json_encode($result);
}
/**
* Draw list widgets.
*
* @return mixed
*/
public function drawAddWidget()
{
global $config;
Widget::dashboardInstallWidgets($this->cellId);
$search = \io_safe_output(\get_parameter('search', ''));
// The limit is fixed here.
$total = count(Widget::getWidgets(-1, -1, $search));
$widgets = Widget::getWidgets($this->offset, 9, $search);
View::render(
'dashboard/listWidgets',
[
'widgets' => $widgets,
'total' => $total,
'offset' => $this->offset,
'dashboardId' => $this->dashboardId,
'cellId' => $this->cellId,
'search' => $search,
'ajaxController' => $this->ajaxController,
]
);
return null;
}
/**
* Form configuration widget.
*
* @return mixed
*/
public function drawConfiguration()
{
global $config;
$instance = $this->instanceWidget();
$blocks = [];
$htmlInputs = $instance->getFormInputs([]);
if (isset($htmlInputs['blocks']) === true) {
$blocks = $htmlInputs['blocks'];
$htmlInputs = $htmlInputs['inputs'];
}
$js = $instance->getFormJS();
View::render(
'dashboard/configurationWidgets',
[
'dashboardId' => $this->dashboardId,
'cellId' => $this->cellId,
'blocks' => $blocks,
'htmlInputs' => $htmlInputs,
'js' => $js,
]
);
return null;
}
/**
* Save widget into cell.
*
* @return void
*/
public function saveWidgetIntoCell()
{
global $config;
// Init result.
$result = ['result' => false];
if ($this->widgetId !== 0) {
// Instance widget for get Post.
$instance = $this->instanceWidget();
$values = $instance->getPost();
// Add new configuration for widget into cell.
$cellClass = new Cell($this->cellId, $this->dashboardId);
$res = $cellClass->put([], $this->widgetId, $values);
$result = [
'result' => $res,
'page' => $this->ajaxController,
'url' => ui_get_full_url('ajax.php'),
'dashboardId' => $this->dashboardId,
'cellId' => $this->cellId,
'widgetId' => $this->widgetId,
];
}
echo json_encode($result);
}
/**
* Image icon Dashboard ajax change.
*
* @return mixed
*/
public function imageIconDashboardAjax()
{
$nameImg = \get_parameter('nameImg', '');
$output = $this->imageIconDashboard($nameImg);
echo $output;
return null;
}
/**
* Return image php.
*
* @param string|null $nameImg Path image.
*
* @return string Image.
*/
public static function imageIconDashboard(?string $nameImg):string
{
if (empty($nameImg) === true) {
$nameImg = 'appliance';
}
$output = html_print_image(
'images/console/icons/'.$nameImg.'.png',
true,
[
'alt' => __('Icon image dashboard'),
'style' => 'max-width:70px; max-height:70px;',
]
);
return $output;
}
/**
* Draw form slides.
*
* @return mixed
*/
public function formSlides()
{
$dashboards = $this->getDashboards(-1, -1, false, false);
View::render(
'dashboard/formSlides',
[
'url' => $this->url,
'dashboards' => $dashboards,
]
);
return null;
}
/**
* Prints error.
*
* @param string $msg Message.
*
* @return void
*/
public function error(string $msg)
{
if ((bool) \is_ajax() === true) {
echo json_encode(['error' => $msg]);
} else {
\ui_print_error_message($msg);
}
}
/**
* Call widget method (ajax only).
*
* @param string $method Method to be invoked.
*
* @return boolean Executed or not.
*/
public function callWidgetMethod(string $method):bool
{
$widget = $this->instanceWidget();
if (method_exists($widget, $method) === true) {
$widget->$method();
return true;
}
return false;
}
/**
* Size configuration modal (ajax only).
*
* @return void.
*/
public function getSizeModalConfiguration():void
{
$result = [];
$widget = $this->instanceWidget();
$result = $widget->getSizeModalConfiguration();
echo json_encode($result);
return;
}
}