* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Serializer\Attribute; use Symfony\Component\Serializer\Exception\InvalidArgumentException; /** * @author Maxime Steinhausser */ #[\Attribute(\Attribute::TARGET_CLASS | \Attribute::TARGET_PROPERTY | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)] class Context { private array $groups; /** * @param array $context The common context to use when serializing or deserializing * @param array $normalizationContext The context to use when serializing * @param array $denormalizationContext The context to use when deserializing * @param string|string[] $groups The groups to use when serializing or deserializing * * @throws InvalidArgumentException */ public function __construct( private readonly array $context = [], private readonly array $normalizationContext = [], private readonly array $denormalizationContext = [], string|array $groups = [], ) { if (!$context && !$normalizationContext && !$denormalizationContext) { throw new InvalidArgumentException(sprintf('At least one of the "context", "normalizationContext", or "denormalizationContext" options must be provided as a non-empty array to "%s".', static::class)); } $this->groups = (array) $groups; foreach ($this->groups as $group) { if (!\is_string($group)) { throw new InvalidArgumentException(sprintf('Parameter "groups" given to "%s" must be a string or an array of strings, "%s" given.', static::class, get_debug_type($group))); } } } public function getContext(): array { return $this->context; } public function getNormalizationContext(): array { return $this->normalizationContext; } public function getDenormalizationContext(): array { return $this->denormalizationContext; } public function getGroups(): array { return $this->groups; } } if (!class_exists(\Symfony\Component\Serializer\Annotation\Context::class, false)) { class_alias(Context::class, \Symfony\Component\Serializer\Annotation\Context::class); }