summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-11-30 10:11:12 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-11-30 10:11:12 +0100
commit9c1dbaf0ad73bc84e41db964b319d7b2842ac7ae (patch)
tree5f1cfe8ae0d7092f37f45410d98dc0741a133b00
parentde02cde70ce5b0df7459d4d45abdaebeca3424d6 (diff)
parentaa822f76e2c608555eba3202bd5139944f72b884 (diff)
downloadnextcloud-server-9c1dbaf0ad73bc84e41db964b319d7b2842ac7ae.tar.gz
nextcloud-server-9c1dbaf0ad73bc84e41db964b319d7b2842ac7ae.zip
Merge pull request #20788 from owncloud/catch-missing-route
Dont die when we're missing a route
-rw-r--r--lib/private/route/cachingrouter.php7
-rw-r--r--lib/private/route/router.php21
-rw-r--r--lib/private/server.php5
-rw-r--r--tests/lib/appframework/routing/RoutingTest.php6
4 files changed, 30 insertions, 9 deletions
diff --git a/lib/private/route/cachingrouter.php b/lib/private/route/cachingrouter.php
index 734aa5aea4b..2d10b8ab691 100644
--- a/lib/private/route/cachingrouter.php
+++ b/lib/private/route/cachingrouter.php
@@ -22,6 +22,8 @@
namespace OC\Route;
+use OCP\ILogger;
+
class CachingRouter extends Router {
/**
* @var \OCP\ICache
@@ -30,10 +32,11 @@ class CachingRouter extends Router {
/**
* @param \OCP\ICache $cache
+ * @param ILogger $logger
*/
- public function __construct($cache) {
+ public function __construct($cache, ILogger $logger) {
$this->cache = $cache;
- parent::__construct();
+ parent::__construct($logger);
}
/**
diff --git a/lib/private/route/router.php b/lib/private/route/router.php
index f4abfae0f43..6d3b7c742bb 100644
--- a/lib/private/route/router.php
+++ b/lib/private/route/router.php
@@ -30,8 +30,10 @@
namespace OC\Route;
+use OCP\ILogger;
use OCP\Route\IRouter;
use OCP\AppFramework\App;
+use Symfony\Component\Routing\Exception\RouteNotFoundException;
use Symfony\Component\Routing\Matcher\UrlMatcher;
use Symfony\Component\Routing\Generator\UrlGenerator;
use Symfony\Component\Routing\RequestContext;
@@ -78,7 +80,13 @@ class Router implements IRouter {
protected $loadedApps = array();
- public function __construct() {
+ /**
+ * @var ILogger
+ */
+ protected $logger;
+
+ public function __construct(ILogger $logger) {
+ $this->logger = $logger;
$baseUrl = \OC_Helper::linkTo('', 'index.php');
if (!\OC::$CLI) {
$method = $_SERVER['REQUEST_METHOD'];
@@ -127,6 +135,7 @@ class Router implements IRouter {
/**
* loads the api routes
+ *
* @return void
*/
public function loadRoutes($app = null) {
@@ -290,6 +299,7 @@ class Router implements IRouter {
/**
* Get the url generator
+ *
* @return \Symfony\Component\Routing\Generator\UrlGenerator
*
*/
@@ -311,11 +321,17 @@ class Router implements IRouter {
*/
public function generate($name, $parameters = array(), $absolute = false) {
$this->loadRoutes();
- return $this->getGenerator()->generate($name, $parameters, $absolute);
+ try {
+ return $this->getGenerator()->generate($name, $parameters, $absolute);
+ } catch (RouteNotFoundException $e) {
+ $this->logger->logException($e);
+ return '';
+ }
}
/**
* To isolate the variable scope used inside the $file it is required in it's own method
+ *
* @param string $file the route file location to include
* @param string $appName
*/
@@ -331,6 +347,7 @@ class Router implements IRouter {
* \OCA\MyApp\AppInfo\Application. If that class does not exist, a default
* App will be intialized. This makes it optional to ship an
* appinfo/application.php by using the built in query resolver
+ *
* @param array $routes the application routes
* @param string $appName the name of the app.
*/
diff --git a/lib/private/server.php b/lib/private/server.php
index ea5937dfea4..7f3e3af6994 100644
--- a/lib/private/server.php
+++ b/lib/private/server.php
@@ -297,10 +297,11 @@ class Server extends SimpleContainer implements IServerContainer {
});
$this->registerService('Router', function (Server $c) {
$cacheFactory = $c->getMemCacheFactory();
+ $logger = $c->getLogger();
if ($cacheFactory->isAvailable()) {
- $router = new \OC\Route\CachingRouter($cacheFactory->create('route'));
+ $router = new \OC\Route\CachingRouter($cacheFactory->create('route'), $logger);
} else {
- $router = new \OC\Route\Router();
+ $router = new \OC\Route\Router($logger);
}
return $router;
});
diff --git a/tests/lib/appframework/routing/RoutingTest.php b/tests/lib/appframework/routing/RoutingTest.php
index 51c191fdfb7..b063ef32835 100644
--- a/tests/lib/appframework/routing/RoutingTest.php
+++ b/tests/lib/appframework/routing/RoutingTest.php
@@ -74,7 +74,7 @@ class RoutingTest extends \Test\TestCase
));
// router mock
- $router = $this->getMock("\OC\Route\Router", array('create'));
+ $router = $this->getMock("\OC\Route\Router", array('create'), [\OC::$server->getLogger()]);
// load route configuration
$container = new DIContainer('app1');
@@ -124,7 +124,7 @@ class RoutingTest extends \Test\TestCase
$route = $this->mockRoute($container, $verb, $controllerName, $actionName, $requirements, $defaults);
// router mock
- $router = $this->getMock("\OC\Route\Router", array('create'));
+ $router = $this->getMock("\OC\Route\Router", array('create'), [\OC::$server->getLogger()]);
// we expect create to be called once:
$router
@@ -148,7 +148,7 @@ class RoutingTest extends \Test\TestCase
private function assertResource($yaml, $resourceName, $url, $controllerName, $paramName)
{
// router mock
- $router = $this->getMock("\OC\Route\Router", array('create'));
+ $router = $this->getMock("\OC\Route\Router", array('create'), [\OC::$server->getLogger()]);
// route mocks
$container = new DIContainer('app1');