content_entity_base-8.x-1.x-dev/src/ParamConverter/EntityRevisionParamConverter.php
src/ParamConverter/EntityRevisionParamConverter.php
<?php
namespace Drupal\content_entity_base\ParamConverter;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\ParamConverter\ParamConverterInterface;
use Symfony\Component\Routing\Route;
/**
* 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:
* @code
* example.route:
* path: /foo/{entity_example_revision}
* options:
* parameters:
* entity_example_revision:
* type: entity_revision:entity_example
* @endcode
*/
class EntityRevisionParamConverter implements ParamConverterInterface {
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* Creates a new EntityRevisionParamConverter instance.
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager) {
$this->entityTypeManager = $entity_type_manager;
}
/**
* {@inheritdoc}
*/
public function convert($value, $definition, $name, array $defaults) {
list (, $entity_type_id) = explode(':', $definition['type'], 2);
$entity_storage = $this->entityTypeManager->getStorage($entity_type_id);
return $entity_storage->loadRevision($value);
}
/**
* {@inheritdoc}
*/
public function applies($definition, $name, Route $route) {
return isset($definition['type']) && strpos($definition['type'], 'entity_revision:') !== FALSE;
}
}
