<?php
namespace App\Security\Voter;
use App\Entity\Folder;
use Symfony\Component\Security\Core\User\UserInterface;
class FolderVoter extends AbstractDeepVoter
{
public static $listAttribute = 'list_folders';
public static $createAttribute = 'create_folder';
private $currentFolder;
protected function listAttribute(): string
{
return self::$listAttribute;
}
protected function createAttribute(): string
{
return self::$createAttribute;
}
protected function isSupportedSubject(object $subject): bool
{
if ($isFolder = $subject instanceof Folder) {
$this->currentFolder = $subject;
}
return $isFolder;
}
protected function canList(UserInterface $user): bool
{
return $user->isAnAdmin();
}
protected function canCreate(UserInterface $user): bool
{
return $user->isAnAdmin();
}
protected function canRead(UserInterface $user): bool
{
return $user->isAnAdmin()
|| $user->canAccessFolder($this->currentFolder)
;
}
protected function canUpdate(UserInterface $user): bool
{
return $user->isAnAdmin();
}
protected function canDelete(UserInterface $user): bool
{
return $user->isMainAdmin();
}
}