2007-10-07 11:47:57 +00:00
. \" Title: shadow
. \" Author:
. \" Generator: DocBook XSL Stylesheets v1.70.1 <http://docbook.sf.net/>
. \" Date: 30/07/2006
. \" Manual: Appels de bibliothèque
. \" Source: Appels de bibliothèque
. \"
.TH "SHADOW" "3" "30/07/2006" "Appels de bibliothèque" "Appels de bibliothèque"
2007-10-07 11:47:11 +00:00
. \" disable hyphenation
.nh
. \" disable justification (adjust text to left margin only)
.ad l
2007-10-07 11:47:57 +00:00
.SH "NOM"
2007-10-07 11:47:11 +00:00
shadow, getspnam \- routines d'utilisation des mots de passe cachés
.SH "SYNTAX"
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI #include <shadow.h>\fR
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI struct spwd *getspent();\fR
.PP
2007-10-07 11:47:57 +00:00
\fI struct spwd *getspnam(char\fR
\fI *nom\fR \fI );\fR
2007-10-07 11:47:11 +00:00
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI void setspent();\fR
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI void endspent();\fR
.PP
2007-10-07 11:47:57 +00:00
\fI struct spwd *fgetspent(FILE\fR
\fI *fp\fR \fI );\fR
2007-10-07 11:47:11 +00:00
.PP
2007-10-07 11:47:57 +00:00
\fI struct spwd *sgetspent(char\fR
\fI *cp\fR \fI );\fR
2007-10-07 11:47:11 +00:00
.PP
2007-10-07 11:47:57 +00:00
\fI int putspent(struct spwd\fR
\fI *p,\fR
\fI FICHIER\fR
\fI *fp\fR \fI );\fR
2007-10-07 11:47:11 +00:00
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI int lckpwdf();\fR
.PP
2007-10-07 11:47:57 +00:00
2007-10-07 11:47:11 +00:00
\fI int ulckpwdf();\fR
.SH "DESCRIPTION"
.PP
\fI shadow\fR
manipule le contenu du fichier des mots de passe cachés,
2007-10-07 11:47:57 +00:00
\fI /etc/shadow\fR . La structure définie dans le fichier inclus est\ :
2007-10-07 11:47:11 +00:00
.sp
2007-10-07 11:47:57 +00:00
.RS 3 n
2007-10-07 11:47:11 +00:00
.nf
struct spwd {
char *sp_namp; /* nom de connexion de l'utilisateur */
char *sp_pwdp; /* mot de passe chiffré */
long int sp_lstchg; /* dernier changement de mot de passe */
long int sp_min; /* jours avant de pouvoir changer de mot de passe */
long int sp_max; /* jours avant l'obligation de changer de mot de passe */
long int sp_warn; /* jours d'avertissement avant la fin de validité */
long int sp_inact; /* jours avant que le compte soit inactif */
long int sp_expire; /* date de fin de validité du compte */
unsigned long int sp_flag; /* réservé pour une utilisation future */
}
.fi
2007-10-07 11:47:57 +00:00
.RE
2007-10-07 11:47:11 +00:00
.PP
La signification de chaque champ est la suivante\ :
2007-10-07 11:47:57 +00:00
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_namp \- pointeur vers le nom d'utilisateur terminé par un zéro binaire (\(Fo \ null\- terminated\ \(Fc )
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_pwdp \- pointeur vers le mot de passe terminé par un zéro binaire ( \(Fo \ null\- terminated\ \(Fc )
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_lstchg \- nombre de jours, comptés à partir du 1er janvier 1970, depuis la dernière modification du mot de passe
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
sp_min \- nombre de jours pendant lesquels le mot de passe ne peut pas être changé
2007-10-07 11:47:57 +00:00
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_max \- nombre maximal de jours avant que le mot de passe doive être changé
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
sp_warn \- nombre de jours avant que le mot de passe n'arrive en fin de validité pendant lesquels l'utilisateur est averti de la fin prochaine de la validité de son mot de passe
2007-10-07 11:47:57 +00:00
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_inact \- nombre de jours après la fin de validité du mot de passe avant de considérer que le compte est inactif et soit désactivé
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
2007-10-07 11:47:57 +00:00
sp_expire \- nombre de jours, comptés à partir du 1er janvier 1970, après lesquels le compte sera désactivé
.TP 3 n
2007-10-07 11:47:11 +00:00
\(bu
sp_flag \- réservé pour une utilisation future
.SH "DESCRIPTION"
.PP
\fI Getspent\fR ,
\fI getspname\fR ,
\fI fgetspent\fR , et
\fI sgetspent\fR
renvoient tous un pointeur vers une structure
\fI struct spwd\fR .
\fI Getspent\fR
renvoie l'entrée suivante du fichier, et
\fI fgetspent\fR
2007-10-07 11:47:57 +00:00
renvoie l'entrée suivante du flux qui est considéré comme étant un fichier au format correct.
2007-10-07 11:47:11 +00:00
\fI Sgetspent\fR
renvoie un pointeur vers une structure
\fI struct spwd\fR
en utilisant la chaîne de caractère fournie en entrée.
\fI Getspnam\fR
cherche à partir de la position courante une entrée correspondant à
\fI nom\fR
dans le fichier fourni en entrée.
.PP
\fI Setspent\fR
et
\fI endspent\fR
peuvent être utilisés pour débuter et terminer l'accès au fichier de mots de passe cachés.
.PP
Les fonctions
\fI lckpwdf\fR
et
\fI ulckpwdf\fR
2007-10-07 11:47:57 +00:00
doivent être utilisées pour garantir un accès exclusif au fichier
2007-10-07 11:47:11 +00:00
\fI /etc/shadow\fR .
\fI Lckpwdf\fR
essaie de placer un verrou avec
\fI pw_lock\fR
pendant 15 secondes. Il essaie ensuite de placer un second verrou en utilisant
\fI spw_lock\fR
pendant le reste de ces 15 secondes. Si un de ces verrous ne peut être placé,
\fI lckpwdf\fR
renvoie \- 1. Quand les deux verrous peuvent être placés, la valeur 0 est renvoyée.
.SH "DIAGNOSTICS"
.PP
2007-10-07 11:47:57 +00:00
Les fonctions renvoient NULL si plus aucune entrée n'est disponible ou si une erreur est survenue lors du traitement. Les fonctions dont la valeur de retour est un
2007-10-07 11:47:11 +00:00
\fI int\fR
renvoient 0 en cas de succès et \- 1 en cas d'échec.
.SH "AVERTISSEMENTS"
.PP
2007-10-07 11:47:57 +00:00
Ces fonctions peuvent n'être disponibles que pour le superutilisateur car l'accès au fichier de mots de passe cachés est restreint.
2007-10-07 11:47:11 +00:00
.SH "FICHIERS"
2007-10-07 11:47:57 +00:00
.TP 3 n
2007-10-07 11:47:11 +00:00
\fI /etc/shadow\fR
2007-10-07 11:47:57 +00:00
Informations sécurisées sur les comptes utilisateurs.
2007-10-07 11:47:11 +00:00
.SH "VOIR AUSSI"
.PP
\fB getpwent\fR (3),
\fB shadow\fR (5).