2013-05-18 04:56:59 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ownCloud - HTTP Middleware
|
|
|
|
*
|
|
|
|
* @author Thomas Tanghus
|
|
|
|
* @copyright 2013 Thomas Tanghus (thomas@tanghus.net)
|
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
namespace OCA\Contacts\Middleware;
|
|
|
|
|
2013-10-11 14:47:17 +02:00
|
|
|
use OCA\Contacts\Controller,
|
|
|
|
OCA\Contacts\JSONResponse,
|
|
|
|
OCP\AppFramework\Middleware,
|
|
|
|
OCP\AppFramework\Http\Response;
|
2013-05-18 04:56:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Used to intercept exceptions thrown in controllers and backends
|
|
|
|
* and transform them into valid HTTP responses.
|
|
|
|
*/
|
2013-10-11 14:47:17 +02:00
|
|
|
class Http extends Middleware {
|
2013-05-18 04:56:59 +02:00
|
|
|
|
|
|
|
private $api;
|
|
|
|
|
|
|
|
/**
|
2013-10-11 14:47:17 +02:00
|
|
|
* @param IAppContainer $app an instance of the app container
|
2013-05-18 04:56:59 +02:00
|
|
|
*/
|
2013-10-11 14:47:17 +02:00
|
|
|
public function __construct($app) {
|
2013-10-01 19:13:28 +02:00
|
|
|
//$this->api = $api;
|
2013-05-18 04:56:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If an Exception is being caught, return a JSON error response with
|
|
|
|
* a suitable status code
|
|
|
|
* @param Controller $controller the controller that is being called
|
|
|
|
* @param string $methodName the name of the method that will be called on
|
|
|
|
* the controller
|
|
|
|
* @param \Exception $exception the thrown exception
|
|
|
|
* @return Response a Response object
|
|
|
|
*/
|
|
|
|
public function afterException($controller, $methodName, \Exception $exception){
|
|
|
|
// If there's no proper status code associated, set it to 500.
|
|
|
|
$response = new JSONResponse();
|
|
|
|
if($exception->getCode() < 100) {
|
|
|
|
$response->setStatus(500);
|
|
|
|
} else {
|
|
|
|
$response->setStatus($exception->getCode());
|
|
|
|
}
|
|
|
|
$response->setErrorMessage($exception->getMessage());
|
2013-10-01 19:13:28 +02:00
|
|
|
//$this->api->log(get_class($controller) . '->' . $methodName . ': ' . $exception->getMessage());
|
2013-05-18 04:56:59 +02:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-10-01 19:13:28 +02:00
|
|
|
function beforeOutput($controller, $methodName, $output) {
|
|
|
|
return $output;
|
|
|
|
}
|
2013-09-27 16:48:15 +02:00
|
|
|
function beforeController($controller, $methodName) {}
|
2013-10-01 19:13:28 +02:00
|
|
|
function afterController($controller, $methodName, Response $response) {
|
|
|
|
return $response;
|
|
|
|
}
|
2013-09-27 16:48:15 +02:00
|
|
|
|
2013-05-18 04:56:59 +02:00
|
|
|
}
|