class ConfigEntityNormalizer

Same name in other branches
  1. 9 core/modules/serialization/src/Normalizer/ConfigEntityNormalizer.php \Drupal\serialization\Normalizer\ConfigEntityNormalizer
  2. 8.9.x core/modules/serialization/src/Normalizer/ConfigEntityNormalizer.php \Drupal\serialization\Normalizer\ConfigEntityNormalizer
  3. 10 core/modules/serialization/src/Normalizer/ConfigEntityNormalizer.php \Drupal\serialization\Normalizer\ConfigEntityNormalizer

Normalizes/denormalizes Drupal config entity objects into an array structure.

Hierarchy

Expanded class hierarchy of ConfigEntityNormalizer

2 files declare their use of ConfigEntityNormalizer
ConfigEntityNormalizerTest.php in core/modules/serialization/tests/src/Unit/Normalizer/ConfigEntityNormalizerTest.php
LayoutEntityDisplayNormalizer.php in core/modules/layout_builder/src/Normalizer/LayoutEntityDisplayNormalizer.php
1 string reference to 'ConfigEntityNormalizer'
serialization.services.yml in core/modules/serialization/serialization.services.yml
core/modules/serialization/serialization.services.yml
1 service uses ConfigEntityNormalizer
serializer.normalizer.config_entity in core/modules/serialization/serialization.services.yml
Drupal\serialization\Normalizer\ConfigEntityNormalizer

File

core/modules/serialization/src/Normalizer/ConfigEntityNormalizer.php, line 10

Namespace

Drupal\serialization\Normalizer
View source
class ConfigEntityNormalizer extends EntityNormalizer {
    
    /**
     * {@inheritdoc}
     */
    public function normalize($object, $format = NULL, array $context = []) : array|string|int|float|bool|\ArrayObject|null {
        return static::getDataWithoutInternals($object->toArray());
    }
    
    /**
     * {@inheritdoc}
     */
    public function denormalize($data, $class, $format = NULL, array $context = []) : mixed {
        return parent::denormalize(static::getDataWithoutInternals($data), $class, $format, $context);
    }
    
    /**
     * Gets the given data without the internal implementation details.
     *
     * @param array $data
     *   The data that is either currently or about to be stored in configuration.
     *
     * @return array
     *   The same data, but without internals. Currently, that is only the '_core'
     *   key, which is reserved by Drupal core to handle complex edge cases
     *   correctly. Data in the '_core' key is irrelevant to clients reading
     *   configuration, and is not allowed to be set by clients writing
     *   configuration: it is for Drupal core only, and managed by Drupal core.
     *
     * @see https://www.drupal.org/node/2653358
     */
    protected static function getDataWithoutInternals(array $data) {
        return array_diff_key($data, [
            '_core' => TRUE,
        ]);
    }
    
    /**
     * {@inheritdoc}
     */
    public function getSupportedTypes(?string $format) : array {
        return [
            ConfigEntityInterface::class => TRUE,
        ];
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title Overrides
CacheableNormalizerInterface::SERIALIZATION_CONTEXT_CACHEABILITY constant Name of key for bubbling cacheability metadata via serialization context.
ConfigEntityNormalizer::denormalize public function Overrides EntityNormalizer::denormalize
ConfigEntityNormalizer::getDataWithoutInternals protected static function Gets the given data without the internal implementation details. 1
ConfigEntityNormalizer::getSupportedTypes public function Overrides EntityNormalizer::getSupportedTypes 1
ConfigEntityNormalizer::normalize public function Overrides ComplexDataNormalizer::normalize
EntityNormalizer::__construct public function Constructs an EntityNormalizer object.
FieldableEntityNormalizerTrait::$entityFieldManager protected property The entity field manager.
FieldableEntityNormalizerTrait::$entityTypeManager protected property The entity type manager.
FieldableEntityNormalizerTrait::$entityTypeRepository protected property The entity type repository.
FieldableEntityNormalizerTrait::constructValue protected function Build the field item value using the incoming data. 5
FieldableEntityNormalizerTrait::denormalizeFieldData protected function Denormalizes entity data by denormalizing each field individually.
FieldableEntityNormalizerTrait::determineEntityTypeId protected function Determines the entity type ID to denormalize as.
FieldableEntityNormalizerTrait::extractBundleData protected function Denormalizes the bundle property so entity creation can use it.
FieldableEntityNormalizerTrait::getEntityFieldManager protected function Returns the entity field manager.
FieldableEntityNormalizerTrait::getEntityTypeDefinition protected function Gets the entity type definition.
FieldableEntityNormalizerTrait::getEntityTypeManager protected function Returns the entity type manager.
FieldableEntityNormalizerTrait::getEntityTypeRepository protected function Returns the entity type repository.
NormalizerBase::$format protected property List of formats which supports (de-)normalization. 1
NormalizerBase::addCacheableDependency protected function Adds cacheability if applicable.
NormalizerBase::checkFormat protected function Checks if the provided format is supported by this normalizer. 1
NormalizerBase::supportsDenormalization public function Implements \Symfony\Component\Serializer\Normalizer\DenormalizerInterface::supportsDenormalization() 1
NormalizerBase::supportsNormalization public function 1

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