SearchPageRoutes.php

Same filename and directory in other branches
  1. 9 core/modules/search/src/Routing/SearchPageRoutes.php
  2. 8.9.x core/modules/search/src/Routing/SearchPageRoutes.php
  3. 10 core/modules/search/src/Routing/SearchPageRoutes.php

Namespace

Drupal\search\Routing

File

core/modules/search/src/Routing/SearchPageRoutes.php

View source
<?php

namespace Drupal\search\Routing;

use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Drupal\search\SearchPageRepositoryInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\Routing\Route;

/**
 * Provides dynamic routes for search.
 */
class SearchPageRoutes implements ContainerInjectionInterface {
  
  /**
   * The search page repository.
   *
   * @var \Drupal\search\SearchPageRepositoryInterface
   */
  protected $searchPageRepository;
  
  /**
   * Constructs a new search route subscriber.
   *
   * @param \Drupal\search\SearchPageRepositoryInterface $search_page_repository
   *   The search page repository.
   */
  public function __construct(SearchPageRepositoryInterface $search_page_repository) {
    $this->searchPageRepository = $search_page_repository;
  }
  
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container) {
    return new static($container->get('search.search_page_repository'));
  }
  
  /**
   * Returns an array of route objects.
   *
   * @return \Symfony\Component\Routing\Route[]
   *   An array of route objects.
   */
  public function routes() {
    $routes = [];
    // @todo Decide if /search should continue to redirect to /search/$default,
    //   or just perform the appropriate search.
    if ($default_page = $this->searchPageRepository
      ->getDefaultSearchPage()) {
      $routes['search.view'] = new Route('/search', [
        '_controller' => 'Drupal\\search\\Controller\\SearchController::redirectSearchPage',
        '_title' => 'Search',
        'entity' => $default_page,
      ], [
        '_entity_access' => 'entity.view',
        '_permission' => 'search content',
      ], [
        'parameters' => [
          'entity' => [
            'type' => 'entity:search_page',
          ],
        ],
      ]);
    }
    $active_pages = $this->searchPageRepository
      ->getActiveSearchPages();
    foreach ($active_pages as $entity_id => $entity) {
      $routes["search.view_{$entity_id}"] = new Route('/search/' . $entity->getPath(), [
        '_controller' => 'Drupal\\search\\Controller\\SearchController::view',
        '_title' => 'Search',
        'entity' => $entity_id,
      ], [
        '_entity_access' => 'entity.view',
        '_permission' => 'search content',
      ], [
        'parameters' => [
          'entity' => [
            'type' => 'entity:search_page',
          ],
        ],
      ]);
      $routes["search.help_{$entity_id}"] = new Route('/search/' . $entity->getPath() . '/help', [
        '_controller' => 'Drupal\\search\\Controller\\SearchController::searchHelp',
        '_title' => 'About searching',
        'entity' => $entity_id,
      ], [
        '_entity_access' => 'entity.view',
        '_permission' => 'search content',
      ], [
        'parameters' => [
          'entity' => [
            'type' => 'entity:search_page',
          ],
        ],
      ]);
      if ($entity->getPlugin()
        ->usesAdminTheme()) {
        $routes["search.view_{$entity_id}"]->setOption('_admin_route', TRUE);
        $routes["search.help_{$entity_id}"]->setOption('_admin_route', TRUE);
      }
    }
    return $routes;
  }

}

Classes

Title Deprecated Summary
SearchPageRoutes Provides dynamic routes for search.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.