| * +-----------------------------------------------------------------------------+ * * @category XML * @package XML_RPC2 * @author Sergio Carvalho * @copyright 2004-2006 Sergio Carvalho * @license http://www.gnu.org/copyleft/lesser.html LGPL License 2.1 * @version CVS: $Id$ * @link http://pear.php.net/package/XML_RPC2 */ // }}} // dependencies {{{ require_once 'XML/RPC2/Exception.php'; require_once 'XML/RPC2/Backend/Php/Value.php'; // }}} /** * XML_RPC request backend class. This class represents an XML_RPC request, exposing the methods * needed to encode/decode a request. * * @category XML * @package XML_RPC2 * @author Sergio Carvalho * @copyright 2004-2006 Sergio Carvalho * @license http://www.gnu.org/copyleft/lesser.html LGPL License 2.1 * @link http://pear.php.net/package/XML_RPC2 */ class XML_RPC2_Backend_Php_Request { // {{{ properties /** * Name of requested method * * @var mixed */ private $_methodName = ''; /** * request parameters * * @var array */ private $_parameters = null; /** * encoding of the request * * @var string */ private $_encoding = 'utf-8'; // }}} // {{{ setParameters() /** * parameters property setter * * @param mixed value The new parameters */ public function setParameters($value) { $this->_parameters = $value; } // }}} // {{{ addParameter() /** * parameters property appender * * @param mixed value The new parameter */ public function addParameter($value) { $this->_parameters[] = $value; } // }}} // {{{ getParameters() /** * parameters property getter * * @return mixed The current parameters */ public function getParameters() { return $this->_parameters; } // }}} // {{{ getMethodName() /** * method name getter * * @return string method name */ public function getMethodName() { return $this->_methodName; } // }}} // {{{ constructor /** * Create a new xml-rpc request with the provided methodname * * @param string Name of method targeted by this xml-rpc request * @param string encoding of the request */ function __construct($methodName, $encoding = 'utf-8') { $this->_methodName = $methodName; $this->setParameters(array()); $this->_encoding = $encoding; } // }}} // {{{ encode() /** * Encode the request for transmission. * * @return string XML-encoded request (a full XML document) */ public function encode() { $methodName = $this->_methodName; $parameters = $this->getParameters(); $result = '_encoding . '"?>' . "\n"; $result .= ""; $result .= "${methodName}"; $result .= ""; foreach($parameters as $parameter) { $result .= ""; $result .= ($parameter instanceof XML_RPC2_Backend_Php_Value) ? $parameter->encode() : XML_RPC2_Backend_Php_Value::createFromNative($parameter)->encode(); $result .= ""; } $result .= ""; $result .= ""; return $result; } // }}} // {{{ createFromDecode() /** * Decode a request from XML and construct a request object with the createFromDecoded values * * @param SimpleXMLElement The encoded XML-RPC request. * @return XML_RPC2_Backend_Php_Request The xml-rpc request, represented as an object instance */ public static function createFromDecode($simpleXML) { $methodName = (string) $simpleXML->methodName; $params = array(); foreach ($simpleXML->params->param as $param) { foreach ($param->value as $value) { $params[] = XML_RPC2_Backend_Php_Value::createFromDecode($value)->getNativeValue(); } } $result = new XML_RPC2_Backend_Php_Request($methodName); $result->setParameters($params); return $result; } // }}} } ?>