aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2014-10-30 14:05:25 +0100
committerMorris Jobke <hey@morrisjobke.de>2014-10-30 14:05:25 +0100
commite2001c6d317e6a0dc797538d8f02af11bdae8a04 (patch)
treeba1814e305c6c796106ac96539f1a9cecef1d181 /lib
parent5f76f825737eca080cb621b2d4364015af7f6bac (diff)
parent0696099bad56727d96c60f6221fe02dc7c71f511 (diff)
downloadnextcloud-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.php5
-rw-r--r--lib/public/appframework/controller.php14
-rw-r--r--lib/public/appframework/http/dataresponse.php79
-rw-r--r--lib/public/appframework/http/response.php14
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
*/