<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.39 (Ruby 3.4.9) -->
<?rfc docmapping="yes"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-nfsv4-nfs-acl-02" category="info" submissionType="IETF" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.0 -->
  <front>
    <title abbrev="NFS ACL Protocol">The Network File System Access Control List Protocol</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-nfsv4-nfs-acl-02"/>
    <author fullname="Chuck Lever" role="editor">
      <organization>Independent</organization>
      <address>
        <postal>
          <country>United States of America</country>
        </postal>
        <email>cel-ietf@chucklever.net</email>
      </address>
    </author>
    <date year="2026" month="June" day="20"/>
    <area>Web and Internet Transport</area>
    <workgroup>Network File System Version 4</workgroup>
    <keyword>NFS</keyword>
    <keyword>ACL</keyword>
    <abstract>
      <?line 89?>

<t>This Informational document describes the NFS_ACL protocol.
NFS_ACL is a legacy member of the Network File System family
of protocols that NFS clients use to view and update Access
Control Lists stored on an NFS version 2 or version 3 server.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://chucklever.github.io/i-d-nfs-acl/draft-ietf-nfsv4-nfs-acl.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-nfsv4-nfs-acl/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Network File System Version 4 Working Group mailing list (<eref target="mailto:nfsv4@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/nfsv4/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/nfsv4/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/chucklever/i-d-nfs-acl"/>.</t>
    </note>
  </front>
  <middle>
    <?line 97?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>The Network File System protocol (NFS) was introduced by Sun
Microsystems in the 1980s. This protocol enabled applications
to access and modify files, via local POSIX system interfaces,
that reside on a remote host <xref target="RFC1094"/>.</t>
      <t>Traditionally, permission to access files stored in NFS file
systems is granted by permission bits, mimicking <xref target="POSIX"/>.
Permission bits provide coarse-grained access control. The
file owner can control only whether members of her group can
read, write, or execute the file contents, or whether anyone
else (without exception) has those rights.</t>
      <t>An Access Control List, or ACL, is a mechanism that enables
file owners to grant specific users fine-grained access
rights to file content <xref target="IEEE"/>.</t>
      <t>Version 2 of NFS is described in <xref target="RFC1094"/>, and version 3
in <xref target="RFC1813"/>. Neither of these protocols include a method
for managing ACLs associated with files shared via the NFS
protocol, even though the local file systems shared via NFS
often implemented ACLs and gave local users mechanisms to
read and update them.</t>
      <t>Sun created the NFS_ACL protocol to provide that mechanism
for files accessed remotely via NFS. Later, other operating
systems, including Linux, implemented NFS_ACL for similar
reasons.</t>
      <t>This document describes the protocol based on the nfs_acl.x
file that is publicly available in the OpenSolaris
code base <xref target="OpenSolaris"/>. The editor has attempted to
introduce no changes to the protocol as it is implemented
in those operating systems and in Linux.</t>
      <t>The document assumes readers are already familiar with the
NFS version 2 or 3 protocols and at least one implementation
of them.</t>
      <t>Issues of compatibility between the protocol described in
this document and NFSv4 ACLs (as described by <xref target="RFC8881"/>)
are considered out of scope. More information on this topic
is available in <xref target="I-D.ietf-nfsv4-posix-acls"/>.</t>
      <t>Local file systems on NFSv2 and NFSv3 servers determine the
particular semantics of each Access Control List -- in other
words, how the server uses each Access Control List to
authorize access to file content. This document serves only
as a description of the network protocol used to exchange
ACLs between NFS clients and servers.</t>
    </section>
    <section anchor="conventions-and-definitions">
      <name>Conventions and Definitions</name>
      <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
      <?line -18?>

<t>As with most publications by standards bodies, this document
has been published so that people may continue to create
compatible implementations. However, note that, as an
Informational document, this RFC does not make any compliance
mandates on implementations of the protocol described herein.</t>
    </section>
    <section anchor="general-concepts">
      <name>General Concepts</name>
      <section anchor="a-glossary-of-useful-terms">
        <name>A Glossary of Useful Terms</name>
        <t>The following are a set of foundational terms used throughout
this document.</t>
        <dl>
          <dt>application:</dt>
          <dd>
            <t>A program that executes on a client system.</t>
          </dd>
          <dt>client:</dt>
          <dd>
            <t>A computer system that utilizes compute resources provided by one or
more servers.</t>
          </dd>
          <dt>file:</dt>
          <dd>
            <t>A unit of data storage consisting of an ordered stream of
bytes and a set of metadata attributes.</t>
          </dd>
          <dt>gid:</dt>
          <dd>
            <t>A 32-bit unsigned integer that represents a group of users.</t>
          </dd>
          <dt>server:</dt>
          <dd>
            <t>A computer system that provides compute resources to network peers.</t>
          </dd>
          <dt>uid:</dt>
          <dd>
            <t>A 32-bit unsigned integer that represents a specific user.</t>
          </dd>
          <dt>user:</dt>
          <dd>
            <t>A person logged in on a client system.</t>
          </dd>
        </dl>
      </section>
      <section anchor="remote-procedure-call">
        <name>Remote Procedure Call</name>
        <t>The Sun Remote Procedure Call (SunRPC) protocol provides a
procedure-oriented interface to remote services. Each server
supplies a program, which is a set of procedures. The NFS
service is one such program. The combination of host address,
program number, version number, and procedure number specify one
remote service procedure.  Servers can support multiple versions
of a program that are accessed using different protocol version
numbers.</t>
        <t>The NFS and NFS_ACL protocols are both based on SunRPC. The
remainder of this document assumes an NFS environment that is
implemented on top of SunRPC, as it is specified in <xref target="RFC5531"/>.</t>
      </section>
      <section anchor="external-data-representation">
        <name>External Data Representation</name>
        <t>The eXternal Data Representation (XDR) specification provides a
standard way of representing a set of data types on a network.
XDR addresses the problem of communication between network
peers with different byte orders, structure alignment, and data
type representation.</t>
        <t>This document utilizes the RPC Data Description Language to
specify the XDR format arguments and results to each of the RPC
service procedures that an NFS_ACL server provides.</t>
        <t>Readers can find a full guide to XDR and the RPC Data Description
Language in <xref target="RFC4506"/>.</t>
        <section anchor="extensions-to-rfc-4506">
          <name>Extensions to RFC 4506</name>
          <t>The original NFS_ACL version 2 RPC language specification includes the use of
the "unsigned short" type. This type is not described in <xref target="RFC4506"/>. However,
most current implementations of the rpcgen program implement support for
this type. This section provides a proper specification for "short" and
"unsigned short" integer types for the RPC language, based on those
implementations. This is so that the NFS_ACL version 2 RPC language
specification appearing in this document accurately reflects the wire behavior
of existing implementations.</t>
          <t>The XDR wire representation of both types is a network-endian 32-bit integer,
sign-extended. This maintains XDR's consistent 4-octet alignment for all basic
integer types while allowing applications to use narrower types internally.</t>
          <section anchor="unsigned-short">
            <name>unsigned short</name>
            <t>The unsigned short type is zero-extended, with the high-order two octets each
containing zeroes on the wire. The value range of this type is zero to 65,535,
inclusive.</t>
            <t>Example: 0xFFFF (65535) appears as 0x0000FFFF on the wire.</t>
          </section>
          <section anchor="signed-short">
            <name>signed short</name>
            <t>The short type is sign-extended, with the high-order two octets replicating
the sign bit. The value range of this type is -32768 to 32767, inclusive.</t>
            <t>When a signed short contains a positive or zero value, its high-order octets
each contain 0x00. For example: 0x7FFF (32767) appears as 0x00007FFF on the
wire.</t>
            <t>When a signed short contains a negative value, its high-order octets each
contain 0xFF. For example: 0xFFFF (-1) appears as 0xFFFFFFFF on the wire,
and 0x8000 (-32768) appears as 0xFFFF8000 on the wire.</t>
          </section>
        </section>
      </section>
      <section anchor="authentication-and-authorization">
        <name>Authentication and Authorization</name>
        <t>The RPC protocol includes fields in every procedure call for
user authentication parameters. The specific content of the
authentication parameters is determined by the type of
authentication used by the server and client. A discussion
of the mechanics of RPC user authentication appears in
<xref target="RFC5531"/>, in particular Sections 9 and 10.</t>
        <t>For NFS ACLs, the user ID carried in RPC calls is used
for two purposes:</t>
        <ul spacing="normal">
          <li>
            <t>When setting an ACL via the SETACL procedure or retrieving
an ACL via the GETACL procedure, the NFS_ACL service verifies
that the calling user has been granted permission to perform
the procedure.</t>
          </li>
          <li>
            <t>Each Access Control Entry (see below) contains an element
that identifies the user to which the ACE applies. That
user is represented by a 32-bit user ID. The value of the
user ID in each ACE has the same meaning and mapping as
the value of incoming RPC calls.</t>
          </li>
        </ul>
        <t>Using user ids and group ids implies that the client and
server either share the same ID list or do local user and
group ID mapping. Servers and clients must agree on the
mapping from user to uid and from group to gid, for those
sites that do not implement a consistent user ID and group
ID number space. In practice, such mapping is typically
performed on the server, following a static mapping scheme
or a mapping established by the user from a client at
mount time.</t>
        <t>RPCSEC_GSS authentication provides stronger
security through the use of cryptographic authentication.
The server and client must agree on the mapping of the
user's GSS principal to a local UID on the server, but
the name to identity mapping is more operating system
independent than the uid and gid mapping in AUTH_UNIX.</t>
      </section>
      <section anchor="file-access-control">
        <name>File Access Control</name>
        <t>This section describes the abstractions that an NFS server
uses to determine whether an access or modification
to a file is permitted. The exact behavior of a server
implementation may vary.</t>
        <section anchor="file-ownership">
          <name>File Ownership</name>
          <t>A file’s "owner" is the designated user that is always granted
permission to update that file’s security attributes. As part of
creating a file, the NFS server assigns the file’s owner. Under
normal circumstances the initial file owner is the RPC user who
issued the NFS CREATE procedure. However, server security policies
can mandate replacement of that user (also known as user squashing)
as part of processing a CREATE procedure.</t>
          <t>An existing file’s designated owner can subsequently be changed by
an NFS SETATTR procedure. After that change, the new owner is
granted permission to update the file’s security attributes and
the old owner is no longer treated specially.</t>
          <t>A file’s "owner group" is a short list of users that have
similar privileges as the file’s owner, but are treated as a
separate category for the purpose of permission checking.</t>
          <t>Any user who is not a file's owner or a member of its owner
group falls into the third category, known as "everyone" or
"other".</t>
          <section anchor="superuser-access">
            <name>Superuser Access</name>
            <t>On most operating systems, there is a category of users known as
privileged users or superusers. These users can bypass most or
all access controls on files.</t>
          </section>
        </section>
        <section anchor="categories-of-access">
          <name>Categories of Access</name>
          <t>In NFS versions 2 and 3, there are three rudimentary categories
of access:</t>
          <dl>
            <dt>Read access:</dt>
            <dd>
              <t>Read access grants permission for a user to read a file or
directory.</t>
            </dd>
            <dt>Write access:</dt>
            <dd>
              <t>Write access grants permission for a user to modify a file
or directory.</t>
            </dd>
            <dt>Execute access:</dt>
            <dd>
              <t>For a file, execute access grants permission for the user to
treat the file content as executable. For a directory object,
execute access grants permission for the user to perform a
lookup in that directory.</t>
            </dd>
          </dl>
        </section>
        <section anchor="traditional-permission-bits">
          <name>Traditional Permission Bits</name>
          <t>Permission bits, or mode bits, are the simplest and perhaps
oldest form of access control. Each file object has a set
of mode bits <xref target="POSIX"/>.</t>
          <t>Each of the user categories is given a set of three access
type bits. Altogether there are then nine bit flags for
every file object.</t>
        </section>
        <section anchor="access-control-lists">
          <name>Access Control Lists</name>
          <t>An Access Control Entry, or ACE, represents a set of access categories
and a specific user or group. An Access Control List is a list of ACEs.</t>
          <t>Mode bits, as explained in the previous section, are essentially an
ACL that always contains exactly three ACEs: one for the file's owner,
one for the file's owner group, and one for everyone else.</t>
          <section anchor="interpreting-access-control-lists">
            <name>Interpreting Access Control Lists</name>
            <t>NFS clients do not perform access checks based on their
interpretation of an ACL read from the server. NFS servers
are solely responsible for authorizing and restricting
access to file content via the NFS protocol.</t>
            <t>An NFS Access Control List is a list of three or more
Access Control Entries (ACEs) associated with one file
system object. Each Access Control Entry in this list
specifies a user and a set of access types granted to
that user.</t>
            <t>Only ACEs that match the requester are considered. Each
ACE is processed until all of the bits of the requester's
access have been ALLOWED. Once a bit has been ALLOWED,
that bit is no longer considered in the processing
of subsequent ACEs in the list.</t>
            <t>When the ACL has been fully processed, if there are bits
in the requester's mask that have not been ALLOWED,
access of that type is denied.</t>
            <t>Note that an ACL might not be the sole determiner of access. For example:</t>
            <ul spacing="normal">
              <li>
                <t>In the case of a file system exported as read-only,
the server may deny write access even though an object's
ACL grants it.</t>
              </li>
              <li>
                <t>Server implementations can grant some limited permission
to update an ACL in order to prevent a situation from
rising in which there is no valid way to ever modify the ACL.</t>
              </li>
              <li>
                <t>All servers will allow a user the ability to read the
data of the file when only the execute permission is granted
(i.e., if the ACL denies the user the NA_READ access and
allows the user NA_EXEC, the server will allow the user to
read the data of the file).</t>
              </li>
              <li>
                <t>Some server implementations have the notion of
owner-override, in which the owner of the object is allowed
to override accesses that are denied by the ACL. This can be
helpful, for example, to allow users continued access to
open files on which the permissions have changed.</t>
              </li>
              <li>
                <t>Some server implementations have the notion of a
"superuser" that has privileges beyond an ordinary user.
The superuser may be able to read or write data or metadata
in ways that would otherwise not be permitted by the object's
ACL.</t>
              </li>
            </ul>
            <t>NFS clients can use either the NFS_ACL version 2 ACCESS
procedure or the NFS version 3 ACCESS procedure to ask the
server to perform an access check based on the requesting
user and the ACL present on a file system object. Clients are
also free to simply try an operation to see what works, then
recover it the server denies access.</t>
          </section>
          <section anchor="acls-in-operation">
            <name>ACLs in Operation</name>
            <t>The SETACL procedure sets two types of Access Control Lists:</t>
            <dl>
              <dt>Access:</dt>
              <dd>
                <t>An NFS access ACL specifies the access permission
for a file object. Access Control Entries in an ACL's
"aclent" field comprise the object's access ACL.</t>
              </dd>
              <dt>Default:</dt>
              <dd>
                <t>An NFS default ACL specifies the default ACL that
is set on objects that are children of a directory.
Access Control Entries in an ACL's "dfaclent" comprise
an object's default ACL. The default ACL does not affect
access to the object on which it is set.</t>
              </dd>
            </dl>
            <t>Each NFS ACL must have one ACE for each of
NA_USER_OBJ, NA_GROUP_OBJ, and NA_OTHER_OBJ.
An NFS ACL that consists only of these
three ACEs is referred to as a minimal NFS ACL.</t>
            <t>An NFS ACL may zero or more NA_USER and/or NA_GROUP
ACEs.</t>
            <t>When a client presents a SETACL operation that a server
finds is invalid or it cannot process, the server responds
with ACL2ERR_IO or ACL3ERR_INVAL, depending on the version
of NFS_ACL that is in use. ACLs that are not valid include:</t>
            <ul spacing="normal">
              <li>
                <t>The presented ACL does not contain one ACE for each of
NA_USER_OBJ, NA_GROUP_OBJ, and NA_OTHER_OBJ</t>
              </li>
              <li>
                <t>The presented ACL is a default ACL but the target object
is not a directory</t>
              </li>
              <li>
                <t>The presented ACL contains too many ACEs</t>
              </li>
              <li>
                <t>The presented ACL's type field contains more than one
set bit</t>
              </li>
            </ul>
            <aside>
              <t>cel: What does the NA_ACL_DEFAULT bit do?</t>
            </aside>
            <aside>
              <t>rthurlow: In the Solaris acl(2)/facl(2) system calls, the
equivalently-defined ACL_DEFAULT is used after aclent
sorting to note where regular entries end and where default
entries start in a single list.  So perhaps it would be
normal for the dfaclent entries to all be so marked.</t>
            </aside>
            <t>The "id" field in an Access Control Entry is interpreted as follows:</t>
            <ul spacing="normal">
              <li>
                <t>For an ACE that specifies an NA_USER_OBJ, NA_USER,
