<?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-rfc2629 version 1.5.24 -->
<?rfc docmapping="yes"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-rmacklem-nfsv4-posix-acls-05" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true" obsoletes="" updates="" submissionType="IETF" xml:lang="en" version="3">
  <!-- xml2rfc v2v3 conversion 3.12.0 -->
  <front>
    <title abbrev="POSIX Draft ACL support for NFSv4.2">POSIX Draft ACL support for Network File System Version 4, Minor Version 2</title>
    <seriesInfo name="Internet-Draft" value="draft-rmacklem-nfsv4-posix-acls-05"/>
    <author initials="R." surname="Macklem" fullname="Rick Macklem">
      <organization abbrev="FreeBSD">FreeBSD Project</organization>
      <address>
        <postal>
          <country>Canada</country>
        </postal>
        <email>rmacklem@uoguelph.ca</email>
      </address>
    </author>
    <date year="2024" month="August" day="10"/>
    <area>Transport</area>
    <workgroup>Network File System Version 4</workgroup>
<abstract>
<t>
This document describes a potential protocol extension involving
the addition of four new attributes to be used by servers to provide
support for POSIX ACLs.
The term POSIX ACLs refers to the ACL component of the
Portable Operating System Interface (POSIX) 1003.1e draft 17
<xref target="IEEE" format="default"/>
document for which sponsorship was
withdrawn in January 1998.
Although the draft POSIX standard that describes these ACLs was
never ratified, several POSIX-based operating systems, such as
Linux, Solaris and FreeBSD include support for them.
The NFS Version 4 (NFSv4) ACLs described in
<xref target="RFC8881" format="default"/>
henceforth referred to as NFSv4 ACLs,
use a different model and attempts to map between the ACLs
of these two models have not been completely successful.
In order to adequately support POSIX ACLs, this document proposes four new attributes that may
optionally be used by an NFS Version 4, minor version 2 (NFSv4.2) server to support ACLs that
conform to the aforementioned POSIX 1003.1e draft 17.
</t>
</abstract>

    <note>
      <name>Note</name>
      <t>This note is to be removed before publishing as an RFC.</t>
      <t>Discussion of this draft occurs on the <eref target="nfsv4@ietf.org">NFSv4 working group mailing
list</eref>, archived at
<eref target="https://mailarchive.ietf.org/arch/browse/nfsv4/"/>. Working Group
information is available at
<eref target="https://datatracker.ietf.org/wg/nfsv4/about/"/>.</t>
    </note>
</front>

<middle>

<section
 anchor="section_8F035331-8EB8-4FBC-973A-673FBA5FE952"
 numbered="true"
 removeInRFC="false"
 toc="default">
<name>Introduction</name>
<t>
In response to the very different over-the-wire formats, attempts have
been made to map between these two sorts of ACLs.
However, because of the 
large number of semantic differences, implementation experience with
mapping between NFSv4 and POSIX ACLs has not been completely successful. 
For example, if a NFSv4 ACL is applied to a server file via SETATTR
on a server that stores POSIX ACLs and then retrieved via 
GETATTR/READDIR, the ACL will often not be the same, since the
mapping algorithm cannot do an exact mapping between them. 
The expired IETF draft
<xref target="Eriksen" format="default"/>
explains the mapping algorithms.
A server has the option of choosing to use these mapping algorithms and/or
support the new attributes proposed by this document to set/get the
POSIX ACLs.
</t>
<t>
In order to provide better support for POSIX ACLs,
this document proposes four new attributes as an extension of NFSv4.2
which can be used by SETATTR/OPEN/CREATE and GETATTR/READDIR to handle POSIX ACLs.
If a server chooses to support either the acl_trueform or
acl_trueform_scope attributes, it MUST support both of them
for all file objects on the server.
If a server chooses to support either the posix_default_acl or
posix_access_acl attributes for a file system, it MUST support
both of these attributes for the file system and the acl_trueform
and acl_trueform_scope for all file objects on the server.
If the server chooses to support posix_default_acl and posix_access_acl
for a file system, it MUST support the mode/mode_umask attributes for the file system.
</t>
<t>
The semantics relevant to the implementation of POSIX ACLs by the server
are described in
<xref target="Gr&#252;nbacher" format="default"/>.
<xref target="RFC8275" format="default"/>
describes a new attribute that is an extension to NFSv4.2 related
to POSIX ACLs called mode_umask.
A server that chooses to support the new attributes described in this
document MUST also support the mode_umask attribute as described in
<xref target="RFC8275" format="default"/>.
In addition, issues related to the over-the-wire format of POSIX ACLs
and the interactions among the various new attributes and with
existing attributes as dealt with in this document.
</t>

