<?php
namespace Crea\SecurityBundle\Voter;
use Crea\SecurityBundle\Entity\Profile;
use Crea\SecurityBundle\Entity\User;
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
use Symfony\Component\Security\Core\Authorization\Voter\Voter;
use Symfony\Component\Security\Core\User\UserInterface;
class ProfileVoter extends Voter
{
const PROFILE_LIST = "SECURITY_PROFILE_LIST";
const PROFILE_CREATE = "SECURITY_PROFILE_CREATE";
const PROFILE_UPDATE = "SECURITY_PROFILE_UPDATE";
const PROFILE_DUPLICATE = "SECURITY_PROFILE_DUPLICATE";
const PROFILE_REMOVE = "SECURITY_PROFILE_REMOVE";
/**
* @inheritDoc
*/
protected function supports($attribute, $subject): bool
{
return in_array($attribute, [
self::PROFILE_LIST,
self::PROFILE_CREATE,
self::PROFILE_UPDATE,
self::PROFILE_DUPLICATE,
self::PROFILE_REMOVE,
]) && ($subject === null || $subject instanceof Profile);
}
/**
* @inheritDoc
*/
protected function voteOnAttribute($attribute, $subject, TokenInterface $token): bool
{
/** @var User $loggedUser */
$loggedUser = $token->getUser();
if (!$loggedUser instanceof UserInterface)
return false;
switch ($attribute) {
case self::PROFILE_LIST:
return $this->voteOnList($loggedUser);
case self::PROFILE_CREATE:
return $this->voteOnCreate($loggedUser);
case self::PROFILE_UPDATE:
return $this->voteOnUpdate($subject, $loggedUser);
case self::PROFILE_DUPLICATE:
return $this->voteOnDuplicate($subject, $loggedUser);
case self::PROFILE_REMOVE:
return $this->voteOnRemove($subject, $loggedUser);
}
return false;
}
private function voteOnList(UserInterface $loggedUser): bool
{
if (in_array(self::PROFILE_LIST, $loggedUser->getRoles())) {
return true;
}
return false;
}
private function voteOnCreate(UserInterface $loggedUser): bool
{
if (in_array(self::PROFILE_CREATE, $loggedUser->getRoles())) {
return true;
}
return false;
}
private function voteOnUpdate(?Profile $subject, User $loggedUser): bool
{
if (!in_array(self::PROFILE_UPDATE, $loggedUser->getRoles()))
return false;
if (null === $subject)
return true;
if ($loggedUser->getProfile()->getId() !== $subject->getId())
return true;
if (in_array("ROLE_ADMIN", $loggedUser->getRoles()))
return true;
return false;
}
private function voteOnRemove(?Profile $subject, User $loggedUser): bool
{
if (!in_array(self::PROFILE_REMOVE, $loggedUser->getRoles()))
return false;
if (null === $subject)
return true;
if ($loggedUser->getProfile()->getId() !== $subject->getId())
return true;
if (in_array("ROLE_ADMIN", $loggedUser->getRoles()))
return true;
return false;
}
private function voteOnDuplicate($subject, User $loggedUser): bool
{
return $this->voteOnUpdate($subject, $loggedUser);
}
}