NA_GROUP, and NA_GROUP_OBJ, the "id" field contains
a UID or GID value that identifies the user on the
server whose access permission is being set.</t>
              </li>
              <li>
                <t>For an ACE that specifies other types of permission,
the "id" field is ignored.</t>
              </li>
            </ul>
          </section>
          <section anchor="relationship-between-acls-and-other-file-attributes">
            <name>Relationship Between ACLs and Other File Attributes</name>
            <t>When an ACL is present on a file, the ACL controls the
requesting user's access to the file. Typically the NFS
server ignores the file's mode bits.</t>
            <t>Depending on the behavior of the local file system
implementation, changing the file's ACL via the SETACL
procedure may alter the file's mode bits, and changing
the mode bits via the SETATTR procedure may alter the
content of the ACL in any way. NFS clients should
refresh cached ACLs or file modes after one of these
operations.</t>
            <t>When an ACL is present on a file, changing the file's owner
(say, via the SETATTR operation) may alter the server's
interpretation of any ACE that targets NA_USER_OBJ.</t>
            <t>When an ACL is present on a file, changing the file's group
(say, via the SETATTR operation) may alter the server's
interpretation of any ACE that targets NA_GROUP_OBJ.</t>
            <t>If an NFS client observes that a file's ctime attribute
has changed, it should assume that any ACLs that are
present might have been modified.</t>
          </section>
          <section anchor="acl-inheritance">
            <name>ACL Inheritance</name>
            <aside>
              <t>Section needs to explain how default ACLs work and what
impact they may have on the mode bits of the new file.</t>
            </aside>
            <t>A client uses one of the NFS CREATE, MKDIR, or MKNOD procedures
to request instantiation of a new file object. The server uses
the default ACL from the parent directory as the initial access
ACL on the new object.</t>
          </section>
          <section anchor="historical-references">
            <name>Historical References</name>
            <t>The section entitled "The POSIX 1003.1e/1003.2c Working Group"
in <xref target="Gruenbacher"/> details the history of POSIX standards efforts
with regard to file access control. The editor recommends that
readers familiarize themselves with the extent to which POSIX
specifies the content and behavior of ACLs.</t>
          </section>
        </section>
      </section>
    </section>
    <section anchor="protocol-elements-common-to-both-versions">
      <name>Protocol Elements Common to Both Versions</name>
      <section anchor="rpc-authentication">
        <name>RPC Authentication</name>
        <t>The NFS_ACL service uses AUTH_NONE in the NULL procedure.
All RPC authentication flavors may be used for other procedures.</t>
      </section>
      <section anchor="constants">
        <name>Constants</name>
        <t>These are the RPC constants needed to call the NFS Version 3
service.  They are given in decimal.</t>
        <dl>
          <dt>100227</dt>
          <dd>
            <t>The RPC program number for the NFS_ACL protocol</t>
          </dd>
        </dl>
        <t>Only versions 2 and 3 of this RPC program are valid.</t>
      </section>
      <section anchor="transport-address">
        <name>Transport address</name>
        <t>The NFS_ACL protocol can operate over the TCP, UDP, and RDMA
transport protocols.
For TCP and UDP, it uses port 2049, and for RDMA, it uses 20049.
In both cases, this is the same as the base NFS protocol.</t>
      </section>
      <section anchor="sizes">
        <name>Sizes</name>
        <sourcecode type="xdr"><![CDATA[
NFS_ACL_MAX_ENTRIES 1024
]]></sourcecode>
        <t>The maximum number of Access Control Entries allowed in one Access Control List array.</t>
      </section>
      <section anchor="basic-data-types">
        <name>Basic Data Types</name>
        <t>The following XDR definitions are basic scalar types that are used in other structures.</t>
        <sourcecode type="xdr"><![CDATA[
typedef unsigned int uid;
]]></sourcecode>
        <sourcecode type="xdr"><![CDATA[
typedef unsigned short o_mode;
]]></sourcecode>
      </section>
      <section anchor="structured-data-types">
        <name>Structured Data types</name>
        <t>The following XDR definitions are common structured data types
that are used in all versions of the NFS_ACL protocol.</t>
        <section anchor="aclent">
          <name>aclent</name>
          <t>This structure represents a single entry in an Access Control List.</t>
          <sourcecode type="xdr"><![CDATA[
struct aclent {
    int type;
    uid id;
    o_mode perm;
};
]]></sourcecode>
          <t>The "type" element in an Access Control Entry is a bit mask.
The bit field values in this mask are defined as follows:</t>
          <sourcecode type="xdr"><![CDATA[
const NA_USER_OBJ = 0x1;        /* object owner */
const NA_USER = 0x2;            /* additional users */
const NA_GROUP_OBJ = 0x4;       /* owning group of the object */
const NA_GROUP = 0x8;           /* additional groups */
const NA_CLASS_OBJ = 0x10;      /* file group class and mask entry */
const NA_OTHER_OBJ = 0x20;      /* other entry for the object */
const NA_ACL_DEFAULT = 0x1000;  /* default flag */
]]></sourcecode>
          <t>The "perm" element in an Access Control Entry is also a bit mask.
The bit field values in this mask are defined as follows:</t>
          <sourcecode type="xdr"><![CDATA[
const NA_READ = 0x4;            /* read permission */
const NA_WRITE = 0x2;           /* write permission */
const NA_EXEC = 0x1;            /* exec permission */
]]></sourcecode>
        </section>
        <section anchor="secattr">
          <name>secattr</name>
          <t>The secattr structure represents, on the wire, the full Access Control
List for one file system object. This list contains an array of
Access Control Entries that apply to the object, plus an array of
default Access Control Entries that are inherited by the object's
children.</t>
          <sourcecode type="xdr"><![CDATA[
struct secattr {
    unsigned int mask;
    int aclcnt;
    aclent aclent<NFS_ACL_MAX_ENTRIES>;
    int dfaclcnt;
    aclent dfaclent<NFS_ACL_MAX_ENTRIES>;
};
]]></sourcecode>
          <t>The "mask" element of the secattr structure is a bit mask. The
bit field values in this mask are defined as follows:</t>
          <sourcecode type="xdr"><![CDATA[
const NA_ACL = 0x1;         /* aclent contains a valid list */
const NA_ACLCNT = 0x2;      /* number of entries in the aclent list */
const NA_DFACL = 0x4;       /* dfaclent contains a valid list */
const NA_DFACLCNT = 0x8;    /* number of entries in the dfaclent list */
]]></sourcecode>
          <t>These bit field values are also used in the "mask" element of the
GETACL2args and GETACL3args structures.</t>
        </section>
        <section anchor="interoperability-considerations">
          <name>Interoperability Considerations</name>
          <t>Interoperability between NFS peers that do not implement
the NFS_ACL protocol is what we already have today.
Interoperability between peers that both implement the NFS_ACL
protocol is described in the rest of this document.</t>
          <t>The following subsections briefly discuss three new
interoperability scenarios.</t>
          <section anchor="client-implements-nfsacl-server-does-not">
            <name>Client Implements NFS_ACL, Server Does Not</name>
            <t>Typically an NFS server that implements the NFS_ACL program will
advertise the presence of NFS_ACL via an rpcbind registration.
An NFS client that implements NFS_ACL should perform an rpcbind
query before attempting any NFS_ACL procedure <xref target="RFC1833"/>.</t>
            <t>If the client sends any NFS_ACL procedure without sending an
rpcbind query first, and the server does not implement the
NFS_ACL program, the server responds with an RPC access_stat
of PROG_UNAVAIL.</t>
          </section>
          <section anchor="server-implements-nfsacl-client-does-not">
            <name>Server Implements NFS_ACL, Client Does Not</name>
            <t>An NFS server that implements advanced access control can
deny requests made by a client by responding with
NFS2ERR_ACCESS or NFS3ERR_ACCESS status codes, and an
NFS client has no visibility as to why the denial occurred.
Neither can that client send operations to update
the access control on file objects.</t>
            <t>This is a quality of implementation issue for the client.</t>
          </section>
          <section anchor="client-implements-exported-file-system-does-not">
            <name>Client Implements, Exported File System Does Not</name>
            <t>An NFS server that implements the NFS_ACL protocol might
share both file systems that implement ACLs and
file systems that do not. In this case, NFS clients
detect the presence of an NFS_ACL service on the NFS
server.</t>
            <t>For file objects that do not implement ACL support:</t>
            <ul spacing="normal">
              <li>
                <t>The server responds to a GETACL procedure by returning
a manufactured minimal ACL (i.e., only three ACEs) that
reflects the current mode bits of the object.</t>
              </li>
              <li>
                <t>The server responds to a SETACL version 3 procedure by
returning ACL3ERR_NOTSUPP.</t>
              </li>
              <li>
                <t>The server responds to a SETACL version 2 procedure by
returning ACL2ERR_IO.</t>
              </li>
            </ul>
            <t>The Linux implementation of the NFS_ACL protocol deviates from
the protocol specified in the current document by returning
NFS3ERR_NOTSUPP in response to a SETACL version 2 procedure on a
file system that does not support ACLs.</t>
          </section>
        </section>
      </section>
    </section>
    <section anchor="nfsacl-version-2">
      <name>NFS_ACL Version 2</name>
      <t>Version 2 of the NFS_ACL protocol is used in conjunction only with
version 2 of the NFS protocol.</t>
      <section anchor="data-types-inherited-from-nfs-version-2">
        <name>Data types inherited from NFS version 2</name>
        <section anchor="ftype">
          <name>ftype</name>
          <t>The enumeration "ftype" gives the type of an NFS version 2 file.
This definition comes from <xref section="2.3.2" sectionFormat="of" target="RFC1094"/>:</t>
          <sourcecode type="xdr"><![CDATA[
enum ftype {
    NFNON = 0,
    NFREG = 1,
    NFDIR = 2,
    NFBLK = 3,
    NFCHR = 4,
    NFLNK = 5
};
]]></sourcecode>
        </section>
        <section anchor="fhandle">
          <name>fhandle</name>
          <t>NFS version 2 uses a fixed-size file handle. The following definition
comes from <xref section="2.3.3" sectionFormat="of" target="RFC1094"/>:</t>
          <sourcecode type="xdr"><![CDATA[
const FHSIZE = 32;

typedef opaque fhandle[FHSIZE];
]]></sourcecode>
        </section>
        <section anchor="timeval">
          <name>timeval</name>
          <t>NFS version 2's "timeval" structure represents the number of seconds
and microseconds since midnight January 1, 1970, Greenwich Mean Time.
This definition comes from <xref section="2.3.4" sectionFormat="of" target="RFC1094"/>:</t>
          <sourcecode type="xdr"><![CDATA[
struct timeval {
    unsigned int seconds;
    unsigned int useconds;
};
]]></sourcecode>
        </section>
        <section anchor="nfsfattr">
          <name>nfsfattr</name>
          <t>This document refers to NFS version 2's file attribute structure
as "nfsfattr". This is the same as the fattr structure described
in <xref section="2.3.5" sectionFormat="of" target="RFC1094"/>:</t>
          <sourcecode type="xdr"><![CDATA[
struct fattr {
    ftype        type;
    unsigned int mode;
    unsigned int nlink;
    unsigned int uid;
    unsigned int gid;
    unsigned int size;
    unsigned int blocksize;
    unsigned int rdev;
    unsigned int blocks;
    unsigned int fsid;
    unsigned int fileid;
    timeval      atime;
    timeval      mtime;
    timeval      ctime;
};
]]></sourcecode>
        </section>
        <section anchor="defined-error-numbers">
          <name>Defined Error Numbers</name>
          <t><xref section="2.3.1" sectionFormat="of" target="RFC1094"/> describes an enumerated type called
"stat" which provides a status code for NFS version 2 results.
A matching type called "aclstat2" is defined in this document
for the similar purpose of returning NFS_ACL version 2 procedure
status codes. The numeric values of these two types match up,
though aclstat2 omits some codes that are not relevant to the
NFS_ACL protocol.</t>
          <sourcecode type="xdr"><![CDATA[
enum aclstat2 {
    ACL2_OK = 0,
    ACL2ERR_PERM = 1,
    ACL2ERR_NOENT = 2,
    ACL2ERR_IO = 5,
    ACL2ERR_ACCES = 13,
    ACL2ERR_NOSPC = 28,
    ACL2ERR_ROFS = 30,
    ACL2ERR_DQUOT = 69,
    ACL2ERR_STALE = 70
};
]]></sourcecode>
          <t>These status codes carry the following meanings:</t>
          <dl>
            <dt>ACL2ERR_PERM</dt>
            <dd>
              <t>Not owner. The caller does not have correct ownership to perform the requested operation.</t>
            </dd>
            <dt>ACL2ERR_NOENT</dt>
            <dd>
              <t>No such file or directory. The file or directory name specified does not exist.</t>
            </dd>
            <dt>ACL2ERR_IO</dt>
            <dd>
              <t>Some sort of hard error occurred when the operation was in progress.  This could be a disk error, for example.</t>
            </dd>
            <dt>ACL2ERR_ACCES</dt>
            <dd>
              <t>Permission denied.  The caller does not have the correct permission to perform the requested operation.</t>
            </dd>
            <dt>ACL2ERR_NOSPC</dt>
            <dd>
              <t>No space left on device.  The operation caused the server's file system to reach its limit.</t>
            </dd>
            <dt>ACL2ERR_ROFS</dt>
            <dd>
              <t>Read-only file system.  Write attempted on a read-only file system.</t>
            </dd>
            <dt>ACL2ERR_DQUOT</dt>
            <dd>
              <t>Disk quota exceeded.  The client's disk quota on the server has been exceeded.</t>
            </dd>
            <dt>ACL2ERR_STALE</dt>
            <dd>
              <t>The "fhandle" given in the arguments was invalid.  That is, the file referred to by that file handle no longer exists, or access to it has been revoked.</t>
            </dd>
          </dl>
        </section>
      </section>
      <section anchor="server-procedures">
        <name>Server Procedures</name>
        <section anchor="procedure-0-null-no-operation">
          <name>Procedure 0: NULL - No Operation</name>
          <section anchor="arguments">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
void;
]]></sourcecode>
          </section>
          <section anchor="results">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
void;
]]></sourcecode>
          </section>
          <section anchor="description">
            <name>DESCRIPTION</name>
            <t>This is the usual NULL procedure with a void argument and void result.</t>
          </section>
          <section anchor="implementation">
            <name>IMPLEMENTATION</name>
            <t>It is important that this procedure do no work at all so that clients
can use it to measure the overhead of processing a service request.
By convention, the NULL procedure should never require any
authentication.
A server implementation may choose to ignore this convention, if
responding to the NULL procedure call acknowledges the existence
of a resource to an unauthenticated client.</t>
          </section>
          <section anchor="errors">
            <name>ERRORS</name>
            <t>Since the NULL procedure returns no result, it can not return an
NFS_ACL error status code. However, some server implementations may
return RPC-level errors based on security or authentication policy
settings.</t>
          </section>
        </section>
        <section anchor="procedure-1-getacl-retrieve-an-access-control-list">
          <name>Procedure 1: GETACL - Retrieve an Access Control List</name>
          <section anchor="arguments-1">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETACL2args {
    fhandle fh;
    unsigned int mask;
};
]]></sourcecode>
          </section>
          <section anchor="results-1">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETACL2resok {
    fattr attr;
    secattr acl;
};

