From 6acdf9bd3761e63ab01f4cc2895d0f0ff11eaf97 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20M=C3=BCller?= Date: Wed, 2 Aug 2017 18:36:39 +0200 Subject: [PATCH] Properly set the status text in the ocs response for v2 calls - fixes https://github.com/owncloud/notifications/issues/103 --- lib/private/AppFramework/Http/Request.php | 2 +- lib/public/AppFramework/Http/OCSResponse.php | 17 ++++++++++++----- lib/public/AppFramework/OCSController.php | 4 +++- .../Controller/OCSControllerTest.php | 2 +- 4 files changed, 17 insertions(+), 8 deletions(-) diff --git a/lib/private/AppFramework/Http/Request.php b/lib/private/AppFramework/Http/Request.php index a9f5b27f4915..f033ea85a4cf 100644 --- a/lib/private/AppFramework/Http/Request.php +++ b/lib/private/AppFramework/Http/Request.php @@ -120,7 +120,7 @@ class Request implements \ArrayAccess, \Countable, IRequest { */ public function __construct(array $vars= [], ISecureRandom $secureRandom = null, - IConfig $config, + IConfig $config = null, CsrfTokenManager $csrfTokenManager = null, $stream = 'php://input') { $this->inputStream = $stream; diff --git a/lib/public/AppFramework/Http/OCSResponse.php b/lib/public/AppFramework/Http/OCSResponse.php index 7716fecdd9d8..fdd5173900a5 100644 --- a/lib/public/AppFramework/Http/OCSResponse.php +++ b/lib/public/AppFramework/Http/OCSResponse.php @@ -29,8 +29,7 @@ */ namespace OCP\AppFramework\Http; - -use OCP\AppFramework\Http; +use OC\OCS\Result; /** * A renderer for OCS responses @@ -44,26 +43,30 @@ class OCSResponse extends Response { private $message; private $itemscount; private $itemsperpage; + private $isV2; /** * generates the xml or json response for the API call from an multidimenional data array. + * * @param string $format * @param int $statuscode * @param string $message * @param array $data * @param int|string $itemscount * @param int|string $itemsperpage + * @param bool $isV2 * @since 8.1.0 */ public function __construct($format, $statuscode, $message, $data=[], $itemscount='', - $itemsperpage='') { + $itemsperpage='', $isV2 = false) { $this->format = $format; $this->statuscode = $statuscode; $this->message = $message; $this->data = $data; $this->itemscount = $itemscount; $this->itemsperpage = $itemsperpage; + $this->isV2 = $isV2; // set the correct header based on the format parameter if ($format === 'json') { @@ -82,11 +85,15 @@ public function __construct($format, $statuscode, $message, * @since 8.1.0 */ public function render() { - $r = new \OC_OCS_Result($this->data, $this->statuscode, $this->message); + $r = new Result($this->data, $this->statuscode, $this->message); $r->setTotalItems($this->itemscount); $r->setItemsPerPage($this->itemsperpage); + $meta = $r->getMeta(); + if ($this->isV2 && $this->statuscode === 200) { + $meta['status'] = 'ok'; + } - return \OC_API::renderResult($this->format, $r->getMeta(), $r->getData()); + return \OC_API::renderResult($this->format, $meta, $r->getData()); } /** diff --git a/lib/public/AppFramework/OCSController.php b/lib/public/AppFramework/OCSController.php index 51934b9043e1..5b5fef8a9ee2 100644 --- a/lib/public/AppFramework/OCSController.php +++ b/lib/public/AppFramework/OCSController.php @@ -105,10 +105,12 @@ private function buildOCSResponse($format, $data) { $params[$key] = $value; } + $isV2 = substr($this->request->getScriptName(), -11) === '/ocs/v2.php'; + $resp = new OCSResponse( $format, $params['statuscode'], $params['message'], $params['data'], - $params['itemscount'], $params['itemsperpage'] + $params['itemscount'], $params['itemsperpage'], $isV2 ); if (isset($data['headers'])) { foreach ($data['headers'] as $key => $value) { diff --git a/tests/lib/AppFramework/Controller/OCSControllerTest.php b/tests/lib/AppFramework/Controller/OCSControllerTest.php index 66d53a3edda2..700358528d52 100644 --- a/tests/lib/AppFramework/Controller/OCSControllerTest.php +++ b/tests/lib/AppFramework/Controller/OCSControllerTest.php @@ -191,7 +191,7 @@ public function testStatusCodeMapping() { $this->createMock(ISecureRandom::class), $configMock )); - $expected = '{"ocs":{"meta":{"status":"failure","statuscode":200,"message":"OK",' . + $expected = '{"ocs":{"meta":{"status":"ok","statuscode":200,"message":"OK",' . '"totalitems":"","itemsperpage":""},"data":{"test":"hi"}}}'; $params = [ 'data' => [