mirror of
https://github.com/etesync/android
synced 2024-12-27 17:08:11 +00:00
a12942c606
* relevant RFCs go into the doc/ directory for reference purposes * read-only calendar collections are set as read-only in Android * HTTP exception refactoring to mark 4xx HTTP errors as hard sync errors (numAuthExcetions/numParseExceptions) for Android sync manager * query current-user-privilege-set for resources, detect read-only resources * show read-only resources as read-only in SelectCollectionsFragment * minor refactoring (DavProp.*)
282 lines
8.6 KiB
Plaintext
282 lines
8.6 KiB
Plaintext
|
||
|
||
|
||
Network Working Group W. Sanchez
|
||
Request for Comments: 5397 C. Daboo
|
||
Category: Standards Track Apple Inc.
|
||
December 2008
|
||
|
||
|
||
WebDAV Current Principal Extension
|
||
|
||
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) 2008 IETF Trust and the persons identified as the
|
||
document authors. All rights reserved.
|
||
|
||
This document is subject to BCP 78 and the IETF Trust's Legal
|
||
Provisions Relating to IETF Documents
|
||
(http://trustee.ietf.org/license-info) in effect on the date of
|
||
publication of this document. Please review these documents
|
||
carefully, as they describe your rights and restrictions with respect
|
||
to this document.
|
||
|
||
Abstract
|
||
|
||
This specification defines a new WebDAV property that allows clients
|
||
to quickly determine the principal corresponding to the current
|
||
authenticated user.
|
||
|
||
Table of Contents
|
||
|
||
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 2
|
||
2. Conventions Used in This Document . . . . . . . . . . . . . . . 2
|
||
3. DAV:current-user-principal . . . . . . . . . . . . . . . . . . 3
|
||
4. Security Considerations . . . . . . . . . . . . . . . . . . . . 4
|
||
5. Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . 4
|
||
6. Normative References . . . . . . . . . . . . . . . . . . . . . 4
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Sanchez & Daboo Standards Track [Page 1]
|
||
|
||
RFC 5397 WebDAV Current Principal December 2008
|
||
|
||
|
||
1. Introduction
|
||
|
||
WebDAV [RFC4918] is an extension to HTTP [RFC2616] to support
|
||
improved document authoring capabilities. The WebDAV Access Control
|
||
Protocol ("WebDAV ACL") [RFC3744] extension adds access control
|
||
capabilities to WebDAV. It introduces the concept of a "principal"
|
||
resource, which is used to represent information about authenticated
|
||
entities on the system.
|
||
|
||
Some clients have a need to determine which [RFC3744] principal a
|
||
server is associating with the currently authenticated HTTP user.
|
||
While [RFC3744] defines a DAV:current-user-privilege-set property for
|
||
retrieving the privileges granted to that principal, there is no
|
||
recommended way to identify the principal in question, which is
|
||
necessary to perform other useful operations. For example, a client
|
||
may wish to determine which groups the current user is a member of,
|
||
or modify a property of the principal resource associated with the
|
||
current user.
|
||
|
||
The DAV:principal-match REPORT provides some useful functionality,
|
||
but there are common situations where the results from that query can
|
||
be ambiguous. For example, not only is an individual user principal
|
||
returned, but also every group principal that the user is a member
|
||
of, and there is no clear way to distinguish which is which.
|
||
|
||
This specification proposes an extension to WebDAV ACL that adds a
|
||
DAV:current-user-principal property to resources under access control
|
||
on the server. This property provides a URL to a principal resource
|
||
corresponding to the currently authenticated user. This allows a
|
||
client to "bootstrap" itself by performing additional queries on the
|
||
principal resource to obtain additional information from that
|
||
resource, which is the purpose of this extension. Note that while it
|
||
is possible for multiple URLs to refer to the same principal
|
||
resource, or for multiple principal resources to correspond to a
|
||
single principal, this specification only allows for a single http(s)
|
||
URL in the DAV:current-user-principal property. If a client wishes
|
||
to obtain alternate URLs for the principal, it can query the
|
||
principal resource for this information; it is not the purpose of
|
||
this extension to provide a complete list of such URLs, but simply to
|
||
provide a means to locate a resource which contains that (and other)
|
||
information.
|
||
|
||
2. Conventions Used in This Document
|
||
|
||
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].
|
||
|
||
|
||
|
||
|
||
Sanchez & Daboo Standards Track [Page 2]
|
||
|
||
RFC 5397 WebDAV Current Principal December 2008
|
||
|
||
|
||
When XML element types in the namespace "DAV:" are referenced in this
|
||
document outside of the context of an XML fragment, the string "DAV:"
|
||
will be prefixed to the element type names.
|
||
|
||
Processing of XML by clients and servers MUST follow the rules
|
||
defined in Section 17 of WebDAV [RFC4918].
|
||
|
||
Some of the declarations refer to XML elements defined by WebDAV
|
||
[RFC4918].
|
||
|
||
3. DAV:current-user-principal
|
||
|
||
Name: current-user-principal
|
||
|
||
Namespace: DAV:
|
||
|
||
Purpose: Indicates a URL for the currently authenticated user's
|
||
principal resource on the server.
|
||
|
||
Value: A single DAV:href or DAV:unauthenticated element.
|
||
|
||
Protected: This property is computed on a per-request basis, and
|
||
therefore is protected.
|
||
|
||
Description: The DAV:current-user-principal property contains either
|
||
a DAV:href or DAV:unauthenticated XML element. The DAV:href
|
||
element contains a URL to a principal resource corresponding to
|
||
the currently authenticated user. That URL MUST be one of the
|
||
URLs in the DAV:principal-URL or DAV:alternate-URI-set properties
|
||
defined on the principal resource and MUST be an http(s) scheme
|
||
URL. When authentication has not been done or has failed, this
|
||
property MUST contain the DAV:unauthenticated pseudo-principal.
|
||
|
||
In some cases, there may be multiple principal resources
|
||
corresponding to the same authenticated principal. In that case,
|
||
the server is free to choose any one of the principal resource
|
||
URIs for the value of the DAV:current-user-principal property.
|
||
However, servers SHOULD be consistent and use the same principal
|
||
resource URI for each authenticated principal.
|
||
|
||
COPY/MOVE behavior: This property is computed on a per-request
|
||
basis, and is thus never copied or moved.
|
||
|
||
Definition:
|
||
|
||
<!ELEMENT current-user-principal (unauthenticated | href)>
|
||
<!-- href value: a URL to a principal resource -->
|
||
|
||
|
||
|
||
|
||
Sanchez & Daboo Standards Track [Page 3]
|
||
|
||
RFC 5397 WebDAV Current Principal December 2008
|
||
|
||
|
||
Example:
|
||
|
||
<D:current-user-principal xmlns:D="DAV:">
|
||
<D:href>/principals/users/cdaboo</D:href>
|
||
</D:current-user-principal>
|
||
|
||
4. Security Considerations
|
||
|
||
This specification does not introduce any additional security issues
|
||
beyond those defined for HTTP [RFC2616], WebDAV [RFC4918], and WebDAV
|
||
ACL [RFC3744].
|
||
|
||
5. Acknowledgments
|
||
|
||
This specification is based on discussions that took place within the
|
||
Calendaring and Scheduling Consortium's CalDAV Technical Committee.
|
||
The authors thank the participants of that group for their input.
|
||
|
||
The authors thank Julian Reschke for his valuable input via the
|
||
WebDAV working group mailing list.
|
||
|
||
6. Normative References
|
||
|
||
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
|
||
Requirement Levels", BCP 14, RFC 2119, March 1997.
|
||
|
||
[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.
|
||
|
||
[RFC3744] Clemm, G., Reschke, J., Sedlar, E., and J. Whitehead, "Web
|
||
Distributed Authoring and Versioning (WebDAV)
|
||
Access Control Protocol", RFC 3744, May 2004.
|
||
|
||
[RFC4918] Dusseault, L., "HTTP Extensions for Web Distributed
|
||
Authoring and Versioning (WebDAV)", RFC 4918, June 2007.
|
||
|
||
Authors' Addresses
|
||
|
||
Wilfredo Sanchez
|
||
Apple Inc.
|
||
1 Infinite Loop
|
||
Cupertino, CA 95014
|
||
USA
|
||
|
||
EMail: wsanchez@wsanchez.net
|
||
URI: http://www.apple.com/
|
||
|
||
|
||
|
||
|
||
Sanchez & Daboo Standards Track [Page 4]
|
||
|
||
RFC 5397 WebDAV Current Principal December 2008
|
||
|
||
|
||
Cyrus Daboo
|
||
Apple Inc.
|
||
1 Infinite Loop
|
||
Cupertino, CA 95014
|
||
USA
|
||
|
||
EMail: cyrus@daboo.name
|
||
URI: http://www.apple.com/
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Sanchez & Daboo Standards Track [Page 5]
|
||
|
||
|