</section>
      <section numbered="true" toc="include" removeInRFC="false">
<name>Requirements Language</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" format="default"/> <xref target="RFC8174" format="default"/> when, and only when, they
appear in all capitals, as shown here.</t>

</section>
      <section numbered="true" toc="include" removeInRFC="false">
<name>Protocol Extension Considerations</name>
<t>
This document presents an extension to minor version 2 of the NFSv4
protocol as described in
<xref target="RFC8178" format="default" sectionFormat="of"/>.
It describes new OPTIONAL
features.
NFSv4.2 servers and clients implemented without knowledge
of this extension will continue to interoperate with clients and
servers that are aware of the extension (whether or not they support
it).
</t>
<t>
Note that
<xref target="RFC7862" format="default" sectionFormat="of"/>
does not define NFSv4.2 as non-extensible, so
<xref target="RFC8178" format="default" sectionFormat="of"/>
treats it as an extensible minor version.
This Standards
Track RFC extends NFSv4.2 but does not update
<xref target="RFC7862" format="default" sectionFormat="of"/>
or
<xref target="RFC8178" format="default" sectionFormat="of"/>.
</t>
</section>


<section
 numbered="true"
 removeInRFC="false"
 toc="default">
<name>XDR definitions for new attributes</name>
   <t>
   This document contains the External Data Representation (XDR)
   [RFC4506] description of the new OPTIONAL ACL related attributes.  The XDR
   description is embedded in this document in a way that makes it
   simple for the reader to extract into a ready-to-compile form.  The
   reader can feed this document into the following shell script to
   produce the machine-readable XDR description of the flexible file
   layout type:
   </t>
   <sourcecode>
   &lt;CODE BEGINS&gt;

   #!/bin/sh
   grep '^ *///' $* | sed 's?^ */// ??' | sed 's?^ *///$??'

   &lt;CODE ENDS&gt;
   </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:
   </t>
   <sourcecode>
   sh extract.sh &lt; spec.txt &gt; flex_files_prot.x
   </sourcecode>
   <t>
   The effect of the script is to remove leading white space from each
   line, plus a sentinel sequence of "///".
   </t>
   <t>
   The embedded XDR file header follows. 
   </t>
   <t>
   Note that the XDR code contained in this document depends on types
   from the NFSv4.1 an the nfs4_prot.x file [RFC5662].  This includes both nfs
   type utf8str_mixed, as well as the more generic type uint32_t.
   </t>
          <sourcecode type="xdr">

