mirror of
https://github.com/torrentpier/torrentpier-lts.git
synced 2025-03-01 15:21:02 +03:00
295 lines
5.8 KiB
PHP
295 lines
5.8 KiB
PHP
|
<?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\Json\Server;
|
||
|
|
||
|
use Zend\Json;
|
||
|
|
||
|
/**
|
||
|
* @todo Revised method regex to allow NS; however, should SMD be revised to strip PHP NS instead when attaching functions?
|
||
|
*/
|
||
|
class Request
|
||
|
{
|
||
|
/**
|
||
|
* Request ID
|
||
|
* @var mixed
|
||
|
*/
|
||
|
protected $id;
|
||
|
|
||
|
/**
|
||
|
* Flag
|
||
|
* @var bool
|
||
|
*/
|
||
|
protected $isMethodError = false;
|
||
|
|
||
|
/**
|
||
|
* Flag
|
||
|
* @var bool
|
||
|
*/
|
||
|
protected $isParseError = false;
|
||
|
|
||
|
/**
|
||
|
* Requested method
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $method;
|
||
|
|
||
|
/**
|
||
|
* Regex for method
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $methodRegex = '/^[a-z][a-z0-9\\\\_.]*$/i';
|
||
|
|
||
|
/**
|
||
|
* Request parameters
|
||
|
* @var array
|
||
|
*/
|
||
|
protected $params = array();
|
||
|
|
||
|
/**
|
||
|
* JSON-RPC version of request
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $version = '1.0';
|
||
|
|
||
|
/**
|
||
|
* Set request state
|
||
|
*
|
||
|
* @param array $options
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function setOptions(array $options)
|
||
|
{
|
||
|
$methods = get_class_methods($this);
|
||
|
foreach ($options as $key => $value) {
|
||
|
$method = 'set' . ucfirst($key);
|
||
|
if (in_array($method, $methods)) {
|
||
|
$this->$method($value);
|
||
|
} elseif ($key == 'jsonrpc') {
|
||
|
$this->setVersion($value);
|
||
|
}
|
||
|
}
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add a parameter to the request
|
||
|
*
|
||
|
* @param mixed $value
|
||
|
* @param string $key
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function addParam($value, $key = null)
|
||
|
{
|
||
|
if ((null === $key) || !is_string($key)) {
|
||
|
$index = count($this->params);
|
||
|
$this->params[$index] = $value;
|
||
|
} else {
|
||
|
$this->params[$key] = $value;
|
||
|
}
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add many params
|
||
|
*
|
||
|
* @param array $params
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function addParams(array $params)
|
||
|
{
|
||
|
foreach ($params as $key => $value) {
|
||
|
$this->addParam($value, $key);
|
||
|
}
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Overwrite params
|
||
|
*
|
||
|
* @param array $params
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function setParams(array $params)
|
||
|
{
|
||
|
$this->params = array();
|
||
|
return $this->addParams($params);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Retrieve param by index or key
|
||
|
*
|
||
|
* @param int|string $index
|
||
|
* @return mixed|null Null when not found
|
||
|
*/
|
||
|
public function getParam($index)
|
||
|
{
|
||
|
if (array_key_exists($index, $this->params)) {
|
||
|
return $this->params[$index];
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Retrieve parameters
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function getParams()
|
||
|
{
|
||
|
return $this->params;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set request method
|
||
|
*
|
||
|
* @param string $name
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function setMethod($name)
|
||
|
{
|
||
|
if (!preg_match($this->methodRegex, $name)) {
|
||
|
$this->isMethodError = true;
|
||
|
} else {
|
||
|
$this->method = $name;
|
||
|
}
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get request method name
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getMethod()
|
||
|
{
|
||
|
return $this->method;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Was a bad method provided?
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isMethodError()
|
||
|
{
|
||
|
return $this->isMethodError;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Was a malformed JSON provided?
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function isParseError()
|
||
|
{
|
||
|
return $this->isParseError;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set request identifier
|
||
|
*
|
||
|
* @param mixed $name
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function setId($name)
|
||
|
{
|
||
|
$this->id = (string) $name;
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Retrieve request identifier
|
||
|
*
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function getId()
|
||
|
{
|
||
|
return $this->id;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set JSON-RPC version
|
||
|
*
|
||
|
* @param string $version
|
||
|
* @return \Zend\Json\Server\Request
|
||
|
*/
|
||
|
public function setVersion($version)
|
||
|
{
|
||
|
if ('2.0' == $version) {
|
||
|
$this->version = '2.0';
|
||
|
} else {
|
||
|
$this->version = '1.0';
|
||
|
}
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Retrieve JSON-RPC version
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getVersion()
|
||
|
{
|
||
|
return $this->version;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set request state based on JSON
|
||
|
*
|
||
|
* @param string $json
|
||
|
* @return void
|
||
|
*/
|
||
|
public function loadJson($json)
|
||
|
{
|
||
|
try {
|
||
|
$options = Json\Json::decode($json, Json\Json::TYPE_ARRAY);
|
||
|
$this->setOptions($options);
|
||
|
} catch (\Exception $e) {
|
||
|
$this->isParseError = true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Cast request to JSON
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function toJson()
|
||
|
{
|
||
|
$jsonArray = array(
|
||
|
'method' => $this->getMethod()
|
||
|
);
|
||
|
if (null !== ($id = $this->getId())) {
|
||
|
$jsonArray['id'] = $id;
|
||
|
}
|
||
|
$params = $this->getParams();
|
||
|
if (!empty($params)) {
|
||
|
$jsonArray['params'] = $params;
|
||
|
}
|
||
|
if ('2.0' == $this->getVersion()) {
|
||
|
$jsonArray['jsonrpc'] = '2.0';
|
||
|
}
|
||
|
|
||
|
return Json\Json::encode($jsonArray);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Cast request to string (JSON)
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function __toString()
|
||
|
{
|
||
|
return $this->toJson();
|
||
|
}
|
||
|
}
|