union GETACL2res switch (aclstat2 status) {
case ACL2_OK:
    GETACL2resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-1">
            <name>DESCRIPTION</name>
            <t>The GETACL procedure retrieves Access Control List
information associated with the file system object
specified by the GETACL2args.fh field. The client
obtains this file handle using one of the NFS
version 2 LOOKUP, CREATE, MKDIR, or SYMLINK procedures,
or the MOUNT service, as described in <xref target="RFC1094"/>.</t>
            <t>The GETACL2args.mask field specifies which information
is to be returned in the response:</t>
            <ul spacing="normal">
              <li>
                <t>If the NA_ACL bit is set, the server fills in the
object's access ACL.</t>
              </li>
              <li>
                <t>If the NA_ACLCNT bit is set, the server fills in
the number of ACEs that are in the object's access ACL.</t>
              </li>
              <li>
                <t>If the NA_DFACL bit is set, the server fills in
the object's default ACL.</t>
              </li>
              <li>
                <t>if the NA_DFACLCNT bit is set, the server fills in
the number of ACEs that are in the object's default ACL.</t>
              </li>
            </ul>
            <t>If the GETACL procedure is successful, the server sets the
GETACL2res.status field to ACL2_OK. It fills in the
GETACL2resok.attr field with the file object's current
file attributes, as detailed in <xref target="RFC1094"/>. Lastly,
it fills in the GETACL2res.acl field with two counted
arrays of Access Control Entries (ACEs).</t>
            <t>Otherwise, GETACL2res.status contains an error status
on failure and no other results are returned.</t>
          </section>
          <section anchor="implementation-1">
            <name>IMPLEMENTATION</name>
            <t>When GETACL2args.fh represents a file object that does not currently
have an ACL associated with it or does not implement support
for ACLs, the server responds by returning a manufactured
minimal NFS ACL that reflects the current owner, group, and
mode bits of the object (see <xref target="acls-in-operation"/>).</t>
          </section>
          <section anchor="errors-1">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL2ERR_IO</t>
              </li>
              <li>
                <t>ACL2ERR_STALE</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-2-setacl-set-or-replace-an-access-control-list">
          <name>Procedure 2: SETACL - Set or replace an Access Control List</name>
          <section anchor="arguments-2">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct SETACL2args {
    fhandle fh;
    secattr acl;
};
]]></sourcecode>
          </section>
          <section anchor="results-2">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct SETACL2resok {
    fattr attr;
};

union SETACL2res switch (aclstat2 status) {
case ACL2_OK:
    SETACL2resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-2">
            <name>DESCRIPTION</name>
            <t>The SETACL procedure replaces the Access Control Lists
associated with the file system object specified by the
SETACL2args.fh field with the ACLs specified by the
SETACL2args.acl field.  The client obtains the file
handle using one of the NFS version 2 LOOKUP, CREATE,
MKDIR, SYMLINK procedures, or the MOUNT service, as
described in <xref target="RFC1094"/>.</t>
            <t>To remove extended access control from a file object, a client
uses SETACL to replace the object's ACL with a minimal NFS ACL
(see <xref target="acls-in-operation"/>).</t>
            <t>If the SETACL procedure is successful, the server sets the
SETACL2res.status field to ACL2_OK and fills in the
SETACL2resok.attr field with the file object's new
file attributes, as detailed in <xref target="RFC1094"/>.</t>
            <t>Otherwise, SETACL2res.status contains an error status
on failure and no other results are returned.</t>
          </section>
          <section anchor="implementation-2">
            <name>IMPLEMENTATION</name>
            <t>On success, the server does not send the reply until
the ACL change is durable locally.</t>
            <t>Changing a file object's ACL changes the object's mtime.
The mtime change is reflected in the attributes returned
in the SETACL response.</t>
            <t>A high-quality server implementation ensures that a
GETACL procedure running concurrently with a SETACL
procedure does not return partially updated (torn)
ACL contents. However, a failed SETACL may partially
change a file's ACLs.</t>
            <t>When SETACL2args.fh represents a file object that does
not implement support for ACLs, or the new ACL does not
contain at least the minimal set of ACEs (as described
in <xref target="acls-in-operation"/>), the server responds by
setting SETACL2res.status to ACL2ERR_IO.</t>
          </section>
          <section anchor="errors-2">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL2ERR_ROFS</t>
              </li>
              <li>
                <t>ACL2ERR_PERM</t>
              </li>
              <li>
                <t>ACL2ERR_IO</t>
              </li>
              <li>
                <t>ACL2ERR_ACCES</t>
              </li>
              <li>
                <t>ACL2ERR_NOSPC</t>
              </li>
              <li>
                <t>ACL2ERR_DQUOT</t>
              </li>
              <li>
                <t>ACL2ERR_STALE</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-3-getattr-get-file-attributes">
          <name>Procedure 3: GETATTR - Get file attributes</name>
          <section anchor="arguments-3">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETATTR2args {
    fhandle fh;
};
]]></sourcecode>
          </section>
          <section anchor="results-3">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETATTR2resok {
    fattr attr;
};

union GETATTR2res switch (aclstat2 status) {
case ACL2_OK:
    GETATTR2resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-3">
            <name>DESCRIPTION</name>
            <t>The GETATTR procedure retrieves the current file
attributes associated with the file system object
specified by the GETATTR2args.fh field. The client
obtains this file handle using one of the NFS
version 2 LOOKUP, CREATE, MKDIR, SYMLINK procedures,
or the MOUNT service, as described in <xref target="RFC1094"/>.</t>
            <t>If the GETATTR procedure is successful, the server
sets the GETATTR2res.status field to ACL2_OK, and
fills in the GETATTR2resok.attr field with the file
object's current file attributes, as detailed in
<xref target="RFC1094"/>.</t>
            <t>Otherwise, GETATTR2res.status contains an error
status on failure and no other results are returned.</t>
          </section>
          <section anchor="implementation-3">
            <name>IMPLEMENTATION</name>
            <t>Refer to <xref section="2.3.5" sectionFormat="of" target="RFC1094"/> for details
about the content of the returned file attributes.</t>
          </section>
          <section anchor="errors-3">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL2ERR_IO</t>
              </li>
              <li>
                <t>ACL2ERR_STALE</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-4-access-check-access-permission">
          <name>Procedure 4: ACCESS - Check access permission</name>
          <section anchor="arguments-4">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct ACCESS2args {
    fhandle fh;
    unsigned int access;
};
]]></sourcecode>
          </section>
          <section anchor="results-4">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
const ACCESS2_READ = 0x1;       /* read data or readdir a directory */
const ACCESS2_LOOKUP = 0x2;     /* lookup a name in a directory */
const ACCESS2_MODIFY = 0x4;     /* rewrite existing file data or */
                                /* modify existing directory entries */
const ACCESS2_EXTEND = 0x8;     /* write new data or add directory entries */
const ACCESS2_DELETE = 0x10;    /* delete existing directory entry */
const ACCESS2_EXECUTE = 0x20;   /* execute file (no meaning for a directory) */

struct ACCESS2resok {
    fattr attr;
    unsigned int access;
};

union ACCESS2res switch (aclstat2 status) {
case ACL2_OK:
    ACCESS2resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-4">
            <name>DESCRIPTION</name>
            <t>The ACCESS procedure determines the access rights
that a user, as identified by the RPC credentials
in the request, has with respect to the file handle
specified by the ACCESS2args.fh field. The client
obtains this file handle using one of the NFS
version 2 LOOKUP, CREATE, MKDIR, SYMLINK procedures,
or the MOUNT service, as described in <xref target="RFC1094"/>.
The client encodes the set of permissions that are
to be checked in the ACCESS2args.access field.</t>
            <t>The following access permissions may be requested:</t>
            <dl>
              <dt>ACCESS2_READ</dt>
              <dd>
                <t>Read data from file or read a directory.</t>
              </dd>
              <dt>ACCESS2_LOOKUP</dt>
              <dd>
                <t>Look up a name in a directory (no meaning for non-directory objects).</t>
              </dd>
              <dt>ACCESS2_MODIFY</dt>
              <dd>
                <t>Rewrite existing file data or modify existing directory entries.</t>
              </dd>
              <dt>ACCESS2_EXTEND</dt>
              <dd>
                <t>Write new data or add directory entries.</t>
              </dd>
              <dt>ACCESS2_DELETE</dt>
              <dd>
                <t>Delete an existing directory entry (no meaning for non-directory objects).</t>
              </dd>
              <dt>ACCESS2_EXECUTE</dt>
              <dd>
                <t>Execute file (no meaning for a directory).</t>
              </dd>
            </dl>
            <t>If the ACCESS procedure is successful, the server
sets the ACCESS2res.status field to ACL2_OK. It
fills in the ACCESS2resok.attr field with the file
object's current file attributes, as detailed in
<xref target="RFC1094"/>. Lastly, it encodes the set of
permissions that the requesting user is granted
in the ACCESS2resok.access field.</t>
          </section>
          <section anchor="implementation-4">
            <name>IMPLEMENTATION</name>
            <t>In the NFS version 2 protocol, the only reliable way to
determine whether an operation is allowed is to try it
and see if it succeeded or failed. Using the ACCESS
procedure in the NFS_ACL version 2 protocol, a client can
ask the server to indicate whether or not one or more
classes of operations are permitted.</t>
            <t>In general, it is not sufficient for a client to attempt
to deduce access permissions by inspecting the uid, gid,
and mode fields in the file attributes, since the server
may perform uid or gid mapping or enforce additional
access control restrictions. It is also possible that the
NFS version 2 protocol server may not be in the same ID
space as the NFS version 2 protocol client. In these cases,
the NFS version 2 protocol client can not reliably perform
an access check with only current file attributes.</t>
            <t>The information returned by the server in response to an
ACCESS call is advisory only. It was correct at the exact
time that the server performed the checks, but not
necessarily afterwards. The server can revoke access
permission to a file object at any time.</t>
            <t>The NFS_ACL version 2 protocol client should use the
effective credentials of the user to build the
authentication information in the ACCESS request used
to determine access rights. It is the effective user
and group credentials that are used in subsequent read
and write operations.</t>
            <t>Many implementations do not directly support the
ACCESS2_DELETE permission. Operating systems like UNIX
may ignore the ACCESS2_DELETE bit if set on an access
request on a non-directory object. In these systems,
delete permission on a file is determined by the access
permissions on the directory in which the file resides,
instead of being determined by the permissions of the file
itself.  Thus, the bit mask returned for such a request
will have the ACCESS2_DELETE bit set to 0, indicating that
the client does not have this permission.</t>
            <t>The server should return a status of ACL2_OK if no
errors occurred that prevented the server from making
the required access checks.</t>
          </section>
          <section anchor="errors-4">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL2ERR_IO</t>
              </li>
              <li>
                <t>ACL2ERR_STALE</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-5-getxattrdir-get-named-attribute-directory">
          <name>Procedure 5: GETXATTRDIR - Get named attribute directory</name>
          <section anchor="arguments-5">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETXATTRDIR2args {
    fhandle fh;
    bool create;
};
]]></sourcecode>
          </section>
          <section anchor="results-5">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETXATTRDIR2resok {
    fhandle fh;
    fattr attr;
};

