class ImageEntityNormalizer in Consumer Image Styles 8.2
Same name and namespace in other branches
- 8 src/Normalizer/ImageEntityNormalizer.php \Drupal\consumer_image_styles\Normalizer\ImageEntityNormalizer
Hierarchy
- class \Drupal\serialization\Normalizer\NormalizerBase implements \Symfony\Component\Serializer\SerializerAwareInterface, CacheableNormalizerInterface uses \Symfony\Component\Serializer\SerializerAwareTrait- class \Drupal\jsonapi\Normalizer\NormalizerBase- class \Drupal\jsonapi\Normalizer\EntityNormalizer implements \Symfony\Component\Serializer\Normalizer\DenormalizerInterface uses SerializedColumnNormalizerTrait- class \Drupal\jsonapi\Normalizer\ContentEntityNormalizer- class \Drupal\consumer_image_styles\Normalizer\ImageEntityNormalizer
 
 
- class \Drupal\jsonapi\Normalizer\ContentEntityNormalizer
 
- class \Drupal\jsonapi\Normalizer\EntityNormalizer implements \Symfony\Component\Serializer\Normalizer\DenormalizerInterface uses SerializedColumnNormalizerTrait
 
- class \Drupal\jsonapi\Normalizer\NormalizerBase
Expanded class hierarchy of ImageEntityNormalizer
1 string reference to 'ImageEntityNormalizer'
1 service uses ImageEntityNormalizer
File
- src/Normalizer/ ImageEntityNormalizer.php, line 18 
Namespace
Drupal\consumer_image_styles\NormalizerView source
class ImageEntityNormalizer extends ContentEntityNormalizer {
  /**
   * The interface or class that this Normalizer supports.
   *
   * @var string
   */
  protected $supportedInterfaceOrClass = File::class;
  /**
   * The formats that the Normalizer can handle.
   *
   * @var array
   */
  protected $formats = [
    'api_json',
  ];
  /**
   * The link manager.
   *
   * @var \Drupal\jsonapi\LinkManager\LinkManager
   */
  protected $linkManager;
  /**
   * The JSON API resource type repository.
   *
   * @var \Drupal\jsonapi\ResourceType\ResourceTypeRepositoryInterface
   */
  protected $resourceTypeRepository;
  /**
   * The entity type manager.
   *
   * @var \Drupal\Core\Entity\EntityTypeManagerInterface
   */
  protected $entityTypeManager;
  /**
   * @var \Drupal\consumers\Negotiator
   */
  protected $consumerNegotiator;
  /**
   * @var \Drupal\consumer_image_styles\ImageStylesProviderInterface
   */
  protected $imageStylesProvider;
  /**
   * Constructs an EntityNormalizer object.
   *
   * @param \Drupal\jsonapi\LinkManager\LinkManager $link_manager
   *   The link manager.
   * @param \Drupal\jsonapi\ResourceType\ResourceTypeRepositoryInterface $resource_type_repository
   *   The JSON API resource type repository.
   * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
   *   The entity type manager.
   * @param \Drupal\consumers\Negotiator $consumer_negotiator
   *   The consumer negotiator.
   * @param \Drupal\consumer_image_styles\ImageStylesProviderInterface
   *   Image styles utility.
   */
  public function __construct(LinkManager $link_manager, ResourceTypeRepositoryInterface $resource_type_repository, EntityTypeManagerInterface $entity_type_manager, Negotiator $consumer_negotiator, ImageStylesProviderInterface $imageStylesProvider) {
    parent::__construct($link_manager, $resource_type_repository, $entity_type_manager);
    $this->consumerNegotiator = $consumer_negotiator;
    $this->imageStylesProvider = $imageStylesProvider;
  }
  /**
   * {@inheritdoc}
   */
  public function supportsNormalization($data, $format = NULL) {
    // It is very tricky to detect if a file entity is an image or not. This is
    // typically done using a special field type to point to this entity.
    // However we don't have access to that in here. Besides we want this to
    // apply when requesting a listing of file entities as well, not only via
    // includes. For all this we'll do string matching against the mimetype.
    return parent::supportsNormalization($data, $format) && strpos($data
      ->get('filemime')->value, 'image/') !== FALSE;
  }
  /**
   * {@inheritdoc}
   */
  public function supportsDenormalization($data, $type, $format = NULL) {
    // We do not need to do anything special about denormalization. Passing here
    // will have the serializer use the normal content entity normalizer.
    return FALSE;
  }
  /**
   * {@inheritdoc}
   */
  public function normalize($entity, $format = NULL, array $context = []) {
    $file_entity_values = parent::normalize($entity, $format, $context);
    $variants = $this
      ->buildVariantValues($entity, $context);
    return new ImageNormalizerValue($variants, $file_entity_values);
  }
  /**
   * {@inheritdoc}
   */
  public function denormalize($data, $class, $format = NULL, array $context = []) {
    // This should never be called.
    throw new \Exception('Unsupported denormalizer.');
  }
  /**
   * @param \Drupal\Core\Entity\EntityInterface $entity
   * @param array $context
   *
   * @return \Drupal\jsonapi\Normalizer\Value\ValueExtractorInterface
   */
  protected function buildVariantValues(EntityInterface $entity, array $context = []) {
    $request = empty($context['request']) ? NULL : $context['request'];
    $consumer = $this->consumerNegotiator
      ->negotiateFromRequest($request);
    // Bail-out if no consumer is found.
    if (!$consumer) {
      $access = $entity
        ->access('view', $context['account'], TRUE);
      return new NullFieldNormalizerValue($access, 'attributes');
    }
    // Prepare some utils.
    $uri = $entity
      ->get('uri')->value;
    $get_image_url = function ($image_style) use ($uri) {
      return file_create_url($image_style
        ->buildUrl($uri));
    };
    // Generate derivatives only for the found ones.
    $image_styles = $this->imageStylesProvider
      ->loadStyles($consumer);
    $keys = array_keys($image_styles);
    $values = array_map($get_image_url, array_values($image_styles));
    $value = array_combine($keys, $values);
    return new ImageVariantItemNormalizerValue($value, new CacheableMetadata());
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| CacheableNormalizerInterface:: | constant | Name of key for bubbling cacheability metadata via serialization context. | ||
| EntityNormalizer:: | protected | function | Gets a field item instance for use with SerializedColumnNormalizerTrait. | |
| EntityNormalizer:: | protected | function | Gets the field names for the given entity. | |
| EntityNormalizer:: | protected | function | Gets the field names for the given entity. | 1 | 
| EntityNormalizer:: | protected | function | Prepares the input data to create the entity. | |
| EntityNormalizer:: | protected | function | Serializes a given field. | 1 | 
| ImageEntityNormalizer:: | protected | property | ||
| ImageEntityNormalizer:: | protected | property | The entity type manager. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | protected | property | The formats that the Normalizer can handle. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | protected | property | ||
| ImageEntityNormalizer:: | protected | property | The link manager. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | protected | property | The JSON API resource type repository. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | protected | property | The interface or class that this Normalizer supports. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | protected | function | ||
| ImageEntityNormalizer:: | public | function | Denormalizes data back into an object of the given class. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | public | function | Normalizes an object into a set of arrays/scalars. Overrides EntityNormalizer:: | |
| ImageEntityNormalizer:: | public | function | Implements \Symfony\Component\Serializer\Normalizer\DenormalizerInterface::supportsDenormalization() Overrides NormalizerBase:: | |
| ImageEntityNormalizer:: | public | function | Checks whether the given class is supported for normalization by this normalizer. Overrides NormalizerBase:: | |
| ImageEntityNormalizer:: | public | function | Constructs an EntityNormalizer object. Overrides EntityNormalizer:: | |
| NormalizerBase:: | protected | property | List of formats which supports (de-)normalization. | 3 | 
| NormalizerBase:: | protected | function | Adds cacheability if applicable. | |
| NormalizerBase:: | protected | function | Checks if the provided format is supported by this normalizer. | 2 | 
| SerializedColumnNormalizerTrait:: | protected | function | Checks if there is a serialized string for a column. | |
| SerializedColumnNormalizerTrait:: | protected | function | Checks if the data contains string value for serialize column. | |
| SerializedColumnNormalizerTrait:: | protected | function | Gets the names of all properties the plugin treats as serialized data. | |
| SerializedColumnNormalizerTrait:: | protected | function | Gets the names of all serialized properties. | 
