getpw

Table des matières
Retour à l'index

 

NOM

getpw - Reconstruire un enregistrement de mot de passe  

BIBLIOTHÈQUE

Bibliothèque C standard (libc, -lc)  

SYNOPSIS

#define _GNU_SOURCE             /* Consultez feature_test_macros(7) */
#include <sys/types.h>
#include <pwd.h>

[[obsolète]] int getpw(uid_t uid, char *buf);
 

DESCRIPTION

La fonction getpw() reconstruit l'enregistrement de la ligne de mot de passe de l'utilisateur uid et le place dans le tampon buf. Ce tampon contient en retour une ligne au format suivant :

name:passwd:uid:gid:gecos:dir:shell

La structure passwd est définie dans <pwd.h> comme ceci :

struct passwd {
    char   *pw_name;       /* Nom d'utilisateur */
    char   *pw_passwd;     /* Mot de passe de l'utilisateur */
    uid_t   pw_uid;        /* ID de l'utilisateur */
    gid_t   pw_gid;        /* ID du groupe */
    char   *pw_gecos;      /* Information utilisateur */
    char   *pw_dir;        /* Répertoire personnel */
    char   *pw_shell;      /* Interpréteur de commande */ };

Pour plus d'informations à propos des champs de cette structure, consultez passwd(5).  

VALEUR RENVOYÉE

Si elle réussit, la fonction getpw() renvoie 0. En cas d'erreur, elle renvoie -1 et définit errno en conséquence.

Si l'uid n'est pas trouvé dans la base de données de mots de passe, getpw() renvoie -1, définit errno à 0 et laisse buf inchangé.  

ERREURS

0 ou ENOENT
Pas d'utilisateur correspondant à uid.
EINVAL
buf est NULL.
ENOMEM
Pas assez de mémoire pour allouer la structure passwd.
 

FICHIERS

/etc/passwd
Fichier de base de données des mots de passe
 

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes(7).
InterfaceAttributValeur
getpw() Sécurité des threadsMT-Safe locale
 

STANDARDS

Aucun.  

HISTORIQUE

SVr2.  

BOGUES

La fonction getpw() est dangereuse car elle peut provoquer un débordement du tampon buf. Elle est rendue obsolète par getpwuid(3).  

VOIR AUSSI

endpwent(3), fgetpwent(3), getpwent(3), getpwnam(3), getpwuid(3), putpwent(3), setpwent(3), passwd(5)

 

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org> et David Prévot <david@tilapin.org>

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à


 

Index

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
FICHIERS
ATTRIBUTS
STANDARDS
HISTORIQUE
BOGUES
VOIR AUSSI
TRADUCTION

This document was created by man2html, using the manual pages.
Time: 05:06:15 GMT, September 19, 2025