union GETXATTRDIR2res switch (aclstat2 status) {
case ACL2_OK:
    GETXATTRDIR2resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-5">
            <name>DESCRIPTION</name>
            <t><xref section="5.3" sectionFormat="of" target="RFC8881"/> defines a set of generic file attributes known
as "named attributes". The GETXATTRDIR procedure extends this facility
into the NFSv2 protocol.</t>
            <t>The GETXATTRDIR procedure obtains the file handle of the named attribute
directory associated with the file handle in the GETXATTRDIR2args.fh
field. This directory contains only objects of type NFREG.</t>
            <t>If the GETXATTRDIR procedure is successful, the server sets the
GETXATTRDIR2res.status field to ACL2_OK.
It fills in the GETXATTRDIR2resok.fh field with a file handle that
the client may use to look up the target file's named attributes.
It fills in the GETXATTRDIR2resok.attr field with the name attribute
directory's current file attributes, as detailed in <xref target="RFC1094"/>.</t>
            <t>Using the file handle returned in GETXATTRDIR2resok.fh, a client
can utilize the READDIR and LOOKUP procedures to obtain file handles
for the named attributes associated with the target file system object.</t>
            <t>If the target file object does not currently have a named attribute
directory associated with it and the GETXATTRDIR2args.create boolean
field is set to false, the server returns ACL2ERR_NOENT.
If the target file object does not currently have a named attribute
directory associated with it and the GETXATTRDIR2args.create boolean
field is set to true, the server attempts to create the named attribute
directory before returning a result.
If the target file currently has a named attribute directory
associated with it and the GETXATTRDIR2args.create boolean is set
to true, the server returns the file handle of that named attribute
directory.</t>
            <t>If the RPC user does not have read access to the target file, or
if the GETXATTRDIR operation is to create a named attribute directory
and the RPC user does not have permission to do so, the server returns
ACL2ERR_ACCES in the GETXATTRDIR2.status field.</t>
            <t>If the target file handle designates an object not of type NFREG or
NFDIR, the server returns the value ACL2ERR_IO in the GETXATTRDIR2.status
field. Neither named attributes nor named attribute directories have
their own named attributes.</t>
            <t>Note: This operation is equivalent to the NFSv4 OPENATTR operation as
specified in <xref section="16.17" sectionFormat="of" target="RFC7530"/> and <xref section="18.17" sectionFormat="of" target="RFC8881"/>.</t>
          </section>
          <section anchor="implementation-5">
            <name>IMPLEMENTATION</name>
            <t>Server implementers are free to choose not to implement this procedure.
In this case, the server returns the RPC-level error PROC_UNAVAIL.</t>
            <t>If the server implementation does implement the GETXATTRDIR procedure
but the shared file system containing the file object specified by the
file handle in the GETXATTRDIR2args.fh field does not support named
attributes, the server returns ACL2ERR_IO in the GETXATTRDIR2.status
field.</t>
          </section>
          <section anchor="errors-5">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL2ERR_PERM</t>
              </li>
              <li>
                <t>ACL2ERR_NOENT</t>
              </li>
              <li>
                <t>ACL2ERR_IO</t>
              </li>
              <li>
                <t>ACL2ERR_ACCES</t>
              </li>
              <li>
                <t>ACL2ERR_NOSPC</t>
              </li>
              <li>
                <t>ACL2ERR_ROFS</t>
              </li>
              <li>
                <t>ACL2ERR_STALE</t>
              </li>
            </ul>
          </section>
        </section>
      </section>
    </section>
    <section anchor="nfsacl-version-3">
      <name>NFS_ACL Version 3</name>
      <t>Version 3 of the NFS_ACL protocol is used in conjunction only with
version 3 of the NFS protocol.</t>
      <section anchor="data-types-inherited-from-nfs-version-3">
        <name>Data types inherited from NFS version 3</name>
        <section anchor="scalar-data-types">
          <name>Scalar Data types</name>
          <t>These are defined in <xref section="2.5" sectionFormat="of" target="RFC1813"/>.</t>
          <sourcecode type="xdr"><![CDATA[
typedef unsigned hyper uint64;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef unsigned long uint32;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef uint64 fileid3;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef uint32 uid3;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef uint32 gid3;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef uint64 size3;
]]></sourcecode>
          <sourcecode type="xdr"><![CDATA[
typedef uint32 mode3;
]]></sourcecode>
        </section>
        <section anchor="ftype3">
          <name>ftype3</name>
          <t>The enumeration "ftype3" represents the type of a file object.
This definition is further explained in <xref section="2.6" sectionFormat="of" target="RFC1813"/>.</t>
          <sourcecode type="xdr"><![CDATA[
enum ftype3 {
    NF3REG    = 1,
    NF3DIR    = 2,
    NF3BLK    = 3,
    NF3CHR    = 4,
    NF3LNK    = 5,
    NF3SOCK   = 6,
    NF3FIFO   = 7
};
]]></sourcecode>
        </section>
        <section anchor="specdata3">
          <name>specdata3</name>
          <sourcecode type="xdr"><![CDATA[
struct specdata3 {
    uint32     specdata1;
    uint32     specdata2;
};
]]></sourcecode>
          <t>The interpretation of the two words depends on the type of file
system object. For a block special (NF3BLK) or character special
(NF3CHR) file, specdata1 and specdata2 are the major and minor
device numbers, respectively. For all other file types, these
two elements should either be set to 0 or the values should be
agreed upon by the client and server.</t>
          <t>Further detail is available in <xref section="2.6" sectionFormat="of" target="RFC1813"/>.</t>
        </section>
        <section anchor="nfsfh3">
          <name>nfs_fh3</name>
          <t>The nfs_fh3 data type is a variable-length opaque object returned
by the NFS version 3 LOOKUP, CREATE, SYMLINK, MKNOD, LINK,
or READDIRPLUS procedures.
A client uses this handle during subsequent NFS operations
to reference the file. This definition comes from
<xref section="2.6" sectionFormat="of" target="RFC1813"/>.</t>
          <sourcecode type="xdr"><![CDATA[
NFS3_FHSIZE 64
]]></sourcecode>
          <t>The maximum size in bytes of the opaque file handle.</t>
          <sourcecode type="xdr"><![CDATA[
struct nfs_fh3 {
    opaque       data<NFS3_FHSIZE>;
};
]]></sourcecode>
          <t>To the client, a file handle is opaque. The client stores file
handles for use in a later request and can compare two file
handles from the same server for equality by doing a
byte-by-byte comparison, but cannot otherwise interpret the
contents of file handles. Further, if two file handles from the
same server are equal, they must refer to the same file, but if
they are not equal, no conclusions can be drawn.</t>
          <t>Servers may revoke access provided by a file handle at any
time. If the file handle passed in a call refers to a file
system object that no longer exists on the server or access for
that file handle has been revoked, the error, ACL3ERR_STALE,
is returned.</t>
        </section>
        <section anchor="nfstime3">
          <name>nfstime3</name>
          <t>NFS version 3's "nfstime3" structure represents the number of
seconds and nanoseconds since midnight January 1, 1970 Greenwich
Mean Time. Further details are in <xref section="2.6" sectionFormat="of" target="RFC1813"/>.</t>
          <sourcecode type="xdr"><![CDATA[
struct nfstime3 {
    uint32   seconds;
    uint32   nseconds;
};
]]></sourcecode>
        </section>
        <section anchor="nfsfattr3">
          <name>nfsfattr3</name>
          <t>This document refers to NFS version 3's file attribute structure
as "nfsfattr3". This is the same as the fattr3 structure described
in <xref section="2.6" sectionFormat="of" target="RFC1813"/>. A definition of the bit fields in
the "mode" element, which relate to traditional file system access
permissions, can also be found there.</t>
          <sourcecode type="xdr"><![CDATA[
struct fattr3 {
    ftype3     type;
    mode3      mode;
    uint32     nlink;
    uid3       uid;
    gid3       gid;
    size3      size;
    size3      used;
    specdata3  rdev;
    uint64     fsid;
    fileid3    fileid;
    nfstime3   atime;
    nfstime3   mtime;
    nfstime3   ctime;
};
]]></sourcecode>
        </section>
        <section anchor="postopattr">
          <name>post_op_attr</name>
          <t>The NFS version 3 "post_op_attr" data type returns file
attributes that are not directly involved in the requested
procedure. See <xref section="2.6" sectionFormat="of" target="RFC1813"/> for more
information.</t>
          <sourcecode type="xdr"><![CDATA[
union post_op_attr switch (bool attributes_follow) {
case TRUE:
    fattr3   attributes;
case FALSE:
    void;
};
]]></sourcecode>
          <t>The format of this data type appears to make returning file
attributes optional. However, server implementers are strongly
encouraged to make a best effort to return attributes whenever
possible, even when returning an error.</t>
        </section>
      </section>
      <section anchor="error-values">
        <name>Error Values</name>
        <t><xref section="2.5" sectionFormat="of" target="RFC1813"/> describes an enumerated type called
"nfsstat3" which provides a status code for NFS version 3 procedure
results.
A matching type called "aclstat3" is defined in this document
for the similar purpose of returning NFS_ACL version 3 procedure
status codes. The numeric values of these two types match up,
although aclstat3 omits some codes that are not relevant to the
NFS_ACL protocol.</t>
        <sourcecode type="xdr"><![CDATA[
enum aclstat3 {
    ACL3_OK             = 0,
    ACL3ERR_PERM        = 1,
    ACL3ERR_NOENT       = 2,
    ACL3ERR_IO          = 5,
    ACL3ERR_ACCES       = 13,
    ACL3ERR_INVAL       = 22,
    ACL3ERR_NOSPC       = 28,
    ACL3ERR_ROFS        = 30,
    ACL3ERR_DQUOT       = 69,
    ACL3ERR_STALE       = 70,
    ACL3ERR_BADHANDLE   = 10001,
    ACL3ERR_NOTSUPP     = 10004,
    ACL3ERR_SERVERFAULT = 10006,
    ACL3ERR_JUKEBOX     = 10008
};
]]></sourcecode>
        <t>These status codes carry the following meanings:</t>
        <dl>
          <dt>ACL3_OK</dt>
          <dd>
            <t>Indicates the call completed successfully.</t>
          </dd>
          <dt>ACL3ERR_PERM</dt>
          <dd>
            <t>Not owner. The operation was not allowed because the caller is either not a privileged user (root) or not the owner of the target of the operation.</t>
          </dd>
          <dt>ACL3ERR_NOENT</dt>
          <dd>
            <t>No such file or directory. The file or directory name specified does not exist.</t>
          </dd>
          <dt>ACL3ERR_IO</dt>
          <dd>
            <t>I/O error. A hard error (for example, a disk error) occurred while processing the requested operation.</t>
          </dd>
          <dt>ACL3ERR_ACCES</dt>
          <dd>
            <t>Permission denied. The caller does not have the correct permission to perform the requested operation. Contrast this with NFS3ERR_PERM, which restricts itself to owner or privileged user permission failures.</t>
          </dd>
          <dt>ACL3ERR_INVAL</dt>
          <dd>
            <t>An invalid or unsupported argument was specified for procedure.</t>
          </dd>
          <dt>ACL3ERR_NOSPC</dt>
          <dd>
            <t>No space left on device. The operation would have caused the server's file system to exceed its limit.</t>
          </dd>
          <dt>ACL3ERR_ROFS</dt>
          <dd>
            <t>Read-only file system. A modifying operation was attempted on a read-only file system.</t>
          </dd>
          <dt>ACL3ERR_DQUOT</dt>
          <dd>
            <t>Resource (quota) hard limit exceeded. The user's resource limit on the server has been exceeded.</t>
          </dd>
          <dt>ACL3ERR_STALE</dt>
          <dd>
            <t>Invalid file handle. The file handle given in the arguments was invalid. The file referred to by that file handle no longer exists or access to it has been revoked.</t>
          </dd>
          <dt>ACL3ERR_BADHANDLE</dt>
          <dd>
            <t>Illegal NFS file handle. The file handle failed internal consistency checks.</t>
          </dd>
          <dt>ACL3ERR_NOTSUPP</dt>
          <dd>
            <t>Operation is not supported.</t>
          </dd>
          <dt>ACL3ERR_SERVERFAULT</dt>
          <dd>
            <t>An error occurred on the server which does not map to any of the legal NFS version 3 protocol error values.  The client should translate this into an appropriate error. UNIX clients may choose to translate this to EIO.</t>
          </dd>
          <dt>ACL3ERR_JUKEBOX</dt>
          <dd>
            <t>The server initiated the request, but was not able to complete it in a timely fashion. The client should wait and then try the request with a new RPC transaction ID. For example, this error should be returned from a server that supports hierarchical storage and receives a request to process a file that has been migrated. In this case, the server should start the immigration process and respond to client with this error.</t>
          </dd>
        </dl>
      </section>
      <section anchor="server-procedures-1">
        <name>Server Procedures</name>
        <section anchor="procedure-0-null-no-operation-1">
          <name>Procedure 0: NULL - No Operation</name>
          <section anchor="arguments-6">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
void;
]]></sourcecode>
          </section>
          <section anchor="results-6">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
void;
]]></sourcecode>
          </section>
          <section anchor="description-6">
            <name>DESCRIPTION</name>
            <t>This is the usual NULL procedure with a void argument and void result.</t>
          </section>
          <section anchor="implementation-6">
            <name>IMPLEMENTATION</name>
            <t>It is important that this procedure do no work at all so that clients
can use it to measure the overhead of processing a service request.
By convention, the NULL procedure should never require any
authentication.
A server implementation may choose to ignore this convention, if
responding to the NULL procedure call acknowledges the existence
of a resource to an unauthenticated client.</t>
          </section>
          <section anchor="errors-6">
            <name>ERRORS</name>
            <t>Since the NULL procedure takes no argument and returns no
result, it can not return an NFS or NFS_ACL error status code.
However, some server implementations may return RPC errors
based on security or authentication policy settings.</t>
          </section>
        </section>
        <section anchor="procedure-1-getacl-retrieve-an-access-control-list-1">
          <name>Procedure 1: GETACL - Retrieve an Access Control List</name>
          <section anchor="arguments-7">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETACL3args {
    nfs_fh3 fh;
    unsigned int mask;
};
]]></sourcecode>
          </section>
          <section anchor="results-7">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETACL3resok {
    post_op_attr attr;
    secattr acl;
};

struct GETACL3resfail {
    post_op_attr attr;
};

union GETACL3res switch (aclstat3 status) {
case ACL3_OK:
    GETACL3resok resok;
default:
    GETACL3resfail resfail;
};
]]></sourcecode>
          </section>
          <section anchor="description-7">
            <name>DESCRIPTION</name>
            <t>The GETACL procedure retrieves Access Control List
information associated with the file system object
specified by the GETACL3args.fh field. The client
obtains this file handle using one of the NFS
version 2 LOOKUP, CREATE, MKDIR, SYMLINK, MKNOD,
or READDIRPLUS procedures, or the MOUNT service,
as described in <xref target="RFC1813"/>.</t>
            <t>The GETACL3args.mask field specifies which information
is to be returned in the response:</t>
            <ul spacing="normal">
              <li>
                <t>If the NA_ACL bit is set, the server fills in the
object's access ACL.</t>
              </li>
              <li>
                <t>If the NA_ACLCNT bit is set, the server fills in
the number of ACEs that are in the object's access ACL.</t>
              </li>
              <li>
                <t>If the NA_DFACL bit is set, the server fills in
the object's default ACL.</t>
              </li>
              <li>
                <t>if the NA_DFACLCNT bit is set, the server fills in
the number of ACEs that are in the object's default ACL.</t>
              </li>
            </ul>
            <t>If the GETACL procedure is successful, the server sets the
GETACL3res.status field to ACL3_OK. It fills in the
GETACL3resok.attr field with the file object's post
operation file attributes, as detailed in <xref target="RFC1813"/>.
Lastly, it fills in the GETACL3resok.acl field with two
counted arrays of Access Control Entries (ACEs).</t>
            <t>Otherwise, GETACL3res.status contains an error status
on failure and no other results are returned.</t>
          </section>
          <section anchor="implementation-7">
            <name>IMPLEMENTATION</name>
            <t>When GETACL3args.fh represents a file object that does
not currently have an ACL associated with it or does not
implement support for ACLs, the server responds by
returning a manufactured minimal NFS ACL that reflects
the current owner, group, and mode bits of the object
(see <xref target="acls-in-operation"/>).</t>
          </section>
          <section anchor="errors-7">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL3ERR_IO</t>
              </li>
              <li>
                <t>ACL3ERR_STALE</t>
              </li>
              <li>
                <t>ACL3ERR_BADHANDLE</t>
              </li>
              <li>
                <t>ACL3ERR_SERVERFAULT</t>
              </li>
              <li>
                <t>ACL3ERR_JUKEBOX</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-2-setacl-set-or-replace-an-access-control-list-1">
          <name>Procedure 2: SETACL - Set or replace an Access Control List</name>
          <section anchor="arguments-8">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct SETACL3args {
    nfs_fh3 fh;
    secattr acl;
};
]]></sourcecode>
          </section>
          <section anchor="results-8">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct SETACL3resok {
    post_op_attr attr;
};

struct SETACL3resfail {
    post_op_attr attr;
};

union SETACL3res switch (aclstat3 status) {
case ACL3_OK:
    SETACL3resok resok;
default:
    SETACL3resfail resfail;
};
]]></sourcecode>
          </section>
          <section anchor="description-8">
            <name>DESCRIPTION</name>
            <t>The SETACL procedure replaces the Access Control Lists
associated with the file system object specified by the
SETACL3args.fh field with the ACLs specified by the
SETACL3args.acl field.  The client obtains the file
handle using one of the NFS version 3 LOOKUP, CREATE,
MKDIR, MKNOD, SYMLINK, or READDIRPLUS procedures, or
the MOUNT service, as described in <xref target="RFC1813"/>.</t>
            <t>To remove extended access control from a file object, a client
uses SETACL to replace the object's ACL with a minimal NFS ACL
(see <xref target="acls-in-operation"/>).</t>
            <t>If the SETACL procedure is successful, the server sets
the SETACL3res.status field to ACL3_OK and fills in the
SETACL3resok.attr field with the file object's post
operation file attributes, as detailed in <xref target="RFC1813"/>.</t>
            <t>Otherwise, SETACL3res.status contains an error status
on failure and no other results are returned.</t>
          </section>
          <section anchor="implementation-8">
            <name>IMPLEMENTATION</name>
            <t>On success, the server does not send the reply until
the ACL change is durable locally.</t>
            <t>Changing a file object's ACL changes the object's mtime.
The mtime change is reflected in the attributes returned
in the SETACL response.</t>
            <t>A high-quality server implementation ensures that a
GETACL procedure running concurrently with a SETACL
procedure does not return partially updated (torn)
ACL contents. However, a failed SETACL may partially
change a file's ACLs.</t>
            <t>When SETACL3args.fh represents a file object that does
not implement support for ACLs, the server responds
by setting SETACL3res.status to ACL3ERR_NOTSUPP.</t>
            <t>When SETACL3args.acl does not contain at least the
minimal set of ACEs (as described in
<xref target="acls-in-operation"/>), the server responds by setting
SETACL3res.status to ACL3ERR_INVAL.</t>
          </section>
          <section anchor="errors-8">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL3ERR_PERM</t>
              </li>
              <li>
                <t>ACL3ERR_IO</t>
              </li>
              <li>
                <t>ACL3ERR_ACCES</t>
              </li>
              <li>
                <t>ACL3ERR_INVAL</t>
              </li>
              <li>
                <t>ACL3ERR_NOSPC</t>
              </li>
              <li>
                <t>ACL3ERR_ROFS</t>
              </li>
              <li>
                <t>ACL3ERR_DQUOT</t>
              </li>
              <li>
                <t>ACL3ERR_STALE</t>
              </li>
              <li>
                <t>ACL3ERR_BADHANDLE</t>
              </li>
              <li>
                <t>ACL3ERR_SERVERFAULT</t>
              </li>
              <li>
                <t>ACL3ERR_JUKEBOX</t>
              </li>
            </ul>
          </section>
        </section>
        <section anchor="procedure-3-getxattrdir-get-named-attribute-directory">
          <name>Procedure 3: GETXATTRDIR - Get named attribute directory</name>
          <section anchor="arguments-9">
            <name>ARGUMENTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETXATTRDIR3args {
    nfs_fh3 fh;
    bool create;
};
]]></sourcecode>
          </section>
          <section anchor="results-9">
            <name>RESULTS</name>
            <sourcecode type="xdr"><![CDATA[
struct GETXATTRDIR3resok {
    nfs_fh3 fh;
    post_op_attr attr;
};

union GETXATTRDIR3res switch (aclstat3 status) {
case ACL3_OK:
    GETXATTRDIR3resok resok;
default:
    void;
};
]]></sourcecode>
          </section>
          <section anchor="description-9">
            <name>DESCRIPTION</name>
            <t><xref section="5.3" sectionFormat="of" target="RFC8881"/> defines a set of generic file attributes known
as "named attributes". The GETXATTRDIR procedure extends this facility
into the NFSv3 protocol.</t>
            <t>The GETXATTRDIR procedure obtains the file handle of the named attribute
directory associated with the file handle in the GETXATTRDIR3args.fh
field. This directory contains only objects of type NF3REG.</t>
            <t>If the GETXATTRDIR procedure is successful, the server sets the
GETXATTRDIR3res.status field to ACL3_OK.
It fills in the GETXATTRDIR3resok.fh field with a file handle that
the client may use to look up the target file's named attributes.
It fills in the GETXATTRDIR3resok.attr field with the name attribute
directory's current file attributes, as detailed in <xref target="RFC1813"/>.</t>
            <t>Using the file handle returned in GETXATTRDIR3resok.fh, a client
can utilize the READDIR and LOOKUP procedures to obtain file handles
for the named attributes associated with the target file system object.</t>
            <t>If the target file object does not currently have a named attribute
directory associated with it and the GETXATTRDIR3args.create boolean
field is set to false, the server returns ACL3ERR_NOENT.
If the target file object does not currently have a named attribute
directory associated with it and the GETXATTRDIR3args.create boolean
field is set to true, the server attempts to create the named attribute
directory before returning a result.
If the target file currently has a named attribute directory
associated with it and the GETXATTRDIR3args.create boolean is set
to true, the server returns the file handle of that named attribute
directory.</t>
            <t>If the RPC user does not have read access to the target file, or
if the GETXATTRDIR operation is to create a named attribute directory
and the RPC user does not have permission to do so, the server returns
ACL3_ACCES in the GETXATTRDIR3.status field.</t>
            <t>If the target file handle designates an object not of type NF3REG or
NF3DIR, the server returns the value ACL3ERR_INVAL in the
GETXATTRDIR3.status field. Neither named attributes nor named attribute
directories have their own named attributes.</t>
            <t>Note: This operation is equivalent to the NFSv4 OPENATTR operation as