&lt;CODE BEGINS&gt;

  ///  enum aclmodel4 {
  ///          ACL_MODEL_NFS4          = 1,
  ///          ACL_MODEL_POSIX_DRAFT   = 2,
  ///          ACL_MODEL_NONE          = 3
  ///  };
  ///  
  ///  enum aclscope4 {
  ///          ACL_SCOPE_FILE_OBJECT   = 1,
  ///          ACL_SCOPE_FILE_SYSTEM   = 2,
  ///          ACL_SCOPE_SERVER        = 3
  ///  };
  ///  
  ///  enum posixacetag4 {
  ///          POSIXACE4_TAG_USER_OBJ  = 1,
  ///          POSIXACE4_TAG_USER      = 2,
  ///          POSIXACE4_TAG_GROUP_OBJ = 3,
  ///          POSIXACE4_TAG_GROUP     = 4,
  ///          POSIXACE4_TAG_MASK      = 5,
  ///          POSIXACE4_TAG_OTHER     = 6
  ///  };
  ///  
  ///  typedef uint32_t        posixaceperm4;
  ///  
  ///  /* Bit definitions for posixaceperm4. */
  ///  const POSIXACE4_PERM_EXECUTE    = 0x00000001;
  ///  const POSIXACE4_PERM_WRITE      = 0x00000002;
  ///  const POSIXACE4_PERM_READ       = 0x00000004;
  ///  
  ///  struct posixace4 {
  ///          posixacetag4    tag;
  ///          posixaceperm4   perm;
  ///          utf8str_mixed   who;
  ///  };
  ///  
  ///  %/*
  ///  % * New for POSIX ACL extension
  ///  % */
  ///  const FATTR4_ACL_TRUEFORM         = 88;
  ///  const FATTR4_ACL_TRUEFORM_SCOPE   = 89;
  ///  const FATTR4_POSIX_DEFAULT_ACL    = 90;
  ///  const FATTR4_POSIX_ACCESS_ACL     = 91;

&lt;CODE ENDS&gt;

</sourcecode>
</section>

      <section numbered="true" toc="include" removeInRFC="false">
        <name>POSIX ACL Considerations</name>
<t>
A POSIX ACL always has one ACE for each of POSIXACE4_TAG_USER_OBJ,
POSIXACE4_TAG_GROUP_OBJ and POSIXACE4_TAG_OTHER.
A setting of a POSIX ACL that does not have these three ACEs is invalid.
If the ACL consists only of these three ACEs, it is referred to as
a minimal POSIX ACL.
A POSIX ACL may also have one or more POSIXACE4_TAG_USER and/or POSIXACE4_TAG_GROUP
ACE(s). Such a POSIX ACL is referred to as an extended POSIX ACL and must
have one POSIXACE4_TAG_MASK ACE as well.
A POSIX access ACL defines permissions for a file object.
A POSIX default ACL can only be associated with directory objects and
is used for inheritance.
The POSIX default ACL has no effect on access.
</t>
<t>
In the who value within the posixace4 structure that appear in these new attributes, the field is interpreted as follows:
</t>
<ul spacing="normal" bare="false" empty="false">
<li>
For ACEs whose tag field is POSIXACE4_TAG_USER or POSIXACE4_TAG_GROUP the who value is a UTF8-encoded Unicode string,
that has the same format as a user or group as represented within other NFSv4 operations and designates the same entity.  
In these cases, the distinction between users and groups derives from the tag rather than a flag bit, as is done in NFSv4 ACLs.
This in in contrast to how the corresponding structures are described in <xref target="Gr&#252;nbacher"/>, where numeric uids and gids are
specified.
</li>
<li>
For ACEs whose tag field has other values, the who field is ignored by the receiver and there is no reason for the sender to set it to any 
particular value.
</li>
</ul>
<t>
For POSIX ACLs, setting of the low-order nine bits of mode can change
the ACL and setting of the POSIX access ACL can change the low-order nine
bits of mode.
As such, the ordering of setting the attributes related to mode and
POSIX ACLs is important.
Therefore, in a manner similar to
<xref target="RFC8881" format="default"/> Section 6.4.1.3,
if the low-order nine bits of mode is being set via the mode/mode_set_masked
attributes in the same SETATTR as posix_access_acl and/or posix_default_acl
attributes, the setting of mode/mode_set_masked MUST be done before setting the POSIX ACL.
</t>
<t>
For
<xref target="IEEE" format="default"/>,
when a new object is created in a directory that has a
POSIX default ACL on it, the inherited ACL includes the intersection
between the mode specified by the POSIX system call and the
posixaceperm4 fields of the POSIX default ACL.
Therefore, to maintain compatible semantics with the POSIX draft, for NFSv4 operations that create new file objects (OPEN/OPEN4_CREATE, CREATE)
in a directory that has a POSIX default ACL, the low-order nine bits of the mode MUST be specified by
mode_umask in the setable attributes for the operation.
(See
<xref target="RFC8275" format="default"/>
for details on how mode_umask is used.)
If the posix_access_acl and/or posix_default_acl are also specified
in the setable attributes for the operation, the setting of these attributes MUST be
done after setting mode_umask and performing any POSIX ACL inheritance.
</t>
</section>
      <section numbered="true" toc="include" removeInRFC="false">
        <name>POSIX ACL vs NFSv4 ACL Considerations</name>
