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

Python Discussion :

écrire dans un fichier dont on a pas les droits


Sujet :

Python

  1. #1
    Membre averti Avatar de awalter1
    Inscrit en
    Août 2004
    Messages
    994
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 994
    Points : 407
    Points
    407
    Par défaut écrire dans un fichier dont on a pas les droits
    Bonjour,
    Dans mon application python, certains utilisateurs doivent pouvoir modifier un fichier dont ils ne sont pas propriétaires. L'appli va demander alors le mot de passe du compte en question. Mais ensuite ... !
    Existe t'il une procédure python (j'en doute mais ...) qui permette d'ouvrir en mode write un tel fichier. Je peux le faire par des commandes via os.system(), mais on est plus dans python et ça ne me semble pas top.
    merci

    PS : je suis sous linux RHEL5 et python 2.7

  2. #2
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    180
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2011
    Messages : 180
    Points : 321
    Points
    321
    Par défaut
    Bonjour,

    Si j'étais à votre place, j'installerais la gestion des ACL sur le système de façon
    à définir qui peu écrire dans tel ou tel répertoire et ou fichier dont ils ne sont
    propriétaire.

    De la sorte, votre application resterait indépendante de l'os.

  3. #3
    Membre averti Avatar de awalter1
    Inscrit en
    Août 2004
    Messages
    994
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 994
    Points : 407
    Points
    407
    Par défaut
    Problème : il ne s'agit pas de mes machines, l'installation de tout soft doit être réglementée et justifiée, donc je ne préfères pas m'engager dans cette voie.

  4. #4
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 462
    Points : 9 249
    Points
    9 249
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Sincèrement, présenté comme ça, j'espère bien que ce n'est pas possible, y compris avec os.system(): ça ferait un méchant trou de sécurité!

    La seule possibilité que je vois, en deça de la solution ACL qui est effectivement très bonne, est d'inscrire les personnes en question comme membre du groupe utilisateur pour les droits relatifs au fichier, et de donner au groupe le droit d'écriture (“rw-rw-r--” au lieu de “rw-r--r--”).

    Une question: ce fichier doit-il rester en place après modification, ou le problème est-il de permettre une version personnalisée située après dans le home des utilisateurs?

    Si c'est le 2e cas, les utilisateurs peuvent toujours recopier ce fichier dans leur home, et la copie leur appartiendra: ils en feront alors ce qu'ils en veulent. Pour faire cette copie, il suffit d'avoir le droit de lecture sur le fichier, et de le placer dans un répertoire sur lequel on a le droit d'écriture.
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  5. #5
    Membre averti Avatar de awalter1
    Inscrit en
    Août 2004
    Messages
    994
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 994
    Points : 407
    Points
    407
    Par défaut
    AU niveau sécurité, je demandais le mot de passe du compte incriminé donc ça me paraissait correct, mais finalement oui, ils suffit que les utilisateurs appartiennent au même groupe pour que mon pb soit résolu.
    Merci de votre participation

  6. #6
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Salut,

    Si vous oubliez Python 2mns, comment feriez vous?

    Pour accéder aux fichiers de l'utilisateur userX à partir du process de l'utilisateur A, il faudrait que:
    - le "process" change de "personne" ou
    - pouvoir créer un process sur le compte de userX
    - donner à A des privilèges "temporaires" lui permettant de...
    - placer les utilisateurs dans un même groupe ou leur assigner des ACLs,...

    Sur Linux, on peut passer via /bin/su.
    Cela va permettre de lancer le script sous le compte d'userX ou de lancer un script qui permettra d'avoir un "proxy" via:
    - les pipes du process vers le fichier demandé avec les bons droits.
    - un dialogue plus élaboré de type RPC,

    Dans tous les cas que ce soit pour lancer toute l'application ou simplement le s/ensemble qui permettra d'accéder au fichier, il n'y a rien de très spécifique à Python: c'est à voir avec l'administrateur système.
    Il a son mot à dire sur comment gérer cela sur ses environnements (et des solutions/bonnes pratiques pour les différents cas qu'il a déjà du traiter).

    Le spécifique Python pourrait être sera le subprocess.Popen qui lancera le process qui accèdera au fichier à la place de.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par awalter1 Voir le message
    AU niveau sécurité, je demandais le mot de passe du compte incriminé donc ça me paraissait correct, mais finalement oui, ils suffit que les utilisateurs appartiennent au même groupe pour que mon pb soit résolu.
    Merci de votre participation
    Salut
    Accessoirement il n'est même pas besoin de modifier le groupe principal des utilisateurs incriminés (ce qui pourrait poser problème ailleurs).
    Suffit de mettre les utilisateurs comme invités du groupe auquel le fichier appartient (suffit de rajouter leurs noms, séparés par une virgule, dans le 4° champ du fichier /etc/group).
    Dès lors les utilisateurs seront aussi membre de ce groupe là et tout accès au fichier par un de ces utilisateurs sera géré au niveau des droits g par l'os (sans impacter d'autre éléments de l'architecture)...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

Discussions similaires

  1. mv d'un fichier dont on a pas les droits
    Par bstevy dans le forum Shell et commandes GNU
    Réponses: 3
    Dernier message: 11/04/2015, 11h42
  2. CGI ne peut pas lire ni écrire dans un fichier
    Par leprofessionnel dans le forum Administration système
    Réponses: 2
    Dernier message: 23/02/2011, 14h19
  3. Réponses: 7
    Dernier message: 22/06/2010, 15h15
  4. Ouvrir et écrire dans un fichier .txt en T-SQL
    Par joul's dans le forum MS SQL Server
    Réponses: 11
    Dernier message: 27/10/2008, 21h04
  5. [JAR] Comment écrire dans un fichier properties dans un jar
    Par Alec6 dans le forum Entrée/Sortie
    Réponses: 3
    Dernier message: 05/10/2004, 15h16

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