specified in <xref section="16.17" sectionFormat="of" target="RFC7530"/> and <xref section="18.17" sectionFormat="of" target="RFC8881"/>.</t>
          </section>
          <section anchor="implementation-9">
            <name>IMPLEMENTATION</name>
            <t>Server implementers are free to choose not to implement this procedure.
In this case, the server returns the RPC-level error PROC_UNAVAIL.</t>
            <t>If the server implementation does implement the GETXATTRDIR procedure
but the shared file system containing the file object specified by the
file handle in the GETXATTRDIR3args.fh field does not support named
attributes, the server returns ACL3ERR_NOTSUPP in the GETXATTRDIR3.status
field.</t>
          </section>
          <section anchor="errors-9">
            <name>ERRORS</name>
            <ul spacing="normal">
              <li>
                <t>ACL3ERR_PERM</t>
              </li>
              <li>
                <t>ACL3ERR_NOENT</t>
              </li>
              <li>
                <t>ACL3ERR_IO</t>
              </li>
              <li>
                <t>ACL3ERR_ACCES</t>
              </li>
              <li>
                <t>ACL3ERR_INVAL</t>
              </li>
              <li>
                <t>ACL3ERR_NOSPC</t>
              </li>
              <li>
                <t>ACL3ERR_ROFS</t>
              </li>
              <li>
                <t>ACL3ERR_STALE</t>
              </li>
              <li>
                <t>ACL3ERR_NOTSUPP</t>
              </li>
              <li>
                <t>ACL3ERR_SERVERFAULT</t>
              </li>
              <li>
                <t>ACL3ERR_JUKEBOX</t>
              </li>
            </ul>
          </section>
        </section>
      </section>
    </section>
    <section anchor="implementation-issues">
      <name>Implementation Issues</name>
      <section anchor="permission-issues">
        <name>Permission issues</name>
        <t>The NFS protocol, strictly speaking, does not
define the permission checking used by NFS servers. However, it
is expected that an NFS server will do normal operating system
permission checking using AUTH_UNIX style authentication as
the basis of its protection mechanism, or another stronger
form of authentication such as RPCSEC_GSS. With
AUTH_UNIX authentication, the server gets the client's
effective uid, effective gid, and groups on each call and
uses them to check permission. These are the so-called UNIX
credentials.</t>
        <t>Using uid and gid implies that the client and server share
the same uid list. Every server and client pair must have the
same mapping from user to uid and from group to gid. Since
every client can also be a server, this tends to imply that
the whole network shares the same uid/gid space. If this is
not the case, then it usually falls upon the server to
perform some custom mapping of credentials from one
authentication domain into another. A discussion of
techniques for managing a shared user space or for providing
mechanisms for user ID mapping is beyond the scope of this
specification.</t>
        <t>In POSIX-based operating systems, a particular user (on UNIX, the
uid 0) has access to all files, no matter what permission and
ownership they have. This superuser permission may not be
allowed on the server, since anyone who can become superuser
on their client could gain access to all remote files. A
POSIX-based NFS server by default maps uid 0 to a distinguished
value (for instance, UID_NOBODY), as well as mapping the groups
list, before doing its access checking. A server implementation
may provide a mechanism to change this mapping.</t>
      </section>
      <section anchor="duplicate-request-cache">
        <name>Duplicate Request Cache</name>
        <t>The typical NFS protocol failure recovery model
uses client time-out and retry to handle server crashes,
network partitions, and lost server replies. A retried
request is referred to as a duplicate of the original.</t>
        <t>When used in a file server context, the term idempotent can
be used to distinguish between operation types. An idempotent
request is one that a server can perform more than once with
equivalent results (though it may in fact change, as a side
effect, the access time on a file, say for READ). Some NFS
operations are obviously non-idempotent. They cannot be
reprocessed without special attention simply because they may
fail if tried a second time. A CREATE request, for example,
can be used to create a file for which the owner does not
have write permission. A duplicate of this request cannot
succeed if the original succeeded. Likewise, a file can be
removed only once.</t>
        <t>The side effects caused by performing a duplicate
non-idempotent request can be destructive. A duplicate
file truncation can result in lost writes. It is the
inherent stateless design of the NFS protocol on top
of an unreliable RPC transport that yields the
possibility of destructive replays of non-idempotent
requests. Even in an implementation of the NFS protocol
over a reliable connection-oriented transport,
a connection break with automatic reestablishment
requires duplicate request processing: the client
retransmits requests that were pending before the
connection loss, and the server needs to recognize
and deal with potential duplicate non-idempotent requests.</t>
        <t>Most NFS server implementations maintain a cache of
recent requests, called the duplicate request cache,
for recognizing duplicate non-idempotent requests. If
the server receives a request and recognizes it as a
duplicate of a recently completed request, the server
returns the original completion status instead of
processing the duplicate request again.</t>
        <t>A description of an early implementation of a
duplicate request cache can be found in <xref target="Juszczak"/>.</t>
        <t>For all versions of the NFS_ACL protocol, the SETACL
procedure is considered to be non-idempotent.</t>
      </section>
      <section anchor="caching-policies">
        <name>Caching Policies</name>
        <t>The NFS protocol does not define a policy for
caching on the client or server. In particular, there is no
support for strict cache consistency between a client and
server, nor between different clients.</t>
        <t>The NFS_ACL protocol does not mandate a specific caching
policy for ACLs or information retrieved via the ACCESS
procedure. However, a high-quality client implementation
that seeks good performance might choose to revalidate
cached access control information with the same regularity
that it invalidates normal file attributes.</t>
      </section>
    </section>
    <section anchor="xdr-protocol-definition">
      <name>XDR Protocol Definition</name>
      <t>This section contains a description of the core features of the
NFS_ACL protocol, version 2 and 3, expressed in the XDR language
<xref target="RFC4506"/>.</t>
      <t>This description is provided in a way that makes it simple to
extract into ready-to-compile form.  The reader can apply the
following shell script to this document to produce a
machine-readable XDR description of the NFS_ACL protocol.</t>
      <sourcecode type="sh"><![CDATA[
#!/bin/sh
grep '^ *///' | sed 's?^ /// ??' | sed 's?^ *///$??'
]]></sourcecode>
      <t>That is, if the above script is stored in a file called
"extract.sh" and this document is in a file called "spec.txt",
then the reader can do the following to extract an XDR
description file:</t>
      <sourcecode type="sh"><![CDATA[
sh extract.sh < spec.txt > nfs_acl.x
]]></sourcecode>
      <section anchor="code-component-license">
        <name>Code Component License</name>
        <t>Code components extracted from this document must include
the following license text.  When the extracted XDR code
is combined with other complementary XDR code which itself
has an identical license, only a single copy of the license
text need be preserved.</t>
        <sourcecode type="xdr"><![CDATA[
/// /*
///  * Copyright (c) 2024 IETF Trust and the persons
///  * identified as authors of the code.  All rights reserved.
///  *
///  * The authors of the code are:
///  * Oracle
///  *
///  * Redistribution and use in source and binary forms, with
///  * or without modification, are permitted provided that the
///  * following conditions are met:
///  *
///  * - Redistributions of source code must retain the above
///  *   copyright notice, this list of conditions and the
///  *   following disclaimer.
///  *
///  * - Redistributions in binary form must reproduce the above
///  *   copyright notice, this list of conditions and the
///  *   following disclaimer in the documentation and/or other
///  *   materials provided with the distribution.
///  *
///  * - Neither the name of Internet Society, IETF or IETF
///  *   Trust, nor the names of specific contributors, may be
///  *   used to endorse or promote products derived from this
///  *   software without specific prior written permission.
///  *
///  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS
///  *   AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
///  *   WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
///  *   IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
///  *   FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO
///  *   EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
///  *   LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
///  *   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
///  *   NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
///  *   SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
///  *   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
///  *   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
///  *   OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
///  *   IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
///  *   ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
///  */
///
/// const NFS_ACL_MAX_ENTRIES = 1024;
///
/// typedef unsigned int uid;
/// typedef unsigned short o_mode;
///
/// /*
///  * This is the format of an ACL which is passed over the network.
///  */
/// struct aclent {
///     int type;
///     uid id;
///     o_mode perm;
/// };
///
/// /*
///  * The values for the type element of the aclent structure.
///  */
/// const NA_USER_OBJ = 0x1;            /* object owner */
/// const NA_USER = 0x2;                /* additional users */
/// const NA_GROUP_OBJ = 0x4;           /* owning group of the object */
/// const NA_GROUP = 0x8;               /* additional groups */
/// const NA_CLASS_OBJ = 0x10;          /* file group class and mask entry */
/// const NA_OTHER_OBJ = 0x20;          /* other entry for the object */
/// const NA_ACL_DEFAULT = 0x1000;      /* default flag */
///
/// /*
///  * The bit field values for the perm element of the aclent
///  * structure.  The three values can be combined to form any
///  * of the 8 combinations.
///  */
/// const NA_READ = 0x4;                /* read permission */
/// const NA_WRITE = 0x2;               /* write permission */
/// const NA_EXEC = 0x1;                /* exec permission */
///
/// /*
///  * This is the structure which contains the ACL entries for a
///  * particular entity.  It contains the ACL entries which apply
///  * to this object plus any default ACL entries which are
///  * inherited by its children.
///  *
///  * The values for the mask field are defined below.
///  */
/// struct secattr {
///     unsigned int mask;
///     int aclcnt;
///     aclent aclent<NFS_ACL_MAX_ENTRIES>;
///     int dfaclcnt;
///     aclent dfaclent<NFS_ACL_MAX_ENTRIES>;
/// };
///
/// /*
///  * The values for the mask element of the secattr struct as well
///  * as for the mask element in the arguments in the GETACL2 and
///  * GETACL3 procedures.
///  */
/// const NA_ACL = 0x1;                 /* aclent contains a valid list */
/// const NA_ACLCNT = 0x2;              /* number of entries in the aclent list */
/// const NA_DFACL = 0x4;               /* dfaclent contains a valid list */
/// const NA_DFACLCNT = 0x8;            /* number of entries in the dfaclent list */
///
/// /*
///  * XDR data types inherited from the NFS version 2 protocol
///  */
///
/// enum ftype {
///     NFNON = 0,
///     NFREG = 1,
///     NFDIR = 2,
///     NFBLK = 3,
///     NFCHR = 4,
///     NFLNK = 5
/// };
///
/// const FHSIZE = 32;
/// typedef opaque fhandle[FHSIZE];
///
/// struct timeval {
///     unsigned int seconds;
///     unsigned int useconds;
/// };
///
/// struct fattr {
///     ftype        type;
///     unsigned int mode;
///     unsigned int nlink;
///     unsigned int uid;
///     unsigned int gid;
///     unsigned int size;
///     unsigned int blocksize;
///     unsigned int rdev;
///     unsigned int blocks;
///     unsigned int fsid;
///     unsigned int fileid;
///     timeval      atime;
///     timeval      mtime;
///     timeval      ctime;
/// };
///
/// /*
///  * ACL error codes; the numeric values match codes with the same
///  * name used in NFS version 2.
///  */
/// enum aclstat2 {
///     ACL2_OK = 0,
///     ACL2ERR_PERM = 1,
///     ACL2ERR_NOENT = 2,
///     ACL2ERR_IO = 5,
///     ACL2ERR_ACCES = 13,
///     ACL2ERR_NOSPC = 28,
///     ACL2ERR_ROFS = 30,
///     ACL2ERR_DQUOT = 69,
///     ACL2ERR_STALE = 70
/// };
///
/// /*
///  * NFS_ACL version 2 procedure arguments and results
///  */
///
/// struct GETACL2args {
///     fhandle fh;
///     unsigned int mask;
/// };
///
/// struct GETACL2resok {
///     fattr attr;
///     secattr acl;
/// };
///
/// union GETACL2res switch (aclstat2 status) {
/// case ACL2_OK:
///     GETACL2resok resok;
/// default:
///     void;
/// };
///
/// struct SETACL2args {
///     fhandle fh;
///     secattr acl;
/// };
///
/// struct SETACL2resok {
///     fattr attr;
/// };
///
/// union SETACL2res switch (aclstat2 status) {
/// case ACL2_OK:
///     SETACL2resok resok;
/// default:
///     void;
/// };
///
/// struct GETATTR2args {
///     fhandle fh;
/// };
///
/// struct GETATTR2resok {
///     fattr attr;
/// };
///
/// union GETATTR2res switch (aclstat2 status) {
/// case ACL2_OK:
///     GETATTR2resok resok;
/// default:
///     void;
/// };
///
/// struct ACCESS2args {
///     fhandle fh;
///     unsigned int access;
/// };
///
/// const ACCESS2_READ = 0x1;           /* read data or readdir a directory */
/// const ACCESS2_LOOKUP = 0x2;         /* lookup a name in a directory */
/// const ACCESS2_MODIFY = 0x4;         /* rewrite existing file data or */
///                                     /* modify existing directory entries */
/// const ACCESS2_EXTEND = 0x8;         /* write new data or add directory entries */
/// const ACCESS2_DELETE = 0x10;        /* delete existing directory entry */
/// const ACCESS2_EXECUTE = 0x20;       /* execute file (no meaning for a directory) */
///
/// struct ACCESS2resok {
///     fattr attr;
///     unsigned int access;
/// };
///
/// union ACCESS2res switch (aclstat2 status) {
/// case ACL2_OK:
///     ACCESS2resok resok;
/// default:
///     void;
/// };
///
/// /*
///  * This is the definition for the GETXATTRDIR procedure which applies
///  * to NFS Version 2 files.
///  */
/// struct GETXATTRDIR2args {
///     fhandle fh;
///     bool create;
/// };
///
/// struct GETXATTRDIR2resok {
///     fhandle fh;
///     fattr attr;
/// };
///
/// union GETXATTRDIR2res switch (aclstat2 status) {
/// case ACL2_OK:
///     GETXATTRDIR2resok resok;
/// default:
///     void;
/// };
///
/// /*
///  * XDR data types inherited from the NFS version 3 protocol
///  */
///
/// typedef unsigned hyper uint64;
/// typedef unsigned long uint32;
/// typedef uint64 fileid3;
/// typedef uint32 uid3;
/// typedef uint32 gid3;
/// typedef uint64 size3;
/// typedef uint32 mode3;
///
/// enum ftype3 {
///     NF3REG    = 1,
///     NF3DIR    = 2,
///     NF3BLK    = 3,
///     NF3CHR    = 4,
///     NF3LNK    = 5,
///     NF3SOCK   = 6,
///     NF3FIFO   = 7
/// };
///
/// struct specdata3 {
///     uint32     specdata1;
///     uint32     specdata2;
/// };
///
/// const NFS3_FHSIZE = 64;
///
/// struct nfs_fh3 {
///     opaque       data<NFS3_FHSIZE>;
/// };
///
/// struct nfstime3 {
///     uint32   seconds;
///     uint32   nseconds;
/// };
///
/// struct fattr3 {
///     ftype3     type;
///     mode3      mode;
///     uint32     nlink;
///     uid3       uid;
///     gid3       gid;
///     size3      size;
///     size3      used;
///     specdata3  rdev;
///     uint64     fsid;
///     fileid3    fileid;
///     nfstime3   atime;
///     nfstime3   mtime;
///     nfstime3   ctime;
/// };
///
/// union post_op_attr switch (bool attributes_follow) {
/// case TRUE:
///     fattr3   attributes;
/// case FALSE:
///     void;
/// };
///
/// /*
///  * ACL error codes; the numeric values match codes with the same
///  * name used in NFS version 3.
///  */
/// enum aclstat3 {
///     ACL3_OK = 0,
///     ACL3ERR_PERM = 1,
///     ACL3ERR_NOENT = 2,
///     ACL3ERR_IO = 5,
///     ACL3ERR_ACCES = 13,
///     ACL3ERR_INVAL = 22,
///     ACL3ERR_NOSPC = 28,
///     ACL3ERR_ROFS = 30,
///     ACL3ERR_DQUOT = 69,
///     ACL3ERR_STALE = 70,
///     ACL3ERR_BADHANDLE = 10001,
///     ACL3ERR_NOTSUPP = 10004,
///     ACL3ERR_SERVERFAULT = 10006,
///     ACL3ERR_JUKEBOX = 10008
/// };
///
/// /*
///  * NFS_ACL version 3 procedure arguments and results
///  */
///
/// struct GETACL3args {
///     nfs_fh3 fh;
///     unsigned int mask;
/// };
///
/// struct GETACL3resok {
///     post_op_attr attr;
///     secattr acl;
/// };
///
/// struct GETACL3resfail {
///     post_op_attr attr;
/// };
///
/// union GETACL3res switch (aclstat3 status) {
/// case ACL3_OK:
///     GETACL3resok resok;
/// default:
///     GETACL3resfail resfail;
/// };
///
/// struct SETACL3args {
///     nfs_fh3 fh;
///     secattr acl;
/// };
///
/// struct SETACL3resok {
///     post_op_attr attr;
/// };
///
/// struct SETACL3resfail {
///     post_op_attr attr;
/// };
///
/// union SETACL3res switch (aclstat3 status) {
/// case ACL3_OK:
///     SETACL3resok resok;
/// default:
///     SETACL3resfail resfail;
/// };
///
/// /*
///  * This is the definition for the GETXATTRDIR procedure which
///  * applies to NFS Version 3 files.
///  */
/// struct GETXATTRDIR3args {
///     nfs_fh3 fh;
///     bool create;
/// };
///
/// struct GETXATTRDIR3resok {
///     nfs_fh3 fh;
///     post_op_attr attr;
/// };
///
/// union GETXATTRDIR3res switch (aclstat3 status) {
/// case ACL3_OK:
///     GETXATTRDIR3resok resok;
/// default:
///     void;
/// };
///
/// /*
///  * Share the port with the NFS service.
///  */
/// const NFS_ACL_PORT = 2049;
///
/// program NFS_ACL_PROGRAM {
///     version NFS_ACL_V2 {
///         void
///             ACLPROC2_NULL(void) = 0;
///         GETACL2res
///             ACLPROC2_GETACL(GETACL2args) = 1;
///         SETACL2res
///             ACLPROC2_SETACL(SETACL2args) = 2;
///         GETATTR2res
///             ACLPROC2_GETATTR(GETATTR2args) = 3;
///         ACCESS2res
///             ACLPROC2_ACCESS(ACCESS2args) = 4;
///         GETXATTRDIR2res
///             ACLPROC2_GETXATTRDIR(GETXATTRDIR2args) = 5;
///     } = 2;
///     version NFS_ACL_V3 {
///         void
///             ACLPROC3_NULL(void) = 0;
///         GETACL3res
///             ACLPROC3_GETACL(GETACL3args) = 1;
///         SETACL3res
///             ACLPROC3_SETACL(SETACL3args) = 2;
///         GETXATTRDIR3res
///             ACLPROC3_GETXATTRDIR(GETXATTRDIR3args) = 3;
///     } = 3;
/// } = 100227;
]]></sourcecode>
      </section>
    </section>
    <section anchor="implementation-status">
      <name>Implementation Status</name>
      <aside>
        <t>This section is to be removed before publishing this document as an RFC.</t>
      </aside>
      <t>This section records the status of known implementations of the
