diff options
author | Morris Jobke <hey@morrisjobke.de> | 2014-10-30 14:05:25 +0100 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2014-10-30 14:05:25 +0100 |
commit | e2001c6d317e6a0dc797538d8f02af11bdae8a04 (patch) | |
tree | ba1814e305c6c796106ac96539f1a9cecef1d181 /lib | |
parent | 5f76f825737eca080cb621b2d4364015af7f6bac (diff) | |
parent | 0696099bad56727d96c60f6221fe02dc7c71f511 (diff) | |
download | nextcloud-server-e2001c6d317e6a0dc797538d8f02af11bdae8a04.tar.gz nextcloud-server-e2001c6d317e6a0dc797538d8f02af11bdae8a04.zip |
Merge pull request #11821 from owncloud/generic-response
Add a generic data response
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/appframework/http/dispatcher.php | 5 | ||||
-rw-r--r-- | lib/public/appframework/controller.php | 14 | ||||
-rw-r--r-- | lib/public/appframework/http/dataresponse.php | 79 | ||||
-rw-r--r-- | lib/public/appframework/http/response.php | 14 |
4 files changed, 107 insertions, 5 deletions
diff --git a/lib/private/appframework/http/dispatcher.php b/lib/private/appframework/http/dispatcher.php index 7f2717951a5..29a661d5743 100644 --- a/lib/private/appframework/http/dispatcher.php +++ b/lib/private/appframework/http/dispatcher.php @@ -30,6 +30,7 @@ use \OC\AppFramework\Utility\ControllerMethodReflector; use OCP\AppFramework\Controller; use OCP\AppFramework\Http\Response; +use OCP\AppFramework\Http\DataResponse; use OCP\IRequest; @@ -154,8 +155,8 @@ class Dispatcher { $response = call_user_func_array(array($controller, $methodName), $arguments); - // format response if not of type response - if(!($response instanceof Response)) { + // format response + if($response instanceof DataResponse || !($response instanceof Response)) { // get format from the url format or request format parameter $format = $this->request->getParam('format'); diff --git a/lib/public/appframework/controller.php b/lib/public/appframework/controller.php index b22eb73343a..398304e6feb 100644 --- a/lib/public/appframework/controller.php +++ b/lib/public/appframework/controller.php @@ -29,6 +29,7 @@ namespace OCP\AppFramework; use OCP\AppFramework\Http\TemplateResponse; use OCP\AppFramework\Http\JSONResponse; +use OCP\AppFramework\Http\DataResponse; use OCP\IRequest; @@ -63,8 +64,17 @@ abstract class Controller { // default responders $this->responders = array( - 'json' => function ($response) { - return new JSONResponse($response); + 'json' => function ($data) { + if ($data instanceof DataResponse) { + $response = new JSONResponse( + $data->getData(), + $data->getStatus() + ); + $response->setHeaders($data->getHeaders()); + return $response; + } else { + return new JSONResponse($data); + } } ); } diff --git a/lib/public/appframework/http/dataresponse.php b/lib/public/appframework/http/dataresponse.php new file mode 100644 index 00000000000..5c21de325e1 --- /dev/null +++ b/lib/public/appframework/http/dataresponse.php @@ -0,0 +1,79 @@ +<?php +/** + * ownCloud - App Framework + * + * @author Bernhard Posselt + * @copyright 2014 Bernhard Posselt <dev@bernhard-posselt.com> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library 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 AFFERO GENERAL PUBLIC LICENSE for more details. + * + * You should have received a copy of the GNU Affero General Public + * License along with this library. If not, see <http://www.gnu.org/licenses/>. + * + */ + +/** + * Public interface of ownCloud for apps to use. + * AppFramework\HTTP\DataResponse class + */ + +namespace OCP\AppFramework\Http; + +use OCP\AppFramework\Http; + +/** + * A generic DataResponse class that is used to return generic data responses + * for responders to transform + */ +class DataResponse extends Response { + + /** + * response data + * @var array|object + */ + protected $data; + + + /** + * @param array|object $data the object or array that should be transformed + * @param int $statusCode the Http status code, defaults to 200 + * @param array $headers additional key value based headers + */ + public function __construct($data=array(), $statusCode=Http::STATUS_OK, + array $headers=array()) { + $this->data = $data; + $this->setStatus($statusCode); + $this->setHeaders(array_merge($this->getHeaders(), $headers)); + } + + + /** + * Sets values in the data json array + * @param array|object $data an array or object which will be transformed + * @return DataResponse Reference to this object + */ + public function setData($data){ + $this->data = $data; + + return $this; + } + + + /** + * Used to get the set parameters + * @return array the data + */ + public function getData(){ + return $this->data; + } + + +} diff --git a/lib/public/appframework/http/response.php b/lib/public/appframework/http/response.php index 20e936bb860..354911fee21 100644 --- a/lib/public/appframework/http/response.php +++ b/lib/public/appframework/http/response.php @@ -93,7 +93,7 @@ class Response { */ public function addHeader($name, $value) { $name = trim($name); // always remove leading and trailing whitespace - // to be able to reliably check for security + // to be able to reliably check for security // headers if(is_null($value)) { @@ -107,6 +107,18 @@ class Response { /** + * Set the headers + * @param array key value header pairs + * @return Response Reference to this object + */ + public function setHeaders($headers) { + $this->headers = $headers; + + return $this; + } + + + /** * Returns the set headers * @return array the headers */ |