FACCESSAT
Section : Manuel du programmeur Linux (
2)
Mise à jour de la version anglaise : 28 février 2007
Index
Menu principal
NOM
faccessat - Vérifier les permissions d'un fichier relativement à un descripteur de fichier de répertoire
SYNOPSIS
#define _ATFILE_SOURCE
#include <fcntl.h> /* Définition des constantes AT_* */
#include <unistd.h>
int faccessat(int dirfd, const char *pathname, int mode, int flags);
DESCRIPTION
L'appel système
faccessat()
opère de la même manière que
access(2),
excepté les différences décrites dans cette page de manuel.
Si le nom de chemin fourni dans
pathname
est relatif, il est interprété relativement au répertoire référencé
par le descripteur de fichier
dirfd
(plutôt que relativement au répertoire de travail courant du processus
appelant, comme cela est fait par
access(2)
pour un chemin relatif).
Si le chemin fourni dans
pathname
est relatif et que
dirfd
est la valeur spéciale
AT_FDCWD,
pathname
est interprété relativement au répertoire de travail courant
du processus appelant (comme avec
access(2)).
Si le chemin fourni dans
pathname
est absolu,
dirfd
est ignoré.
flags
est construit en réalisant un OU logique entre zéro ou plusieurs des valeurs
suivantes :
- AT_EACCESS
-
Réaliser les vérifications d'accès en utilisant les UID et GID effectifs.
Par défaut,
faccessat()
utilise les ID réels (comme
access(2)).
- AT_SYMLINK_NOFOLLOW
-
Si
pathname
est un lien symbolique, ne pas le déréférencer :
à la place, renvoyer les informations sur le lien lui-même.
VALEUR RENVOYÉE
S'il réussit (toutes les permissions demandées sont accordées),
faccessat()
renvoie 0.
S'il échoue, il renvoie -1 et écrit
errno
en conséquence.
ERREURS
Les mêmes erreurs qui apparaissent pour
access(2)
peuvent apparaître pour
faccessat().
Les erreurs supplémentaires suivantes peuvent également se produire pour
faccessat() :
- EBADF
-
dirfd
n'est pas un descripteur de fichier valide.
- EINVAL
-
Un attribut invalide a été spécifié dans
flags.
- ENOTDIR
-
pathname
est un chemin relatif et
dirfd
est un descripteur de fichier se référant à un fichier
autre qu'un répertoire.
VERSIONS
faccessat()
a été ajouté au noyau Linux dans sa version 2.6.16.
CONFORMITÉ
Cet appel système n'est pas standard mais est proposé pour une inclusion
dans une prochaine révision de POSIX.1.
NOTES
Voir
openat(2)
pour des explications sur la nécessité de
faccessat().
Notes glibc
Les attributs
AT_EACCESS
et
AT_SYMLINK_NOFOLLOW
sont actuellement implémentés dans la fonction enveloppe de la glibc pour
faccessat().
Si aucun de ces attributs n'est spécifié, la fonction enveloppe utilise
fstatat(2)
pour déterminer les permissions d'accès.
VOIR AUSSI
access(2),
openat(2),
euidaccess(3),
credentials(7),
path_resolution(7),
symlink(7)
TRADUCTION
Ce document est une traduction réalisée par Alain Portal
<aportal AT univ-montp2 DOT fr> le 8 août 2006
et révisée le 2 juillet 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation
française de qualité. La version anglaise la plus à jour de ce document est
toujours consultable via la commande : « LANG=C man 2 faccessat ».
N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute
erreur dans cette page de manuel.
Index
- NOM
-
- SYNOPSIS
-
- DESCRIPTION
-
- VALEUR RENVOYÉE
-
- ERREURS
-
- VERSIONS
-
- CONFORMITÉ
-
- NOTES
-
- Notes glibc
-
- VOIR AUSSI
-
- TRADUCTION
-
Dernière mise à jour : 2 juillet 2008