3 namespace Friendica\App;
\r
6 use FastRoute\DataGenerator\GroupCountBased;
\r
7 use FastRoute\Dispatcher;
\r
8 use FastRoute\RouteCollector;
\r
9 use FastRoute\RouteParser\Std;
\r
12 * Wrapper for FastRoute\Router
\r
14 * This wrapper only makes use of a subset of the router features, mainly parses a route rule to return the relevant
\r
17 * Actual routes are defined in App->collectRoutes.
\r
19 * @package Friendica\App
\r
23 /** @var RouteCollector */
\r
24 protected $routeCollector;
\r
26 public function __construct(RouteCollector $routeCollector = null)
\r
28 if (!$routeCollector) {
\r
29 $routeCollector = new RouteCollector(new Std(), new GroupCountBased());
\r
32 $this->routeCollector = $routeCollector;
\r
35 public function getRouteCollector()
\r
37 return $this->routeCollector;
\r
40 public function getModuleClass($cmd)
\r
42 $cmd = '/' . ltrim($cmd, '/');
\r
44 $dispatcher = new \FastRoute\Dispatcher\GroupCountBased($this->routeCollector->getData());
\r
46 $moduleClass = null;
\r
48 // @TODO: Enable method-specific modules
\r
49 $httpMethod = 'GET';
\r
50 $routeInfo = $dispatcher->dispatch($httpMethod, $cmd);
\r
51 if ($routeInfo[0] === Dispatcher::FOUND) {
\r
52 $moduleClass = $routeInfo[1];
\r
55 return $moduleClass;
\r