2013-11-20 19:10:38 +01:00
|
|
|
<?php
|
2014-07-15 13:39:22 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
2013-11-20 19:10:38 +01:00
|
|
|
|
|
|
|
namespace Icinga\Web\Widget;
|
|
|
|
|
2014-04-28 14:03:52 +02:00
|
|
|
use Zend_Log;
|
|
|
|
use Zend_Form;
|
2014-01-23 12:09:48 +01:00
|
|
|
use Icinga\User;
|
|
|
|
use Icinga\User\Message;
|
|
|
|
use Icinga\Web\Session;
|
|
|
|
use Icinga\Authentication\Manager as AuthenticationManager;
|
2013-11-20 19:10:38 +01:00
|
|
|
|
|
|
|
/**
|
2014-01-23 12:09:48 +01:00
|
|
|
* Displays a set of alert messages to the user.
|
2013-11-20 19:10:38 +01:00
|
|
|
*
|
2014-01-23 12:09:48 +01:00
|
|
|
* The messages are fetched automatically from the current AuthenticationManager,
|
|
|
|
* but this is done lazily when render() is called, to ensure that messages will
|
|
|
|
* always be displayed before they are cleared.
|
2013-11-20 19:10:38 +01:00
|
|
|
*/
|
2014-06-24 20:30:41 +02:00
|
|
|
class AlertMessageBox extends AbstractWidget
|
2014-02-21 14:07:32 +01:00
|
|
|
{
|
2013-11-26 10:35:46 +01:00
|
|
|
/**
|
|
|
|
* Remove all messages from the current user, return them and commit
|
|
|
|
* changes to the underlying session.
|
|
|
|
*
|
|
|
|
* @return array The messages
|
|
|
|
*/
|
|
|
|
protected function getAndClearMessages()
|
|
|
|
{
|
|
|
|
$messages = $this->user->getMessages();
|
|
|
|
$this->user->clearMessages();
|
2014-01-23 12:09:48 +01:00
|
|
|
Session::getSession()->write();
|
2013-11-26 10:35:46 +01:00
|
|
|
return $messages;
|
|
|
|
}
|
|
|
|
|
2013-11-20 19:10:38 +01:00
|
|
|
/**
|
|
|
|
* The displayed alert messages
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private $messages = array();
|
2014-03-06 13:08:11 +01:00
|
|
|
|
2013-11-26 10:35:46 +01:00
|
|
|
/**
|
|
|
|
* The user to fetch the messages from
|
|
|
|
*
|
|
|
|
* @var User
|
|
|
|
*/
|
|
|
|
private $user;
|
2013-11-20 19:10:38 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The available states.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private $states = array(
|
|
|
|
Zend_Log::INFO => array(
|
|
|
|
'state' => 'alert-success',
|
2014-06-24 20:30:41 +02:00
|
|
|
'icon' => 'success.png'
|
2013-11-20 19:10:38 +01:00
|
|
|
),
|
|
|
|
Zend_Log::NOTICE => array(
|
|
|
|
'state' => 'alert-info',
|
2014-06-24 20:30:41 +02:00
|
|
|
'icon' => 'info.png'
|
2013-11-20 19:10:38 +01:00
|
|
|
),
|
|
|
|
Zend_Log::WARN => array(
|
|
|
|
'state' => 'alert-warning',
|
2014-06-24 20:30:41 +02:00
|
|
|
'icon' => 'warning.png'
|
2013-11-20 19:10:38 +01:00
|
|
|
),
|
|
|
|
Zend_Log::ERR => array(
|
|
|
|
'state' => 'alert-danger',
|
2014-06-24 20:30:41 +02:00
|
|
|
'icon' => 'error.png'
|
2013-11-20 19:10:38 +01:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new AlertBox
|
|
|
|
*
|
2014-02-21 14:07:32 +01:00
|
|
|
* @param boolean showUserMessages If the current user messages should be displayed
|
|
|
|
* in this AlertMessageBox. Defaults to false
|
2013-11-20 19:10:38 +01:00
|
|
|
*/
|
2014-02-21 14:07:32 +01:00
|
|
|
public function __construct($showUserMessages = false)
|
|
|
|
{
|
2014-01-23 12:09:48 +01:00
|
|
|
if ($showUserMessages) {
|
2013-11-26 10:35:46 +01:00
|
|
|
$this->user = AuthenticationManager::getInstance()->getUser();
|
2013-11-20 19:10:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a new error
|
|
|
|
*
|
|
|
|
* @param $error
|
|
|
|
*/
|
|
|
|
public function addError($error)
|
|
|
|
{
|
|
|
|
$this->messages[] = new Message($error, Zend_Log::ERR);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add the error messages of the given Zend_Form
|
|
|
|
*/
|
|
|
|
public function addForm(Zend_Form $form)
|
|
|
|
{
|
|
|
|
foreach ($form->getErrorMessages() as $error) {
|
|
|
|
$this->addError($error);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output the HTML of the AlertBox
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-02-21 14:07:32 +01:00
|
|
|
public function render(Zend_View_Abstract $view = null)
|
|
|
|
{
|
2013-11-20 19:10:38 +01:00
|
|
|
$html = '';
|
2013-11-26 10:35:46 +01:00
|
|
|
if (isset($this->user)) {
|
2014-02-21 14:07:32 +01:00
|
|
|
$this->messages = array_merge($this->messages, $this->getAndClearMessages());
|
2013-11-26 10:35:46 +01:00
|
|
|
}
|
2013-11-20 19:10:38 +01:00
|
|
|
foreach ($this->messages as $message) {
|
|
|
|
$level = $message->getLevel();
|
|
|
|
if (!array_key_exists($level, $this->states)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$alert = $this->states[$level];
|
|
|
|
$html .= '<div class="alert ' . $alert['state']. '">' .
|
2014-06-24 20:30:41 +02:00
|
|
|
$this->view()->icon($alert['icon']) .
|
2014-07-23 12:28:04 +02:00
|
|
|
'<strong>' . htmlspecialchars($message->getMessage()) . '</strong>' .
|
2013-11-20 19:10:38 +01:00
|
|
|
'</div>';
|
|
|
|
}
|
|
|
|
return $html;
|
|
|
|
}
|
2013-11-26 10:35:46 +01:00
|
|
|
}
|