<?php
namespace App\Security\Voter\ElearningPlatform;
use App\Entity\User;
use App\Service\Member\MemberQualificationChecker;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
/**
* @extends Voter<string, mixed>
*/
class DirectorOrMoreAccessVoter extends Voter
{
public const DIRECTOR_OR_MORE_ACCESS = 'director_or_more_access';
private MemberQualificationChecker $memberQualificationChecker;
public function __construct(MemberQualificationChecker $memberQualificationChecker)
{
$this->memberQualificationChecker = $memberQualificationChecker;
}
protected function supports(string $attribute, $subject): bool
{
return self::DIRECTOR_OR_MORE_ACCESS === $attribute;
}
protected function voteOnAttribute(string $attribute, $subject, TokenInterface $token): bool
{
/** @var User|null $user */
$user = $token->getUser();
if (!$user instanceof User) {
return false;
}
$member = $user->getMember();
if (null === $member) {
return false;
}
if (true === $member->isDeleted()) {
return false;
}
return $this->memberQualificationChecker->isMemberDirectorOrMore($member);
}
}