protocol defined by this specification at the time of posting of this
Internet-Draft, and is based on a proposal described in
<xref target="RFC7942"/>. The description of implementations in this section is
intended to assist the IETF in its decision processes in progressing
drafts to RFCs.</t>
      <t>Please note that the listing of any individual implementation here
does not imply endorsement by the IETF. Furthermore, no effort has
been spent to verify the information presented here that was supplied
by IETF contributors. This is not intended as, and must not be
construed to be, a catalog of available implementations or their
features. Readers are advised to note that other implementations may
exist.</t>
      <section anchor="solaris-nfs-server-and-client">
        <name>Solaris NFS server and client</name>
        <t>Organization: Oracle</t>
        <t>URL:       <eref target="https://www.oracle.com">https://www.oracle.com</eref></t>
        <t>Maturity:  Complete.</t>
        <t>Coverage:  All procedures are implemented.</t>
        <t>Licensing: CDDL</t>
        <t>Implementation experience:</t>
      </section>
      <section anchor="linux-nfs-server-and-client">
        <name>Linux NFS server and client</name>
        <t>Organization:  The Linux Foundation</t>
        <t>URL:       <eref target="https://www.kernel.org">https://www.kernel.org</eref></t>
        <t>Maturity:  Complete.</t>
        <t>Coverage:  All procedures except GETXATTRDIR are implemented in
           both versions of the protocol.</t>
        <t>Licensing: GPLv2</t>
        <t>Implementation experience:  The initial Linux implementation
of the NFS_ACL protocol is described in <xref target="Gruenbacher"/>, and
subsequent modifications can be found in the Linux kernel
source code repository <xref target="Linux"/>.</t>
        <t><xref target="Gruenbacher"/> notes several minor differences between the
Linux and Solaris implementations of ACLs, and remarks that:
&gt; Solaris ACLs are based on an earlier draft of POSIX 1003.1e,
&gt; so its handling of the mask ACL entry is slightly different
&gt; than in draft 17 for ACLs with only four ACL entries. This
&gt; is a corner case that occurs only rarely, so the semantic
&gt; differences may not be noticeable.</t>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>An attacker can alter the content of an ACL as it transits
an open network, giving the attacker access to file content
that the ACL is supposed to protect.</t>
      <t>Therefore, implementations of NFS_ACL should protect the
integrity of ACL content when it transits a network. The
use of an integrity-preserving transport layer security
service, such as the GSS Kerberos integrity service, is
strongly recommended.</t>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>In accordance with <xref section="13" sectionFormat="of" target="RFC5531"/>, the editor
requests that IANA update the entry for the NFS ACL
service in the RPC Program Numbers registry to add
the current document as a Reference.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC4506">
          <front>
            <title>XDR: External Data Representation Standard</title>
            <author fullname="M. Eisler" initials="M." role="editor" surname="Eisler"/>
            <date month="May" year="2006"/>
            <abstract>
              <t>This document describes the External Data Representation Standard (XDR) protocol as it is currently deployed and accepted. This document obsoletes RFC 1832. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="67"/>
          <seriesInfo name="RFC" value="4506"/>
          <seriesInfo name="DOI" value="10.17487/RFC4506"/>
        </reference>
        <reference anchor="RFC5531">
          <front>
            <title>RPC: Remote Procedure Call Protocol Specification Version 2</title>
            <author fullname="R. Thurlow" initials="R." surname="Thurlow"/>
            <date month="May" year="2009"/>
            <abstract>
              <t>This document describes the Open Network Computing (ONC) Remote Procedure Call (RPC) version 2 protocol as it is currently deployed and accepted. This document obsoletes RFC 1831. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5531"/>
          <seriesInfo name="DOI" value="10.17487/RFC5531"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC7942">
          <front>
            <title>Improving Awareness of Running Code: The Implementation Status Section</title>
            <author fullname="Y. Sheffer" initials="Y." surname="Sheffer"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <date month="July" year="2016"/>
            <abstract>
              <t>This document describes a simple process that allows authors of Internet-Drafts to record the status of known implementations by including an Implementation Status section. This will allow reviewers and working groups to assign due consideration to documents that have the benefit of running code, which may serve as evidence of valuable experimentation and feedback that have made the implemented protocols more mature.</t>
              <t>This process is not mandatory. Authors of Internet-Drafts are encouraged to consider using the process for their documents, and working groups are invited to think about applying the process to all of their protocol specifications. This document obsoletes RFC 6982, advancing it to a Best Current Practice.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="205"/>
          <seriesInfo name="RFC" value="7942"/>
          <seriesInfo name="DOI" value="10.17487/RFC7942"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC1094">
          <front>
            <title>NFS: Network File System Protocol specification</title>
            <author fullname="B. Nowicki" initials="B." surname="Nowicki"/>
            <date month="March" year="1989"/>
            <abstract>
              <t>This RFC describes a protocol that Sun Microsystems, Inc., and others are using. A new version of the protocol is under development, but others may benefit from the descriptions of the current protocol, and discussion of some of the design issues.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1094"/>
          <seriesInfo name="DOI" value="10.17487/RFC1094"/>
        </reference>
        <reference anchor="RFC1813">
          <front>
            <title>NFS Version 3 Protocol Specification</title>
            <author fullname="B. Callaghan" initials="B." surname="Callaghan"/>
            <author fullname="B. Pawlowski" initials="B." surname="Pawlowski"/>
            <author fullname="P. Staubach" initials="P." surname="Staubach"/>
            <date month="June" year="1995"/>
            <abstract>
              <t>This paper describes the NFS version 3 protocol. This paper is provided so that people can write compatible implementations. This memo provides information for the Internet community. This memo does not specify an Internet standard of any kind.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1813"/>
          <seriesInfo name="DOI" value="10.17487/RFC1813"/>
        </reference>
        <reference anchor="RFC7530">
          <front>
            <title>Network File System (NFS) Version 4 Protocol</title>
            <author fullname="T. Haynes" initials="T." role="editor" surname="Haynes"/>
            <author fullname="D. Noveck" initials="D." role="editor" surname="Noveck"/>
            <date month="March" year="2015"/>
            <abstract>
              <t>The Network File System (NFS) version 4 protocol is a distributed file system protocol that builds on the heritage of NFS protocol version 2 (RFC 1094) and version 3 (RFC 1813). Unlike earlier versions, the NFS version 4 protocol supports traditional file access while integrating support for file locking and the MOUNT protocol. In addition, support for strong security (and its negotiation), COMPOUND operations, client caching, and internationalization has been added. Of course, attention has been applied to making NFS version 4 operate well in an Internet environment.</t>
              <t>This document, together with the companion External Data Representation (XDR) description document, RFC 7531, obsoletes RFC 3530 as the definition of the NFS version 4 protocol.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7530"/>
          <seriesInfo name="DOI" value="10.17487/RFC7530"/>
        </reference>
        <reference anchor="RFC8881">
          <front>
            <title>Network File System (NFS) Version 4 Minor Version 1 Protocol</title>
            <author fullname="D. Noveck" initials="D." role="editor" surname="Noveck"/>
            <author fullname="C. Lever" initials="C." surname="Lever"/>
            <date month="August" year="2020"/>
            <abstract>
              <t>This document describes the Network File System (NFS) version 4 minor version 1, including features retained from the base protocol (NFS version 4 minor version 0, which is specified in RFC 7530) and protocol extensions made subsequently. The later minor version has no dependencies on NFS version 4 minor version 0, and is considered a separate protocol.</t>
              <t>This document obsoletes RFC 5661. It substantially revises the treatment of features relating to multi-server namespace, superseding the description of those features appearing in RFC 5661.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8881"/>
          <seriesInfo name="DOI" value="10.17487/RFC8881"/>
        </reference>
        <reference anchor="Gruenbacher">
          <front>
            <title>POSIX Access Control Lists on Linux</title>
            <author initials="A." surname="Grünbacher" fullname="Andreas Grünbacher">
              <organization>SuSE Labs</organization>
            </author>
            <date year="2003" month="January"/>
          </front>
          <seriesInfo name="Proceedings" value="of the FREENIX Track: 2003 USENIX Annual Technical Conference, pp. 259-272"/>
          <seriesInfo name="ISBN" value="1-931971-11-0"/>
        </reference>
        <reference anchor="Juszczak">
          <front>
            <title>Improving the Performance and Correctness of an NFS Server</title>
            <author initials="C." surname="Juszcak" fullname="Chet Juszcak">
              <organization>Digital Equipment Corporation</organization>
            </author>
            <date year="1989" month="January"/>
          </front>
          <seriesInfo name="USENIX" value="Conference Proceedings, USENIX Association, Berkeley, CA, pp. 53-63"/>
        </reference>
        <reference anchor="IEEE">
          <front>
            <title>IEEE 1003.1e and 1003.2c: Draft Standard for Information Technology-- Portable Operating System Interface (POSIX)-- Part 1: System Application Program Interface (API) and Part 2: Shell and Utilities, draft 17</title>
            <author>
              <organization>Institute of Electrical and Electronics Engineers</organization>
            </author>
            <date year="1997" month="January"/>
          </front>
        </reference>
        <reference anchor="POSIX">
          <front>
            <title>IEEE Std 1003.1-2001 (Open Group Technical Standard, Issue 6), Standard for Information Technology-- Portable Operating System Interface (POSIX)</title>
            <author>
              <organization>Institute of Electrical and Electronics Engineers</organization>
            </author>
            <date year="2001"/>
          </front>
          <seriesInfo name="ISBN" value="0-7381-3010-9"/>
        </reference>
        <reference anchor="Linux" target="https://www.kernel.org">
          <front>
            <title>Linux kernel source code</title>
            <author>
              <organization/>
            </author>
            <date>n.d.</date>
          </front>
        </reference>
        <reference anchor="OpenSolaris" target="https://github.com/kofemann/opensolaris">
          <front>
            <title>Archived OpenSolaris source code</title>
            <author>
              <organization/>
            </author>
            <date>n.d.</date>
          </front>
        </reference>
        <reference anchor="I-D.ietf-nfsv4-posix-acls">
          <front>
            <title>POSIX Draft ACL support for Network File System Version 4, Minor Version 2</title>
            <author fullname="Rick Macklem" initials="R." surname="Macklem">
              <organization>FreeBSD Project</organization>
            </author>
            <date day="8" month="January" year="2026"/>
            <abstract>
              <t>   This document proposes four new optional file attributes for NFSv4.2
   to support POSIX ACLs conforming to the withdrawn POSIX 1003.1e draft
   17.  Although never ratified, POSIX ACLs are implemented in widely
   deployed operating systems.  Existing attempts to map between NFSv4
   and POSIX ACL models have been unsuccessful due to semantic
   incompatibilities.  These new attributes allow servers to expose
   POSIX ACLs directly, avoiding lossy mapping.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-nfsv4-posix-acls-01"/>
        </reference>
        <reference anchor="RFC1833">
          <front>
            <title>Binding Protocols for ONC RPC Version 2</title>
            <author fullname="R. Srinivasan" initials="R." surname="Srinivasan"/>
            <date month="August" year="1995"/>
            <abstract>
              <t>This document describes the binding protocols used in conjunction with the ONC Remote Procedure Call (ONC RPC Version 2) protocols. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1833"/>
          <seriesInfo name="DOI" value="10.17487/RFC1833"/>
        </reference>
      </references>
    </references>
    <?line 2495?>

<section anchor="source-material">
      <name>Source Material</name>
      <t>The on-the-wire protocol described here is intended to
match existing de facto implementations of NFS_ACL.</t>
      <t>The source for the XDR specification provided in this
document is the nfs_acl.x file as found in published
versions of the OpenSolaris source code base <xref target="OpenSolaris"/>,
an open source descendant of Solaris.</t>
      <t>However, there are a few changes to the protocol as it
was originally described in the OpenSolaris source code
base.</t>
      <section anchor="redaction-of-nfsacl-version-4">
        <name>Redaction of NFS_ACL Version 4</name>
        <t>Version 4 of NFS_ACL is described in the original nfs_acl.x source
file this way:</t>
        <ul empty="true">
          <li>
            <t>This is a transitional interface to enable Solaris NFSv4
clients to manipulate ACLs on Solaris servers until the
spec is complete enough to implement this inside the
NFSv4 protocol itself.  NFSv4 does handle extended
attributes in-band.</t>
          </li>
        </ul>
        <t>Because the two non-NULL procedures in this version of the NFS_ACL
protocol were used only as part of a Solaris a prototype and there
are no other implementations of NFS_ACL version 4, it is not included
in the protocol description appearing in this document.</t>
      </section>
      <section anchor="extension-of-nfsacl">
        <name>Extension of NFS_ACL</name>
        <t>Extension of this legacy protocol is out of scope for an
Informational document whose purpose is to describe existing
implementations.</t>
      </section>
      <section anchor="code-compilation-requirements">
        <name>Code Compilation Requirements</name>
        <t>The original nfs_acl.x file that appears in the OpenSolaris code
base did not compile using the widely-available rpcgen tool).</t>
        <ul spacing="normal">
          <li>
            <t>The file does not include a definition of the ACL2_OK or
ACL3_OK constants used in definitions of result unions.</t>
          </li>
          <li>
            <t>The file does not include definitions of NFS protocol elements
that are shared with the NFS_ACL protocol, such as fhandle and
post_op_attr.</t>
          </li>
        </ul>
        <t>The XDR specification provided in this document rectifies those
omissions to provide a complete and compilable XDR language
description of the NFS_ACL protocol.</t>
      </section>
    </section>
    <section numbered="false" anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>The editor is grateful to
Bill Baker,
Wim Coekaerts,
Andreas Gruenbacher,
Rick Macklem,
Greg Marsden,
Martin Thomson,
Rob Thurlow,
and
Jim Wright
for their input and support.</t>
      <t>Special thanks to
