2014-09-04 08:47:16 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2014-09-04 08:47:16 +02:00
|
|
|
|
2014-11-14 11:17:22 +01:00
|
|
|
namespace Icinga\Module\Monitoring\Forms\Config;
|
2014-09-04 08:47:16 +02:00
|
|
|
|
|
|
|
use InvalidArgumentException;
|
2015-06-29 12:01:43 +02:00
|
|
|
use Icinga\Exception\IcingaException;
|
|
|
|
use Icinga\Exception\NotFoundError;
|
2014-11-14 10:57:14 +01:00
|
|
|
use Icinga\Forms\ConfigForm;
|
2014-10-29 13:36:09 +01:00
|
|
|
use Icinga\Module\Monitoring\Command\Transport\LocalCommandFile;
|
|
|
|
use Icinga\Module\Monitoring\Command\Transport\RemoteCommandFile;
|
2014-11-14 11:17:22 +01:00
|
|
|
use Icinga\Module\Monitoring\Forms\Config\Instance\LocalInstanceForm;
|
|
|
|
use Icinga\Module\Monitoring\Forms\Config\Instance\RemoteInstanceForm;
|
2014-09-04 08:47:16 +02:00
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Form for managing monitoring instances
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
|
|
|
class InstanceConfigForm extends ConfigForm
|
|
|
|
{
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* The instance to load when displaying the form for the first time
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $instanceToLoad;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize this form
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
$this->setName('form_config_monitoring_instance');
|
2015-01-19 13:47:01 +01:00
|
|
|
$this->setSubmitLabel($this->translate('Save Changes'));
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Return a form object for the given instance type
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @param string $type The instance type for which to return a form
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @return Form
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
|
|
|
* @throws InvalidArgumentException In case the given instance type is invalid
|
|
|
|
*/
|
|
|
|
public function getInstanceForm($type)
|
|
|
|
{
|
2014-10-29 13:36:09 +01:00
|
|
|
switch (strtolower($type)) {
|
|
|
|
case LocalCommandFile::TRANSPORT:
|
2015-06-29 12:01:43 +02:00
|
|
|
return new LocalInstanceForm();
|
2014-10-29 13:36:09 +01:00
|
|
|
case RemoteCommandFile::TRANSPORT;
|
2015-06-29 12:01:43 +02:00
|
|
|
return new RemoteInstanceForm();
|
2014-10-29 13:36:09 +01:00
|
|
|
default:
|
|
|
|
throw new InvalidArgumentException(
|
2015-06-29 12:01:43 +02:00
|
|
|
sprintf($this->translate('Invalid monitoring instance type "%s" given'), $type)
|
2014-10-29 13:36:09 +01:00
|
|
|
);
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Populate the form with the given instance's config
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @param string $name
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-04-07 14:23:26 +02:00
|
|
|
* @return $this
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @throws NotFoundError In case no instance with the given name is found
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
2015-06-29 12:01:43 +02:00
|
|
|
public function load($name)
|
2014-09-04 08:47:16 +02:00
|
|
|
{
|
2015-06-29 12:01:43 +02:00
|
|
|
if (! $this->config->hasSection($name)) {
|
|
|
|
throw new NotFoundError('No monitoring instance called "%s" found', $name);
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
2015-06-29 12:01:43 +02:00
|
|
|
$this->instanceToLoad = $name;
|
2014-09-04 08:47:16 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Add a new instance
|
|
|
|
*
|
|
|
|
* The instance to add is identified by the array-key `name'.
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @param array $data
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @return $this
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @throws InvalidArgumentException In case $data does not contain a instance name
|
|
|
|
* @throws IcingaException In case a instance with the same name already exists
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
2015-06-29 12:01:43 +02:00
|
|
|
public function add(array $data)
|
2014-09-04 08:47:16 +02:00
|
|
|
{
|
2015-06-29 12:01:43 +02:00
|
|
|
if (! isset($data['name'])) {
|
|
|
|
throw new InvalidArgumentException('Key \'name\' missing');
|
|
|
|
}
|
|
|
|
|
|
|
|
$instanceName = $data['name'];
|
|
|
|
if ($this->config->hasSection($instanceName)) {
|
2015-07-23 16:18:44 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
$this->translate('A monitoring instance with the name "%s" does already exist'),
|
|
|
|
$instanceName
|
|
|
|
);
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
2015-06-29 12:01:43 +02:00
|
|
|
unset($data['name']);
|
|
|
|
$this->config->setSection($instanceName, $data);
|
|
|
|
return $this;
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Edit an existing instance
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @param string $name
|
|
|
|
* @param array $data
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @return $this
|
2014-09-04 08:47:16 +02:00
|
|
|
*
|
2015-06-29 12:01:43 +02:00
|
|
|
* @throws NotFoundError In case no instance with the given name is found
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
2015-06-29 12:01:43 +02:00
|
|
|
public function edit($name, array $data)
|
2014-09-04 08:47:16 +02:00
|
|
|
{
|
2015-06-29 12:01:43 +02:00
|
|
|
if (! $this->config->hasSection($name)) {
|
|
|
|
throw new NotFoundError('No monitoring instance called "%s" found', $name);
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
2014-11-18 13:11:52 +01:00
|
|
|
$instanceConfig = $this->config->getSection($name);
|
2015-06-29 12:01:43 +02:00
|
|
|
if (isset($data['name'])) {
|
|
|
|
if ($data['name'] !== $name) {
|
|
|
|
$this->config->removeSection($name);
|
|
|
|
$name = $data['name'];
|
2014-10-29 13:36:09 +01:00
|
|
|
}
|
2014-09-04 08:47:16 +02:00
|
|
|
|
2015-06-29 12:01:43 +02:00
|
|
|
unset($data['name']);
|
|
|
|
}
|
2015-05-28 10:50:13 +02:00
|
|
|
|
2015-06-29 12:01:43 +02:00
|
|
|
$instanceConfig->merge($data);
|
|
|
|
foreach ($instanceConfig->toArray() as $k => $v) {
|
|
|
|
if ($v === null) {
|
|
|
|
unset($instanceConfig->$k);
|
2015-05-28 10:50:13 +02:00
|
|
|
}
|
2014-10-29 13:36:09 +01:00
|
|
|
}
|
2015-06-29 12:01:43 +02:00
|
|
|
|
|
|
|
$this->config->setSection($name, $instanceConfig);
|
|
|
|
return $this;
|
2014-10-29 13:36:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Remove a instance
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
*
|
|
|
|
* @return $this
|
2014-10-29 13:36:09 +01:00
|
|
|
*/
|
2015-06-29 12:01:43 +02:00
|
|
|
public function delete($name)
|
2014-10-29 13:36:09 +01:00
|
|
|
{
|
2015-06-29 12:01:43 +02:00
|
|
|
$this->config->removeSection($name);
|
|
|
|
return $this;
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-06-29 12:01:43 +02:00
|
|
|
* Create and add elements to this form
|
|
|
|
*
|
|
|
|
* @param array $formData
|
2014-09-04 08:47:16 +02:00
|
|
|
*/
|
2015-06-29 12:01:43 +02:00
|
|
|
public function createElements(array $formData)
|
2014-09-04 08:47:16 +02:00
|
|
|
{
|
2015-06-29 12:01:43 +02:00
|
|
|
$this->addElement(
|
|
|
|
'text',
|
|
|
|
'name',
|
2014-09-04 08:47:16 +02:00
|
|
|
array(
|
2015-06-29 12:01:43 +02:00
|
|
|
'required' => true,
|
|
|
|
'label' => $this->translate('Instance Name'),
|
|
|
|
'description' => $this->translate(
|
|
|
|
'The name of this monitoring instance 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 \':\'.'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2014-10-29 13:36:09 +01:00
|
|
|
)
|
2015-06-29 12:01:43 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$instanceTypes = array(
|
|
|
|
LocalCommandFile::TRANSPORT => $this->translate('Local Command File'),
|
|
|
|
RemoteCommandFile::TRANSPORT => $this->translate('Remote Command File')
|
|
|
|
);
|
|
|
|
|
|
|
|
$instanceType = isset($formData['transport']) ? $formData['transport'] : null;
|
|
|
|
if ($instanceType === null) {
|
|
|
|
$instanceType = key($instanceTypes);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->addElements(array(
|
2014-09-04 08:47:16 +02:00
|
|
|
array(
|
2014-10-29 13:36:09 +01:00
|
|
|
'select',
|
|
|
|
'transport',
|
|
|
|
array(
|
|
|
|
'required' => true,
|
|
|
|
'autosubmit' => true,
|
2015-01-19 13:47:01 +01:00
|
|
|
'label' => $this->translate('Instance Type'),
|
2015-06-29 12:01:43 +02:00
|
|
|
'description' => $this->translate('The type of transport to use for this monitoring instance'),
|
|
|
|
'multiOptions' => $instanceTypes
|
2014-10-29 13:36:09 +01:00
|
|
|
)
|
2014-09-04 08:47:16 +02:00
|
|
|
)
|
2014-10-29 13:36:09 +01:00
|
|
|
));
|
2014-09-04 08:47:16 +02:00
|
|
|
|
2015-06-29 12:01:43 +02:00
|
|
|
$this->addSubForm($this->getInstanceForm($instanceType)->create($formData), 'instance_form');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Populate the configuration of the instance to load
|
|
|
|
*/
|
|
|
|
public function onRequest()
|
|
|
|
{
|
|
|
|
if ($this->instanceToLoad) {
|
|
|
|
$data = $this->config->getSection($this->instanceToLoad)->toArray();
|
|
|
|
$data['name'] = $this->instanceToLoad;
|
|
|
|
$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['instance_form']);
|
|
|
|
unset($values['instance_form']);
|
|
|
|
return $values;
|
2014-09-04 08:47:16 +02:00
|
|
|
}
|
|
|
|
}
|