class EntityRevisionParamConverter in Drupal 8
Same name and namespace in other branches
- 9 core/lib/Drupal/Core/ParamConverter/EntityRevisionParamConverter.php \Drupal\Core\ParamConverter\EntityRevisionParamConverter
- 10 core/lib/Drupal/Core/ParamConverter/EntityRevisionParamConverter.php \Drupal\Core\ParamConverter\EntityRevisionParamConverter
Parameter converter for upcasting entity revision IDs to full objects.
This is useful for pages which want to show a specific revision, like "/entity_example/{entity_example}/revision/{entity_example_revision}".
In order to use it you should specify some additional options in your route:
example.route:
path: /foo/{entity_example_revision}
options:
parameters:
entity_example_revision:
type: entity_revision:entity_example
Hierarchy
- class \Drupal\Core\ParamConverter\EntityRevisionParamConverter implements ParamConverterInterface uses DynamicEntityTypeParamConverterTrait
Expanded class hierarchy of EntityRevisionParamConverter
1 file declares its use of EntityRevisionParamConverter
- EntityRevisionParamConverterTest.php in core/
tests/ Drupal/ Tests/ Core/ ParamConverter/ EntityRevisionParamConverterTest.php
1 string reference to 'EntityRevisionParamConverter'
- core.services.yml in core/
core.services.yml - core/core.services.yml
1 service uses EntityRevisionParamConverter
File
- core/
lib/ Drupal/ Core/ ParamConverter/ EntityRevisionParamConverter.php, line 28
Namespace
Drupal\Core\ParamConverterView source
class EntityRevisionParamConverter implements ParamConverterInterface {
use DynamicEntityTypeParamConverterTrait;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The entity repository.
*
* @var \Drupal\Core\Entity\EntityRepositoryInterface
*/
protected $entityRepository;
/**
* Creates a new EntityRevisionParamConverter instance.
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Entity\EntityRepositoryInterface $entity_repository
* The entity repository.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager, EntityRepositoryInterface $entity_repository) {
$this->entityTypeManager = $entity_type_manager;
$this->entityRepository = $entity_repository;
}
/**
* {@inheritdoc}
*/
public function convert($value, $definition, $name, array $defaults) {
$entity_type_id = $this
->getEntityTypeFromDefaults($definition, $name, $defaults);
$entity = $this->entityTypeManager
->getStorage($entity_type_id)
->loadRevision($value);
// If the entity type is translatable, ensure we return the proper
// translation object for the current context.
if ($entity instanceof EntityInterface && $entity instanceof TranslatableInterface) {
$entity = $this->entityRepository
->getTranslationFromContext($entity, NULL, [
'operation' => 'entity_upcast',
]);
}
return $entity;
}
/**
* {@inheritdoc}
*/
public function applies($definition, $name, Route $route) {
return isset($definition['type']) && strpos($definition['type'], 'entity_revision:') !== FALSE;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DynamicEntityTypeParamConverterTrait:: |
protected | function | Determines the entity type ID given a route definition and route defaults. | |
EntityRevisionParamConverter:: |
protected | property | The entity repository. | |
EntityRevisionParamConverter:: |
protected | property | The entity type manager. | |
EntityRevisionParamConverter:: |
public | function |
Determines if the converter applies to a specific route and variable. Overrides ParamConverterInterface:: |
|
EntityRevisionParamConverter:: |
public | function |
Converts path variables to their corresponding objects. Overrides ParamConverterInterface:: |
|
EntityRevisionParamConverter:: |
public | function | Creates a new EntityRevisionParamConverter instance. |