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

C++ Discussion :

perdu dans les ACL


Sujet :

C++

  1. #1
    Membre averti
    Inscrit en
    Août 2007
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 29
    Par défaut perdu dans les ACL
    Bonjour à tous !

    Voila, je viens du monde Linux et je suis un peu perdu dans les ACL, ACE, SID...

    J'ai un petit souci :
    J'ai un programme qui créé un fichier. Les droits effectifs de ce programme étant ceux d'Utilisateurs, mon fichier créé a pour proprietaire l'utilisateur courant.

    J'aimerais juste changer cela en disant que le propriétaire du fichier créé est administeur, et que l'utilisateur a juste le droit d'écrie dans le fichier (enfin, n'a pas le droit de lire, ni d'executer le fichier)

    en gros sous linux ca donnerait :

    chmod 662 monfichier
    chown root:root monfichier

    #>ls -l monfichier
    rw-rw--w- root:root monfichier

    Et enfin, comment connaitre le nom du propriétaire du fichier ?

    Merci de votre aide!

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Rien à voir avec le C++, c'est de la prog Windows.

    Connaitre le propriétaire: GetFileSecurity() + GetSecurityDescriptorOwner().
    Changer le propriétaire: SetSecurityDescriptorOwner(), mais il faut un privilège pour ça:
    • Si tu es admin et que tu veux que le fichier devienne "à toi", tu dois utiliser le privilège Take Ownership (SE_TAKE_OWNERSHIP_NAME) (les admin ont ce privilège, mais il faut l'activer).
    • Si le fichier t'appartient et que tu veux le "donner" à quelqu'un, tu dois utiliser le privilège Restore (SE_RESTORE_NAME) (les utilisateurs normaux n'ont pas ce privilège, les admins si).
      • Si j'ai bien compris, l'interdiction de "donner" un fichier est utile dès qu'il est question de quotas: Il ne faut pas que quelqu'un puisse "donner" un fichier à un autre à son insu...

    Tu peux activer ou désactiver un privilège avec AdjustTokenPrivileges().

    Quant aux ACLs, c'est un peu plus compliqué. Il y a des fonctions du genre SetEntriesInAcl(), SetSecurityDescriptorDacl(), etc. En fait, en ce qui concerne les ACLs, tu aura plus vite fait d'utiliser les outils présents (notamment l'outil en ligne de commande cacls.exe, qui a l'avantage d'être disponible même sous XP familial).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Perdu dans les numéros de versions de l'Application Server
    Par Christophe P. dans le forum Oracle
    Réponses: 4
    Dernier message: 28/06/2007, 15h33
  2. Perdu dans les joins
    Par kabkab dans le forum Requêtes
    Réponses: 1
    Dernier message: 15/03/2007, 23h16
  3. perdu dans les fonctions en c++ builder
    Par davidc dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/02/2007, 16h22
  4. [Débutant] Perdu dans les streams
    Par Le Furet dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 04/01/2007, 10h58
  5. Perdue dans les Response.Write...
    Par Tapioca dans le forum ASP
    Réponses: 4
    Dernier message: 11/07/2004, 11h54

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