class RouteInfoController in Devel 8
Same name and namespace in other branches
- 8.3 src/Controller/RouteInfoController.php \Drupal\devel\Controller\RouteInfoController
- 8.2 src/Controller/RouteInfoController.php \Drupal\devel\Controller\RouteInfoController
- 4.x src/Controller/RouteInfoController.php \Drupal\devel\Controller\RouteInfoController
Provides route responses for the route info pages.
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\devel\Controller\RouteInfoController
Expanded class hierarchy of RouteInfoController
File
- src/
Controller/ RouteInfoController.php, line 17
Namespace
Drupal\devel\ControllerView source
class RouteInfoController extends ControllerBase {
/**
* The route provider.
*
* @var \Drupal\Core\Routing\RouteProviderInterface
*/
protected $routeProvider;
/**
* The router service.
*
* @var \Symfony\Component\Routing\RouterInterface
*/
protected $router;
/**
* The dumper service.
*
* @var \Drupal\devel\DevelDumperManagerInterface
*/
protected $dumper;
/**
* RouterInfoController constructor.
*
* @param \Drupal\Core\Routing\RouteProviderInterface $provider
* The route provider.
* @param \Symfony\Component\Routing\RouterInterface $router
* The router service.
* @param \Drupal\devel\DevelDumperManagerInterface $dumper
* The dumper service.
*/
public function __construct(RouteProviderInterface $provider, RouterInterface $router, DevelDumperManagerInterface $dumper) {
$this->routeProvider = $provider;
$this->router = $router;
$this->dumper = $dumper;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('router.route_provider'), $container
->get('router.no_access_checks'), $container
->get('devel.dumper'));
}
/**
* Builds the routes overview page.
*
* @return array
* A render array as expected by the renderer.
*/
public function routeList() {
$headers = [
$this
->t('Route Name'),
$this
->t('Path'),
$this
->t('Allowed Methods'),
$this
->t('Operations'),
];
$rows = [];
foreach ($this->routeProvider
->getAllRoutes() as $route_name => $route) {
$row['name'] = [
'data' => $route_name,
'class' => 'table-filter-text-source',
];
$row['path'] = [
'data' => $route
->getPath(),
'class' => 'table-filter-text-source',
];
$row['methods']['data'] = [
'#theme' => 'item_list',
'#items' => $route
->getMethods(),
'#empty' => $this
->t('ANY'),
'#context' => [
'list_style' => 'comma-list',
],
];
// We cannot resolve routes with dynamic parameters from route path. For
// these routes we pass the route name.
// @see ::routeItem()
if (strpos($route
->getPath(), '{') !== FALSE) {
$parameters = [
'query' => [
'route_name' => $route_name,
],
];
}
else {
$parameters = [
'query' => [
'path' => $route
->getPath(),
],
];
}
$row['operations']['data'] = [
'#type' => 'operations',
'#links' => [
'devel' => [
'title' => $this
->t('Devel'),
'url' => Url::fromRoute('devel.route_info.item', [], $parameters),
],
],
];
$rows[] = $row;
}
$output['#attached']['library'][] = 'system/drupal.system.modules';
$output['filters'] = [
'#type' => 'container',
'#attributes' => [
'class' => [
'table-filter',
'js-show',
],
],
];
$output['filters']['name'] = [
'#type' => 'search',
'#title' => $this
->t('Search'),
'#size' => 30,
'#placeholder' => $this
->t('Enter route name or path'),
'#attributes' => [
'class' => [
'table-filter-text',
],
'data-table' => '.devel-filter-text',
'autocomplete' => 'off',
'title' => $this
->t('Enter a part of the route name or path to filter by.'),
],
];
$output['routes'] = [
'#type' => 'table',
'#header' => $headers,
'#rows' => $rows,
'#empty' => $this
->t('No routes found.'),
'#sticky' => TRUE,
'#attributes' => [
'class' => [
'devel-route-list',
'devel-filter-text',
],
],
];
return $output;
}
/**
* Returns a render array representation of the route object.
*
* The method tries to resolve the route from the 'path' or the 'route_name'
* query string value if available. If no route is retrieved from the query
* string parameters it fallbacks to the current route.
*
* @param \Symfony\Component\HttpFoundation\Request $request
* The request object.
* @param \Drupal\Core\Routing\RouteMatchInterface $route_match
* The route match.
*
* @return array
* A render array as expected by the renderer.
*/
public function routeDetail(Request $request, RouteMatchInterface $route_match) {
$route = NULL;
// Get the route object from the path query string if available.
if ($path = $request->query
->get('path')) {
try {
$route = $this->router
->match($path);
} catch (\Exception $e) {
drupal_set_message($this
->t("Unable to load route for url '%url'", [
'%url' => $path,
]), 'warning');
}
}
// Get the route object from the route name query string if available and
// the route is not retrieved by path.
if ($route === NULL && ($route_name = $request->query
->get('route_name'))) {
try {
$route = $this->routeProvider
->getRouteByName($route_name);
} catch (\Exception $e) {
drupal_set_message($this
->t("Unable to load route '%name'", [
'%name' => $route_name,
]), 'warning');
}
}
// No route retrieved from path or name specified, get the current route.
if ($route === NULL) {
$route = $route_match
->getRouteObject();
}
return $this->dumper
->exportAsRenderable($route);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ControllerBase:: |
protected | property | The configuration factory. | |
ControllerBase:: |
protected | property | The current user service. | 1 |
ControllerBase:: |
protected | property | The entity form builder. | |
ControllerBase:: |
protected | property | The entity manager. | |
ControllerBase:: |
protected | property | The entity type manager. | |
ControllerBase:: |
protected | property | The form builder. | 2 |
ControllerBase:: |
protected | property | The key-value storage. | 1 |
ControllerBase:: |
protected | property | The language manager. | 1 |
ControllerBase:: |
protected | property | The module handler. | 2 |
ControllerBase:: |
protected | property | The state service. | |
ControllerBase:: |
protected | function | Returns the requested cache bin. | |
ControllerBase:: |
protected | function | Retrieves a configuration object. | |
ControllerBase:: |
private | function | Returns the service container. | |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity manager service. | |
ControllerBase:: |
protected | function | Retrieves the entity type manager. | |
ControllerBase:: |
protected | function | Returns the form builder service. | 2 |
ControllerBase:: |
protected | function | Returns a key/value storage collection. | 1 |
ControllerBase:: |
protected | function | Returns the language manager service. | 1 |
ControllerBase:: |
protected | function | Returns the module handler. | 2 |
ControllerBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
ControllerBase:: |
protected | function | Returns the state storage service. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
RouteInfoController:: |
protected | property | The dumper service. | |
RouteInfoController:: |
protected | property | The route provider. | |
RouteInfoController:: |
protected | property | The router service. | |
RouteInfoController:: |
public static | function |
Instantiates a new instance of this class. Overrides ControllerBase:: |
|
RouteInfoController:: |
public | function | Returns a render array representation of the route object. | |
RouteInfoController:: |
public | function | Builds the routes overview page. | |
RouteInfoController:: |
public | function | RouterInfoController constructor. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |