<?php
namespace App\Voter\__Accounting;
use App\Voter\VoterTrait;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
use Symfony\Component\Security\Core\User\UserInterface;
class AccountingInsuranceVoter extends Voter
{
use VoterTrait;
const LIST = "ACCOUNTING_INSURANCE_LIST";
const EXPORT = "ACCOUNTING_INSURANCE_EXPORT";
protected function supports($attribute, $subject): bool
{
return (in_array($attribute, [self::LIST, self::EXPORT]) && $subject === null);
}
protected function voteOnAttribute($attribute, $subject, TokenInterface $token): bool
{
$loggedUser = $token->getUser();
if (!$loggedUser instanceof UserInterface) {
return false;
}
switch ($attribute) {
case self::LIST:
return $this->voteOnList($loggedUser);
case self::EXPORT:
return $this->voteOnExport($loggedUser);
}
return false;
}
private function voteOnList(UserInterface $loggedUser): bool
{
return in_array(self::LIST, $loggedUser->getRoles());
}
private function voteOnExport(UserInterface $loggedUser): bool
{
return in_array(self::EXPORT, $loggedUser->getRoles());
}
}