<t>
The model for the ACL(s) stored on a file object and used to determine
file access is referred to as the true form.
</t>
<t>
For servers that support the posix_access_acl and posix_default_acl
attributes for a file system,
each file object will have ACL(s) of one true form at any given time.
For servers that return a acl_trueform_scope attribute value other than ACL_SCOPE_FILE_OBJECT,
the true form MUST not change over time.
However, for servers that return a acl_trueform_scope attribute value of
ACL_SCOPE_FILE_OBJECT,
the value of acl_trueform can change,
due to a SETATTR operation that sets any of the
acl/dacl/posix_access_acl/posix_default_acl attributes.
For servers that return a acl_trueform_scope attribute value of
ACL_SCOPE_FILE_OBJECT, there might be different acl_trueform values
for different file objects in the file system.
</t>
<t>
The low-order nine bits of mode SHOULD be synchronized with the true form
ACL for the file object.
If the true form is ACL_MODEL_NFS4, synchronization is described in
<xref target="RFC8881" format="default"/>.
If the true form is ACL_MODEL_POSIX_DRAFT, synchronization is described in
<xref target="Gr&#252;nbacher" format="default"/>.
If the true form is ACL_MODEL_NONE, there is no ACL to synchronize with
and the low-order nine bits of mode are used to control access to the
file object.
</t>
<t>
For servers configured as described above and not for any others, the
following apply:
</t>
<ul spacing="normal" bare="false" empty="false">
<li>
The server MUST return a value of
ACL_MODEL_NONE for acl_trueform if there is no true form ACL(s) associated with the file object.
</li>
<li>
The server MUST return a zero length ACL for posix_default_acl and
posix_access_acl if the value of acl_trueform for the file object is not
ACL_MODEL_POSIX_DRAFT.
</li>
<li>
Using SETATTR to set a zero-length posix_default_acl or posix_access_acl (for a file object with a true form ACL of ACL_MODEL_POSIX_DRAFT) 
will delete the true form ACL(s) from the file object and revert it to ACL_MODEL_NONE.
</li>
<li>
Using SETATTR to set the dacl attribute to any value or to set the acl attribute
so that it contains one or more ALLOW or DENY ACEs 
will result in the object's acl model being set to ACL_MODEL_NFS4.
In addition, if the object's acl model had been ACL_MODEL_POSIX_DRAFT, the existing default and access ACLs are to be deleted.
</li>
<li>
Using SETATTR to set a posix_default_acl or posix_access_acl of non-zero length
(for a file object with a true form ACL not
ACL_MODEL_POSIX_DRAFT) will result in the object's acl model being set to ACL_MODEL_POSIX_DRAFT.
In addition, if the object's acl model had been ACL_MODEL_NFS4, all ALLOW and DENY ACEs will be deleted
so that the value of the dacl attribute is a zero-length array.
</li>
</ul>
<t>
All other configurations of acl_trueform and acl_trueform_scope
MUST never return ACL_MODEL_NONE and MUST always return at least a minimal POSIX ACL for posix_access_acl,
if that attribute is supported for the file object's file system.
A server that is configured for a acl_trueform_scope other
that ACL_SCOPE_FILE_OBJECT MUST not support the posix_default_acl and
posix_access_acl unless the true form for the file system is
ACL_MODEL_POSIX_DRAFT.
If a client does a SETATTR of a zero-length acl for posix_default_acl or posix_access_acl
and the acl_trueform_scope is anything other than
ACL_SCOPE_FILE_OBJECT, the server MUST reply NFS4ERR_INVAL.
</t>
</section>
      <section numbered="true" toc="include" removeInRFC="false">
        <name>ACL Related Attribute Atomicity</name>
