2012-07-23 20:58:52 +04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2012 Bart Visscher <bartv@thisnet.nl>
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
use Symfony\Component\Routing\Matcher\UrlMatcher;
|
2012-09-12 20:00:33 +04:00
|
|
|
use Symfony\Component\Routing\Generator\UrlGenerator;
|
2012-07-23 20:58:52 +04:00
|
|
|
use Symfony\Component\Routing\RequestContext;
|
|
|
|
use Symfony\Component\Routing\RouteCollection;
|
|
|
|
//use Symfony\Component\Routing\Route;
|
|
|
|
|
|
|
|
class OC_Router {
|
|
|
|
protected $collections = array();
|
|
|
|
protected $collection = null;
|
2012-08-02 23:51:31 +04:00
|
|
|
protected $root = null;
|
2012-08-02 19:59:18 +04:00
|
|
|
|
2012-10-28 20:53:05 +04:00
|
|
|
protected $generator = null;
|
|
|
|
protected $routing_files;
|
|
|
|
protected $cache_key;
|
2012-09-12 20:00:33 +04:00
|
|
|
|
2012-08-11 02:04:43 +04:00
|
|
|
public function __construct() {
|
2012-09-12 20:00:33 +04:00
|
|
|
$baseUrl = OC_Helper::linkTo('', 'index.php');
|
2013-02-07 21:30:01 +04:00
|
|
|
if ( !OC::$CLI) {
|
2013-02-07 21:28:56 +04:00
|
|
|
$method = $_SERVER['REQUEST_METHOD'];
|
|
|
|
}else{
|
|
|
|
$method = 'GET';
|
|
|
|
}
|
2012-09-12 20:00:33 +04:00
|
|
|
$host = OC_Request::serverHost();
|
|
|
|
$schema = OC_Request::serverProtocol();
|
|
|
|
$this->context = new RequestContext($baseUrl, $method, $host, $schema);
|
2012-08-11 02:04:43 +04:00
|
|
|
// TODO cache
|
|
|
|
$this->root = $this->getCollection('root');
|
|
|
|
}
|
|
|
|
|
2012-10-28 20:53:05 +04:00
|
|
|
public function getRoutingFiles() {
|
|
|
|
if (!isset($this->routing_files)) {
|
|
|
|
$this->routing_files = array();
|
2012-11-04 13:46:32 +04:00
|
|
|
foreach(OC_APP::getEnabledApps() as $app) {
|
2012-10-28 20:53:05 +04:00
|
|
|
$file = OC_App::getAppPath($app).'/appinfo/routes.php';
|
|
|
|
if(file_exists($file)) {
|
|
|
|
$this->routing_files[$app] = $file;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->routing_files;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCacheKey() {
|
|
|
|
if (!isset($this->cache_key)) {
|
|
|
|
$files = $this->getRoutingFiles();
|
2012-10-28 22:29:49 +04:00
|
|
|
$files[] = 'settings/routes.php';
|
2012-10-28 20:53:05 +04:00
|
|
|
$files[] = 'core/routes.php';
|
2013-01-08 00:57:13 +04:00
|
|
|
$files[] = 'ocs/routes.php';
|
2012-10-28 20:53:05 +04:00
|
|
|
$this->cache_key = OC_Cache::generateCacheKeyFromFiles($files);
|
|
|
|
}
|
|
|
|
return $this->cache_key;
|
|
|
|
}
|
|
|
|
|
2012-07-30 22:48:03 +04:00
|
|
|
/**
|
|
|
|
* loads the api routes
|
|
|
|
*/
|
2012-08-02 19:59:18 +04:00
|
|
|
public function loadRoutes() {
|
2012-10-28 20:53:05 +04:00
|
|
|
foreach($this->getRoutingFiles() as $app => $file) {
|
|
|
|
$this->useCollection($app);
|
|
|
|
require_once $file;
|
|
|
|
$collection = $this->getCollection($app);
|
2013-12-04 21:01:51 +04:00
|
|
|
$collection->addPrefix('/apps/'.$app);
|
|
|
|
$this->root->addCollection($collection);
|
2012-07-30 22:48:03 +04:00
|
|
|
}
|
2012-08-12 18:52:36 +04:00
|
|
|
$this->useCollection('root');
|
2012-10-28 22:29:49 +04:00
|
|
|
require_once 'settings/routes.php';
|
|
|
|
require_once 'core/routes.php';
|
2012-12-14 19:15:05 +04:00
|
|
|
|
2013-01-08 00:57:13 +04:00
|
|
|
// include ocs routes
|
|
|
|
require_once 'ocs/routes.php';
|
|
|
|
$collection = $this->getCollection('ocs');
|
2013-12-04 21:01:51 +04:00
|
|
|
$collection->addPrefix('/ocs');
|
|
|
|
$this->root->addCollection($collection);
|
2012-07-30 22:48:03 +04:00
|
|
|
}
|
|
|
|
|
2012-08-02 23:51:31 +04:00
|
|
|
protected function getCollection($name) {
|
2012-07-23 20:58:52 +04:00
|
|
|
if (!isset($this->collections[$name])) {
|
|
|
|
$this->collections[$name] = new RouteCollection();
|
|
|
|
}
|
2012-08-02 23:51:31 +04:00
|
|
|
return $this->collections[$name];
|
|
|
|
}
|
|
|
|
|
2012-10-05 19:42:42 +04:00
|
|
|
/**
|
|
|
|
* Sets the collection to use for adding routes
|
|
|
|
*
|
|
|
|
* @param string $name Name of the colletion to use.
|
|
|
|
*/
|
2012-08-02 23:51:31 +04:00
|
|
|
public function useCollection($name) {
|
|
|
|
$this->collection = $this->getCollection($name);
|
2012-07-23 20:58:52 +04:00
|
|
|
}
|
|
|
|
|
2012-10-05 19:42:42 +04:00
|
|
|
/**
|
|
|
|
* Create a OC_Route.
|
|
|
|
*
|
|
|
|
* @param string $name Name of the route to create.
|
|
|
|
* @param string $pattern The pattern to match
|
|
|
|
* @param array $defaults An array of default parameter values
|
|
|
|
* @param array $requirements An array of requirements for parameters (regexes)
|
|
|
|
*/
|
2012-07-23 20:58:52 +04:00
|
|
|
public function create($name, $pattern, array $defaults = array(), array $requirements = array()) {
|
|
|
|
$route = new OC_Route($pattern, $defaults, $requirements);
|
|
|
|
$this->collection->add($name, $route);
|
|
|
|
return $route;
|
|
|
|
}
|
|
|
|
|
2012-10-05 19:42:42 +04:00
|
|
|
/**
|
|
|
|
* Find the route matching $url.
|
|
|
|
*
|
|
|
|
* @param string $url The url to find
|
|
|
|
*/
|
2012-10-27 19:45:09 +04:00
|
|
|
public function match($url) {
|
2012-09-12 20:00:33 +04:00
|
|
|
$matcher = new UrlMatcher($this->root, $this->context);
|
2012-07-23 20:58:52 +04:00
|
|
|
$parameters = $matcher->match($url);
|
|
|
|
if (isset($parameters['action'])) {
|
|
|
|
$action = $parameters['action'];
|
|
|
|
if (!is_callable($action)) {
|
2012-08-01 00:33:11 +04:00
|
|
|
var_dump($action);
|
2012-07-23 20:58:52 +04:00
|
|
|
throw new Exception('not a callable action');
|
|
|
|
}
|
|
|
|
unset($parameters['action']);
|
|
|
|
call_user_func($action, $parameters);
|
|
|
|
} elseif (isset($parameters['file'])) {
|
2012-10-27 19:45:09 +04:00
|
|
|
include $parameters['file'];
|
2012-07-23 20:58:52 +04:00
|
|
|
} else {
|
|
|
|
throw new Exception('no action available');
|
|
|
|
}
|
|
|
|
}
|
2012-09-12 20:00:33 +04:00
|
|
|
|
2012-10-05 19:42:42 +04:00
|
|
|
/**
|
|
|
|
* Get the url generator
|
|
|
|
*
|
|
|
|
*/
|
2012-09-12 20:00:33 +04:00
|
|
|
public function getGenerator()
|
|
|
|
{
|
|
|
|
if (null !== $this->generator) {
|
|
|
|
return $this->generator;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->generator = new UrlGenerator($this->root, $this->context);
|
|
|
|
}
|
|
|
|
|
2012-10-05 19:42:42 +04:00
|
|
|
/**
|
|
|
|
* Generate url based on $name and $parameters
|
|
|
|
*
|
|
|
|
* @param string $name Name of the route to use.
|
|
|
|
* @param array $parameters Parameters for the route
|
|
|
|
*/
|
2012-09-12 20:00:33 +04:00
|
|
|
public function generate($name, $parameters = array(), $absolute = false)
|
|
|
|
{
|
|
|
|
return $this->getGenerator()->generate($name, $parameters, $absolute);
|
|
|
|
}
|
2012-10-05 11:42:36 +04:00
|
|
|
|
2012-07-23 20:58:52 +04:00
|
|
|
}
|