RoleCheck.php 1.55 KB
Newer Older
Julien Jorry committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
<?php

namespace App\Tools;

use Symfony\Component\HttpFoundation\Session\SessionInterface;
use Symfony\Component\Security\Core\Security;

class RoleCheck
{
    private $security;
    private $session;

    public function __construct(Security $security, SessionInterface $session)
    {
        $this->security = $security;
        $this->session = $session;
    }

    /**
     * Fonction permettant de vérifier que l'utilisateur a choisi ce rôle si il en a plusieurs ou sinon qu'il a bien ce rôle
     *
     * @param  string  $role Role
     * @return boolean       Boolean
     */
    public function isGranted($role)
    {
        if ($this->session->has('_groupId')) {
            $group = $this->session->get('_groupId');
            return in_array($role, $group->getRoles());
        } else {
            return ($this->security->getUser() && $this->security->getUser()->isGranted($role));
        }
    }

    public function getCurrentRole()
    {
        if ($this->session->has('_groupId')) {
            return $this->session->get('_groupId');
        } else {
            if (count($this->security->getUser()->getRoles()) == 1) {
                return $this->security->getUser()->getRoles()[0];
            } elseif (count($this->security->getUser()->getRoles()) <= 0) {
                throw new \Exception('Utilisateur sans rôle => Impossible de faire une transaction ! ');
            } else {
                throw new \Exception('Utilisateur avec plusieurs rôles devant choisir le rôle avant de faire une transaction ! ');
            }
        }
    }
}