<t>
For servers that choose to implement the extensions described in this
document, the following semantics with
respect to ACL related attributes SHOULD be implemented.
</t>
<t>
To ensure a reply to operations that return attributes (GETATTR/READDIR) provide coherent results when multiple ACL
related attributes
(acl/dacl/posix_access_acl/posix_default_acl/acl_trueform/mode/mode_set_masked)
are acquired,
the server SHOULD acquire the reply values for these attributes atomically with respect to any
SETATTR of any of these attributes.
Similarily, when VERIFY/NVERIFY acquire attributes for comparison, the server
SHOULD acquire the values for these attributes atomically with respect to any
SETATTR of any of these attributes.
For this purpose, atomically means that no SETATTR of any of the above ACL
related attributes can be performed during acquisition of the attribute values
for a given file object.
</t>
</section>
      <section anchor="attr_table" numbered="true" toc="include" removeInRFC="false">
        <name slugifiedName="name-new-attributes-list-an"><bcp14>OPTIONAL</bcp14> New Attributes - List and Definition References</name>
        <t>
     The list of New <bcp14>OPTIONAL</bcp14> attributes appears in <xref target="new_attr_table" format="default" sectionFormat="of" derivedContent="Table 1"/>.
     The meaning of the columns of the table are:
        </t>
        <dl spacing="normal" newline="false">
          <dt>Name:</dt>
          <dd>The name of the attribute.</dd>
          <dt>Id:</dt>
          <dd>The number assigned to the attribute.</dd>
          <dt>Data Type:</dt>
          <dd>The XDR data type of the attribute.</dd>
          <dt>Acc:</dt>
          <dd>Access allowed to the attribute. R means
        read-only. RW means read/write.</dd>
          <dt>Defined in:</dt>
          <dd>The section of this specification that describes the
        attribute.</dd>
        </dl>
        <table anchor="new_attr_table" align="center" pn="table-1">
          <thead>
            <tr>
              <th align="left" colspan="1" rowspan="1">Name</th>
              <th align="left" colspan="1" rowspan="1">Id</th>
              <th align="left" colspan="1" rowspan="1">Data Type</th>
              <th align="left" colspan="1" rowspan="1">Acc</th>
              <th align="left" colspan="1" rowspan="1">Defined in:</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="left" colspan="1" rowspan="1">acl_trueform</td>
              <td align="left" colspan="1" rowspan="1">88</td>
              <td align="left" colspan="1" rowspan="1">aclmodel4</td>
              <td align="left" colspan="1" rowspan="1">R</td>
              <td align="left" colspan="1" rowspan="1">
                <xref target="attrdef_acl_model" format="default" sectionFormat="of"/>
              </td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">acl_trueform_scope</td>
              <td align="left" colspan="1" rowspan="1">89</td>
              <td align="left" colspan="1" rowspan="1">aclscope4</td>
              <td align="left" colspan="1" rowspan="1">R</td>
              <td align="left" colspan="1" rowspan="1">
                <xref target="attrdef_acl_model_scope" format="default" sectionFormat="of"/>
              </td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">posix_default_acl</td>
              <td align="left" colspan="1" rowspan="1">90</td>
              <td align="left" colspan="1" rowspan="1">posixace4&lt;&gt;</td>
              <td align="left" colspan="1" rowspan="1">RW</td>
              <td align="left" colspan="1" rowspan="1">
                <xref target="attrdef_posix_default_acl" format="default" sectionFormat="of"/>
              </td>
            </tr>
            <tr>
              <td align="left" colspan="1" rowspan="1">posix_access_acl</td>
              <td align="left" colspan="1" rowspan="1">91</td>
              <td align="left" colspan="1" rowspan="1">posixace4&lt;&gt;</td>
              <td align="left" colspan="1" rowspan="1">RW</td>
              <td align="left" colspan="1" rowspan="1">
                <xref target="attrdef_posix_access_acl" format="default" sectionFormat="of"/>
              </td>
            </tr>
          </tbody>
        </table>
	</section>
      <section numbered="true" toc="include" removeInRFC="false">
	<name>Definitions of new optional attributes</name>
      <section anchor="attrdef_acl_model" numbered="true" toc="include" removeInRFC="false">
            <name slugifiedName="name-attribute-88-acl-model">Attribute 88: acl_trueform</name>
            <t>
	This attribute is a read-only attribute that describes which
	ACL model (NFSv4 vs POSIX) is used for ACL(s) stored on the file
	object (its true form) on the NFSv4.2 server.
	For a server that returns ACL_SCOPE_FILE_OBJECT for acl_trueform_scope,
	the value of this attribute can also be ACL_MODEL_NONE to
	indicate that no true form ACL is stored for this file object.
            </t>
	<t>
	It is a per-file system object attribute.
	</t>
      <section numbered="true" removeInRFC="false">
	<name>Rationale</name>
            <t>
	For a server that returns ACL_SCOPE_FILE_OBJECT for acl_trueform_scope,
	this attribute can be acquired in the same GETATTR as other ACL related
	attributes (acl/dacl/posix_access_acl/posix_default_acl), so that the client knows which ACL attribute(s) are
	for the true form.
	For a server that returns a value other than ACL_SCOPE_FILE_OBJECT
	for acl_trueform_scope, this attribute need only be acquired once
	per file system (or for the entire mount).
	The reply value can then be used by the client
	to determine whether to GETATTR/READDIR of the acl/dacl attribute(s) or
	the posix_default_acl/posix_access_acl attribute(s) to avoid the
	server doing mapping between the true form and the requested form
	for the attribute.
            </t>
	   </section>
          </section>
      <section anchor="attrdef_acl_model_scope" numbered="true" toc="include" removeInRFC="false">
            <name slugifiedName="name-attribute-89-acl-model-scope">Attribute 89: acl_trueform_scope</name>
            <t>
	Although the acl_trueform attribute is defined as a
	per-file system object attribute, some servers will be configured
	to provide the same acl_trueform reply for all file objects
	on either a file system or all file objects that share the same server
        owner (ie. per server).
	This attribute is a read-only attribute that describes what
	the actual scope of the acl_trueform attribute is for
	the file server.
            </t>
	<t>
	It is a per server attribute.
	</t>
      <section numbered="true" removeInRFC="false">
	<name>Rationale</name>
            <t>
	For a value of ACL_SCOPE_FILE_OBJECT, the acl_trueform attribute
	can be acquired in the same GETATTR as other ACL related
	attributes (acl/dacl/posix_access_acl/posix_default_acl), so that the client knows which ACL attribute(s) are
	for the true form.
	For a value other than ACL_SCOPE_FILE_OBJECT, the acl_trueform
	attribute
	allows the client to choose whether to use the
	acl/dacl attribute or the posix_access_acl/posix_default_acl
	attributes when doing GETATTR/SETATTR/READDIR/OPEN/CREATE for servers that choose
	to support both the acl/dacl and posix_default_acl/posix_access_acl
	attributes for a file system.
            </t>
	   </section>
          </section>
      <section anchor="attrdef_posix_default_acl" numbered="true" toc="include" removeInRFC="false">
            <name slugifiedName="name-attribute-90-posix-default-acl">Attribute 90: posix_default_acl</name>
            <t>
	This attribute specifies the POSIX default ACL for a
	directory.
	</t>
	<t>
	For the posixacetag4 values of POSIXACE4_TAG_USER_OBJ,
	POSIXACE4_TAG_GROUP_OBJ, POSIXACE4_TAG_MASK and
	POSIXACE4_TAG_OTHER
	the who field MUST be of zero length.
	For the posxiacetag4 values of POSIXACE4_TAG_USER and
	POSIXACE4_TAG_GROUP, the who field must be in the same format
	as would be used for the owner or owner_group attribute, respectively.
	There MUST only be one POSIXACE4_TAG_USER ACE in the ACL for each
	user as represented by the who value.
	Similarily, there MUST be only one POSIXACE4_TAG_GROUP in the ACL
	for each group as represented by the who value.
	</t>
	<t>
	Since a POSIX default ACL only applies to directories,
	a SETATTR/OPEN/CREATE of the posix_default_acl for a non-directory object
	MUST reply NFS4ERR_INVAL.
	If SETATTR of a POSIX extended ACL does not have a
	POSIXACE4_TAG_MASK ACE, the SETATTR of the ACL MUST reply NFS4ERR_INVAL.
	</t>
	<t>
	For file servers that reply ACL_SCOPE_FILE_OBJECT for the
	acl_trueform_scope attribute,
	a successful setting of this attribute sets the value of acl_trueform
	to ACL_MODEL_POSIX_DRAFT.
