You are here

protected function EntityBase::urlRouteParameters in Drupal 10

Same name and namespace in other branches
  1. 8 core/lib/Drupal/Core/Entity/EntityBase.php \Drupal\Core\Entity\EntityBase::urlRouteParameters()
  2. 9 core/lib/Drupal/Core/Entity/EntityBase.php \Drupal\Core\Entity\EntityBase::urlRouteParameters()

Gets an array of placeholders for this entity.

Individual entity classes may override this method to add additional placeholders if desired. If so, they should be sure to replicate the property caching logic.

Parameters

string $rel: The link relationship type, for example: canonical or edit-form.

Return value

array An array of URI placeholders.

1 call to EntityBase::urlRouteParameters()
EntityDisplayModeBase::urlRouteParameters in core/lib/Drupal/Core/Entity/EntityDisplayModeBase.php
Gets an array of placeholders for this entity.
1 method overrides EntityBase::urlRouteParameters()
EntityDisplayModeBase::urlRouteParameters in core/lib/Drupal/Core/Entity/EntityDisplayModeBase.php
Gets an array of placeholders for this entity.

File

core/lib/Drupal/Core/Entity/EntityBase.php, line 263

Class

EntityBase
Defines a base entity class.

Namespace

Drupal\Core\Entity

Code

protected function urlRouteParameters($rel) {
  $uri_route_parameters = [];
  if (!in_array($rel, [
    'collection',
    'add-page',
    'add-form',
  ], TRUE)) {

    // The entity ID is needed as a route parameter.
    $uri_route_parameters[$this
      ->getEntityTypeId()] = $this
      ->id();
  }
  if ($rel === 'add-form' && $this
    ->getEntityType()
    ->hasKey('bundle')) {
    $parameter_name = $this
      ->getEntityType()
      ->getBundleEntityType() ?: $this
      ->getEntityType()
      ->getKey('bundle');
    $uri_route_parameters[$parameter_name] = $this
      ->bundle();
  }
  if ($this instanceof RevisionableInterface && strpos($rel, 'revision') === 0) {
    $uri_route_parameters[$this
      ->getEntityTypeId() . '_revision'] = $this
      ->getRevisionId();
  }
  return $uri_route_parameters;
}