icingaweb2/library/Icinga/Web/Cookie.php

266 lines
5.8 KiB
PHP
Raw Normal View History

<?php
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
namespace Icinga\Web;
2015-11-27 15:40:00 +01:00
use Icinga\Application\Config;
use Icinga\Application\Icinga;
use InvalidArgumentException;
/**
2015-11-27 15:40:00 +01:00
* A HTTP cookie
*/
class Cookie
{
/**
2015-11-27 15:40:00 +01:00
* Domain of the cookie
*
* @var string
*/
protected $domain;
/**
* The timestamp at which the cookie expires
*
* @var int
*/
protected $expire;
/**
* Whether to protect the cookie against client side script code attempts to read the cookie
*
* Defaults to true.
*
* @var bool
*/
protected $httpOnly = true;
/**
* Name of the cookie
*
* @var string
*/
protected $name;
/**
* The path on the web server where the cookie is available
*
* Defaults to the base URL.
*
* @var string
*/
protected $path;
/**
* Whether to send the cookie only over a secure connection
*
* Defaults to auto-detection so that if the current request was sent over a secure connection the secure flag will
* be set to true.
*
* @var bool
*/
2015-11-27 15:40:00 +01:00
protected $secure;
/**
2015-11-27 15:40:00 +01:00
* Value of the cookie
*
2015-11-27 15:40:00 +01:00
* @var string
*/
2015-11-27 15:40:00 +01:00
protected $value;
/**
* Create a new cookie
*
2015-11-27 15:40:00 +01:00
* @param string $name
* @param string $value
*/
2015-11-27 15:40:00 +01:00
public function __construct($name, $value = null)
{
2015-11-27 15:40:00 +01:00
if (preg_match("/[=,; \t\r\n\013\014]/", $name)) {
throw new InvalidArgumentException(sprintf(
'Cookie name can\'t contain these characters: =,; \t\r\n\013\014 (%s)',
$name
));
}
if (empty($name)) {
throw new InvalidArgumentException('The cookie name can\'t be empty');
}
$this->name = $name;
$this->value = $value;
}
/**
2015-11-27 15:40:00 +01:00
* Get the domain of the cookie
*
2015-11-27 15:40:00 +01:00
* @return string
*/
2015-11-27 15:40:00 +01:00
public function getDomain()
{
if ($this->domain === null) {
$this->domain = Config::app()->get('cookie', 'domain');
}
2015-11-27 15:40:00 +01:00
return $this->domain;
}
2015-11-27 15:40:00 +01:00
/**
* Set the domain of the cookie
*
* @param string $domain
*
* @return $this
*/
public function setDomain($domain)
{
$this->domain = $domain;
return $this;
}
2015-11-27 15:40:00 +01:00
/**
* Get the timestamp at which the cookie expires
*
* @return int
*/
public function getExpire()
{
return $this->expire;
}
2015-11-27 15:40:00 +01:00
/**
* Set the timestamp at which the cookie expires
*
* @param int $expire
*
* @return $this
*/
public function setExpire($expire)
{
$this->expire = $expire;
return $this;
}
2015-11-27 15:40:00 +01:00
/**
* Get whether to protect the cookie against client side script code attempts to read the cookie
*
* @return bool
*/
public function isHttpOnly()
{
return $this->httpOnly;
}
/**
2015-11-27 15:40:00 +01:00
* Set whether to protect the cookie against client side script code attempts to read the cookie
*
* @param bool $httpOnly
*
* @return $this
*/
2015-11-27 15:40:00 +01:00
public function setHttpOnly($httpOnly)
{
2015-11-27 15:40:00 +01:00
$this->httpOnly = $httpOnly;
return $this;
}
2015-11-27 15:40:00 +01:00
/**
* Get the name of the cookie
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
2015-11-27 15:40:00 +01:00
* Get the path on the web server where the cookie is available
*
* If the path has not been set either via {@link setPath()} or via config, the base URL will be returned.
*
* @return string
*/
2015-11-27 15:40:00 +01:00
public function getPath()
{
2015-11-27 15:40:00 +01:00
if ($this->path === null) {
$path = Config::app()->get('cookie', 'path');
if ($path === null) {
// The following call could be used as default for ConfigObject::get(), but we prevent unnecessary
// function calls here, if the path is set in the config
$path = Icinga::app()->getRequest()->getBaseUrl() . '/'; // Zend has rtrim($baseUrl, '/')
2015-11-27 15:40:00 +01:00
}
$this->path = $path;
}
2015-11-27 15:40:00 +01:00
return $this->path;
}
/**
* Set the path on the web server where the cookie is available
*
* @param string $path
*
* @return $this
*/
public function setPath($path)
{
$this->path = $path;
return $this;
}
/**
* Get whether to send the cookie only over a secure connection
*
* If the secure flag has not been set either via {@link setSecure()} or via config and if the current request was
* sent over a secure connection, true will be returned.
*
* @return bool
*/
public function isSecure()
{
if ($this->secure === null) {
$secure = Config::app()->get('cookie', 'secure');
if ($secure === null) {
// The following call could be used as default for ConfigObject::get(), but we prevent unnecessary
// function calls here, if the secure flag is set in the config
$secure = Icinga::app()->getRequest()->isSecure();
}
$this->secure = $secure;
2015-11-27 15:40:00 +01:00
}
return $this->secure;
}
/**
* Set whether to send the cookie only over a secure connection
*
* @param bool $secure
*
* @return $this
*/
public function setSecure($secure)
{
$this->secure = $secure;
return $this;
}
/**
* Get the value of the cookie
*
* @return string
*/
public function getValue()
{
return $this->value;
}
/**
* Set the value of the cookie
*
* @param string $value
*
* @return $this
*/
public function setValue($value)
{
$this->value = $value;
return $this;
}
}