Provided by: manpages-ru-dev_4.21.0-2_all
ИМЯ
euidaccess, eaccess - проверяет эффективные права пользователя на файл
LIBRARY
Standard C library (libc, -lc)
СИНТАКСИС
#define _GNU_SOURCE /* Смотрите feature_test_macros(7) */ #include <unistd.h> int euidaccess(const char *pathname, int mode); int eaccess(const char *pathname, int mode);
ОПИСАНИЕ
Подобно access(2), euidaccess() проверяет права и существование файла, указанного в аргументе pathname. Однако, если access(2) выполняет проверку для реального идентификатора пользователя и группы процесса, то euidaccess() использует эффективные идентификаторы. Значение mode представляет собой маску, состоящую из одного и более флагов R_OK, W_OK, X_OK и F_OK (значение описано в access(2)). Функция eaccess() — ещё одно название euidaccess(), предоставляется для совместимости с некоторыми другими системами.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
On success (all requested permissions granted), zero is returned. On error (at least one bit in mode asked for a permission that is denied, or some other error occurred), -1 is returned, and errno is set to indicate the error.
ОШИБКИ
Аналогичны access(2).
ВЕРСИИ
The eaccess() function was added in glibc 2.4.
АТРИБУТЫ
Описание терминов данного раздела смотрите в attributes(7). ┌───────────────────────────────────────────────────────┬──────────────────────┬──────────┐ │Интерфейс │ Атрибут │ Значение │ ├───────────────────────────────────────────────────────┼──────────────────────┼──────────┤ │euidaccess(), eaccess() │ Безвредность в нитях │ MT-Safe │ └───────────────────────────────────────────────────────┴──────────────────────┴──────────┘
СТАНДАРТЫ
Эти функции являются нестандартными. В некоторых системах есть функция eaccess().
ЗАМЕЧАНИЯ
Предупреждение: Использование этой функции для проверки прав процесса на файл перед выполнением какой-то операции на основе этой информации приводит к состоянию состязательности: права на файл могут измениться между двумя этими шагами. Обычно, безопасней просто попытаться выполнить желаемую операцию и что-то предпринять при возникновении ошибки с правами. Эта функция всегда разыменовывает символьные ссылки. Если вам нужно проверить права символьной ссылки, используйте вызов faccessat(2) с флагами AT_EACCESS и AT_SYMLINK_NOFOLLOW.
СМ. ТАКЖЕ
access(2), chmod(2), chown(2), faccessat(2), open(2), setgid(2), setuid(2), stat(2), credentials(7), path_resolution(7)
ПЕРЕВОД
Русский перевод этой страницы руководства был сделан Azamat Hackimov <azamat.hackimov@gmail.com>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com> Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩ или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ. Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на ⟨man-pages-ru-talks@lists.sourceforge.net⟩.