| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- <?php
- declare(strict_types=1);
- namespace App\Serializer;
- use ApiPlatform\Core\Serializer\SerializerContextBuilderInterface;
- use Symfony\Component\HttpFoundation\Request;
- use Symfony\Component\Security\Core\Authorization\AuthorizationCheckerInterface;
- use App\Entity\Access\Access;
- use Symfony\Component\Security\Core\Security;
- /**
- * Classe servant à ajouter le groupe de denormalization à la ressource Access par rapport au role de l'utilisateur
- */
- final class AccessContextBuilder implements SerializerContextBuilderInterface
- {
- public function __construct(
- private SerializerContextBuilderInterface $decorated,
- private AuthorizationCheckerInterface $authorizationChecker,
- private Security $security
- )
- { }
- public function createFromRequest(Request $request, bool $normalization, ?array $extractedAttributes = null): array
- {
- $context = $this->decorated->createFromRequest($request, $normalization, $extractedAttributes);
- $resourceClass = $context['resource_class'] ?? null;
- //On ajoute un nouveau groupe seulement si : la ressource est Access, on est en denormalization, l'utilisateur n'a pas le ROLE_USERS
- //et la denormalization est faite sur l'Access de l'utilisateur connecté
- if (
- $resourceClass === Access::class &&
- false === $normalization &&
- !$this->authorizationChecker->isGranted('ROLE_USERS') &&
- $request->get('id') == $this->security->getUser()->getId()
- ){
- $context['groups'] = $context['groups'] ?? [];
- $context['groups'][] = 'my_access:input';
- }
- return $context;
- }
- }
|