TypedDataNormalizer.php
Same filename and directory in other branches
Namespace
Drupal\serialization\NormalizerFile
-
core/
modules/ serialization/ src/ Normalizer/ TypedDataNormalizer.php
View source
<?php
namespace Drupal\serialization\Normalizer;
use Drupal\Core\TypedData\TypedDataInterface;
/**
* Normalizes typed data objects into strings or arrays.
*/
class TypedDataNormalizer extends NormalizerBase {
use SchematicNormalizerTrait;
use JsonSchemaReflectionTrait;
/**
* {@inheritdoc}
*/
public function doNormalize($object, $format = NULL, array $context = []) : array|string|int|float|bool|\ArrayObject|null {
$this->addCacheableDependency($context, $object);
$value = $object->getValue();
// Support for stringable value objects: avoid numerous custom normalizers.
if (is_object($value) && method_exists($value, '__toString')) {
$value = (string) $value;
}
return $value;
}
/**
* {@inheritdoc}
*/
protected function getNormalizationSchema(mixed $object, array $context = []) : array {
assert($object instanceof TypedDataInterface);
$value = $object->getValue();
$nullable = !$object->getDataDefinition()
->isRequired();
// Match the special-cased logic in ::normalize().
if (is_object($value) && method_exists($value, '__toString')) {
return $nullable ? [
'oneOf' => [
'string',
'null',
],
] : [
'type' => 'string',
];
}
return $this->getJsonSchemaForMethod($object, 'getValue', [
'$comment' => static::generateNoSchemaAvailableMessage($object),
], $nullable);
}
/**
* {@inheritdoc}
*/
public function getSupportedTypes(?string $format) : array {
return [
TypedDataInterface::class => TRUE,
];
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
TypedDataNormalizer | Normalizes typed data objects into strings or arrays. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.