In addition, if the object's acl model had been ACL_MODEL_NFS4, all ALLOW and DENY ACEs will be deleted
so that the value of the dacl attribute is a zero-length array.
	</t>
	<t>
	Doing a SETATTR for a posix_default_acl of zero length deletes
	the POSIX default ACL, if one exists.
	For file servers that reply ACL_SCOPE_FILE_OBJECT for the
	acl_trueform attribute and no POSIX access ACL exists for the
	directory, this SETATTR might
	set the file object's acl_trueform to ACL_MODEL_NONE.
	</t>
	<t>
	If a directory does not have a POSIX default ACL, a GETATTR/READDIR
	for the posix_default_acl attribute will reply with an ACL
	of zero length.
	</t>
	<t>
	This attribute is a per-file system object attribute.
	</t>
      <section numbered="true" removeInRFC="false">
	<name>Rationale</name>
            <t>
	Without this optional attribute, for a file object whose true form is ACL_MODEL_POSIX_DRAFT,
	the server must map a NFSv4 ACL into a POSIX default ACL.
	It also must somehow combine the POSIX default ACL used
	for inheritance with the POSIX access ACL used for access
	control to the directory itself during the mapping, since a directory
	file object can only have, at most, one NFSv4 ACL.
            </t>
	   </section>
          </section>
      <section anchor="attrdef_posix_access_acl" numbered="true" toc="include" removeInRFC="false">
            <name slugifiedName="name-attribute-91-posix-access-acl">Attribute 91: posix_access_acl</name>
            <t>
	This attribute specifies the POSIX access ACL for a
	file object.
	</t>
	<t>
	For a GETATTR/READDIR, if the
	acl_trueform is ACL_MODEL_NONE
	(which is only allowed for a acl_trueform_scope of ACL_SCOPE_FILE_OBJECT),
	the server MUST return a zero length ACL.
	</t>
	<t>
	For the posixacetag4 values of POSIXACE4_TAG_USER_OBJ,
	POSIXACE4_TAG_GROUP_OBJ, POSIXACE4_TAG_MASK and
	POSIXACE4_TAG_OTHER
	the who field MUST be of zero length.
	For the posxiacetag4 values of POSIXACE4_TAG_USER and
	POSIXACE4_TAG_GROUP, the who field must be in the same format
	as would be used for the owner or owner_group attribute, respectively.
	There MUST only be one POSIXACE4_TAG_USER ACE in the ACL for each
	user as represented by the who value.
	Similarily, there MUST be only one POSIXACE4_TAG_GROUP in the ACL
	for each group as represented by the who value.
	</t>
	<t>
	For file servers that reply ACL_SCOPE_FILE_OBJECT for the
	acl_trueform_scope attribute,
	a successful setting of this attribute sets the value of acl_trueform
	to ACL_MODEL_POSIX_DRAFT.
