diff options
author | Bart Visscher <bartv@thisnet.nl> | 2012-09-12 18:00:33 +0200 |
---|---|---|
committer | Bart Visscher <bartv@thisnet.nl> | 2012-09-12 18:00:33 +0200 |
commit | 3efe1d3b24e65ed76d521c24b0cfe4e0ff2e7af5 (patch) | |
tree | 6fd36eeeb824d069f9ea9ead530f4f03f8f3e2c7 /lib/router.php | |
parent | ceec5e593c677ed9e9339739d0a66a28e4f25d12 (diff) | |
download | nextcloud-server-3efe1d3b24e65ed76d521c24b0cfe4e0ff2e7af5.tar.gz nextcloud-server-3efe1d3b24e65ed76d521c24b0cfe4e0ff2e7af5.zip |
Add linkToRoute functionality
Diffstat (limited to 'lib/router.php')
-rw-r--r-- | lib/router.php | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/lib/router.php b/lib/router.php index 65fc51aff2c..da491e217fc 100644 --- a/lib/router.php +++ b/lib/router.php @@ -7,6 +7,7 @@ */ use Symfony\Component\Routing\Matcher\UrlMatcher; +use Symfony\Component\Routing\Generator\UrlGenerator; use Symfony\Component\Routing\RequestContext; use Symfony\Component\Routing\RouteCollection; //use Symfony\Component\Routing\Route; @@ -16,7 +17,14 @@ class OC_Router { protected $collection = null; protected $root = null; + protected $generator= null; + public function __construct() { + $baseUrl = OC_Helper::linkTo('', 'index.php'); + $method = $_SERVER['REQUEST_METHOD']; + $host = OC_Request::serverHost(); + $schema = OC_Request::serverProtocol(); + $this->context = new RequestContext($baseUrl, $method, $host, $schema); // TODO cache $this->root = $this->getCollection('root'); } @@ -56,12 +64,7 @@ class OC_Router { } public function match($url) { - $baseUrl = OC_Helper::linkTo('', 'index.php'); - $method = $_SERVER['REQUEST_METHOD']; - $host = OC_Request::serverHost(); - $schema = OC_Request::serverProtocol(); - $context = new RequestContext($baseUrl, $method, $host, $schema); - $matcher = new UrlMatcher($this->root, $context); + $matcher = new UrlMatcher($this->root, $this->context); $parameters = $matcher->match($url); if (isset($parameters['action'])) { $action = $parameters['action']; @@ -77,4 +80,18 @@ class OC_Router { throw new Exception('no action available'); } } + + public function getGenerator() + { + if (null !== $this->generator) { + return $this->generator; + } + + return $this->generator = new UrlGenerator($this->root, $this->context); + } + + public function generate($name, $parameters = array(), $absolute = false) + { + return $this->getGenerator()->generate($name, $parameters, $absolute); + } } |