2013-07-15 13:58:09 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2013-07-15 13:58:09 +02:00
|
|
|
|
|
|
|
namespace Icinga\Web;
|
|
|
|
|
2014-08-29 12:21:31 +02:00
|
|
|
use LogicException;
|
2014-10-06 10:42:24 +02:00
|
|
|
use Zend_Config;
|
2014-04-24 10:13:47 +02:00
|
|
|
use Zend_Form;
|
2015-02-05 13:15:18 +01:00
|
|
|
use Zend_Form_Element;
|
2014-07-18 09:51:15 +02:00
|
|
|
use Zend_View_Interface;
|
2014-08-26 12:30:37 +02:00
|
|
|
use Icinga\Application\Icinga;
|
2015-01-30 09:35:01 +01:00
|
|
|
use Icinga\Authentication\Manager;
|
|
|
|
use Icinga\Security\SecurityException;
|
2014-12-19 11:29:24 +01:00
|
|
|
use Icinga\Util\Translator;
|
2015-02-12 09:06:34 +01:00
|
|
|
use Icinga\Web\Form\ErrorLabeller;
|
2014-08-29 09:08:53 +02:00
|
|
|
use Icinga\Web\Form\Decorator\NoScriptApply;
|
2014-08-12 14:43:10 +02:00
|
|
|
use Icinga\Web\Form\Element\CsrfCounterMeasure;
|
2013-07-15 13:58:09 +02:00
|
|
|
|
2013-07-15 14:32:18 +02:00
|
|
|
/**
|
2013-08-12 11:23:01 +02:00
|
|
|
* Base class for forms providing CSRF protection, confirmation logic and auto submission
|
2014-10-08 17:43:28 +02:00
|
|
|
*
|
|
|
|
* @method $this setDefaults(array $defaults) {
|
|
|
|
* Use `Form::populate()' for setting default values for elements instead because `Form::setDefaults()' does not
|
|
|
|
* create the form via `Form::create()'.
|
|
|
|
*
|
|
|
|
* Due to a BC introduced with https://github.com/mhujer/zf1/commit/244e3d3f88a363ee0ca49cf63eee31f925f515cd
|
|
|
|
* we cannot override this function without running into a strict standards violation on Zend version 1.12.7.
|
|
|
|
*
|
|
|
|
* @param array $defaults
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
* }
|
2013-07-15 14:32:18 +02:00
|
|
|
*/
|
2013-08-26 16:56:23 +02:00
|
|
|
class Form extends Zend_Form
|
2013-07-15 13:58:09 +02:00
|
|
|
{
|
2014-07-18 09:51:15 +02:00
|
|
|
/**
|
|
|
|
* Whether this form has been created
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $created = false;
|
|
|
|
|
2014-11-14 14:59:12 +01:00
|
|
|
/**
|
|
|
|
* The request associated with this form
|
|
|
|
*
|
|
|
|
* @var Request
|
|
|
|
*/
|
|
|
|
protected $request;
|
|
|
|
|
2014-08-29 12:21:31 +02:00
|
|
|
/**
|
|
|
|
* The callback to call instead of Form::onSuccess()
|
|
|
|
*
|
2014-10-31 15:59:45 +01:00
|
|
|
* @var callable
|
2014-08-29 12:21:31 +02:00
|
|
|
*/
|
|
|
|
protected $onSuccess;
|
|
|
|
|
2014-08-22 15:20:54 +02:00
|
|
|
/**
|
|
|
|
* Label to use for the standard submit button
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $submitLabel;
|
|
|
|
|
2014-08-26 12:30:37 +02:00
|
|
|
/**
|
|
|
|
* The url to redirect to upon success
|
|
|
|
*
|
|
|
|
* @var string|Url
|
|
|
|
*/
|
|
|
|
protected $redirectUrl;
|
|
|
|
|
2013-07-24 10:56:41 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* The view script to use when rendering this form
|
2013-08-21 11:02:53 +02:00
|
|
|
*
|
2013-08-12 11:23:01 +02:00
|
|
|
* @var string
|
2013-07-24 10:56:41 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
protected $viewScript;
|
2013-07-24 10:56:41 +02:00
|
|
|
|
2013-08-26 15:06:07 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Whether this form should NOT add random generated "challenge" tokens that are associated with the user's current
|
|
|
|
* session in order to prevent Cross-Site Request Forgery (CSRF). It is the form's responsibility to verify the
|
|
|
|
* existence and correctness of this token
|
2013-08-26 15:06:07 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @var bool
|
2013-08-26 15:06:07 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
protected $tokenDisabled = false;
|
2013-09-11 17:19:18 +02:00
|
|
|
|
2013-07-24 10:56:41 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Name of the CSRF token element
|
2013-08-12 11:23:01 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @var string
|
2013-07-24 10:56:41 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
protected $tokenElementName = 'CSRFToken';
|
2013-09-11 17:19:18 +02:00
|
|
|
|
2014-09-05 09:16:09 +02:00
|
|
|
/**
|
|
|
|
* Whether this form should add a UID element being used to distinct different forms posting to the same action
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $uidDisabled = false;
|
|
|
|
|
2014-08-27 13:14:40 +02:00
|
|
|
/**
|
|
|
|
* Name of the form identification element
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $uidElementName = 'formUID';
|
|
|
|
|
2014-11-18 15:04:11 +01:00
|
|
|
/**
|
|
|
|
* Whether the form should validate the sent data when being automatically submitted
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $validatePartial = false;
|
|
|
|
|
2015-02-25 18:00:28 +01:00
|
|
|
/**
|
|
|
|
* Whether element ids will be protected against collisions by appending a request-specific unique identifier
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $protectIds = true;
|
|
|
|
|
2015-01-30 09:35:01 +01:00
|
|
|
/**
|
|
|
|
* Authentication manager
|
|
|
|
*
|
|
|
|
* @type Manager|null
|
|
|
|
*/
|
|
|
|
private $auth;
|
|
|
|
|
2014-10-06 10:42:24 +02:00
|
|
|
/**
|
|
|
|
* Default element decorators
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public static $defaultElementDecorators = array(
|
2014-10-15 15:46:07 +02:00
|
|
|
array('ViewHelper', array('separator' => '')),
|
|
|
|
array('Errors', array('separator' => '')),
|
2015-02-27 08:10:25 +01:00
|
|
|
array('Help'),
|
2014-10-15 15:46:07 +02:00
|
|
|
array('Label', array('separator' => '')),
|
|
|
|
array('HtmlTag', array('tag' => 'div', 'class' => 'element'))
|
2014-10-06 10:42:24 +02:00
|
|
|
);
|
|
|
|
|
2014-08-29 12:21:31 +02:00
|
|
|
/**
|
2014-11-18 17:08:25 +01:00
|
|
|
* (non-PHPDoc)
|
|
|
|
* @see \Zend_Form::construct() For the method documentation.
|
2014-08-29 12:21:31 +02:00
|
|
|
*/
|
|
|
|
public function __construct($options = null)
|
|
|
|
{
|
2014-11-18 12:51:06 +01:00
|
|
|
// Zend's plugin loader reverses the order of added prefix paths thus trying our paths first before trying
|
|
|
|
// Zend paths
|
|
|
|
$this->addPrefixPaths(array(
|
|
|
|
array(
|
|
|
|
'prefix' => 'Icinga\\Web\\Form\\Element\\',
|
|
|
|
'path' => Icinga::app()->getLibraryDir('Icinga/Web/Form/Element'),
|
|
|
|
'type' => static::ELEMENT
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'prefix' => 'Icinga\\Web\\Form\\Decorator\\',
|
|
|
|
'path' => Icinga::app()->getLibraryDir('Icinga/Web/Form/Decorator'),
|
|
|
|
'type' => static::DECORATOR
|
|
|
|
)
|
|
|
|
));
|
|
|
|
|
2014-08-29 12:21:31 +02:00
|
|
|
parent::__construct($options);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-04 16:15:06 +01:00
|
|
|
* Set a callback that is called instead of this form's onSuccess method
|
2014-08-29 12:21:31 +02:00
|
|
|
*
|
2014-12-18 17:21:06 +01:00
|
|
|
* It is called using the following signature: (Form $this).
|
2014-08-29 12:21:31 +02:00
|
|
|
*
|
2014-11-04 16:15:06 +01:00
|
|
|
* @param callable $onSuccess Callback
|
2014-08-29 12:21:31 +02:00
|
|
|
*
|
2014-11-04 16:15:06 +01:00
|
|
|
* @return $this
|
|
|
|
*
|
|
|
|
* @throws LogicException If the callback is not callable
|
2014-08-29 12:21:31 +02:00
|
|
|
*/
|
2014-11-04 16:15:06 +01:00
|
|
|
public function setOnSuccess($onSuccess)
|
2014-08-29 12:21:31 +02:00
|
|
|
{
|
2014-11-04 16:15:06 +01:00
|
|
|
if (! is_callable($onSuccess)) {
|
2014-08-29 12:21:31 +02:00
|
|
|
throw new LogicException('The option `onSuccess\' is not callable');
|
|
|
|
}
|
2014-11-04 16:15:06 +01:00
|
|
|
$this->onSuccess = $onSuccess;
|
|
|
|
return $this;
|
2014-08-29 12:21:31 +02:00
|
|
|
}
|
|
|
|
|
2014-08-22 15:20:54 +02:00
|
|
|
/**
|
|
|
|
* Set the label to use for the standard submit button
|
|
|
|
*
|
|
|
|
* @param string $label The label to use for the submit button
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setSubmitLabel($label)
|
|
|
|
{
|
|
|
|
$this->submitLabel = $label;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the label being used for the standard submit button
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSubmitLabel()
|
|
|
|
{
|
|
|
|
return $this->submitLabel;
|
|
|
|
}
|
|
|
|
|
2014-08-26 12:30:37 +02:00
|
|
|
/**
|
|
|
|
* Set the url to redirect to upon success
|
|
|
|
*
|
|
|
|
* @param string|Url $url The url to redirect to
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setRedirectUrl($url)
|
|
|
|
{
|
|
|
|
$this->redirectUrl = $url;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the url to redirect to upon success
|
|
|
|
*
|
|
|
|
* @return string|Url
|
|
|
|
*/
|
|
|
|
public function getRedirectUrl()
|
|
|
|
{
|
|
|
|
if ($this->redirectUrl === null) {
|
2014-09-09 09:31:15 +02:00
|
|
|
$url = Url::fromRequest(array(), $this->getRequest());
|
2014-08-26 12:30:37 +02:00
|
|
|
// Be sure to remove all form dependent params because we do not want to submit it again
|
2014-09-09 09:31:15 +02:00
|
|
|
$this->redirectUrl = $url->without(array_keys($this->getElements()));
|
2014-08-26 12:30:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $this->redirectUrl;
|
|
|
|
}
|
|
|
|
|
2013-07-18 10:32:53 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Set the view script to use when rendering this form
|
2013-08-12 11:23:01 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @param string $viewScript The view script to use
|
2013-08-21 11:02:53 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return self
|
2013-07-18 10:32:53 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function setViewScript($viewScript)
|
2013-07-16 15:39:47 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
$this->viewScript = $viewScript;
|
|
|
|
return $this;
|
2013-07-15 13:58:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Return the view script being used when rendering this form
|
|
|
|
*
|
|
|
|
* @return string
|
2013-07-15 13:58:09 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function getViewScript()
|
2013-08-27 14:37:22 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
return $this->viewScript;
|
2013-08-27 14:37:22 +02:00
|
|
|
}
|
2013-07-15 13:58:09 +02:00
|
|
|
|
2013-08-27 14:27:31 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Disable CSRF counter measure and remove its field if already added
|
2013-08-27 14:27:31 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @param bool $disabled Set true in order to disable CSRF protection for this form, otherwise false
|
2013-08-27 14:27:31 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return self
|
2013-08-27 14:27:31 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function setTokenDisabled($disabled = true)
|
2013-08-27 14:27:31 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
$this->tokenDisabled = (bool) $disabled;
|
|
|
|
|
|
|
|
if ($disabled && $this->getElement($this->tokenElementName) !== null) {
|
|
|
|
$this->removeElement($this->tokenElementName);
|
2013-08-27 14:27:31 +02:00
|
|
|
}
|
2014-04-24 10:13:47 +02:00
|
|
|
|
2014-07-10 11:13:45 +02:00
|
|
|
return $this;
|
2013-08-27 14:27:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Return whether CSRF counter measures are disabled for this form
|
2013-08-27 14:27:31 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return bool
|
2013-08-27 14:27:31 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function getTokenDisabled()
|
2013-08-27 14:27:31 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
return $this->tokenDisabled;
|
2013-08-27 14:27:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Set the name to use for the CSRF element
|
|
|
|
*
|
|
|
|
* @param string $name The name to set
|
2013-08-27 14:27:31 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return self
|
2013-08-27 14:27:31 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function setTokenElementName($name)
|
2013-08-27 14:27:31 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
$this->tokenElementName = $name;
|
|
|
|
return $this;
|
2013-08-27 14:27:31 +02:00
|
|
|
}
|
|
|
|
|
2013-07-18 10:32:53 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Return the name of the CSRF element
|
2013-08-12 11:23:01 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return string
|
2013-07-18 10:32:53 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function getTokenElementName()
|
2013-07-18 10:32:53 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
return $this->tokenElementName;
|
2013-07-18 10:32:53 +02:00
|
|
|
}
|
|
|
|
|
2014-09-05 09:16:09 +02:00
|
|
|
/**
|
|
|
|
* Disable form identification and remove its field if already added
|
|
|
|
*
|
|
|
|
* @param bool $disabled Set true in order to disable identification for this form, otherwise false
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setUidDisabled($disabled = true)
|
|
|
|
{
|
|
|
|
$this->uidDisabled = (bool) $disabled;
|
|
|
|
|
|
|
|
if ($disabled && $this->getElement($this->uidElementName) !== null) {
|
|
|
|
$this->removeElement($this->uidElementName);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return whether identification is disabled for this form
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function getUidDisabled()
|
|
|
|
{
|
|
|
|
return $this->uidDisabled;
|
|
|
|
}
|
|
|
|
|
2014-08-27 13:14:40 +02:00
|
|
|
/**
|
|
|
|
* Set the name to use for the form identification element
|
|
|
|
*
|
|
|
|
* @param string $name The name to set
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setUidElementName($name)
|
|
|
|
{
|
|
|
|
$this->uidElementName = $name;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the name of the form identification element
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getUidElementName()
|
|
|
|
{
|
|
|
|
return $this->uidElementName;
|
|
|
|
}
|
|
|
|
|
2014-11-18 15:04:11 +01:00
|
|
|
/**
|
|
|
|
* Set whether this form should validate the sent data when being automatically submitted
|
|
|
|
*
|
|
|
|
* @param bool $state
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setValidatePartial($state)
|
|
|
|
{
|
|
|
|
$this->validatePartial = $state;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return whether this form should validate the sent data when being automatically submitted
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function getValidatePartial()
|
|
|
|
{
|
|
|
|
return $this->validatePartial;
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
/**
|
|
|
|
* Create this form
|
|
|
|
*
|
2014-08-22 12:04:14 +02:00
|
|
|
* @param array $formData The data sent by the user
|
2014-07-18 09:51:15 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function create(array $formData = array())
|
|
|
|
{
|
|
|
|
if (false === $this->created) {
|
2014-09-08 09:24:53 +02:00
|
|
|
$this->createElements($formData);
|
|
|
|
$this->addFormIdentification()
|
2014-08-25 16:49:54 +02:00
|
|
|
->addCsrfCounterMeasure()
|
|
|
|
->addSubmitButton();
|
2014-08-13 14:50:21 +02:00
|
|
|
|
2014-08-12 10:41:19 +02:00
|
|
|
if ($this->getAction() === '') {
|
|
|
|
// We MUST set an action as JS gets confused otherwise, if
|
|
|
|
// this form is being displayed in an additional column
|
2014-09-09 09:31:15 +02:00
|
|
|
$this->setAction(Url::fromRequest()->without(array_keys($this->getElements())));
|
2014-08-12 10:41:19 +02:00
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
$this->created = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-08-05 11:05:11 +02:00
|
|
|
/**
|
2014-09-03 12:21:31 +02:00
|
|
|
* Create and add elements to this form
|
2014-07-10 11:13:45 +02:00
|
|
|
*
|
|
|
|
* Intended to be implemented by concrete form classes.
|
|
|
|
*
|
2014-08-22 12:04:14 +02:00
|
|
|
* @param array $formData The data sent by the user
|
2013-08-05 11:05:11 +02:00
|
|
|
*/
|
2014-07-18 09:51:15 +02:00
|
|
|
public function createElements(array $formData)
|
2013-08-05 11:05:11 +02:00
|
|
|
{
|
2014-09-08 09:24:53 +02:00
|
|
|
|
2013-08-05 11:05:11 +02:00
|
|
|
}
|
|
|
|
|
2014-08-25 17:06:45 +02:00
|
|
|
/**
|
|
|
|
* Perform actions after this form was submitted using a valid request
|
|
|
|
*
|
2014-08-27 10:09:29 +02:00
|
|
|
* Intended to be implemented by concrete form classes. The base implementation returns always FALSE.
|
2014-08-25 17:06:45 +02:00
|
|
|
*
|
2014-08-29 09:04:20 +02:00
|
|
|
* @return null|bool Return FALSE in case no redirect should take place
|
2014-08-25 17:06:45 +02:00
|
|
|
*/
|
2014-11-14 14:59:12 +01:00
|
|
|
public function onSuccess()
|
2014-08-25 17:06:45 +02:00
|
|
|
{
|
2014-08-27 10:09:29 +02:00
|
|
|
return false;
|
2014-08-25 17:06:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-08-27 10:25:50 +02:00
|
|
|
* Perform actions when no form dependent data was sent
|
2014-08-25 17:06:45 +02:00
|
|
|
*
|
|
|
|
* Intended to be implemented by concrete form classes.
|
|
|
|
*/
|
2014-11-14 14:59:12 +01:00
|
|
|
public function onRequest()
|
2014-08-25 17:06:45 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:54:36 +02:00
|
|
|
/**
|
|
|
|
* Add a submit button to this form
|
|
|
|
*
|
2014-08-22 15:20:54 +02:00
|
|
|
* Uses the label previously set with Form::setSubmitLabel(). Overwrite this
|
|
|
|
* method in order to add multiple submit buttons or one with a custom name.
|
2014-07-18 09:54:36 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function addSubmitButton()
|
|
|
|
{
|
2014-09-19 13:39:38 +02:00
|
|
|
$submitLabel = $this->getSubmitLabel();
|
|
|
|
if ($submitLabel) {
|
2014-08-22 15:20:54 +02:00
|
|
|
$this->addElement(
|
|
|
|
'submit',
|
|
|
|
'btn_submit',
|
|
|
|
array(
|
2014-09-02 15:23:07 +02:00
|
|
|
'ignore' => true,
|
2014-09-19 13:39:38 +02:00
|
|
|
'label' => $submitLabel,
|
2014-09-02 15:23:07 +02:00
|
|
|
'decorators' => array(
|
|
|
|
'ViewHelper',
|
|
|
|
array('HtmlTag', array('tag' => 'div'))
|
|
|
|
)
|
2014-08-22 15:20:54 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:54:36 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-09 15:00:33 +02:00
|
|
|
/**
|
|
|
|
* Add a subform
|
|
|
|
*
|
|
|
|
* @param Zend_Form $form The subform to add
|
|
|
|
* @param string $name The name of the subform or null to use the name of $form
|
|
|
|
* @param int $order The location where to insert the form
|
|
|
|
*
|
|
|
|
* @return Zend_Form
|
|
|
|
*/
|
|
|
|
public function addSubForm(Zend_Form $form, $name = null, $order = null)
|
|
|
|
{
|
|
|
|
if ($form instanceof self) {
|
|
|
|
$form->removeDecorator('Form');
|
|
|
|
$form->setSubmitLabel('');
|
|
|
|
$form->setTokenDisabled();
|
|
|
|
$form->setUidDisabled();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($name === null) {
|
|
|
|
$name = $form->getName();
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::addSubForm($form, $name, $order);
|
|
|
|
}
|
|
|
|
|
2013-08-05 11:05:11 +02:00
|
|
|
/**
|
2014-07-23 10:57:46 +02:00
|
|
|
* Create a new element
|
2014-07-10 11:13:45 +02:00
|
|
|
*
|
2014-10-06 10:42:24 +02:00
|
|
|
* Icinga Web 2 loads its own default element decorators. For loading Zend's default element decorators set the
|
|
|
|
* `disableLoadDefaultDecorators' option to any other value than `true'. For loading custom element decorators use
|
|
|
|
* the 'decorators' option.
|
2014-07-10 11:13:45 +02:00
|
|
|
*
|
2014-11-14 10:12:01 +01:00
|
|
|
* @param string $type The type of the element
|
|
|
|
* @param string $name The name of the element
|
2014-10-06 10:42:24 +02:00
|
|
|
* @param mixed $options The options for the element
|
2014-07-10 11:13:45 +02:00
|
|
|
*
|
2014-07-23 10:57:46 +02:00
|
|
|
* @return Zend_Form_Element
|
2013-08-12 11:23:01 +02:00
|
|
|
*
|
2014-10-06 10:42:24 +02:00
|
|
|
* @see Form::$defaultElementDecorators For Icinga Web 2's default element decorators.
|
2013-08-05 11:05:11 +02:00
|
|
|
*/
|
2014-07-23 10:57:46 +02:00
|
|
|
public function createElement($type, $name, $options = null)
|
2013-08-05 11:05:11 +02:00
|
|
|
{
|
2014-10-06 10:42:24 +02:00
|
|
|
if ($options !== null) {
|
|
|
|
if ($options instanceof Zend_Config) {
|
|
|
|
$options = $options->toArray();
|
|
|
|
}
|
|
|
|
if (! isset($options['decorators'])
|
|
|
|
&& ! array_key_exists('disabledLoadDefaultDecorators', $options)
|
|
|
|
) {
|
|
|
|
$options['decorators'] = static::$defaultElementDecorators;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$options = array('decorators' => static::$defaultElementDecorators);
|
2014-09-02 15:23:07 +02:00
|
|
|
}
|
2014-09-02 14:48:37 +02:00
|
|
|
|
2014-07-23 10:57:46 +02:00
|
|
|
$el = parent::createElement($type, $name, $options);
|
2015-02-12 09:06:34 +01:00
|
|
|
$el->setTranslator(new ErrorLabeller(array('element' => $el)));
|
2014-10-06 10:42:24 +02:00
|
|
|
|
2015-02-11 09:50:17 +01:00
|
|
|
$el->addPrefixPaths(array(
|
|
|
|
array(
|
|
|
|
'prefix' => 'Icinga\\Web\\Form\\Validator\\',
|
|
|
|
'path' => Icinga::app()->getLibraryDir('Icinga/Web/Form/Validator'),
|
|
|
|
'type' => $el::VALIDATE
|
|
|
|
)
|
|
|
|
));
|
|
|
|
|
2014-11-20 13:23:21 +01:00
|
|
|
if ($el->getAttrib('autosubmit')) {
|
2014-11-12 10:48:52 +01:00
|
|
|
$noScript = new NoScriptApply(); // Non-JS environments
|
|
|
|
$decorators = $el->getDecorators();
|
|
|
|
$pos = array_search('Zend_Form_Decorator_ViewHelper', array_keys($decorators)) + 1;
|
|
|
|
$el->setDecorators(
|
|
|
|
array_slice($decorators, 0, $pos, true)
|
|
|
|
+ array(get_class($noScript) => $noScript)
|
|
|
|
+ array_slice($decorators, $pos, count($decorators) - $pos, true)
|
|
|
|
);
|
|
|
|
|
2014-09-02 15:23:07 +02:00
|
|
|
$class = $el->getAttrib('class');
|
|
|
|
if (is_array($class)) {
|
|
|
|
$class[] = 'autosubmit';
|
|
|
|
} elseif ($class === null) {
|
|
|
|
$class = 'autosubmit';
|
2014-07-10 11:13:45 +02:00
|
|
|
} else {
|
2014-09-02 15:23:07 +02:00
|
|
|
$class .= ' autosubmit';
|
2014-07-10 11:13:45 +02:00
|
|
|
}
|
2014-09-02 15:23:07 +02:00
|
|
|
$el->setAttrib('class', $class); // JS environments
|
2014-11-12 10:48:52 +01:00
|
|
|
|
2014-09-02 15:23:07 +02:00
|
|
|
unset($el->autosubmit);
|
2014-07-10 11:13:45 +02:00
|
|
|
}
|
2014-09-02 14:48:37 +02:00
|
|
|
|
2015-02-05 13:15:18 +01:00
|
|
|
return $this->ensureElementAccessibility($el);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add accessibility related attributes
|
|
|
|
*
|
|
|
|
* @param Zend_Form_Element $element
|
|
|
|
*
|
|
|
|
* @return Zend_Form_Element
|
|
|
|
*/
|
|
|
|
public function ensureElementAccessibility(Zend_Form_Element $element)
|
|
|
|
{
|
|
|
|
if ($element->isRequired() && strpos(strtolower($element->getType()), 'checkbox') === false) {
|
|
|
|
$element->setAttrib('aria-required', 'true'); // ARIA
|
|
|
|
$element->setAttrib('required', ''); // HTML5
|
2015-02-26 16:05:13 +01:00
|
|
|
if (($label = $element->getDecorator('label')) !== false) {
|
|
|
|
$element->setLabel($this->getView()->escape($element->getLabel()));
|
|
|
|
$label->setOption('escape', false);
|
|
|
|
$label->setOption('requiredSuffix', ' <span aria-hidden="true">*</span>');
|
|
|
|
}
|
2015-02-05 13:15:18 +01:00
|
|
|
}
|
|
|
|
|
2015-02-27 08:10:25 +01:00
|
|
|
if ($element->getDescription() !== null && ($help = $element->getDecorator('help')) !== false) {
|
|
|
|
$element->setAttrib('aria-describedby', $help->setAccessible()->getDescriptionId($element));
|
|
|
|
}
|
|
|
|
|
2015-02-05 13:15:18 +01:00
|
|
|
return $element;
|
2013-08-05 11:05:11 +02:00
|
|
|
}
|
|
|
|
|
2014-08-25 16:49:54 +02:00
|
|
|
/**
|
|
|
|
* Add a field with a unique and form specific ID
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function addFormIdentification()
|
|
|
|
{
|
2014-09-05 09:16:09 +02:00
|
|
|
if (false === $this->uidDisabled && $this->getElement($this->uidElementName) === null) {
|
|
|
|
$this->addElement(
|
|
|
|
'hidden',
|
|
|
|
$this->uidElementName,
|
|
|
|
array(
|
2014-09-05 10:21:24 +02:00
|
|
|
'ignore' => true,
|
|
|
|
'value' => $this->getName(),
|
|
|
|
'decorators' => array('ViewHelper')
|
2014-09-05 09:16:09 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2014-08-25 16:49:54 +02:00
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:43:03 +02:00
|
|
|
/**
|
|
|
|
* Add CSRF counter measure field to this form
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2014-08-12 14:43:10 +02:00
|
|
|
public function addCsrfCounterMeasure()
|
2014-07-18 09:43:03 +02:00
|
|
|
{
|
|
|
|
if (false === $this->tokenDisabled && $this->getElement($this->tokenElementName) === null) {
|
2014-09-19 12:57:53 +02:00
|
|
|
$this->addElement(new CsrfCounterMeasure($this->tokenElementName));
|
2014-07-18 09:43:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
/**
|
|
|
|
* Populate the elements with the given values
|
|
|
|
*
|
|
|
|
* @param array $defaults The values to populate the elements with
|
|
|
|
*/
|
2014-10-08 17:43:28 +02:00
|
|
|
public function populate(array $defaults)
|
2014-07-18 09:51:15 +02:00
|
|
|
{
|
|
|
|
$this->create($defaults);
|
2014-10-08 17:43:28 +02:00
|
|
|
return parent::populate($defaults);
|
2014-07-18 09:51:15 +02:00
|
|
|
}
|
|
|
|
|
2014-08-25 17:06:45 +02:00
|
|
|
/**
|
|
|
|
* Process the given request using this form
|
|
|
|
*
|
2014-08-27 10:25:50 +02:00
|
|
|
* Redirects to the url set with setRedirectUrl() upon success. See onSuccess()
|
2014-09-02 14:35:01 +02:00
|
|
|
* and onRequest() wherewith you can customize the processing logic.
|
2014-08-26 12:30:37 +02:00
|
|
|
*
|
2014-08-25 17:06:45 +02:00
|
|
|
* @param Request $request The request to be processed
|
|
|
|
*
|
2014-08-27 10:19:33 +02:00
|
|
|
* @return Request The request supposed to be processed
|
2014-08-25 17:06:45 +02:00
|
|
|
*/
|
2014-08-26 12:31:05 +02:00
|
|
|
public function handleRequest(Request $request = null)
|
2014-08-25 17:06:45 +02:00
|
|
|
{
|
2014-08-26 12:31:05 +02:00
|
|
|
if ($request === null) {
|
|
|
|
$request = $this->getRequest();
|
2014-11-14 14:59:12 +01:00
|
|
|
} else {
|
|
|
|
$this->request = $request;
|
2014-08-26 12:31:05 +02:00
|
|
|
}
|
|
|
|
|
2014-11-14 14:59:12 +01:00
|
|
|
$formData = $this->getRequestData();
|
2014-09-09 09:30:33 +02:00
|
|
|
if ($this->getUidDisabled() || $this->wasSent($formData)) {
|
2014-08-27 10:19:33 +02:00
|
|
|
$this->populate($formData); // Necessary to get isSubmitted() to work
|
2014-08-29 09:04:20 +02:00
|
|
|
if (! $this->getSubmitLabel() || $this->isSubmitted()) {
|
2014-08-29 12:21:31 +02:00
|
|
|
if ($this->isValid($formData)
|
2014-11-14 14:59:12 +01:00
|
|
|
&& (($this->onSuccess !== null && false !== call_user_func($this->onSuccess, $this))
|
|
|
|
|| ($this->onSuccess === null && false !== $this->onSuccess()))) {
|
2014-08-27 10:25:50 +02:00
|
|
|
$this->getResponse()->redirectAndExit($this->getRedirectUrl());
|
2014-08-25 17:06:45 +02:00
|
|
|
}
|
2014-11-18 15:04:11 +01:00
|
|
|
} elseif ($this->getValidatePartial()) {
|
|
|
|
// The form can't be processed but we may want to show validation errors though
|
2014-08-27 10:19:33 +02:00
|
|
|
$this->isValidPartial($formData);
|
2014-08-25 17:06:45 +02:00
|
|
|
}
|
2014-08-27 10:25:50 +02:00
|
|
|
} else {
|
2014-11-14 14:59:12 +01:00
|
|
|
$this->onRequest();
|
2014-08-25 17:06:45 +02:00
|
|
|
}
|
2014-08-26 12:30:37 +02:00
|
|
|
|
2014-08-27 10:19:33 +02:00
|
|
|
return $request;
|
2014-08-25 17:06:45 +02:00
|
|
|
}
|
|
|
|
|
2014-08-22 15:20:54 +02:00
|
|
|
/**
|
|
|
|
* Return whether the submit button of this form was pressed
|
|
|
|
*
|
|
|
|
* When overwriting Form::addSubmitButton() be sure to overwrite this method as well.
|
|
|
|
*
|
|
|
|
* @return bool True in case it was pressed, False otherwise or no submit label was set
|
|
|
|
*/
|
|
|
|
public function isSubmitted()
|
|
|
|
{
|
2014-09-19 14:27:04 +02:00
|
|
|
if ($this->getSubmitLabel()) {
|
2014-08-22 15:20:54 +02:00
|
|
|
return $this->getElement('btn_submit')->isChecked();
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-08-25 16:49:54 +02:00
|
|
|
/**
|
|
|
|
* Return whether the data sent by the user refers to this form
|
|
|
|
*
|
|
|
|
* Ensures that the correct form gets processed in case there are multiple forms
|
|
|
|
* with equal submit button names being posted against the same route.
|
|
|
|
*
|
|
|
|
* @param array $formData The data sent by the user
|
|
|
|
*
|
|
|
|
* @return bool Whether the given data refers to this form
|
|
|
|
*/
|
|
|
|
public function wasSent(array $formData)
|
|
|
|
{
|
2014-08-27 13:14:40 +02:00
|
|
|
return isset($formData[$this->uidElementName]) && $formData[$this->uidElementName] === $this->getName();
|
2014-08-25 16:49:54 +02:00
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
/**
|
|
|
|
* Return whether the given values (possibly incomplete) are valid
|
|
|
|
*
|
|
|
|
* Unlike Zend_Form::isValid() this will not set NULL as value for
|
|
|
|
* an element that is not present in the given data.
|
|
|
|
*
|
|
|
|
* @param array $formData The data to validate
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValidPartial(array $formData)
|
|
|
|
{
|
|
|
|
$this->create($formData);
|
2014-11-18 15:06:36 +01:00
|
|
|
|
|
|
|
// Ensure that disabled elements are not overwritten (http://www.zendframework.com/issues/browse/ZF-6909)
|
|
|
|
foreach ($this->getElements() as $name => $element) {
|
|
|
|
if ($element->getAttrib('disabled')) {
|
|
|
|
$formData[$name] = $element->getValue();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
return parent::isValidPartial($formData);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-08-25 16:49:54 +02:00
|
|
|
* Return whether the given values are valid
|
2014-07-18 09:51:15 +02:00
|
|
|
*
|
|
|
|
* @param array $formData The data to validate
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValid($formData)
|
|
|
|
{
|
2014-08-25 16:49:54 +02:00
|
|
|
$this->create($formData);
|
2014-11-18 15:06:36 +01:00
|
|
|
|
|
|
|
// Ensure that disabled elements are not overwritten (http://www.zendframework.com/issues/browse/ZF-6909)
|
|
|
|
foreach ($this->getElements() as $name => $element) {
|
|
|
|
if ($element->getAttrib('disabled')) {
|
|
|
|
$formData[$name] = $element->getValue();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-25 16:49:54 +02:00
|
|
|
return parent::isValid($formData);
|
2014-07-18 09:51:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all elements of this form
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function clearElements()
|
|
|
|
{
|
|
|
|
$this->created = false;
|
|
|
|
return parent::clearElements();
|
|
|
|
}
|
|
|
|
|
2013-08-26 15:06:07 +02:00
|
|
|
/**
|
2014-07-10 11:13:45 +02:00
|
|
|
* Load the default decorators
|
|
|
|
*
|
2014-07-18 09:52:50 +02:00
|
|
|
* Overwrites Zend_Form::loadDefaultDecorators to avoid having
|
|
|
|
* the HtmlTag-Decorator added and to provide viewscript usage
|
2013-08-26 15:06:07 +02:00
|
|
|
*
|
2014-07-10 11:13:45 +02:00
|
|
|
* @return self
|
2013-08-26 15:06:07 +02:00
|
|
|
*/
|
2014-07-10 11:13:45 +02:00
|
|
|
public function loadDefaultDecorators()
|
2013-08-26 15:06:07 +02:00
|
|
|
{
|
2014-07-10 11:13:45 +02:00
|
|
|
if ($this->loadDefaultDecoratorsIsDisabled()) {
|
|
|
|
return $this;
|
|
|
|
}
|
2014-09-02 14:48:37 +02:00
|
|
|
|
2014-07-10 11:13:45 +02:00
|
|
|
$decorators = $this->getDecorators();
|
|
|
|
if (empty($decorators)) {
|
|
|
|
if ($this->viewScript) {
|
2014-08-27 10:10:55 +02:00
|
|
|
$this->addDecorator('ViewScript', array(
|
|
|
|
'viewScript' => $this->viewScript,
|
|
|
|
'form' => $this
|
|
|
|
));
|
2014-07-10 11:13:45 +02:00
|
|
|
} else {
|
2014-09-02 14:48:37 +02:00
|
|
|
$this->addDecorator('FormErrors', array('onlyCustomFormErrors' => true))
|
2014-09-02 15:23:07 +02:00
|
|
|
->addDecorator('FormElements')
|
2014-09-02 14:48:37 +02:00
|
|
|
//->addDecorator('HtmlTag', array('tag' => 'dl', 'class' => 'zend_form'))
|
2014-07-10 11:13:45 +02:00
|
|
|
->addDecorator('Form');
|
|
|
|
}
|
|
|
|
}
|
2014-09-02 14:48:37 +02:00
|
|
|
|
2014-07-10 11:13:45 +02:00
|
|
|
return $this;
|
2013-08-26 15:06:07 +02:00
|
|
|
}
|
|
|
|
|
2014-08-25 16:49:54 +02:00
|
|
|
/**
|
|
|
|
* Return the name of this form
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
$name = parent::getName();
|
|
|
|
if (! $name) {
|
|
|
|
$name = get_class($this);
|
|
|
|
$this->setName($name);
|
2014-09-01 14:40:45 +02:00
|
|
|
$name = parent::getName();
|
2014-08-25 16:49:54 +02:00
|
|
|
}
|
|
|
|
return $name;
|
|
|
|
}
|
|
|
|
|
2014-08-27 10:19:33 +02:00
|
|
|
/**
|
2014-11-14 14:59:12 +01:00
|
|
|
* Return the request associated with this form
|
2014-08-27 10:19:33 +02:00
|
|
|
*
|
2014-11-14 14:59:12 +01:00
|
|
|
* Returns the global request if none has been set for this form yet.
|
2014-08-27 10:19:33 +02:00
|
|
|
*
|
2014-11-14 14:59:12 +01:00
|
|
|
* @return Request
|
2014-08-27 10:19:33 +02:00
|
|
|
*/
|
2014-11-14 14:59:12 +01:00
|
|
|
public function getRequest()
|
2014-08-27 10:19:33 +02:00
|
|
|
{
|
2014-11-14 14:59:12 +01:00
|
|
|
if ($this->request === null) {
|
|
|
|
$this->request = Icinga::app()->getFrontController()->getRequest();
|
2014-08-27 10:19:33 +02:00
|
|
|
}
|
|
|
|
|
2014-11-14 14:59:12 +01:00
|
|
|
return $this->request;
|
2014-08-27 10:19:33 +02:00
|
|
|
}
|
|
|
|
|
2014-08-26 12:31:05 +02:00
|
|
|
/**
|
2014-11-14 14:59:12 +01:00
|
|
|
* Return the current Response
|
2014-08-26 12:31:05 +02:00
|
|
|
*
|
2014-11-14 14:59:12 +01:00
|
|
|
* @return Response
|
2014-08-26 12:31:05 +02:00
|
|
|
*/
|
2014-11-14 14:59:12 +01:00
|
|
|
public function getResponse()
|
2014-08-26 12:31:05 +02:00
|
|
|
{
|
2014-11-14 14:59:12 +01:00
|
|
|
return Icinga::app()->getFrontController()->getResponse();
|
2014-08-26 12:31:05 +02:00
|
|
|
}
|
|
|
|
|
2014-08-26 12:30:37 +02:00
|
|
|
/**
|
2014-11-14 14:59:12 +01:00
|
|
|
* Return the request data based on this form's request method
|
2014-08-26 12:30:37 +02:00
|
|
|
*
|
2014-11-14 14:59:12 +01:00
|
|
|
* @return array
|
2014-08-26 12:30:37 +02:00
|
|
|
*/
|
2014-11-14 14:59:12 +01:00
|
|
|
protected function getRequestData()
|
2014-08-26 12:30:37 +02:00
|
|
|
{
|
2014-11-14 14:59:12 +01:00
|
|
|
if (strtolower($this->request->getMethod()) === $this->getMethod()) {
|
|
|
|
return $this->request->{'get' . ($this->request->isPost() ? 'Post' : 'Query')}();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array();
|
2014-08-26 12:30:37 +02:00
|
|
|
}
|
|
|
|
|
2014-12-19 12:08:54 +01:00
|
|
|
/**
|
2014-12-30 10:08:33 +01:00
|
|
|
* Get the translation domain for this form
|
2014-12-19 12:08:54 +01:00
|
|
|
*
|
2014-12-30 10:08:33 +01:00
|
|
|
* The returned translation domain is either determined based on this form's qualified name or it is the default
|
|
|
|
* 'icinga' domain
|
2014-12-19 13:07:51 +01:00
|
|
|
*
|
2014-12-30 10:08:33 +01:00
|
|
|
* @return string
|
2014-12-19 12:08:54 +01:00
|
|
|
*/
|
|
|
|
protected function getTranslationDomain()
|
|
|
|
{
|
2014-12-30 10:08:33 +01:00
|
|
|
$parts = explode('\\', get_called_class());
|
|
|
|
if ($parts[1] === 'Module') {
|
|
|
|
// Assume format Icinga\Module\ModuleName\Forms\...
|
|
|
|
return strtolower($parts[2]);
|
2014-12-19 12:08:54 +01:00
|
|
|
}
|
2014-12-19 13:07:51 +01:00
|
|
|
return 'icinga';
|
2014-12-19 12:08:54 +01:00
|
|
|
}
|
|
|
|
|
2014-12-19 11:29:24 +01:00
|
|
|
/**
|
|
|
|
* Translate a string
|
|
|
|
*
|
|
|
|
* @param string $text The string to translate
|
|
|
|
* @param string|null $context Optional parameter for context based translation
|
|
|
|
*
|
|
|
|
* @return string The translated string
|
|
|
|
*/
|
|
|
|
protected function translate($text, $context = null)
|
|
|
|
{
|
2014-12-19 12:08:54 +01:00
|
|
|
return Translator::translate($text, $this->getTranslationDomain(), $context);
|
2014-12-19 11:29:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Translate a plural string
|
|
|
|
*
|
|
|
|
* @param string $textSingular The string in singular form to translate
|
|
|
|
* @param string $textPlural The string in plural form to translate
|
|
|
|
* @param integer $number The amount to determine from whether to return singular or plural
|
|
|
|
* @param string|null $context Optional parameter for context based translation
|
|
|
|
*
|
|
|
|
* @return string The translated string
|
|
|
|
*/
|
|
|
|
protected function translatePlural($textSingular, $textPlural, $number, $context = null)
|
|
|
|
{
|
|
|
|
return Translator::translatePlural(
|
|
|
|
$textSingular,
|
|
|
|
$textPlural,
|
|
|
|
$number,
|
2014-12-19 12:08:54 +01:00
|
|
|
$this->getTranslationDomain(),
|
2014-12-19 11:29:24 +01:00
|
|
|
$context
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2014-07-18 09:51:15 +02:00
|
|
|
/**
|
|
|
|
* Render this form
|
|
|
|
*
|
|
|
|
* @param Zend_View_Interface $view The view context to use
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function render(Zend_View_Interface $view = null)
|
|
|
|
{
|
|
|
|
$this->create();
|
2015-02-25 18:00:28 +01:00
|
|
|
if ($this->protectIds) {
|
|
|
|
if (null !== $this->getAttrib('id')) {
|
|
|
|
$this->setAttrib('id', $this->getRequest()->protectId($this->getAttrib('id')));
|
|
|
|
} else {
|
|
|
|
$this->setAttrib('id', $this->getRequest()->protectId($this->name));
|
|
|
|
}
|
|
|
|
|
|
|
|
/** @var Zend_Form_Element $element */
|
|
|
|
foreach ($this->getElements() as $element) {
|
|
|
|
if (null !== $element->getAttrib('id')) {
|
|
|
|
$element->setAttrib(
|
|
|
|
'id',
|
|
|
|
$this->getRequest()->protectId($this->getName() . '-' . $element->getAttrib('id'))
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$element->setAttrib(
|
|
|
|
'id',
|
|
|
|
$this->getRequest()->protectId($this->getName() . '-' . $element->getName())
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-07-18 09:51:15 +02:00
|
|
|
return parent::render($view);
|
|
|
|
}
|
2015-01-30 09:35:01 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the authentication manager
|
|
|
|
*
|
|
|
|
* @return Manager
|
|
|
|
*/
|
|
|
|
public function Auth()
|
|
|
|
{
|
|
|
|
if ($this->auth === null) {
|
|
|
|
$this->auth = Manager::getInstance();
|
|
|
|
}
|
|
|
|
return $this->auth;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the current user has the given permission
|
|
|
|
*
|
|
|
|
* @param string $permission Name of the permission
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasPermission($permission)
|
|
|
|
{
|
|
|
|
return $this->Auth()->hasPermission($permission);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assert that the current user has the given permission
|
|
|
|
*
|
|
|
|
* @param string $permission Name of the permission
|
|
|
|
*
|
|
|
|
* @throws SecurityException If the current user lacks the given permission
|
|
|
|
*/
|
|
|
|
public function assertPermission($permission)
|
|
|
|
{
|
|
|
|
if (! $this->Auth()->hasPermission($permission)) {
|
|
|
|
throw new SecurityException('No permission for %s', $permission);
|
|
|
|
}
|
|
|
|
}
|
2015-02-25 18:00:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable or disable whether ids should be altered to guard them against duplications
|
|
|
|
*
|
|
|
|
* @param $value boolean Whether or not protect ids against collisions through other requests
|
|
|
|
*/
|
|
|
|
public function setProtectIds($value)
|
|
|
|
{
|
|
|
|
$this->protectIds = $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the id that is written into the output html when rendering this form
|
|
|
|
*
|
|
|
|
* This will return the protected id, in case $protectIds is enabled.
|
|
|
|
*
|
|
|
|
* @return string The id
|
|
|
|
*/
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
if ($this->protectIds) {
|
|
|
|
return $this->getRequest()->protectId($this->getName());
|
|
|
|
}
|
|
|
|
return $this->getName();
|
|
|
|
}
|
2013-07-15 13:58:09 +02:00
|
|
|
}
|