2020-03-26 12:29:38 +01:00
|
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* Widget URL Pandora FMS Console
|
|
|
|
|
*
|
|
|
|
|
* @category Console Class
|
|
|
|
|
* @package Pandora FMS
|
|
|
|
|
* @subpackage Widget URL
|
|
|
|
|
* @version 1.0.0
|
|
|
|
|
* @license See below
|
|
|
|
|
*
|
|
|
|
|
* ______ ___ _______ _______ ________
|
|
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
|
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
|
*
|
|
|
|
|
* ============================================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
|
* Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2020-03-26 12:29:38 +01:00
|
|
|
|
* Please see http://pandorafms.org for full contribution list
|
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
|
* as published by the Free Software Foundation for version 2.
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
* ============================================================================
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace PandoraFMS\Dashboard;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* URL Widgets
|
|
|
|
|
*/
|
|
|
|
|
class UrlWidget extends Widget
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Name widget.
|
|
|
|
|
*
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
|
|
|
|
protected $name;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Title widget.
|
|
|
|
|
*
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
|
|
|
|
protected $title;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Page widget;
|
|
|
|
|
*
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
|
|
|
|
protected $page;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Class name widget.
|
|
|
|
|
*
|
|
|
|
|
* @var [type]
|
|
|
|
|
*/
|
|
|
|
|
protected $className;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Values options for each widget.
|
|
|
|
|
*
|
|
|
|
|
* @var [type]
|
|
|
|
|
*/
|
|
|
|
|
protected $values;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Configuration required.
|
|
|
|
|
*
|
|
|
|
|
* @var boolean
|
|
|
|
|
*/
|
|
|
|
|
protected $configurationRequired;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Error load widget.
|
|
|
|
|
*
|
|
|
|
|
* @var boolean
|
|
|
|
|
*/
|
|
|
|
|
protected $loadError;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Width.
|
|
|
|
|
*
|
|
|
|
|
* @var integer
|
|
|
|
|
*/
|
|
|
|
|
protected $width;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Heigth.
|
|
|
|
|
*
|
|
|
|
|
* @var integer
|
|
|
|
|
*/
|
|
|
|
|
protected $height;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Grid Width.
|
|
|
|
|
*
|
|
|
|
|
* @var integer
|
|
|
|
|
*/
|
|
|
|
|
protected $gridWidth;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Construct.
|
|
|
|
|
*
|
|
|
|
|
* @param integer $cellId Cell ID.
|
|
|
|
|
* @param integer $dashboardId Dashboard ID.
|
|
|
|
|
* @param integer $widgetId Widget ID.
|
|
|
|
|
* @param integer|null $width New width.
|
|
|
|
|
* @param integer|null $height New height.
|
|
|
|
|
* @param integer|null $gridWidth Grid width.
|
|
|
|
|
*/
|
|
|
|
|
public function __construct(
|
|
|
|
|
int $cellId,
|
|
|
|
|
int $dashboardId=0,
|
|
|
|
|
int $widgetId=0,
|
|
|
|
|
?int $width=0,
|
|
|
|
|
?int $height=0,
|
|
|
|
|
?int $gridWidth=0
|
|
|
|
|
) {
|
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
|
|
// WARNING: Do not edit. This chunk must be in the constructor.
|
|
|
|
|
parent::__construct(
|
|
|
|
|
$cellId,
|
|
|
|
|
$dashboardId,
|
|
|
|
|
$widgetId
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Width.
|
|
|
|
|
$this->width = $width;
|
|
|
|
|
|
|
|
|
|
// Height.
|
|
|
|
|
$this->height = $height;
|
|
|
|
|
|
|
|
|
|
// Grid Width.
|
|
|
|
|
$this->gridWidth = $gridWidth;
|
|
|
|
|
|
|
|
|
|
// Options.
|
2020-04-30 14:08:56 +02:00
|
|
|
|
$this->values = $this->decoders($this->getOptionsWidget());
|
2020-03-26 12:29:38 +01:00
|
|
|
|
|
|
|
|
|
// Positions.
|
|
|
|
|
$this->position = $this->getPositionWidget();
|
|
|
|
|
|
|
|
|
|
// Page.
|
|
|
|
|
$this->page = basename(__FILE__);
|
|
|
|
|
|
|
|
|
|
// ClassName.
|
|
|
|
|
$class = new \ReflectionClass($this);
|
|
|
|
|
$this->className = $class->getShortName();
|
|
|
|
|
|
|
|
|
|
// Title.
|
|
|
|
|
$this->title = __('URL content');
|
|
|
|
|
|
|
|
|
|
// Name.
|
|
|
|
|
if (empty($this->name) === true) {
|
|
|
|
|
$this->name = 'url';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// This forces at least a first configuration.
|
|
|
|
|
$this->configurationRequired = false;
|
|
|
|
|
if (empty($this->values['urlText']) === true) {
|
|
|
|
|
$this->configurationRequired = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$this->overflow_scrollbars = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-04-30 14:08:56 +02:00
|
|
|
|
/**
|
|
|
|
|
* Decoders hack for retrocompability.
|
|
|
|
|
*
|
|
|
|
|
* @param array $decoder Values.
|
|
|
|
|
*
|
|
|
|
|
* @return array Returns the values with the correct key.
|
|
|
|
|
*/
|
|
|
|
|
public function decoders(array $decoder): array
|
|
|
|
|
{
|
|
|
|
|
$values = [];
|
|
|
|
|
// Retrieve global - common inputs.
|
|
|
|
|
$values = parent::decoders($decoder);
|
|
|
|
|
|
|
|
|
|
if (isset($decoder['url']) === true) {
|
|
|
|
|
$values['urlText'] = $decoder['url'];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (isset($decoder['urlText']) === true) {
|
|
|
|
|
$values['urlText'] = $decoder['urlText'];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $values;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
|
/**
|
|
|
|
|
* Generates inputs for form (specific).
|
|
|
|
|
*
|
|
|
|
|
* @return array Of inputs.
|
|
|
|
|
*
|
|
|
|
|
* @throws Exception On error.
|
|
|
|
|
*/
|
|
|
|
|
public function getFormInputs(): array
|
|
|
|
|
{
|
|
|
|
|
$values = $this->values;
|
|
|
|
|
|
|
|
|
|
// Retrieve global - common inputs.
|
|
|
|
|
$inputs = parent::getFormInputs();
|
|
|
|
|
|
|
|
|
|
// Url.
|
|
|
|
|
$inputs[] = [
|
|
|
|
|
'label' => __('Url'),
|
|
|
|
|
'arguments' => [
|
|
|
|
|
'name' => 'urlText',
|
|
|
|
|
'type' => 'text',
|
|
|
|
|
'value' => $values['urlText'],
|
|
|
|
|
'return' => true,
|
|
|
|
|
'size' => 0,
|
|
|
|
|
],
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
return $inputs;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get Post for widget.
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function getPost():array
|
|
|
|
|
{
|
|
|
|
|
// Retrieve global - common inputs.
|
|
|
|
|
$values = parent::getPost();
|
|
|
|
|
|
|
|
|
|
$values['urlText'] = \get_parameter('urlText', '');
|
|
|
|
|
|
|
|
|
|
return $values;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Draw widget.
|
|
|
|
|
*
|
|
|
|
|
* @return string;
|
|
|
|
|
*/
|
|
|
|
|
public function load()
|
|
|
|
|
{
|
|
|
|
|
$output = '';
|
|
|
|
|
|
|
|
|
|
$url = $this->values['urlText'];
|
|
|
|
|
|
|
|
|
|
$size = parent::getSize();
|
|
|
|
|
|
|
|
|
|
$width = $size['width'];
|
|
|
|
|
$height = $size['height'];
|
|
|
|
|
|
|
|
|
|
if (isset($url) === false || empty($url) === true) {
|
|
|
|
|
$output .= __('Please, configure this widget before use');
|
|
|
|
|
} else {
|
|
|
|
|
if (!preg_match('/^https?:\/\/.+/', $url)) {
|
|
|
|
|
$url = 'http://'.$url;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$url = str_replace('watch?v=', 'embed/', $url);
|
|
|
|
|
$style = 'border:none; width:100%; height:'.$height.'px;';
|
|
|
|
|
$output .= '<iframe id="item" src="'.$url.'" style="'.$style.'">';
|
|
|
|
|
$output .= '</iframe>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get description.
|
|
|
|
|
*
|
|
|
|
|
* @return string.
|
|
|
|
|
*/
|
|
|
|
|
public static function getDescription()
|
|
|
|
|
{
|
|
|
|
|
return __('URL content');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get Name.
|
|
|
|
|
*
|
|
|
|
|
* @return string.
|
|
|
|
|
*/
|
|
|
|
|
public static function getName()
|
|
|
|
|
{
|
|
|
|
|
return 'url';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2022-05-18 12:55:10 +02:00
|
|
|
|
/**
|
|
|
|
|
* Get size Modal Configuration.
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function getSizeModalConfiguration(): array
|
|
|
|
|
{
|
|
|
|
|
$size = [
|
|
|
|
|
'width' => 450,
|
2022-06-27 15:43:42 +02:00
|
|
|
|
'height' => 270,
|
2022-05-18 12:55:10 +02:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
return $size;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2020-03-26 12:29:38 +01:00
|
|
|
|
}
|