mirror of
https://github.com/etesync/android
synced 2025-01-25 15:10:55 +00:00
4036 lines
143 KiB
Plaintext
4036 lines
143 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Network Working Group G. Clemm
|
|||
|
Request for Comments: 3744 IBM
|
|||
|
Category: Standards Track J. Reschke
|
|||
|
greenbytes
|
|||
|
E. Sedlar
|
|||
|
Oracle Corporation
|
|||
|
J. Whitehead
|
|||
|
U.C. Santa Cruz
|
|||
|
May 2004
|
|||
|
|
|||
|
|
|||
|
Web Distributed Authoring and Versioning (WebDAV)
|
|||
|
Access Control Protocol
|
|||
|
|
|||
|
Status of this Memo
|
|||
|
|
|||
|
This document specifies an Internet standards track protocol for the
|
|||
|
Internet community, and requests discussion and suggestions for
|
|||
|
improvements. Please refer to the current edition of the "Internet
|
|||
|
Official Protocol Standards" (STD 1) for the standardization state
|
|||
|
and status of this protocol. Distribution of this memo is unlimited.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2004). All Rights Reserved.
|
|||
|
|
|||
|
Abstract
|
|||
|
|
|||
|
This document specifies a set of methods, headers, message bodies,
|
|||
|
properties, and reports that define Access Control extensions to the
|
|||
|
WebDAV Distributed Authoring Protocol. This protocol permits a
|
|||
|
client to read and modify access control lists that instruct a server
|
|||
|
whether to allow or deny operations upon a resource (such as
|
|||
|
HyperText Transfer Protocol (HTTP) method invocations) by a given
|
|||
|
principal. A lightweight representation of principals as Web
|
|||
|
resources supports integration of a wide range of user management
|
|||
|
repositories. Search operations allow discovery and manipulation of
|
|||
|
principals using human names.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 1]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Table of Contents
|
|||
|
|
|||
|
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 4
|
|||
|
1.1. Terms. . . . . . . . . . . . . . . . . . . . . . . . . . 6
|
|||
|
1.2. Notational Conventions . . . . . . . . . . . . . . . . . 8
|
|||
|
2. Principals . . . . . . . . . . . . . . . . . . . . . . . . . . 8
|
|||
|
3. Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . 8
|
|||
|
3.1. DAV:read Privilege . . . . . . . . . . . . . . . . . . . 10
|
|||
|
3.2. DAV:write Privilege. . . . . . . . . . . . . . . . . . . 10
|
|||
|
3.3. DAV:write-properties Privilege . . . . . . . . . . . . . 10
|
|||
|
3.4. DAV:write-content Privilege. . . . . . . . . . . . . . . 11
|
|||
|
3.5. DAV:unlock Privilege . . . . . . . . . . . . . . . . . . 11
|
|||
|
3.6. DAV:read-acl Privilege . . . . . . . . . . . . . . . . . 11
|
|||
|
3.7. DAV:read-current-user-privilege-set Privilege. . . . . . 12
|
|||
|
3.8. DAV:write-acl Privilege. . . . . . . . . . . . . . . . . 12
|
|||
|
3.9. DAV:bind Privilege . . . . . . . . . . . . . . . . . . . 12
|
|||
|
3.10. DAV:unbind Privilege . . . . . . . . . . . . . . . . . . 12
|
|||
|
3.11. DAV:all Privilege. . . . . . . . . . . . . . . . . . . . 13
|
|||
|
3.12. Aggregation of Predefined Privileges . . . . . . . . . . 13
|
|||
|
4. Principal Properties . . . . . . . . . . . . . . . . . . . . . 13
|
|||
|
4.1. DAV:alternate-URI-set. . . . . . . . . . . . . . . . . . 14
|
|||
|
4.2. DAV:principal-URL. . . . . . . . . . . . . . . . . . . . 14
|
|||
|
4.3. DAV:group-member-set . . . . . . . . . . . . . . . . . . 14
|
|||
|
4.4. DAV:group-membership . . . . . . . . . . . . . . . . . . 14
|
|||
|
5. Access Control Properties. . . . . . . . . . . . . . . . . . . 15
|
|||
|
5.1. DAV:owner. . . . . . . . . . . . . . . . . . . . . . . . 15
|
|||
|
5.1.1. Example: Retrieving DAV:owner . . . . . . . . . . 15
|
|||
|
5.1.2. Example: An Attempt to Set DAV:owner. . . . . . . 16
|
|||
|
5.2. DAV:group. . . . . . . . . . . . . . . . . . . . . . . . 18
|
|||
|
5.3. DAV:supported-privilege-set. . . . . . . . . . . . . . . 18
|
|||
|
5.3.1. Example: Retrieving a List of Privileges
|
|||
|
Supported on a Resource . . . . . . . . . . . . . 19
|
|||
|
5.4. DAV:current-user-privilege-set . . . . . . . . . . . . . 21
|
|||
|
5.4.1. Example: Retrieving the User's Current Set of
|
|||
|
Assigned Privileges . . . . . . . . . . . . . . . 22
|
|||
|
5.5. DAV:acl. . . . . . . . . . . . . . . . . . . . . . . . . 23
|
|||
|
5.5.1. ACE Principal . . . . . . . . . . . . . . . . . . 23
|
|||
|
5.5.2. ACE Grant and Deny. . . . . . . . . . . . . . . . 25
|
|||
|
5.5.3. ACE Protection. . . . . . . . . . . . . . . . . . 25
|
|||
|
5.5.4. ACE Inheritance . . . . . . . . . . . . . . . . . 25
|
|||
|
5.5.5. Example: Retrieving a Resource's Access Control
|
|||
|
List. . . . . . . . . . . . . . . . . . . . . . . 25
|
|||
|
5.6. DAV:acl-restrictions . . . . . . . . . . . . . . . . . . 27
|
|||
|
5.6.1. DAV:grant-only. . . . . . . . . . . . . . . . . . 27
|
|||
|
5.6.2. DAV:no-invert ACE Constraint. . . . . . . . . . . 28
|
|||
|
5.6.3. DAV:deny-before-grant . . . . . . . . . . . . . . 28
|
|||
|
5.6.4. Required Principals . . . . . . . . . . . . . . . 28
|
|||
|
5.6.5. Example: Retrieving DAV:acl-restrictions. . . . . 28
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 2]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.7. DAV:inherited-acl-set. . . . . . . . . . . . . . . . . . 29
|
|||
|
5.8. DAV:principal-collection-set . . . . . . . . . . . . . . 30
|
|||
|
5.8.1. Example: Retrieving DAV:principal-collection-set. 30
|
|||
|
5.9. Example: PROPFIND to retrieve access control properties. 32
|
|||
|
6. ACL Evaluation . . . . . . . . . . . . . . . . . . . . . . . . 36
|
|||
|
7. Access Control and existing methods. . . . . . . . . . . . . . 37
|
|||
|
7.1. Any HTTP method. . . . . . . . . . . . . . . . . . . . . 37
|
|||
|
7.1.1. Error Handling. . . . . . . . . . . . . . . . . . 37
|
|||
|
7.2. OPTIONS. . . . . . . . . . . . . . . . . . . . . . . . . 38
|
|||
|
7.2.1. Example - OPTIONS . . . . . . . . . . . . . . . . 39
|
|||
|
7.3. MOVE . . . . . . . . . . . . . . . . . . . . . . . . . . 39
|
|||
|
7.4. COPY . . . . . . . . . . . . . . . . . . . . . . . . . . 39
|
|||
|
7.5. LOCK . . . . . . . . . . . . . . . . . . . . . . . . . . 39
|
|||
|
8. Access Control Methods . . . . . . . . . . . . . . . . . . . . 40
|
|||
|
8.1. ACL. . . . . . . . . . . . . . . . . . . . . . . . . . . 40
|
|||
|
8.1.1. ACL Preconditions . . . . . . . . . . . . . . . . 40
|
|||
|
8.1.2. Example: the ACL method . . . . . . . . . . . . . 42
|
|||
|
8.1.3. Example: ACL method failure due to protected
|
|||
|
ACE conflict. . . . . . . . . . . . . . . . . . . 43
|
|||
|
8.1.4. Example: ACL method failure due to an
|
|||
|
inherited ACE conflict. . . . . . . . . . . . . . 44
|
|||
|
8.1.5. Example: ACL method failure due to an attempt
|
|||
|
to set grant and deny in a single ACE . . . . . . 45
|
|||
|
9. Access Control Reports . . . . . . . . . . . . . . . . . . . . 46
|
|||
|
9.1. REPORT Method. . . . . . . . . . . . . . . . . . . . . . 46
|
|||
|
9.2. DAV:acl-principal-prop-set Report. . . . . . . . . . . . 47
|
|||
|
9.2.1. Example: DAV:acl-principal-prop-set Report. . . . 48
|
|||
|
9.3. DAV:principal-match REPORT . . . . . . . . . . . . . . . 49
|
|||
|
9.3.1. Example: DAV:principal-match REPORT . . . . . . . 50
|
|||
|
9.4. DAV:principal-property-search REPORT . . . . . . . . . . 51
|
|||
|
9.4.1. Matching. . . . . . . . . . . . . . . . . . . . . 53
|
|||
|
9.4.2. Example: successful DAV:principal-property-search
|
|||
|
REPORT. . . . . . . . . . . . . . . . . . . . . . 54
|
|||
|
9.5. DAV:principal-search-property-set REPORT . . . . . . . . 56
|
|||
|
9.5.1. Example: DAV:principal-search-property-set
|
|||
|
REPORT. . . . . . . . . . . . . . . . . . . . . . 58
|
|||
|
10. XML Processing . . . . . . . . . . . . . . . . . . . . . . . . 59
|
|||
|
11. Internationalization Considerations. . . . . . . . . . . . . . 59
|
|||
|
12. Security Considerations. . . . . . . . . . . . . . . . . . . . 60
|
|||
|
12.1. Increased Risk of Compromised Users. . . . . . . . . . . 60
|
|||
|
12.2. Risks of the DAV:read-acl and
|
|||
|
DAV:current-user-privilege-set Privileges. . . . . . . . 60
|
|||
|
12.3. No Foreknowledge of Initial ACL. . . . . . . . . . . . . 61
|
|||
|
13. Authentication . . . . . . . . . . . . . . . . . . . . . . . . 61
|
|||
|
14. IANA Considerations. . . . . . . . . . . . . . . . . . . . . . 62
|
|||
|
15. Acknowledgements . . . . . . . . . . . . . . . . . . . . . . . 62
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 3]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
16. References . . . . . . . . . . . . . . . . . . . . . . . . . . 62
|
|||
|
16.1. Normative References . . . . . . . . . . . . . . . . . . 62
|
|||
|
16.2. Informative References . . . . . . . . . . . . . . . . . 63
|
|||
|
Appendices
|
|||
|
A. WebDAV XML Document Type Definition Addendum . . . . . . . . . 64
|
|||
|
B. WebDAV Method Privilege Table (Normative). . . . . . . . . . . 67
|
|||
|
Index. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
|
|||
|
Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 71
|
|||
|
Full Copyright Statement. . . . . . . . . . . . . . . . . . . . . 72
|
|||
|
|
|||
|
1. Introduction
|
|||
|
|
|||
|
The goal of the WebDAV access control extensions is to provide an
|
|||
|
interoperable mechanism for handling discretionary access control for
|
|||
|
content and metadata managed by WebDAV servers. WebDAV access
|
|||
|
control can be implemented on content repositories with security as
|
|||
|
simple as that of a UNIX file system, as well as more sophisticated
|
|||
|
models. The underlying principle of access control is that who you
|
|||
|
are determines what operations you can perform on a resource. The
|
|||
|
"who you are" is defined by a "principal" identifier; users, client
|
|||
|
software, servers, and groups of the previous have principal
|
|||
|
identifiers. The "operations you can perform" are determined by a
|
|||
|
single "access control list" (ACL) associated with a resource. An
|
|||
|
ACL contains a set of "access control entries" (ACEs), where each ACE
|
|||
|
specifies a principal and a set of privileges that are either granted
|
|||
|
or denied to that principal. When a principal submits an operation
|
|||
|
(such as an HTTP or WebDAV method) to a resource for execution, the
|
|||
|
server evaluates the ACEs in the ACL to determine if the principal
|
|||
|
has permission for that operation.
|
|||
|
|
|||
|
Since every ACE contains the identifier of a principal, client
|
|||
|
software operated by a human must provide a mechanism for selecting
|
|||
|
this principal. This specification uses http(s) scheme URLs to
|
|||
|
identify principals, which are represented as WebDAV-capable
|
|||
|
resources. There is no guarantee that the URLs identifying
|
|||
|
principals will be meaningful to a human. For example,
|
|||
|
http://www.example.com/u/256432 and
|
|||
|
http://www.example.com/people/Greg.Stein are both valid URLs that
|
|||
|
could be used to identify the same principal. To remedy this, every
|
|||
|
principal resource has the DAV:displayname property containing a
|
|||
|
human-readable name for the principal.
|
|||
|
|
|||
|
Since a principal can be identified by multiple URLs, it raises the
|
|||
|
problem of determining exactly which principal is being referenced in
|
|||
|
a given ACE. It is impossible for a client to determine that an ACE
|
|||
|
granting the read privilege to http://www.example.com/people/
|
|||
|
Greg.Stein also affects the principal at http://www.example.com/u/
|
|||
|
256432. That is, a client has no mechanism for determining that two
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 4]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
URLs identify the same principal resource. As a result, this
|
|||
|
specification requires clients to use just one of the many possible
|
|||
|
URLs for a principal when creating ACEs. A client can discover which
|
|||
|
URL to use by retrieving the DAV:principal-URL property (Section 4.2)
|
|||
|
from a principal resource. No matter which of the principal's URLs
|
|||
|
is used with PROPFIND, the property always returns the same URL.
|
|||
|
|
|||
|
With a system having hundreds to thousands of principals, the problem
|
|||
|
arises of how to allow a human operator of client software to select
|
|||
|
just one of these principals. One approach is to use broad
|
|||
|
collection hierarchies to spread the principals over a large number
|
|||
|
of collections, yielding few principals per collection. An example
|
|||
|
of this is a two level hierarchy with the first level containing 36
|
|||
|
collections (a-z, 0-9), and the second level being another 36,
|
|||
|
creating collections /a/a/, /a/b/, ..., /a/z/, such that a principal
|
|||
|
with last name "Stein" would appear at /s/t/Stein. In effect, this
|
|||
|
pre-computes a common query, search on last name, and encodes it into
|
|||
|
a hierarchy. The drawback with this scheme is that it handles only a
|
|||
|
small set of predefined queries, and drilling down through the
|
|||
|
collection hierarchy adds unnecessary steps (navigate down/up) when
|
|||
|
the user already knows the principal's name. While organizing
|
|||
|
principal URLs into a hierarchy is a valid namespace organization,
|
|||
|
users should not be forced to navigate this hierarchy to select a
|
|||
|
principal.
|
|||
|
|
|||
|
This specification provides the capability to perform substring
|
|||
|
searches over a small set of properties on the resources representing
|
|||
|
principals. This permits searches based on last name, first name,
|
|||
|
user name, job title, etc. Two separate searches are supported, both
|
|||
|
via the REPORT method, one to search principal resources
|
|||
|
(DAV:principal-property-search, Section 9.4), the other to determine
|
|||
|
which properties may be searched at all (DAV:principal-search-
|
|||
|
property-set, Section 9.5).
|
|||
|
|
|||
|
Once a principal has been identified in an ACE, a server evaluating
|
|||
|
that ACE must know the identity of the principal making a protocol
|
|||
|
request, and must validate that that principal is who they claim to
|
|||
|
be, a process known as authentication. This specification
|
|||
|
intentionally omits discussion of authentication, as the HTTP
|
|||
|
protocol already has a number of authentication mechanisms [RFC2617].
|
|||
|
Some authentication mechanism (such as HTTP Digest Authentication,
|
|||
|
which all WebDAV compliant implementations are required to support)
|
|||
|
must be available to validate the identity of a principal.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 5]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The following issues are out of scope for this document:
|
|||
|
|
|||
|
o Access control that applies only to a particular property on a
|
|||
|
resource (excepting the access control properties DAV:acl and
|
|||
|
DAV:current-user-privilege-set), rather than the entire resource,
|
|||
|
|
|||
|
o Role-based security (where a role can be seen as a dynamically
|
|||
|
defined group of principals),
|
|||
|
|
|||
|
o Specification of the ways an ACL on a resource is initialized,
|
|||
|
|
|||
|
o Specification of an ACL that applies globally to all resources,
|
|||
|
rather than to a particular resource.
|
|||
|
|
|||
|
o Creation and maintenance of resources representing people or
|
|||
|
computational agents (principals), and groups of these.
|
|||
|
|
|||
|
This specification is organized as follows. Section 1.1 defines key
|
|||
|
concepts used throughout the specification, and is followed by a more
|
|||
|
in-depth discussion of principals (Section 2), and privileges
|
|||
|
(Section 3). Properties defined on principals are specified in
|
|||
|
Section 4, and access control properties for content resources are
|
|||
|
specified in Section 5. The ways ACLs are to be evaluated is
|
|||
|
described in Section 6. Client discovery of access control
|
|||
|
capability using OPTIONS is described in Section 7.2. Interactions
|
|||
|
between access control functionality and existing HTTP and WebDAV
|
|||
|
methods are described in the remainder of Section 7. The access
|
|||
|
control setting method, ACL, is specified in Section 8. Four reports
|
|||
|
that provide limited server-side searching capabilities are described
|
|||
|
in Section 9. Sections on XML processing (Section 10),
|
|||
|
Internationalization considerations (Section 11), security
|
|||
|
considerations (Section 12), and authentication (Section 13) round
|
|||
|
out the specification. An appendix (Appendix A) provides an XML
|
|||
|
Document Type Definition (DTD) for the XML elements defined in the
|
|||
|
specification.
|
|||
|
|
|||
|
1.1. Terms
|
|||
|
|
|||
|
This document uses the terms defined in HTTP [RFC2616] and WebDAV
|
|||
|
[RFC2518]. In addition, the following terms are defined:
|
|||
|
|
|||
|
principal
|
|||
|
|
|||
|
A "principal" is a distinct human or computational actor that
|
|||
|
initiates access to network resources. In this protocol, a
|
|||
|
principal is an HTTP resource that represents such an actor.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 6]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
group
|
|||
|
|
|||
|
A "group" is a principal that represents a set of other
|
|||
|
principals.
|
|||
|
|
|||
|
privilege
|
|||
|
|
|||
|
A "privilege" controls access to a particular set of HTTP
|
|||
|
operations on a resource.
|
|||
|
|
|||
|
aggregate privilege
|
|||
|
|
|||
|
An "aggregate privilege" is a privilege that contains a set of
|
|||
|
other privileges.
|
|||
|
|
|||
|
abstract privilege
|
|||
|
|
|||
|
The modifier "abstract", when applied to a privilege on a
|
|||
|
resource, means the privilege cannot be set in an access control
|
|||
|
element (ACE) on that resource.
|
|||
|
|
|||
|
access control list (ACL)
|
|||
|
|
|||
|
An "ACL" is a list of access control elements that define access
|
|||
|
control to a particular resource.
|
|||
|
|
|||
|
access control element (ACE)
|
|||
|
|
|||
|
An "ACE" either grants or denies a particular set of (non-
|
|||
|
abstract) privileges for a particular principal.
|
|||
|
|
|||
|
inherited ACE
|
|||
|
|
|||
|
An "inherited ACE" is an ACE that is dynamically shared from the
|
|||
|
ACL of another resource. When a shared ACE changes on the primary
|
|||
|
resource, it is also changed on inheriting resources.
|
|||
|
|
|||
|
protected property
|
|||
|
|
|||
|
A "protected property" is one whose value cannot be updated except
|
|||
|
by a method explicitly defined as updating that specific property.
|
|||
|
In particular, a protected property cannot be updated with a
|
|||
|
PROPPATCH request.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 7]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
1.2. Notational Conventions
|
|||
|
|
|||
|
The augmented BNF used by this document to describe protocol elements
|
|||
|
is described in Section 2.1 of [RFC2616]. Because this augmented BNF
|
|||
|
uses the basic production rules provided in Section 2.2 of [RFC2616],
|
|||
|
those rules apply to this document as well.
|
|||
|
|
|||
|
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
|
|||
|
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
|
|||
|
document are to be interpreted as described in [RFC2119].
|
|||
|
|
|||
|
Definitions of XML elements in this document use XML element type
|
|||
|
declarations (as found in XML Document Type Declarations), described
|
|||
|
in Section 3.2 of [REC-XML]. When an XML element type in the "DAV:"
|
|||
|
namespace is referenced in this document outside of the context of an
|
|||
|
XML fragment, the string "DAV:" will be prefixed to the element name.
|
|||
|
|
|||
|
2. Principals
|
|||
|
|
|||
|
A principal is a network resource that represents a distinct human or
|
|||
|
computational actor that initiates access to network resources.
|
|||
|
Users and groups are represented as principals in many
|
|||
|
implementations; other types of principals are also possible. A URI
|
|||
|
of any scheme MAY be used to identify a principal resource. However,
|
|||
|
servers implementing this specification MUST expose principal
|
|||
|
resources at an http(s) URL, which is a privileged scheme that points
|
|||
|
to resources that have additional properties, as described in Section
|
|||
|
4. So, a principal resource can have multiple URIs, one of which has
|
|||
|
to be an http(s) scheme URL. Although an implementation SHOULD
|
|||
|
support PROPFIND and MAY support PROPPATCH to access and modify
|
|||
|
information about a principal, it is not required to do so.
|
|||
|
|
|||
|
A principal resource may be a group, where a group is a principal
|
|||
|
that represents a set of other principals, called the members of the
|
|||
|
group. If a person or computational agent matches a principal
|
|||
|
resource that is a member of a group, they also match the group.
|
|||
|
Membership in a group is recursive, so if a principal is a member of
|
|||
|
group GRPA, and GRPA is a member of group GRPB, then the principal is
|
|||
|
also a member of GRPB.
|
|||
|
|
|||
|
3. Privileges
|
|||
|
|
|||
|
Ability to perform a given method on a resource MUST be controlled by
|
|||
|
one or more privileges. Authors of protocol extensions that define
|
|||
|
new HTTP methods SHOULD specify which privileges (by defining new
|
|||
|
privileges, or mapping to ones below) are required to perform the
|
|||
|
method. A principal with no privileges to a resource MUST be denied
|
|||
|
any HTTP access to that resource, unless the principal matches an ACE
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 8]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
constructed using the DAV:all, DAV:authenticated, or
|
|||
|
DAV:unauthenticated pseudo-principals (see Section 5.5.1). Servers
|
|||
|
MUST report a 403 "Forbidden" error if access is denied, except in
|
|||
|
the case where the privilege restricts the ability to know the
|
|||
|
resource exists, in which case 404 "Not Found" may be returned.
|
|||
|
|
|||
|
Privileges may be containers of other privileges, in which case they
|
|||
|
are termed "aggregate privileges". If a principal is granted or
|
|||
|
denied an aggregate privilege, it is semantically equivalent to
|
|||
|
granting or denying each of the aggregated privileges individually.
|
|||
|
For example, an implementation may define add-member and remove-
|
|||
|
member privileges that control the ability to add and remove a member
|
|||
|
of a group. Since these privileges control the ability to update the
|
|||
|
state of a group, these privileges would be aggregated by the
|
|||
|
DAV:write privilege on a group, and granting the DAV:write privilege
|
|||
|
on a group would also grant the add-member and remove-member
|
|||
|
privileges.
|
|||
|
|
|||
|
Privileges may be declared to be "abstract" for a given resource, in
|
|||
|
which case they cannot be set in an ACE on that resource. Aggregate
|
|||
|
and non-aggregate privileges are both capable of being abstract.
|
|||
|
Abstract privileges are useful for modeling privileges that otherwise
|
|||
|
would not be exposed via the protocol. Abstract privileges also
|
|||
|
provide server implementations with flexibility in implementing the
|
|||
|
privileges defined in this specification. For example, if a server
|
|||
|
is incapable of separating the read resource capability from the read
|
|||
|
ACL capability, it can still model the DAV:read and DAV:read-acl
|
|||
|
privileges defined in this specification by declaring them abstract,
|
|||
|
and containing them within a non-abstract aggregate privilege (say,
|
|||
|
read-all) that holds DAV:read, and DAV:read-acl. In this way, it is
|
|||
|
possible to set the aggregate privilege, read-all, thus coupling the
|
|||
|
setting of DAV:read and DAV:read-acl, but it is not possible to set
|
|||
|
DAV:read, or DAV:read-acl individually. Since aggregate privileges
|
|||
|
can be abstract, it is also possible to use abstract privileges to
|
|||
|
group or organize non-abstract privileges. Privilege containment
|
|||
|
loops are not allowed; therefore, a privilege MUST NOT contain
|
|||
|
itself. For example, DAV:read cannot contain DAV:read.
|
|||
|
|
|||
|
The set of privileges that apply to a particular resource may vary
|
|||
|
with the DAV:resourcetype of the resource, as well as between
|
|||
|
different server implementations. To promote interoperability,
|
|||
|
however, this specification defines a set of well-known privileges
|
|||
|
(e.g., DAV:read, DAV:write, DAV:read-acl, DAV:write-acl, DAV:read-
|
|||
|
current-user-privilege-set, and DAV:all), which can at least be used
|
|||
|
to classify the other privileges defined on a particular resource.
|
|||
|
The access permissions on null resources (defined in [RFC2518],
|
|||
|
Section 3) are solely those they inherit (if any), and they are not
|
|||
|
discoverable (i.e., the access control properties specified in
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 9]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Section 5 are not defined on null resources). On the transition from
|
|||
|
null to stateful resource, the initial access control list is set by
|
|||
|
the server's default ACL value policy (if any).
|
|||
|
|
|||
|
Server implementations MAY define new privileges beyond those defined
|
|||
|
in this specification. Privileges defined by individual
|
|||
|
implementations MUST NOT use the DAV: namespace, and instead should
|
|||
|
use a namespace that they control, such as an http scheme URL.
|
|||
|
|
|||
|
3.1. DAV:read Privilege
|
|||
|
|
|||
|
The read privilege controls methods that return information about the
|
|||
|
state of the resource, including the resource's properties. Affected
|
|||
|
methods include GET and PROPFIND. Any implementation-defined
|
|||
|
privilege that also controls access to GET and PROPFIND must be
|
|||
|
aggregated under DAV:read - if an ACL grants access to DAV:read, the
|
|||
|
client may expect that no other privilege needs to be granted to have
|
|||
|
access to GET and PROPFIND. Additionally, the read privilege MUST
|
|||
|
control the OPTIONS method.
|
|||
|
|
|||
|
<!ELEMENT read EMPTY>
|
|||
|
|
|||
|
3.2. DAV:write Privilege
|
|||
|
|
|||
|
The write privilege controls methods that lock a resource or modify
|
|||
|
the content, dead properties, or (in the case of a collection)
|
|||
|
membership of the resource, such as PUT and PROPPATCH. Note that
|
|||
|
state modification is also controlled via locking (see section 5.3 of
|
|||
|
[RFC2518]), so effective write access requires that both write
|
|||
|
privileges and write locking requirements are satisfied. Any
|
|||
|
implementation-defined privilege that also controls access to methods
|
|||
|
modifying content, dead properties or collection membership must be
|
|||
|
aggregated under DAV:write, e.g., if an ACL grants access to
|
|||
|
DAV:write, the client may expect that no other privilege needs to be
|
|||
|
granted to have access to PUT and PROPPATCH.
|
|||
|
|
|||
|
<!ELEMENT write EMPTY>
|
|||
|
|
|||
|
3.3. DAV:write-properties Privilege
|
|||
|
|
|||
|
The DAV:write-properties privilege controls methods that modify the
|
|||
|
dead properties of the resource, such as PROPPATCH. Whether this
|
|||
|
privilege may be used to control access to any live properties is
|
|||
|
determined by the implementation. Any implementation-defined
|
|||
|
privilege that also controls access to methods modifying dead
|
|||
|
properties must be aggregated under DAV:write-properties - e.g., if
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 10]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
an ACL grants access to DAV:write-properties, the client can safely
|
|||
|
expect that no other privilege needs to be granted to have access to
|
|||
|
PROPPATCH.
|
|||
|
|
|||
|
<!ELEMENT write-properties EMPTY>
|
|||
|
|
|||
|
3.4. DAV:write-content Privilege
|
|||
|
|
|||
|
The DAV:write-content privilege controls methods that modify the
|
|||
|
content of an existing resource, such as PUT. Any implementation-
|
|||
|
defined privilege that also controls access to content must be
|
|||
|
aggregated under DAV:write-content - e.g., if an ACL grants access to
|
|||
|
DAV:write-content, the client can safely expect that no other
|
|||
|
privilege needs to be granted to have access to PUT. Note that PUT -
|
|||
|
when applied to an unmapped URI - creates a new resource and
|
|||
|
therefore is controlled by the DAV:bind privilege on the parent
|
|||
|
collection.
|
|||
|
|
|||
|
<!ELEMENT write-content EMPTY>
|
|||
|
|
|||
|
3.5. DAV:unlock Privilege
|
|||
|
|
|||
|
The DAV:unlock privilege controls the use of the UNLOCK method by a
|
|||
|
principal other than the lock owner (the principal that created a
|
|||
|
lock can always perform an UNLOCK). While the set of users who may
|
|||
|
lock a resource is most commonly the same set of users who may modify
|
|||
|
a resource, servers may allow various kinds of administrators to
|
|||
|
unlock resources locked by others. Any privilege controlling access
|
|||
|
by non-lock owners to UNLOCK MUST be aggregated under DAV:unlock.
|
|||
|
|
|||
|
A lock owner can always remove a lock by issuing an UNLOCK with the
|
|||
|
correct lock token and authentication credentials. That is, even if
|
|||
|
a principal does not have DAV:unlock privilege, they can still remove
|
|||
|
locks they own. Principals other than the lock owner can remove a
|
|||
|
lock only if they have DAV:unlock privilege and they issue an UNLOCK
|
|||
|
with the correct lock token. Lock timeout is not affected by the
|
|||
|
DAV:unlock privilege.
|
|||
|
|
|||
|
<!ELEMENT unlock EMPTY>
|
|||
|
|
|||
|
3.6. DAV:read-acl Privilege
|
|||
|
|
|||
|
The DAV:read-acl privilege controls the use of PROPFIND to retrieve
|
|||
|
the DAV:acl property of the resource.
|
|||
|
|
|||
|
<!ELEMENT read-acl EMPTY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 11]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
3.7. DAV:read-current-user-privilege-set Privilege
|
|||
|
|
|||
|
The DAV:read-current-user-privilege-set privilege controls the use of
|
|||
|
PROPFIND to retrieve the DAV:current-user-privilege-set property of
|
|||
|
the resource.
|
|||
|
|
|||
|
Clients are intended to use this property to visually indicate in
|
|||
|
their UI items that are dependent on the permissions of a resource,
|
|||
|
for example, by graying out resources that are not writable.
|
|||
|
|
|||
|
This privilege is separate from DAV:read-acl because there is a need
|
|||
|
to allow most users access to the privileges permitted the current
|
|||
|
user (due to its use in creating the UI), while the full ACL contains
|
|||
|
information that may not be appropriate for the current authenticated
|
|||
|
user. As a result, the set of users who can view the full ACL is
|
|||
|
expected to be much smaller than those who can read the current user
|
|||
|
privilege set, and hence distinct privileges are needed for each.
|
|||
|
|
|||
|
<!ELEMENT read-current-user-privilege-set EMPTY>
|
|||
|
|
|||
|
3.8. DAV:write-acl Privilege
|
|||
|
|
|||
|
The DAV:write-acl privilege controls use of the ACL method to modify
|
|||
|
the DAV:acl property of the resource.
|
|||
|
|
|||
|
<!ELEMENT write-acl EMPTY>
|
|||
|
|
|||
|
3.9. DAV:bind Privilege
|
|||
|
|
|||
|
The DAV:bind privilege allows a method to add a new member URL to the
|
|||
|
specified collection (for example via PUT or MKCOL). It is ignored
|
|||
|
for resources that are not collections.
|
|||
|
|
|||
|
<!ELEMENT bind EMPTY>
|
|||
|
|
|||
|
3.10. DAV:unbind Privilege
|
|||
|
|
|||
|
The DAV:unbind privilege allows a method to remove a member URL from
|
|||
|
the specified collection (for example via DELETE or MOVE). It is
|
|||
|
ignored for resources that are not collections.
|
|||
|
|
|||
|
<!ELEMENT unbind EMPTY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 12]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
3.11. DAV:all Privilege
|
|||
|
|
|||
|
DAV:all is an aggregate privilege that contains the entire set of
|
|||
|
privileges that can be applied to the resource.
|
|||
|
|
|||
|
<!ELEMENT all EMPTY>
|
|||
|
|
|||
|
3.12. Aggregation of Predefined Privileges
|
|||
|
|
|||
|
Server implementations are free to aggregate the predefined
|
|||
|
privileges (defined above in Sections 3.1-3.10) subject to the
|
|||
|
following limitations:
|
|||
|
|
|||
|
DAV:read-acl MUST NOT contain DAV:read, DAV:write, DAV:write-acl,
|
|||
|
DAV:write-properties, DAV:write-content, or DAV:read-current-user-
|
|||
|
privilege-set.
|
|||
|
|
|||
|
DAV:write-acl MUST NOT contain DAV:write, DAV:read, DAV:read-acl, or
|
|||
|
DAV:read-current-user-privilege-set.
|
|||
|
|
|||
|
DAV:read-current-user-privilege-set MUST NOT contain DAV:write,
|
|||
|
DAV:read, DAV:read-acl, or DAV:write-acl.
|
|||
|
|
|||
|
DAV:write MUST NOT contain DAV:read, DAV:read-acl, or DAV:read-
|
|||
|
current-user-privilege-set.
|
|||
|
|
|||
|
DAV:read MUST NOT contain DAV:write, DAV:write-acl, DAV:write-
|
|||
|
properties, or DAV:write-content.
|
|||
|
|
|||
|
DAV:write MUST contain DAV:bind, DAV:unbind, DAV:write-properties and
|
|||
|
DAV:write-content.
|
|||
|
|
|||
|
4. Principal Properties
|
|||
|
|
|||
|
Principals are manifested to clients as a WebDAV resource, identified
|
|||
|
by a URL. A principal MUST have a non-empty DAV:displayname property
|
|||
|
(defined in Section 13.2 of [RFC2518]), and a DAV:resourcetype
|
|||
|
property (defined in Section 13.9 of [RFC2518]). Additionally, a
|
|||
|
principal MUST report the DAV:principal XML element in the value of
|
|||
|
the DAV:resourcetype property. The element type declaration for
|
|||
|
DAV:principal is:
|
|||
|
|
|||
|
<!ELEMENT principal EMPTY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 13]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
This protocol defines the following additional properties for a
|
|||
|
principal. Since it can be expensive for a server to retrieve access
|
|||
|
control information, the name and value of these properties SHOULD
|
|||
|
NOT be returned by a PROPFIND allprop request (as defined in Section
|
|||
|
12.14.1 of [RFC2518]).
|
|||
|
|
|||
|
4.1. DAV:alternate-URI-set
|
|||
|
|
|||
|
This protected property, if non-empty, contains the URIs of network
|
|||
|
resources with additional descriptive information about the
|
|||
|
principal. This property identifies additional network resources
|
|||
|
(i.e., it contains one or more URIs) that may be consulted by a
|
|||
|
client to gain additional knowledge concerning a principal. One
|
|||
|
expected use for this property is the storage of an LDAP [RFC2255]
|
|||
|
scheme URL. A user-agent encountering an LDAP URL could use LDAP
|
|||
|
[RFC2251] to retrieve additional machine-readable directory
|
|||
|
information about the principal, and display that information in its
|
|||
|
user interface. Support for this property is REQUIRED, and the value
|
|||
|
is empty if no alternate URI exists for the principal.
|
|||
|
|
|||
|
<!ELEMENT alternate-URI-set (href*)>
|
|||
|
|
|||
|
4.2. DAV:principal-URL
|
|||
|
|
|||
|
A principal may have many URLs, but there must be one "principal URL"
|
|||
|
that clients can use to uniquely identify a principal. This
|
|||
|
protected property contains the URL that MUST be used to identify
|
|||
|
this principal in an ACL request. Support for this property is
|
|||
|
REQUIRED.
|
|||
|
|
|||
|
<!ELEMENT principal-URL (href)>
|
|||
|
|
|||
|
4.3. DAV:group-member-set
|
|||
|
|
|||
|
This property of a group principal identifies the principals that are
|
|||
|
direct members of this group. Since a group may be a member of
|
|||
|
another group, a group may also have indirect members (i.e., the
|
|||
|
members of its direct members). A URL in the DAV:group-member-set
|
|||
|
for a principal MUST be the DAV:principal-URL of that principal.
|
|||
|
|
|||
|
<!ELEMENT group-member-set (href*)>
|
|||
|
|
|||
|
4.4. DAV:group-membership
|
|||
|
|
|||
|
This protected property identifies the groups in which the principal
|
|||
|
is directly a member. Note that a server may allow a group to be a
|
|||
|
member of another group, in which case the DAV:group-membership of
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 14]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
those other groups would need to be queried in order to determine the
|
|||
|
groups in which the principal is indirectly a member. Support for
|
|||
|
this property is REQUIRED.
|
|||
|
|
|||
|
<!ELEMENT group-membership (href*)>
|
|||
|
|
|||
|
5. Access Control Properties
|
|||
|
|
|||
|
This specification defines a number of new properties for WebDAV
|
|||
|
resources. Access control properties may be retrieved just like
|
|||
|
other WebDAV properties, using the PROPFIND method. Since it is
|
|||
|
expensive, for many servers, to retrieve access control information,
|
|||
|
a PROPFIND allprop request (as defined in Section 12.14.1 of
|
|||
|
[RFC2518]) SHOULD NOT return the names and values of the properties
|
|||
|
defined in this section.
|
|||
|
|
|||
|
Access control properties (especially DAV:acl and DAV:inherited-acl-
|
|||
|
set) are defined on the resource identified by the Request-URI of a
|
|||
|
PROPFIND request. A direct consequence is that if the resource is
|
|||
|
accessible via multiple URI, the value of access control properties
|
|||
|
is the same across these URI.
|
|||
|
|
|||
|
HTTP resources that support the WebDAV Access Control Protocol MUST
|
|||
|
contain the following properties. Null resources (described in
|
|||
|
Section 3 of [RFC2518]) MUST NOT contain the following properties.
|
|||
|
|
|||
|
5.1. DAV:owner
|
|||
|
|
|||
|
This property identifies a particular principal as being the "owner"
|
|||
|
of the resource. Since the owner of a resource often has special
|
|||
|
access control capabilities (e.g., the owner frequently has permanent
|
|||
|
DAV:write-acl privilege), clients might display the resource owner in
|
|||
|
their user interface.
|
|||
|
|
|||
|
Servers MAY implement DAV:owner as protected property and MAY return
|
|||
|
an empty DAV:owner element as property value in case no owner
|
|||
|
information is available.
|
|||
|
|
|||
|
<!ELEMENT owner (href?)>
|
|||
|
|
|||
|
5.1.1. Example: Retrieving DAV:owner
|
|||
|
|
|||
|
This example shows a client request for the value of the DAV:owner
|
|||
|
property from a collection resource with URL http://www.example.com/
|
|||
|
papers/. The principal making the request is authenticated using
|
|||
|
Digest authentication. The value of DAV:owner is the URL http://
|
|||
|
www.example.com/acl/users/gstein, wrapped in the DAV:href XML
|
|||
|
element.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 15]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="jim",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:owner/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:owner>
|
|||
|
<D:href>http://www.example.com/acl/users/gstein</D:href>
|
|||
|
</D:owner>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
5.1.2. Example: An Attempt to Set DAV:owner
|
|||
|
|
|||
|
The following example shows a client request to modify the value of
|
|||
|
the DAV:owner property on the resource with URL <http://
|
|||
|
www.example.com/papers>. Since DAV:owner is a protected property on
|
|||
|
this particular server, it responds with a 207 (Multi-Status)
|
|||
|
response that contains a 403 (Forbidden) status code for the act of
|
|||
|
setting DAV:owner. Section 8.2.1 of [RFC2518] describes PROPPATCH
|
|||
|
status code information, Section 11 of [RFC2518] describes the
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 16]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Multi-Status response and Sections 1.6 and 3.12 of [RFC3253] describe
|
|||
|
additional error marshaling for PROPPATCH attempts on protected
|
|||
|
properties.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPPATCH /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="jim",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propertyupdate xmlns:D="DAV:">
|
|||
|
<D:set>
|
|||
|
<D:prop>
|
|||
|
<D:owner>
|
|||
|
<D:href>http://www.example.com/acl/users/jim</D:href>
|
|||
|
</D:owner>
|
|||
|
</D:prop>
|
|||
|
</D:set>
|
|||
|
</D:propertyupdate>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop><D:owner/></D:prop>
|
|||
|
<D:status>HTTP/1.1 403 Forbidden</D:status>
|
|||
|
<D:responsedescription>
|
|||
|
<D:error><D:cannot-modify-protected-property/></D:error>
|
|||
|
Failure to set protected property (DAV:owner)
|
|||
|
</D:responsedescription>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 17]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.2. DAV:group
|
|||
|
|
|||
|
This property identifies a particular principal as being the "group"
|
|||
|
of the resource. This property is commonly found on repositories
|
|||
|
that implement the Unix privileges model.
|
|||
|
|
|||
|
Servers MAY implement DAV:group as protected property and MAY return
|
|||
|
an empty DAV:group element as property value in case no group
|
|||
|
information is available.
|
|||
|
|
|||
|
<!ELEMENT group (href?)>
|
|||
|
|
|||
|
5.3. DAV:supported-privilege-set
|
|||
|
|
|||
|
This is a protected property that identifies the privileges defined
|
|||
|
for the resource.
|
|||
|
|
|||
|
<!ELEMENT supported-privilege-set (supported-privilege*)>
|
|||
|
|
|||
|
Each privilege appears as an XML element, where aggregate privileges
|
|||
|
list as sub-elements all of the privileges that they aggregate.
|
|||
|
|
|||
|
<!ELEMENT supported-privilege
|
|||
|
(privilege, abstract?, description, supported-privilege*)>
|
|||
|
<!ELEMENT privilege ANY>
|
|||
|
|
|||
|
An abstract privilege MUST NOT be used in an ACE for that resource.
|
|||
|
Servers MUST fail an attempt to set an abstract privilege.
|
|||
|
|
|||
|
<!ELEMENT abstract EMPTY>
|
|||
|
|
|||
|
A description is a human-readable description of what this privilege
|
|||
|
controls access to. Servers MUST indicate the human language of the
|
|||
|
description using the xml:lang attribute and SHOULD consider the HTTP
|
|||
|
Accept-Language request header when selecting one of multiple
|
|||
|
available languages.
|
|||
|
|
|||
|
<!ELEMENT description #PCDATA>
|
|||
|
|
|||
|
It is envisioned that a WebDAV ACL-aware administrative client would
|
|||
|
list the supported privileges in a dialog box, and allow the user to
|
|||
|
choose non-abstract privileges to apply in an ACE. The privileges
|
|||
|
tree is useful programmatically to map well-known privileges (defined
|
|||
|
by WebDAV or other standards groups) into privileges that are
|
|||
|
supported by any particular server implementation. The privilege
|
|||
|
tree also serves to hide complexity in implementations allowing large
|
|||
|
number of privileges to be defined by displaying aggregates to the
|
|||
|
user.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 18]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.3.1. Example: Retrieving a List of Privileges Supported on a Resource
|
|||
|
|
|||
|
This example shows a client request for the DAV:supported-privilege-
|
|||
|
set property on the resource http://www.example.com/papers/. The
|
|||
|
value of the DAV:supported-privilege-set property is a tree of
|
|||
|
supported privileges (using "[XML Namespace , localname]" to identify
|
|||
|
each privilege):
|
|||
|
|
|||
|
[DAV:, all] (aggregate, abstract)
|
|||
|
|
|
|||
|
+-- [DAV:, read] (aggregate)
|
|||
|
|
|
|||
|
+-- [DAV:, read-acl] (abstract)
|
|||
|
+-- [DAV:, read-current-user-privilege-set] (abstract)
|
|||
|
|
|
|||
|
+-- [DAV:, write] (aggregate)
|
|||
|
|
|
|||
|
+-- [DAV:, write-acl] (abstract)
|
|||
|
+-- [DAV:, write-properties]
|
|||
|
+-- [DAV:, write-content]
|
|||
|
|
|
|||
|
+-- [DAV:, unlock]
|
|||
|
|
|||
|
This privilege tree is not normative (except that it reflects the
|
|||
|
normative aggregation rules given in Section 3.12), and many possible
|
|||
|
privilege trees are possible.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="gclemm",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:supported-privilege-set/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 19]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:supported-privilege-set>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:all/></D:privilege>
|
|||
|
<D:abstract/>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Any operation
|
|||
|
</D:description>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Read any object
|
|||
|
</D:description>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
<D:abstract/>
|
|||
|
<D:description xml:lang="en">Read ACL</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege>
|
|||
|
<D:read-current-user-privilege-set/>
|
|||
|
</D:privilege>
|
|||
|
<D:abstract/>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Read current user privilege set property
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Write any object
|
|||
|
</D:description>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write-acl/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 20]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Write ACL
|
|||
|
</D:description>
|
|||
|
<D:abstract/>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write-properties/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Write properties
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write-content/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Write resource content
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:unlock/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Unlock resource
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege-set>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
5.4. DAV:current-user-privilege-set
|
|||
|
|
|||
|
DAV:current-user-privilege-set is a protected property containing the
|
|||
|
exact set of privileges (as computed by the server) granted to the
|
|||
|
currently authenticated HTTP user. Aggregate privileges and their
|
|||
|
contained privileges are listed. A user-agent can use the value of
|
|||
|
this property to adjust its user interface to make actions
|
|||
|
inaccessible (e.g., by graying out a menu item or button) for which
|
|||
|
the current principal does not have permission. This property is
|
|||
|
also useful for determining what operations the current principal can
|
|||
|
perform, without having to actually execute an operation.
|
|||
|
|
|||
|
<!ELEMENT current-user-privilege-set (privilege*)>
|
|||
|
<!ELEMENT privilege ANY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 21]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
If the current user is granted a specific privilege, that privilege
|
|||
|
must belong to the set of privileges that may be set on this
|
|||
|
resource. Therefore, each element in the DAV:current-user-
|
|||
|
privilege-set property MUST identify a non-abstract privilege from
|
|||
|
the DAV:supported-privilege-set property.
|
|||
|
|
|||
|
5.4.1. Example: Retrieving the User's Current Set of Assigned
|
|||
|
Privileges
|
|||
|
|
|||
|
Continuing the example from Section 5.3.1, this example shows a
|
|||
|
client requesting the DAV:current-user-privilege-set property from
|
|||
|
the resource with URL http://www.example.com/papers/. The username
|
|||
|
of the principal making the request is "khare", and Digest
|
|||
|
authentication is used in the request. The principal with username
|
|||
|
"khare" has been granted the DAV:read privilege. Since the DAV:read
|
|||
|
privilege contains the DAV:read-acl and DAV:read-current-user-
|
|||
|
privilege-set privileges (see Section 5.3.1), the principal with
|
|||
|
username "khare" can read the ACL property, and the DAV:current-
|
|||
|
user-privilege-set property. However, the DAV:all, DAV:read-acl,
|
|||
|
DAV:write-acl and DAV:read-current-user-privilege-set privileges are
|
|||
|
not listed in the value of DAV:current-user-privilege-set, since (for
|
|||
|
this example) they are abstract privileges. DAV:write is not listed
|
|||
|
since the principal with username "khare" is not listed in an ACE
|
|||
|
granting that principal write permission.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="khare",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:current-user-privilege-set/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 22]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:current-user-privilege-set>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:current-user-privilege-set>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
5.5. DAV:acl
|
|||
|
|
|||
|
This is a protected property that specifies the list of access
|
|||
|
control entries (ACEs), which define what principals are to get what
|
|||
|
privileges for this resource.
|
|||
|
|
|||
|
<!ELEMENT acl (ace*) >
|
|||
|
|
|||
|
Each DAV:ace element specifies the set of privileges to be either
|
|||
|
granted or denied to a single principal. If the DAV:acl property is
|
|||
|
empty, no principal is granted any privilege.
|
|||
|
|
|||
|
<!ELEMENT ace ((principal | invert), (grant|deny), protected?,
|
|||
|
inherited?)>
|
|||
|
|
|||
|
5.5.1. ACE Principal
|
|||
|
|
|||
|
The DAV:principal element identifies the principal to which this ACE
|
|||
|
applies.
|
|||
|
|
|||
|
<!ELEMENT principal (href | all | authenticated | unauthenticated
|
|||
|
| property | self)>
|
|||
|
|
|||
|
The current user matches DAV:href only if that user is authenticated
|
|||
|
as being (or being a member of) the principal identified by the URL
|
|||
|
contained by that DAV:href.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 23]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The current user always matches DAV:all.
|
|||
|
|
|||
|
<!ELEMENT all EMPTY>
|
|||
|
|
|||
|
The current user matches DAV:authenticated only if authenticated.
|
|||
|
|
|||
|
<!ELEMENT authenticated EMPTY>
|
|||
|
|
|||
|
The current user matches DAV:unauthenticated only if not
|
|||
|
authenticated.
|
|||
|
|
|||
|
<!ELEMENT unauthenticated EMPTY>
|
|||
|
|
|||
|
DAV:all is the union of DAV:authenticated, and DAV:unauthenticated.
|
|||
|
For a given request, the user matches either DAV:authenticated, or
|
|||
|
DAV:unauthenticated, but not both (that is, DAV:authenticated and
|
|||
|
DAV:unauthenticated are disjoint sets).
|
|||
|
|
|||
|
The current user matches a DAV:property principal in a DAV:acl
|
|||
|
property of a resource only if the value of the identified property
|
|||
|
of that resource contains at most one DAV:href XML element, the URI
|
|||
|
value of DAV:href identifies a principal, and the current user is
|
|||
|
authenticated as being (or being a member of) that principal. For
|
|||
|
example, if the DAV:property element contained <DAV:owner/>, the
|
|||
|
current user would match the DAV:property principal only if the
|
|||
|
current user is authenticated as matching the principal identified by
|
|||
|
the DAV:owner property of the resource.
|
|||
|
|
|||
|
<!ELEMENT property ANY>
|
|||
|
|
|||
|
The current user matches DAV:self in a DAV:acl property of the
|
|||
|
resource only if that resource is a principal and that principal
|
|||
|
matches the current user or, if the principal is a group, a member of
|
|||
|
that group matches the current user.
|
|||
|
|
|||
|
<!ELEMENT self EMPTY>
|
|||
|
|
|||
|
Some servers may support ACEs applying to those users NOT matching
|
|||
|
the current principal, e.g., all users not in a particular group.
|
|||
|
This can be done by wrapping the DAV:principal element with
|
|||
|
DAV:invert.
|
|||
|
|
|||
|
<!ELEMENT invert principal>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 24]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.5.2. ACE Grant and Deny
|
|||
|
|
|||
|
Each DAV:grant or DAV:deny element specifies the set of privileges to
|
|||
|
be either granted or denied to the specified principal. A DAV:grant
|
|||
|
or DAV:deny element of the DAV:acl of a resource MUST only contain
|
|||
|
non-abstract elements specified in the DAV:supported-privilege-set of
|
|||
|
that resource.
|
|||
|
|
|||
|
<!ELEMENT grant (privilege+)>
|
|||
|
<!ELEMENT deny (privilege+)>
|
|||
|
<!ELEMENT privilege ANY>
|
|||
|
|
|||
|
5.5.3. ACE Protection
|
|||
|
|
|||
|
A server indicates an ACE is protected by including the DAV:protected
|
|||
|
element in the ACE. If the ACL of a resource contains an ACE with a
|
|||
|
DAV:protected element, an attempt to remove that ACE from the ACL
|
|||
|
MUST fail.
|
|||
|
|
|||
|
<!ELEMENT protected EMPTY>
|
|||
|
|
|||
|
5.5.4. ACE Inheritance
|
|||
|
|
|||
|
The presence of a DAV:inherited element indicates that this ACE is
|
|||
|
inherited from another resource that is identified by the URL
|
|||
|
contained in a DAV:href element. An inherited ACE cannot be modified
|
|||
|
directly, but instead the ACL on the resource from which it is
|
|||
|
inherited must be modified.
|
|||
|
|
|||
|
Note that ACE inheritance is not the same as ACL initialization. ACL
|
|||
|
initialization defines the ACL that a newly created resource will use
|
|||
|
(if not specified). ACE inheritance refers to an ACE that is
|
|||
|
logically shared - where an update to the resource containing an ACE
|
|||
|
will affect the ACE of each resource that inherits that ACE. The
|
|||
|
method by which ACLs are initialized or by which ACEs are inherited
|
|||
|
is not defined by this document.
|
|||
|
|
|||
|
<!ELEMENT inherited (href)>
|
|||
|
|
|||
|
5.5.5. Example: Retrieving a Resource's Access Control List
|
|||
|
|
|||
|
Continuing the example from Sections 5.3.1 and 5.4.1, this example
|
|||
|
shows a client requesting the DAV:acl property from the resource with
|
|||
|
URL http://www.example.com/papers/. There are two ACEs defined in
|
|||
|
this ACL:
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 25]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
ACE #1: The group identified by URL http://www.example.com/acl/
|
|||
|
groups/maintainers (the group of site maintainers) is granted
|
|||
|
DAV:write privilege. Since (for this example) DAV:write contains the
|
|||
|
DAV:write-acl privilege (see Section 5.3.1), this means the
|
|||
|
"maintainers" group can also modify the access control list.
|
|||
|
|
|||
|
ACE #2: All principals (DAV:all) are granted the DAV:read privilege.
|
|||
|
Since (for this example) DAV:read contains DAV:read-acl and
|
|||
|
DAV:read-current-user-privilege-set, this means all users (including
|
|||
|
all members of the "maintainers" group) can read the DAV:acl property
|
|||
|
and the DAV:current-user-privilege-set property.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="masinter",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:acl/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:acl>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href
|
|||
|
>http://www.example.com/acl/groups/maintainers</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 26]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:all/>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
5.6. DAV:acl-restrictions
|
|||
|
|
|||
|
This protected property defines the types of ACLs supported by this
|
|||
|
server, to avoid clients needlessly getting errors. When a client
|
|||
|
tries to set an ACL via the ACL method, the server may reject the
|
|||
|
attempt to set the ACL as specified. The following properties
|
|||
|
indicate the restrictions the client must observe before setting an
|
|||
|
ACL:
|
|||
|
|
|||
|
<grant-only> Deny ACEs are not supported
|
|||
|
|
|||
|
<no-invert> Inverted ACEs are not supported
|
|||
|
|
|||
|
<deny-before-grant> All deny ACEs must occur before any grant ACEs
|
|||
|
|
|||
|
<required-principal> Indicates which principals are required to be
|
|||
|
present
|
|||
|
|
|||
|
|
|||
|
<!ELEMENT acl-restrictions (grant-only?, no-invert?,
|
|||
|
deny-before-grant?,
|
|||
|
required-principal?)>
|
|||
|
|
|||
|
5.6.1. DAV:grant-only
|
|||
|
|
|||
|
This element indicates that ACEs with deny clauses are not allowed.
|
|||
|
|
|||
|
<!ELEMENT grant-only EMPTY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 27]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.6.2. DAV:no-invert ACE Constraint
|
|||
|
|
|||
|
This element indicates that ACEs with the <invert> element are not
|
|||
|
allowed.
|
|||
|
|
|||
|
<!ELEMENT no-invert EMPTY>
|
|||
|
|
|||
|
5.6.3. DAV:deny-before-grant
|
|||
|
|
|||
|
This element indicates that all deny ACEs must precede all grant
|
|||
|
ACEs.
|
|||
|
|
|||
|
<!ELEMENT deny-before-grant EMPTY>
|
|||
|
|
|||
|
5.6.4. Required Principals
|
|||
|
|
|||
|
The required principal elements identify which principals must have
|
|||
|
an ACE defined in the ACL.
|
|||
|
|
|||
|
<!ELEMENT required-principal
|
|||
|
(all? | authenticated? | unauthenticated? | self? | href* |
|
|||
|
property*)>
|
|||
|
|
|||
|
For example, the following element requires that the ACL contain a
|
|||
|
|
|||
|
DAV:owner property ACE:
|
|||
|
|
|||
|
<D:required-principal xmlns:D="DAV:">
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
</D:required-principal>
|
|||
|
|
|||
|
5.6.5. Example: Retrieving DAV:acl-restrictions
|
|||
|
|
|||
|
In this example, the client requests the value of the DAV:acl-
|
|||
|
restrictions property. Digest authentication provides credentials
|
|||
|
for the principal operating the client.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="srcarter",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 28]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:acl-restrictions/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:acl-restrictions>
|
|||
|
<D:grant-only/>
|
|||
|
<D:required-principal>
|
|||
|
<D:all/>
|
|||
|
</D:required-principal>
|
|||
|
</D:acl-restrictions>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
5.7. DAV:inherited-acl-set
|
|||
|
|
|||
|
This protected property contains a set of URLs that identify other
|
|||
|
resources that also control the access to this resource. To have a
|
|||
|
privilege on a resource, not only must the ACL on that resource
|
|||
|
(specified in the DAV:acl property of that resource) grant the
|
|||
|
privilege, but so must the ACL of each resource identified in the
|
|||
|
DAV:inherited-acl-set property of that resource. Effectively, the
|
|||
|
privileges granted by the current ACL are ANDed with the privileges
|
|||
|
granted by each inherited ACL.
|
|||
|
|
|||
|
<!ELEMENT inherited-acl-set (href*)>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 29]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.8. DAV:principal-collection-set
|
|||
|
|
|||
|
This protected property of a resource contains a set of URLs that
|
|||
|
identify the root collections that contain the principals that are
|
|||
|
available on the server that implements this resource. A WebDAV
|
|||
|
Access Control Protocol user agent could use the contents of
|
|||
|
DAV:principal-collection-set to retrieve the DAV:displayname property
|
|||
|
(specified in Section 13.2 of [RFC2518]) of all principals on that
|
|||
|
server, thereby yielding human-readable names for each principal that
|
|||
|
could be displayed in a user interface.
|
|||
|
|
|||
|
<!ELEMENT principal-collection-set (href*)>
|
|||
|
|
|||
|
Since different servers can control different parts of the URL
|
|||
|
namespace, different resources on the same host MAY have different
|
|||
|
DAV:principal-collection-set values. The collections specified in
|
|||
|
the DAV:principal-collection-set MAY be located on different hosts
|
|||
|
from the resource. The URLs in DAV:principal-collection-set SHOULD be
|
|||
|
http or https scheme URLs. For security and scalability reasons, a
|
|||
|
server MAY report only a subset of the entire set of known principal
|
|||
|
collections, and therefore clients should not assume they have
|
|||
|
retrieved an exhaustive listing. Additionally, a server MAY elect to
|
|||
|
report none of the principal collections it knows about, in which
|
|||
|
case the property value would be empty.
|
|||
|
|
|||
|
The value of DAV:principal-collection-set gives the scope of the
|
|||
|
DAV:principal-property-search REPORT (defined in Section 9.4).
|
|||
|
Clients use the DAV:principal-property-search REPORT to populate
|
|||
|
their user interface with a list of principals. Therefore, servers
|
|||
|
that limit a client's ability to obtain principal information will
|
|||
|
interfere with the client's ability to manipulate access control
|
|||
|
lists, due to the difficulty of getting the URL of a principal for
|
|||
|
use in an ACE.
|
|||
|
|
|||
|
5.8.1. Example: Retrieving DAV:principal-collection-set
|
|||
|
|
|||
|
In this example, the client requests the value of the DAV:principal-
|
|||
|
collection-set property on the collection resource identified by URL
|
|||
|
http://www.example.com/papers/. The property contains the two URLs,
|
|||
|
http://www.example.com/acl/users/ and http://
|
|||
|
www.example.com/acl/groups/, both wrapped in DAV:href XML elements.
|
|||
|
Digest authentication provides credentials for the principal
|
|||
|
operating the client.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 30]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The client might reasonably follow this request with two separate
|
|||
|
PROPFIND requests to retrieve the DAV:displayname property of the
|
|||
|
members of the two collections (/acl/users and /acl/groups). This
|
|||
|
information could be used when displaying a user interface for
|
|||
|
creating access control entries.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /papers/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="yarong",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:principal-collection-set/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/papers/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:principal-collection-set>
|
|||
|
<D:href>http://www.example.com/acl/users/</D:href>
|
|||
|
<D:href>http://www.example.com/acl/groups/</D:href>
|
|||
|
</D:principal-collection-set>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 31]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
5.9. Example: PROPFIND to retrieve access control properties
|
|||
|
|
|||
|
The following example shows how access control information can be
|
|||
|
retrieved by using the PROPFIND method to fetch the values of the
|
|||
|
DAV:owner, DAV:supported-privilege-set, DAV:current-user-privilege-
|
|||
|
set, and DAV:acl properties.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PROPFIND /top/container/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Depth: 0
|
|||
|
Authorization: Digest username="ejw",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/top/container/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:propfind xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:owner/>
|
|||
|
<D:supported-privilege-set/>
|
|||
|
<D:current-user-privilege-set/>
|
|||
|
<D:acl/>
|
|||
|
</D:prop>
|
|||
|
</D:propfind>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:"
|
|||
|
xmlns:A="http://www.example.com/acl/">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/top/container/</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:owner>
|
|||
|
<D:href>http://www.example.com/users/gclemm</D:href>
|
|||
|
</D:owner>
|
|||
|
<D:supported-privilege-set>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:all/></D:privilege>
|
|||
|
<D:abstract/>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 32]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:description xml:lang="en">
|
|||
|
Any operation
|
|||
|
</D:description>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Read any object
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
<D:abstract/>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Write any object
|
|||
|
</D:description>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><A:create/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Create an object
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><A:update/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Update an object
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><A:delete/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Delete an object
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Read the ACL
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
<D:supported-privilege>
|
|||
|
<D:privilege><D:write-acl/></D:privilege>
|
|||
|
<D:description xml:lang="en">
|
|||
|
Write the ACL
|
|||
|
</D:description>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege>
|
|||
|
</D:supported-privilege-set>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 33]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:current-user-privilege-set>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
</D:current-user-privilege-set>
|
|||
|
<D:acl>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/users/esedlar</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/groups/mrktng</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:deny>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:deny>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
<D:privilege><D:write-acl/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal><D:all/></D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
<D:inherited>
|
|||
|
<D:href>http://www.example.com/top</D:href>
|
|||
|
</D:inherited>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 34]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The value of the DAV:owner property is a single DAV:href XML element
|
|||
|
containing the URL of the principal that owns this resource.
|
|||
|
|
|||
|
The value of the DAV:supported-privilege-set property is a tree of
|
|||
|
supported privileges (using "[XML Namespace , localname]" to identify
|
|||
|
each privilege):
|
|||
|
|
|||
|
[DAV:, all] (aggregate, abstract)
|
|||
|
|
|
|||
|
+-- [DAV:, read]
|
|||
|
+-- [DAV:, write] (aggregate, abstract)
|
|||
|
|
|
|||
|
+-- [http://www.example.com/acl, create]
|
|||
|
+-- [http://www.example.com/acl, update]
|
|||
|
+-- [http://www.example.com/acl, delete]
|
|||
|
+-- [DAV:, read-acl]
|
|||
|
+-- [DAV:, write-acl]
|
|||
|
|
|||
|
The DAV:current-user-privilege-set property contains two privileges,
|
|||
|
DAV:read, and DAV:read-acl. This indicates that the current
|
|||
|
authenticated user only has the ability to read the resource, and
|
|||
|
read the DAV:acl property on the resource. The DAV:acl property
|
|||
|
contains a set of four ACEs:
|
|||
|
|
|||
|
ACE #1: The principal identified by the URL http://www.example.com/
|
|||
|
users/esedlar is granted the DAV:read, DAV:write, and DAV:read-acl
|
|||
|
privileges.
|
|||
|
|
|||
|
ACE #2: The principals identified by the URL http://www.example.com/
|
|||
|
groups/mrktng are denied the DAV:read privilege. In this example,
|
|||
|
the principal URL identifies a group.
|
|||
|
|
|||
|
ACE #3: In this ACE, the principal is a property principal,
|
|||
|
specifically the DAV:owner property. When evaluating this ACE, the
|
|||
|
value of the DAV:owner property is retrieved, and is examined to see
|
|||
|
if it contains a DAV:href XML element. If so, the URL within the
|
|||
|
DAV:href element is read, and identifies a principal. In this ACE,
|
|||
|
the owner is granted DAV:read-acl, and DAV:write-acl privileges.
|
|||
|
|
|||
|
ACE #4: This ACE grants the DAV:all principal (all users) the
|
|||
|
DAV:read privilege. This ACE is inherited from the resource http://
|
|||
|
www.example.com/top, the parent collection of this resource.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 35]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
6. ACL Evaluation
|
|||
|
|
|||
|
WebDAV ACLs are evaluated in similar manner as ACLs on Windows NT and
|
|||
|
in NFSv4 [RFC3530]). An ACL is evaluated to determine whether or not
|
|||
|
access will be granted for a WebDAV request. ACEs are maintained in
|
|||
|
a particular order, and are evaluated until all of the permissions
|
|||
|
required by the current request have been granted, at which point the
|
|||
|
ACL evaluation is terminated and access is granted. If, during ACL
|
|||
|
evaluation, a <deny> ACE (matching the current user) is encountered
|
|||
|
for a privilege which has not yet been granted, the ACL evaluation is
|
|||
|
terminated and access is denied. Failure to have all required
|
|||
|
privileges granted results in access being denied.
|
|||
|
|
|||
|
Note that the semantics of many other existing ACL systems may be
|
|||
|
represented via this mechanism, by mixing deny and grant ACEs. For
|
|||
|
example, consider the standard "rwx" privilege scheme used by UNIX.
|
|||
|
In this scheme, if the current user is the owner of the file, access
|
|||
|
is granted if the corresponding privilege bit is set and denied if
|
|||
|
not set, regardless of the permissions set on the file's group and
|
|||
|
for the world. An ACL for UNIX permissions of "r--rw-r--" might be
|
|||
|
constructed like:
|
|||
|
|
|||
|
<D:acl>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:deny>
|
|||
|
<D:privilege><D:all/></D:privilege>
|
|||
|
</D:deny>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:group/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 36]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:group/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:deny>
|
|||
|
<D:privilege><D:all/></D:privilege>
|
|||
|
</D:deny>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal><D:all></D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
|
|||
|
and the <acl-restrictions> would be defined as:
|
|||
|
|
|||
|
<D:no-invert/>
|
|||
|
<D:required-principal>
|
|||
|
<D:all/>
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
<D:property><D:group/><D:group/>
|
|||
|
</D:required-principal>
|
|||
|
|
|||
|
Note that the client can still get errors from a UNIX server in spite
|
|||
|
of obeying the <acl-restrictions>, including <D:allowed-principal>
|
|||
|
(adding an ACE specifying a principal other than the ones in the ACL
|
|||
|
above) or <D:ace-conflict> (by trying to reorder the ACEs in the
|
|||
|
example above), as these particular implementation semantics are too
|
|||
|
complex to be captured with the simple (but general) declarative
|
|||
|
restrictions.
|
|||
|
|
|||
|
7. Access Control and existing methods
|
|||
|
|
|||
|
This section defines the impact of access control functionality on
|
|||
|
existing methods.
|
|||
|
|
|||
|
7.1. Any HTTP method
|
|||
|
|
|||
|
7.1.1. Error Handling
|
|||
|
|
|||
|
The WebDAV ACL mechanism requires the usage of HTTP method
|
|||
|
"preconditions" as described in section 1.6 of RFC3253 for ALL HTTP
|
|||
|
methods. All HTTP methods have an additional precondition called
|
|||
|
DAV:need-privileges. If an HTTP method fails due to insufficient
|
|||
|
privileges, the response body to the "403 Forbidden" error MUST
|
|||
|
contain the <DAV:error> element, which in turn contains the
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 37]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<DAV:need-privileges> element, which contains one or more
|
|||
|
<DAV:resource> elements indicating which resource had insufficient
|
|||
|
privileges, and what the lacking privileges were:
|
|||
|
|
|||
|
<!ELEMENT need-privileges (resource)* >
|
|||
|
<!ELEMENT resource ( href , privilege ) >
|
|||
|
|
|||
|
Since some methods require multiple permissions on multiple
|
|||
|
resources, this information is needed to resolve any ambiguity.
|
|||
|
There is no requirement that all privilege violations be reported -
|
|||
|
for implementation reasons, some servers may only report the first
|
|||
|
privilege violation. For example:
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
MOVE /a/b/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Destination: http://www.example.com/c/d
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 403 Forbidden
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<D:error xmlns:D="DAV:">
|
|||
|
<D:need-privileges>
|
|||
|
<D:resource>
|
|||
|
<D:href>/a</D:href>
|
|||
|
<D:privilege><D:unbind/></D:privilege>
|
|||
|
</D:resource>
|
|||
|
<D:resource>
|
|||
|
<D:href>/c</D:href>
|
|||
|
<D:privilege><D:bind/></D:privilege>
|
|||
|
</D:resource>
|
|||
|
</D:need-privileges>
|
|||
|
</D:error>
|
|||
|
|
|||
|
7.2. OPTIONS
|
|||
|
|
|||
|
If the server supports access control, it MUST return "access-
|
|||
|
control" as a field in the DAV response header from an OPTIONS
|
|||
|
request on any resource implemented by that server. A value of
|
|||
|
"access-control" in the DAV header MUST indicate that the server
|
|||
|
supports all MUST level requirements and REQUIRED features specified
|
|||
|
in this document.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 38]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
7.2.1. Example - OPTIONS
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
OPTIONS /foo.html HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Length: 0
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
DAV: 1, 2, access-control
|
|||
|
Allow: OPTIONS, GET, PUT, PROPFIND, PROPPATCH, ACL
|
|||
|
|
|||
|
In this example, the OPTIONS response indicates that the server
|
|||
|
supports access control and that /foo.html can have its access
|
|||
|
control list modified by the ACL method.
|
|||
|
|
|||
|
7.3. MOVE
|
|||
|
|
|||
|
When a resource is moved from one location to another due to a MOVE
|
|||
|
request, the non-inherited and non-protected ACEs in the DAV:acl
|
|||
|
property of the resource MUST NOT be modified, or the MOVE request
|
|||
|
fails. Handling of inherited and protected ACEs is intentionally
|
|||
|
undefined to give server implementations flexibility in how they
|
|||
|
implement ACE inheritance and protection.
|
|||
|
|
|||
|
7.4. COPY
|
|||
|
|
|||
|
The DAV:acl property on the resource at the destination of a COPY
|
|||
|
MUST be the same as if the resource was created by an individual
|
|||
|
resource creation request (e.g., MKCOL, PUT). Clients wishing to
|
|||
|
preserve the DAV:acl property across a copy need to read the DAV:acl
|
|||
|
property prior to the COPY, then perform an ACL operation on the new
|
|||
|
resource at the destination to restore, insofar as this is possible,
|
|||
|
the original access control list.
|
|||
|
|
|||
|
7.5. LOCK
|
|||
|
|
|||
|
A lock on a resource ensures that only the lock owner can modify ACEs
|
|||
|
that are not inherited and not protected (these are the only ACEs
|
|||
|
that a client can modify with an ACL request). A lock does not
|
|||
|
protect inherited or protected ACEs, since a client cannot modify
|
|||
|
them with an ACL request on that resource.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 39]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
8. Access Control Methods
|
|||
|
|
|||
|
8.1. ACL
|
|||
|
|
|||
|
The ACL method modifies the access control list (which can be read
|
|||
|
via the DAV:acl property) of a resource. Specifically, the ACL
|
|||
|
method only permits modification to ACEs that are not inherited, and
|
|||
|
are not protected. An ACL method invocation modifies all non-
|
|||
|
inherited and non-protected ACEs in a resource's access control list
|
|||
|
to exactly match the ACEs contained within in the DAV:acl XML element
|
|||
|
(specified in Section 5.5) of the request body. An ACL request body
|
|||
|
MUST contain only one DAV:acl XML element. Unless the non-inherited
|
|||
|
and non-protected ACEs of the DAV:acl property of the resource can be
|
|||
|
updated to be exactly the value specified in the ACL request, the ACL
|
|||
|
request MUST fail.
|
|||
|
|
|||
|
It is possible that the ACEs visible to the current user in the
|
|||
|
DAV:acl property may only be a portion of the complete set of ACEs on
|
|||
|
that resource. If this is the case, an ACL request only modifies the
|
|||
|
set of ACEs visible to the current user, and does not affect any
|
|||
|
non-visible ACE.
|
|||
|
|
|||
|
In order to avoid overwriting DAV:acl changes by another client, a
|
|||
|
client SHOULD acquire a WebDAV lock on the resource before retrieving
|
|||
|
the DAV:acl property of a resource that it intends on updating.
|
|||
|
|
|||
|
Implementation Note: Two common operations are to add or remove an
|
|||
|
ACE from an existing access control list. To accomplish this, a
|
|||
|
client uses the PROPFIND method to retrieve the value of the
|
|||
|
DAV:acl property, then parses the returned access control list to
|
|||
|
remove all inherited and protected ACEs (these ACEs are tagged
|
|||
|
with the DAV:inherited and DAV:protected XML elements). In the
|
|||
|
remaining set of non-inherited, non-protected ACEs, the client can
|
|||
|
add or remove one or more ACEs before submitting the final ACE set
|
|||
|
in the request body of the ACL method.
|
|||
|
|
|||
|
8.1.1. ACL Preconditions
|
|||
|
|
|||
|
An implementation MUST enforce the following constraints on an ACL
|
|||
|
request. If the constraint is violated, a 403 (Forbidden) or 409
|
|||
|
(Conflict) response MUST be returned and the indicated XML element
|
|||
|
MUST be returned as a child of a top level DAV:error element in an
|
|||
|
XML response body.
|
|||
|
|
|||
|
Though these status elements are generally expressed as empty XML
|
|||
|
elements (and are defined as EMPTY in the DTD), implementations MAY
|
|||
|
return additional descriptive XML elements as children of the status
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 40]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
element. Clients MUST be able to accept children of these status
|
|||
|
elements. Clients that do not understand the additional XML elements
|
|||
|
should ignore them.
|
|||
|
|
|||
|
(DAV:no-ace-conflict): The ACEs submitted in the ACL request MUST NOT
|
|||
|
conflict with each other. This is a catchall error code indicating
|
|||
|
that an implementation-specific ACL restriction has been violated.
|
|||
|
|
|||
|
(DAV:no-protected-ace-conflict): The ACEs submitted in the ACL
|
|||
|
request MUST NOT conflict with the protected ACEs on the resource.
|
|||
|
For example, if the resource has a protected ACE granting DAV:write
|
|||
|
to a given principal, then it would not be consistent if the ACL
|
|||
|
request submitted an ACE denying DAV:write to the same principal.
|
|||
|
|
|||
|
(DAV:no-inherited-ace-conflict): The ACEs submitted in the ACL
|
|||
|
request MUST NOT conflict with the inherited ACEs on the resource.
|
|||
|
For example, if the resource inherits an ACE from its parent
|
|||
|
collection granting DAV:write to a given principal, then it would not
|
|||
|
be consistent if the ACL request submitted an ACE denying DAV:write
|
|||
|
to the same principal. Note that reporting of this error will be
|
|||
|
implementation-dependent. Implementations MUST either report this
|
|||
|
error or allow the ACE to be set, and then let normal ACE evaluation
|
|||
|
rules determine whether the new ACE has any impact on the privileges
|
|||
|
available to a specific principal.
|
|||
|
|
|||
|
(DAV:limited-number-of-aces): The number of ACEs submitted in the ACL
|
|||
|
request MUST NOT exceed the number of ACEs allowed on that resource.
|
|||
|
However, ACL-compliant servers MUST support at least one ACE granting
|
|||
|
privileges to a single principal, and one ACE granting privileges to
|
|||
|
a group.
|
|||
|
|
|||
|
(DAV:deny-before-grant): All non-inherited deny ACEs MUST precede all
|
|||
|
non-inherited grant ACEs.
|
|||
|
|
|||
|
(DAV:grant-only): The ACEs submitted in the ACL request MUST NOT
|
|||
|
include a deny ACE. This precondition applies only when the ACL
|
|||
|
restrictions of the resource include the DAV:grant-only constraint
|
|||
|
(defined in Section 5.6.1).
|
|||
|
|
|||
|
(DAV:no-invert): The ACL request MUST NOT include a DAV:invert
|
|||
|
element. This precondition applies only when the ACL semantics of
|
|||
|
the resource includes the DAV:no-invert constraint (defined in
|
|||
|
Section 5.6.2).
|
|||
|
|
|||
|
(DAV:no-abstract): The ACL request MUST NOT attempt to grant or deny
|
|||
|
an abstract privilege (see Section 5.3).
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 41]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
(DAV:not-supported-privilege): The ACEs submitted in the ACL request
|
|||
|
MUST be supported by the resource.
|
|||
|
|
|||
|
(DAV:missing-required-principal): The result of the ACL request MUST
|
|||
|
have at least one ACE for each principal identified in a
|
|||
|
DAV:required-principal XML element in the ACL semantics of that
|
|||
|
resource (see Section 5.5).
|
|||
|
|
|||
|
(DAV:recognized-principal): Every principal URL in the ACL request
|
|||
|
MUST identify a principal resource.
|
|||
|
|
|||
|
(DAV:allowed-principal): The principals specified in the ACEs
|
|||
|
submitted in the ACL request MUST be allowed as principals for the
|
|||
|
resource. For example, a server where only authenticated principals
|
|||
|
can access resources would not allow the DAV:all or
|
|||
|
DAV:unauthenticated principals to be used in an ACE, since these
|
|||
|
would allow unauthenticated access to resources.
|
|||
|
|
|||
|
8.1.2. Example: the ACL method
|
|||
|
|
|||
|
In the following example, user "fielding", authenticated by
|
|||
|
information in the Authorization header, grants the principal
|
|||
|
identified by the URL http://www.example.com/users/esedlar (i.e., the
|
|||
|
user "esedlar") read and write privileges, grants the owner of the
|
|||
|
resource read-acl and write-acl privileges, and grants everyone read
|
|||
|
privileges.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
ACL /top/container/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Authorization: Digest username="fielding",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/top/container/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:acl xmlns:D="DAV:">
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/users/esedlar</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 42]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:property><D:owner/></D:property>
|
|||
|
</D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read-acl/></D:privilege>
|
|||
|
<D:privilege><D:write-acl/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
<D:ace>
|
|||
|
<D:principal><D:all/></D:principal>
|
|||
|
<D:grant>
|
|||
|
<D:privilege><D:read/></D:privilege>
|
|||
|
</D:grant>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
|
|||
|
8.1.3. Example: ACL method failure due to protected ACE conflict
|
|||
|
|
|||
|
In the following request, user "fielding", authenticated by
|
|||
|
information in the Authorization header, attempts to deny the
|
|||
|
principal identified by the URL http://www.example.com/users/esedlar
|
|||
|
(i.e., the user "esedlar") write privileges. Prior to the request,
|
|||
|
the DAV:acl property on the resource contained a protected ACE (see
|
|||
|
Section 5.5.3) granting DAV:owner the DAV:read and DAV:write
|
|||
|
privileges. The principal identified by URL http://www.example.com/
|
|||
|
users/esedlar is the owner of the resource. The ACL method
|
|||
|
invocation fails because the submitted ACE conflicts with the
|
|||
|
protected ACE, thus violating the semantics of ACE protection.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
ACL /top/container/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Authorization: Digest username="fielding",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/top/container/", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:acl xmlns:D="DAV:">
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 43]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:href>http://www.example.com/users/esedlar</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:deny>
|
|||
|
<D:privilege><D:write/></D:privilege>
|
|||
|
</D:deny>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 403 Forbidden
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:error xmlns:D="DAV:">
|
|||
|
<D:no-protected-ace-conflict/>
|
|||
|
</D:error>
|
|||
|
|
|||
|
8.1.4. Example: ACL method failure due to an inherited ACE conflict
|
|||
|
|
|||
|
In the following request, user "ejw", authenticated by information in
|
|||
|
the Authorization header, tries to change the access control list on
|
|||
|
the resource http://www.example.com/top/index.html. This resource
|
|||
|
has two inherited ACEs.
|
|||
|
|
|||
|
Inherited ACE #1 grants the principal identified by URL http://
|
|||
|
www.example.com/users/ejw (i.e., the user "ejw") http://
|
|||
|
www.example.com/privs/write-all and DAV:read-acl privileges. On this
|
|||
|
server, http://www.example.com/privs/write-all is an aggregate
|
|||
|
privilege containing DAV:write, and DAV:write-acl.
|
|||
|
|
|||
|
Inherited ACE #2 grants principal DAV:all the DAV:read privilege.
|
|||
|
|
|||
|
The request attempts to set a (non-inherited) ACE, denying the
|
|||
|
principal identified by the URL http://www.example.com/users/ejw
|
|||
|
(i.e., the user "ejw") DAV:write permission. This conflicts with
|
|||
|
inherited ACE #1. Note that the decision to report an inherited ACE
|
|||
|
conflict is specific to this server implementation. Another server
|
|||
|
implementation could have allowed the new ACE to be set, and then
|
|||
|
used normal ACE evaluation rules to determine whether the new ACE has
|
|||
|
any impact on the privileges available to a principal.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 44]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
ACL /top/index.html HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Authorization: Digest username="ejw",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/top/index.html", response="...", opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:acl xmlns:D="DAV:" xmlns:F="http://www.example.com/privs/">
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/users/ejw</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:grant><D:write/></D:grant>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 403 Forbidden
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:error xmlns:D="DAV:">
|
|||
|
<D:no-inherited-ace-conflict/>
|
|||
|
</D:error>
|
|||
|
|
|||
|
8.1.5. Example: ACL method failure due to an attempt to set grant and
|
|||
|
deny in a single ACE
|
|||
|
|
|||
|
In this example, user "ygoland", authenticated by information in the
|
|||
|
Authorization header, tries to change the access control list on the
|
|||
|
resource http://www.example.com/diamond/engagement-ring.gif. The ACL
|
|||
|
request includes a single, syntactically and semantically incorrect
|
|||
|
ACE, which attempts to grant the group identified by the URL http://
|
|||
|
www.example.com/users/friends DAV:read privilege and deny the
|
|||
|
principal identified by URL http://www.example.com/users/ygoland-so
|
|||
|
(i.e., the user "ygoland-so") DAV:read privilege. However, it is
|
|||
|
illegal to have multiple principal elements, as well as both a grant
|
|||
|
and deny element in the same ACE, so the request fails due to poor
|
|||
|
syntax.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 45]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
ACL /diamond/engagement-ring.gif HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Authorization: Digest username="ygoland",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/diamond/engagement-ring.gif", response="...",
|
|||
|
opaque="..."
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:acl xmlns:D="DAV:">
|
|||
|
<D:ace>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/users/friends</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:grant><D:read/></D:grant>
|
|||
|
<D:principal>
|
|||
|
<D:href>http://www.example.com/users/ygoland-so</D:href>
|
|||
|
</D:principal>
|
|||
|
<D:deny><D:read/></D:deny>
|
|||
|
</D:ace>
|
|||
|
</D:acl>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 400 Bad Request
|
|||
|
Content-Length: 0
|
|||
|
|
|||
|
Note that if the request had been divided into two ACEs, one to
|
|||
|
grant, and one to deny, the request would have been syntactically
|
|||
|
well formed.
|
|||
|
|
|||
|
9. Access Control Reports
|
|||
|
|
|||
|
9.1. REPORT Method
|
|||
|
|
|||
|
The REPORT method (defined in Section 3.6 of [RFC3253]) provides an
|
|||
|
extensible mechanism for obtaining information about a resource.
|
|||
|
Unlike the PROPFIND method, which returns the value of one or more
|
|||
|
named properties, the REPORT method can involve more complex
|
|||
|
processing. REPORT is valuable in cases where the server has access
|
|||
|
to all of the information needed to perform the complex request (such
|
|||
|
as a query), and where it would require multiple requests for the
|
|||
|
client to retrieve the information needed to perform the same
|
|||
|
request.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 46]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
A server that supports the WebDAV Access Control Protocol MUST
|
|||
|
support the DAV:expand-property report (defined in Section 3.8 of
|
|||
|
[RFC3253]).
|
|||
|
|
|||
|
9.2. DAV:acl-principal-prop-set Report
|
|||
|
|
|||
|
The DAV:acl-principal-prop-set report returns, for all principals in
|
|||
|
the DAV:acl property (of the Request-URI) that are identified by
|
|||
|
http(s) URLs or by a DAV:property principal, the value of the
|
|||
|
properties specified in the REPORT request body. In the case where a
|
|||
|
principal URL appears multiple times, the DAV:acl-principal-prop-set
|
|||
|
report MUST return the properties for that principal only once.
|
|||
|
Support for this report is REQUIRED.
|
|||
|
|
|||
|
One expected use of this report is to retrieve the human readable
|
|||
|
name (found in the DAV:displayname property) of each principal found
|
|||
|
in an ACL. This is useful for constructing user interfaces that show
|
|||
|
each ACE in a human readable form.
|
|||
|
|
|||
|
Marshalling
|
|||
|
|
|||
|
The request body MUST be a DAV:acl-principal-prop-set XML element.
|
|||
|
|
|||
|
<!ELEMENT acl-principal-prop-set ANY>
|
|||
|
ANY value: a sequence of one or more elements, with at most one
|
|||
|
DAV:prop element.
|
|||
|
prop: see RFC 2518, Section 12.11
|
|||
|
|
|||
|
This report is only defined when the Depth header has value "0";
|
|||
|
other values result in a 400 (Bad Request) error response. Note
|
|||
|
that [RFC3253], Section 3.6, states that if the Depth header is
|
|||
|
not present, it defaults to a value of "0".
|
|||
|
|
|||
|
The response body for a successful request MUST be a
|
|||
|
DAV:multistatus XML element (i.e., the response uses the same
|
|||
|
format as the response for PROPFIND). In the case where there are
|
|||
|
no response elements, the returned multistatus XML element is
|
|||
|
empty.
|
|||
|
|
|||
|
multistatus: see RFC 2518, Section 12.9
|
|||
|
|
|||
|
The response body for a successful DAV:acl-principal-prop-set
|
|||
|
REPORT request MUST contain a DAV:response element for each
|
|||
|
principal identified by an http(s) URL listed in a DAV:principal
|
|||
|
XML element of an ACE within the DAV:acl property of the resource
|
|||
|
identified by the Request-URI.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 47]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Postconditions:
|
|||
|
|
|||
|
(DAV:number-of-matches-within-limits): The number of matching
|
|||
|
principals must fall within server-specific, predefined limits.
|
|||
|
For example, this condition might be triggered if a search
|
|||
|
specification would cause the return of an extremely large number
|
|||
|
of responses.
|
|||
|
|
|||
|
9.2.1. Example: DAV:acl-principal-prop-set Report
|
|||
|
|
|||
|
Resource http://www.example.com/index.html has an ACL with three
|
|||
|
ACEs:
|
|||
|
|
|||
|
ACE #1: All principals (DAV:all) have DAV:read and DAV:read-current-
|
|||
|
user-privilege-set access.
|
|||
|
|
|||
|
ACE #2: The principal identified by http://www.example.com/people/
|
|||
|
gstein (the user "gstein") is granted DAV:write, DAV:write-acl,
|
|||
|
DAV:read-acl privileges.
|
|||
|
|
|||
|
ACE #3: The group identified by http://www.example.com/groups/authors
|
|||
|
(the "authors" group) is granted DAV:write and DAV:read-acl
|
|||
|
privileges.
|
|||
|
|
|||
|
The following example shows a DAV:acl-principal-prop-set report
|
|||
|
requesting the DAV:displayname property. It returns the value of
|
|||
|
DAV:displayname for resources http://www.example.com/people/gstein
|
|||
|
and http://www.example.com/groups/authors , but not for DAV:all,
|
|||
|
since this is not an http(s) URL.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
REPORT /index.html HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Depth: 0
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:acl-principal-prop-set xmlns:D="DAV:">
|
|||
|
<D:prop>
|
|||
|
<D:displayname/>
|
|||
|
</D:prop>
|
|||
|
</D:acl-principal-prop-set>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 48]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/people/gstein</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:displayname>Greg Stein</D:displayname>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/groups/authors</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:displayname>Site authors</D:displayname>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
9.3. DAV:principal-match REPORT
|
|||
|
|
|||
|
The DAV:principal-match REPORT is used to identify all members (at
|
|||
|
any depth) of the collection identified by the Request-URI that are
|
|||
|
principals and that match the current user. In particular, if the
|
|||
|
collection contains principals, the report can be used to identify
|
|||
|
all members of the collection that match the current user.
|
|||
|
Alternatively, if the collection contains resources that have a
|
|||
|
property that identifies a principal (e.g., DAV:owner), the report
|
|||
|
can be used to identify all members of the collection whose property
|
|||
|
identifies a principal that matches the current user. For example,
|
|||
|
this report can return all of the resources in a collection hierarchy
|
|||
|
that are owned by the current user. Support for this report is
|
|||
|
REQUIRED.
|
|||
|
|
|||
|
Marshalling:
|
|||
|
|
|||
|
The request body MUST be a DAV:principal-match XML element.
|
|||
|
<!ELEMENT principal-match ((principal-property | self), prop?)>
|
|||
|
<!ELEMENT principal-property ANY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 49]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
ANY value: an element whose value identifies a property. The
|
|||
|
expectation is the value of the named property typically contains
|
|||
|
an href element that contains the URI of a principal
|
|||
|
<!ELEMENT self EMPTY>
|
|||
|
prop: see RFC 2518, Section 12.11
|
|||
|
|
|||
|
This report is only defined when the Depth header has value "0";
|
|||
|
other values result in a 400 (Bad Request) error response. Note
|
|||
|
that [RFC3253], Section 3.6, states that if the Depth header is
|
|||
|
not present, it defaults to a value of "0". The response body for
|
|||
|
a successful request MUST be a DAV:multistatus XML element. In
|
|||
|
the case where there are no response elements, the returned
|
|||
|
multistatus XML element is empty.
|
|||
|
|
|||
|
multistatus: see RFC 2518, Section 12.9
|
|||
|
|
|||
|
The response body for a successful DAV:principal-match REPORT
|
|||
|
request MUST contain a DAV:response element for each member of the
|
|||
|
collection that matches the current user. When the
|
|||
|
DAV:principal-property element is used, a match occurs if the
|
|||
|
current user is matched by the principal identified by the URI
|
|||
|
found in the DAV:href element of the property identified by the
|
|||
|
DAV:principal-property element. When the DAV:self element is used
|
|||
|
in a DAV:principal-match report issued against a group, it matches
|
|||
|
the group if a member identifies the same principal as the current
|
|||
|
user.
|
|||
|
|
|||
|
If DAV:prop is specified in the request body, the properties
|
|||
|
specified in the DAV:prop element MUST be reported in the
|
|||
|
DAV:response elements.
|
|||
|
|
|||
|
9.3.1. Example: DAV:principal-match REPORT
|
|||
|
|
|||
|
The following example identifies the members of the collection
|
|||
|
identified by the URL http://www.example.com/doc that are owned by
|
|||
|
the current user. The current user ("gclemm") is authenticated using
|
|||
|
Digest authentication.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
REPORT /doc/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Authorization: Digest username="gclemm",
|
|||
|
realm="users@example.com", nonce="...",
|
|||
|
uri="/papers/", response="...", opaque="..."
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
Depth: 0
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 50]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:principal-match xmlns:D="DAV:">
|
|||
|
<D:principal-property>
|
|||
|
<D:owner/>
|
|||
|
</D:principal-property>
|
|||
|
</D:principal-match>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/doc/foo.html</D:href>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:response>
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/doc/img/bar.gif</D:href>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
9.4. DAV:principal-property-search REPORT
|
|||
|
|
|||
|
The DAV:principal-property-search REPORT performs a search for all
|
|||
|
principals whose properties contain character data that matches the
|
|||
|
search criteria specified in the request. One expected use of this
|
|||
|
report is to discover the URL of a principal associated with a given
|
|||
|
person or group by searching for them by name. This is done by
|
|||
|
searching over DAV:displayname, which is defined on all principals.
|
|||
|
|
|||
|
The actual search method (exact matching vs. substring matching vs,
|
|||
|
prefix-matching, case-sensitivity) deliberately is left to the server
|
|||
|
implementation to allow implementation on a wide set of possible user
|
|||
|
management systems. In cases where the implementation of
|
|||
|
DAV:principal-property-search is not constrained by the semantics of
|
|||
|
an underlying user management repository, preferred default semantics
|
|||
|
are caseless substring matches.
|
|||
|
|
|||
|
For implementation efficiency, servers do not typically support
|
|||
|
searching on all properties. A search requesting properties that are
|
|||
|
not searchable for a particular principal will not match that
|
|||
|
principal.
|
|||
|
|
|||
|
Support for the DAV:principal-property-search report is REQUIRED.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 51]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Implementation Note: The value of a WebDAV property is a sequence
|
|||
|
of well-formed XML, and hence can include any character in the
|
|||
|
Unicode/ISO-10646 standard, that is, most known characters in
|
|||
|
human languages. Due to the idiosyncrasies of case mapping across
|
|||
|
human languages, implementation of case-insensitive matching is
|
|||
|
non-trivial. Implementors of servers that do perform substring
|
|||
|
matching are strongly encouraged to consult "The Unicode Standard"
|
|||
|
[UNICODE4], especially Section 5.18, Subsection "Caseless
|
|||
|
Matching", for guidance when implementing their case-insensitive
|
|||
|
matching algorithms.
|
|||
|
|
|||
|
Implementation Note: Some implementations of this protocol will
|
|||
|
use an LDAP repository for storage of principal metadata. The
|
|||
|
schema describing each attribute (akin to a WebDAV property) in an
|
|||
|
LDAP repository specifies whether it supports case-sensitive or
|
|||
|
caseless searching. One of the benefits of leaving the search
|
|||
|
method to the discretion of the server implementation is the
|
|||
|
default LDAP attribute search behavior can be used when
|
|||
|
implementing the DAV:principal-property-search report.
|
|||
|
|
|||
|
Marshalling:
|
|||
|
|
|||
|
The request body MUST be a DAV:principal-property-search XML
|
|||
|
element containing a search specification and an optional list of
|
|||
|
properties. For every principal that matches the search
|
|||
|
specification, the response will contain the value of the
|
|||
|
requested properties on that principal.
|
|||
|
|
|||
|
<!ELEMENT principal-property-search
|
|||
|
((property-search+), prop?, apply-to-principal-collection-set?) >
|
|||
|
|
|||
|
By default, the report searches all members (at any depth) of the
|
|||
|
collection identified by the Request-URI. If DAV:apply-to-
|
|||
|
principal-collection-set is specified in the request body, the
|
|||
|
request is applied instead to each collection identified by the
|
|||
|
DAV:principal-collection-set property of the resource identified
|
|||
|
by the Request-URI.
|
|||
|
|
|||
|
The DAV:property-search element contains a prop element
|
|||
|
enumerating the properties to be searched and a match element,
|
|||
|
containing the search string.
|
|||
|
|
|||
|
<!ELEMENT property-search (prop, match) >
|
|||
|
prop: see RFC 2518, Section 12.11
|
|||
|
|
|||
|
<!ELEMENT match #PCDATA >
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 52]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Multiple property-search elements or multiple elements within a
|
|||
|
DAV:prop element will be interpreted with a logical AND.
|
|||
|
|
|||
|
This report is only defined when the Depth header has value "0";
|
|||
|
other values result in a 400 (Bad Request) error response. Note
|
|||
|
that [RFC3253], Section 3.6, states that if the Depth header is
|
|||
|
not present, it defaults to a value of "0".
|
|||
|
|
|||
|
The response body for a successful request MUST be a
|
|||
|
DAV:multistatus XML element. In the case where there are no
|
|||
|
response elements, the returned multistatus XML element is empty.
|
|||
|
|
|||
|
multistatus: see RFC 2518, Section 12.9
|
|||
|
|
|||
|
The response body for a successful DAV:principal-property-search
|
|||
|
REPORT request MUST contain a DAV:response element for each
|
|||
|
principal whose property values satisfy the search specification
|
|||
|
given in DAV:principal-property-search.
|
|||
|
|
|||
|
If DAV:prop is specified in the request body, the properties
|
|||
|
specified in the DAV:prop element MUST be reported in the
|
|||
|
DAV:response elements.
|
|||
|
|
|||
|
Preconditions:
|
|||
|
|
|||
|
None
|
|||
|
|
|||
|
Postconditions:
|
|||
|
|
|||
|
(DAV:number-of-matches-within-limits): The number of matching
|
|||
|
principals must fall within server-specific, predefined limits.
|
|||
|
For example, this condition might be triggered if a search
|
|||
|
specification would cause the return of an extremely large number
|
|||
|
of responses.
|
|||
|
|
|||
|
9.4.1. Matching
|
|||
|
|
|||
|
There are several cases to consider when matching strings. The
|
|||
|
easiest case is when a property value is "simple" and has only
|
|||
|
character information item content (see [REC-XML-INFOSET]). For
|
|||
|
example, the search string "julian" would match the DAV:displayname
|
|||
|
property with value "Julian Reschke". Note that the on-the-wire
|
|||
|
marshaling of DAV:displayname in this case is:
|
|||
|
|
|||
|
<D:displayname xmlns:D="DAV:">Julian Reschke</D:displayname>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 53]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The name of the property is encoded into the XML element information
|
|||
|
item, and the character information item content of the property is
|
|||
|
"Julian Reschke".
|
|||
|
|
|||
|
A more complicated case occurs when properties have mixed content
|
|||
|
(that is, compound values consisting of multiple child element items,
|
|||
|
other types of information items, and character information item
|
|||
|
content). Consider the property "aprop" in the namespace "http://
|
|||
|
www.example.com/props/", marshaled as:
|
|||
|
|
|||
|
<W:aprop xmlns:W="http://www.example.com/props/">
|
|||
|
{cdata 0}<W:elem1>{cdata 1}</W:elem1>
|
|||
|
<W:elem2>{cdata 2}</W:elem2>{cdata 3}
|
|||
|
</W:aprop>
|
|||
|
|
|||
|
In this case, matching is performed on each individual contiguous
|
|||
|
sequence of character information items. In the example above, a
|
|||
|
search string would be compared to the four following strings:
|
|||
|
|
|||
|
{cdata 0}
|
|||
|
{cdata 1}
|
|||
|
{cdata 2}
|
|||
|
{cdata 3}
|
|||
|
|
|||
|
That is, four individual matches would be performed, one each for
|
|||
|
{cdata 0}, {cdata 1}, {cdata 2}, and {cdata 3}.
|
|||
|
|
|||
|
9.4.2. Example: successful DAV:principal-property-search REPORT
|
|||
|
|
|||
|
In this example, the client requests the principal URLs of all users
|
|||
|
whose DAV:displayname property contains the substring "doE" and whose
|
|||
|
"title" property in the namespace "http://BigCorp.com/ns/" (that is,
|
|||
|
their professional title) contains "Sales". In addition, the client
|
|||
|
requests five properties to be returned with the matching principals:
|
|||
|
|
|||
|
In the DAV: namespace: displayname
|
|||
|
|
|||
|
In the http://www.example.com/ns/ namespace: department, phone,
|
|||
|
office, salary
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 54]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The response shows that two principal resources meet the search
|
|||
|
specification, "John Doe" and "Zygdoebert Smith". The property
|
|||
|
"salary" in namespace "http://www.example.com/ns/" is not returned,
|
|||
|
since the principal making the request does not have sufficient
|
|||
|
access permissions to read this property.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
REPORT /users/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset=utf-8
|
|||
|
Content-Length: xxxx
|
|||
|
Depth: 0
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:principal-property-search xmlns:D="DAV:">
|
|||
|
<D:property-search>
|
|||
|
<D:prop>
|
|||
|
<D:displayname/>
|
|||
|
</D:prop>
|
|||
|
<D:match>doE</D:match>
|
|||
|
</D:property-search>
|
|||
|
<D:property-search>
|
|||
|
<D:prop xmlns:B="http://www.example.com/ns/">
|
|||
|
<B:title/>
|
|||
|
</D:prop>
|
|||
|
<D:match>Sales</D:match>
|
|||
|
</D:property-search>
|
|||
|
<D:prop xmlns:B="http://www.example.com/ns/">
|
|||
|
<D:displayname/>
|
|||
|
<B:department/>
|
|||
|
<B:phone/>
|
|||
|
<B:office/>
|
|||
|
<B:salary/>
|
|||
|
</D:prop>
|
|||
|
</D:principal-property-search>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 207 Multi-Status
|
|||
|
Content-Type: text/xml; charset=utf-8
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:multistatus xmlns:D="DAV:" xmlns:B="http://BigCorp.com/ns/">
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/users/jdoe</D:href>
|
|||
|
<D:propstat>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 55]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<D:prop>
|
|||
|
<D:displayname>John Doe</D:displayname>
|
|||
|
<B:department>Widget Sales</B:department>
|
|||
|
<B:phone>234-4567</B:phone>
|
|||
|
<B:office>209</B:office>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<B:salary/>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 403 Forbidden</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
<D:response>
|
|||
|
<D:href>http://www.example.com/users/zsmith</D:href>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<D:displayname>Zygdoebert Smith</D:displayname>
|
|||
|
<B:department>Gadget Sales</B:department>
|
|||
|
<B:phone>234-7654</B:phone>
|
|||
|
<B:office>114</B:office>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 200 OK</D:status>
|
|||
|
</D:propstat>
|
|||
|
<D:propstat>
|
|||
|
<D:prop>
|
|||
|
<B:salary/>
|
|||
|
</D:prop>
|
|||
|
<D:status>HTTP/1.1 403 Forbidden</D:status>
|
|||
|
</D:propstat>
|
|||
|
</D:response>
|
|||
|
</D:multistatus>
|
|||
|
|
|||
|
9.5. DAV:principal-search-property-set REPORT
|
|||
|
|
|||
|
The DAV:principal-search-property-set REPORT identifies those
|
|||
|
properties that may be searched using the DAV:principal-property-
|
|||
|
search REPORT (defined in Section 9.4).
|
|||
|
|
|||
|
Servers MUST support the DAV:principal-search-property-set REPORT on
|
|||
|
all collections identified in the value of a DAV:principal-
|
|||
|
collection-set property.
|
|||
|
|
|||
|
An access control protocol user agent could use the results of the
|
|||
|
DAV:principal-search-property-set REPORT to present a query interface
|
|||
|
to the user for retrieving principals.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 56]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Support for this report is REQUIRED.
|
|||
|
|
|||
|
Implementation Note: Some clients will have only limited screen
|
|||
|
real estate for the display of lists of searchable properties. In
|
|||
|
this case, a user might appreciate having the most frequently
|
|||
|
searched properties be displayed on-screen, rather than having to
|
|||
|
scroll through a long list of searchable properties. One
|
|||
|
mechanism for signaling the most frequently searched properties is
|
|||
|
to return them towards the start of a list of properties. A
|
|||
|
client can then preferentially display the list of properties in
|
|||
|
order, increasing the likelihood that the most frequently searched
|
|||
|
properties will appear on-screen, and will not require scrolling
|
|||
|
for their selection.
|
|||
|
|
|||
|
Marshalling:
|
|||
|
|
|||
|
The request body MUST be an empty DAV:principal-search-property-
|
|||
|
set XML element.
|
|||
|
|
|||
|
This report is only defined when the Depth header has value "0";
|
|||
|
other values result in a 400 (Bad Request) error response. Note
|
|||
|
that [RFC3253], Section 3.6, states that if the Depth header is
|
|||
|
not present, it defaults to a value of "0".
|
|||
|
|
|||
|
The response body MUST be a DAV:principal-search-property-set XML
|
|||
|
element, containing a DAV:principal-search-property XML element
|
|||
|
for each property that may be searched with the DAV:principal-
|
|||
|
property-search REPORT. A server MAY limit its response to just a
|
|||
|
subset of the searchable properties, such as those likely to be
|
|||
|
useful to an interactive access control client.
|
|||
|
|
|||
|
<!ELEMENT principal-search-property-set
|
|||
|
(principal-search-property*) >
|
|||
|
|
|||
|
Each DAV:principal-search-property XML element contains exactly
|
|||
|
one searchable property, and a description of the property.
|
|||
|
|
|||
|
<!ELEMENT principal-search-property (prop, description) >
|
|||
|
|
|||
|
The DAV:prop element contains one principal property on which the
|
|||
|
server is able to perform a DAV:principal-property-search REPORT.
|
|||
|
|
|||
|
prop: see RFC 2518, Section 12.11
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 57]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
The description element is a human-readable description of what
|
|||
|
information this property represents. Servers MUST indicate the
|
|||
|
human language of the description using the xml:lang attribute and
|
|||
|
SHOULD consider the HTTP Accept-Language request header when
|
|||
|
selecting one of multiple available languages.
|
|||
|
|
|||
|
<!ELEMENT description #PCDATA >
|
|||
|
|
|||
|
9.5.1. Example: DAV:principal-search-property-set REPORT
|
|||
|
|
|||
|
In this example, the client determines the set of searchable
|
|||
|
principal properties by requesting the DAV:principal-search-
|
|||
|
property-set REPORT on the root of the server's principal URL
|
|||
|
collection set, identified by http://www.example.com/users/.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
REPORT /users/ HTTP/1.1
|
|||
|
Host: www.example.com
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
Accept-Language: en, de
|
|||
|
Authorization: BASIC d2FubmFtYWs6cGFzc3dvcmQ=
|
|||
|
Depth: 0
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:principal-search-property-set xmlns:D="DAV:"/>
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Content-Type: text/xml; charset="utf-8"
|
|||
|
Content-Length: xxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:principal-search-property-set xmlns:D="DAV:">
|
|||
|
<D:principal-search-property>
|
|||
|
<D:prop>
|
|||
|
<D:displayname/>
|
|||
|
</D:prop>
|
|||
|
<D:description xml:lang="en">Full name</D:description>
|
|||
|
</D:principal-search-property>
|
|||
|
<D:principal-search-property>
|
|||
|
<D:prop xmlns:B="http://BigCorp.com/ns/">
|
|||
|
<B:title/>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 58]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
</D:prop>
|
|||
|
<D:description xml:lang="en">Job title</D:description>
|
|||
|
</D:principal-search-property>
|
|||
|
</D:principal-search-property-set>
|
|||
|
|
|||
|
10. XML Processing
|
|||
|
|
|||
|
Implementations of this specification MUST support the XML element
|
|||
|
ignore rule, as specified in Section 23.3.2 of [RFC2518], and the XML
|
|||
|
Namespace recommendation [REC-XML-NAMES].
|
|||
|
|
|||
|
Note that use of the DAV namespace is reserved for XML elements and
|
|||
|
property names defined in a standards-track or Experimental IETF RFC.
|
|||
|
|
|||
|
11. Internationalization Considerations
|
|||
|
|
|||
|
In this specification, the only human-readable content can be found
|
|||
|
in the description XML element, found within the DAV:supported-
|
|||
|
privilege-set property. This element contains a human-readable
|
|||
|
description of the capabilities controlled by a privilege. As a
|
|||
|
result, the description element must be capable of representing
|
|||
|
descriptions in multiple character sets. Since the description
|
|||
|
element is found within a WebDAV property, it is represented on the
|
|||
|
wire as XML [REC-XML], and hence can leverage XML's language tagging
|
|||
|
and character set encoding capabilities. Specifically, XML
|
|||
|
processors at minimum must be able to read XML elements encoded using
|
|||
|
the UTF-8 [RFC3629] encoding of the ISO 10646 multilingual plane.
|
|||
|
XML examples in this specification demonstrate use of the charset
|
|||
|
parameter of the Content-Type header, as defined in [RFC3023], as
|
|||
|
well as the XML "encoding" attribute, which together provide charset
|
|||
|
identification information for MIME and XML processors. Furthermore,
|
|||
|
this specification requires server implementations to tag description
|
|||
|
fields with the xml:lang attribute (see Section 2.12 of [REC-XML]),
|
|||
|
which specifies the human language of the description. Additionally,
|
|||
|
server implementations should take into account the value of the
|
|||
|
Accept-Language HTTP header to determine which description string to
|
|||
|
return.
|
|||
|
|
|||
|
For XML elements other than the description element, it is expected
|
|||
|
that implementations will treat the property names, privilege names,
|
|||
|
and values as tokens, and convert these tokens into human-readable
|
|||
|
text in the user's language and character set when displayed to a
|
|||
|
person. Only a generic WebDAV property display utility would display
|
|||
|
these values in their raw form to a human user.
|
|||
|
|
|||
|
For error reporting, we follow the convention of HTTP/1.1 status
|
|||
|
codes, including with each status code a short, English description
|
|||
|
of the code (e.g., 200 (OK)). While the possibility exists that a
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 59]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
poorly crafted user agent would display this message to a user,
|
|||
|
internationalized applications will ignore this message, and display
|
|||
|
an appropriate message in the user's language and character set.
|
|||
|
|
|||
|
Further internationalization considerations for this protocol are
|
|||
|
described in the WebDAV Distributed Authoring protocol specification
|
|||
|
[RFC2518].
|
|||
|
|
|||
|
12. Security Considerations
|
|||
|
|
|||
|
Applications and users of this access control protocol should be
|
|||
|
aware of several security considerations, detailed below. In
|
|||
|
addition to the discussion in this document, the security
|
|||
|
considerations detailed in the HTTP/1.1 specification [RFC2616], the
|
|||
|
WebDAV Distributed Authoring Protocol specification [RFC2518], and
|
|||
|
the XML Media Types specification [RFC3023] should be considered in a
|
|||
|
security analysis of this protocol.
|
|||
|
|
|||
|
12.1. Increased Risk of Compromised Users
|
|||
|
|
|||
|
In the absence of a mechanism for remotely manipulating access
|
|||
|
control lists, if a single user's authentication credentials are
|
|||
|
compromised, only those resources for which the user has access
|
|||
|
permission can be read, modified, moved, or deleted. With the
|
|||
|
introduction of this access control protocol, if a single compromised
|
|||
|
user has the ability to change ACLs for a broad range of other users
|
|||
|
(e.g., a super-user), the number of resources that could be altered
|
|||
|
by a single compromised user increases. This risk can be mitigated
|
|||
|
by limiting the number of people who have write-acl privileges across
|
|||
|
a broad range of resources.
|
|||
|
|
|||
|
12.2. Risks of the DAV:read-acl and DAV:current-user-privilege-set
|
|||
|
Privileges
|
|||
|
|
|||
|
The ability to read the access privileges (stored in the DAV:acl
|
|||
|
property), or the privileges permitted the currently authenticated
|
|||
|
user (stored in the DAV:current-user-privilege-set property) on a
|
|||
|
resource may seem innocuous, since reading an ACL cannot possibly
|
|||
|
affect the resource's state. However, if all resources have world-
|
|||
|
readable ACLs, it is possible to perform an exhaustive search for
|
|||
|
those resources that have inadvertently left themselves in a
|
|||
|
vulnerable state, such as being world-writable. In particular, the
|
|||
|
property retrieval method PROPFIND, executed with Depth infinity on
|
|||
|
an entire hierarchy, is a very efficient way to retrieve the DAV:acl
|
|||
|
or DAV:current-user-privilege-set properties. Once found, this
|
|||
|
vulnerability can be exploited by a denial of service attack in which
|
|||
|
the open resource is repeatedly overwritten. Alternately, writable
|
|||
|
resources can be modified in undesirable ways.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 60]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
To reduce this risk, read-acl privileges should not be granted to
|
|||
|
unauthenticated principals, and restrictions on read-acl and read-
|
|||
|
current-user-privilege-set privileges for authenticated principals
|
|||
|
should be carefully analyzed when deploying this protocol. Access to
|
|||
|
the current-user-privilege-set property will involve a tradeoff of
|
|||
|
usability versus security. When the current-user-privilege-set is
|
|||
|
visible, user interfaces are expected to provide enhanced information
|
|||
|
concerning permitted and restricted operations, yet this information
|
|||
|
may also indicate a vulnerability that could be exploited.
|
|||
|
Deployment of this protocol will need to evaluate this tradeoff in
|
|||
|
light of the requirements of the deployment environment.
|
|||
|
|
|||
|
12.3. No Foreknowledge of Initial ACL
|
|||
|
|
|||
|
In an effort to reduce protocol complexity, this protocol
|
|||
|
specification intentionally does not address the issue of how to
|
|||
|
manage or discover the initial ACL that is placed upon a resource
|
|||
|
when it is created. The only way to discover the initial ACL is to
|
|||
|
create a new resource, then retrieve the value of the DAV:acl
|
|||
|
property. This assumes the principal creating the resource also has
|
|||
|
been granted the DAV:read-acl privilege.
|
|||
|
|
|||
|
As a result, it is possible that a principal could create a resource,
|
|||
|
and then discover that its ACL grants privileges that are
|
|||
|
undesirable. Furthermore, this protocol makes it possible (though
|
|||
|
unlikely) that the creating principal could be unable to modify the
|
|||
|
ACL, or even delete the resource. Even when the ACL can be modified,
|
|||
|
there will be a short period of time when the resource exists with
|
|||
|
the initial ACL before its new ACL can be set.
|
|||
|
|
|||
|
Several factors mitigate this risk. Human principals are often aware
|
|||
|
of the default access permissions in their editing environments and
|
|||
|
take this into account when writing information. Furthermore,
|
|||
|
default privilege policies are usually very conservative, limiting
|
|||
|
the privileges granted by the initial ACL.
|
|||
|
|
|||
|
13. Authentication
|
|||
|
|
|||
|
Authentication mechanisms defined for use with HTTP and WebDAV also
|
|||
|
apply to this WebDAV Access Control Protocol, in particular the Basic
|
|||
|
and Digest authentication mechanisms defined in [RFC2617].
|
|||
|
Implementation of the ACL spec requires that Basic authentication, if
|
|||
|
used, MUST only be supported over secure transport such as TLS.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 61]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
14. IANA Considerations
|
|||
|
|
|||
|
This document uses the namespace defined by [RFC2518] for XML
|
|||
|
elements. That is, this specification uses the "DAV:" URI namespace,
|
|||
|
previously registered in the URI schemes registry. All other IANA
|
|||
|
considerations mentioned in [RFC2518] are also applicable to this
|
|||
|
specification.
|
|||
|
|
|||
|
15. Acknowledgements
|
|||
|
|
|||
|
This protocol is the collaborative product of the WebDAV ACL design
|
|||
|
team: Bernard Chester, Geoff Clemm, Anne Hopkins, Barry Lind, Sean
|
|||
|
Lyndersay, Eric Sedlar, Greg Stein, and Jim Whitehead. The authors
|
|||
|
are grateful for the detailed review and comments provided by Jim
|
|||
|
Amsden, Dylan Barrell, Gino Basso, Murthy Chintalapati, Lisa
|
|||
|
Dusseault, Stefan Eissing, Tim Ellison, Yaron Goland, Dennis
|
|||
|
Hamilton, Laurie Harper, Eckehard Hermann, Ron Jacobs, Chris Knight,
|
|||
|
Remy Maucherat, Larry Masinter, Joe Orton, Peter Raymond, and Keith
|
|||
|
Wannamaker. We thank Keith Wannamaker for the initial text of the
|
|||
|
principal property search sections. Prior work on WebDAV access
|
|||
|
control protocols has been performed by Yaron Goland, Paul Leach,
|
|||
|
Lisa Dusseault, Howard Palmer, and Jon Radoff. We would like to
|
|||
|
acknowledge the foundation laid for us by the authors of the DeltaV,
|
|||
|
WebDAV and HTTP protocols upon which this protocol is layered, and
|
|||
|
the invaluable feedback from the WebDAV working group.
|
|||
|
|
|||
|
16. References
|
|||
|
|
|||
|
16.1. Normative References
|
|||
|
|
|||
|
[REC-XML] Bray, T., Paoli, J., Sperberg-McQueen, C. and E.
|
|||
|
Maler, "Extensible Markup Language (XML) 1.0
|
|||
|
((Third ed)", W3C REC REC-xml-20040204, February
|
|||
|
2004, <http://www.w3.org/TR/2004/REC-xml-20040204>.
|
|||
|
|
|||
|
[REC-XML-INFOSET] Cowan, J. and R. Tobin, "XML Information Set
|
|||
|
(Second Edition)", W3C REC REC-xml-infoset-
|
|||
|
20040204, February 2004,
|
|||
|
<http://www.w3.org/TR/2004/REC-xml-infoset-
|
|||
|
20040204/>.
|
|||
|
|
|||
|
[REC-XML-NAMES] Bray, T., Hollander, D. and A. Layman, "Namespaces
|
|||
|
in XML", W3C REC REC-xml-names-19990114, January
|
|||
|
1999, <http://www.w3.org/TR/1999/REC-xml-names-
|
|||
|
19990114>.
|
|||
|
|
|||
|
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
|
|||
|
Requirement Levels", BCP 14, RFC 2119, March 1997.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 62]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
[RFC2518] Goland, Y., Whitehead, E., Faizi, A., Carter, S.
|
|||
|
and D. Jensen, "HTTP Extensions for Distributed
|
|||
|
Authoring -- WEBDAV", RFC 2518, February 1999.
|
|||
|
|
|||
|
[RFC2616] Fielding, R., Gettys, J., Mogul, J., Frystyk, H.,
|
|||
|
Masinter, L., Leach, P. and T. Berners-Lee,
|
|||
|
"Hypertext Transfer Protocol -- HTTP/1.1", RFC
|
|||
|
2616, June 1999.
|
|||
|
|
|||
|
[RFC2617] Franks, J., Hallam-Baker, P., Hostetler, J.,
|
|||
|
Lawrence, S., Leach, P., Luotonen, A. and L.
|
|||
|
Stewart, "HTTP Authentication: Basic and Digest
|
|||
|
Access Authentication", RFC 2617, June 1999.
|
|||
|
|
|||
|
[RFC3023] Murata, M., St.Laurent, S. and D. Kohn, "XML Media
|
|||
|
Types", RFC 3023, January 2001.
|
|||
|
|
|||
|
[RFC3253] Clemm, G., Amsden, J., Ellison, T., Kaler, C. and
|
|||
|
J. Whitehead, "Versioning Extensions to WebDAV",
|
|||
|
RFC 3253, March 2002.
|
|||
|
|
|||
|
[RFC3530] Shepler, S., Ed., Callaghan, B., Robinson, D.,
|
|||
|
Thurlow, R., Beame, C., Eisler, M. and D. Noveck,
|
|||
|
"Network File System (NFS) version 4 Protocol", RFC
|
|||
|
3530, April 2003.
|
|||
|
|
|||
|
[RFC3629] Yergeau, F., "UTF-8, a transformation format of ISO
|
|||
|
10646", STD 63, RFC 3629 November 2003.
|
|||
|
|
|||
|
16.2. Informative References
|
|||
|
|
|||
|
[RFC2251] Wahl, M., Howes, T. and S. Kille, "Lightweight
|
|||
|
Directory Access Protocol (v3)", RFC 2251, December
|
|||
|
1997.
|
|||
|
|
|||
|
[RFC2255] Howes, T. and M. Smith, "The LDAP URL Format", RFC
|
|||
|
2255, December 1997.
|
|||
|
|
|||
|
[UNICODE4] The Unicode Consortium, "The Unicode Standard -
|
|||
|
Version 4.0", Addison-Wesley , August 2003,
|
|||
|
<http://www.unicode.org/versions/Unicode4.0.0/>.
|
|||
|
ISBN 0321185781.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 63]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Appendix A. WebDAV XML Document Type Definition Addendum
|
|||
|
|
|||
|
All XML elements defined in this Document Type Definition (DTD)
|
|||
|
belong to the DAV namespace. This DTD should be viewed as an addendum
|
|||
|
to the DTD provided in [RFC2518], section 23.1.
|
|||
|
|
|||
|
<!-- Privileges -- (Section 3)>
|
|||
|
|
|||
|
<!ELEMENT read EMPTY>
|
|||
|
<!ELEMENT write EMPTY>
|
|||
|
<!ELEMENT write-properties EMPTY>
|
|||
|
<!ELEMENT write-content EMPTY>
|
|||
|
<!ELEMENT unlock EMPTY>
|
|||
|
<!ELEMENT read-acl EMPTY>
|
|||
|
<!ELEMENT read-current-user-privilege-set EMPTY>
|
|||
|
<!ELEMENT write-acl EMPTY>
|
|||
|
<!ELEMENT bind EMPTY>
|
|||
|
<!ELEMENT unbind EMPTY>
|
|||
|
<!ELEMENT all EMPTY>
|
|||
|
|
|||
|
<!-- Principal Properties (Section 4) -->
|
|||
|
|
|||
|
<!ELEMENT principal EMPTY>
|
|||
|
|
|||
|
<!ELEMENT alternate-URI-set (href*)>
|
|||
|
<!ELEMENT principal-URL (href)>
|
|||
|
<!ELEMENT group-member-set (href*)>
|
|||
|
<!ELEMENT group-membership (href*)>
|
|||
|
|
|||
|
<!-- Access Control Properties (Section 5) -->
|
|||
|
|
|||
|
<!-- DAV:owner Property (Section 5.1) -->
|
|||
|
|
|||
|
<!ELEMENT owner (href?)>
|
|||
|
|
|||
|
<!-- DAV:group Property (Section 5.2) -->
|
|||
|
|
|||
|
<!ELEMENT group (href?)>
|
|||
|
|
|||
|
<!-- DAV:supported-privilege-set Property (Section 5.3) -->
|
|||
|
|
|||
|
<!ELEMENT supported-privilege-set (supported-privilege*)>
|
|||
|
<!ELEMENT supported-privilege
|
|||
|
(privilege, abstract?, description, supported-privilege*)>
|
|||
|
|
|||
|
<!ELEMENT privilege ANY>
|
|||
|
<!ELEMENT abstract EMPTY>
|
|||
|
<!ELEMENT description #PCDATA>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 64]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<!-- DAV:current-user-privilege-set Property (Section 5.4) -->
|
|||
|
|
|||
|
<!ELEMENT current-user-privilege-set (privilege*)>
|
|||
|
|
|||
|
<!-- DAV:acl Property (Section 5.5) -->
|
|||
|
|
|||
|
<!ELEMENT acl (ace)* >
|
|||
|
<!ELEMENT ace ((principal | invert), (grant|deny), protected?,
|
|||
|
inherited?)>
|
|||
|
|
|||
|
<!ELEMENT principal (href)
|
|||
|
| all | authenticated | unauthenticated
|
|||
|
| property | self)>
|
|||
|
|
|||
|
<!ELEMENT all EMPTY>
|
|||
|
<!ELEMENT authenticated EMPTY>
|
|||
|
<!ELEMENT unauthenticated EMPTY>
|
|||
|
<!ELEMENT property ANY>
|
|||
|
<!ELEMENT self EMPTY>
|
|||
|
|
|||
|
<!ELEMENT invert principal>
|
|||
|
|
|||
|
<!ELEMENT grant (privilege+)>
|
|||
|
<!ELEMENT deny (privilege+)>
|
|||
|
<!ELEMENT privilege ANY>
|
|||
|
|
|||
|
<!ELEMENT protected EMPTY>
|
|||
|
|
|||
|
<!ELEMENT inherited (href)>
|
|||
|
|
|||
|
<!-- DAV:acl-restrictions Property (Section 5.6) -->
|
|||
|
|
|||
|
<!ELEMENT acl-restrictions (grant-only?, no-invert?,
|
|||
|
deny-before-grant?, required-principal?)>
|
|||
|
|
|||
|
<!ELEMENT grant-only EMPTY>
|
|||
|
<!ELEMENT no-invert EMPTY>
|
|||
|
<!ELEMENT deny-before-grant EMPTY>
|
|||
|
|
|||
|
<!ELEMENT required-principal
|
|||
|
(all? | authenticated? | unauthenticated? | self? | href*
|
|||
|
|property*)>
|
|||
|
|
|||
|
<!-- DAV:inherited-acl-set Property (Section 5.7) -->
|
|||
|
|
|||
|
<!ELEMENT inherited-acl-set (href*)>
|
|||
|
|
|||
|
<!-- DAV:principal-collection-set Property (Section 5.8) -->
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 65]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
<!ELEMENT principal-collection-set (href*)>
|
|||
|
|
|||
|
<!-- Access Control and Existing Methods (Section 7) -->
|
|||
|
|
|||
|
<!ELEMENT need-privileges (resource)* >
|
|||
|
<!ELEMENT resource ( href, privilege )
|
|||
|
|
|||
|
<!-- ACL method preconditions (Section 8.1.1) -->
|
|||
|
|
|||
|
<!ELEMENT no-ace-conflict EMPTY>
|
|||
|
<!ELEMENT no-protected-ace-conflict EMPTY>
|
|||
|
<!ELEMENT no-inherited-ace-conflict EMPTY>
|
|||
|
<!ELEMENT limited-number-of-aces EMPTY>
|
|||
|
<!ELEMENT grant-only EMPTY>
|
|||
|
<!ELEMENT no-invert EMPTY>
|
|||
|
<!ELEMENT deny-before-grant EMPTY>
|
|||
|
<!ELEMENT no-abstract EMPTY>
|
|||
|
<!ELEMENT not-supported-privilege EMPTY>
|
|||
|
<!ELEMENT missing-required-principal EMPTY>
|
|||
|
<!ELEMENT recognized-principal EMPTY>
|
|||
|
<!ELEMENT allowed-principal EMPTY>
|
|||
|
|
|||
|
<!-- REPORTs (Section 9) -->
|
|||
|
|
|||
|
<!ELEMENT acl-principal-prop-set ANY>
|
|||
|
ANY value: a sequence of one or more elements, with at most one
|
|||
|
DAV:prop element.
|
|||
|
|
|||
|
<!ELEMENT principal-match ((principal-property | self), prop?)>
|
|||
|
<!ELEMENT principal-property ANY>
|
|||
|
ANY value: an element whose value identifies a property. The
|
|||
|
expectation is the value of the named property typically contains
|
|||
|
an href element that contains the URI of a principal
|
|||
|
<!ELEMENT self EMPTY>
|
|||
|
|
|||
|
<!ELEMENT principal-property-search ((property-search+), prop?) >
|
|||
|
<!ELEMENT property-search (prop, match) >
|
|||
|
<!ELEMENT match #PCDATA >
|
|||
|
|
|||
|
<!ELEMENT principal-search-property-set (
|
|||
|
principal-search-property*) >
|
|||
|
<!ELEMENT principal-search-property (prop, description) >
|
|||
|
<!ELEMENT description #PCDATA >
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 66]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Appendix B. WebDAV Method Privilege Table (Normative)
|
|||
|
|
|||
|
The following table of WebDAV methods (as defined in RFC 2518, 2616,
|
|||
|
and 3253) clarifies which privileges are required for access for each
|
|||
|
method. Note that the privileges listed, if denied, MUST cause
|
|||
|
access to be denied. However, given that a specific implementation
|
|||
|
MAY define an additional custom privilege to control access to
|
|||
|
existing methods, having all of the indicated privileges does not
|
|||
|
mean that access will be granted. Note that lack of the indicated
|
|||
|
privileges does not imply that access will be denied, since a
|
|||
|
particular implementation may use a sub-privilege aggregated under
|
|||
|
the indicated privilege to control access. Privileges required refer
|
|||
|
to the current resource being processed unless otherwise specified.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 67]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
+---------------------------------+---------------------------------+
|
|||
|
| METHOD | PRIVILEGES |
|
|||
|
+---------------------------------+---------------------------------+
|
|||
|
| GET | <D:read> |
|
|||
|
| HEAD | <D:read> |
|
|||
|
| OPTIONS | <D:read> |
|
|||
|
| PUT (target exists) | <D:write-content> on target |
|
|||
|
| | resource |
|
|||
|
| PUT (no target exists) | <D:bind> on parent collection |
|
|||
|
| | of target |
|
|||
|
| PROPPATCH | <D:write-properties> |
|
|||
|
| ACL | <D:write-acl> |
|
|||
|
| PROPFIND | <D:read> (plus <D:read-acl> and |
|
|||
|
| | <D:read-current-user-privilege- |
|
|||
|
| | set> as needed) |
|
|||
|
| COPY (target exists) | <D:read>, <D:write-content> and |
|
|||
|
| | <D:write-properties> on target |
|
|||
|
| | resource |
|
|||
|
| COPY (no target exists) | <D:read>, <D:bind> on target |
|
|||
|
| | collection |
|
|||
|
| MOVE (no target exists) | <D:unbind> on source collection |
|
|||
|
| | and <D:bind> on target |
|
|||
|
| | collection |
|
|||
|
| MOVE (target exists) | As above, plus <D:unbind> on |
|
|||
|
| | the target collection |
|
|||
|
| DELETE | <D:unbind> on parent collection |
|
|||
|
| LOCK (target exists) | <D:write-content> |
|
|||
|
| LOCK (no target exists) | <D:bind> on parent collection |
|
|||
|
| MKCOL | <D:bind> on parent collection |
|
|||
|
| UNLOCK | <D:unlock> |
|
|||
|
| CHECKOUT | <D:write-properties> |
|
|||
|
| CHECKIN | <D:write-properties> |
|
|||
|
| REPORT | <D:read> (on all referenced |
|
|||
|
| | resources) |
|
|||
|
| VERSION-CONTROL | <D:write-properties> |
|
|||
|
| MERGE | <D:write-content> |
|
|||
|
| MKWORKSPACE | <D:write-content> on parent |
|
|||
|
| | collection |
|
|||
|
| BASELINE-CONTROL | <D:write-properties> and |
|
|||
|
| | <D:write-content> |
|
|||
|
| MKACTIVITY | <D:write-content> on parent |
|
|||
|
| | collection |
|
|||
|
+---------------------------------+---------------------------------+
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 68]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Index
|
|||
|
|
|||
|
A
|
|||
|
ACL method 40
|
|||
|
|
|||
|
C
|
|||
|
Condition Names
|
|||
|
DAV:allowed-principal (pre) 42
|
|||
|
DAV:deny-before-grant (pre) 41
|
|||
|
DAV:grant-only (pre) 41
|
|||
|
DAV:limited-number-of-aces (pre) 41
|
|||
|
DAV:missing-required-principal (pre) 42
|
|||
|
DAV:no-abstract (pre) 41
|
|||
|
DAV:no-ace-conflict (pre) 41
|
|||
|
DAV:no-inherited-ace-conflict (pre) 41
|
|||
|
DAV:no-invert (pre) 41
|
|||
|
DAV:no-protected-ace-conflict (pre) 41
|
|||
|
DAV:not-supported-privilege (pre) 42
|
|||
|
DAV:number-of-matches-within-limits (post) 48, 53
|
|||
|
DAV:recognized-principal (pre) 42
|
|||
|
|
|||
|
D
|
|||
|
DAV header
|
|||
|
compliance class 'access-control' 38
|
|||
|
DAV:acl property 23
|
|||
|
DAV:acl-principal-prop-set report 48
|
|||
|
DAV:acl-restrictions property 27
|
|||
|
DAV:all privilege 13
|
|||
|
DAV:allowed-principal precondition 42
|
|||
|
DAV:alternate-URI-set property 14
|
|||
|
DAV:bind privilege 12
|
|||
|
DAV:current-user-privilege-set property 21
|
|||
|
DAV:deny-before-grant precondition 41
|
|||
|
DAV:grant-only precondition 41
|
|||
|
DAV:group property 18
|
|||
|
DAV:group-member-set property 14
|
|||
|
DAV:group-membership property 14
|
|||
|
DAV:inherited-acl-set property 29
|
|||
|
DAV:limited-number-of-aces precondition 41
|
|||
|
DAV:missing-required-principal precondition 42
|
|||
|
DAV:no-abstract precondition 41
|
|||
|
DAV:no-ace-conflict precondition 41
|
|||
|
DAV:no-inherited-ace-conflict precondition 41
|
|||
|
DAV:no-invert precondition 41
|
|||
|
DAV:no-protected-ace-conflict precondition 41
|
|||
|
DAV:not-supported-privilege precondition 42
|
|||
|
DAV:number-of-matches-within-limits postcondition 48, 53
|
|||
|
DAV:owner property 15
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 69]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
DAV:principal resource type 13
|
|||
|
DAV:principal-collection-set property 30
|
|||
|
DAV:principal-match report 50
|
|||
|
DAV:principal-property-search 51
|
|||
|
DAV:principal-search-property-set 56
|
|||
|
DAV:principal-URL property 14
|
|||
|
DAV:read privilege 10
|
|||
|
DAV:read-acl privilege 11
|
|||
|
DAV:read-current-user-privilege-set privilege 12
|
|||
|
DAV:recognized-principal precondition 42
|
|||
|
DAV:supported-privilege-set property 18
|
|||
|
DAV:unbind privilege 12
|
|||
|
DAV:unlock privilege 11
|
|||
|
DAV:write privilege 10
|
|||
|
DAV:write-acl privilege 12
|
|||
|
DAV:write-content privilege 10
|
|||
|
DAV:write-properties privilege 10
|
|||
|
|
|||
|
M
|
|||
|
Methods
|
|||
|
ACL 40
|
|||
|
|
|||
|
P
|
|||
|
Privileges
|
|||
|
DAV:all 13
|
|||
|
DAV:bind 12
|
|||
|
DAV:read 10
|
|||
|
DAV:read-acl 11
|
|||
|
DAV:read-current-user-privilege-set 12
|
|||
|
DAV:unbind 12
|
|||
|
DAV:unlock 11
|
|||
|
DAV:write 10
|
|||
|
DAV:write-acl 12
|
|||
|
DAV:write-content 11
|
|||
|
DAV:write-properties 10
|
|||
|
Properties
|
|||
|
DAV:acl 23
|
|||
|
DAV:acl-restrictions 27
|
|||
|
DAV:alternate-URI-set 14
|
|||
|
DAV:current-user-privilege-set 21
|
|||
|
DAV:group 18
|
|||
|
DAV:group-member-set 14
|
|||
|
DAV:group-membership 14
|
|||
|
DAV:inherited-acl-set 29
|
|||
|
DAV:owner 15
|
|||
|
DAV:principal-collection-set 30
|
|||
|
DAV:principal-URL 14
|
|||
|
DAV:supported-privilege-set 18
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 70]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
R
|
|||
|
Reports
|
|||
|
DAV:acl-principal-prop-set 47
|
|||
|
DAV:principal-match 49
|
|||
|
DAV:principal-property-search 51
|
|||
|
DAV:principal-search-property-set 56
|
|||
|
Resource Types
|
|||
|
DAV:principal 13
|
|||
|
|
|||
|
Authors' Addresses
|
|||
|
|
|||
|
Geoffrey Clemm
|
|||
|
IBM
|
|||
|
20 Maguire Road
|
|||
|
Lexington, MA 02421
|
|||
|
|
|||
|
EMail: geoffrey.clemm@us.ibm.com
|
|||
|
|
|||
|
|
|||
|
Julian F. Reschke
|
|||
|
greenbytes GmbH
|
|||
|
Salzmannstrasse 152
|
|||
|
Muenster, NW 48159
|
|||
|
Germany
|
|||
|
|
|||
|
EMail: julian.reschke@greenbytes.de
|
|||
|
|
|||
|
|
|||
|
Eric Sedlar
|
|||
|
Oracle Corporation
|
|||
|
500 Oracle Parkway
|
|||
|
Redwood Shores, CA 94065
|
|||
|
|
|||
|
EMail: eric.sedlar@oracle.com
|
|||
|
|
|||
|
|
|||
|
Jim Whitehead
|
|||
|
U.C. Santa Cruz, Dept. of Computer Science
|
|||
|
1156 High Street
|
|||
|
Santa Cruz, CA 95064
|
|||
|
|
|||
|
EMail: ejw@cse.ucsc.edu
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 71]
|
|||
|
|
|||
|
RFC 3744 WebDAV Access Control Protocol May 2004
|
|||
|
|
|||
|
|
|||
|
Full Copyright Statement
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2004). This document is subject
|
|||
|
to the rights, licenses and restrictions contained in BCP 78, and
|
|||
|
except as set forth therein, the authors retain all their rights.
|
|||
|
|
|||
|
This document and the information contained herein are provided on an
|
|||
|
"AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE
|
|||
|
REPRESENTS OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE
|
|||
|
INTERNET ENGINEERING TASK FORCE DISCLAIM ALL WARRANTIES, EXPRESS OR
|
|||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF
|
|||
|
THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
|
|||
|
WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
|
|||
|
|
|||
|
Intellectual Property
|
|||
|
|
|||
|
The IETF takes no position regarding the validity or scope of any
|
|||
|
Intellectual Property Rights or other rights that might be claimed
|
|||
|
to pertain to the implementation or use of the technology
|
|||
|
described in this document or the extent to which any license
|
|||
|
under such rights might or might not be available; nor does it
|
|||
|
represent that it has made any independent effort to identify any
|
|||
|
such rights. Information on the procedures with respect to
|
|||
|
rights in RFC documents can be found in BCP 78 and BCP 79.
|
|||
|
|
|||
|
Copies of IPR disclosures made to the IETF Secretariat and any
|
|||
|
assurances of licenses to be made available, or the result of an
|
|||
|
attempt made to obtain a general license or permission for the use
|
|||
|
of such proprietary rights by implementers or users of this
|
|||
|
specification can be obtained from the IETF on-line IPR repository
|
|||
|
at http://www.ietf.org/ipr.
|
|||
|
|
|||
|
The IETF invites any interested party to bring to its attention
|
|||
|
any copyrights, patents or patent applications, or other
|
|||
|
proprietary rights that may cover technology that may be required
|
|||
|
to implement this standard. Please address the information to the
|
|||
|
IETF at ietf-ipr@ietf.org.
|
|||
|
|
|||
|
Acknowledgement
|
|||
|
|
|||
|
Funding for the RFC Editor function is currently provided by the
|
|||
|
Internet Society.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Clemm, et al. Standards Track [Page 72]
|
|||
|
|