208 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			208 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Friendica\App;
 | 
						|
 | 
						|
 | 
						|
use FastRoute\DataGenerator\GroupCountBased;
 | 
						|
use FastRoute\Dispatcher;
 | 
						|
use FastRoute\RouteCollector;
 | 
						|
use FastRoute\RouteParser\Std;
 | 
						|
use Friendica\Module;
 | 
						|
 | 
						|
/**
 | 
						|
 * Wrapper for FastRoute\Router
 | 
						|
 *
 | 
						|
 * This wrapper only makes use of a subset of the router features, mainly parses a route rule to return the relevant
 | 
						|
 * module class.
 | 
						|
 *
 | 
						|
 * Actual routes are defined in App->collectRoutes.
 | 
						|
 *
 | 
						|
 * @package Friendica\App
 | 
						|
 */
 | 
						|
class Router
 | 
						|
{
 | 
						|
	/** @var RouteCollector */
 | 
						|
	protected $routeCollector;
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Static declaration of Friendica routes.
 | 
						|
	 *
 | 
						|
	 * Supports:
 | 
						|
	 * - Route groups
 | 
						|
	 * - Variable parts
 | 
						|
	 * Disregards:
 | 
						|
	 * - HTTP method other than GET
 | 
						|
	 * - Named parameters
 | 
						|
	 *
 | 
						|
	 * Handler must be the name of a class extending Friendica\BaseModule.
 | 
						|
	 *
 | 
						|
	 * @brief Static declaration of Friendica routes.
 | 
						|
	 */
 | 
						|
	public function collectRoutes()
 | 
						|
	{
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '[/]',               Module\Home::class);
 | 
						|
		$this->routeCollector->addGroup('/.well-known', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/host-meta'       , Module\WellKnown\HostMeta::class);
 | 
						|
			$collector->addRoute(['GET'], '/nodeinfo[/1.0]'  , Module\NodeInfo::class);
 | 
						|
			$collector->addRoute(['GET'], '/webfinger'       , Module\Xrd::class);
 | 
						|
			$collector->addRoute(['GET'], '/x-social-relay'  , Module\WellKnown\XSocialRelay::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addGroup('/admin', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET']        , '[/]'                     , Module\Admin\Summary::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/addons'                 , Module\Admin\Addons\Index::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/addons/{addon}'         , Module\Admin\Addons\Details::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/blocklist/contact'      , Module\Admin\Blocklist\Contact::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/blocklist/server'       , Module\Admin\Blocklist\Server::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET']        , '/dbsync[/check]'         , Module\Admin\DBSync::class);
 | 
						|
			$collector->addRoute(['GET']        , '/dbsync/{update:\d+}'    , Module\Admin\DBSync::class);
 | 
						|
			$collector->addRoute(['GET']        , '/dbsync/mark/{update:\d+}', Module\Admin\DBSync::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/features'               , Module\Admin\Features::class);
 | 
						|
			$collector->addRoute(['GET']        , '/federation'             , Module\Admin\Federation::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/item/delete'            , Module\Admin\Item\Delete::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/item/source[/{guid}]'   , Module\Admin\Item\Source::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET']        , '/logs/view'              , Module\Admin\Logs\View::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/logs'                   , Module\Admin\Logs\Settings::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET']        , '/phpinfo'                , Module\Admin\PhpInfo::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET']        , '/queue[/deferred]'       , Module\Admin\Queue::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/site'                   , Module\Admin\Site::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/themes'                 , Module\Admin\Themes\Index::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/themes/{theme}'         , Module\Admin\Themes\Details::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/themes/{theme}/embed'   , Module\Admin\Themes\Embed::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/tos'                    , Module\Admin\Tos::class);
 | 
						|
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/users[/{action}/{uid}]' , Module\Admin\Users::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/amcd',                Module\AccountManagementControlDocument::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/acctlink',            Module\Acctlink::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/allfriends/{id:\d+}', Module\AllFriends::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/apps',                Module\Apps::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/attach/{item:\d+}',   Module\Attach::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/babel',               Module\Babel::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/bookmarklet',         Module\BookMarklet::class);
 | 
						|
		$this->routeCollector->addGroup('/contact', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '[/]',                                 Module\Contact::class);
 | 
						|
			$collector->addRoute(['GET'], '/{id:\d+}[/posts|conversations]',     Module\Contact::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/credits',             Module\Credits::class);
 | 
						|
		$this->routeCollector->addGroup('/feed', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}',                         Module\Feed::class);
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}/posts',                   Module\Feed::class);
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}/comments',                Module\Feed::class);
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}/replies',                 Module\Feed::class);
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}/activity',                Module\Feed::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/directory',           Module\Directory::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/feedtest',            Module\Feedtest::class);
 | 
						|
		$this->routeCollector->addGroup('/fetch', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/{guid}/post',                        Module\Diaspora\Fetch::class);
 | 
						|
			$collector->addRoute(['GET'], '/{guid}/status_message',              Module\Diaspora\Fetch::class);
 | 
						|
			$collector->addRoute(['GET'], '/{guid}/reshare',                     Module\Diaspora\Fetch::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/filer[/{id:\d+}]',    Module\Filer::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/followers/{owner}',   Module\Followers::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/following/{owner}',   Module\Following::class);
 | 
						|
		$this->routeCollector->addGroup('/group', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET', 'POST'], '[/]',                         Module\Group::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/{group:\d+}',                Module\Group::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/none',                       Module\Group::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/new',                        Module\Group::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/drop/{group:\d+}',           Module\Group::class);
 | 
						|
			$collector->addRoute(['GET', 'POST'], '/{group:\d+}/{contact:\d+}',  Module\Group::class);
 | 
						|
 | 
						|
			$collector->addRoute(['POST'], '/{group:\d+}/add/{contact:\d+}',     Module\Group::class);
 | 
						|
			$collector->addRoute(['POST'], '/{group:\d+}/remove/{contact:\d+}',  Module\Group::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/hashtag',             Module\Hashtag::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/home',                Module\Home::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/inbox[/{nickname}]',  Module\Inbox::class);
 | 
						|
		$this->routeCollector->addGroup('/install', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET', 'POST'], '[/]',                         Module\Install::class);
 | 
						|
			$collector->addRoute(['GET'],         '/testrewrite',                Module\Install::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET', 'POST'], '/itemsource[/{guid}]', Module\Itemsource::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/like/{item:\d+}',     Module\Like::class);
 | 
						|
		$this->routeCollector->addRoute(['GET', 'POST'], '/localtime',           Module\Localtime::class);
 | 
						|
		$this->routeCollector->addRoute(['GET', 'POST'], '/login',               Module\Login::class);
 | 
						|
		$this->routeCollector->addRoute(['GET', 'POST'], '/logout',              Module\Logout::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/magic',               Module\Magic::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/manifest',            Module\Manifest::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/nodeinfo/1.0',        Module\NodeInfo::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/nogroup',             Module\Group::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/objects/{guid}',      Module\Objects::class);
 | 
						|
		$this->routeCollector->addGroup('/oembed', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/[b2h|h2b]',                          Module\Oembed::class);
 | 
						|
			$collector->addRoute(['GET'], '/{hash}',                             Module\Oembed::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/outbox/{owner}',      Module\Outbox::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/owa',                 Module\Owa::class);
 | 
						|
		$this->routeCollector->addGroup('/photo', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/{name}',                             Module\Photo::class);
 | 
						|
			$collector->addRoute(['GET'], '/{type}/{name}',                      Module\Photo::class);
 | 
						|
			$collector->addRoute(['GET'], '/{type}/{customize}/{name}',          Module\Photo::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addGroup('/profile', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '/{nickname}',                         Module\Profile::class);
 | 
						|
			$collector->addRoute(['GET'], '/{profile:\d+}/view',                 Module\Profile::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addGroup('/proxy', function (RouteCollector $collector) {
 | 
						|
			$collector->addRoute(['GET'], '[/]'                                , Module\Proxy::class);
 | 
						|
			$collector->addRoute(['GET'], '/{url}'                             , Module\Proxy::class);
 | 
						|
			$collector->addRoute(['GET'], '/{sub1}/{url}'                      , Module\Proxy::class);
 | 
						|
			$collector->addRoute(['GET'], '/{sub1}/{sub2}/{url}'               , Module\Proxy::class);
 | 
						|
		});
 | 
						|
		$this->routeCollector->addRoute(['GET', 'POST'], '/register',            Module\Register::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/statistics.json',     Module\Statistics::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/tos',                 Module\Tos::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/webfinger',           Module\WebFinger::class);
 | 
						|
		$this->routeCollector->addRoute(['GET'],         '/xrd',                 Module\Xrd::class);
 | 
						|
	}
 | 
						|
 | 
						|
	public function __construct(RouteCollector $routeCollector = null)
 | 
						|
	{
 | 
						|
		if (!$routeCollector) {
 | 
						|
			$routeCollector = new RouteCollector(new Std(), new GroupCountBased());
 | 
						|
		}
 | 
						|
 | 
						|
		$this->routeCollector = $routeCollector;
 | 
						|
	}
 | 
						|
 | 
						|
	public function getRouteCollector()
 | 
						|
	{
 | 
						|
		return $this->routeCollector;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Returns the relevant module class name for the given page URI or NULL if no route rule matched.
 | 
						|
	 *
 | 
						|
	 * @param string $cmd The path component of the request URL without the query string
 | 
						|
	 * @return string|null A Friendica\BaseModule-extending class name if a route rule matched
 | 
						|
	 */
 | 
						|
	public function getModuleClass($cmd)
 | 
						|
	{
 | 
						|
		$cmd = '/' . ltrim($cmd, '/');
 | 
						|
 | 
						|
		$dispatcher = new \FastRoute\Dispatcher\GroupCountBased($this->routeCollector->getData());
 | 
						|
 | 
						|
		$moduleClass = null;
 | 
						|
 | 
						|
		// @TODO: Enable method-specific modules
 | 
						|
		$httpMethod = 'GET';
 | 
						|
		$routeInfo = $dispatcher->dispatch($httpMethod, $cmd);
 | 
						|
		if ($routeInfo[0] === Dispatcher::FOUND) {
 | 
						|
			$moduleClass = $routeInfo[1];
 | 
						|
		}
 | 
						|
 | 
						|
		return $moduleClass;
 | 
						|
	}
 | 
						|
}
 |