Linux |
CentOS 5.3 |
|
faccessat(2) |
faccessat − Modifier les permissions d’un fichier relativement à un descripteur de fichier de répertoire. |
#include <unistd.h> int faccessat(int dirfd, const char *path, int mode, int flags); |
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 path 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 path est relatif et que dirfd est la valeur spéciale AT_FDCWD, path est interprété relativement au répertoire de travail courant du processus appelant (comme avec access(2)). Si le chemin fourni dans path est absolu, dirfd est ignoré. flags est contruit 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 effectifs (comme access(2)). |
AT_SYMLINK_NOFOLLOW |
Si path est un lien symbolique, ne pas le déréférencer : à la place, renvoyer les informations du lien lui-même. |
S’il réussit, faccessat() renvoie 0. S’il échoue, il renvoie −1 et écrit errno en conséquence. |
Les mêmes erreurs qui apparaissent pour access(2) peuvent apparaître pour faccessat(). Les erreurs supplémentaires suivantes peuvent également apparaître pour faccessat() : |
EBADF |
dirfd n’est pas un descripteur de fichier valide. |
||
EINVAL |
Un attribut invalide a été spécifié dans flags. |
ENOTDIR |
path est un chemin relatif et dirfd est un descripteur de fichier se référant à un fichier autre qu’un répertoire. |
Voir openat(2) pour des explications sur la nécessité de faccessat(). |
Cet appel système n’est pas standard mais est proposé pour une inclusion dans une future révision de POSIX.1. |
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. |
faccessat() a été ajouté à Linux dans le noyau 2.6.16. |
access(2), openat(2), path_resolution(2) |
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 10 août 2006. 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. |
faccessat(2) |