In addition, if the object's acl model had been ACL_MODEL_NFS4, all ALLOW and DENY ACEs will be deleted
so that the value of the dacl attribute is a zero-length array.
	</t>
	<t>
	For a SETATTR, a posix_access_acl of zero length deletes the POSIX
	access ACL, where the exact behaviour is defined by the server's value for
	the acl_trueform_scope attribute:
	</t>
<ul spacing="normal" bare="false" empty="false">
	<li>
	For a acl_trueform_scope value of ACL_SCOPE_FILE_OBJECT,
	the deletion results in the file object having a acl_trueform
	value of either ACL_MODEL_NONE or ACL_MODEL_POSIX_DRAFT.
	It also deletes any POSIX default ACL stored for the object,
	if it is a directory.
	</li>
	<li>
	For a acl_trueform_scope that is not a value of ACL_SCOPE_FILE_OBJECT,
	the deletion results in a minimal POSIX access ACL based on mode.
	</li>
	</ul>
	<t>
	If SETATTR of a POSIX extended ACL does not have a
	POSIXACE4_TAG_MASK ACE, the SETATTR of the ACL MUST reply NFS4ERR_INVAL.
            </t>
	<t>
	This attribute is a per-file system object attribute.
	</t>
      <section numbered="true" removeInRFC="false">
	<name>Rationale</name>
            <t>
	Without this optional attribute, for a file object whose true form is ACL_MODEL_POSIX_DRAFT,
	the server must map a NFSv4 ACL into a POSIX access ACL.
            </t>
	   </section>
          </section>
