MDL-30994 webservice API, check and update DocBlock

This commit is contained in:
Jerome Mouneyrac 2012-02-21 11:24:32 +08:00
parent 5bbf3cb72b
commit a0a07014c2
38 changed files with 1122 additions and 506 deletions

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,12 +14,13 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Manual plugin external functions and service definitions. * Manual plugin external functions and service definitions.
* *
* @package enrol * @package enrol_manual
* @subpackage manual * @category webservice
* @author 2011 Jerome Mouneyrac * @copyright 2011 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,12 +14,13 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Core external functions and service definitions. * Core external functions and service definitions.
* *
* @package core * @package core_webservice
* @subpackage webservice * @category webservice
* @copyright 2009 Petr Skoda (http://skodak.org) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,4 +1,28 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* AMF server capabilities.
*
* @package webservice_amf
* @category access
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$capabilities = array( $capabilities = array(

View File

@ -1,50 +1,67 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Moodle - Modular Object-Oriented Dynamic Learning Environment * Introspection for amf
* http://moodle.org
* Copyright (C) 1999 onwards Martin Dougiamas http://dougiamas.com
* *
* This program is free software: you can redistribute it and/or modify * Figures out where all the services are and
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* @package moodle
* @author Penny Leach <penny@liip.ch>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL
* @copyright (C) 1999 onwards Martin Dougiamas http://dougiamas.com
*
* Introspection for amf - figures out where all the services are and
* returns a list of their available methods. * returns a list of their available methods.
* Requires $CFG->amf_introspection = true for security. * Requires $CFG->amf_introspection = true for security.
*
* @package webservice_amf
* @copyright 2009 Penny Leach <penny@liip.ch>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
/** /**
* Provides a function to get details of methods available on another class. * Provides a function to get details of methods available on another class.
* @author HP
* *
* @package webservice_amf
* @copyright HP
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class MethodDescriptor { class MethodDescriptor {
/** @var array The details of the methods*/
private $methods; private $methods;
/** @var array Classes to introspect
* Note: setup() code has been written to introspect multiple classes.
* However the setup() only deal with $classnametointrospect.
*/
private $classes; private $classes;
/** @var string Class to introspect */
static public $classnametointrospect; static public $classnametointrospect;
/**
* constructor
*/
public function __construct() { public function __construct() {
$this->setup(); $this->setup();
} }
/**
* Generate the class method descriptions.
* These description are assigned in the class properties
*
* @return void
*/
private function setup() { private function setup() {
global $CFG; global $CFG;
if (!empty($this->nothing)) { if (!empty($this->nothing)) {
@ -53,11 +70,13 @@ class MethodDescriptor {
if (!empty($this->classes)) { // we've already done it successfully. if (!empty($this->classes)) { // we've already done it successfully.
return; return;
} }
//TODO MDL-31148 most likely can be removed, but check if there is any interest, never know...
/*if (empty($CFG->amf_introspection)) { /*if (empty($CFG->amf_introspection)) {
throw new Exception(get_string('amfintrospectiondisabled', 'local')); throw new Exception(get_string('amfintrospectiondisabled', 'local'));
}*/ }*/
//just one class here, possibility for expansion in future //TODO MDL-31148 just one class here, possibility for expansion in future
$classes = array(MethodDescriptor::$classnametointrospect); $classes = array(MethodDescriptor::$classnametointrospect);
$hugestructure = array(); $hugestructure = array();
@ -90,16 +109,34 @@ class MethodDescriptor {
} }
} }
/**
* Get the method descriptions
*
* @return array
*/
public function getMethods() { public function getMethods() {
$this->setup(); $this->setup();
return $this->methods; return $this->methods;
} }
/**
* Get the class descriptions
*
* @return array
*/
public function getClasses() { public function getClasses() {
$this->setup(); $this->setup();
return $this->classes; return $this->classes;
} }
/**
* As the class does not extend another class and as this function does nothing
* except return true,
* I guess this is just a function that was a copy/paste and it has been forgotten.
* TODO MDL-31148 this function is not called and most likely can be removed
*
* @return true
*/
public function isConnected() { public function isConnected() {
return true; return true;
} }

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,13 +14,16 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Strings for component 'webservice_amf', language 'en', branch 'MOODLE_20_STABLE' * Strings for component 'webservice_amf', language 'en', branch 'MOODLE_20_STABLE'
* *
* @package webservice_amf * @package webservice_amf
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @category string
* @copyright 2010 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
$string['amf:use'] = 'Use AMF protocol'; $string['amf:use'] = 'Use AMF protocol';
$string['pluginname'] = 'AMF protocol'; $string['pluginname'] = 'AMF protocol';

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,24 +14,33 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* AMF web service implementation classes and methods. * AMF web service implementation classes and methods.
* *
* @package webservice * @package webservice_amf
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
require_once("$CFG->dirroot/webservice/lib.php"); require_once("$CFG->dirroot/webservice/lib.php");
require_once( "{$CFG->dirroot}/webservice/amf/introspector.php"); require_once( "{$CFG->dirroot}/webservice/amf/introspector.php");
require_once 'Zend/Amf/Server.php'; require_once 'Zend/Amf/Server.php';
/** /**
* Exception indicating an invalid return value from a function. * Exception indicating an invalid return value from a function.
*
* Used when an externallib function does not return values of the expected structure. * Used when an externallib function does not return values of the expected structure.
*
* @package webservice_amf
* @copyright 2010 Jamie Pratt
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class invalid_return_value_exception extends moodle_exception { class invalid_return_value_exception extends moodle_exception {
/** /**
* Constructor * Constructor
*
* @param string $debuginfo some detailed information * @param string $debuginfo some detailed information
*/ */
function __construct($debuginfo=null) { function __construct($debuginfo=null) {
@ -42,17 +50,26 @@ class invalid_return_value_exception extends moodle_exception {
/** /**
* AMF service server implementation. * AMF service server implementation.
* @author Petr Skoda (skodak) *
* @package webservice_amf
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_amf_server extends webservice_zend_server { class webservice_amf_server extends webservice_zend_server {
/** /**
* Contructor * Contructor
*
* @param integer $authmethod authentication method - one of WEBSERVICE_AUTHMETHOD_* * @param integer $authmethod authentication method - one of WEBSERVICE_AUTHMETHOD_*
*/ */
public function __construct($authmethod) { public function __construct($authmethod) {
parent::__construct($authmethod, 'Moodle_Amf_Server'); parent::__construct($authmethod, 'Moodle_Amf_Server');
$this->wsname = 'amf'; $this->wsname = 'amf';
} }
/**
* Load virtual class needed for Zend api
*/
protected function init_service_class(){ protected function init_service_class(){
parent::init_service_class(); parent::init_service_class();
//allow access to data about methods available. //allow access to data about methods available.
@ -60,6 +77,13 @@ class webservice_amf_server extends webservice_zend_server {
MethodDescriptor::$classnametointrospect = $this->service_class; MethodDescriptor::$classnametointrospect = $this->service_class;
} }
/**
* Get the generated web service function code.
*
* @param stdClass $function contains function name and class name
* @param array $params all the function parameters
* @return string the generate web service function code
*/
protected function service_class_method_body($function, $params){ protected function service_class_method_body($function, $params){
//cast the param from object to array (validate_parameters except array only) //cast the param from object to array (validate_parameters except array only)
$castingcode = ''; $castingcode = '';
@ -79,15 +103,16 @@ class webservice_amf_server extends webservice_zend_server {
return $castingcode . return $castingcode .
' return webservice_amf_server::validate_and_cast_values('.$callforreturnvaluedesc.', '.$externallibcall.');'; ' return webservice_amf_server::validate_and_cast_values('.$callforreturnvaluedesc.', '.$externallibcall.');';
} }
/** /**
* Validates submitted value, comparing it to a description. If anything is incorrect * Validates submitted value, comparing it to a description. If anything is incorrect
* invalid_return_value_exception is thrown. Also casts the values to the type specified in * invalid_return_value_exception is thrown. Also casts the values to the type specified in
* the description. * the description.
* @param mixed $description description of parameters or null if no return value *
* @param external_description $description description of parameters or null if no return value
* @param mixed $value the actual values * @param mixed $value the actual values
* @param boolean $singleasobject specifies whether a external_single_structure should be cast to a stdClass object * @return mixed params with added defaults for optional items
* should always be false for use in validating parameters in externallib functions. * @throws invalid_return_value_exception
* @return mixed params with added defaults for optional items, invalid_parameters_exception thrown if any problem found
*/ */
public static function validate_and_cast_values($description, $value) { public static function validate_and_cast_values($description, $value) {
if (is_null($description)){ if (is_null($description)){
@ -126,10 +151,7 @@ class webservice_amf_server extends webservice_zend_server {
} }
unset($value[$key]); unset($value[$key]);
} }
/* Was decided that extra keys should just be ignored and not returned.
* if (!empty($value)) {
throw new invalid_return_value_exception('Unexpected keys detected in parameter array.');
}*/
return (object)$result; return (object)$result;
} else if ($description instanceof external_multiple_structure) { } else if ($description instanceof external_multiple_structure) {
@ -149,23 +171,28 @@ class webservice_amf_server extends webservice_zend_server {
/** /**
* Set up zend service class * Set up zend service class
* @return void
*/ */
protected function init_zend_server() { protected function init_zend_server() {
parent::init_zend_server(); parent::init_zend_server();
$this->zend_server->setProduction(false); //set to false for development mode $this->zend_server->setProduction(false); //set to false for development mode
//(complete error message displayed into your AMF client) //(complete error message displayed into your AMF client)
// TODO: add some exception handling
} }
} }
/**
* Zend Amf server with a different fault management
*
* @package webservice_amf
* @copyright 2010 Jamie Pratt
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class Moodle_Amf_Server extends Zend_Amf_Server{ class Moodle_Amf_Server extends Zend_Amf_Server{
/** /**
* Raise a server fault * Raise a server fault
* *
* @param string|Exception $fault * @param string|Exception $fault
* @return void * @param int $code fault code
*/ */
public function fault($fault = null, $code = 404) public function fault($fault = null, $code = 404)
{ {
@ -198,5 +225,3 @@ class Moodle_Amf_Server extends Zend_Amf_Server{
echo $response; echo $response;
} }
} }
// TODO: implement AMF test client somehow, maybe we could use moodle form to feed the data to the flash app somehow

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* AMF web service entry point. The authentication is done via tokens. * AMF web service entry point. The authentication is done via tokens.
* *
* @package webservice * @package webservice_amf
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,24 +14,29 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* AMF web service entry point. The authentication is done via tokens. * AMF web service entry point. The authentication is done via username/password.
* *
* @package webservice * @package webservice_amf
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');
require_once("$CFG->dirroot/webservice/amf/locallib.php"); require_once("$CFG->dirroot/webservice/amf/locallib.php");
//ob_start(); //disable all 'displayed error' mess in xml
//TODO: for now disable all mess in xml
ini_set('display_errors', '0'); ini_set('display_errors', '0');
ini_set('log_errors', '1'); ini_set('log_errors', '1');
$CFG->debugdisplay = false; $CFG->debugdisplay = false;

View File

@ -1,4 +1,28 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Index page of the AMF test client
*
* @package webservice_amf
* @copyright 2009 Jamie Pratt
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require "../../../config.php"; require "../../../config.php";
require_once($CFG->libdir . '/adminlib.php'); require_once($CFG->libdir . '/adminlib.php');

View File

@ -14,12 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Version details * Version details
* *
* @package webservice * @package webservice_amf
* @subpackage amf * @copyright 2009 Petr Skodak
* @copyright 2009 Moodle Pty Ltd (http://moodle.com)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -14,23 +14,32 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* external API for mobile web services * external API for mobile web services
* *
* @package core * @package core_webservice
* @subpackage webservice * @category external
* @copyright 2011 Moodle Pty Ltd (http://moodle.com) * @copyright 2011 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
/** /**
* Web service related functions * Web service related functions
*
* @package core_webservice
* @category external
* @copyright 2011 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since Moodle 2.2
*/ */
class core_webservice_external extends external_api { class core_webservice_external extends external_api {
/** /**
* Returns description of method parameters * Returns description of method parameters
*
* @return external_function_parameters * @return external_function_parameters
* @since Moodle 2.2
*/ */
public static function get_site_info_parameters() { public static function get_site_info_parameters() {
return new external_function_parameters( return new external_function_parameters(
@ -49,9 +58,11 @@ class core_webservice_external extends external_api {
/** /**
* Return user information including profile picture + basic site information * Return user information including profile picture + basic site information
* Note: * Note:
* - no capability checking because we return just known information by logged user * - no capability checking because we return only known information about logged user
*
* @param array $serviceshortnames - DEPRECATED PARAMETER - values will be ignored - it was an original design error, we keep for backward compatibility. * @param array $serviceshortnames - DEPRECATED PARAMETER - values will be ignored - it was an original design error, we keep for backward compatibility.
* @return array * @return array site info
* @since Moodle 2.2
*/ */
public function get_site_info($serviceshortnames = array()) { public function get_site_info($serviceshortnames = array()) {
global $USER, $SITE, $CFG, $DB; global $USER, $SITE, $CFG, $DB;
@ -139,7 +150,9 @@ class core_webservice_external extends external_api {
/** /**
* Returns description of method result value * Returns description of method result value
*
* @return external_single_structure * @return external_single_structure
* @since Moodle 2.2
*/ */
public static function get_site_info_returns() { public static function get_site_info_returns() {
return new external_single_structure( return new external_single_structure(
@ -167,14 +180,26 @@ class core_webservice_external extends external_api {
/** /**
* Deprecated web service related functions * Deprecated web service related functions
* @deprecated since Moodle 2.2 please use core_webservice_external instead *
* @package core_webservice
* @category external
* @copyright 2011 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @deprecated Moodle 2.2 MDL-29106 - please do not use this class any more.
* @todo MDL-31194 This will be deleted in Moodle 2.5.
* @see core_webservice_external
* @since Moodle 2.1
*/ */
class moodle_webservice_external extends external_api { class moodle_webservice_external extends external_api {
/** /**
* Returns description of method parameters * Returns description of method parameters
* @deprecated since Moodle 2.2 please use core_webservice_external::get_site_info_parameters instead *
* @return external_function_parameters * @return external_function_parameters
* @deprecated Moodle 2.2 - please do not use this function any more.
* @todo MDL-31194 This will be deleted in Moodle 2.5.
* @see core_webservice_external::get_site_info_parameters
* @since Moodle 2.1
*/ */
public static function get_siteinfo_parameters() { public static function get_siteinfo_parameters() {
return core_webservice_external::get_site_info_parameters(); return core_webservice_external::get_site_info_parameters();
@ -184,9 +209,13 @@ class moodle_webservice_external extends external_api {
* Return user information including profile picture + basic site information * Return user information including profile picture + basic site information
* Note: * Note:
* - no capability checking because we return just known information by logged user * - no capability checking because we return just known information by logged user
* @deprecated since Moodle 2.2 please use core_webservice_external::get_site_info instead *
* @param array $serviceshortnames of service shortnames - the functions of these services will be returned * @param array $serviceshortnames of service shortnames - the functions of these services will be returned
* @return array * @return array
* @deprecated Moodle 2.2 - please do not use this function any more.
* @todo MDL-31194 This will be deleted in Moodle 2.5.
* @see core_webservice_external::get_site_info
* @since Moodle 2.1
*/ */
public function get_siteinfo($serviceshortnames = array()) { public function get_siteinfo($serviceshortnames = array()) {
return core_webservice_external::get_site_info($serviceshortnames); return core_webservice_external::get_site_info($serviceshortnames);
@ -194,8 +223,12 @@ class moodle_webservice_external extends external_api {
/** /**
* Returns description of method result value * Returns description of method result value
* @deprecated since Moodle 2.2 please use core_webservice_external::get_site_info_returns instead *
* @return external_single_structure * @return external_single_structure
* @deprecated Moodle 2.2 - please do not use this function any more.
* @todo MDL-31194 This will be deleted in Moodle 2.5.
* @see core_webservice_external::get_site_info_returns
* @since Moodle 2.1
*/ */
public static function get_siteinfo_returns() { public static function get_siteinfo_returns() {
return core_webservice_external::get_site_info_returns(); return core_webservice_external::get_site_info_returns();

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,27 +14,44 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Web services utility functions and classes * Web services utility functions and classes
* *
* @package webservice * @package core_webservice
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
require_once($CFG->libdir.'/externallib.php'); require_once($CFG->libdir.'/externallib.php');
/**
* WEBSERVICE_AUTHMETHOD_USERNAME - username/password authentication (also called simple authentication)
*/
define('WEBSERVICE_AUTHMETHOD_USERNAME', 0); define('WEBSERVICE_AUTHMETHOD_USERNAME', 0);
/**
* WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN - most common token authentication (external app, mobile app...)
*/
define('WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN', 1); define('WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN', 1);
/**
* WEBSERVICE_AUTHMETHOD_SESSION_TOKEN - token for embedded application (requires Moodle session)
*/
define('WEBSERVICE_AUTHMETHOD_SESSION_TOKEN', 2); define('WEBSERVICE_AUTHMETHOD_SESSION_TOKEN', 2);
/** /**
* General web service library * General web service library
*
* @package core_webservice
* @copyright 2010 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice { class webservice {
/** /**
* Authenticate user (used by download/upload file scripts) * Authenticate user (used by download/upload file scripts)
*
* @param string $token * @param string $token
* @return array - contains the authenticated user, token and service objects * @return array - contains the authenticated user, token and service objects
*/ */
@ -153,8 +169,9 @@ class webservice {
} }
/** /**
* Add a user to the list of authorised user of a given service * Allow user to call a service
* @param object $user *
* @param stdClass $user a user
*/ */
public function add_ws_authorised_user($user) { public function add_ws_authorised_user($user) {
global $DB; global $DB;
@ -163,8 +180,9 @@ class webservice {
} }
/** /**
* Remove a user from a list of allowed user of a service * Disallow a user to call a service
* @param object $user *
* @param stdClass $user a user
* @param int $serviceid * @param int $serviceid
*/ */
public function remove_ws_authorised_user($user, $serviceid) { public function remove_ws_authorised_user($user, $serviceid) {
@ -174,8 +192,9 @@ class webservice {
} }
/** /**
* Update service allowed user settings * Update allowed user settings (ip restriction, valid until...)
* @param object $user *
* @param stdClass $user
*/ */
public function update_ws_authorised_user($user) { public function update_ws_authorised_user($user) {
global $DB; global $DB;
@ -185,7 +204,8 @@ class webservice {
/** /**
* Return list of allowed users with their options (ip/timecreated / validuntil...) * Return list of allowed users with their options (ip/timecreated / validuntil...)
* for a given service * for a given service
* @param int $serviceid *
* @param int $serviceid the service id to search against
* @return array $users * @return array $users
*/ */
public function get_ws_authorised_users($serviceid) { public function get_ws_authorised_users($serviceid) {
@ -205,10 +225,11 @@ class webservice {
} }
/** /**
* Return a authorised user with his options (ip/timecreated / validuntil...) * Return an authorised user with their options (ip/timecreated / validuntil...)
* @param int $serviceid *
* @param int $userid * @param int $serviceid the service id to search against
* @return object * @param int $userid the user to search against
* @return stdClass
*/ */
public function get_ws_authorised_user($serviceid, $userid) { public function get_ws_authorised_user($serviceid, $userid) {
global $DB, $CFG; global $DB, $CFG;
@ -227,24 +248,25 @@ class webservice {
} }
/** /**
* Generate all ws token needed by a user * Generate all tokens of a specific user
* @param int $userid *
* @param int $userid user id
*/ */
public function generate_user_ws_tokens($userid) { public function generate_user_ws_tokens($userid) {
global $CFG, $DB; global $CFG, $DB;
/// generate a token for non admin if web service are enable and the user has the capability to create a token // generate a token for non admin if web service are enable and the user has the capability to create a token
if (!is_siteadmin() && has_capability('moodle/webservice:createtoken', get_context_instance(CONTEXT_SYSTEM), $userid) && !empty($CFG->enablewebservices)) { if (!is_siteadmin() && has_capability('moodle/webservice:createtoken', get_context_instance(CONTEXT_SYSTEM), $userid) && !empty($CFG->enablewebservices)) {
/// for every service than the user is authorised on, create a token (if it doesn't already exist) // for every service than the user is authorised on, create a token (if it doesn't already exist)
///get all services which are set to all user (no restricted to specific users) // get all services which are set to all user (no restricted to specific users)
$norestrictedservices = $DB->get_records('external_services', array('restrictedusers' => 0)); $norestrictedservices = $DB->get_records('external_services', array('restrictedusers' => 0));
$serviceidlist = array(); $serviceidlist = array();
foreach ($norestrictedservices as $service) { foreach ($norestrictedservices as $service) {
$serviceidlist[] = $service->id; $serviceidlist[] = $service->id;
} }
//get all services which are set to the current user (the current user is specified in the restricted user list) // get all services which are set to the current user (the current user is specified in the restricted user list)
$servicesusers = $DB->get_records('external_services_users', array('userid' => $userid)); $servicesusers = $DB->get_records('external_services_users', array('userid' => $userid));
foreach ($servicesusers as $serviceuser) { foreach ($servicesusers as $serviceuser) {
if (!in_array($serviceuser->externalserviceid,$serviceidlist)) { if (!in_array($serviceuser->externalserviceid,$serviceidlist)) {
@ -252,24 +274,24 @@ class webservice {
} }
} }
//get all services which already have a token set for the current user // get all services which already have a token set for the current user
$usertokens = $DB->get_records('external_tokens', array('userid' => $userid, 'tokentype' => EXTERNAL_TOKEN_PERMANENT)); $usertokens = $DB->get_records('external_tokens', array('userid' => $userid, 'tokentype' => EXTERNAL_TOKEN_PERMANENT));
$tokenizedservice = array(); $tokenizedservice = array();
foreach ($usertokens as $token) { foreach ($usertokens as $token) {
$tokenizedservice[] = $token->externalserviceid; $tokenizedservice[] = $token->externalserviceid;
} }
//create a token for the service which have no token already // create a token for the service which have no token already
foreach ($serviceidlist as $serviceid) { foreach ($serviceidlist as $serviceid) {
if (!in_array($serviceid, $tokenizedservice)) { if (!in_array($serviceid, $tokenizedservice)) {
//create the token for this service // create the token for this service
$newtoken = new stdClass(); $newtoken = new stdClass();
$newtoken->token = md5(uniqid(rand(),1)); $newtoken->token = md5(uniqid(rand(),1));
//check that the user has capability on this service // check that the user has capability on this service
$newtoken->tokentype = EXTERNAL_TOKEN_PERMANENT; $newtoken->tokentype = EXTERNAL_TOKEN_PERMANENT;
$newtoken->userid = $userid; $newtoken->userid = $userid;
$newtoken->externalserviceid = $serviceid; $newtoken->externalserviceid = $serviceid;
//TODO: find a way to get the context - UPDATE FOLLOWING LINE // TODO MDL-31190 find a way to get the context - UPDATE FOLLOWING LINE
$newtoken->contextid = get_context_instance(CONTEXT_SYSTEM)->id; $newtoken->contextid = get_context_instance(CONTEXT_SYSTEM)->id;
$newtoken->creatorid = $userid; $newtoken->creatorid = $userid;
$newtoken->timecreated = time(); $newtoken->timecreated = time();
@ -283,9 +305,12 @@ class webservice {
} }
/** /**
* Return all ws user token with ws enabled/disabled and ws restricted users mode. * Return all tokens of a specific user
* @param integer $userid * + the service state (enabled/disabled)
* @return array of token * + the authorised user mode (restricted/not restricted)
*
* @param int $userid user id
* @return array
*/ */
public function get_user_ws_tokens($userid) { public function get_user_ws_tokens($userid) {
global $DB; global $DB;
@ -301,16 +326,19 @@ class webservice {
} }
/** /**
* Return a user token that has been created by the user * Return a token that has been created by the user (i.e. to created by an admin)
* If doesn't exist a exception is thrown * If no tokens exist an exception is thrown
* @param integer $userid *
* @param integer $tokenid * The returned value is a stdClass:
* @return object token
* ->id token id * ->id token id
* ->token * ->token
* ->firstname user firstname * ->firstname user firstname
* ->lastname * ->lastname
* ->name service name * ->name service name
*
* @param int $userid user id
* @param int $tokenid token id
* @return stdClass
*/ */
public function get_created_by_user_ws_token($userid, $tokenid) { public function get_created_by_user_ws_token($userid, $tokenid) {
global $DB; global $DB;
@ -328,8 +356,9 @@ class webservice {
} }
/** /**
* Return a token for a given id * Return a database token record for a token id
* @param integer $tokenid *
* @param int $tokenid token id
* @return object token * @return object token
*/ */
public function get_token_by_id($tokenid) { public function get_token_by_id($tokenid) {
@ -338,8 +367,9 @@ class webservice {
} }
/** /**
* Delete a user token * Delete a token
* @param int $tokenid *
* @param int $tokenid token id
*/ */
public function delete_user_ws_token($tokenid) { public function delete_user_ws_token($tokenid) {
global $DB; global $DB;
@ -347,8 +377,10 @@ class webservice {
} }
/** /**
* Delete a service - it also delete the functions and users references to this service * Delete a service
* @param int $serviceid * Also delete function references and authorised user references.
*
* @param int $serviceid service id
*/ */
public function delete_service($serviceid) { public function delete_service($serviceid) {
global $DB; global $DB;
@ -359,7 +391,8 @@ class webservice {
} }
/** /**
* Get a user token by token * Get a full database token record for a given token value
*
* @param string $token * @param string $token
* @throws moodle_exception if there is multiple result * @throws moodle_exception if there is multiple result
*/ */
@ -369,9 +402,10 @@ class webservice {
} }
/** /**
* Get the list of all functions for given service ids * Get the functions list of a service list (by id)
* @param array $serviceids *
* @return array functions * @param array $serviceids service ids
* @return array of functions
*/ */
public function get_external_functions($serviceids) { public function get_external_functions($serviceids) {
global $DB; global $DB;
@ -390,9 +424,10 @@ class webservice {
} }
/** /**
* Get the list of all functions for given service shortnames * Get the functions of a service list (by shortname). It can return only enabled functions if required.
* @param array $serviceshortnames *
* @param $enabledonly if true then only return function for the service that has been enabled * @param array $serviceshortnames service shortnames
* @param bool $enabledonly if true then only return functions for services that have been enabled
* @return array functions * @return array functions
*/ */
public function get_external_functions_by_enabled_services($serviceshortnames, $enabledonly = true) { public function get_external_functions_by_enabled_services($serviceshortnames, $enabledonly = true) {
@ -415,8 +450,9 @@ class webservice {
} }
/** /**
* Get the list of all functions not in the given service id * Get functions not included in a service
* @param int $serviceid *
* @param int $serviceid service id
* @return array functions * @return array functions
*/ */
public function get_not_associated_external_functions($serviceid) { public function get_not_associated_external_functions($serviceid) {
@ -434,9 +470,7 @@ class webservice {
/** /**
* Get list of required capabilities of a service, sorted by functions * Get list of required capabilities of a service, sorted by functions
* @param integer $serviceid * Example of returned value:
* @return array
* example of return value:
* Array * Array
* ( * (
* [moodle_group_create_groups] => Array * [moodle_group_create_groups] => Array
@ -453,6 +487,9 @@ class webservice {
* [4] => moodle/course:enrolreview * [4] => moodle/course:enrolreview
* ) * )
* ) * )
*
* @param int $serviceid service id
* @return array
*/ */
public function get_service_required_capabilities($serviceid) { public function get_service_required_capabilities($serviceid) {
$functions = $this->get_external_functions(array($serviceid)); $functions = $this->get_external_functions(array($serviceid));
@ -470,8 +507,9 @@ class webservice {
/** /**
* Get user capabilities (with context) * Get user capabilities (with context)
* Only usefull for documentation purpose * Only useful for documentation purpose
* @param integer $userid *
* @param int $userid user id
* @return array * @return array
*/ */
public function get_user_capabilities($userid) { public function get_user_capabilities($userid) {
@ -488,10 +526,11 @@ class webservice {
} }
/** /**
* Get users missing capabilities for a given service * Get missing user capabilities for a given service
* @param array $users *
* @param integer $serviceid * @param array $users users
* @return array of missing capabilities, the key being the user id * @param int $serviceid service id
* @return array of missing capabilities, keys being the user ids
*/ */
public function get_missing_capabilities_by_users($users, $serviceid) { public function get_missing_capabilities_by_users($users, $serviceid) {
global $DB; global $DB;
@ -525,10 +564,11 @@ class webservice {
} }
/** /**
* Get a external service for a given id * Get an external service for a given service id
* @param service id $serviceid *
* @param integer $strictness IGNORE_MISSING, MUST_EXIST... * @param int $serviceid service id
* @return object external service * @param int $strictness IGNORE_MISSING, MUST_EXIST...
* @return stdClass external service
*/ */
public function get_external_service_by_id($serviceid, $strictness=IGNORE_MISSING) { public function get_external_service_by_id($serviceid, $strictness=IGNORE_MISSING) {
global $DB; global $DB;
@ -538,10 +578,11 @@ class webservice {
} }
/** /**
* Get a external service for a given shortname * Get an external service for a given shortname
* @param service shortname $shortname *
* @param integer $strictness IGNORE_MISSING, MUST_EXIST... * @param string $shortname service shortname
* @return object external service * @param int $strictness IGNORE_MISSING, MUST_EXIST...
* @return stdClass external service
*/ */
public function get_external_service_by_shortname($shortname, $strictness=IGNORE_MISSING) { public function get_external_service_by_shortname($shortname, $strictness=IGNORE_MISSING) {
global $DB; global $DB;
@ -551,10 +592,11 @@ class webservice {
} }
/** /**
* Get a external function for a given id * Get an external function for a given function id
* @param function id $functionid *
* @param integer $strictness IGNORE_MISSING, MUST_EXIST... * @param int $functionid function id
* @return object external function * @param int $strictness IGNORE_MISSING, MUST_EXIST...
* @return stdClass external function
*/ */
public function get_external_function_by_id($functionid, $strictness=IGNORE_MISSING) { public function get_external_function_by_id($functionid, $strictness=IGNORE_MISSING) {
global $DB; global $DB;
@ -565,8 +607,9 @@ class webservice {
/** /**
* Add a function to a service * Add a function to a service
* @param string $functionname *
* @param integer $serviceid * @param string $functionname function name
* @param int $serviceid service id
*/ */
public function add_external_function_to_service($functionname, $serviceid) { public function add_external_function_to_service($functionname, $serviceid) {
global $DB; global $DB;
@ -578,7 +621,9 @@ class webservice {
/** /**
* Add a service * Add a service
* @param object $service * It generates the timecreated field automatically.
*
* @param stdClass $service
* @return serviceid integer * @return serviceid integer
*/ */
public function add_external_service($service) { public function add_external_service($service) {
@ -590,7 +635,9 @@ class webservice {
/** /**
* Update a service * Update a service
* @param object $service * It modifies the timemodified automatically.
*
* @param stdClass $service
*/ */
public function update_external_service($service) { public function update_external_service($service) {
global $DB; global $DB;
@ -599,9 +646,10 @@ class webservice {
} }
/** /**
* Test whether a external function is already linked to a service * Test whether an external function is already linked to a service
* @param string $functionname *
* @param integer $serviceid * @param string $functionname function name
* @param int $serviceid service id
* @return bool true if a matching function exists for the service, else false. * @return bool true if a matching function exists for the service, else false.
* @throws dml_exception if error * @throws dml_exception if error
*/ */
@ -612,6 +660,12 @@ class webservice {
'functionname' => $functionname)); 'functionname' => $functionname));
} }
/**
* Remove a function from a service
*
* @param string $functionname function name
* @param int $serviceid service id
*/
public function remove_external_function_from_service($functionname, $serviceid) { public function remove_external_function_from_service($functionname, $serviceid) {
global $DB; global $DB;
$DB->delete_records('external_services_functions', $DB->delete_records('external_services_functions',
@ -624,11 +678,17 @@ class webservice {
/** /**
* Exception indicating access control problem in web service call * Exception indicating access control problem in web service call
* @author Petr Skoda (skodak) *
* @package core_webservice
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_access_exception extends moodle_exception { class webservice_access_exception extends moodle_exception {
/** /**
* Constructor * Constructor
*
* @param string $debuginfo the debug info
*/ */
function __construct($debuginfo) { function __construct($debuginfo) {
parent::__construct('accessexception', 'webservice', '', null, $debuginfo); parent::__construct('accessexception', 'webservice', '', null, $debuginfo);
@ -636,9 +696,10 @@ class webservice_access_exception extends moodle_exception {
} }
/** /**
* Is protocol enabled? * Check if a protocol is enabled
* @param string $protocol name of WS protocol *
* @return bool * @param string $protocol name of WS protocol ('rest', 'soap', 'xmlrpc', 'amf'...)
* @return bool true if the protocol is enabled
*/ */
function webservice_protocol_is_enabled($protocol) { function webservice_protocol_is_enabled($protocol) {
global $CFG; global $CFG;
@ -652,18 +713,21 @@ function webservice_protocol_is_enabled($protocol) {
return(in_array($protocol, $active)); return(in_array($protocol, $active));
} }
//=== WS classes ===
/** /**
* Mandatory interface for all test client classes. * Mandatory interface for all test client classes.
* @author Petr Skoda (skodak) *
* @package core_webservice
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
interface webservice_test_client_interface { interface webservice_test_client_interface {
/** /**
* Execute test client WS request * Execute test client WS request
* @param string $serverurl *
* @param string $function * @param string $serverurl server url (including the token param)
* @param array $params * @param string $function web service function name
* @param array $params parameters of the web service function
* @return mixed * @return mixed
*/ */
public function simpletest($serverurl, $function, $params); public function simpletest($serverurl, $function, $params);
@ -671,48 +735,55 @@ interface webservice_test_client_interface {
/** /**
* Mandatory interface for all web service protocol classes * Mandatory interface for all web service protocol classes
* @author Petr Skoda (skodak) *
* @package core_webservice
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
interface webservice_server_interface { interface webservice_server_interface {
/** /**
* Process request from client. * Process request from client.
* @return void
*/ */
public function run(); public function run();
} }
/** /**
* Abstract web service base class. * Abstract web service base class.
* @author Petr Skoda (skodak) *
* @package core_webservice
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
abstract class webservice_server implements webservice_server_interface { abstract class webservice_server implements webservice_server_interface {
/** @property string $wsname name of the web server plugin */ /** @var string Name of the web server plugin */
protected $wsname = null; protected $wsname = null;
/** @property string $username name of local user */ /** @var string Name of local user */
protected $username = null; protected $username = null;
/** @property string $password password of the local user */ /** @var string Password of the local user */
protected $password = null; protected $password = null;
/** @property int $userid the local user */ /** @var int The local user */
protected $userid = null; protected $userid = null;
/** @property integer $authmethod authentication method one of WEBSERVICE_AUTHMETHOD_* */ /** @var integer Authentication method one of WEBSERVICE_AUTHMETHOD_* */
protected $authmethod; protected $authmethod;
/** @property string $token authentication token*/ /** @var string Authentication token*/
protected $token = null; protected $token = null;
/** @property object restricted context */ /** @var stdClass Restricted context */
protected $restricted_context; protected $restricted_context;
/** @property int restrict call to one service id*/ /** @var int Restrict call to one service id*/
protected $restricted_serviceid = null; protected $restricted_serviceid = null;
/** /**
* Contructor * Constructor
*
* @param integer $authmethod authentication method one of WEBSERVICE_AUTHMETHOD_* * @param integer $authmethod authentication method one of WEBSERVICE_AUTHMETHOD_*
*/ */
public function __construct($authmethod) { public function __construct($authmethod) {
@ -726,7 +797,6 @@ abstract class webservice_server implements webservice_server_interface {
* It is safe to use has_capability() after this. * It is safe to use has_capability() after this.
* This method also verifies user is allowed to use this * This method also verifies user is allowed to use this
* server. * server.
* @return void
*/ */
protected function authenticate_user() { protected function authenticate_user() {
global $CFG, $DB; global $CFG, $DB;
@ -827,6 +897,13 @@ abstract class webservice_server implements webservice_server_interface {
external_api::set_context_restriction($this->restricted_context); external_api::set_context_restriction($this->restricted_context);
} }
/**
* User authentication by token
*
* @param string $tokentype token type (EXTERNAL_TOKEN_EMBEDDED or EXTERNAL_TOKEN_PERMANENT)
* @return stdClass the authenticated user
* @throws webservice_access_exception
*/
protected function authenticate_by_token($tokentype){ protected function authenticate_by_token($tokentype){
global $DB; global $DB;
if (!$token = $DB->get_record('external_tokens', array('token'=>$this->token, 'tokentype'=>$tokentype))) { if (!$token = $DB->get_record('external_tokens', array('token'=>$this->token, 'tokentype'=>$tokentype))) {
@ -867,24 +944,28 @@ abstract class webservice_server implements webservice_server_interface {
} }
/** /**
* Special abstraction of our srvices that allows * Special abstraction of our services that allows interaction with stock Zend ws servers.
* interaction with stock Zend ws servers. *
* @author Petr Skoda (skodak) * @package core_webservice
* @copyright 2009 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
abstract class webservice_zend_server extends webservice_server { abstract class webservice_zend_server extends webservice_server {
/** @property string name of the zend server class : Zend_XmlRpc_Server, Zend_Soap_Server, Zend_Soap_AutoDiscover, ...*/ /** @var string Name of the zend server class : Zend_Amf_Server, moodle_zend_soap_server, Zend_Soap_AutoDiscover, ...*/
protected $zend_class; protected $zend_class;
/** @property object Zend server instance */ /** @var stdClass Zend server instance */
protected $zend_server; protected $zend_server;
/** @property string $service_class virtual web service class with all functions user name execute, created on the fly */ /** @var string Virtual web service class with all functions user name execute, created on the fly */
protected $service_class; protected $service_class;
/** /**
* Contructor * Constructor
* @param integer $authmethod authentication method - one of WEBSERVICE_AUTHMETHOD_* *
* @param int $authmethod authentication method - one of WEBSERVICE_AUTHMETHOD_*
* @param string $zend_class Name of the zend server class
*/ */
public function __construct($authmethod, $zend_class) { public function __construct($authmethod, $zend_class) {
parent::__construct($authmethod); parent::__construct($authmethod);
@ -893,8 +974,8 @@ abstract class webservice_zend_server extends webservice_server {
/** /**
* Process request from client. * Process request from client.
* @param bool $simple use simple authentication *
* @return void * @uses die
*/ */
public function run() { public function run() {
// we will probably need a lot of memory in some functions // we will probably need a lot of memory in some functions
@ -944,7 +1025,6 @@ abstract class webservice_zend_server extends webservice_server {
/** /**
* Load virtual class needed for Zend api * Load virtual class needed for Zend api
* @return void
*/ */
protected function init_service_class() { protected function init_service_class() {
global $USER, $DB; global $USER, $DB;
@ -1035,7 +1115,8 @@ class '.$classname.' {
/** /**
* returns virtual method code * returns virtual method code
* @param object $function *
* @param stdClass $function a record from external_function
* @return string PHP code * @return string PHP code
*/ */
protected function get_virtual_method_code($function) { protected function get_virtual_method_code($function) {
@ -1121,6 +1202,15 @@ class '.$classname.' {
return $code; return $code;
} }
/**
* Get the phpdoc type for an external_description
* external_value => int, double or string
* external_single_structure => object|struct, on-fly generated stdClass name, ...
* external_multiple_structure => array
*
* @param string $keydesc any of PARAM_*
* @return string phpdoc type (string, double, int, array...)
*/
protected function get_phpdoc_type($keydesc) { protected function get_phpdoc_type($keydesc) {
if ($keydesc instanceof external_value) { if ($keydesc instanceof external_value) {
switch($keydesc->type) { switch($keydesc->type) {
@ -1144,6 +1234,15 @@ class '.$classname.' {
return $type; return $type;
} }
/**
* Generate 'struct'/'object' type name
* Some servers (our Zend ones) parse the phpdoc to know the parameter types.
* The purpose to this function is to be overwritten when the common object|struct type are not understood by the server.
* See webservice/soap/locallib.php - the SOAP server requires detailed structure)
*
* @param external_single_structure $structdesc the structure for which we generate the phpdoc type
* @return string the phpdoc type
*/
protected function generate_simple_struct_class(external_single_structure $structdesc) { protected function generate_simple_struct_class(external_single_structure $structdesc) {
return 'object|struct'; //only 'object' is supported by SOAP, 'struct' by XML-RPC MDL-23083 return 'object|struct'; //only 'object' is supported by SOAP, 'struct' by XML-RPC MDL-23083
} }
@ -1152,8 +1251,9 @@ class '.$classname.' {
* You can override this function in your child class to add extra code into the dynamically * You can override this function in your child class to add extra code into the dynamically
* created service class. For example it is used in the amf server to cast types of parameters and to * created service class. For example it is used in the amf server to cast types of parameters and to
* cast the return value to the types as specified in the return value description. * cast the return value to the types as specified in the return value description.
* @param stdClass $function *
* @param array $params * @param stdClass $function a record from external_function
* @param array $params web service function parameters
* @return string body of the method for $function ie. everything within the {} of the method declaration. * @return string body of the method for $function ie. everything within the {} of the method declaration.
*/ */
protected function service_class_method_body($function, $params){ protected function service_class_method_body($function, $params){
@ -1182,6 +1282,7 @@ class '.$classname.' {
/** /**
* Recursive function to recurse down into a complex variable and convert all * Recursive function to recurse down into a complex variable and convert all
* objects to arrays. * objects to arrays.
*
* @param mixed $param value to cast * @param mixed $param value to cast
* @return mixed Cast value * @return mixed Cast value
*/ */
@ -1202,7 +1303,6 @@ class '.$classname.' {
/** /**
* Set up zend service class * Set up zend service class
* @return void
*/ */
protected function init_zend_server() { protected function init_zend_server() {
$this->zend_server = new $this->zend_class(); $this->zend_server = new $this->zend_class();
@ -1237,7 +1337,6 @@ class '.$classname.' {
/** /**
* Internal implementation - sending of page headers. * Internal implementation - sending of page headers.
* @return void
*/ */
protected function send_headers() { protected function send_headers() {
header('Cache-Control: private, must-revalidate, pre-check=0, post-check=0, max-age=0'); header('Cache-Control: private, must-revalidate, pre-check=0, post-check=0, max-age=0');
@ -1251,7 +1350,7 @@ class '.$classname.' {
* it can not just print html to output. * it can not just print html to output.
* *
* @param exception $ex * @param exception $ex
* @return void does not return * @uses exit
*/ */
public function exception_handler($ex) { public function exception_handler($ex) {
// detect active db transactions, rollback and log as error // detect active db transactions, rollback and log as error
@ -1270,8 +1369,8 @@ class '.$classname.' {
/** /**
* Send the error information to the WS client * Send the error information to the WS client
* formatted as XML document. * formatted as XML document.
*
* @param exception $ex * @param exception $ex
* @return void
*/ */
protected function send_error($ex=null) { protected function send_error($ex=null) {
$this->send_headers(); $this->send_headers();
@ -1280,8 +1379,8 @@ class '.$classname.' {
/** /**
* Future hook needed for emulated sessions. * Future hook needed for emulated sessions.
*
* @param exception $exception null means normal termination, $exception received when WS call failed * @param exception $exception null means normal termination, $exception received when WS call failed
* @return void
*/ */
protected function session_cleanup($exception=null) { protected function session_cleanup($exception=null) {
if ($this->authmethod == WEBSERVICE_AUTHMETHOD_USERNAME) { if ($this->authmethod == WEBSERVICE_AUTHMETHOD_USERNAME) {
@ -1294,22 +1393,26 @@ class '.$classname.' {
} }
/** /**
* Web Service server base class, this class handles both * Web Service server base class.
* simple and token authentication. *
* @author Petr Skoda (skodak) * This class handles both simple and token authentication.
*
* @package core_webservice
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
abstract class webservice_base_server extends webservice_server { abstract class webservice_base_server extends webservice_server {
/** @property array $parameters the function parameters - the real values submitted in the request */ /** @var array The function parameters - the real values submitted in the request */
protected $parameters = null; protected $parameters = null;
/** @property string $functionname the name of the function that is executed */ /** @var string The name of the function that is executed */
protected $functionname = null; protected $functionname = null;
/** @property object $function full function description */ /** @var stdClass Full function description */
protected $function = null; protected $function = null;
/** @property mixed $returns function return value */ /** @var mixed Function return value */
protected $returns = null; protected $returns = null;
/** /**
@ -1317,27 +1420,25 @@ abstract class webservice_base_server extends webservice_server {
* 1/ user authentication - username+password or token * 1/ user authentication - username+password or token
* 2/ function name * 2/ function name
* 3/ function parameters * 3/ function parameters
*
* @return void
*/ */
abstract protected function parse_request(); abstract protected function parse_request();
/** /**
* Send the result of function call to the WS client. * Send the result of function call to the WS client.
* @return void
*/ */
abstract protected function send_response(); abstract protected function send_response();
/** /**
* Send the error information to the WS client. * Send the error information to the WS client.
*
* @param exception $ex * @param exception $ex
* @return void
*/ */
abstract protected function send_error($ex=null); abstract protected function send_error($ex=null);
/** /**
* Process request from client. * Process request from client.
* @return void *
* @uses die
*/ */
public function run() { public function run() {
// we will probably need a lot of memory in some functions // we will probably need a lot of memory in some functions
@ -1383,7 +1484,7 @@ abstract class webservice_base_server extends webservice_server {
* it can not just print html to output. * it can not just print html to output.
* *
* @param exception $ex * @param exception $ex
* @return void does not return * $uses exit
*/ */
public function exception_handler($ex) { public function exception_handler($ex) {
// detect active db transactions, rollback and log as error // detect active db transactions, rollback and log as error
@ -1401,8 +1502,8 @@ abstract class webservice_base_server extends webservice_server {
/** /**
* Future hook needed for emulated sessions. * Future hook needed for emulated sessions.
*
* @param exception $exception null means normal termination, $exception received when WS call failed * @param exception $exception null means normal termination, $exception received when WS call failed
* @return void
*/ */
protected function session_cleanup($exception=null) { protected function session_cleanup($exception=null) {
if ($this->authmethod == WEBSERVICE_AUTHMETHOD_USERNAME) { if ($this->authmethod == WEBSERVICE_AUTHMETHOD_USERNAME) {
@ -1416,7 +1517,6 @@ abstract class webservice_base_server extends webservice_server {
* Fetches the function description from database, * Fetches the function description from database,
* verifies user is allowed to use this function and * verifies user is allowed to use this function and
* loads all paremeters and return descriptions. * loads all paremeters and return descriptions.
* @return void
*/ */
protected function load_function_info() { protected function load_function_info() {
global $DB, $USER, $CFG; global $DB, $USER, $CFG;
@ -1486,7 +1586,6 @@ abstract class webservice_base_server extends webservice_server {
/** /**
* Execute previously loaded function using parameters parsed from the request data. * Execute previously loaded function using parameters parsed from the request data.
* @return void
*/ */
protected function execute() { protected function execute() {
// validate params, this also sorts the params properly, we need the correct order in the next part // validate params, this also sorts the params properly, we need the correct order in the next part

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,17 +14,26 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* A script to serve files from web service client * A script to serve files from web service client
* *
* @package core * @package core_webservice
* @subpackage file
* @copyright 2011 Dongsheng Cai <dongsheng@moodle.com> * @copyright 2011 Dongsheng Cai <dongsheng@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
/**
* AJAX_SCRIPT - exception will be converted into JSON
*/
define('AJAX_SCRIPT', true); define('AJAX_SCRIPT', true);
/**
* NO_MOODLE_COOKIES - we don't want any cookie
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require_once(dirname(dirname(__FILE__)) . '/config.php'); require_once(dirname(dirname(__FILE__)) . '/config.php');
require_once($CFG->libdir . '/filelib.php'); require_once($CFG->libdir . '/filelib.php');
require_once($CFG->dirroot . '/webservice/lib.php'); require_once($CFG->dirroot . '/webservice/lib.php');

View File

@ -1,37 +1,34 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
///////////////////////////////////////////////////////////////////////////
// //
// This file is part of Moodle - http://moodle.org/ //
// Moodle - Modular Object-Oriented Dynamic Learning Environment //
// //
// Moodle is free software: you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation, either version 3 of the License, or //
// (at your option) any later version. //
// //
// Moodle 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 General Public License for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. //
// //
///////////////////////////////////////////////////////////////////////////
/** /**
* Web service documentation renderer. * Web service documentation renderer.
* @package webservice *
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @package core_webservice
* @author Jerome Mouneyrac * @category output
* @copyright 2009 Jerome Mouneyrac <jerome@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class core_webservice_renderer extends plugin_renderer_base { class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display the authorised user selector * Display the authorised user selector
* @param object $options *
* @param stdClass $options It contains alloweduserselector, potentialuserselector and serviceid
* @return string html * @return string html
*/ */
public function admin_authorised_user_selector(&$options) { public function admin_authorised_user_selector(&$options) {
@ -99,8 +96,10 @@ class core_webservice_renderer extends plugin_renderer_base {
} }
/** /**
* Display list of authorised user * Display list of authorised users
* @param array $users *
* @param array $users authorised users
* @param int $serviceid service id
* @return string $html * @return string $html
*/ */
public function admin_authorised_user_list($users, $serviceid) { public function admin_authorised_user_list($users, $serviceid) {
@ -129,8 +128,9 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display a confirmation page to remove a function from a service * Display a confirmation page to remove a function from a service
* @param object $function *
* @param object $service * @param stdClass $function It needs function id + function name properties.
* @param stdClass $service It needs service id + service name properties.
* @return string html * @return string html
*/ */
public function admin_remove_service_function_confirmation($function, $service) { public function admin_remove_service_function_confirmation($function, $service) {
@ -148,7 +148,8 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display a confirmation page to remove a service * Display a confirmation page to remove a service
* @param object $service *
* @param stdClass $service It needs service id + service name properties.
* @return string html * @return string html
*/ */
public function admin_remove_service_confirmation($service) { public function admin_remove_service_confirmation($service) {
@ -167,7 +168,8 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display a confirmation page to delete a token * Display a confirmation page to delete a token
* @param object $token *
* @param stdClass $token Required properties: id (token id), firstname (user firstname), lastname (user lastname), name (service name)
* @return string html * @return string html
*/ */
public function admin_delete_token_confirmation($token) { public function admin_delete_token_confirmation($token) {
@ -188,10 +190,11 @@ class core_webservice_renderer extends plugin_renderer_base {
} }
/** /**
* Display list of function for a given service * Display a list of functions for a given service
* If the service is build-in do not display remove/add operation (read-only) * If the service is built-in, do not display remove/add operation (read-only)
* @param array $functions *
* @param object $service * @param array $functions list of functions
* @param stdClass $service the given service
* @return string the table html + add operation html * @return string the table html + add operation html
*/ */
public function admin_service_function_list($functions, $service) { public function admin_service_function_list($functions, $service) {
@ -251,7 +254,8 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display Reset token confirmation box * Display Reset token confirmation box
* @param object $token to reset *
* @param stdClass $token token to reset
* @return string html * @return string html
*/ */
public function user_reset_token_confirmation($token) { public function user_reset_token_confirmation($token) {
@ -273,8 +277,10 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Display user tokens with buttons to reset them * Display user tokens with buttons to reset them
* @param object $tokens *
* @param int $userid * @param stdClass $tokens user tokens
* @param int $userid user id
* @param bool $documentation if true display a link to the API documentation
* @return string html code * @return string html code
*/ */
public function user_webservice_tokens_box($tokens, $userid, $documentation = false) { public function user_webservice_tokens_box($tokens, $userid, $documentation = false) {
@ -326,7 +332,7 @@ class core_webservice_renderer extends plugin_renderer_base {
$validuntil = ''; $validuntil = '';
if (!empty($token->validuntil)) { if (!empty($token->validuntil)) {
$validuntil = date("F j, Y"); //TODO: language support (look for moodle function) $validuntil = date("F j, Y"); //TODO MDL-31193 language support (look for moodle function)
} }
$tokenname = $token->name; $tokenname = $token->name;
@ -357,20 +363,22 @@ class core_webservice_renderer extends plugin_renderer_base {
* Return documentation for a ws description object * Return documentation for a ws description object
* ws description object can be 'external_multiple_structure', 'external_single_structure' * ws description object can be 'external_multiple_structure', 'external_single_structure'
* or 'external_value' * or 'external_value'
*
* Example of documentation for moodle_group_create_groups function: * Example of documentation for moodle_group_create_groups function:
list of ( * list of (
object { * object {
courseid int //id of course * courseid int //id of course
name string //multilang compatible name, course unique * name string //multilang compatible name, course unique
description string //group description text * description string //group description text
enrolmentkey string //group enrol secret phrase * enrolmentkey string //group enrol secret phrase
} * }
) * )
* @param object $params a part of parameter/return description *
* @param stdClass $params a part of parameter/return description
* @return string the html to display * @return string the html to display
*/ */
public function detailed_description_html($params) { public function detailed_description_html($params) {
/// retrieve the description of the description object // retrieve the description of the description object
$paramdesc = ""; $paramdesc = "";
if (!empty($params->desc)) { if (!empty($params->desc)) {
$paramdesc .= html_writer::start_tag('span', array('style' => "color:#2A33A6")); $paramdesc .= html_writer::start_tag('span', array('style' => "color:#2A33A6"));
@ -401,12 +409,12 @@ class core_webservice_renderer extends plugin_renderer_base {
$paramdesc .= html_writer::empty_tag('br', array()); $paramdesc .= html_writer::empty_tag('br', array());
} }
/// description object is a list // description object is a list
if ($params instanceof external_multiple_structure) { if ($params instanceof external_multiple_structure) {
return $paramdesc . "list of ( " . html_writer::empty_tag('br', array()) return $paramdesc . "list of ( " . html_writer::empty_tag('br', array())
. $this->detailed_description_html($params->content) . ")"; . $this->detailed_description_html($params->content) . ")";
} else if ($params instanceof external_single_structure) { } else if ($params instanceof external_single_structure) {
/// description object is an object // description object is an object
$singlestructuredesc = $paramdesc . "object {" . html_writer::empty_tag('br', array()); $singlestructuredesc = $paramdesc . "object {" . html_writer::empty_tag('br', array());
foreach ($params->keys as $attributname => $attribut) { foreach ($params->keys as $attributname => $attribut) {
$singlestructuredesc .= html_writer::start_tag('b', array()); $singlestructuredesc .= html_writer::start_tag('b', array());
@ -419,7 +427,7 @@ class core_webservice_renderer extends plugin_renderer_base {
$singlestructuredesc .= html_writer::empty_tag('br', array()); $singlestructuredesc .= html_writer::empty_tag('br', array());
return $singlestructuredesc; return $singlestructuredesc;
} else { } else {
/// description object is a primary type (string, integer) // description object is a primary type (string, integer)
switch ($params->type) { switch ($params->type) {
case PARAM_BOOL: // 0 or 1 only for now case PARAM_BOOL: // 0 or 1 only for now
case PARAM_INT: case PARAM_INT:
@ -437,9 +445,10 @@ class core_webservice_renderer extends plugin_renderer_base {
/** /**
* Return a description object in indented xml format (for REST response) * Return a description object in indented xml format (for REST response)
* It is indented in order to be displayed into <pre> tag * It is indented to be output within <pre> tags
* @param object $returndescription *
* @param string $indentation composed by space only * @param external_description $returndescription the description structure of the web service function returned value
* @param string $indentation Indentation in the generated HTML code; should contain only spaces.
* @return string the html to diplay * @return string the html to diplay
*/ */
public function description_in_indented_xml_format($returndescription, $indentation = "") { public function description_in_indented_xml_format($returndescription, $indentation = "") {
@ -448,7 +457,7 @@ class core_webservice_renderer extends plugin_renderer_base {
EOF; EOF;
/// description object is a list // description object is a list
if ($returndescription instanceof external_multiple_structure) { if ($returndescription instanceof external_multiple_structure) {
$return = $indentation . "<MULTIPLE>" . $brakeline; $return = $indentation . "<MULTIPLE>" . $brakeline;
$return .= $this->description_in_indented_xml_format($returndescription->content, $return .= $this->description_in_indented_xml_format($returndescription->content,
@ -456,7 +465,7 @@ EOF;
$return .= $indentation . "</MULTIPLE>" . $brakeline; $return .= $indentation . "</MULTIPLE>" . $brakeline;
return $return; return $return;
} else if ($returndescription instanceof external_single_structure) { } else if ($returndescription instanceof external_single_structure) {
/// description object is an object // description object is an object
$singlestructuredesc = $indentation . "<SINGLE>" . $brakeline; $singlestructuredesc = $indentation . "<SINGLE>" . $brakeline;
$keyindentation = $indentation . " "; $keyindentation = $indentation . " ";
foreach ($returndescription->keys as $attributname => $attribut) { foreach ($returndescription->keys as $attributname => $attribut) {
@ -469,7 +478,7 @@ EOF;
$singlestructuredesc .= $indentation . "</SINGLE>" . $brakeline; $singlestructuredesc .= $indentation . "</SINGLE>" . $brakeline;
return $singlestructuredesc; return $singlestructuredesc;
} else { } else {
/// description object is a primary type (string, integer) // description object is a primary type (string, integer)
switch ($returndescription->type) { switch ($returndescription->type) {
case PARAM_BOOL: // 0 or 1 only for now case PARAM_BOOL: // 0 or 1 only for now
case PARAM_INT: case PARAM_INT:
@ -487,8 +496,9 @@ EOF;
/** /**
* Create indented XML-RPC param description * Create indented XML-RPC param description
* @param object $paramdescription *
* @param string $indentation composed by space only * @param external_description $paramdescription the description structure of the web service function parameters
* @param string $indentation Indentation in the generated HTML code; should contain only spaces.
* @return string the html to diplay * @return string the html to diplay
*/ */
public function xmlrpc_param_description_html($paramdescription, $indentation = "") { public function xmlrpc_param_description_html($paramdescription, $indentation = "") {
@ -497,7 +507,7 @@ EOF;
EOF; EOF;
/// description object is a list // description object is a list
if ($paramdescription instanceof external_multiple_structure) { if ($paramdescription instanceof external_multiple_structure) {
$return = $brakeline . $indentation . "Array "; $return = $brakeline . $indentation . "Array ";
$indentation = $indentation . " "; $indentation = $indentation . " ";
@ -507,7 +517,7 @@ EOF;
$return .= $brakeline . $indentation . ")"; $return .= $brakeline . $indentation . ")";
return $return; return $return;
} else if ($paramdescription instanceof external_single_structure) { } else if ($paramdescription instanceof external_single_structure) {
/// description object is an object // description object is an object
$singlestructuredesc = $brakeline . $indentation . "Array "; $singlestructuredesc = $brakeline . $indentation . "Array ";
$keyindentation = $indentation . " "; $keyindentation = $indentation . " ";
$singlestructuredesc .= $brakeline . $keyindentation . "("; $singlestructuredesc .= $brakeline . $keyindentation . "(";
@ -520,7 +530,7 @@ EOF;
$singlestructuredesc .= $brakeline . $keyindentation . ")"; $singlestructuredesc .= $brakeline . $keyindentation . ")";
return $singlestructuredesc; return $singlestructuredesc;
} else { } else {
/// description object is a primary type (string, integer) // description object is a primary type (string, integer)
switch ($paramdescription->type) { switch ($paramdescription->type) {
case PARAM_BOOL: // 0 or 1 only for now case PARAM_BOOL: // 0 or 1 only for now
case PARAM_INT: case PARAM_INT:
@ -537,14 +547,15 @@ EOF;
} }
/** /**
* Return the html of a colored box with content * Return the html of a coloured box with content
*
* @param string $title - the title of the box * @param string $title - the title of the box
* @param string $content - the content to displayed * @param string $content - the content to displayed
* @param string $rgb - the background color of the box * @param string $rgb - the background color of the box
* @return <type> * @return string HTML code
*/ */
public function colored_box_with_pre_tag($title, $content, $rgb = 'FEEBE5') { public function colored_box_with_pre_tag($title, $content, $rgb = 'FEEBE5') {
//TODO: this tag removes xhtml strict error but cause warning //TODO MDL-31192 this tag removes xhtml strict error but cause warning
$coloredbox = html_writer::start_tag('div', array()); $coloredbox = html_writer::start_tag('div', array());
$coloredbox .= html_writer::start_tag('div', $coloredbox .= html_writer::start_tag('div',
array('style' => "border:solid 1px #DEDEDE;background:#" . $rgb array('style' => "border:solid 1px #DEDEDE;background:#" . $rgb
@ -563,8 +574,9 @@ EOF;
/** /**
* Return indented REST param description * Return indented REST param description
* @param object $paramdescription *
* @param string $indentation composed by space only * @param external_description $paramdescription the description structure of the web service function parameters
* @param string $paramstring parameter
* @return string the html to diplay * @return string the html to diplay
*/ */
public function rest_param_description_html($paramdescription, $paramstring) { public function rest_param_description_html($paramdescription, $paramstring) {
@ -572,13 +584,13 @@ EOF;
EOF; EOF;
/// description object is a list // description object is a list
if ($paramdescription instanceof external_multiple_structure) { if ($paramdescription instanceof external_multiple_structure) {
$paramstring = $paramstring . '[0]'; $paramstring = $paramstring . '[0]';
$return = $this->rest_param_description_html($paramdescription->content, $paramstring); $return = $this->rest_param_description_html($paramdescription->content, $paramstring);
return $return; return $return;
} else if ($paramdescription instanceof external_single_structure) { } else if ($paramdescription instanceof external_single_structure) {
/// description object is an object // description object is an object
$singlestructuredesc = ""; $singlestructuredesc = "";
$initialparamstring = $paramstring; $initialparamstring = $paramstring;
foreach ($paramdescription->keys as $attributname => $attribut) { foreach ($paramdescription->keys as $attributname => $attribut) {
@ -588,7 +600,7 @@ EOF;
} }
return $singlestructuredesc; return $singlestructuredesc;
} else { } else {
/// description object is a primary type (string, integer) // description object is a primary type (string, integer)
$paramstring = $paramstring . '='; $paramstring = $paramstring . '=';
switch ($paramdescription->type) { switch ($paramdescription->type) {
case PARAM_BOOL: // 0 or 1 only for now case PARAM_BOOL: // 0 or 1 only for now
@ -606,11 +618,12 @@ EOF;
} }
/** /**
* This display all the documentation * Displays all the documentation
* @param array $functions contains all decription objects *
* @param array $authparam keys contains 'tokenid' * @param array $functions external_description of all the web service functions
* @param boolean $printableformat true if we want to display the documentation in a printable format * @param boolean $printableformat true if we want to display the documentation in a printable format
* @param array $activatedprotocol * @param array $activatedprotocol the currently enabled protocol
* @param array $authparams url parameters (it contains 'tokenid' and sometimes 'print')
* @param string $parenturl url of the calling page - needed for the print button url: * @param string $parenturl url of the calling page - needed for the print button url:
* '/admin/documentation.php' or '/webservice/wsdoc.php' (default) * '/admin/documentation.php' or '/webservice/wsdoc.php' (default)
* @return string the html to diplay * @return string the html to diplay
@ -625,7 +638,7 @@ EOF;
EOF; EOF;
/// Some general information // Some general information
$docinfo = new stdClass(); $docinfo = new stdClass();
$docurl = new moodle_url('http://docs.moodle.org/dev/Creating_a_web_service_client'); $docurl = new moodle_url('http://docs.moodle.org/dev/Creating_a_web_service_client');
$docinfo->doclink = html_writer::tag('a', $docinfo->doclink = html_writer::tag('a',
@ -638,15 +651,14 @@ EOF;
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
/// Print button // Print button
$authparams['print'] = true; $authparams['print'] = true;
//$parameters = array ('token' => $token, 'wsusername' => $username, 'wspassword' => $password, 'print' => true);
$url = new moodle_url($parenturl, $authparams); // Required $url = new moodle_url($parenturl, $authparams); // Required
$documentationhtml .= $this->output->single_button($url, get_string('print', 'webservice')); $documentationhtml .= $this->output->single_button($url, get_string('print', 'webservice'));
$documentationhtml .= $br; $documentationhtml .= $br;
/// each functions will be displayed into a collapsible region // each functions will be displayed into a collapsible region
//(opened if printableformat = true) //(opened if printableformat = true)
foreach ($functions as $functionname => $description) { foreach ($functions as $functionname => $description) {
@ -663,7 +675,7 @@ EOF;
$documentationhtml .= $br; $documentationhtml .= $br;
} }
/// function global description // function global description
$documentationhtml .= $br; $documentationhtml .= $br;
$documentationhtml .= html_writer::start_tag('div', $documentationhtml .= html_writer::start_tag('div',
array('style' => 'border:solid 1px #DEDEDE;background:#E2E0E0; array('style' => 'border:solid 1px #DEDEDE;background:#E2E0E0;
@ -672,13 +684,13 @@ EOF;
$documentationhtml .= html_writer::end_tag('div'); $documentationhtml .= html_writer::end_tag('div');
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
/// function arguments documentation // function arguments documentation
$documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6')); $documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6'));
$documentationhtml .= get_string('arguments', 'webservice'); $documentationhtml .= get_string('arguments', 'webservice');
$documentationhtml .= html_writer::end_tag('span'); $documentationhtml .= html_writer::end_tag('span');
$documentationhtml .= $br; $documentationhtml .= $br;
foreach ($description->parameters_desc->keys as $paramname => $paramdesc) { foreach ($description->parameters_desc->keys as $paramname => $paramdesc) {
/// a argument documentation // a argument documentation
$documentationhtml .= html_writer::start_tag('span', array('style' => 'font-size:80%')); $documentationhtml .= html_writer::start_tag('span', array('style' => 'font-size:80%'));
if ($paramdesc->required == VALUE_REQUIRED) { if ($paramdesc->required == VALUE_REQUIRED) {
@ -704,12 +716,12 @@ EOF;
$documentationhtml .= "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" $documentationhtml .= "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;"
. $paramdesc->desc; // argument description . $paramdesc->desc; // argument description
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
///general structure of the argument // general structure of the argument
$documentationhtml .= $this->colored_box_with_pre_tag( $documentationhtml .= $this->colored_box_with_pre_tag(
get_string('generalstructure', 'webservice'), get_string('generalstructure', 'webservice'),
$this->detailed_description_html($paramdesc), $this->detailed_description_html($paramdesc),
'FFF1BC'); 'FFF1BC');
///xml-rpc structure of the argument in PHP format // xml-rpc structure of the argument in PHP format
if (!empty($activatedprotocol['xmlrpc'])) { if (!empty($activatedprotocol['xmlrpc'])) {
$documentationhtml .= $this->colored_box_with_pre_tag( $documentationhtml .= $this->colored_box_with_pre_tag(
get_string('phpparam', 'webservice'), get_string('phpparam', 'webservice'),
@ -717,7 +729,7 @@ EOF;
. $this->xmlrpc_param_description_html($paramdesc)), . $this->xmlrpc_param_description_html($paramdesc)),
'DFEEE7'); 'DFEEE7');
} }
///POST format for the REST protocol for the argument // POST format for the REST protocol for the argument
if (!empty($activatedprotocol['rest'])) { if (!empty($activatedprotocol['rest'])) {
$documentationhtml .= $this->colored_box_with_pre_tag( $documentationhtml .= $this->colored_box_with_pre_tag(
get_string('restparam', 'webservice'), get_string('restparam', 'webservice'),
@ -730,24 +742,24 @@ EOF;
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
/// function response documentation // function response documentation
$documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6')); $documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6'));
$documentationhtml .= get_string('response', 'webservice'); $documentationhtml .= get_string('response', 'webservice');
$documentationhtml .= html_writer::end_tag('span'); $documentationhtml .= html_writer::end_tag('span');
$documentationhtml .= $br; $documentationhtml .= $br;
/// function response description // function response description
$documentationhtml .= html_writer::start_tag('span', array('style' => 'font-size:80%')); $documentationhtml .= html_writer::start_tag('span', array('style' => 'font-size:80%'));
if (!empty($description->returns_desc->desc)) { if (!empty($description->returns_desc->desc)) {
$documentationhtml .= $description->returns_desc->desc; $documentationhtml .= $description->returns_desc->desc;
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
} }
if (!empty($description->returns_desc)) { if (!empty($description->returns_desc)) {
///general structure of the response // general structure of the response
$documentationhtml .= $this->colored_box_with_pre_tag( $documentationhtml .= $this->colored_box_with_pre_tag(
get_string('generalstructure', 'webservice'), get_string('generalstructure', 'webservice'),
$this->detailed_description_html($description->returns_desc), $this->detailed_description_html($description->returns_desc),
'FFF1BC'); 'FFF1BC');
///xml-rpc structure of the response in PHP format // xml-rpc structure of the response in PHP format
if (!empty($activatedprotocol['xmlrpc'])) { if (!empty($activatedprotocol['xmlrpc'])) {
$documentationhtml .= $this->colored_box_with_pre_tag( $documentationhtml .= $this->colored_box_with_pre_tag(
get_string('phpresponse', 'webservice'), get_string('phpresponse', 'webservice'),
@ -755,7 +767,7 @@ EOF;
$description->returns_desc)), $description->returns_desc)),
'DFEEE7'); 'DFEEE7');
} }
///XML response for the REST protocol // XML response for the REST protocol
if (!empty($activatedprotocol['rest'])) { if (!empty($activatedprotocol['rest'])) {
$restresponse = "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>" $restresponse = "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>"
. $brakeline . "<RESPONSE>" . $brakeline; . $brakeline . "<RESPONSE>" . $brakeline;
@ -771,7 +783,7 @@ EOF;
$documentationhtml .= html_writer::end_tag('span'); $documentationhtml .= html_writer::end_tag('span');
$documentationhtml .= $br . $br; $documentationhtml .= $br . $br;
/// function errors documentation for REST protocol // function errors documentation for REST protocol
if (!empty($activatedprotocol['rest'])) { if (!empty($activatedprotocol['rest'])) {
$documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6')); $documentationhtml .= html_writer::start_tag('span', array('style' => 'color:#EA33A6'));
$documentationhtml .= get_string('errorcodes', 'webservice'); $documentationhtml .= get_string('errorcodes', 'webservice');
@ -799,7 +811,7 @@ EOF;
} }
} }
/// close the table and return the documentation // close the table and return the documentation
$documentationhtml .= html_writer::end_tag('td'); $documentationhtml .= html_writer::end_tag('td');
$documentationhtml .= html_writer::end_tag('tr'); $documentationhtml .= html_writer::end_tag('tr');
$documentationhtml .= html_writer::end_tag('table'); $documentationhtml .= html_writer::end_tag('table');

View File

@ -1,4 +1,28 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* REST server related capabilities
*
* @package webservice_rest
* @category access
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$capabilities = array( $capabilities = array(

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,13 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Strings for component 'webservice_rest', language 'en', branch 'MOODLE_20_STABLE' * Strings for component 'webservice_rest', language 'en', branch 'MOODLE_20_STABLE'
* *
* @package webservice_rest * @package webservice_rest
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @category string
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,22 +14,42 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Moodle REST client class * Moodle REST library
* TODO: XML to PHP *
* @package webservice_rest
* @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
/**
* Moodle REST client
*
* It has been implemented for unit testing purpose (all protocols have similar client)
*
* @package webservice_rest
* @copyright 2010 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_rest_client { class webservice_rest_client {
/** @var moodle_url the REST server url */ /** @var moodle_url the REST server url */
private $serverurl; private $serverurl;
/** @var string token */
private $token; private $token;
/** @var string returned value format: xml or json */
private $format; private $format;
/** /**
* Constructor * Constructor
*
* @param string $serverurl a Moodle URL * @param string $serverurl a Moodle URL
* @param string $token * @param string $token the token used to do the web service call
* @param string $format returned value format: xml or json
*/ */
public function __construct($serverurl, $token, $format = 'xml') { public function __construct($serverurl, $token, $format = 'xml') {
$this->serverurl = new moodle_url($serverurl); $this->serverurl = new moodle_url($serverurl);
@ -40,7 +59,8 @@ class webservice_rest_client {
/** /**
* Set the token used to do the REST call * Set the token used to do the REST call
* @param string $token *
* @param string $token the token used to do the web service call
*/ */
public function set_token($token) { public function set_token($token) {
$this->token = $token; $this->token = $token;
@ -48,8 +68,9 @@ class webservice_rest_client {
/** /**
* Execute client WS request with token authentication * Execute client WS request with token authentication
* @param string $functionname *
* @param array $params * @param string $functionname the function name
* @param array $params the parameters of the function
* @return mixed * @return mixed
*/ */
public function call($functionname, $params) { public function call($functionname, $params) {
@ -67,7 +88,7 @@ class webservice_rest_client {
$result = download_file_content($this->serverurl->out(false), null, $params); $result = download_file_content($this->serverurl->out(false), null, $params);
//TODO : transform the XML result into PHP values - MDL-22965 //TODO MDL-22965 transform the XML result into PHP values
if ($this->format == 'json') { if ($this->format == 'json') {
$result = json_decode($result); $result = json_decode($result);
} }

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* REST web service implementation classes and methods. * REST web service implementation classes and methods.
* *
* @package webservice * @package webservice_rest
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
@ -27,15 +27,21 @@ require_once("$CFG->dirroot/webservice/lib.php");
/** /**
* REST service server implementation. * REST service server implementation.
* @author Petr Skoda (skodak) *
* @package webservice_rest
* @copyright 2009 Petr Skoda (skodak)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_rest_server extends webservice_base_server { class webservice_rest_server extends webservice_base_server {
/** @property string $alt return method (XML / JSON) */ /** @var string return method ('xml' or 'json') */
protected $restformat; protected $restformat;
/** /**
* Contructor * Contructor
*
* @param string $authmethod authentication method of the web service (WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN, ...)
* @param string $restformat Format of the return values: 'xml' or 'json'
*/ */
public function __construct($authmethod, $restformat = 'xml') { public function __construct($authmethod, $restformat = 'xml') {
parent::__construct($authmethod); parent::__construct($authmethod);
@ -49,8 +55,6 @@ class webservice_rest_server extends webservice_base_server {
* 1/ user authentication - username+password or token (wsusername, wspassword and wstoken parameters) * 1/ user authentication - username+password or token (wsusername, wspassword and wstoken parameters)
* 2/ function name (wsfunction parameter) * 2/ function name (wsfunction parameter)
* 3/ function parameters (all other parameters except those above) * 3/ function parameters (all other parameters except those above)
*
* @return void
*/ */
protected function parse_request() { protected function parse_request() {
@ -83,7 +87,6 @@ class webservice_rest_server extends webservice_base_server {
/** /**
* Send the result of function call to the WS client * Send the result of function call to the WS client
* formatted as XML document. * formatted as XML document.
* @return void
*/ */
protected function send_response() { protected function send_response() {
@ -121,8 +124,7 @@ class webservice_rest_server extends webservice_base_server {
* formatted as XML document. * formatted as XML document.
* Note: the exception is never passed as null, * Note: the exception is never passed as null,
* it only matches the abstract function declaration. * it only matches the abstract function declaration.
* @param exception $ex * @param exception $ex the exception that we are sending
* @return void
*/ */
protected function send_error($ex=null) { protected function send_error($ex=null) {
$this->send_headers(); $this->send_headers();
@ -131,7 +133,7 @@ class webservice_rest_server extends webservice_base_server {
/** /**
* Build the error information matching the REST returned value format (JSON or XML) * Build the error information matching the REST returned value format (JSON or XML)
* @param exception $ex * @param exception $ex the exception we are converting in the server rest format
* @return string the error in the requested REST format * @return string the error in the requested REST format
*/ */
protected function generate_error($ex) { protected function generate_error($ex) {
@ -157,7 +159,6 @@ class webservice_rest_server extends webservice_base_server {
/** /**
* Internal implementation - sending of page headers. * Internal implementation - sending of page headers.
* @return void
*/ */
protected function send_headers() { protected function send_headers() {
if ($this->restformat == 'json') { if ($this->restformat == 'json') {
@ -174,9 +175,10 @@ class webservice_rest_server extends webservice_base_server {
/** /**
* Internal implementation - recursive function producing XML markup. * Internal implementation - recursive function producing XML markup.
* @param mixed $returns *
* @param $desc * @param mixed $returns the returned values
* @return unknown_type * @param external_description $desc
* @return string
*/ */
protected static function xmlize_result($returns, $desc) { protected static function xmlize_result($returns, $desc) {
if ($desc === null) { if ($desc === null) {
@ -217,13 +219,17 @@ class webservice_rest_server extends webservice_base_server {
/** /**
* REST test client class * REST test client class
*
* @package webservice_rest
* @copyright 2009 Petr Skoda (skodak)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_rest_test_client implements webservice_test_client_interface { class webservice_rest_test_client implements webservice_test_client_interface {
/** /**
* Execute test client WS request * Execute test client WS request
* @param string $serverurl * @param string $serverurl server url (including token parameter or username/password parameters)
* @param string $function * @param string $function function name
* @param array $params * @param array $params parameters of the called function
* @return mixed * @return mixed
*/ */
public function simpletest($serverurl, $function, $params) { public function simpletest($serverurl, $function, $params) {

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* REST web service entry point. The authentication is done via tokens. * REST web service entry point. The authentication is done via tokens.
* *
* @package webservice * @package webservice_rest
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* REST web service entry point. The authentication is done via tokens. * REST web service entry point. The authentication is done via username/password.
* *
* @package webservice * @package webservice_rest
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -14,12 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Version details * Version details
* *
* @package webservice * @package webservice_rest
* @subpackage rest * @copyright 2009 Jerome Mouneyrac
* @copyright 2009 Moodle Pty Ltd (http://moodle.com)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,58 +14,88 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Test the different web service protocols. * Test the different web service protocols.
* *
* @author jerome@moodle.com * @package core_webservice
* @license http://www.gnu.org/copyleft/gpl.html GNU Public License * @copyright 2010 Jerome Mouneyrac
* @package web service * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
if (!defined('MOODLE_INTERNAL')) { if (!defined('MOODLE_INTERNAL')) {
/// It must be included from a Moodle page // It must be included from a Moodle page
die('Direct access to this script is forbidden.'); die('Direct access to this script is forbidden.');
} }
/** /**
* How to configure this unit tests: * Web service unit test class
* 0- Enable the web service you wish to test in the Moodle administration *
* 1- Create a service with all functions in the Moodle administration * How to configure these unit tests:
* 2- Create a token associate this service and to an admin (or a user with all required capabilities) * 0- Enable the web service you wish to test using Moodle site administration
* 1- Create a service with all functions using Moodle site administration
* 2- Create a token for this service. The token should be linked to an admin (or a user with all required capabilities)
* 3- Configure setUp() function: * 3- Configure setUp() function:
* a- write the token * a- write the token
* b- activate the protocols you wish to test * b- activate the protocols you wish to test
* c- activate the functions you wish to test (readonlytests and writetests arrays) * c- activate the functions you wish to test (readonlytests and writetests arrays)
* d- set the number of time the web services are run * d- set the number of times the web services are run
* Do not run WRITE test function on a production site as they impact the DB (even though every * Do not run the WRITE test function on a production site as they impact the DB (even though every
* test should clean the modified data) * test should clean the modified data)
* *
* How to write a new function: * How to write a new function:
* 1- Add the function name to the array readonlytests/writetests * 1- Add the function name to the array readonlytests/writetests
* 2- Set it as false when you commit! * 2- Set it as false when you commit!
* 3- write the function - Do not prefix the function name by 'test' * 3- write the function - Do not prefix the function name with 'test'
*
* @package core_webservice
* @copyright 2010 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_test extends UnitTestCase { class webservice_test extends UnitTestCase {
/** @var string the token used to call the web service functions during tests */
public $testtoken; public $testtoken;
/** @var bool Set it to true if you want to test the functions with the REST protocol */
public $testrest; public $testrest;
/** @var bool Set it to true if you want to test the functions with the XML-RPC protocol */
public $testxmlrpc; public $testxmlrpc;
/** @var bool Set it to true if you want to test the functions with the SOAP protocol */
public $testsoap; public $testsoap;
/** @var bool Set it to true if you want to time profile the REST protocol */
public $timerrest; public $timerrest;
/** @var bool Set it to true if you want to time profile the XML-RPC protocol */
public $timerxmlrpc; public $timerxmlrpc;
/** @var bool Set it to true if you want to time profile the SOAP protocol */
public $timersoap; public $timersoap;
/** @var bool DB READ-ONLY functions. Only "set to true" functions are run.*/
public $readonlytests; public $readonlytests;
/** @var bool DB WRITE functions. Only "set to true" functions are run. */
public $writetests; public $writetests;
/**
* Test set up
*/
function setUp() { function setUp() {
//token to test //token to test
$this->testtoken = 'acabec9d20933913f14309785324f579'; $this->testtoken = 'acabec9d20933913f14309785324f579';
//protocols to test //protocols to test
$this->testrest = false; //Does not work till XML => PHP is implemented (MDL-22965) $this->testrest = false; //TODO MDL-30210/MDL-22965 call REST in JSON mode
//DO NOT CHANGE
//The REST server cannot be tested till the issue ares fixed
$this->testxmlrpc = false; $this->testxmlrpc = false;
$this->testsoap = false; $this->testsoap = false;
////// READ-ONLY DB tests //// // READ-ONLY DB tests
$this->readonlytests = array( $this->readonlytests = array(
'moodle_group_get_groups' => false, 'moodle_group_get_groups' => false,
'moodle_course_get_courses' => false, 'moodle_course_get_courses' => false,
@ -78,7 +107,7 @@ class webservice_test extends UnitTestCase {
'core_course_get_contents' => false 'core_course_get_contents' => false
); );
////// WRITE DB tests //// // WRITE DB tests
$this->writetests = array( $this->writetests = array(
'moodle_user_create_users' => false, 'moodle_user_create_users' => false,
'moodle_course_create_courses' => false, 'moodle_course_create_courses' => false,
@ -105,6 +134,9 @@ class webservice_test extends UnitTestCase {
$this->timersoap = 0; $this->timersoap = 0;
} }
/**
* Run the tests
*/
function testRun() { function testRun() {
global $CFG; global $CFG;
@ -115,7 +147,8 @@ class webservice_test extends UnitTestCase {
if (!empty($this->testtoken)) { if (!empty($this->testtoken)) {
//Does not work till XML => PHP is implemented (MDL-22965) //TODO MDL-30210/MDL-22965 call REST in JSON mode
//The REST cannot be tested till the issue ares fixed
if ($this->testrest) { if ($this->testrest) {
$this->timerrest = time(); $this->timerrest = time();
@ -205,8 +238,11 @@ class webservice_test extends UnitTestCase {
} }
} }
///// WEB SERVICE TEST FUNCTIONS /**
* Test moodle_group_get_groups web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_group_get_groups($client) { function moodle_group_get_groups($client) {
global $DB; global $DB;
$dbgroups = $DB->get_records('groups'); $dbgroups = $DB->get_records('groups');
@ -221,6 +257,11 @@ class webservice_test extends UnitTestCase {
$this->assertEqual(count($groups), count($groupids)); $this->assertEqual(count($groups), count($groupids));
} }
/**
* Test moodle_webservice_get_siteinfo web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_webservice_get_siteinfo($client) { function moodle_webservice_get_siteinfo($client) {
global $SITE, $CFG; global $SITE, $CFG;
@ -233,6 +274,11 @@ class webservice_test extends UnitTestCase {
$this->assertEqual($info['siteurl'], $CFG->wwwroot); $this->assertEqual($info['siteurl'], $CFG->wwwroot);
} }
/**
* Test moodle_user_get_users_by_id web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_user_get_users_by_id($client) { function moodle_user_get_users_by_id($client) {
global $DB; global $DB;
$dbusers = $DB->get_records('user', array('deleted' => 0)); $dbusers = $DB->get_records('user', array('deleted' => 0));
@ -248,6 +294,11 @@ class webservice_test extends UnitTestCase {
$this->assertEqual(count($users), count($userids)); $this->assertEqual(count($users), count($userids));
} }
/**
* Test moodle_group_get_groups web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function core_course_get_contents($client) { function core_course_get_contents($client) {
global $DB, $CFG; global $DB, $CFG;
$dbcourses = $DB->get_records('course'); $dbcourses = $DB->get_records('course');
@ -269,10 +320,13 @@ class webservice_test extends UnitTestCase {
} }
/** /**
* Test moodle_enrol_manual_enrol_users web service function
* This test will: * This test will:
* 1- create a user (core call) * 1- create a user (core call)
* 2- enrol this user in the courses supporting enrolment * 2- enrol this user in the courses supporting enrolment
* 3- unenrol this user (core call) * 3- unenrol this user (core call)
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/ */
function moodle_enrol_manual_enrol_users($client) { function moodle_enrol_manual_enrol_users($client) {
global $DB, $CFG; global $DB, $CFG;
@ -349,7 +403,11 @@ class webservice_test extends UnitTestCase {
delete_role($roleid); delete_role($roleid);
} }
/**
* Test moodle_enrol_get_enrolled_users web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_enrol_get_enrolled_users($client) { function moodle_enrol_get_enrolled_users($client) {
global $DB; global $DB;
@ -385,6 +443,11 @@ class webservice_test extends UnitTestCase {
} }
} }
/**
* Test moodle_course_get_courses web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_course_get_courses($client) { function moodle_course_get_courses($client) {
global $DB; global $DB;
@ -465,10 +528,15 @@ class webservice_test extends UnitTestCase {
} }
} }
/**
* Test moodle_course_create_courses web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_course_create_courses($client) { function moodle_course_create_courses($client) {
global $DB, $CFG; global $DB, $CFG;
///Test data // Test data
$courseconfig = get_config('moodlecourse'); $courseconfig = get_config('moodlecourse');
$themeobjects = get_list_of_themes(); $themeobjects = get_list_of_themes();
@ -577,6 +645,11 @@ class webservice_test extends UnitTestCase {
array($dbcourse1->id, $dbcourse2->id)); array($dbcourse1->id, $dbcourse2->id));
} }
/**
* Test moodle_user_create_users web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_user_create_users($client) { function moodle_user_create_users($client) {
global $DB, $CFG; global $DB, $CFG;
@ -707,6 +780,11 @@ class webservice_test extends UnitTestCase {
array($dbuser1->id, $dbuser2->id)); array($dbuser1->id, $dbuser2->id));
} }
/**
* Test moodle_user_delete_users web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_user_delete_users($client) { function moodle_user_delete_users($client) {
global $DB, $CFG; global $DB, $CFG;
@ -813,6 +891,11 @@ class webservice_test extends UnitTestCase {
} }
} }
/**
* Test moodle_user_update_users web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_user_update_users($client) { function moodle_user_update_users($client) {
global $DB, $CFG; global $DB, $CFG;
@ -994,6 +1077,11 @@ class webservice_test extends UnitTestCase {
} }
} }
/**
* Test moodle_role_assign web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_role_assign($client) { function moodle_role_assign($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1048,6 +1136,11 @@ class webservice_test extends UnitTestCase {
} }
} }
/**
* Test moodle_role_unassign web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_role_unassign($client) { function moodle_role_unassign($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1107,11 +1200,9 @@ class webservice_test extends UnitTestCase {
} }
/** /**
* READ ONLY test * Test moodle_group_get_course_groups web service function
* TODO: find a better solution that running web service for each course *
* in the system * @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
* For each courses, test the number of groups
* @param object $client
*/ */
function moodle_group_get_course_groups($client) { function moodle_group_get_course_groups($client) {
global $DB; global $DB;
@ -1126,12 +1217,12 @@ class webservice_test extends UnitTestCase {
} }
} }
/** /**
* READ ONLY test * Test moodle_group_get_groupmembers web service function
* Test that the same number of members are returned * Test that the same number of members are returned
* for each existing group in the system * for each existing group in the system
* @param object $client *
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/ */
function moodle_group_get_groupmembers($client) { function moodle_group_get_groupmembers($client) {
global $DB; global $DB;
@ -1157,6 +1248,11 @@ class webservice_test extends UnitTestCase {
} }
/**
* Test moodle_group_add_groupmembers web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_group_add_groupmembers($client) { function moodle_group_add_groupmembers($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1247,6 +1343,11 @@ class webservice_test extends UnitTestCase {
} }
/**
* Test moodle_group_delete_groupmembers web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_group_delete_groupmembers($client) { function moodle_group_delete_groupmembers($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1337,6 +1438,11 @@ class webservice_test extends UnitTestCase {
} }
/**
* Test moodle_group_create_groups web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_group_create_groups($client) { function moodle_group_create_groups($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1431,6 +1537,11 @@ class webservice_test extends UnitTestCase {
} }
/**
* Test moodle_group_delete_groups web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
*/
function moodle_group_delete_groups($client) { function moodle_group_delete_groups($client) {
global $DB, $CFG; global $DB, $CFG;
@ -1523,6 +1634,12 @@ class webservice_test extends UnitTestCase {
$DB->delete_records('course_categories', array('id' => $category->id)); $DB->delete_records('course_categories', array('id' => $category->id));
} }
/**
* Test moodle_message_send_messages web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
* @since Moodle 2.1
*/
function moodle_message_send_messages($client) { function moodle_message_send_messages($client) {
global $DB; global $DB;
$function = 'moodle_message_send_messages'; $function = 'moodle_message_send_messages';
@ -1540,6 +1657,12 @@ class webservice_test extends UnitTestCase {
$this->assertEqual(count($success), 2); $this->assertEqual(count($success), 2);
} }
/**
* Test moodle_notes_create_notes web service function
*
* @param webservice_rest_client|webservice_soap_client|webservice_xmlrpc_client $client the protocol test client
* @since Moodle 2.1
*/
function moodle_notes_create_notes($client) { function moodle_notes_create_notes($client) {
global $DB, $CFG; global $DB, $CFG;

View File

@ -1,4 +1,28 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* SOAP server related capabilities
*
* @package webservice_soap
* @category access
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$capabilities = array( $capabilities = array(

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,13 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Strings for component 'webservice_soap', language 'en', branch 'MOODLE_20_STABLE' * Strings for component 'webservice_soap', language 'en', branch 'MOODLE_20_STABLE'
* *
* @package webservice_soap * @package webservice_soap
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @category string
* @copyright 2010 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,19 +14,36 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Moodle SOAP library
*
* @package webservice_soap
* @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once 'Zend/Soap/Client.php'; require_once 'Zend/Soap/Client.php';
/** /**
* Moodle SOAP client class * Moodle SOAP client
*
* It has been implemented for unit testing purpose (all protocols have similar client)
*
* @package webservice_soap
* @copyright 2010 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
class webservice_soap_client extends Zend_Soap_Client { class webservice_soap_client extends Zend_Soap_Client {
/** @var string server url e.g. https://yyyyy.com/server.php */
private $serverurl; private $serverurl;
/** /**
* Constructor * Constructor
* @param string $serverurl *
* @param string $token * @param string $serverurl a Moodle URL
* @param string $token the token used to do the web service call
* @param array $options PHP SOAP client options - see php.net * @param array $options PHP SOAP client options - see php.net
*/ */
public function __construct($serverurl, $token, $options = null) { public function __construct($serverurl, $token, $options = null) {
@ -38,7 +54,8 @@ class webservice_soap_client extends Zend_Soap_Client {
/** /**
* Set the token used to do the SOAP call * Set the token used to do the SOAP call
* @param string $token *
* @param string $token the token used to do the web service call
*/ */
public function set_token($token) { public function set_token($token) {
$wsdl = $this->serverurl . "?wstoken=" . $token . '&wsdl=1'; $wsdl = $this->serverurl . "?wstoken=" . $token . '&wsdl=1';
@ -46,9 +63,10 @@ class webservice_soap_client extends Zend_Soap_Client {
} }
/** /**
* Execute client WS request * Execute client WS request with token authentication
* @param string $functionname *
* @param array $params * @param string $functionname the function name
* @param array $params the parameters of the function
* @return mixed * @return mixed
*/ */
public function call($functionname, $params) { public function call($functionname, $params) {

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* SOAP web service implementation classes and methods. * SOAP web service implementation classes and methods.
* *
* @package webservice * @package webservice_soap
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
@ -28,16 +28,21 @@ require_once 'Zend/Soap/Server.php';
/** /**
* The Zend XMLRPC server but with a fault that returns debuginfo * The Zend XMLRPC server but with a fault that returns debuginfo
*
* @package webservice_soap
* @copyright 2011 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.2
*/ */
class moodle_zend_soap_server extends Zend_Soap_Server { class moodle_zend_soap_server extends Zend_Soap_Server {
/** /**
* Generate a server fault * Generate a server fault
* *
* Note that the arguments are reverse to those of SoapFault. * Note that the arguments are the reverse of those used by SoapFault.
* *
* Moodle note: the difference with the Zend server is that we throw a SoapFault exception * Moodle note: the difference with the Zend server is that we throw a SoapFault exception
* with the debuginfo integrated to the exception message when DEBUG >= NORMAL * with the debuginfo integrated in the exception message when DEBUG >= NORMAL
* *
* If an exception is passed as the first argument, its message and code * If an exception is passed as the first argument, its message and code
* will be used to create the fault object if it has been registered via * will be used to create the fault object if it has been registered via
@ -64,12 +69,18 @@ class moodle_zend_soap_server extends Zend_Soap_Server {
/** /**
* SOAP service server implementation. * SOAP service server implementation.
* @author Petr Skoda (skodak) *
* @package webservice_soap
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.0
*/ */
class webservice_soap_server extends webservice_zend_server { class webservice_soap_server extends webservice_zend_server {
/** /**
* Contructor * Contructor
* @param bool $simple use simple authentication *
* @param string $authmethod authentication method of the web service (WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN, ...)
*/ */
public function __construct($authmethod) { public function __construct($authmethod) {
// must not cache wsdl - the list of functions is created on the fly // must not cache wsdl - the list of functions is created on the fly
@ -87,7 +98,6 @@ class webservice_soap_server extends webservice_zend_server {
/** /**
* Set up zend service class * Set up zend service class
* @return void
*/ */
protected function init_zend_server() { protected function init_zend_server() {
global $CFG; global $CFG;
@ -98,7 +108,7 @@ class webservice_soap_server extends webservice_zend_server {
$username = optional_param('wsusername', '', PARAM_RAW); $username = optional_param('wsusername', '', PARAM_RAW);
$password = optional_param('wspassword', '', PARAM_RAW); $password = optional_param('wspassword', '', PARAM_RAW);
// aparently some clients and zend soap server does not work well with "&" in urls :-( // aparently some clients and zend soap server does not work well with "&" in urls :-(
//TODO: the zend error has been fixed in the last Zend SOAP version, check that is fixed and remove obsolete code //TODO MDL-31151 the zend error has been fixed in the last Zend SOAP version, check that is fixed and remove obsolete code
$url = $CFG->wwwroot.'/webservice/soap/simpleserver.php/'.urlencode($username).'/'.urlencode($password); $url = $CFG->wwwroot.'/webservice/soap/simpleserver.php/'.urlencode($username).'/'.urlencode($password);
// the Zend server is using this uri directly in xml - weird :-( // the Zend server is using this uri directly in xml - weird :-(
$this->zend_server->setUri(htmlentities($url)); $this->zend_server->setUri(htmlentities($url));
@ -111,7 +121,6 @@ class webservice_soap_server extends webservice_zend_server {
if (!optional_param('wsdl', 0, PARAM_BOOL)) { if (!optional_param('wsdl', 0, PARAM_BOOL)) {
$this->zend_server->setReturnResponse(true); $this->zend_server->setReturnResponse(true);
//TODO: the error handling in Zend Soap server is useless, XML-RPC is much, much better :-(
$this->zend_server->registerFaultException('moodle_exception'); $this->zend_server->registerFaultException('moodle_exception');
$this->zend_server->registerFaultException('webservice_parameter_exception'); //deprecated since Moodle 2.2 - kept for backward compatibility $this->zend_server->registerFaultException('webservice_parameter_exception'); //deprecated since Moodle 2.2 - kept for backward compatibility
$this->zend_server->registerFaultException('invalid_parameter_exception'); $this->zend_server->registerFaultException('invalid_parameter_exception');
@ -127,9 +136,7 @@ class webservice_soap_server extends webservice_zend_server {
/** /**
* This method parses the $_POST and $_GET superglobals and looks for * This method parses the $_POST and $_GET superglobals and looks for
* the following information: * the following information:
* 1/ user authentication - username+password or token (wsusername, wspassword and wstoken parameters) * user authentication - username+password or token (wsusername, wspassword and wstoken parameters)
*
* @return void
*/ */
protected function parse_request() { protected function parse_request() {
parent::parse_request(); parent::parse_request();
@ -146,14 +153,12 @@ class webservice_soap_server extends webservice_zend_server {
/** /**
* Send the error information to the WS client * Send the error information to the WS client
* formatted as XML document. * formatted as an XML document.
* @param exception $ex *
* @return void * @param exception $ex the exception to send back
*/ */
protected function send_error($ex=null) { protected function send_error($ex=null) {
// Zend Soap server fault handling is incomplete compared to XML-RPC :-(
// we can not use: echo $this->zend_server->fault($ex);
//TODO: send some better response in XML
if ($ex) { if ($ex) {
$info = $ex->getMessage(); $info = $ex->getMessage();
if (debugging() and isset($ex->debuginfo)) { if (debugging() and isset($ex->debuginfo)) {
@ -177,6 +182,13 @@ class webservice_soap_server extends webservice_zend_server {
echo $xml; echo $xml;
} }
/**
* Generate 'struct' type name
* This type name is the name of a class generated on the fly.
*
* @param external_single_structure $structdesc
* @return string
*/
protected function generate_simple_struct_class(external_single_structure $structdesc) { protected function generate_simple_struct_class(external_single_structure $structdesc) {
global $USER; global $USER;
// let's use unique class name, there might be problem in unit tests // let's use unique class name, there might be problem in unit tests
@ -207,13 +219,20 @@ class '.$classname.' {
/** /**
* SOAP test client class * SOAP test client class
*
* @package webservice_soap
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.0
*/ */
class webservice_soap_test_client implements webservice_test_client_interface { class webservice_soap_test_client implements webservice_test_client_interface {
/** /**
* Execute test client WS request * Execute test client WS request
* @param string $serverurl *
* @param string $function * @param string $serverurl server url (including token parameter or username/password parameters)
* @param array $params * @param string $function function name
* @param array $params parameters of the called function
* @return mixed * @return mixed
*/ */
public function simpletest($serverurl, $function, $params) { public function simpletest($serverurl, $function, $params) {

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* SOAP web service entry point. The authentication is done via tokens. * SOAP web service entry point. The authentication is done via tokens.
* *
* @package webservice * @package webservice_soap
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* XML-RPC web service entry point. The authentication is done via tokens. * SOAP web service entry point. The authentication is done via username/password.
* *
* @package webservice * @package webservice_soap
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -14,12 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Version details * Version details
* *
* @package webservice * @package webservice_soap
* @subpackage soap * @copyright 2009 Petr Skodak
* @copyright 2009 Moodle Pty Ltd (http://moodle.com)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -14,6 +14,7 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Accept uploading files by web service token * Accept uploading files by web service token
* *
@ -23,26 +24,33 @@
* [_FILES] => for example you can send the files with <input type=file>, * [_FILES] => for example you can send the files with <input type=file>,
* or with curl magic: 'file_1' => '@/path/to/file', or ... * or with curl magic: 'file_1' => '@/path/to/file', or ...
* *
* @package moodlecore * @package core_webservice
* @subpackage files
* @copyright 2011 Dongsheng Cai <dongsheng@moodle.com> * @copyright 2011 Dongsheng Cai <dongsheng@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
/**
* AJAX_SCRIPT - exception will be converted into JSON
*/
define('AJAX_SCRIPT', true); define('AJAX_SCRIPT', true);
/**
* NO_MOODLE_COOKIES - we don't want any cookie
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require_once(dirname(dirname(__FILE__)) . '/config.php'); require_once(dirname(dirname(__FILE__)) . '/config.php');
require_once($CFG->dirroot . '/webservice/lib.php'); require_once($CFG->dirroot . '/webservice/lib.php');
$filepath = optional_param('filepath', '/', PARAM_PATH); $filepath = optional_param('filepath', '/', PARAM_PATH);
echo $OUTPUT->header(); echo $OUTPUT->header();
//authenticate the user // authenticate the user
$token = required_param('token', PARAM_ALPHANUM); $token = required_param('token', PARAM_ALPHANUM);
$webservicelib = new webservice(); $webservicelib = new webservice();
$authenticationinfo = $webservicelib->authenticate_user($token); $authenticationinfo = $webservicelib->authenticate_user($token);
//check the user can manage his own files (can upload) // check the user can manage his own files (can upload)
$context = get_context_instance(CONTEXT_USER, $USER->id); $context = get_context_instance(CONTEXT_USER, $USER->id);
require_capability('moodle/user:manageownfiles', $context); require_capability('moodle/user:manageownfiles', $context);

View File

@ -1,24 +1,27 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
///////////////////////////////////////////////////////////////////////////
// // /**
// This file is part of Moodle - http://moodle.org/ // * Web services auto-generated documentation
// Moodle - Modular Object-Oriented Dynamic Learning Environment // *
// // * @package core_webservice
// Moodle is free software: you can redistribute it and/or modify // * @copyright 2009 Jerome Mouneyrac <jerome@moodle.com>
// it under the terms of the GNU General Public License as published by // * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
// the Free Software Foundation, either version 3 of the License, or // */
// (at your option) any later version. //
// //
// Moodle 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 General Public License for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. //
// //
///////////////////////////////////////////////////////////////////////////
require_once('../config.php'); require_once('../config.php');
require($CFG->dirroot . '/webservice/lib.php'); require($CFG->dirroot . '/webservice/lib.php');
@ -29,14 +32,14 @@ require_sesskey();
$usercontext = get_context_instance(CONTEXT_USER, $USER->id); $usercontext = get_context_instance(CONTEXT_USER, $USER->id);
$tokenid = required_param('id', PARAM_INT); $tokenid = required_param('id', PARAM_INT);
//PAGE settings // PAGE settings
$PAGE->set_context($usercontext); $PAGE->set_context($usercontext);
$PAGE->set_url('/user/wsdoc.php'); $PAGE->set_url('/user/wsdoc.php');
$PAGE->set_title(get_string('documentation', 'webservice')); $PAGE->set_title(get_string('documentation', 'webservice'));
$PAGE->set_heading(get_string('documentation', 'webservice')); $PAGE->set_heading(get_string('documentation', 'webservice'));
$PAGE->set_pagelayout('standard'); $PAGE->set_pagelayout('standard');
//nav bar // nav bar
$PAGE->navbar->ignore_active(true); $PAGE->navbar->ignore_active(true);
$PAGE->navbar->add(get_string('usercurrentsettings')); $PAGE->navbar->add(get_string('usercurrentsettings'));
$PAGE->navbar->add(get_string('securitykeys', 'webservice'), $PAGE->navbar->add(get_string('securitykeys', 'webservice'),
@ -44,13 +47,13 @@ $PAGE->navbar->add(get_string('securitykeys', 'webservice'),
array('id' => $tokenid, 'sesskey' => sesskey()))); array('id' => $tokenid, 'sesskey' => sesskey())));
$PAGE->navbar->add(get_string('documentation', 'webservice')); $PAGE->navbar->add(get_string('documentation', 'webservice'));
//check web service are enabled // check web service are enabled
if (empty($CFG->enablewsdocumentation)) { if (empty($CFG->enablewsdocumentation)) {
echo get_string('wsdocumentationdisable', 'webservice'); echo get_string('wsdocumentationdisable', 'webservice');
die; die;
} }
//check that the current user is the token user // check that the current user is the token user
$webservice = new webservice(); $webservice = new webservice();
$token = $webservice->get_token_by_id($tokenid); $token = $webservice->get_token_by_id($tokenid);
if (empty($token) or empty($token->userid) or empty($USER->id) if (empty($token) or empty($token->userid) or empty($USER->id)
@ -67,22 +70,22 @@ foreach ($functions as $function) {
$functiondescs[$function->name] = external_function_info($function); $functiondescs[$function->name] = external_function_info($function);
} }
//get activated protocol // get activated protocol
$activatedprotocol = array(); $activatedprotocol = array();
$activatedprotocol['rest'] = webservice_protocol_is_enabled('rest'); $activatedprotocol['rest'] = webservice_protocol_is_enabled('rest');
$activatedprotocol['xmlrpc'] = webservice_protocol_is_enabled('xmlrpc'); $activatedprotocol['xmlrpc'] = webservice_protocol_is_enabled('xmlrpc');
/// Check if we are in printable mode // Check if we are in printable mode
$printableformat = optional_param('print', false, PARAM_BOOL); $printableformat = optional_param('print', false, PARAM_BOOL);
/// OUTPUT // OUTPUT
echo $OUTPUT->header(); echo $OUTPUT->header();
$renderer = $PAGE->get_renderer('core', 'webservice'); $renderer = $PAGE->get_renderer('core', 'webservice');
echo $renderer->documentation_html($functiondescs, echo $renderer->documentation_html($functiondescs,
$printableformat, $activatedprotocol, array('id' => $tokenid)); $printableformat, $activatedprotocol, array('id' => $tokenid));
/// trigger browser print operation // trigger browser print operation
if (!empty($printableformat)) { if (!empty($printableformat)) {
$PAGE->requires->js_function_call('window.print', array()); $PAGE->requires->js_function_call('window.print', array());
} }

View File

@ -1,4 +1,28 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* XML-RPC server related capabilities
*
* @package webservice_xmlrpc
* @category access
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$capabilities = array( $capabilities = array(

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,13 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Strings for component 'webservice_xmlrpc', language 'en', branch 'MOODLE_20_STABLE' * Strings for component 'webservice_xmlrpc', language 'en', branch 'MOODLE_20_STABLE'
* *
* @package webservice_xmlrpc * @package webservice_xmlrpc
* @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @category string
* @copyright 2010 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,19 +14,36 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* 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'; require_once 'Zend/XmlRpc/Client.php';
/** /**
* XML-RPC client class * 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 { class webservice_xmlrpc_client extends Zend_XmlRpc_Client {
/** @var string server url e.g. https://yyyyy.com/server.php */
private $serverurl; private $serverurl;
/** /**
* Constructor * Constructor
* @param string $serverurl *
* @param string $token * @param string $serverurl a Moodle URL
* @param string $token the token used to do the web service call
*/ */
public function __construct($serverurl, $token) { public function __construct($serverurl, $token) {
$this->serverurl = $serverurl; $this->serverurl = $serverurl;
@ -37,16 +53,18 @@ class webservice_xmlrpc_client extends Zend_XmlRpc_Client {
/** /**
* Set the token used to do the XML-RPC call * Set the token used to do the XML-RPC call
* @param string $token *
* @param string $token the token used to do the web service call
*/ */
public function set_token($token) { public function set_token($token) {
$this->_serverAddress = $this->serverurl . '?wstoken=' . $token; $this->_serverAddress = $this->serverurl . '?wstoken=' . $token;
} }
/** /**
* Execute client WS request * Execute client WS request with token authentication
* @param string $functionname *
* @param array $params * @param string $functionname the function name
* @param array $params the parameters of the function
* @return mixed * @return mixed
*/ */
public function call($functionname, $params) { public function call($functionname, $params) {

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,11 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* XML-RPC web service implementation classes and methods. * XML-RPC web service implementation classes and methods.
* *
* @package webservice * @package webservice_xmlrpc
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
@ -28,6 +28,11 @@ require_once 'Zend/XmlRpc/Server.php';
/** /**
* The Zend XMLRPC server but with a fault that return debuginfo * The Zend XMLRPC server but with a fault that return debuginfo
*
* @package webservice_xmlrpc
* @copyright 2011 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.2
*/ */
class moodle_zend_xmlrpc_server extends Zend_XmlRpc_Server { class moodle_zend_xmlrpc_server extends Zend_XmlRpc_Server {
@ -57,12 +62,18 @@ class moodle_zend_xmlrpc_server extends Zend_XmlRpc_Server {
/** /**
* XML-RPC service server implementation. * XML-RPC service server implementation.
* @author Petr Skoda (skodak) *
* @package webservice_xmlrpc
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.0
*/ */
class webservice_xmlrpc_server extends webservice_zend_server { class webservice_xmlrpc_server extends webservice_zend_server {
/** /**
* Contructor * Contructor
* @param integer $authmethod authentication method one of WEBSERVICE_AUTHMETHOD_* *
* @param string $authmethod authentication method of the web service (WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN, ...)
*/ */
public function __construct($authmethod) { public function __construct($authmethod) {
require_once 'Zend/XmlRpc/Server.php'; require_once 'Zend/XmlRpc/Server.php';
@ -72,7 +83,6 @@ class webservice_xmlrpc_server extends webservice_zend_server {
/** /**
* Set up zend service class * Set up zend service class
* @return void
*/ */
protected function init_zend_server() { protected function init_zend_server() {
parent::init_zend_server(); parent::init_zend_server();
@ -89,13 +99,18 @@ class webservice_xmlrpc_server extends webservice_zend_server {
/** /**
* XML-RPC test client class * XML-RPC test client class
*
* @package webservice_xmlrpc
* @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @since 2.0
*/ */
class webservice_xmlrpc_test_client implements webservice_test_client_interface { class webservice_xmlrpc_test_client implements webservice_test_client_interface {
/** /**
* Execute test client WS request * Execute test client WS request
* @param string $serverurl * @param string $serverurl server url (including token parameter or username/password parameters)
* @param string $function * @param string $function function name
* @param array $params * @param array $params parameters of the called function
* @return mixed * @return mixed
*/ */
public function simpletest($serverurl, $function, $params) { public function simpletest($serverurl, $function, $params) {

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* XML-RPC web service entry point. The authentication is done via tokens. * XML-RPC web service entry point. The authentication is done via tokens.
* *
* @package webservice * @package webservice_xmlrpc
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Jerome Mouneyrac
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -1,5 +1,4 @@
<?php <?php
// This file is part of Moodle - http://moodle.org/ // This file is part of Moodle - http://moodle.org/
// //
// Moodle is free software: you can redistribute it and/or modify // Moodle is free software: you can redistribute it and/or modify
@ -15,16 +14,23 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* XML-RPC web service entry point. The authentication is done via tokens. * XML-RPC web service entry point. The authentication is done via username/password.
* *
* @package webservice * @package webservice_xmlrpc
* @copyright 2009 Moodle Pty Ltd (http://moodle.com) * @copyright 2009 Petr Skodak
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */
// disable moodle specific debug messages and any errors in output /**
* NO_DEBUG_DISPLAY - disable moodle specific debug messages and any errors in output
*/
define('NO_DEBUG_DISPLAY', true); define('NO_DEBUG_DISPLAY', true);
/**
* NO_MOODLE_COOKIES - no cookies with web service
*/
define('NO_MOODLE_COOKIES', true); define('NO_MOODLE_COOKIES', true);
require('../../config.php'); require('../../config.php');

View File

@ -14,12 +14,12 @@
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/** /**
* Version details * Version details
* *
* @package webservice * @package webservice_xmlrpc
* @subpackage xmlrpc * @copyright 2009 Petr Skodak
* @copyright 2009 Moodle Pty Ltd (http://moodle.com)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/ */