. /** * Moodle XML-RPC library * * @package webservice_xmlrpc * @copyright 2009 Jerome Mouneyrac * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require_once 'Zend/XmlRpc/Client.php'; /** * Moodle XML-RPC client * * It has been implemented for unit testing purpose (all protocols have similar client) * * @package webservice_xmlrpc * @copyright 2010 Jerome Mouneyrac * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class webservice_xmlrpc_client extends Zend_XmlRpc_Client { /** @var string server url e.g. https://yyyyy.com/server.php */ private $serverurl; /** * Constructor * * @param string $serverurl a Moodle URL * @param string $token the token used to do the web service call */ public function __construct($serverurl, $token) { global $CFG; $this->serverurl = $serverurl; $serverurl = $serverurl . '?wstoken=' . $token; parent::__construct($serverurl); if (!empty($CFG->proxyhost) && !is_proxybypass($serverurl)) { $config = array( 'adapter' => 'Zend_Http_Client_Adapter_Proxy', 'proxy_host' => $CFG->proxyhost, 'proxy_user' => !empty($CFG->proxyuser) ? $CFG->proxyuser : null, 'proxy_pass' => !empty($CFG->proxypassword) ? $CFG->proxypassword : null ); if (!empty($CFG->proxyport)) { $config['proxy_port'] = $CFG->proxyport; } $this->getHttpClient()->setConfig($config); } } /** * Set the token used to do the XML-RPC call * * @param string $token the token used to do the web service call */ public function set_token($token) { $this->_serverAddress = $this->serverurl . '?wstoken=' . $token; } /** * Execute client WS request with token authentication * * @param string $functionname the function name * @param array $params the parameters of the function * @return mixed */ public function call($functionname, $params=array()) { global $DB, $CFG; //zend expects 0 based array with numeric indexes $params = array_values($params); //traditional Zend soap client call (integrating the token into the URL) $result = parent::call($functionname, $params); return $result; } }