1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
<?php
/**
* PHP OpenCloud library.
*
* @copyright 2014 Rackspace Hosting, Inc. See LICENSE for information.
* @license https://www.apache.org/licenses/LICENSE-2.0
* @author Glen Campbell <glen.campbell@rackspace.com>
* @author Jamie Hannaford <jamie.hannaford@rackspace.com>
*/
namespace OpenCloud\Common;
/**
* The Metadata class represents either Server or Image metadata
*/
class Metadata extends Base implements \Countable
{
/**
* @var array Internal data store.
*/
protected $metadata = array();
/**
* This setter overrides the base one, since the metadata key can be
* anything
*
* @param string $property
* @param string $value
* @return void
*/
public function __set($property, $value)
{
return $this->setProperty($property, $value);
}
public function __get($key)
{
return $this->getProperty($key);
}
public function propertyExists($property, $allowRetry = true)
{
return isset($this->metadata[strtolower($property)])
|| parent::propertyExists($property, $allowRetry);
}
public function getProperty($property)
{
return $this->propertyExists($property) ? $this->metadata[strtolower($property)] : null;
}
public function setProperty($property, $value)
{
$this->metadata[strtolower($property)] = $value;
}
public function __isset($property)
{
return $this->propertyExists($property);
}
/**
* Returns the list of keys defined
*
* @return array
*/
public function keylist()
{
return $this->metadata;
}
/**
* Sets metadata values from an array, with optional prefix
*
* If $prefix is provided, then only array keys that match the prefix
* are set as metadata values, and $prefix is stripped from the key name.
*
* @param array $values an array of key/value pairs to set
* @param string $prefix if provided, a prefix that is used to identify
* metadata values. For example, you can set values from headers
* for a Container by using $prefix='X-Container-Meta-'.
* @return void
*/
public function setArray($values, $prefix = null)
{
if (empty($values)) {
return false;
}
foreach ($values as $key => $value) {
if ($prefix && strpos($key, $prefix) === 0) {
$key = substr($key, strlen($prefix));
}
$this->setProperty($key, $value);
}
}
public function toArray()
{
return $this->metadata;
}
public function count()
{
return count($this->metadata);
}
}
|