IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Symfony PHP Discussion :

Redirection après le login selon le role du user


Sujet :

Symfony PHP

  1. #1
    Membre habitué
    Homme Profil pro
    Webmaster
    Inscrit en
    juillet 2015
    Messages
    473
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : juillet 2015
    Messages : 473
    Points : 178
    Points
    178
    Par défaut Redirection après le login selon le role du user
    Bonjour,

    J'ai deux rôles, ROLE_WORKER et ROLE_CUSTOMER je souhaite rediriger l'utilisateur après sa connexion selon son rôle.

    J'ai déjà généré la base de code avec le make:auth voici mon code (voir ligne 53) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    <?php
     
    namespace App\Security;
     
    use Symfony\Component\HttpFoundation\RedirectResponse;
    use Symfony\Component\HttpFoundation\Request;
    use Symfony\Component\HttpFoundation\Response;
    use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
    use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
    use Symfony\Component\Security\Core\Security;
    use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
    use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
    use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
    use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
    use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
    use Symfony\Component\Security\Http\Authenticator\Passport\PassportInterface;
    use Symfony\Component\Security\Http\Util\TargetPathTrait;
     
    class AppAuthenticator extends AbstractLoginFormAuthenticator
    {
        use TargetPathTrait;
     
        public const LOGIN_ROUTE = 'app_login';
     
        private UrlGeneratorInterface $urlGenerator;
     
        public function __construct(UrlGeneratorInterface $urlGenerator)
        {
            $this->urlGenerator = $urlGenerator;
        }
     
        public function authenticate(Request $request): PassportInterface
        {
            $email = $request->request->get('email', '');
     
            $request->getSession()->set(Security::LAST_USERNAME, $email);
     
            return new Passport(
                new UserBadge($email),
                new PasswordCredentials($request->request->get('password', '')),
                [
                    new CsrfTokenBadge('authenticate', $request->get('_csrf_token')),
                ]
            );
        }
     
        public function onAuthenticationSuccess(Request $request, TokenInterface $token, string $firewallName): ?Response
        {
            if ($targetPath = $this->getTargetPath($request->getSession(), $firewallName)) {
                return new RedirectResponse($targetPath);
            }
     
            // Je pense que je dois écrire mon code ici avec un if selon le rôle mais je ne trouve aucune doc la dessus pour accéder au rôle du user
            return new RedirectResponse($this->urlGenerator->generate('home'));
        }
     
        protected function getLoginUrl(Request $request): string
        {
            return $this->urlGenerator->generate(self::LOGIN_ROUTE);
        }
    }
    Vous avez des idées ?

    merci.

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    Autre
    Inscrit en
    juillet 2021
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : juillet 2021
    Messages : 20
    Points : 31
    Points
    31
    Par défaut
    Bonjour,

    Tu peux récupérer l'utilisateur (et ces rôles) via le paramètres $token dans la fonction onAuthenticationSuccess, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
        public function onAuthenticationSuccess(Request $request, TokenInterface $token, string $firewallName): ?Response
        {
            $user = $token->getUser();
     
            if (in_array('ROLE_WORKER', $user->getRoles())) {
                return new RedirectResponse($this->urlGenerator->generate('routename_for_workers'));
            }
     
            if (in_array('ROLE_CUSTOMER', $user->getRoles())) {
                return new RedirectResponse($this->urlGenerator->generate('routename_for_customers'));
            }
     
            if ($targetPath = $this->getTargetPath($request->getSession(), $firewallName)) {
                return new RedirectResponse($targetPath);
            }
     
            return new RedirectResponse($this->urlGenerator->generate('home'));
        }

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [2.x] Redirection après un login précédé d'un session timeout
    Par placide90 dans le forum Symfony
    Réponses: 1
    Dernier message: 21/05/2015, 12h06
  2. Réponses: 2
    Dernier message: 27/12/2011, 17h07
  3. Authentification jdbcRealm et redirection vers des pages selon le role
    Par younesgates dans le forum Développement Web en Java
    Réponses: 0
    Dernier message: 02/03/2011, 10h21
  4. Redirection après un login
    Par Icanhas dans le forum Réseau/Web
    Réponses: 4
    Dernier message: 10/03/2010, 11h53
  5. Effectuer une redirection après un login
    Par chflb dans le forum JSF
    Réponses: 6
    Dernier message: 26/08/2008, 20h18

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo