CHMOD(1) CHMOD(1) НАЗВАНИЕ chmod - изменение режима доступа к файлам СИНТАКСИС |chmod режим файл ... ОПИСАНИЕ Права доступа к указанным файлам (среди которых могут быть каталоги) изменяются в соответствии с указанным режимом. Режим может быть задан в абсолютном или сим- вольном виде. Абсолютный вид - восьмеричное число, являющееся пораз- рядным ИЛИ следующих режимов: 04000 При выполнении переустановить действующий иден- тификатор пользователя. 020#0 При выполнении переустановить действующий иден- тификатор группы, если # есть 7, 5, 3 или 1; учитывать блокировку доступа, если # есть 6, 4, 2 или 0. 01000 Бит навязчивости [см. chmod(2)]. 00400 Доступен для чтения владельцем. 00200 Доступен для записи владельцем. 00100 Доступен для выполнения (в случае каталога - для просмотра) владельцем. 00040 Доступен для чтения членами группы. 00020 Доступен для записи членами группы. 00010 Доступен для выполнения (просмотра) членами группы. 00004 Доступен для чтения прочими пользователями. 00002 Доступен для записи прочими пользователями. 00001 Доступен для выполнения (просмотра) прочими пользователями. Использование символьного вида основано на однобуквен- ных обозначениях, которые определяют класс доступа и права доступа для членов данного класса. Права доступа к файлу зависят от идентификатора пользователя и иден- тификатора группы, в которую он входит. Режим в целом описывается в терминах трех последовательностей, по три буквы в каждой: |Владелец Группа Прочие | (u) (g) (o) | rwx rwx rwx Здесь владелец, члены группы и все прочие пользователи обладают правами чтения файла, записи в него и его вы- полнения. В примере показаны обозначения как для класса доступа, так и для прав доступа внутри класса. Для задания режима доступа в символьном виде использу- ется следующий синтаксис: |[кому] операция права Часть кому есть комбинация букв u, g и o (владелец, члены группы и прочие пользователи соответственно). Ес- ли часть кому опущена или указано a, то это эквивалент но ugo. Операция может быть: + (добавить право), - (лишить пра ва), = (в пределах данного класса присвоить права абсо- лютно, то есть добавить указанные права и отнять неука- занные). Права - любая осмысленная комбинация следующих букв: r Право на чтение. w Право на запись. x Право на выполнение (поиск в каталоге). s При выполнении переустанавливать действующий иден- тификатор пользователя или группы. t После выполнения программы сохранять сегмент ко- манд (бит навязчивости). l Учет блокировки доступа. Опустить часть права можно только если операция есть = (для лишения всех прав). Если надо сделать более одного указания об изменении прав, то при использовании символьного вида в правах не должно быть пробелов, а указания должны разделяться з пятыми. Например, команда |chmod u+w,go+x f1 добавит для владельца право писать в файл f1, а для членов группы и прочих пользователей - право выполнять файл. Права устанавливаются в указанном порядке. Право s можно добавлять только для пользователя и группы, право t - только для пользователя. Учет блокировки доступа (l) к файлу и его частям озна чает возможность монопольного захвата сегментов файла на время их обработки. Нельзя, однако, разрешить выпол- нение файла для членов группы и одновременно учитывать блокировку файла. Нельзя также разрешить переустановить при выполнении действующий идентификатор группы и учи- тывать блокировку файла. Таким образом, следующие ко- манды являются некорректными: |chmod g+x,+l f2 |chmod g+s,+l f3 Попытка их выполнения вызовет соответствующую диагнос- тику. Изменить режим доступа к файлу может только его владе- лец или суперпользователь. Бит навязчивости может уста- новить только суперпользователь. Чтобы добавить право переустановки идентификатора группы, надо быть членом этой группы; кроме того, для членов группы должно бы установлено право выполнения. Для просмотра прав доступа и контроля при их изменении используется команда ls(1) с флагом -l. Права переуста- новки идентификаторов пользователя и группы отмечаются буквой s на месте соответствующей буквы x: малой s, ес- ли соответствующая категория пользователей имеет право x, и большой S - если не имеет; право t отмечается на месте последней буквы x: малой t, если прочие пользова- тели имеют право выполнять файл, и большой T - если не имеют. Право l отмечается на месте права x для членов группы. ПРИМЕРЫ 1. Чтобы установить права, позволяющие владельцу читать и писать в файл, а членам группы и прочим пользователям только читать, надо сложить 0400, 0200, 0040 и 0004. Таким образом, команду можно записать двумя способами: |chmod 644 f1 |chmod u=rw,go=r f1 2. Позволить всем выполнять файл f2: |chmod +x f2 3. Учитывать блокировку доступа к файлу f3: |chmod +l f3 4. Дать всем права на чтение запись и выполнение, а также на переустановку идентификатора группы при выпол- нении файла f4: |chmod =rwx,g+s f4 |chmod 2777 f4 СМ. ТАКЖЕ ls(1). chmod(2) в Справочнике программиста.