class NamespacedAttributeBag in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/symfony/http-foundation/Session/Attribute/NamespacedAttributeBag.php \Symfony\Component\HttpFoundation\Session\Attribute\NamespacedAttributeBag
This class provides structured storage of session attributes using a name spacing character in the key.
@author Drak <drak@zikula.org>
Hierarchy
- class \Symfony\Component\HttpFoundation\Session\Attribute\AttributeBag implements \Symfony\Component\HttpFoundation\Session\Attribute\IteratorAggregate, \Symfony\Component\HttpFoundation\Session\Attribute\Countable, AttributeBagInterface
- class \Symfony\Component\HttpFoundation\Session\Attribute\NamespacedAttributeBag
Expanded class hierarchy of NamespacedAttributeBag
1 file declares its use of NamespacedAttributeBag
- NamespacedAttributeBagTest.php in vendor/
symfony/ http-foundation/ Tests/ Session/ Attribute/ NamespacedAttributeBagTest.php
File
- vendor/
symfony/ http-foundation/ Session/ Attribute/ NamespacedAttributeBag.php, line 20
Namespace
Symfony\Component\HttpFoundation\Session\AttributeView source
class NamespacedAttributeBag extends AttributeBag {
/**
* Namespace character.
*
* @var string
*/
private $namespaceCharacter;
/**
* Constructor.
*
* @param string $storageKey Session storage key.
* @param string $namespaceCharacter Namespace character to use in keys.
*/
public function __construct($storageKey = '_sf2_attributes', $namespaceCharacter = '/') {
$this->namespaceCharacter = $namespaceCharacter;
parent::__construct($storageKey);
}
/**
* {@inheritdoc}
*/
public function has($name) {
// reference mismatch: if fixed, re-introduced in array_key_exists; keep as it is
$attributes = $this
->resolveAttributePath($name);
$name = $this
->resolveKey($name);
if (null === $attributes) {
return false;
}
return array_key_exists($name, $attributes);
}
/**
* {@inheritdoc}
*/
public function get($name, $default = null) {
// reference mismatch: if fixed, re-introduced in array_key_exists; keep as it is
$attributes = $this
->resolveAttributePath($name);
$name = $this
->resolveKey($name);
if (null === $attributes) {
return $default;
}
return array_key_exists($name, $attributes) ? $attributes[$name] : $default;
}
/**
* {@inheritdoc}
*/
public function set($name, $value) {
$attributes =& $this
->resolveAttributePath($name, true);
$name = $this
->resolveKey($name);
$attributes[$name] = $value;
}
/**
* {@inheritdoc}
*/
public function remove($name) {
$retval = null;
$attributes =& $this
->resolveAttributePath($name);
$name = $this
->resolveKey($name);
if (null !== $attributes && array_key_exists($name, $attributes)) {
$retval = $attributes[$name];
unset($attributes[$name]);
}
return $retval;
}
/**
* Resolves a path in attributes property and returns it as a reference.
*
* This method allows structured namespacing of session attributes.
*
* @param string $name Key name
* @param bool $writeContext Write context, default false
*
* @return array
*/
protected function &resolveAttributePath($name, $writeContext = false) {
$array =& $this->attributes;
$name = strpos($name, $this->namespaceCharacter) === 0 ? substr($name, 1) : $name;
// Check if there is anything to do, else return
if (!$name) {
return $array;
}
$parts = explode($this->namespaceCharacter, $name);
if (count($parts) < 2) {
if (!$writeContext) {
return $array;
}
$array[$parts[0]] = array();
return $array;
}
unset($parts[count($parts) - 1]);
foreach ($parts as $part) {
if (null !== $array && !array_key_exists($part, $array)) {
$array[$part] = $writeContext ? array() : null;
}
$array =& $array[$part];
}
return $array;
}
/**
* Resolves the key from the name.
*
* This is the last part in a dot separated string.
*
* @param string $name
*
* @return string
*/
protected function resolveKey($name) {
if (false !== ($pos = strrpos($name, $this->namespaceCharacter))) {
$name = substr($name, $pos + 1);
}
return $name;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AttributeBag:: |
protected | property | ||
AttributeBag:: |
private | property | ||
AttributeBag:: |
private | property | ||
AttributeBag:: |
public | function |
Returns attributes. Overrides AttributeBagInterface:: |
|
AttributeBag:: |
public | function |
Clears out data from bag. Overrides SessionBagInterface:: |
|
AttributeBag:: |
public | function | Returns the number of attributes. | |
AttributeBag:: |
public | function | Returns an iterator for attributes. | |
AttributeBag:: |
public | function |
Gets this bag's name. Overrides SessionBagInterface:: |
|
AttributeBag:: |
public | function |
Gets the storage key for this bag. Overrides SessionBagInterface:: |
|
AttributeBag:: |
public | function |
Initializes the Bag. Overrides SessionBagInterface:: |
|
AttributeBag:: |
public | function |
Sets attributes. Overrides AttributeBagInterface:: |
|
AttributeBag:: |
public | function | ||
NamespacedAttributeBag:: |
private | property | Namespace character. | |
NamespacedAttributeBag:: |
public | function |
Returns an attribute. Overrides AttributeBag:: |
|
NamespacedAttributeBag:: |
public | function |
Checks if an attribute is defined. Overrides AttributeBag:: |
|
NamespacedAttributeBag:: |
public | function |
Removes an attribute. Overrides AttributeBag:: |
|
NamespacedAttributeBag:: |
protected | function | Resolves a path in attributes property and returns it as a reference. | |
NamespacedAttributeBag:: |
protected | function | Resolves the key from the name. | |
NamespacedAttributeBag:: |
public | function |
Sets an attribute. Overrides AttributeBag:: |
|
NamespacedAttributeBag:: |
public | function |
Constructor. Overrides AttributeBag:: |