FestinHegre/vendor/symfony/serializer/Exception/NotNormalizableValueException.php
2024-09-26 17:26:04 +02:00

65 lines
1.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\Exception;
/**
* @author Christian Flothmann <christian.flothmann@sensiolabs.de>
*/
class NotNormalizableValueException extends UnexpectedValueException
{
private ?string $currentType = null;
private ?array $expectedTypes = null;
private ?string $path = null;
private bool $useMessageForUser = false;
/**
* @param list<string|\Stringable> $expectedTypes
* @param bool $useMessageForUser If the message passed to this exception is something that can be shown
* safely to your user. In other words, avoid catching other exceptions and
* passing their message directly to this class.
*/
public static function createForUnexpectedDataType(string $message, mixed $data, array $expectedTypes, ?string $path = null, bool $useMessageForUser = false, int $code = 0, ?\Throwable $previous = null): self
{
$self = new self($message, $code, $previous);
$self->currentType = get_debug_type($data);
$self->expectedTypes = array_map(strval(...), $expectedTypes);
$self->path = $path;
$self->useMessageForUser = $useMessageForUser;
return $self;
}
public function getCurrentType(): ?string
{
return $this->currentType;
}
/**
* @return string[]|null
*/
public function getExpectedTypes(): ?array
{
return $this->expectedTypes;
}
public function getPath(): ?string
{
return $this->path;
}
public function canUseMessageForUser(): ?bool
{
return $this->useMessageForUser;
}
}