</section>

<section
 anchor="section_88BBA4D6-ED42-4FE6-A208-9D277B68729A"
 numbered="true"
 removeInRFC="true"
 toc="default">
<name>Implementation Status</name>
<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.
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="section_86689813-E907-4046-ADF1-58E2BF668546"
 numbered="true"
 removeInRFC="false"
 toc="default">
<name>FreeBSD NFS server and client</name>
<dl newline="false" spacing="normal" indent="11">
<dt>Organization:</dt>
<dd>
FreeBSD Project
</dd>
<dt>URL:</dt>
<dd>
<eref target="https://www.freebsd.org"/>
</dd>
<dt>Maturity:</dt>
<dd>
Experimental software based on the current document.
</dd>
<dt>Coverage:</dt>
<dd>
The posix_default_acl and posix_access_acl attributes described in this document were implemented for a
UFS file system configured to store POSIX ACLs as its true form.
This experimental implementation does not yet support the mode_umask attribute
and does not explore the case of ACL_SCOPE_FILE_OBJECT.
</dd>
<dt>Licensing:</dt>
<dd>
BSD
</dd>
<dt>Implementation experience:</dt>
<dd>
The setfacl and getfacl commands appeared to function correctly.
</dd>
</dl>
</section>

</section>

</middle>

<back>

<references>
<name>References</name>

<references>
<name>Normative References</name>

<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.7862.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8178.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8275.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
 href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8881.xml"/>
</references>

<references>
<name>Informational References</name>
        <reference anchor="Eriksen">
          <front>
            <title>Mapping Between NFSv4 and Posix Draft ACLs</title>
            <author fullname="M. Eriksen" initials="M." surname="Eriksen">
	    </author>
            <author fullname="J. Fields" initials="J." surname="Fields">
            </author>
            <date month="August" year="2006"/>
            <abstract>
		<t>
		This is an expired IETF draft that describes the mapping
		algorithms used when mapping between NFSv4 and POSIX draft
		ACLs</t>
            </abstract>
          </front>
        </reference>
        <reference anchor="Gr&#252;nbacher">
          <front>
            <title>POSIX Access Control Lists on Linux</title>
            <author fullname="A. Gr&#252;nbacher" initials="A." surname="Gr&#252;nbacher">
              <organization/>
            </author>
            <date month="June" year="2003"/>
          </front>
	  <refcontent>USENIX 2003 Annual Technical Conference Proceedings</refcontent>
        </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 month="October" year="1997"/>
          </front>
        </reference>
</references>
</references>
    <section numbered="false" anchor="acknowledgments" toc="default">
      <name>Acknowledgments</name>
	<t>
	Thanks go to David Noveck for pointing out that a per-file object
	scope for acl_trueform_scope was useful and to Frank Filz for
	noting that IBM's GPFS already does this.
	David Noveck also helped greatly with editorial corrections.
	Thanks also goes to Pali Roh&#225;r for assorted corrections,
	particularily with respect to the setting of a zero length NFSv4 ACL.
	</t>
     </section>

</back>

</rfc>
