X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=src%2FServer.php;h=9b4c59dfc14f05f1aac9edeb70af13349042b089;hb=c672d42d1109a5daa4cf243ba1f0383717e43104;hp=d530fcdef0f8c8a3603e9db03a8668b7076e1156;hpb=22592a7334c7ae95b074c4e967cf18e519284f40;p=plcapi.git diff --git a/src/Server.php b/src/Server.php index d530fcd..9b4c59d 100644 --- a/src/Server.php +++ b/src/Server.php @@ -51,7 +51,8 @@ class Server public $allow_system_funcs = true; /** * List of charset encodings natively accepted for requests. - * Set at constructor time. + * Set at constructor time. + * UNUSED so far... */ public $accepted_charset_encodings = array(); /** @@ -914,7 +915,8 @@ class Server if ($call->kindOf() != 'struct') { return static::_xmlrpcs_multicall_error('notstruct'); } - $methName = @$call->structmem('methodName'); + //$methName = $call->structmem('methodName'); + $methName = @$call['methodName']; if (!$methName) { return static::_xmlrpcs_multicall_error('nomethod'); } @@ -925,20 +927,22 @@ class Server return static::_xmlrpcs_multicall_error('recursion'); } - $params = @$call->structmem('params'); + //$params = @$call->structmem('params'); + $params = @$call['params']; if (!$params) { return static::_xmlrpcs_multicall_error('noparams'); } if ($params->kindOf() != 'array') { return static::_xmlrpcs_multicall_error('notarray'); } - $numParams = $params->count(); + //$numParams = $params->count(); $req = new Request($methName->scalarval()); - for ($i = 0; $i < $numParams; $i++) { - if (!$req->addParam($params->arraymem($i))) { - $i++; - + //for ($i = 0; $i < $numParams; $i++) { + foreach($params as $i => $param) { + //if (!$req->addParam($params->arraymem($i))) { + if (!$req->addParam($param)) { + $i++; // for error message, we count params from 1 return static::_xmlrpcs_multicall_error(new Response(0, PhpXmlRpc::$xmlrpcerr['incorrect_params'], PhpXmlRpc::$xmlrpcstr['incorrect_params'] . ": probable xml error in param " . $i)); @@ -999,10 +1003,11 @@ class Server // let accept a plain list of php parameters, beside a single xmlrpc msg object if (is_object($req)) { $calls = $req->getParam(0); - $numCalls = $calls->count(); - for ($i = 0; $i < $numCalls; $i++) { - $call = $calls->arraymem($i); - $result[$i] = static::_xmlrpcs_multicall_do_call($server, $call); + //$numCalls = $calls->count(); + //for ($i = 0; $i < $numCalls; $i++) { + foreach($calls as $call) { + //$call = $calls->arraymem($i); + $result[] = static::_xmlrpcs_multicall_do_call($server, $call); } } else { $numCalls = count($req);