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

Firebird Discussion :

[FB 1.5] faire un grant dans une procedure


Sujet :

Firebird

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Moine
    Inscrit en
    Mars 2006
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 210
    Par défaut [FB 1.5] faire un grant dans une procedure
    Salut!

    J'ai fait une procédure pour donner les droits à un nouveau utilisateur qu'on vient de creer. J'utilise cette procédure chaque fois que l'on crée un utilisateur. Elle prend en paramètre le nom de l'utilisateur.

    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
     
    CREATE PROCEDURE privilege(name varchar(40))
    AS
    ECLARE VARIABLE nomTable VARCHAR(40);
    DECLARE VARIABLE nomProc  VARCHAR(40);                          
    BEGIN
         FOR 
             SELECT RDB$RELATION_NAME
             FROM   RDB$RELATIONS
             WHERE  RDB$SYSTEM_FLAG = 0
             INTO  :nomTable
         DO
           IF(nomTable <>'USER')THEN
              EXECUTE STATEMENT 'GRANT ALL ON '||:nomTable||' TO '||:name;
     
     
         FOR 
           SELECT RDB$PROCEDURE_NAME
           FROM   RDB$PROCEDURES
           INTO  :nomProc
         DO
           EXECUTE STATEMENT 'GRANT EXECUTE ON PROCEDURE '||:nomProc||'      TO '||:name;  
     
          EXECUTE STATEMENT 'GRANT ALL ON "USER" '|| 'TO ' ||:mat;  
     
    END
    Quand je tente de l'executer j'obtiens ce message d'erreur:
    unsuccessful metadata update STORE RDB$USER_PRIVILEGES failed in grant action cancel by trigger(0) preserve data integrity could not find table/procedure for grant
    si j'enlève cette partie tout marche bien:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    FOR 
           SELECT RDB$PROCEDURE_NAME
           FROM   RDB$PROCEDURES
           INTO  :nomProc
    DO
          EXECUTE STATEMENT 'GRANT EXECUTE ON PROCEDURE '||:nomProc||'      TO '||:name;
    Si quelque peut me dire où se situe le problème. Merci d'avance!!

  2. #2
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Salut

    A part cette dernière ligne, je ne vois pas d'erreur.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    EXECUTE STATEMENT 'GRANT ALL ON "USER" '|| 'TO ' ||:mat;
    D'où sort mat ? Il n'est pas défini dans ta PS.

    Ensuite nommer une table USER, personnellement j'évite.
    Et enfin dans cette PS tu accordes également les droits sur cette même PS. Est-ce vraiment voulu ?

    @+ Claudius.

  3. #3
    Membre confirmé Avatar de Moine
    Inscrit en
    Mars 2006
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 210
    Par défaut
    Citation Envoyé par Cl@udius Voir le message
    Salut
    A part cette dernière ligne, je ne vois pas d'erreur.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    EXECUTE STATEMENT 'GRANT ALL ON "USER" '|| 'TO ' ||:mat;
    D'où sort mat ? Il n'est pas défini dans ta PS.
    Je me suis trompé, c'est name que je voulais ecrire. J'ai corriger mais ça ne change rien.

    Ensuite nommer une table USER, personnellement j'évite.
    J'ignorais que USER etait une table système.

    Et enfin dans cette PS tu accordes également les droits sur cette même PS. Est-ce vraiment voulu ?
    Oui, c'est voulu.

    @+ Claudius.[/QUOTE]

    c'est plûtot cette ligne qui semble causé le problème:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    EXECUTE STATEMENT 'GRANT EXECUTE ON PROCEDURE '||:nomProc||'      TO '||:name;
    Dès que je l'enlève tout marche bien. Si quelqu'un peut me dire ce qu'il ne va pas où s'il y a une autre manière de faire la même chose cad donner le droit d'execution au nouveau utilisateur sur toutes les procedures. Merci!!

  4. #4
    Membre Expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Par défaut
    bizarre, c'est pourtant bien la bonne manière de faire
    sauf que tes variables peuvent être limitées à des VARCHAR(31)

    tu peux donner le résultat de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT RDB$PROCEDURE_NAME  FROM  RDB$PROCEDURES

  5. #5
    Membre confirmé Avatar de Moine
    Inscrit en
    Mars 2006
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 210
    Par défaut [FB 1.5] faire un grant dans une procedure
    ça y est! tout marche bien maintenant. Mais je n'est absolument rien changé à part qu'on a redémarré la machine. Ce ne pas la première fois que FB me joue ces genres de tour.

    Je voudrais savoir si FB est vraiment fiable ou si c'est mon outil qui déconne. J'utilise IBAccess. L'application est destinée à un environnement de production donc je ne voudrais pas prendre de risque inutile. Dites mois ce que vous en savez.

    Merci Makowski!

  6. #6
    Membre Expert

    Homme Profil pro
    Consultant spécialité Firebird
    Inscrit en
    Mai 2002
    Messages
    2 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Consultant spécialité Firebird
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 342
    Par défaut
    ibaccess n'est pas fait pour Firebird

  7. #7
    Membre confirmé Avatar de Moine
    Inscrit en
    Mars 2006
    Messages
    210
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 210
    Par défaut [FB 1.5] faire un grant dans une procedure
    Merci à vous tous pour tout.

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

Discussions similaires

  1. Faire un DROP dans une procedure PL/SQL
    Par Bebert71 dans le forum PL/SQL
    Réponses: 4
    Dernier message: 19/05/2008, 12h04
  2. [HTML] faire des tabulation dans une liste <select>
    Par renofx1 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 20/01/2006, 23h36
  3. [Xquery] faire un insert dans une base
    Par Batou dans le forum XQUERY/SGBD
    Réponses: 1
    Dernier message: 13/12/2005, 01h07
  4. Faire un test dans une procédure
    Par PrinceMaster77 dans le forum SQL
    Réponses: 1
    Dernier message: 23/11/2004, 09h55
  5. faire un selection dans une image aves les APIs
    Par merahyazid dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/04/2002, 10h44

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