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