mirror of
https://github.com/Icinga/icingaweb2.git
synced 2025-05-12 10:40:10 +02:00
245 lines
7.0 KiB
PHP
245 lines
7.0 KiB
PHP
<?php
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
|
|
|
namespace Icinga\Module\Monitoring\Forms\Config;
|
|
|
|
use InvalidArgumentException;
|
|
use Icinga\Exception\IcingaException;
|
|
use Icinga\Exception\NotFoundError;
|
|
use Icinga\Forms\ConfigForm;
|
|
use Icinga\Module\Monitoring\Command\Transport\LocalCommandFile;
|
|
use Icinga\Module\Monitoring\Command\Transport\RemoteCommandFile;
|
|
use Icinga\Module\Monitoring\Forms\Config\Instance\LocalInstanceForm;
|
|
use Icinga\Module\Monitoring\Forms\Config\Instance\RemoteInstanceForm;
|
|
|
|
/**
|
|
* Form for managing command transports
|
|
*/
|
|
class InstanceConfigForm extends ConfigForm
|
|
{
|
|
/**
|
|
* The transport to load when displaying the form for the first time
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $transportToLoad;
|
|
|
|
/**
|
|
* Initialize this form
|
|
*/
|
|
public function init()
|
|
{
|
|
$this->setName('form_config_command_transports');
|
|
$this->setSubmitLabel($this->translate('Save Changes'));
|
|
}
|
|
|
|
/**
|
|
* Return a form object for the given transport type
|
|
*
|
|
* @param string $type The transport type for which to return a form
|
|
*
|
|
* @return Form
|
|
*
|
|
* @throws InvalidArgumentException In case the given transport type is invalid
|
|
*/
|
|
public function getTransportForm($type)
|
|
{
|
|
switch (strtolower($type)) {
|
|
case LocalCommandFile::TRANSPORT:
|
|
return new LocalInstanceForm();
|
|
case RemoteCommandFile::TRANSPORT;
|
|
return new RemoteInstanceForm();
|
|
default:
|
|
throw new InvalidArgumentException(
|
|
sprintf($this->translate('Invalid command transport type "%s" given'), $type)
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Populate the form with the given transport's config
|
|
*
|
|
* @param string $name
|
|
*
|
|
* @return $this
|
|
*
|
|
* @throws NotFoundError In case no transport with the given name is found
|
|
*/
|
|
public function load($name)
|
|
{
|
|
if (! $this->config->hasSection($name)) {
|
|
throw new NotFoundError('No command transport called "%s" found', $name);
|
|
}
|
|
|
|
$this->transportToLoad = $name;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Add a new command transport
|
|
*
|
|
* The transport to add is identified by the array-key `name'.
|
|
*
|
|
* @param array $data
|
|
*
|
|
* @return $this
|
|
*
|
|
* @throws InvalidArgumentException In case $data does not contain a transport name
|
|
* @throws IcingaException In case a transport with the same name already exists
|
|
*/
|
|
public function add(array $data)
|
|
{
|
|
if (! isset($data['name'])) {
|
|
throw new InvalidArgumentException('Key \'name\' missing');
|
|
}
|
|
|
|
$transportName = $data['name'];
|
|
if ($this->config->hasSection($transportName)) {
|
|
throw new IcingaException(
|
|
$this->translate('A command transport with the name "%s" does already exist'),
|
|
$transportName
|
|
);
|
|
}
|
|
|
|
unset($data['name']);
|
|
$this->config->setSection($transportName, $data);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Edit an existing command transport
|
|
*
|
|
* @param string $name
|
|
* @param array $data
|
|
*
|
|
* @return $this
|
|
*
|
|
* @throws NotFoundError In case no transport with the given name is found
|
|
*/
|
|
public function edit($name, array $data)
|
|
{
|
|
if (! $this->config->hasSection($name)) {
|
|
throw new NotFoundError('No command transport called "%s" found', $name);
|
|
}
|
|
|
|
$transportConfig = $this->config->getSection($name);
|
|
if (isset($data['name'])) {
|
|
if ($data['name'] !== $name) {
|
|
$this->config->removeSection($name);
|
|
$name = $data['name'];
|
|
}
|
|
|
|
unset($data['name']);
|
|
}
|
|
|
|
$transportConfig->merge($data);
|
|
foreach ($transportConfig->toArray() as $k => $v) {
|
|
if ($v === null) {
|
|
unset($transportConfig->$k);
|
|
}
|
|
}
|
|
|
|
$this->config->setSection($name, $transportConfig);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Remove a command transport
|
|
*
|
|
* @param string $name
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function delete($name)
|
|
{
|
|
$this->config->removeSection($name);
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Create and add elements to this form
|
|
*
|
|
* @param array $formData
|
|
*/
|
|
public function createElements(array $formData)
|
|
{
|
|
$this->addElement(
|
|
'text',
|
|
'name',
|
|
array(
|
|
'required' => true,
|
|
'label' => $this->translate('Transport Name'),
|
|
'description' => $this->translate(
|
|
'The name of this command transport that is used to differentiate it from others'
|
|
),
|
|
'validators' => array(
|
|
array(
|
|
'Regex',
|
|
false,
|
|
array(
|
|
'pattern' => '/^[^\\[\\]:]+$/',
|
|
'messages' => array(
|
|
'regexNotMatch' => $this->translate(
|
|
'The name cannot contain \'[\', \']\' or \':\'.'
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
);
|
|
|
|
$transportTypes = array(
|
|
LocalCommandFile::TRANSPORT => $this->translate('Local Command File'),
|
|
RemoteCommandFile::TRANSPORT => $this->translate('Remote Command File')
|
|
);
|
|
|
|
$transportType = isset($formData['transport']) ? $formData['transport'] : null;
|
|
if ($transportType === null) {
|
|
$transportType = key($transportTypes);
|
|
}
|
|
|
|
$this->addElements(array(
|
|
array(
|
|
'select',
|
|
'transport',
|
|
array(
|
|
'required' => true,
|
|
'autosubmit' => true,
|
|
'label' => $this->translate('Transport Type'),
|
|
'multiOptions' => $transportTypes
|
|
)
|
|
)
|
|
));
|
|
|
|
$this->addSubForm($this->getTransportForm($transportType)->create($formData), 'transport_form');
|
|
}
|
|
|
|
/**
|
|
* Populate the configuration of the transport to load
|
|
*/
|
|
public function onRequest()
|
|
{
|
|
if ($this->transportToLoad) {
|
|
$data = $this->config->getSection($this->transportToLoad)->toArray();
|
|
$data['name'] = $this->transportToLoad;
|
|
$this->populate($data);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Retrieve all form element values
|
|
*
|
|
* @param bool $suppressArrayNotation Ignored
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getValues($suppressArrayNotation = false)
|
|
{
|
|
$values = parent::getValues();
|
|
$values = array_merge($values, $values['transport_form']);
|
|
unset($values['transport_form']);
|
|
return $values;
|
|
}
|
|
}
|