<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
namespace Zend\Server;
use Countable;
use Iterator;
/**
* Server methods metadata
*/
class Definition implements Countable, Iterator
{
/**
* @var array Array of \Zend\Server\Method\Definition objects
*/
protected $methods = array();
/**
* @var bool Whether or not overwriting existing methods is allowed
*/
protected $overwriteExistingMethods = false;
/**
* Constructor
*
* @param null|array $methods
*/
public function __construct($methods = null)
{
if (is_array($methods)) {
$this->setMethods($methods);
}
}
/**
* Set flag indicating whether or not overwriting existing methods is allowed
*
* @param mixed $flag
* @return \Zend\Server\Definition
*/
public function setOverwriteExistingMethods($flag)
{
$this->overwriteExistingMethods = (bool) $flag;
return $this;
}
/**
* Add method to definition
*
* @param array|\Zend\Server\Method\Definition $method
* @param null|string $name
* @return \Zend\Server\Definition
* @throws \Zend\Server\Exception\InvalidArgumentException if duplicate or invalid method provided
*/
public function addMethod($method, $name = null)
{
if (is_array($method)) {
$method = new Method\Definition($method);
} elseif (!$method instanceof Method\Definition) {
throw new Exception\InvalidArgumentException('Invalid method provided');
}
if (is_numeric($name)) {
$name = null;
}
if (null !== $name) {
$method->setName($name);
} else {
$name = $method->getName();
}
if (null === $name) {
throw new Exception\InvalidArgumentException('No method name provided');
}
if (!$this->overwriteExistingMethods && array_key_exists($name, $this->methods)) {
throw new Exception\InvalidArgumentException(sprintf('Method by name of "%s" already exists', $name));
}
$this->methods[$name] = $method;
return $this;
}
/**
* Add multiple methods
*
* @param array $methods Array of \Zend\Server\Method\Definition objects or arrays
* @return \Zend\Server\Definition
*/
public function addMethods(array $methods)
{
foreach ($methods as $key => $method) {
$this->addMethod($method, $key);
}
return $this;
}
/**
* Set all methods at once (overwrite)
*
* @param array $methods Array of \Zend\Server\Method\Definition objects or arrays
* @return \Zend\Server\Definition
*/
public function setMethods(array $methods)
{
$this->clearMethods();
$this->addMethods($methods);
return $this;
}
/**
* Does the definition have the given method?
*
* @param string $method
* @return bool
*/
public function hasMethod($method)
{
return array_key_exists($method, $this->methods);
}
/**
* Get a given method definition
*
* @param string $method
* @return null|\Zend\Server\Method\Definition
*/
public function getMethod($method)
{
if ($this->hasMethod($method)) {
return $this->methods[$method];
}
return false;
}
/**
* Get all method definitions
*
* @return array Array of \Zend\Server\Method\Definition objects
*/
public function getMethods()
{
return $this->methods;
}
/**
* Remove a method definition
*
* @param string $method
* @return \Zend\Server\Definition
*/
public function removeMethod($method)
{
if ($this->hasMethod($method)) {
unset($this->methods[$method]);
}
return $this;
}
/**
* Clear all method definitions
*
* @return \Zend\Server\Definition
*/
public function clearMethods()
{
$this->methods = array();
return $this;
}
/**
* Cast definition to an array
*
* @return array
*/
public function toArray()
{
$methods = array();
foreach ($this->getMethods() as $key => $method) {
$methods[$key] = $method->toArray();
}
return $methods;
}
/**
* Countable: count of methods
*
* @return int
*/
public function count()
{
return count($this->methods);
}
/**
* Iterator: current item
*
* @return Method\Definition
*/
public function current()
{
return current($this->methods);
}
/**
* Iterator: current item key
*
* @return int|string
*/
public function key()
{
return key($this->methods);
}
/**
* Iterator: advance to next method
*
* @return Method\Definition
*/
public function next()
{
return next($this->methods);
}
/**
* Iterator: return to first method
*
* @return void
*/
public function rewind()
{
reset($this->methods);
}
/**
* Iterator: is the current index valid?
*
* @return bool
*/
public function valid()
{
return (bool) $this->current();
}
}
# |
Change |
User |
Description |
Committed |
|
#1
|
18334 |
Liz Lam |
initial add of jambox |
|
|