mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2025-01-15 19:24:28 +00:00
675 lines
19 KiB
Text
675 lines
19 KiB
Text
|
||
|
||
|
||
|
||
|
||
|
||
Network Working Group C. Daboo
|
||
Request for Comments: 5689 Apple Inc.
|
||
Updates: 4791, 4918 September 2009
|
||
Category: Standards Track
|
||
|
||
|
||
Extended MKCOL for Web Distributed Authoring and Versioning (WebDAV)
|
||
|
||
Abstract
|
||
|
||
This specification extends the Web Distributed Authoring and
|
||
Versioning (WebDAV) MKCOL (Make Collection) method to allow
|
||
collections of arbitrary resourcetype to be created and to allow
|
||
properties to be set at the same time.
|
||
|
||
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) 2009 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. Code Components extracted from this document must
|
||
include Simplified BSD License text as described in Section 4.e of
|
||
the Trust Legal Provisions and are provided without warranty as
|
||
described in the BSD License.
|
||
|
||
This document may contain material from IETF Documents or IETF
|
||
Contributions published or made publicly available before November
|
||
10, 2008. The person(s) controlling the copyright in some of this
|
||
material may not have granted the IETF Trust the right to allow
|
||
modifications of such material outside the IETF Standards Process.
|
||
Without obtaining an adequate license from the person(s) controlling
|
||
the copyright in such materials, this document may not be modified
|
||
outside the IETF Standards Process, and derivative works of it may
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 1]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
not be created outside the IETF Standards Process, except to format
|
||
it for publication as an RFC or to translate it into languages other
|
||
than English.
|
||
|
||
Table of Contents
|
||
|
||
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 3
|
||
2. Conventions Used in This Document . . . . . . . . . . . . . . 3
|
||
3. WebDAV Extended MKCOL . . . . . . . . . . . . . . . . . . . . 4
|
||
3.1. Extended MKCOL Support . . . . . . . . . . . . . . . . . . 5
|
||
3.1.1. Example: Using OPTIONS for the Discovery of
|
||
Support for Extended MKCOL . . . . . . . . . . . . . . 5
|
||
3.2. Status Codes . . . . . . . . . . . . . . . . . . . . . . . 5
|
||
3.3. Additional Precondition for Extended MKCOL . . . . . . . . 5
|
||
3.4. Example: Successful Extended MKCOL Request . . . . . . . . 6
|
||
3.5. Example: Unsuccessful Extended MKCOL Request . . . . . . . 6
|
||
4. Using Extended MKCOL as an Alternative for MKxxx Methods . . . 8
|
||
4.1. MKCALENDAR Alternative . . . . . . . . . . . . . . . . . . 8
|
||
4.1.1. Example: Using MKCOL Instead of MKCALENDAR . . . . . . 8
|
||
5. XML Element Definitions . . . . . . . . . . . . . . . . . . . 10
|
||
5.1. mkcol XML Element . . . . . . . . . . . . . . . . . . . . 10
|
||
5.2. mkcol-response XML Element . . . . . . . . . . . . . . . . 10
|
||
6. Security Considerations . . . . . . . . . . . . . . . . . . . 11
|
||
7. Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . 11
|
||
8. Normative References . . . . . . . . . . . . . . . . . . . . . 11
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 2]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
1. Introduction
|
||
|
||
WebDAV [RFC4918] defines the HTTP [RFC2616] method MKCOL. This
|
||
method is used to create WebDAV collections on the server. However,
|
||
several WebDAV-based specifications (e.g., CalDAV [RFC4791]) define
|
||
"special" collections -- ones that are identified by additional
|
||
values in the DAV:resourcetype property assigned to the collection
|
||
resource or by other means. These "special" collections are created
|
||
by new methods (e.g., MKCALENDAR). The addition of a new MKxxx
|
||
method for each new "special" collection adds to server complexity
|
||
and is detrimental to overall reliability due to the need to make
|
||
sure intermediaries are aware of these methods.
|
||
|
||
This specification defines an extension to the WebDAV MKCOL method
|
||
that adds a request body allowing a client to specify WebDAV
|
||
properties to be set on the newly created collection or resource. In
|
||
particular, the DAV:resourcetype property can be used to create a
|
||
"special" collection; alternatively, other properties can be used to
|
||
create a "special" resource. This avoids the need to invent new
|
||
MKxxx methods.
|
||
|
||
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].
|
||
|
||
This document uses XML DTD fragments (Section 3.2 of
|
||
[W3C.REC-xml-20081126]) as a purely notational convention. WebDAV
|
||
request and response bodies cannot be validated by a DTD due to the
|
||
specific extensibility rules defined in Section 17 of [RFC4918] and
|
||
due to the fact that all XML elements defined by this specification
|
||
use the XML namespace name "DAV:". In particular:
|
||
|
||
1. Element names use the "DAV:" namespace.
|
||
|
||
2. Element ordering is irrelevant unless explicitly stated.
|
||
|
||
3. Extension elements (elements not already defined as valid child
|
||
elements) may be added anywhere, except when explicitly stated
|
||
otherwise.
|
||
|
||
4. Extension attributes (attributes not already defined as valid for
|
||
this element) may be added anywhere, except when explicitly
|
||
stated otherwise.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 3]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
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 type.
|
||
|
||
This document inherits, and sometimes extends, DTD productions from
|
||
Section 14 of [RFC4918].
|
||
|
||
3. WebDAV Extended MKCOL
|
||
|
||
The WebDAV MKCOL request is extended to allow the inclusion of a
|
||
request body. The request body is an XML document containing a
|
||
single DAV:mkcol XML element as the root element. The Content-Type
|
||
request header MUST be set appropriately for an XML body (e.g., set
|
||
to "text/xml" or "application/xml"). XML-typed bodies for an MKCOL
|
||
request that do not have DAV:mkcol as the root element are reserved
|
||
for future usage.
|
||
|
||
One or more DAV:set XML elements may be included in the DAV:mkcol XML
|
||
element to allow setting properties on the collection as it is
|
||
created. In particular, to create a collection of a particular type,
|
||
the DAV:resourcetype XML element MUST be included in a DAV:set XML
|
||
element and MUST specify the expected resource type elements for the
|
||
new resource, which MUST include the DAV:collection element that
|
||
needs to be present for any WebDAV collection.
|
||
|
||
As per the PROPPATCH method (Section 9.2 of [RFC4918]), servers MUST
|
||
process any DAV:set instructions in document order (an exception to
|
||
the normal rule that ordering is irrelevant). If any one instruction
|
||
fails to execute successfully, all instructions MUST fail (i.e.,
|
||
either all succeed or all fail). Thus, if any error occurs during
|
||
processing, all executed instructions MUST be undone and a proper
|
||
error result returned. Failure to set a property value on the
|
||
collection MUST result in a failure of the overall MKCOL request --
|
||
i.e., the collection is not created.
|
||
|
||
The response to an extended MKCOL request MUST be an XML document
|
||
containing a single DAV:mkcol-response XML element, which MUST
|
||
contain DAV:propstat XML elements with the status of each property
|
||
when the request fails due to a failure to set one or more of the
|
||
properties specified in the request body. The server MAY return a
|
||
response body in the case where the request is successful, indicating
|
||
success for setting each property specified in the request body.
|
||
When an empty response body is returned with a success request status
|
||
code, the client can assume that all properties were set.
|
||
|
||
In all other respects, the behavior of the extended MKCOL request
|
||
follows that of the standard MKCOL request.
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 4]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
3.1. Extended MKCOL Support
|
||
|
||
A server supporting the features described in this document MUST
|
||
include "extended-mkcol" as a field in the DAV response header from
|
||
an OPTIONS request on any URI that supports use of the extended MKCOL
|
||
method.
|
||
|
||
3.1.1. Example: Using OPTIONS for the Discovery of Support for Extended
|
||
MKCOL
|
||
|
||
>> Request <<
|
||
|
||
OPTIONS /addressbooks/users/ HTTP/1.1
|
||
Host: addressbook.example.com
|
||
|
||
>> Response <<
|
||
|
||
HTTP/1.1 200 OK
|
||
Allow: OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, COPY, MOVE
|
||
Allow: MKCOL, PROPFIND, PROPPATCH, LOCK, UNLOCK, REPORT, ACL
|
||
DAV: 1, 2, 3, access-control, extended-mkcol
|
||
Date: Sat, 11 Nov 2006 09:32:12 GMT
|
||
Content-Length: 0
|
||
|
||
3.2. Status Codes
|
||
|
||
As per Section 9.3.1 of [RFC4918].
|
||
|
||
3.3. Additional Precondition for Extended MKCOL
|
||
|
||
WebDAV ([RFC4918], Section 16) defines preconditions and
|
||
postconditions for request behavior. This specification adds the
|
||
following precondition for the extended MKCOL request.
|
||
|
||
Name: valid-resourcetype
|
||
|
||
Namespace: DAV:
|
||
|
||
Use with: Typically 403 (Forbidden)
|
||
|
||
Purpose: (precondition) -- The server MUST support the specified
|
||
resourcetype value for the specified collection.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 5]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
3.4. Example: Successful Extended MKCOL Request
|
||
|
||
This example shows how the extended MKCOL request is used to create a
|
||
collection of a fictitious type "special-resource". The response
|
||
body is empty as the request completed successfully.
|
||
|
||
>> Request <<
|
||
|
||
MKCOL /home/special/ HTTP/1.1
|
||
Host: special.example.com
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<D:mkcol xmlns:D="DAV:"
|
||
xmlns:E="http://example.com/ns/">
|
||
<D:set>
|
||
<D:prop>
|
||
<D:resourcetype>
|
||
<D:collection/>
|
||
<E:special-resource/>
|
||
</D:resourcetype>
|
||
<D:displayname>Special Resource</D:displayname>
|
||
</D:prop>
|
||
</D:set>
|
||
</D:mkcol>
|
||
|
||
>> Response <<
|
||
|
||
HTTP/1.1 201 Created
|
||
Cache-Control: no-cache
|
||
Date: Sat, 11 Nov 2006 09:32:12 GMT
|
||
|
||
3.5. Example: Unsuccessful Extended MKCOL Request
|
||
|
||
This example shows an attempt to use the extended MKCOL request to
|
||
create a collection of a fictitious type "special-resource", which is
|
||
not actually supported by the server. The response body shows that
|
||
an error occurred specifically with the DAV:resourcetype property.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 6]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
>> Request <<
|
||
|
||
MKCOL /home/special/ HTTP/1.1
|
||
Host: special.example.com
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<D:mkcol xmlns:D="DAV:"
|
||
xmlns:E="http://example.com/ns/">
|
||
<D:set>
|
||
<D:prop>
|
||
<D:resourcetype>
|
||
<D:collection/>
|
||
<E:special-resource/>
|
||
</D:resourcetype>
|
||
<D:displayname>Special Resource</D:displayname>
|
||
</D:prop>
|
||
</D:set>
|
||
</D:mkcol>
|
||
|
||
>> Response <<
|
||
|
||
HTTP/1.1 403 Forbidden
|
||
Cache-Control: no-cache
|
||
Date: Sat, 11 Nov 2006 09:32:12 GMT
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<D:mkcol-response xmlns:D="DAV:">
|
||
<D:propstat>
|
||
<D:prop>
|
||
<D:resourcetype/>
|
||
</D:prop>
|
||
<D:status>HTTP/1.1 403 Forbidden</D:status>
|
||
<D:error><D:valid-resourcetype /></D:error>
|
||
<D:responsedescription>Resource type is not
|
||
supported by this server</D:responsedescription>
|
||
</D:propstat>
|
||
<D:propstat>
|
||
<D:prop>
|
||
<D:displayname/>
|
||
</D:prop>
|
||
<D:status>HTTP/1.1 424 Failed Dependency</D:status>
|
||
</D:propstat>
|
||
</D:mkcol-response>
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 7]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
4. Using Extended MKCOL as an Alternative for MKxxx Methods
|
||
|
||
One of the goals of this extension is to eliminate the need for other
|
||
extensions to define their own variant of MKCOL to create the special
|
||
collections they need. This extension can be used as an alternative
|
||
to existing MKxxx methods in other extensions as detailed below. If
|
||
a server supports this extension and the other extension listed, then
|
||
the server MUST support use of the extended MKCOL method to achieve
|
||
the same result as the MKxxx method of the other extension.
|
||
|
||
4.1. MKCALENDAR Alternative
|
||
|
||
CalDAV defines the MKCALENDAR method to create a calendar collection
|
||
as well as to set properties during creation (Section 5.3.1 of
|
||
[RFC4791]).
|
||
|
||
The extended MKCOL method can be used instead by specifying both DAV:
|
||
collection and CALDAV:calendar-collection XML elements in the DAV:
|
||
resourcetype property, set during the extended MKCOL request.
|
||
|
||
4.1.1. Example: Using MKCOL Instead of MKCALENDAR
|
||
|
||
The first example below shows an MKCALENDAR request containing a
|
||
CALDAV:mkcalendar XML element in the request body and returning a
|
||
CALDAV:mkcalendar-response XML element in the response body.
|
||
|
||
>> MKCALENDAR Request <<
|
||
|
||
MKCALENDAR /home/lisa/calendars/events/ HTTP/1.1
|
||
Host: calendar.example.com
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<C:mkcalendar xmlns:D="DAV:"
|
||
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
||
<D:set>
|
||
<D:prop>
|
||
<D:displayname>Lisa's Events</D:displayname>
|
||
</D:prop>
|
||
</D:set>
|
||
</C:mkcalendar>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 8]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
>> MKCALENDAR Response <<
|
||
|
||
HTTP/1.1 201 Created
|
||
Cache-Control: no-cache
|
||
Date: Sat, 11 Nov 2006 09:32:12 GMT
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<C:mkcalendar-response xmlns:D="DAV:"
|
||
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
||
<D:propstat>
|
||
<D:prop>
|
||
<D:displayname/>
|
||
</D:prop>
|
||
<D:status>HTTP/1.1 200 OK</D:status>
|
||
</D:propstat>
|
||
</C:mkcalendar-response>
|
||
|
||
The second example shows the equivalent extended MKCOL request with
|
||
the same request and response XML elements.
|
||
|
||
>> MKCOL Request <<
|
||
|
||
MKCOL /home/lisa/calendars/events/ HTTP/1.1
|
||
Host: calendar.example.com
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<D:mkcol xmlns:D="DAV:"
|
||
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
||
<D:set>
|
||
<D:prop>
|
||
<D:resourcetype>
|
||
<D:collection/>
|
||
<C:calendar/>
|
||
</D:resourcetype>
|
||
<D:displayname>Lisa's Events</D:displayname>
|
||
</D:prop>
|
||
</D:set>
|
||
</D:mkcol>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 9]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
>> MKCOL Response <<
|
||
|
||
HTTP/1.1 201 Created
|
||
Cache-Control: no-cache
|
||
Date: Sat, 11 Nov 2006 09:32:12 GMT
|
||
Content-Type: application/xml; charset="utf-8"
|
||
Content-Length: xxxx
|
||
|
||
<?xml version="1.0" encoding="utf-8" ?>
|
||
<D:mkcol-response xmlns:D="DAV:"
|
||
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
||
<D:propstat>
|
||
<D:prop>
|
||
<D:resourcetype/>
|
||
<D:displayname/>
|
||
</D:prop>
|
||
<D:status>HTTP/1.1 200 OK</D:status>
|
||
</D:propstat>
|
||
</D:mkcol-response>
|
||
|
||
5. XML Element Definitions
|
||
|
||
5.1. mkcol XML Element
|
||
|
||
Name: mkcol
|
||
|
||
Namespace: DAV:
|
||
|
||
Purpose: Used in a request to specify properties to be set in an
|
||
extended MKCOL request, as well as any additional information
|
||
needed when creating the resource.
|
||
|
||
Description: This XML element is a container for the information
|
||
required to modify the properties on a collection resource as it
|
||
is created in an extended MKCOL request.
|
||
|
||
Definition:
|
||
|
||
<!ELEMENT mkcol (set+)>
|
||
|
||
5.2. mkcol-response XML Element
|
||
|
||
Name: mkcol-response
|
||
|
||
Namespace: DAV:
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 10]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
Purpose: Used in a response to indicate the status of properties
|
||
that were set or failed to be set during an extended MKCOL
|
||
request.
|
||
|
||
Description: This XML element is a container for the information
|
||
returned about a resource that has been created in an extended
|
||
MKCOL request.
|
||
|
||
Definition:
|
||
|
||
<!ELEMENT mkcol-response (propstat+)>
|
||
|
||
6. Security Considerations
|
||
|
||
This extension does not introduce any new security concerns beyond
|
||
those already described in HTTP [RFC2616] and WebDAV [RFC4918].
|
||
|
||
7. Acknowledgments
|
||
|
||
Thanks to Bernard Desruisseaux, Mike Douglass, Alexey Melnikov,
|
||
Julian Reschke, and Simon Vaillancourt.
|
||
|
||
|
||
8. 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.
|
||
|
||
[RFC4791] Daboo, C., Desruisseaux, B., and L. Dusseault,
|
||
"Calendaring Extensions to WebDAV (CalDAV)", RFC 4791,
|
||
March 2007.
|
||
|
||
[RFC4918] Dusseault, L., "HTTP Extensions for Web Distributed
|
||
Authoring and Versioning (WebDAV)", RFC 4918, June 2007.
|
||
|
||
[W3C.REC-xml-20081126]
|
||
Maler, E., Yergeau, F., Paoli, J., Bray, T., and C.
|
||
Sperberg-McQueen, "Extensible Markup Language (XML) 1.0
|
||
(Fifth Edition)", World Wide Web Consortium
|
||
Recommendation REC-xml-20081126, November 2008,
|
||
<http://www.w3.org/TR/2008/REC-xml-20081126>.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 11]
|
||
|
||
RFC 5689 Extended MKCOL for WebDAV September 2009
|
||
|
||
|
||
Author's Address
|
||
|
||
Cyrus Daboo
|
||
Apple Inc.
|
||
1 Infinite Loop
|
||
Cupertino, CA 95014
|
||
USA
|
||
|
||
EMail: cyrus@daboo.name
|
||
URI: http://www.apple.com/
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Daboo Standards Track [Page 12]
|
||
|