3 * XMLRPC server acting as proxy for requests to other servers
4 * (useful e.g. for ajax-originated calls that can only connect back to
5 * the originating server).
7 * @author Gaetano Giunta
8 * @copyright (C) 2006-2014 G. Giunta
9 * @license code licensed under the BSD License: http://phpxmlrpc.sourceforge.net/license.txt
11 include_once __DIR__ . "/../../vendor/autoload.php";
13 include_once __DIR__ . "/../../lib/xmlrpc.inc";
14 include_once __DIR__ . "/../../lib/xmlrpcs.inc";
17 * Forward an xmlrpc request to another server, and return to client the response received.
19 * @param xmlrpcmsg $m (see method docs below for a description of the expected parameters)
23 function forward_request($m)
27 $url = php_xmlrpc_decode($m->getParam(0));
28 $c = new xmlrpc_client($url);
29 if ($m->getNumParams() > 3) {
30 // we have to set some options onto the client.
31 // Note that if we do not untaint the received values, warnings might be generated...
32 $options = php_xmlrpc_decode($m->getParam(3));
33 foreach ($options as $key => $val) {
39 case 'RequestCompression':
40 $c->setRequestCompression($val);
43 $c->setSSLVerifyHost($val);
46 $c->setSSLVerifyPeer($val);
49 $timeout = (integer)$val;
55 // build call for remote server
56 /// @todo find a weay to forward client info (such as IP) to server, either
57 /// - as xml comments in the payload, or
58 /// - using std http header conventions, such as X-forwarded-for...
59 $method = php_xmlrpc_decode($m->getParam(1));
60 $pars = $m->getParam(2);
61 $m = new xmlrpcmsg($method);
62 for ($i = 0; $i < $pars->arraySize(); $i++) {
63 $m->addParam($pars->arraymem($i));
66 // add debug info into response we give back to caller
67 xmlrpc_debugmsg("Sending to server $url the payload: " . $m->serialize());
69 return $c->send($m, $timeout);
73 $server = new xmlrpc_server(
75 'xmlrpcproxy.call' => array(
76 'function' => 'forward_request',
78 array('mixed', 'string', 'string', 'array'),
79 array('mixed', 'string', 'string', 'array', 'stuct'),
81 'docstring' => 'forwards xmlrpc calls to remote servers. Returns remote method\'s response. Accepts params: remote server url (might include basic auth credentials), method name, array of params, and (optionally) a struct containing call options',