caisse-bliss/vendor/symfony/serializer/Normalizer/MimeMessageNormalizer.php

125 lines
3.9 KiB
PHP

<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Serializer\Normalizer;
use Symfony\Component\Mime\Address;
use Symfony\Component\Mime\Header\HeaderInterface;
use Symfony\Component\Mime\Header\Headers;
use Symfony\Component\Mime\Header\UnstructuredHeader;
use Symfony\Component\Mime\Message;
use Symfony\Component\Mime\Part\AbstractPart;
use Symfony\Component\Serializer\SerializerAwareInterface;
use Symfony\Component\Serializer\SerializerInterface;
/**
* Normalize Mime message classes.
*
* It forces the use of a PropertyNormalizer instance for normalization
* of all data objects composing a Message.
*
* Emails using resources for any parts are not serializable.
*/
final class MimeMessageNormalizer implements NormalizerInterface, DenormalizerInterface, SerializerAwareInterface, CacheableSupportsMethodInterface
{
private $serializer;
private $normalizer;
private $headerClassMap;
private $headersProperty;
public function __construct(PropertyNormalizer $normalizer)
{
$this->normalizer = $normalizer;
$this->headerClassMap = (new \ReflectionClassConstant(Headers::class, 'HEADER_CLASS_MAP'))->getValue();
$this->headersProperty = new \ReflectionProperty(Headers::class, 'headers');
$this->headersProperty->setAccessible(true);
}
public function setSerializer(SerializerInterface $serializer)
{
$this->serializer = $serializer;
$this->normalizer->setSerializer($serializer);
}
/**
* {@inheritdoc}
*/
public function normalize(mixed $object, string $format = null, array $context = []): array|string|int|float|bool|\ArrayObject|null
{
if ($object instanceof Headers) {
$ret = [];
foreach ($this->headersProperty->getValue($object) as $name => $header) {
$ret[$name] = $this->serializer->normalize($header, $format, $context);
}
return $ret;
}
if ($object instanceof AbstractPart) {
$ret = $this->normalizer->normalize($object, $format, $context);
$ret['class'] = \get_class($object);
unset($ret['seekable'], $ret['cid'], $ret['handle']);
return $ret;
}
return $this->normalizer->normalize($object, $format, $context);
}
/**
* {@inheritdoc}
*/
public function denormalize(mixed $data, string $type, string $format = null, array $context = []): mixed
{
if (Headers::class === $type) {
$ret = [];
foreach ($data as $headers) {
foreach ($headers as $header) {
$ret[] = $this->serializer->denormalize($header, $this->headerClassMap[strtolower($header['name'])] ?? UnstructuredHeader::class, $format, $context);
}
}
return new Headers(...$ret);
}
if (AbstractPart::class === $type) {
$type = $data['class'];
unset($data['class']);
}
return $this->normalizer->denormalize($data, $type, $format, $context);
}
/**
* {@inheritdoc}
*/
public function supportsNormalization(mixed $data, string $format = null): bool
{
return $data instanceof Message || $data instanceof Headers || $data instanceof HeaderInterface || $data instanceof Address || $data instanceof AbstractPart;
}
/**
* {@inheritdoc}
*/
public function supportsDenormalization(mixed $data, string $type, string $format = null): bool
{
return is_a($type, Message::class, true) || Headers::class === $type || AbstractPart::class === $type;
}
/**
* {@inheritdoc}
*/
public function hasCacheableSupportsMethod(): bool
{
return __CLASS__ === static::class;
}
}