Area Director
Gorry Fairhurst,
NFSV4 Working Group Chairs
Brian Pawlowski
and
Christopher Inacio,
and
NFSV4 Working Group Secretary
Thomas Haynes
for their patience, guidance, and oversight.</t>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA+1923Lb2JbY+/4KjDpVbXeRtCXabbd8ps/QEm3ztCxpRKnd
namJCyJBCSMS4AFAyWrHU/mNvOVD8pT8Sb4k67ovAEjJ7ksmM8dV57QIYN/W
Xnvd19rdbtdUaTVPdqOt08skOkyqm7y4il6l8yQa35ZVsogGk0lSltFenlVF
Po8O0rKKjou8yif5fMvE5+dFcg3ND1+No8HegfdqElfJRV7c7kZpNsuNmeaT
LF7AUNMinlXdNKlm3WxWXj/B/+/Gk3n38Y5ZprvRP5V5URXJrOxE5e2C/4DG
i3i5TLOLfzbl6nyRlmUKM7pdQn+j4ekrky6L3agqVmW18/jxd9BTWcXZ9H08
zzP45DYpDcyyb+IiiWG275LzCF5Ho6xKiiypotMizsoljLtlEAIXRb5a4qpa
APJjUuDY0ZMtc5Xcwuvprom6EQAA/wMwMNdJtkrgYXTPbqKIF7L1Dj6CJUav
sR0+X8TpHJ4TmP4BIdbLiwt8EReTS3hxWVXLcvfRI/wOH6XXSU8/e4QPHp0X
+U2ZPKIeHmHLi7S6XJ1D28nlanI1T66T4lHaneom4Cdz2Lmy8rp3n/a4eS/N
/UaP1m1p77JaQJcmXlWXeYFwgu6jaLaazxkX9rDn6AC7pjeAYvA0maZVzg9g
IXGW/hJXACvY6myaLBP4v6yit5N8BWgJKHaWpVUyjcYVTj3KZ9FgkRTpJKav
EgbjJJnTFP/BWw7svTFZXixggGvas5NXe0+ePv5W/nz6tL+9awxicPjN9uPv
nuifz7f78uezp/3H8ufz58+38c/XxSrJzuPJZYLrh39y4I6PxqOf2k4XTD+D
P7LVB/rcgo7+pVm5Gw160Ov//p/Sq7xheA6yKWB42fIeALkbjVfjYXQQn5f0
cArA2o2+7cKJ6dODEmCWlLhYHW8LzvMkgf3ILsotwAiAbAWE4tXJcHgI04dj
M7najbCD6GxMjwZZtorn0WkyucxgA+a4tllSJNkk6UTLZS/aefpdd+fZzpaM
MBq/PNyNtrvf9be/e7bd3d7uPoY3f1mVv0x+ia8CkI0WyyK/xgOCczhOCtoU
6JjO8l5eFMmkyhCeMM04wyMZjZNCcasFkns9Him+CqC4dwkkIXxB4NtPAf1h
ScO/rtLlApAQBwWqQdjpgRSW8d3z79aBlAGF0HSgiTw4dywoyzKfpNR5J3qZ
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
rM081kpBCEBGBr8Xa+bgpXu98PHiFkqBW6bva/M8kcfYCXSgIgoGGGAThyGI
NPfGELQb/15oQn6eYN909WT891Rcf8nvTkanwyaqQCt2Faxphh6jGj5KM/Ra
1VoJ7fkKhS6UsK0Ehj9aj3wnSKdgHQKT82rxpkSdifOLE7xutD9VP3cQqU70
HG1na1gCU7MlWfV9e2wnWs5XYQ9WdN3UE1UcIWm/xXmiFugm8VIAMfUKyD+i
xgtL1IDKTbKKfwvF4//8qYVPfu/akUmo3lLtRGvaBtQRp+FwX8hCc19D2kj5
vb8V0iM/qaEhEhteipcFxOZWwoTagd87PA3QH5o7mSFxZn/2f1C/jW72X+k8
fJppLW53z4M60Jkw6dw0D9uzdqRbUraQEy70U+aWN1frts5wyskOaNJMZ/l3
n34HsomN6yF5UlzbexJJIcXdTOMDvwAMZyG3Jh2YNmEBkYhdaa5sEftP8ykK
Z2sH8wYi+dPlNnjDGH+YIE+W/YYaphNWsAiFJgoUkfj2c9itGZAPSWWK2GkC
CipbMfx5lpMkAxUut04/djRisVRVuGSSHY2K2EeL92GOMpO12QXB9GIDdT3U
IEpaBPr4TTyFzyv1vTH5nSSR58pAQw10Xiwn5ykFQ12kGMjPOQ6DwLRSH9Uq
fWw78Xy00pv56wqj9M6TGVr8pT4Wh13d+vMVA93Hj3+msmz9PkUVjpjeaDEJ
0o/bG2olu1IMlVgfT9bDM5ilRSk57r5PVv0vAc6YGiBb/UishMecNsaq/XvM
Z0En0fHJ0ev3Z4eDHwejAxt7zM3bNl3wwW36YONWw46iTaleUpCKAlJAjlhr
kNSiVejWOdjONRaOgIQrwLWSJ0y88Jwo1/ee4KJWJZXnFLsrjOPhBNrRMIgm
LbX2V1yyReJWnLUZWnPyCWWdg0ar1fYmsXj1vP11VsLSBdIbzzPtaiT6Vidb
FY4Y0V9XMc0Dw8jDRBDKcbDyoSQkrjuVnWioQVB+1cz7blMrjSO7oeFsMSJW
QV2xsAvrLDDNj5ii9tjJRYEvJUhRnsnaYAwYWwuDQ1+rmICWGhHEnD9AEiZ9
+LbTcXbNc1EA6+GsnxNK4amnOjImArPJKOYSnYgrYHmsdqqHGVtIEJSETKlj
+qGaybz8ey1q0DCFWovhhvmJu9kFpfgzNXam1lN8eHQ6Pjs+/qxOdzZ0Ks5o
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
q2dTdxaLl7jD5b47Ef1AP7GoXccHZ56TjlLu/SrixLVVFFsVtjoaW1VxaGdK
5QLiUpzbslDV7dvKYZh7HWssV/NeyoN821IYmIqTpLhrVeIyAqRwiFezpHHu
FPx86qQF/8Md+ZM3sF8vMfeQo1PT9Umgw358z3+EZcST0o8Wp6tNOeMTbYnz
uJKMTL3DFbVkvIuIzspNXmtr78OMXRoiZXJr1CzgxjQnjckgWLrnt138r3SZ
lpimiaKQXKTjrgiz9IPEHA12VRKh+jecRj4HfG2dzC+qz8/486OLTXF+dGBv
+cKjQkO67GqYdODc0pmptD43Zchz4yynqN75im3JfBVcNC3iGzTYjuXuPjSy
BN4SrT4x5UJp/qaxr4TcNj3N4PLf403OUgyZ3UGuZkrcQjlF26vlTtdyvF0i
Nd5x28i8rudVs4QoOftanIoksI5JXVS1IzK4mH5YFaf/NddtoVf3KYtjtAoO
RezF2T2r4riiOMYVxYlCwllqStq9KIA7rzT3OpsMa+Ho06y1Do7Wrenfrw5O
/751cPp3FcLp36cSTg0C0cCnm+4uVedW5utpUDizJUA74qUp8F6ahA0x7oJp
X+FpOn06dJzIWXyOMTsrtgcULcRTFuXV5OkT5XQVeUhkZHLq1eNxEoxfjQdE
VKG8thbPhXtmK/GQoMrPXK0d7yGqFPLQylR++R0Wd2nGtsaOSNnuT35skS2o
r+M9XbQ+bamts8zL6n2+fO8KJocse8v/YMsTBlQTrMdSB3VjrIcyza7z+bWf
SyvRVC4qoxeNKU9nHcIRD6HACs976209u1v86VpfC/l83Bzfc7yXdbmcnpwN
d50Lh6GqH7/gb14NDsbDNnfLKcWP4XRc7VYLpHi5TGI+uIv4yjcW1sGWL/kM
+Gn8a+wbgONAu+e3BsN9VkV8wTUyaAAQiZFJ8w0gnCzFHkE3ElZlwQGMRlx0
+L5cqtbiWTMlRpq1WS699CPJpWHlpVANvV/dJUBJtBD0P7P2klcQ0dy3ClP/
d6jC5M/j11VhiudhHab+71OHqe/qMPXRF+z/82sy9W1NJvtyO3zJpZn05U74
cnTkd/s0fMnmVtttv9YULz10/e7UR8VqTvbt8/At1XSyb/u15XBpJ33rFXhy
Uop9+6zW9uVg/83gcJ+++Hu8r+dxAxxcpDKyHzyp9T88+XF4oqX+8YNvww/+
cvbD8OXRT14Pz39dqSncYIMXD3KAmiS+oGCI4vWcLtFzvsc5R6W6nW8WqAqL
N9HNjBKRd55QhSM7AkcSqmGarnC0NwpP2WT/oMjz6qFGy5Eu5F/BrFdBqpoU
1GByCPg7lbbq29JWo0dHQv1AyvFKWz0I7nL2i1U99Mte4eBeOZyA4bWuakNJ
q9PL37yiFacwc55dKsHkWnYVccAJaRyrh1c+YhwM+Tt5u4rGznpTkFya0ocq
nm++Vde7LHWVidE58UobIZa5fZrlhW+rNwFJ2FSLq4a6ZEnh2mp3V+Xi0lb1
slyW2KwvyzWQ0GoKhwzOzf0rdTmqReNIkaEHVIvrISMjTcor3XUqMW9fl64q
EX9zr9pdjhIS4eDtaRZU9TTA+5T0sm0+t5DXfep4NSg0zhwOyYXkfW+c/Uyj
B0CkQrVDriAGcerWhTXVSDz0f+Q7wzyPSQhGR/AZ3Ws18cIN4XNmz/UiXnJ8
p16EHLkVBcIHuym4a5YzwjIAYjmkK7ZY0brke1SpVBVIpUUO5xdfCJXDGEB7
0WRYSKvWCTwZUoZsjYNJ2TcbsYrX52lImc1dQcuJ5SJyZ7yyJYp+xrOBSgoe
jLi8JGrVXNdN7JziGYWEe6NolAtmKqCrmOYfs7g62mdTrSXhtCTJhFdrqxfZ
x1UJ/NrqsudldJkCNhQgeOK1f2hDiy84exAIckIlmW04INFkZgdq3KG+LF4v
0guSkuul1P24IJ4d38+Lz9MFtyKlRzun4SndmSDLQJNQE13o36rg/a0K3r/V
KngV6LBUAy/YYlcbz2yqjccW/8Kqa80Seea+JfK0U6QfHDJr7l8cL/oDi+P1
vUhX9Rj8NsXx+n6oa2BV2VAjr9EDstr1fdTL6vVbAmT7LQGy/VpZvf762Nja
VOS//2YL7fX/6AxN9b2t97qtKflj2hM31Tp+WlvS34rv/YctvtdfE77c31B8
r3/fAklIVdzt5vcMFxYk9TInW2rw6RQaVfiMVOGLfkUVPh8mf1QVvv5nVvKp
B+bepwqf2VT+J4gjc0V51lXhqxfyioIqfBy0vq4K37oLeO4oBtYMVFObUDc0
GXq/nQrabTP7eU9VU/qDKvhtkg2+tILfXVKBJwSMP1sIGH+hEDC+SwgYf5EQ
8IdXA+x/QTXA/m9eDbARpqPVACVIxwoOGyUG05QY1pR6sBLDv7sigca12cQD
1xUJ/EN4YLNe4B/Gmv5WL/DfY73Az5UyPlNgwMDCsIqfj69yqMLL8RqTQ2rp
0o9aag+aO2sPchWOz6k9qLM2G2dNfpL1goiLmG/KJV6EvOdy6XoAsRHzzpPh
fnrlCH8fMaf/u6X7bhJ0flW6byDt1Hu+y57hd/LZRo3aDP79Zf32/ZiF9T39
gVm//V+X9dv/zdN+N+rNmzJu+/8W0n43SC+/WdqvyjCflfZrofO3tN8G9v+a
tF8XnvH/Ju33Xiv4/z3tt22Rf0v7vWfab39tzm//N8357duk3/69sn69CDhn
BF0ztc9K/DX1xF/s/G+Jv/9BE3/7v1Hib/167jVnaUP2b5su42X//ua6TV2X
0Zie+2sy0Sjc2VFZrjhmwo/ZS+Xp6WWYEdyJOJAOS3UtE6qp1HEmc5bGCYwe
MaNAJKnQSBuMHfJm+Op6WqHPLPmwZBsFmxAy7+OIalFReEOBKm1eKwJm2sek
K+HPTt+8p8igsrpFeSz0dsds4DqPy5QEYTS244rlPC8SNBak5YIvZszYQMTB
60lhKEIRQwjCTrmQVonHbjzce/96PO5F7zDl2k0mbBFg6YUW69R7LL06cVQA
0f3EUoiRrdVGGVB0FydHPWRTIymGHBHIJf38YmqnNj+bxs+7EnhO1dS8ym9W
PMWKiTQe/BdpQqoWH08Md9mcTAoIwJStg63nGKkaDeGttSRRNh63XcZA2Slv
TSk9Z7hpeUaynmplPJ0MPeRqdfD0AuP2KDjDJDSKV/NQ8240HEpip0TRYzJ7
6/SKm8scQ/uSikJqaDFe7hEM/wjhQKGbktZGAUBGw4ItTc5QEqKQIIoJQ2WD
0mC9Xa9yoyGvHDgPQKDiZVKXchZU4qMl51mjJuA0X6BIL0FyhK2U45SW0B+X
qZsZQO7LLMVoHk5HibNYLI1CugnAHJGaFxq9ep1imI2xJ8ImWBbRaN/OM8Vo
sNtcxJ1yki8TTSlRpqrBP8i6jo/Go5+6EpZSr+yHug1Z7SYrTGvg2GtYAmIn
gdUgBjx+yGKpleIQ95GJlJTJuEDhGIMU4yDCGA+HdzExZkEixonGDNwkKeoR
wa5Yp9Hg8WALtdhonN3mVAo2l9TJCcXpaJeGGwGeK2JSsNQF2e+CRaAnQUoC
A7UcGB9YHm3ETFRxdsMulHQsHnPq5JQLFa/S8hK4IstqFP6N5QTjDP0ZZ6N9
YCUvj/Z/fkgK6k2CpKO0G4rrY+pi8Oh2VHfg5Fckl34tPXiG+NYqSXDpVc6S
QeeFIhKTJjLJ0gGSkaUCxQqIDBWpPZE4xD0gcAmzJxBVKXLRZ1PWpA9CY07n
H72oc6aEWoA2XSRdvLdAArMw9jJXmUOLgRYxAK3sGD3+hIkV5/Bhu3leVk6w
IFKIS+cgm6mtKsnWdxs7TArU1C5K/bpFCicwnquhd2WzYVmKkimhofuDxEZg
9UcsvL5Y5pWW+D2XypyoQ7idhx2rbjBC00m4lMLTo0B224M/4zyT6E4bN4qY
rPRpwdF4qDkgvlMxEU+8VvfJA0kLStkyg5aGGAQ+3uoOQwKrWwp742XpCUD/
ha2oCScLOpiJr+5hj2/txgihWk3i/Pw6zVfl/JbqeLq1Eae71Vzsc8y8khhH
0VQRGbQCAxKMjPk48wMvReSW7p4lBywqhrjTBKMJUTxKwx2Iy9EFDPv5Fkay
qXWfrO5IG41fugqgnKZgRSziiFxd1efhgzo6EcbxVvKCjZSW1pAbxTZXcroX
HaRXCTvQZCo8T8PezKkYDGG7tWQnHmLeuFKzEc5tHWHmJnZeJtwNf3qUWZ6w
1Tq9ToLlsCoAr7KJ3kWeCXYhNtEBJHj4lWwNFarhmgDQxxyxidXdtjI3RMHz
JYWBYuCnrextg66lJi2chVtOCcYxOOuQLMLYq7cA9tlyQE24aj1fJUk/lHiA
Zo9QJG+ZoslJRnJFxwHXMhZPu6gUc81TnWrHxN4H0Tmgl1RxBkkhxwC1CfQE
04CugDYsdGIpijYOkXSHXCTwrifiYbQLDkhpfrosBtJNQqXBOSRXWEXFdQ50
TrBvQkI98ScDPCzZ5z3JL7L0l4RsJtME0JSmz0DE8+lm2Y5WVHEYccPjkc3w
2FQ8ZoBUEzwTGEs88XvpaBYmzrIJGWrWIXupTpnK8t45ORAUTaCTNiLtJQCf
wVCSEQ1em+CYxxFPFytz25Q4S3Fc/8Y3A9iDL02IxrFhxtUXNrWkr+bSY5RV
yC/MrsSloi462ONiXq/1TK/MGhAqEeBUeLK2/GVV/jL5Jb4i44kWpZHIjtI7
IkHWaMdzXpvAW0GZMdNEk3fqO8NyBkoVuOJjjH5O2/RfZ2sQXTfWUGmsLzGR
9iIRauxKoXVtMCnCybI0WZ5dlhvfZ8w6toLGy+lRJh57apZRwRPNZvrBNJ3N
mABK0H+tOnlzPaAATJkJqYQeyXKMWyEH8JDoGJR6p4jiaXSdxhLmE15TEDjl
gzACWUZNRuT8lCS5KqOLPJ8qQ4m5HAbWwnB5AUVCWVrIKQhejVgbf6rWaUG6
W5Fc4D6gR49GpLQd7a1UM0PL1VXRT/sn6A9mEO7b2hGS/VEKjXMxJ/UzQtiB
VHEGjJ88MfywkQbd8erII0Xod9BCUiRaKQU7wsnMQZxaxRcJX6jx5OnjbyV2
OS2DsVOvQAsRPrq8Ahe/oIQFLOhNm4GqKIiZWHmKFUm0kt92q7yLZEPElIUE
aeE7EQ9BbJ+LCc+m9YIIjVkoNAm2u/oVQTiliK9/AO0AUS7pYo/E53BxLcBb
ky5eXpqv/u7ReZo9gr8ugAtHX/+X6JtHjx59Hf3XCEH2dfnn/xLB7+jPfw4e
4Tf/CZ5pujJiQ9lRWSk+x2AuWQBuMBYa8mVzLQcgEOuVl1vC2/yVUuJa2CTa
wtPWqz5UW3Rlg4aIW3hO5UokC0xK6uR9gdcAHuODB7vetbAAsd/NKPpTpGNF
31MMQDyZ9z6o0z2K9jDQdA92FwR/mO1BCqylBCWLnk/0ealdalZZuEYy26RY
N2jKNh838zl3GKH6AojzTlfr+sPNxvQWQwR7cU6VDvj2CTK5McciOgHamn6t
wfeU2WvIDJDJbVSoF8qwHZZeUdvILkiAWrrcRFkqzoyEEGQQFPMDlHXqlSJA
zHn0Df0n+gZgtbylSxSiB5OH0c7jnSfRaHj6KjotVqXzeQHxKrFslzTyrsnC
ma5A7ShKRxOmQCyjAer9dDtD5CbB7bUbPHYtjVEB2tVvjgCs86TW8CRBrZCI
mZhAtD6WpD/hE4A8QhiPOJwC0u2kOeomoipRgrC1XQa3wTgiY+9AkfYOHVBb
Sp3Wtkiq3dpUu7XJ0kpllrRYqW1FMpw9p9o6oi3m/QEGR3GbhKtowSBTmjcB
3ivX1E0TrWbzGJS6or4FzelhdTQHOZ2eUrfff4bKEfQ0xrrFjzBxF4+Qa7/A
WmhkRrR7Zbmjv6rmqtVvZwMgYKYjykBOKlDKQXCqbjt8EmBY/K8blY4Giyra
nHfVyhzItXHoHEsT8o1lrrkqzKBawPuEs/dzMpAxlCtkd0V67RMn17zMZ9VN
LDmYVtvHYZdFiphdIPZmwd0U4ephBW9G42h89Or03eBkGMHfxydHP472h/vR
y5/h5TDaOzr++WT0+s1p9OboYH94MnZtB4f78Prw9GT08uz06GQcbQ3G0MUW
vRgc/hwNfzo+wbtbjk7IVTga7rvGMN7J4PB0NBwDcA/3Ds72R4evOxH0FB0e
nUYHo7ejU5jF6VEHp+HaSUde++joVfR2eLL3Bn4OXo4ORqc/0wxejU4PUW6z
TV/BPAbR8eDkdLR3djAAmefs5PhoPIxw6fuj8d7BYPR2uA8Ua3QIk3ANhz9i
cZXxm8HBQQ0mR+8Ohye4vgAOL735HowGLw+GPDaAZH90Mtw7xSW7v/YA3jD1
g040Ph7ujeAPb+ifhrDgwcnPHRllPPzHM/gavor2B28Hr2H9D0L4ucZ1QKKL
9OyEPLYItPHZy/Hp6BQvi3x9dLSP++TaouNtBHLvi+jgaEwwPhsPOzDm6YCm
An0BgOE1/P3ybDwKQT06PB2enJxRxNtDwJx3AEKY/gD62KfNOTokcAA0j05+
ht5DgNEmdqJ3b4bwwQluB8F3gPAaA5z3Tr3PXFOYCsD/1ANIdDh8fTB6PTzc
G+LbI+zu3Wg8fAh7PoJJv/anTDN6N4DpnBF8cKthwvynd0w6hBDRyJv0YP/H
ES5NWgFWjUeCigTovTeyW3oCH+F/6W++vVMkwPdvBz+9HyIqwb5i2ZmdJy/s
l42awJg/SpXPWt+Wl6iA5e+5jJp28sjjuS612xXKkmwiEUJKLWOYXyuJZNNx
sA4pUodJKyg0feR38A8nyKXd9Aka8nXG+I+nRySKH35qn6qtvarBXBTSIcXr
VGSQ8W3JvHCSAujBe9jTk/dHL/8S3mdL/x59oz58NlS2NfVvrw2butvVyLFT
Npq/Pjk6O7ZDP3lRG/mGognY6xdkR7V35N87u24e4kSttwdSNx47GDx+EbQn
iV6uysK78jhxCxNFE71zNuiNjpXtbafWGwu73FJ3b82y8ATsD7UqE07ssXZG
V+GyR2g2jy/8ExTiia10WMcYxLF2jNHmDnFYEawuMXBFuhGbjhXkMewOxSKs
AaDSJHf6XD7Su8JakdBeqPykDZMoiMvz09VbvzsZ6RW/LftfN6g3muMdnS3Y
L83xsuBm6w3Uw9WoZLJhLQVsPTmwVx7TlYnag+cGRR2iukXGW61vzH2TRq5d
qPYt6LScr0oq0uIlytabF1b+ctXf8VJGNPlfpvNpkTSkpBbq42VN+5XgzxMQ
YltJo+b1OdrYUgXAJ5uAmZOscs+EtvF//tTCLr4P209na3qgF5v7uC8NZpIQ
nihdqLIE9r5qJ/Gaxo2KRUHGLxmLtAvJmQ3KT7eeMNz8dhwnGsnQ8IxaXF6J
lJWWrjCXu+28QVcufVtxTZfDY7R2ycnmrQQASd3ss+Zns82bHGHT/OwoXqe1
XSeD1dobE9Sv07wdsiHmuDL73hk4fHUIgiBVOnSPMEiT6hu6RxiUR1UN3SOs
vU+F990jrL1PhffdI6y9//fR0zpWM+CkOjj0shOKUFoGnL3n/8Tf/bNrLriN
vlHYlHVn2lYSbn27Cl5/anQ+q5ELBp38q8lUASVRaa/5Skrntk/HF8qCNxdr
33Ax3dZXVP9/w3uurruh6ZqXXIC3/ZWU4dWXujtM+7jAbuu7xYZ3E/eulSi6
cjZUBvIFi8hhoVGuKsplIgOLvXZCVgcNjwiOU0jZ/MqhOx5qDOQmyeAcDby7
XMLjNPCvdQmP1cDdHkN1QuvPOUybq4Q2u8NaoFwFtP6OKoFyCdD6Ky4DygVA
6++4CCiW/1y/A60X1IqjzLETKcCFMRwNyhTUxtEbKu2x8+6SvINzN8+wdKnJ
arZPLzNNnwV5/7Xe/Eo8d11VSdQtuK5SRwgmI3lr+M7mrumHnL/WvqLxvYG0
aUFhZ3eBpwGJ8a+ExPi3gASC8/T05C5QrG/42cv2Gn45BriRv3Thcmnu554T
dmM2OmVOrBfxWqVou6Yakz5EcgjFJqCCW1AsoGb/fNPWnWSI1cQ26A5T6UC5
5ewW9mLd0dXbo/3Rq5/r8hrNjLUtKr+mBcTtVKWv+/yDvrhGqevKzUkFt9a5
DX86HR7u12U/qwdivUWdDwDuvr3Kpcg1+wCp4VQVcs0s18APNc4zVVltd6Js
riQiNHqQ5Vo1mXVF1/nDFpItnd+Hvt4HF/mYuU6/7JQFk/rsQ9auYHv3Oaj6
1J7I6nRkjPeQnuR2ih8th+To20C2WH9X86YTHiRxryV3jUuaN3V5HzJ433ub
N5LC9vubv2SnPk9H6q/Xke64IK71k+BeuOCL2nVw9Xf2FriWFxetL9ydby1N
5Kq3Rw11rx/oe8HNat5j/3Y177F/w5r32L9lzXvs37TmPfZvW/MeezeutaOu
f8OapSOtt6xteLuzhuX591PBzJ40Rnf3TGnvd9011b4K7/6bxjSbKmrzHpz2
Xu1FLvbc1i9z0ReNC11agFXXTGsXu+jz+uUuVtasX/DS8oIvebEv6he9+JMK
Lnux62te+KKvmpe+tLxZrH3TrmN+0a0pluDxzSkBTa3fnmK/lRtU7knsfl+N
t79e4+2HGm+/TePtr9V4++s13v4ajbe/QeP1MoP5VozmUK3acH+9NtzfoA33
Q224+c5diGGvw2jOiBND7XUYjf7brsSof6TXYuiVGGvxZMPdLF+il/dr0ohf
9KVVxrtbL+/XxZGWwjGWXtytzTZq697R7RoF/66qNL5M029R8Pt3izPrSu+2
r2t8b/jfW+W/L+Q3tf9CIN+vlOF6ILeVNGwF8rrShmsPzJfL+9qDiP11eb9/
P3n/Pjv8efJ+Y5vbuvyM03Hfwk0bj0h7AafWLbyDE44vNcmYIt0to9MUDbzt
JIB5GOlxjJEqwCAeP/nO9Q47e1HEC/fRydHrk8FbD4ZKT/WLH31LsM46eCDk
G4N/dt5jXfcH+MlDZJ4vgg+dhXB9e/7mgWcsxY62w47G9+iIv3kwDjvaac5I
LFabpwQfPfAtcthXP+zL6eXru+JvHngmLuzoSWNSvu64cWL64YO6Yo39PnX9
fgrX3tjk/mdscv8em9zfMPF+uMn9jZu8uaNgk/vrN9k/lBun1QbPfsuGf3I/
P7GssrPzTCuy1WtGjLkshvm4G2NSzSfzfRQkPni1zzlxUHLAlivKN+OkIj9q
nGO2T17t9WopFJgBVUw1aIKSlPIZF3NrpHNJCoVLbdEYg1seLcg8j6RcAeeY
zoiqSoo9xYxqQGt3v4hnFWeqYVq73p2AF4Ll0AhT0cJSin+HZWG+e7KDF4ue
Xib17IX6rPUiPwc7LC/HVWMpVRiTf2iqFFGLef0U5DpJS+/CFHZREzHkrC0z
xXnTPsB8MGvlGItCUi2ZxFVrmKd22RgGkmbT9Dqd4q0ltewtzFQyNlmIU2Il
Cpd2UGr/4xztJbSYIkzp93KJ42VcGrolBnaCEz/g2KL9Flv6aTpSbhPtOUkh
s6XLtFbEsOlOboKGHy3sLoalGSoMY0kzpGBsSfwlvlKsNBeMyqeBbjvPGRDu
pvE6hhWctG80badH12dp1Z54ep1KgLKDMgdztdzMYfS+NrzDJsc8pNJPVnT1
MIw5Ki7iLP2F2u5qWL85OznYlRP/p8uqWpa7jx7d3Nz0cnrfm+SL7415ixNN
q9vdiFI70BCNdWUxOjG+SHY518CrCEdV9G05Isx94DwQSv7c298/MKZGDLBi
C2agTjDxBNZykGarD/dbCZ0P/v4VZv7JxTzrFnaFJ3IO67v4goXhRWHLQNqq
rxWPr0dFz2HnGgmHXr6RB5fXxwfXO5sAwyvlq6TmsuJaztuaxKYobZSafg2Y
m51jrlvx6VOHUwDdZfF+VkbZyKusLMAZmMZPpygSIGgpOSY+fqSvKImsNiLh
NtIrhPQcy0/T7YQzuZG+tDmISIx5LMQARfEWqj2gErms2S7i4oqziHeBq2gj
SjvE7XL0l7NMU8yNR0qH/VBpDGRd/d520oHmZU7EkozmlrhLIJVGut1SQtcc
kzCApNm8SWhNxQ0AZtz/9jOXAMkpSXTnHYDPD5pjIgSNUwxAAt6VUR5XqcQA
L0+TwpsFrAfvbCjlVnZYOmYsQVsfmK7eiKSIIGGiHMSx3t6zJ6mtDFBjBnRJ
bjy50pS8eSWhyFIk2Ytajinlj/K4U6z6TvUhMo1Z7uD1eJoCbPt09Uk4kY07
NZanYL9cPgUvoJ1Kgl/FFSFPkaLPiDG0YIJiv9wdJc0ko79KLgrJtR+4is98
26+3CLowjUOu8dRhzQ9ZsO2iK7ldtDSb3z+Pb6l+KYPV2GLvWsiJlMrxOPoh
Kc6TIi9df64wPBa4kUuNSXZZLIgL0YaNBoeDxmaNqN4LyDixVtHwC8lptdun
T/vbeNYpXW6KR9SEGffUN5fF5o+C4GEtDa+3eAkhwPIGx6o/Ucgb5ptdYPIP
1UKJp9PgbopAXAPOJ0gKi+t2u3A0J1eEl0xR3kp+Eecd51kXeure4B1gnoCm
dE3zoD3Jx7BN1DlNE6ockm9AG61KwRPQxaOzKRT9/AxYEvb8DE2yzmpypCT/
lo6AigiLhXRqrOEIDo7SK5+qIsmCPfVew07akyZfIihg5TEfTvkO1mPzpjlV
nKSMaJbcuOLvecCX+EAbFJY0zx+pms9ANsyVrgZjieQkmcpNg96xVAPJE2Ps
n/77Oq8Kyg04oPKIUtiD7m2Nb0F2+N4KcLEeZg7Jp+stZzFfzZZkJJp5EtP1
E2iqNz7S9eFZulzRPY+crp7Zr6XqHFfgJ7LyPeEGVwiQ2xuTjCrWNAsupnR0
pRkXjnRsmrJPe5E8J0lZnLV6CQQ08opcpln3HN4DtF96lw/j1dpYmSC8Tc5p
CarnhtKC03mo8saq1FotcUlB41wrQoEQ86z5WndOKwTZni/mXiOuenusM3hC
tw1ZaZsSfu31AbUjzsoPXyFPBaNql5fLzewIpzJEOWOCp5wdmVzEk9tAQsJc
PswipEpjFAeRAWW1CgUqaXrEby6xcIDejs6aqiKtpTamBgApD6EJ0qAe0IpO
uGYKWeaFzjWx3d2SyQAo2w6hPX3A/KdSzZ/T7Fe2BscNIN/8tuvUk2I5uUA5
K8/neLXHN+56WKeo8cZQBQJrIRXk0ShIYCbqHiLFKMZzpL4m16zkq+Sp8A5Z
GMs7xqw1DcpoSBh7aezVXVJ1zjcK1iohKB/WIAgUfH1jqJD/u+m9QwYMleEL
3CpEC5NLBkcpQotUKbOkgVQZRgAtTmArL9yvSsFX0cDeQ8kQ+LjL4ebJ9O+3
qCz11ideCDN6RFG6U3W2miNbfIlFMF/GIIh1zLt0AfiYXMVJUZUdEPymBej4
kSeud8xJOrkCZjy5Aoh3zGvg7/CrKKdJ1gEdqgBshy3MF2UOv0/yc/ixKub5
DXKoqfkLDPCOEpS1JniKScZLqZomNUtgWWMpm4UyM8rvuRnAVKJ9CUYyr3O8
7f1VnBbQfVl1sNDFj0+idyClIXq/ptSpvUt4X5qXIDZk0XF8A9Mor1KayN4l
nJIqXyJxGmXxJM15gm3dgPSEOeHFrcGFATzexLeZq2oOK1gCXiRU+O5ilU65
BB6uJyfiBqvtmf8LqT2dBioyAQA=

-->

</rfc>
