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

Langage Delphi Discussion :

Stockage de fichiers de configuration dans ProgramData, problèmes de droits


Sujet :

Langage Delphi

  1. #1
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 091
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 091
    Points : 41 064
    Points
    41 064
    Billets dans le blog
    62
    Par défaut Stockage de fichiers de configuration dans ProgramData, problèmes de droits
    Bonjour,

    Je stocke mes fichiers de configuration de programme dans ProgramData\<nom programme>\maconfig.ini (.ini pour faire simple)
    Quand le répertoire n'est pas créé je crée celui-ci par ForceDirectories
    Jusque-là pas de soucis.

    C'est ensuite que cela se corse :
    Sur mon poste, pas de soucis, si je modifie le fichier de config aucune erreur de levée
    Sur certains postes utilisateurs (pas tous ce serait trop facile) impossible de ré-écrire le fichier sans exécuter le programme en mode administrateur

    Si j'en crois cette réponse
    C: \\ ProgramData, alias FOLDERID_ProgramData, a des paramètres de sécurité restreints. Les utilisateurs standard peuvent y créer des fichiers. Mais ces fichiers sont, par défaut, sécurisés de sorte que seul l'utilisateur qui a créé le fichier peut ultérieurement le modifier.

    La solution recommandée consiste pour votre programme d'installation à créer un sous-répertoire de C: \\ ProgramData pour votre stockage partagé. Et ce sous-répertoire doit recevoir une ACL permissive par le programme d'installation. C'est ce qui accorde l'accès souhaité à tous les utilisateurs standard.
    La question est donc : comment, je cite, "donner une ACL (Access Control List) permissive" ?
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 091
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 091
    Points : 41 064
    Points
    41 064
    Billets dans le blog
    62
    Par défaut
    Évidemment je pose une question et en cherchant mieux je trouve ce post de Guillemouze

    ce code pourrait donc me permettre de contrer le problème
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    if not FileExists(ininame)  then
     begin
       ForceDirectories(ininame);
       {$IFDEF MSWINDOWS}
       // droit d'accès
           ACLParams := '"'+iniName+'" /grant *S-1-5-32-545:(OI)(CI)F';
           ShellExecute(0, 'open', PChar(ACLPath), PChar(ACLParams), nil, SW_HIDE);
       {$ENDIF}
     end;
    Votre avis ?
    Qu'en serait-il pour un Mac ?

    cela ne va pas être facile à tester surtout à distance !
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  3. #3
    Membre actif Avatar de oneDev
    Homme Profil pro
    dilettant
    Inscrit en
    Mars 2019
    Messages
    213
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : dilettant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2019
    Messages : 213
    Points : 222
    Points
    222
    Par défaut
    Il serait peut être plus simple de placer le fichier de config dans un sous-dossier de l'utilisateur, style %appdata%.

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 091
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 091
    Points : 41 064
    Points
    41 064
    Billets dans le blog
    62
    Par défaut
    Plusieurs utilisateurs sur le même poste mais même config donc GetHomePath n'est pas possible, contrairement aux fichiers de préférences (taille de fenêtre, position, styles) par utilisateur.

    Programdata à l'avantage d'être bien protégé, le hic est dû à ForceDirectories
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  5. #5
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 522
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 522
    Points : 25 052
    Points
    25 052
    Par défaut
    Avec l'UAC qui mettait les fichiers ini en quarantaine en Vista dans son VirtualStore, les fichiers ini ont été abandonné, reste juste des fichiers cfg pour les paramètres systèmes minimum, le format DFM tout simplement et tout le reste dans une table T_REMOTED_INI[VALUES] permettant de gérer des sections communes, des sections par utilisateur (local ou session CITRIX), des sections par machine (local ou client distant sur le CITRIX)

    Cela a grandement simplifié la gestion, même le déploiement ...


    Sinon, lors du lancement du programme, si le dossier est manquant, as-tu pensé à une élévation de privilège via l'UAC
    Oui, cela va solliciter l'utilisateur mais cela fonctionne normalement

    Voir aussi à lancer via un ShellExecute un mini programme qui ferait les taches nécessitant une élévation avec un manifest au maximum, ce qui évite de "contaminer" ton projet principal.


    D'ailleurs, je ne comprends pas "ProgramData\<nom programme>\" ... n'est-ce pas au Setup de créer ce dossier lors de l'installation de ton programme et la création du fichier de configuration commune, une seule fois pour toute ?
    Ou alors, ton programme est un setup maison ?
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  6. #6
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 091
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 091
    Points : 41 064
    Points
    41 064
    Billets dans le blog
    62
    Par défaut
    @Shailetroll J'ai écrit ini pour faire simple, en réalité c'est plus un XML mais j'aurais pu le nommer cfg ou autre.

    Sinon, lors du lancement du programme, si le dossier est manquant, as-tu pensé à une élévation de privilège via l'UAC
    Oui, le premier lancement (installation) du programme doit se faire en mode administrateur mais justement c'est là ou le bât blesse du coup

    Citation Envoyé par Problème
    Les utilisateurs standard peuvent y créer des fichiers. Mais ces fichiers sont, par défaut, sécurisés de sorte que seul l'utilisateur qui a créé le fichier peut ultérieurement le modifier.
    Et c'est ce que fait forcedirectories qui reprend des droits hérités de ProgramData

    Ou alors, ton programme est un setup maison ?
    Il n'y a pas de Setup donc oui c'est une sorte de Setup maison. C'est le programme qui, a la première utilisation, crée les infos nécessaires de configuration pour tous (en gros les infos de connexion aux bases de données, au serveur ftp, smtp et autres trucs du même genre, infos en partie chiffrées qui plus est). Toutefois j'ai laissé le droit à l'utilisateur de modifier certains de ces paramètres après installation "normale". Sur les 5 postes tests deux m'ont posé soucis : les deux "partagés" entre utilisateurs, pour un sixième c'est pire mais dû à une installation de windows totalement aberrante Je n'ai pratiquement jamais la main sur les postes au moment de leur installations et je ne parle même pas des chaises (PC) musicales au sein de l'entreprise

    Lorsque le programme se termine (et c'est là ou ça plante) les dernières informations sont ré-écrites, plusieurs programmes peuvent utiliser tout ou partie de ce même fichier de configuration.
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

Discussions similaires

  1. Charger un fichier de configuration dans un WebService
    Par wizaord dans le forum Services Web
    Réponses: 5
    Dernier message: 21/12/2011, 10h37
  2. Réponses: 7
    Dernier message: 14/04/2010, 14h45
  3. Réponses: 0
    Dernier message: 14/04/2010, 11h35
  4. Réponses: 0
    Dernier message: 02/02/2009, 13h03
  5. Réponses: 5
    Dernier message: 25/03/2008, 10h58

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