Provided by: manpages-ru-dev_4.27.0-1_all 

НАИМЕНОВАНИЕ
chmod, fchmod, fchmodat - изменяет права доступа к файлу
БИБЛИОТЕКА
Стандартная библиотека языка C (libc, -lc)
ОБЗОР
#include <sys/stat.h> int chmod(const char *pathname, mode_t mode); int fchmod(int fd, mode_t mode); #include <fcntl.h> /* определения констант AT_* */ #include <sys/stat.h> int fchmodat(int dirfd, const char *pathname, mode_t mode, int flags); Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)): fchmod(): Начиная с glibc 2.24: _POSIX_C_SOURCE >= 199309L glibc 2.19 до glibc 2.23 _POSIX_C_SOURCE glibc 2.16 до glibc 2.19: _BSD_SOURCE || _POSIX_C_SOURCE glibc 2.12 до glibc 2.16: _BSD_SOURCE || _XOPEN_SOURCE >= 500 || _POSIX_C_SOURCE >= 200809L glibc 2.11 и ранее: _BSD_SOURCE || _XOPEN_SOURCE >= 500 fchmodat(): Начиная с glibc 2.10: _POSIX_C_SOURCE >= 200809L До glibc 2.10: _ATFILE_SOURCE
ОПИСАНИЕ
Системные вызовы chmod() и fchmod() изменяют биты режима файла (режим файла состоит из бит прав доступа к файлу плюс биты set-user-ID, set-group-ID и бит закрепления) Данные системные вызовы отличаются только способом указания файла: • Вызов chmod() изменяет режим файла, задаваемого путём из параметра pathname, который разыменовывается, если является символьной ссылкой. • Вызов fchown() изменяет режим файла, задаваемого открытым файловым дескриптором fd. Новый режим файла указывается в mode и представляет собой битовую маску, создаваемую побитовым сложением нуля или более следующих констант: S_ISUID (04000) set-user-ID (установить эффективный идентификатор пользователя процесса при execve(2)) S_ISGID (02000) set-group-ID (установить эффективный идентификатор группы процесса при execve(2); обязательная блокировка, описывается в fcntl(2); выбрать новую группу файла от родительского каталога, описывается в chown(2) и mkdir(2)) S_ISVTX (01000) закрепляющий бит (ограничительный флаг удаления, описывается в unlink(2)) S_IRUSR (00400) владелец может читать S_IWUSR (00200) владелец может писать S_IXUSR (00100) владелец может выполнять файл или искать в каталоге ("поиск" применим к каталогам и означает, что к элементам внутри каталога есть доступ) S_IRGRP (00040) группа-владелец может читать S_IWGRP (00020) группа-владелец может писать S_IXGRP (00010) группа-владелец может выполнять файл или искать в каталоге S_IROTH (00004) все остальные могут читать S_IWOTH (00002) все остальные могут писать S_IXOTH (00001) все остальные могут выполнять файл или искать в каталоге Эффективный идентификатор пользователя (UID) вызывающего процесса должен совпадать с UID владельца файла или процесс должен быть привилегированным (Linux: у него должен быть мандат CAP_FOWNER). Если вызывающий процесс не является привилегированным (Linux: не имеет мандата CAP_FSETID), а группа-владелец файла не совпадает с эффективным групповым ID процесса или одним из его дополнительных групповых идентификаторов, то бит S_ISGID будет сброшен, но ошибки при этом не возникнет. В зависимости от файловой системы в целях безопасности биты выполнения set-user-ID и set-group-ID могут сбрасываться при записи в файл (в Linux это происходит, если записывающий процесс не имеет мандата CAP_FSETID). В некоторых файловых системах только суперпользователь может устанавливать закрепляющий бит, который может иметь специальное назначение. Значения закрепляющего бита, set-user-ID и set-group-ID для каталогов смотрите в inode(7). В файловых системах NFS ограничивающие права сразу начинают действовать даже уже на открытые файлы, так как контроль доступа выполняется сервером, но открытые файлы находятся в ведении клиента. Распространение прав может откладываться для других клиентов, если у них установлен атрибут кэширования. fchmodat() Системный вызов fchmodat() работает также как системный вызов chmod(), за исключением случаев, описанных здесь. Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в chmod()). Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как chmod()). Если в pathname задан абсолютный путь, то dirfd игнорируется. Значение flags может быть 0, или включать следующие флаги: AT_SYMLINK_NOFOLLOW Если значение pathname является символьной ссылкой, не разыменовывать её, а изменить права на самой ссылке. Этот флаг пока не реализован. Смотрите в openat(2) объяснение необходимости fchmodat().
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении возвращается 0. При ошибке возвращается -1, а в errno содержится код ошибки.
ОШИБКИ
В зависимости от файловой системы могут также возвращаться другие ошибки, перечисленные далее. Наиболее распространённые ошибки chmod() перечислены далее: EACCES Поиск запрещён из-за одного из частей префикса пути (См. также path_resolution(7).) EBADF (fchmod()) Файловый дескриптор fd не действителен. EBADF (fchmodat()) pathname является относительным, но dirfd не является ни AT_FDCWD, ни допустимым файловым дескриптором. EFAULT Аргумент pathname указывает за пределы доступного адресного пространства. EINVAL (fchmodat()) Указано неверное значение в flags. EIO Произошла ошибка ввода-вывода. ELOOP Во время определения pathname встретилось слишком много символьных ссылок. ENAMETOOLONG Слишком длинное значение аргумента pathname. ENOENT Файл не существует. ENOMEM Недостаточное количество памяти ядра. ENOTDIR Компонент в префиксе пути не является каталогом. ENOTDIR (fchmodat()) Значение pathname содержит относительный путь и dirfd содержит файловый дескриптор, указывающий на файл, а не на каталог. ENOTSUP (fchmodat()) В flags указано AT_SYMLINK_NOFOLLOW, но оно не поддерживается. EPERM Эффективный UID не совпадает с идентификатором владельца файла, а процесс не является привилегированным (Linux: не имеет мандата CAP_FOWNER). EPERM Файл помечен как неизменяемый (immutable) или только для добавления (смотрите FS_IOC_SETFLAGS(2const)). EROFS Указанный файл находится на файловой системе, смонтированной только для чтения.
ВЕРСИИ
Отличия между библиотекой C и ядром В этой странице описана обёрточная функция fchmodat() библиотеки GNU C, реализующая POSIX-интерфейс. Данный интерфейс отличается от лежащего в основе системного вызова Linux тем, что имеет аргумент flags. Замечания по glibc В старых ядрах, где fchmodat() отсутствует, обёрточная функция glibc использует chmod(). Если pathname является относительным путём, то glibc собирает путь относительно символической ссылки в /proc/self/fd, которая соответствует аргументу dirfd.
СТАНДАРТЫ
POSIX.1-2008.
ИСТОРИЯ
chmod() fchmod() 4.4BSD, SVr4, POSIX.1-2001. fchmodat() POSIX.1-2008. Linux 2.6.16, glibc 2.4.
СМОТРИТЕ ТАКЖЕ
chmod(1), chown(2), execve(2), open(2), stat(2), inode(7), path_resolution(7), symlink(7)
ПЕРЕВОД
Русский перевод этой страницы руководства разработал(и) Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitriy S. Seregin <dseregin@59.ru>, Dmitry Bolkhovskikh <d20052005@yandex.ru>, Katrin Kutepova <blackkatelv@gmail.com>, Yuri Kozlov <yuray@komyakino.ru>, Иван Павлов <pavia00@gmail.com> и Kirill Rekhov <krekhov.dev@gmail.com> Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику(ам) по его(их) адресу(ам) электронной почты или по адресу списка рассылки русских переводчиков. Справочные страницы Linux 6.9.1 13 июня 2024 г. chmod(2)