<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4 foldmethod=marker: */
// LICENSE AGREEMENT. If folded, press za here to unfold and read license {{{
/**
* +-----------------------------------------------------------------------------+
* | Copyright (c) 2004-2006 Sergio Goncalves Carvalho |
* +-----------------------------------------------------------------------------+
* | This file is part of XML_RPC2. |
* | |
* | XML_RPC2 is free software; you can redistribute it and/or modify |
* | it under the terms of the GNU Lesser General Public License as published by |
* | the Free Software Foundation; either version 2.1 of the License, or |
* | (at your option) any later version. |
* | |
* | XML_RPC2 is distributed in the hope that it will be useful, |
* | but WITHOUT ANY WARRANTY; without even the implied warranty of |
* | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
* | GNU Lesser General Public License for more details. |
* | |
* | You should have received a copy of the GNU Lesser General Public License |
* | along with XML_RPC2; if not, write to the Free Software |
* | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA |
* | 02111-1307 USA |
* +-----------------------------------------------------------------------------+
* | Author: Sergio Carvalho <hide@address.com> |
* +-----------------------------------------------------------------------------+
*
* @category XML
* @package XML_RPC2
* @author Sergio Carvalho <hide@address.com>
* @copyright 2004-2006 Sergio Carvalho
* @license http://www.gnu.org/copyleft/lesser.html LGPL License 2.1
* @version CVS: $Id: Client.php,v 1.10 2007/07/30 08:47:11 sergiosgc Exp $
* @link http://pear.php.net/package/XML_RPC2
*/
// }}}
// dependencies {{{
require_once 'XML/RPC2/Exception.php';
require_once 'XML/RPC2/Util/HTTPRequest.php';
require_once 'XML/RPC2/Value.php';
require_once 'XML/RPC2/Client.php';
require_once 'XML/RPC2/Backend/Php/Request.php';
require_once 'XML/RPC2/Backend/Php/Response.php';
// }}}
/**
* XML_RPC client backend class. This is the default, all-php XML_RPC client backend.
*
* This backend does not require the xmlrpc extension to be compiled in. It implements
* XML_RPC based on the always present DOM and SimpleXML PHP5 extensions.
*
* @category XML
* @package XML_RPC2
* @author Sergio Carvalho <hide@address.com>
* @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_Client extends XML_RPC2_Client
{
// {{{ constructor
/**
* Construct a new XML_RPC2_Client PHP Backend.
*
* To create a new XML_RPC2_Client, a URI must be provided (e.g. http://xmlrpc.example.com/1.0/).
* Optionally, some options may be set
*
* @param string URI for the XML-RPC server
* @param array (optional) Associative array of options
*/
public function __construct($uri, $options = array())
{
parent::__construct($uri, $options);
}
// }}}
// {{{ remoteCall___()
/**
* remoteCall executes the XML-RPC call, and returns the result
*
* NB : The '___' at the end of the method name is to avoid collisions with
* XMLRPC __call()
*
* @param string Method name
* @param array Parameters
*/
public function remoteCall___($methodName, $parameters)
{
$request = new XML_RPC2_Backend_Php_Request($this->prefix . $methodName, $this->encoding);
$request->setParameters($parameters);
$request = $request->encode();
$uri = $this->uri;
$options = array(
'encoding' => $this->encoding,
'proxy' => $this->proxy,
'sslverify' => $this->sslverify
);
$httpRequest = new XML_RPC2_Util_HTTPRequest($uri, $options);
$httpRequest->setPostData($request);
$httpRequest->sendRequest();
$body = $httpRequest->getBody();
if ($this->debug) {
$this->displayDebugInformations___($request, $body);
}
try {
$result = XML_RPC2_Backend_Php_Response::decode(simplexml_load_string($body));
} catch (XML_RPC2_Exception $e) {
if ($this->debug) {
if (get_class($e)=='XML_RPC2_FaultException') {
print "XML_RPC2_FaultException #" . $e->getFaultCode() . " : " . $e->getMessage();
} else {
print get_class($e) . " : " . $e->getMessage();
}
}
throw $e;
}
if ($this->debug) {
$this->displayDebugInformations2___($result);
}
return $result;
}
// }}}
}
?>