<?php
declare(strict_types=1);
/**
* Pimcore
*
* This source file is available under two different licenses:
* - GNU General Public License version 3 (GPLv3)
* - Pimcore Enterprise License (PEL)
* Full copyright and license information is available in
* LICENSE.md which is distributed with this source code.
*
* @copyright Copyright (c) Pimcore GmbH (http://www.pimcore.org)
* @license http://www.pimcore.org/license GPLv3 and PEL
*/
namespace Pimcore\Controller\Configuration;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\ConfigurationAnnotation;
/**
* Allows to set HTTP headers on the response via annotation. The annotation will
* be processed by ResponseHeaderListener which will set the HTTP headers on the
* response.
*
* See ResponseHeaderBag for documentation on the fields.
*
* @Annotation
*/
class ResponseHeader extends ConfigurationAnnotation
{
/**
* @var string
*/
protected $key;
/**
* @var string|array
*/
protected $values;
/**
* @var bool
*/
protected $replace = false;
/**
* @param array $data
*/
public function __construct(array $data)
{
// value is the default key if annotation was called without assignment
// e.g. @ResponseHeader("X-Foo") instead of @ResponseHeader(key="X-Foo")
if (isset($data['value'])) {
$data['key'] = $data['value'];
unset($data['value']);
}
parent::__construct($data);
if (empty($this->key)) {
throw new \InvalidArgumentException('The @ResponseHeaderAnnotation needs at least a key to be set');
}
}
/**
* @inheritDoc
*/
public function getAliasName(): string
{
return 'response_header';
}
/**
* @inheritDoc
*/
public function allowArray(): bool
{
return true;
}
/**
* @return string
*/
public function getKey(): string
{
return $this->key;
}
/**
* @param string $key
*/
public function setKey(string $key)
{
$this->key = $key;
}
/**
* @return array|string
*/
public function getValues()
{
return $this->values;
}
/**
* @param array|string $values
*/
public function setValues($values)
{
$this->values = $values;
}
/**
* @return bool
*/
public function getReplace(): bool
{
return $this->replace;
}
/**
* @param bool $replace
*/
public function setReplace(bool $replace)
{
$this->replace = $replace;
}
}