<?php
namespace App\Voter;
use App\Entity\Partner\PartnerCompanyDiscount;
use Crea\SecurityBundle\Entity\User;
use Crea\SecurityBundle\Entity\UserInterface;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
class PartnerVoter extends Voter
{
const LIST = "PARTNER_LIST";
const DETAIL = "PARTNER_DETAIL";
const CREATE = "PARTNER_CREATE";
const UPDATE = "PARTNER_UPDATE";
const REMOVE = "PARTNER_REMOVE";
const SWITCH_ACTIVE = "PARTNER_SWITCH_ACTIVE";
const DISCOUNT_LIST = "PARTNER_DISCOUNT_LIST";
const DISCOUNT_CREATE = "PARTNER_DISCOUNT_CREATE";
const DISCOUNT_UPDATE = "PARTNER_DISCOUNT_UPDATE";
const DISCOUNT_UPDATE_FORCE = "PARTNER_DISCOUNT_UPDATE_FORCE";
const DISCOUNT_DELETE = "PARTNER_DISCOUNT_DELETE";
const COMMERCIAL_FOLLOW_UP_LIST = "PARTNER_COMMERCIAL_FOLLOW_UP_LIST";
const FOLLOW_UP_LIST = "PARTNER_FOLLOW_UP_LIST";
const FOLLOW_UP_UPDATE = "PARTNER_FOLLOW_UP_UPDATE";
const GLOBAL_TURNOVER_LIST = "PARTNER_GLOBAL_TURNOVER_LIST";
const INDIVIDUAL_SALE_LIST = "PARTNER_INDIVIDUAL_SALE_LIST";
protected function supports($attribute, $subject): bool
{
return in_array($attribute, [
self::LIST,
self::DETAIL,
self::CREATE,
self::UPDATE,
self::REMOVE,
self::SWITCH_ACTIVE,
self::DISCOUNT_LIST,
self::DISCOUNT_CREATE,
self::DISCOUNT_UPDATE,
self::DISCOUNT_UPDATE_FORCE,
self::DISCOUNT_DELETE,
self::COMMERCIAL_FOLLOW_UP_LIST,
self::FOLLOW_UP_LIST,
self::FOLLOW_UP_UPDATE,
self::GLOBAL_TURNOVER_LIST,
self::INDIVIDUAL_SALE_LIST,
]);
}
protected function voteOnAttribute($attribute, $subject, TokenInterface $token): bool
{
/** @var User $loggedUser */
$loggedUser = $token->getUser();
if (!$loggedUser instanceof UserInterface)
return false;
switch ($attribute) {
case self::DISCOUNT_UPDATE:
return $this->voteOnDiscountUpdate($subject, $loggedUser);
default:
return in_array($attribute, $loggedUser->getRoles());
}
}
private function voteOnDiscountUpdate($subject, UserInterface $loggedUser): bool
{
if ($subject === null) {
return false;
}
/** @var PartnerCompanyDiscount $partnerCompanyDiscount */
$partnerCompanyDiscount = $subject;
if ($partnerCompanyDiscount->isArchived() || $partnerCompanyDiscount->isDefault()) {
return in_array(self::DISCOUNT_UPDATE_FORCE, $loggedUser->getRoles());
}
return in_array(self::DISCOUNT_UPDATE, $loggedUser->getRoles());
}
}