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

ORM PHP Discussion :

[Doctrine] Template list (CRUD) : Afficher seulement les enregistrements du user connecté ?


Sujet :

ORM PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 80
    Points : 53
    Points
    53
    Par défaut [Doctrine] Template list (CRUD) : Afficher seulement les enregistrements du user connecté ?
    Bonjour à tous,


    J'ai un module CRUD sur Symfony 1.4 avec Doctrine "Fréquentation" sur lequel les utilisateurs saisissent les visites mensuelles dans leur structure.
    Mon problème est que, actuellement le template list de ce module affiche toutes les fréquentations tout utilisateur confondus.
    Ce que je voudrai faire c'est :
    - pour les administrateurs : toutes les fréquentations visibles dans la list
    - pour les non-admin : seulement les fréquentations de l'utilisateur connecté

    J'ai cherché dans les classes du module où modifier la requête, mais avec la notion de filtre qui se greffe là-dessus je sais pas trop comment résoudre mon problème.

    L'authentification est gérée avec sfDoctrineGuard.

    Quelqu'un aurait-il une idée svp ?


    Merci d'avance,

    cli16 *- *-

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

    Informations forums :
    Inscription : Mars 2005
    Messages : 546
    Points : 219
    Points
    219
    Par défaut
    Pas sur que tu puisse faire ça directement...
    J'ai écrit un truc dans le genre pour une déclaration de ticket d'intervention.
    Et dans mon action class, si le user n'a pas le credential de gestion (administrateur), je rajoute une clause where pour filtrer que ses propres déclaration...
    Jérôme

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 47
    Points : 35
    Points
    35
    Par défaut
    Si ça peut t'aider, tu peux filtrer tes requêtes dans ce style là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $q = Doctrine_Query::create()
        ->from('Fichier f')
        ->where('f.user_id = ?' , $this->getUser()->getGuardUser()->getId() );
        $this->fichiers = $q->execute();
    Et je sais que tu peux tester si l'utilisateur est admin ou pas, cherche dans la doc.

    Avec ça, tu devrait y arriver je pense.

  4. #4
    Expert éminent
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Points : 8 486
    Points
    8 486
    Par défaut
    Quant tu dis module CRUD, c'est un généré ou un module admin ?

    La meilleur chose est de créer une méthode dans l'objet de la table, qui va te retourner les données de l'utilisateur courant, sauf s'il est admin.

    Le DQL de vincent.le est "presque" bon, vu qu'il lui manque le test sur le fait d'être admin ou pas et qu'il utilise une méthode pour récupérer l'Id de l'utilisateur qui me fait dire qu'il est dans le contrôleur et pas dans le modèle...

    Après, dans le module admin, tu précises que tu utilise cette méthode pour récupérer les données.

    Si pas de module admin, idem, mais dans la route globale du module.

    Il peut aussi être intéressant de mettre une vérification sur l'ouverture de l'enregistrement, pour éviter quelqu'un qui essaye des numéros "au pif".

    Pour le module admin, même combat, il faut une méthode dans l'objet du modèle.

    Pour le module plus classique, on peut faire le teste une fois l'enregistrement récupéré, si l'id du user est pas bon, forward404...
    Si tu donnes un poisson à un homme, il mangera un jour. Si tu lui apprends à pêcher, il mangera toujours (Lao Tseu).

    • Pensez à valoriser les réponses pertinantes, cliquez sur le bouton vert +1 pour indiquer votre accord avec la solution proposée.
    • Pensez à utiliser la balise [code] pour afficher du code, elle est cachée sous le bouton [#] dans l'éditeur.
    • Une discussion est terminée ? Alors le bouton est votre ami !

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 80
    Points : 53
    Points
    53
    Par défaut
    Bonjour,

    Merci pour vos réponses.
    J'avais déjà essayé de mettre la requête comme vous me l'avez proposé mais ça ne fonctionnait pas.
    Je ne sais pas si le code si dessous est correct ?

    Dans actions.class.php :
    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
      protected function getPager()
      {
        $pager = $this->configuration->getPager('Frequentation');
     
        if (sfContext::getInstance()->getUser()->hasCredential('admin')) {
            $pager->setQuery($this->buildQuery());
        } else {
          $q = Doctrine_Query::create()
          ->from('Frequentation')
          ->where('user_id=?', sfContext::getInstance()->getUser()->getGuardUser()->getId())
          ->orderBy('periode');
          $pager->setQuery($q);
        }
     
        $pager->setPage($this->getPage());
        $pager->init();
     
        return $pager;
      }
    Quand je me connecte en admin c'est tout bon (normal car rien ne change...!) par contre avec un compte non admin j'obtiens une erreur sur les filtres : Notice: Undefined variable: filters.
    Je ne sais pas comment gérer ces filtres sans la fonction buildQuery et avec ma propre requête.

    Pour Michel : c'est bien un module généré par symfony.

    Merci pour vos éclaircissements !

    cli16 *-*-

  6. #6
    Expert éminent
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Points : 8 486
    Points
    8 486
    Par défaut
    Ceci ne répond pas à ma dernière question.

    Est-ce un module administration avec un generator.yml où un module CRUD que tu modifies par après ?
    Si tu donnes un poisson à un homme, il mangera un jour. Si tu lui apprends à pêcher, il mangera toujours (Lao Tseu).

    • Pensez à valoriser les réponses pertinantes, cliquez sur le bouton vert +1 pour indiquer votre accord avec la solution proposée.
    • Pensez à utiliser la balise [code] pour afficher du code, elle est cachée sous le bouton [#] dans l'éditeur.
    • Une discussion est terminée ? Alors le bouton est votre ami !

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 80
    Points : 53
    Points
    53
    Par défaut
    C'est un module d'administration avec generator.yml.

    Merci,


    cli16 *-*-

  8. #8
    Expert éminent
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Points : 8 486
    Points
    8 486
    Par défaut
    Il n'est pas nécessaire (ni souhaitable) de modifier le fichier action.class.php

    Tu va créé une méthode tel que je l'ai expliqué plus haut.

    Ensuite tu vas modifier ton fichier generator.yml pour lui dire que la méthode à utiliser pour récupérer les enregistrements est une nouvelle méthode.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    config:
      list:
        peer_method: MaMethodePourRecupererLesBonnesDonnees
    Et tu as le résultat voulu.

    Plus simple, non ?
    Si tu donnes un poisson à un homme, il mangera un jour. Si tu lui apprends à pêcher, il mangera toujours (Lao Tseu).

    • Pensez à valoriser les réponses pertinantes, cliquez sur le bouton vert +1 pour indiquer votre accord avec la solution proposée.
    • Pensez à utiliser la balise [code] pour afficher du code, elle est cachée sous le bouton [#] dans l'éditeur.
    • Une discussion est terminée ? Alors le bouton est votre ami !

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 80
    Points : 53
    Points
    53
    Par défaut
    Bonjour,

    Parfait, merci pour les explications.

    cli16 *-*-

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

Discussions similaires

  1. [SP-2010] Afficher tous les enregistrements d'une zone de liste déroulante
    Par fabaccess dans le forum SharePoint
    Réponses: 1
    Dernier message: 21/12/2011, 10h23
  2. Réponses: 7
    Dernier message: 24/04/2006, 15h48
  3. [JFileChooser] Afficher seulement les répertoires
    Par Cyborg289 dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 04/09/2005, 15h45
  4. Afficher tous les enregistrements d'une table
    Par bertrand_declerck dans le forum QuickReport
    Réponses: 2
    Dernier message: 08/07/2005, 08h35
  5. Réponses: 2
    Dernier message: 23/11/2003, 18h44

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