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 :

Security et les ROLES


Sujet :

Symfony PHP

  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    546
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 546
    Par défaut Security et les ROLES
    Bonjour,

    Je croyais avoir bien fait mais il y a quelque chose qui m'échappe, je m'explique.
    Dans mon application j'ai 2 types d'utilisateurs : client et supplier qui ont chacun un ROLE_CLIENT ou un ROLE_SUPPLIER. (il y a aussi admin, mais je n'en parle pas ici...)
    Quand je me connecte avec un client dans la webtoolbar, je vois son role qui est : [ROLE_CLIENT, ROLE_USER]
    Et si je me connecte avec un supplier le role est : [ROLE_SUPPLIER, ROLE_USER]
    Donc je me dit jusque là c'est bon.
    Dans mon sécurity.yml j'ai mis comme hierarchy :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        role_hierarchy:
            ROLE_ADMIN:       [ROLE_CLIENT, ROLE_SUPPLIER]
    J'utilise les annotations pour ma security dans les controlleurs.
    J'ai écrit une action dont la signature est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        /**
         * Assure le téléchargement de fichier simple
         * @param \ENT\DatabaseBundle\Entity\File $file
         * @return \Symfony\Component\HttpFoundation\Response
         * @Secure(roles="ROLE_CLIENT")
         */
        public function downloadAction(File $file) {
    donc pour moi seul un client peut exécuter cette action. Or si je me connecte avec un supplier je peux sans problème exécuter l'action.
    Aurais-je oublié quelque chose ?
    Merci de votre aide.

  2. #2
    Membre émérite
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    725
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juin 2011
    Messages : 725
    Par défaut
    Bonjour,

    As tu activé le JMS\DiExtraBundle\JMSDiExtraBundle ?

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    546
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 546
    Par défaut
    J'ai activé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
                new JMS\SecurityExtraBundle\JMSSecurityExtraBundle(),
                new JMS\AopBundle\JMSAopBundle(),
    C'est quoi ce bundle JMSDiExtraBundle ?
    D'après la doc Symfony : http://symfony.com/fr/doc/current/book/security.html JMS\SecurityExtraBundle est suffisant...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    use JMS\SecurityExtraBundle\Annotation\Secure;
    /**
     * @Secure(roles="ROLE_ADMIN")
     */
    public function helloAction($name)
    {
        // ...
    }

  4. #4
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    546
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 546
    Par défaut
    J'ai activé le bundle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new JMS\DiExtraBundle\JMSDiExtraBundle($this),
    dans mon AppKernel.php et ça à l'air de fonctionner.
    Je vais quand même creuser la question car on ne parle pas de ce bundle dans la doc ou les tutos que j'ai pu voir. Et j'aime bien savoir ce que je fais...
    Si vous avez des infos je suis preneur...
    Merci.

  5. #5
    Membre émérite
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    725
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juin 2011
    Messages : 725
    Par défaut
    Il est vrai qu'il serait bien plus pertinent de lever une Exception si le système d'annotation "Secure" n'est pas pleinement fonctionnel

    néammoins la doc est ici et parle bien de l'installation du DIExtraBundle
    http://jmsyst.com/bundles/JMSSecurit...2/installation

    Il y a également une issue en attente (depuis 1 an!)
    https://github.com/schmittjoh/JMSSec...dle/issues/139

Discussions similaires

  1. Problème sur les roles d'applications
    Par Peter p@n ! dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 23/05/2008, 23h23
  2. page par défault et les roles
    Par Mathieu.Nanoux dans le forum ASP.NET
    Réponses: 1
    Dernier message: 23/11/2007, 14h24
  3. Page d'authentification selon les roles
    Par taroudant dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 27/01/2007, 17h44
  4. Norton Internet security et les sockets
    Par djo.mos dans le forum Web & réseau
    Réponses: 1
    Dernier message: 20/07/2005, 10h48
  5. Question sur les roles
    Par learn dans le forum Oracle
    Réponses: 3
    Dernier message: 25/01/2005, 17h38

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