table of contents
FACCESSAT(2) | Руководство программиста Linux | FACCESSAT(2) |
ИМЯ¶
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() могут возникнуть следующие ошибки:
ВЕРСИИ¶
Вызов faccessat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.
СООТВЕТСТВИЕ СТАНДАРТАМ¶
POSIX.1-2008.
ЗАМЕЧАНИЯ¶
Смотрите в openat(2) объяснение необходимости faccessat().
Предупреждение: в faccessat() подвержен тем же самым вида состязательности как access(2) и euidaccess(3).
Замечания по glibc¶
Флаги AT_EACCESS и AT_SYMLINK_NOFOLLOW на самом деле реализованы внутри обёрточной функции glibc faccessat(). Если задан какой-то из этих флагов, то обёрточная функция использует fstatat(2) для определения прав доступа.
СМОТРИТЕ ТАКЖЕ¶
access(2), openat(2), euidaccess(3), credentials(7), path_resolution(7), symlink(7)
2012-05-04 | Linux |