src/Security/Voter/IsUserHimselfVoter.php
<?php
declare(strict_types = 1);
/**
* /src/Security/Voter/IsUserHimselfVoter.php
*
* @author TLe, Tarmo Leppänen <tarmo.leppanen@pinja.com>
*/
namespace App\Security\Voter;
use App\Entity\User;
use App\Security\SecurityUser;
use Override;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
/**
* @package App\Security
* @author TLe, Tarmo Leppänen <tarmo.leppanen@pinja.com>
*
* @template TAttribute of string
* @template TSubject of mixed
*
* @extends Voter<TAttribute, TSubject>
*/
class IsUserHimselfVoter extends Voter
{
private const string ATTRIBUTE = 'IS_USER_HIMSELF';
/**
* {@inheritdoc}
*/
#[Override]
protected function supports(string $attribute, mixed $subject): bool
{
return $attribute === self::ATTRIBUTE && $subject instanceof User;
}
/**
* {@inheritdoc}
*/
#[Override]
protected function voteOnAttribute(string $attribute, mixed $subject, TokenInterface $token): bool
{
$user = $token->getUser();
return $user instanceof SecurityUser && $subject instanceof User && $user->getUuid() === $subject->getId();
}
}