Location: /core/modules/serialization/src/Normalizer/PrimitiveDataNormalizer.php
namespace Drupal\serialization\Normalizer;
use Drupal\Core\Field\FieldItemInterface;
use Drupal\Core\TypedData\PrimitiveInterface;
use Drupal\Core\TypedData\TypedDataInterface;
/**
* Converts primitive data objects to their casted values.
*/
class PrimitiveDataNormalizer extends NormalizerBase {
use SerializedColumnNormalizerTrait;
use SchematicNormalizerTrait;
use JsonSchemaReflectionTrait;
/**
* {@inheritdoc}
*/
public function doNormalize($object, $format = NULL, array $context = []): array|string|int|float|bool|\ArrayObject|NULL {
// Add cacheability if applicable.
$this->addCacheableDependency($context, $object);
$parent = $object->getParent();
if ($parent instanceof FieldItemInterface && $object->getValue()) {
$serialized_property_names = $this->getCustomSerializedPropertyNames($parent);
if (in_array($object->getName(), $serialized_property_names, TRUE)) {
return unserialize($object->getValue());
}
}
// Typed data casts NULL objects to their empty variants, so for example
// the empty string ('') for string type data, or 0 for integer typed data.
// In a better world with typed data implementing algebraic data types,
// getCastedValue would return NULL, but as typed data is not aware of real
// optional values on the primitive level, we implement our own optional
// value normalization here.
return $object->getValue() === NULL ? NULL : $object->getCastedValue();
}
/**
* {@inheritdoc}
*/
public function getNormalizationSchema(mixed $object, array $context = []): array {
$nullable = !$object instanceof TypedDataInterface || !$object->getDataDefinition()->isRequired();
return $this->getJsonSchemaForMethod(
$object,
'getCastedValue',
['$comment' => 'Unable to provide schema, no type specified.'],
$nullable,
);
}
/**
* {@inheritdoc}
*/
public function getSupportedTypes(?string $format): array {
return [
PrimitiveInterface::class => TRUE,
];
}
}