<?php
namespace App\Voter\__Quote;
use App\Entity\Booking\Quote;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
use Symfony\Component\Security\Core\User\UserInterface;
class QuoteQuoteVoter extends Voter
{
const LIST = "QUOTE_QUOTE_LIST";
const DETAILS_BASE = "QUOTE_QUOTE_DETAILS_BASE";
const UPDATE = "QUOTE_QUOTE_UPDATE";
protected function supports($attribute, $subject): bool
{
return in_array($attribute, [
self::LIST,
self::DETAILS_BASE,
self::UPDATE,
]) && ($subject === null || $subject instanceof Quote);
}
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::DETAILS_BASE:
return $this->voteOnDetailsBase($subject, $loggedUser);
case self::UPDATE:
return $this->voteOnUpdate($subject, $loggedUser);
}
return false;
}
private function voteOnList(UserInterface $loggedUser): bool
{
return in_array(self::LIST, $loggedUser->getRoles());
}
private function voteOnDetailsBase(?Quote $quote, UserInterface $loggedUser): bool
{
if ($quote === null) {
return false;
}
return in_array(self::DETAILS_BASE, $loggedUser->getRoles());
}
private function voteOnUpdate(?Quote $quote, UserInterface $loggedUser): bool
{
if ($quote === null) {
return false;
}
return in_array(self::UPDATE, $loggedUser->getRoles());
}
}