mirror of
https://github.com/moodle/moodle.git
synced 2025-01-18 05:58:34 +01:00
Merged branch 'MDL-29277' of git://github.com/mouneyrac/moodle.git with improvements
This commit is contained in:
commit
92fe97f922
@ -35,8 +35,8 @@ $string['configmoodle'] = 'Moodle has not been configured yet. You need to edit
|
||||
$string['erroroccur'] = 'An error has occurred during this process';
|
||||
$string['invalidarraysize'] = 'Incorrect size of arrays in params of {$a}';
|
||||
$string['invalideventdata'] = 'Incorrect eventadata submitted: {$a}';
|
||||
$string['invalidparameter'] = 'Invalid parameter value detected, execution can not continue.';
|
||||
$string['invalidresponse'] = 'Invalid response value detected, execution can not continue.';
|
||||
$string['invalidparameter'] = 'Invalid parameter value detected';
|
||||
$string['invalidresponse'] = 'Invalid response value detected';
|
||||
$string['missingconfigversion'] = 'Config table does not contain version, can not continue, sorry.';
|
||||
$string['modulenotexist'] = '{$a} module doesn\'t exist';
|
||||
$string['morethanonerecordinfetch'] = 'Found more than one record in fetch() !';
|
||||
|
@ -79,17 +79,8 @@ $string['errorcatcontextnotvalid'] = 'You cannot execute functions in the catego
|
||||
$string['errorcodes'] = 'Error message';
|
||||
$string['errorcoursecontextnotvalid'] = 'You cannot execute functions in the course context (course id:{$a->courseid}). The context error message was: {$a->message}';
|
||||
$string['errorinvalidparam'] = 'The param "{$a}" is invalid.';
|
||||
$string['errorinvalidparamsapi'] = 'Invalid external api parameter';
|
||||
$string['errorinvalidparamsdesc'] = 'Invalid external api description';
|
||||
$string['errorinvalidresponseapi'] = 'Invalid external api response';
|
||||
$string['errorinvalidresponsedesc'] = 'Invalid external api response description';
|
||||
$string['errormissingkey'] = 'Missing required key in single structure: {$a}';
|
||||
$string['errornotemptydefaultparamarray'] = 'The web service description parameter named \'{$a}\' is an single or multiple structure. The default can only be empty array. Check web service description.';
|
||||
$string['erroronlyarray'] = 'Only arrays accepted.';
|
||||
$string['erroroptionalparamarray'] = 'The web service description parameter named \'{$a}\' is an single or multiple structure. It can not be set as VALUE_OPTIONAL. Check web service description.';
|
||||
$string['errorresponsemissingkey'] = 'Error in response - Missing following required key in a single structure: {$a}';
|
||||
$string['errorscalartype'] = 'Scalar type expected, array or object received.';
|
||||
$string['errorunexpectedkey'] = 'Unexpected keys ({$a}) detected in parameter array.';
|
||||
$string['execute'] = 'Execute';
|
||||
$string['executewarnign'] = 'WARNING: If you press execute your database will be modified and changes can not be reverted automatically!';
|
||||
$string['externalservice'] = 'External service';
|
||||
|
@ -149,7 +149,7 @@ class external_api {
|
||||
public static function validate_parameters(external_description $description, $params) {
|
||||
if ($description instanceof external_value) {
|
||||
if (is_array($params) or is_object($params)) {
|
||||
throw new invalid_parameter_exception(get_string('errorscalartype', 'webservice'));
|
||||
throw new invalid_parameter_exception('Scalar type expected, array or object received.');
|
||||
}
|
||||
|
||||
if ($description->type == PARAM_BOOL) {
|
||||
@ -158,48 +158,50 @@ class external_api {
|
||||
return (bool)$params;
|
||||
}
|
||||
}
|
||||
return validate_param($params, $description->type, $description->allownull, get_string('errorinvalidparamsapi', 'webservice'));
|
||||
$debuginfo = 'Invalid external api parameter: the value is "' . $params .
|
||||
'", the server was expecting "' . $description->type . '" type';
|
||||
return validate_param($params, $description->type, $description->allownull, $debuginfo);
|
||||
|
||||
} else if ($description instanceof external_single_structure) {
|
||||
if (!is_array($params)) {
|
||||
throw new invalid_parameter_exception(get_string('erroronlyarray', 'webservice'));
|
||||
throw new invalid_parameter_exception('Only arrays accepted. The bad value is: \''
|
||||
. print_r($params, true) . '\'');
|
||||
}
|
||||
$result = array();
|
||||
foreach ($description->keys as $key=>$subdesc) {
|
||||
if (!array_key_exists($key, $params)) {
|
||||
if ($subdesc->required == VALUE_REQUIRED) {
|
||||
throw new invalid_parameter_exception(get_string('errormissingkey', 'webservice', $key));
|
||||
throw new invalid_parameter_exception('Missing required key in single structure: '. $key);
|
||||
}
|
||||
if ($subdesc->required == VALUE_DEFAULT) {
|
||||
try {
|
||||
$result[$key] = self::validate_parameters($subdesc, $subdesc->default);
|
||||
} catch (invalid_parameter_exception $e) {
|
||||
throw new webservice_parameter_exception('invalidextparam',$key);
|
||||
//we are only interested by exceptions returned by validate_param() and validate_parameters()
|
||||
//(in order to build the path to the faulty attribut)
|
||||
throw new invalid_parameter_exception($key." => ".$e->getMessage() . ': ' .$e->debuginfo);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
try {
|
||||
$result[$key] = self::validate_parameters($subdesc, $params[$key]);
|
||||
} catch (invalid_parameter_exception $e) {
|
||||
//it's ok to display debug info as here the information is useful for ws client/dev
|
||||
throw new webservice_parameter_exception('invalidextparam',$key." (".$e->debuginfo.")");
|
||||
//we are only interested by exceptions returned by validate_param() and validate_parameters()
|
||||
//(in order to build the path to the faulty attribut)
|
||||
throw new invalid_parameter_exception($key." => ".$e->getMessage() . ': ' .$e->debuginfo);
|
||||
}
|
||||
}
|
||||
unset($params[$key]);
|
||||
}
|
||||
if (!empty($params)) {
|
||||
//list all unexpected keys
|
||||
$keys = '';
|
||||
foreach($params as $key => $value) {
|
||||
$keys .= $key . ',';
|
||||
}
|
||||
throw new invalid_parameter_exception(get_string('errorunexpectedkey', 'webservice', $keys));
|
||||
throw new invalid_parameter_exception('Unexpected keys (' . implode(', ', array_keys($params)) . ') detected in parameter array.');
|
||||
}
|
||||
return $result;
|
||||
|
||||
} else if ($description instanceof external_multiple_structure) {
|
||||
if (!is_array($params)) {
|
||||
throw new invalid_parameter_exception(get_string('erroronlyarray', 'webservice'));
|
||||
throw new invalid_parameter_exception('Only arrays accepted. The bad value is: \''
|
||||
. print_r($params, true) . '\'');
|
||||
}
|
||||
$result = array();
|
||||
foreach ($params as $param) {
|
||||
@ -208,7 +210,7 @@ class external_api {
|
||||
return $result;
|
||||
|
||||
} else {
|
||||
throw new invalid_parameter_exception(get_string('errorinvalidparamsdesc', 'webservice'));
|
||||
throw new invalid_parameter_exception('Invalid external api description');
|
||||
}
|
||||
}
|
||||
|
||||
@ -225,7 +227,7 @@ class external_api {
|
||||
public static function clean_returnvalue(external_description $description, $response) {
|
||||
if ($description instanceof external_value) {
|
||||
if (is_array($response) or is_object($response)) {
|
||||
throw new invalid_response_exception(get_string('errorscalartype', 'webservice'));
|
||||
throw new invalid_response_exception('Scalar type expected, array or object received.');
|
||||
}
|
||||
|
||||
if ($description->type == PARAM_BOOL) {
|
||||
@ -234,33 +236,42 @@ class external_api {
|
||||
return (bool)$response;
|
||||
}
|
||||
}
|
||||
return validate_param($response, $description->type, $description->allownull, get_string('errorinvalidresponseapi', 'webservice'));
|
||||
$debuginfo = 'Invalid external api response: the value is "' . $response .
|
||||
'", the server was expecting "' . $description->type . '" type';
|
||||
try {
|
||||
return validate_param($response, $description->type, $description->allownull, $debuginfo);
|
||||
} catch (invalid_parameter_exception $e) {
|
||||
//proper exception name, to be recursively catched to build the path to the faulty attribut
|
||||
throw new invalid_response_exception($e->debuginfo);
|
||||
}
|
||||
|
||||
} else if ($description instanceof external_single_structure) {
|
||||
if (!is_array($response)) {
|
||||
throw new invalid_response_exception(get_string('erroronlyarray', 'webservice'));
|
||||
throw new invalid_response_exception('Only arrays accepted. The bad value is: \'' .
|
||||
print_r($response, true) . '\'');
|
||||
}
|
||||
$result = array();
|
||||
foreach ($description->keys as $key=>$subdesc) {
|
||||
if (!array_key_exists($key, $response)) {
|
||||
if ($subdesc->required == VALUE_REQUIRED) {
|
||||
throw new webservice_parameter_exception('errorresponsemissingkey', $key);
|
||||
throw new invalid_response_exception('Error in response - Missing following required key in a single structure: ' . $key);
|
||||
}
|
||||
if ($subdesc instanceof external_value) {
|
||||
if ($subdesc->required == VALUE_DEFAULT) {
|
||||
try {
|
||||
$result[$key] = self::clean_returnvalue($subdesc, $subdesc->default);
|
||||
} catch (Exception $e) {
|
||||
throw new webservice_parameter_exception('invalidextresponse',$key." (".$e->debuginfo.")");
|
||||
} catch (invalid_response_exception $e) {
|
||||
//build the path to the faulty attribut
|
||||
throw new invalid_response_exception($key." => ".$e->getMessage() . ': ' . $e->debuginfo);
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
try {
|
||||
$result[$key] = self::clean_returnvalue($subdesc, $response[$key]);
|
||||
} catch (Exception $e) {
|
||||
//it's ok to display debug info as here the information is useful for ws client/dev
|
||||
throw new webservice_parameter_exception('invalidextresponse',$key." (".$e->debuginfo.")");
|
||||
} catch (invalid_response_exception $e) {
|
||||
//build the path to the faulty attribut
|
||||
throw new invalid_response_exception($key." => ".$e->getMessage() . ': ' . $e->debuginfo);
|
||||
}
|
||||
}
|
||||
unset($response[$key]);
|
||||
@ -270,7 +281,8 @@ class external_api {
|
||||
|
||||
} else if ($description instanceof external_multiple_structure) {
|
||||
if (!is_array($response)) {
|
||||
throw new invalid_response_exception(get_string('erroronlyarray', 'webservice'));
|
||||
throw new invalid_response_exception('Only arrays accepted. The bad value is: \'' .
|
||||
print_r($response, true) . '\'');
|
||||
}
|
||||
$result = array();
|
||||
foreach ($response as $param) {
|
||||
@ -279,7 +291,7 @@ class external_api {
|
||||
return $result;
|
||||
|
||||
} else {
|
||||
throw new invalid_response_exception(get_string('errorinvalidresponsedesc', 'webservice'));
|
||||
throw new invalid_response_exception('Invalid external api response description');
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -139,7 +139,7 @@ class require_login_exception extends moodle_exception {
|
||||
|
||||
/**
|
||||
* Web service parameter exception class
|
||||
*
|
||||
* @deprecated since Moodle 2.2 - use moodle exception instead
|
||||
* This exception must be thrown to the web service client when a web service parameter is invalid
|
||||
* The error string is gotten from webservice.php
|
||||
*/
|
||||
@ -149,8 +149,8 @@ class webservice_parameter_exception extends moodle_exception {
|
||||
* @param string $errorcode The name of the string from webservice.php to print
|
||||
* @param string $a The name of the parameter
|
||||
*/
|
||||
function __construct($errorcode=null, $a = '') {
|
||||
parent::__construct($errorcode, 'webservice', '', $a, null);
|
||||
function __construct($errorcode=null, $a = '', $debuginfo = null) {
|
||||
parent::__construct($errorcode, 'webservice', '', $a, $debuginfo);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -76,7 +76,7 @@ class webservice_soap_server extends webservice_zend_server {
|
||||
$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('webservice_parameter_exception');
|
||||
$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_response_exception');
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user