mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-04 19:10:28 +01:00
156 lines
3.5 KiB
PHP
156 lines
3.5 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Xentral\Components\Http\Session;
|
||
|
|
||
|
use Xentral\Components\Http\Exception\InvalidArgumentException;
|
||
|
|
||
|
final class FlashMessageData
|
||
|
{
|
||
|
/** @var string FLASHTYPE_DEFAULT */
|
||
|
const FLASHTYPE_DEFAULT = 'default';
|
||
|
|
||
|
/** @var string FLASHTYPE_NOTICE */
|
||
|
const FLASHTYPE_NOTICE = 'notice';
|
||
|
|
||
|
/** @var string FLASHTYPE_SUCCESS */
|
||
|
const FLASHTYPE_SUCCESS = 'success';
|
||
|
|
||
|
/** @var string FLASHTYPE_WARNING */
|
||
|
const FLASHTYPE_WARNING = 'warning';
|
||
|
|
||
|
/** @var string FLASHTYPE_ERROR */
|
||
|
const FLASHTYPE_ERROR = 'error';
|
||
|
|
||
|
/** @var array $flashTypes */
|
||
|
public static $flashTypes = [
|
||
|
self::FLASHTYPE_DEFAULT,
|
||
|
self::FLASHTYPE_NOTICE,
|
||
|
self::FLASHTYPE_SUCCESS,
|
||
|
self::FLASHTYPE_WARNING,
|
||
|
self::FLASHTYPE_ERROR,
|
||
|
];
|
||
|
|
||
|
/**@var string $type */
|
||
|
private $type;
|
||
|
|
||
|
/** @var string $message */
|
||
|
private $message;
|
||
|
|
||
|
/** @var int $priority */
|
||
|
private $priority;
|
||
|
|
||
|
/** @var string $segmentName */
|
||
|
private $segmentName;
|
||
|
|
||
|
/**
|
||
|
* @param string $message
|
||
|
* @param string $type
|
||
|
* @param string $segmentName
|
||
|
* @param int $priority
|
||
|
*/
|
||
|
public function __construct($message, $type, $segmentName = '', $priority = 0)
|
||
|
{
|
||
|
$this->setType($type);
|
||
|
$this->message = $message;
|
||
|
$this->setSegmentName($segmentName);
|
||
|
$this->priority = (int)$priority;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Create FlashMessageData object from session array entry
|
||
|
*
|
||
|
* @param array $data required keys: 'priority', 'segment, 'type', 'message'
|
||
|
*
|
||
|
* @throws InvalidArgumentException
|
||
|
*
|
||
|
* @return FlashMessageData
|
||
|
*/
|
||
|
public static function createFromArray($data)
|
||
|
{
|
||
|
if (
|
||
|
!array_key_exists('priority', $data)
|
||
|
|| !array_key_exists('segment', $data)
|
||
|
|| !array_key_exists('type', $data)
|
||
|
|| !array_key_exists('message', $data)
|
||
|
) {
|
||
|
throw new InvalidArgumentException('Invalid array data for FlashMessageData.');
|
||
|
}
|
||
|
|
||
|
return new self($data['message'], $data['type'], $data['segment'], $data['priority']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getType()
|
||
|
{
|
||
|
return $this->type;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getMessage()
|
||
|
{
|
||
|
return $this->message;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return int
|
||
|
*/
|
||
|
public function getPriority()
|
||
|
{
|
||
|
return $this->priority;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function getSegmentName()
|
||
|
{
|
||
|
return $this->segmentName;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns array to store in the session
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function toSessionArray()
|
||
|
{
|
||
|
return [
|
||
|
'priority' => $this->getPriority(),
|
||
|
'segment' => $this->getSegmentName(),
|
||
|
'type' => $this->getType(),
|
||
|
'message' => $this->getMessage(),
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $type
|
||
|
*
|
||
|
* @throws InvalidArgumentException
|
||
|
*/
|
||
|
private function setType($type)
|
||
|
{
|
||
|
if (!in_array($type, self::$flashTypes, true)) {
|
||
|
throw new InvalidArgumentException(sprintf('Unknown message type "%s".', $type));
|
||
|
}
|
||
|
$this->type = $type;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $name
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
private function setSegmentName($name)
|
||
|
{
|
||
|
if (!preg_match('/^[a-z0-9_]*$/', $name)) {
|
||
|
throw new InvalidArgumentException(sprintf('Invalid Segment Name "%s".', $name));
|
||
|
}
|
||
|
|
||
|
$this->segmentName = $name;
|
||
|
}
|
||
|
}
|