> Linux Reviews > man >

faccessat


  1. faccessat.2.man


1. faccessat.2.man

Manpage of FACCESSAT

FACCESSAT

Section: Руководство программиста Linux (2)
Updated: 2009-12-13
Index Return to Main Contents
 

ИМЯ

faccessat - проверяет пользовательские права на файл, определяемый относительно файлового дескриптора каталога  

ОБЗОР

#include <fcntl.h> /* определения констант AT_* */
#include <unistd.h>

int faccessat(int dirfd, const char *pathname, int mode, int flags);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

faccessat():

Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
До glibc 2.10:
_ATFILE_SOURCE
 

ОПИСАНИЕ

Системный вызов faccessat() работает также как системный вызов access(2), за исключением случаев, описанных в данной справочной странице.

Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в access(2)).

Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как access(2)).

Если в pathname задан абсолютный путь, то dirfd игнорируется.

Значение flags составляется из побитово сложенных следующих значений:

AT_EACCESS
Выполнять проверку, доступа используя эффективный идентификатор пользователя и группы. По умолчанию в faccessat() используются реальные идентификаторы (как в access(2)).
AT_SYMLINK_NOFOLLOW
Если значение pathname является символьной ссылкой, не разыменовывать её, а выдать информацию о самой ссылке.
 

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении (доступны все запрошенные права) faccessat() возвращает 0. При ошибке возвращается -1, а errno устанавливается в соответствующее значение.  

ОШИБКИ

В faccessat() могут возникнуть те же ошибки, что и в access(2). Дополнительно в faccessat() могут возникнуть следующие ошибки:
EBADF
dirfd не является правильным файловым дескриптором.
EINVAL
Указано неверное значение в flags.
ENOTDIR
Значение pathname содержит относительный путь и dirfd содержит файловый дескриптор, указывающий на файл, а не на каталог.
 

ВЕРСИИ

Вызов faccessat() был добавлен в ядро Linux 2.6.16.  

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2008.  

ЗАМЕЧАНИЯ

Смотрите в openat(2) объяснение нужности faccessat().  

Замечания по glibc

Флаги AT_EACCESS и AT_SYMLINK_NOFOLLOW на самом деле реализованы внутри обёрточной функции glibc faccessat(). Если задан какой-то из этих флагов, то обёрточная функция использует fstatat(2) для определения прав доступа.  

СМОТРИТЕ ТАКЖЕ

access(2), openat(2), euidaccess(3), credentials(7), path_resolution(7), symlink(7)


 

Index

ИМЯ
ОБЗОР
ОПИСАНИЕ
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
ОШИБКИ
ВЕРСИИ
СООТВЕТСТВИЕ СТАНДАРТАМ
ЗАМЕЧАНИЯ
Замечания по glibc
СМОТРИТЕ ТАКЖЕ

This document was created by man2html using the manual pages.
Time: 17:41:16 GMT, October 23, 2013

SVENSKA - SVENSKA - ja