setfsuid

Autres langues

Langue: fr

Version: 27 mai 2004 (fedora - 25/11/07)

Section: 2 (Appels système)

NOM

setfsuid - Fixer l'UID pour les vérifications d'accès au système de fichiers.

SYNOPSIS

#include <unistd.h> /* glibc uses <sys/fsuid.h> */

int setfsuid(uid_t fsuid)

DESCRIPTION

setfsuid() fixe l'UID que le noyau Linux utilise pour vérifier tous les accès du processus au système de fichiers. Normalement, la valeur de fsuid va masquer la valeur de l'UID effectif. En fait, si l'UID effectif est modifié, fsuid sera aussi modifié pour la nouvelle valeur de l'UID effectif.

L'appel explicite de setfsuid() n'est normalement utile qu'aux programmes tels que le serveur NFS qui ont besoin de modifier l'UID utilisé pour les accès aux fichiers sans changer véritablement leurs UID réels et effectifs. Une modification de l'UID normal d'un programme comme un serveur NFS serait un trou de sécurité qui l'exposerait à des signaux indésirables en provenance d'autres processus du même utilisateur.

setfsuid() ne réussira que si l'appelant est le super-utilisateur ou si fsuid correspond à l'UID réel, à l'UID effectif, à l'UID sauvé, ou encore à la valeur actuelle de fsuid.

VALEUR RENVOYÉE

setfsuid() renvoie la valeur précédente fsuid s'il réussit. En cas d'erreur la valeur actuelle de fsuid est renvoyée.

CONFORMITÉ

setfsuid() est spécifique à Linux et ne doit pas être employé dans des programmes conçus pour être portables.

BOGUES

Il n'y a pas de messages d'erreur renvoyés. Il serait bon d'avoir au moins un code d'erreur EPERM en cas d'échec(dans le cas où l'appelant n'a pas la capacité CAP_SETGID).

NOTE

Lorsque la bibliothèque glibc s'aperçoit que l'argument n'est pas un UID valide, elle renvoie -1 et place EINVAL dans errno sans essayer d'appeler l'appel système réel.

Notez que lors de l'introduction de cet appel système, un processus pouvait envoyer un signal à un autre processus avec le même UID effectif. De nos jours, les permissions pour les signaux sont légèrement différentes.

VOIR AUSSI

kill(2), setfsgid(2), capabilities(7)

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 15 octobre 1996 et révisée le 7 décembre 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 setfsuid ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.