mirror of
https://github.com/etesync/android
synced 2025-01-11 16:21:10 +00:00
4372 lines
153 KiB
Plaintext
4372 lines
153 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Internet Engineering Task Force (IETF) C. Daboo
|
|||
|
Request for Comments: 6638 Apple Inc.
|
|||
|
Updates: 4791, 5546 B. Desruisseaux
|
|||
|
Category: Standards Track Oracle
|
|||
|
ISSN: 2070-1721 June 2012
|
|||
|
|
|||
|
|
|||
|
Scheduling Extensions to CalDAV
|
|||
|
|
|||
|
Abstract
|
|||
|
|
|||
|
This document defines extensions to the Calendaring Extensions to
|
|||
|
WebDAV (CalDAV) "calendar-access" feature to specify a standard way
|
|||
|
of performing scheduling operations with iCalendar-based calendar
|
|||
|
components. This document defines the "calendar-auto-schedule"
|
|||
|
feature of CalDAV.
|
|||
|
|
|||
|
Status of This Memo
|
|||
|
|
|||
|
This is an Internet Standards Track document.
|
|||
|
|
|||
|
This document is a product of the Internet Engineering Task Force
|
|||
|
(IETF). It represents the consensus of the IETF community. It has
|
|||
|
received public review and has been approved for publication by the
|
|||
|
Internet Engineering Steering Group (IESG). Further information on
|
|||
|
Internet Standards is available in Section 2 of RFC 5741.
|
|||
|
|
|||
|
Information about the current status of this document, any errata,
|
|||
|
and how to provide feedback on it may be obtained at
|
|||
|
http://www.rfc-editor.org/info/rfc6638.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (c) 2012 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 Simplified BSD License.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 1]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
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
|
|||
|
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 ....................................................5
|
|||
|
1.1. Terminology ................................................6
|
|||
|
1.2. Notational Conventions .....................................7
|
|||
|
1.3. XML Namespaces and Processing ..............................7
|
|||
|
2. Scheduling Support ..............................................8
|
|||
|
2.1. Scheduling Outbox Collection ...............................9
|
|||
|
2.1.1. CALDAV:schedule-outbox-URL Property ................10
|
|||
|
2.2. Scheduling Inbox Collection ...............................10
|
|||
|
2.2.1. CALDAV:schedule-inbox-URL Property .................11
|
|||
|
2.3. Calendaring Reports Extensions ............................12
|
|||
|
2.4. Additional Principal Properties ...........................12
|
|||
|
2.4.1. CALDAV:calendar-user-address-set Property ..........12
|
|||
|
2.4.2. CALDAV:calendar-user-type Property .................13
|
|||
|
3. Scheduling Operations ..........................................14
|
|||
|
3.1. Identifying Scheduling Object Resources ...................14
|
|||
|
3.2. Handling Scheduling Object Resources ......................15
|
|||
|
3.2.1. Organizer Scheduling Object Resources ..............15
|
|||
|
3.2.1.1. Create ....................................16
|
|||
|
3.2.1.2. Modify ....................................17
|
|||
|
3.2.1.3. Remove ....................................18
|
|||
|
3.2.2. Attendee Scheduling Object Resources ...............18
|
|||
|
3.2.2.1. Allowed "Attendee" Changes ................18
|
|||
|
3.2.2.2. Create ....................................19
|
|||
|
3.2.2.3. Modify ....................................20
|
|||
|
3.2.2.4. Remove ....................................21
|
|||
|
3.2.3. HTTP Methods .......................................21
|
|||
|
3.2.3.1. PUT .......................................22
|
|||
|
3.2.3.2. DELETE ....................................22
|
|||
|
3.2.3.3. COPY ......................................23
|
|||
|
3.2.3.4. MOVE ......................................24
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 2]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.4. Additional Method Preconditions ....................24
|
|||
|
3.2.4.1. CALDAV:unique-scheduling-object-resource
|
|||
|
Precondition ..............................24
|
|||
|
3.2.4.2. CALDAV:same-organizer-in-all-components
|
|||
|
Precondition ..............................25
|
|||
|
3.2.4.3. CALDAV:allowed-organizer-scheduling-
|
|||
|
object-change Precondition .............25
|
|||
|
3.2.4.4. CALDAV:allowed-attendee-scheduling-
|
|||
|
object-change Precondition .............26
|
|||
|
3.2.5. DTSTAMP and SEQUENCE Properties ....................26
|
|||
|
3.2.6. Restrict Recurrence Instances Sent to "Attendees" ..27
|
|||
|
3.2.7. Forcing the Server to Send a Scheduling Message ....27
|
|||
|
3.2.8. "Attendee" Participation Status ....................28
|
|||
|
3.2.9. Schedule Status Values .............................29
|
|||
|
3.2.10. Avoiding Conflicts when Updating Scheduling Object
|
|||
|
Resources .........................................31
|
|||
|
3.2.10.1. PUT .....................................33
|
|||
|
3.2.10.2. DELETE, COPY, or MOVE ...................33
|
|||
|
4. Processing Incoming Scheduling Messages ........................34
|
|||
|
4.1. Processing "Organizer" Requests, Additions, and
|
|||
|
Cancellations .............................................34
|
|||
|
4.2. Processing "Attendee" Replies .............................35
|
|||
|
4.3. Default Calendar Collection ...............................35
|
|||
|
4.3.1. Additional Method Preconditions ....................36
|
|||
|
4.3.1.1. CALDAV:default-calendar-needed
|
|||
|
Precondition ..............................36
|
|||
|
4.3.1.2. CALDAV:valid-schedule-default-calendar-URL
|
|||
|
Precondition ..............................36
|
|||
|
5. Request for Busy Time Information ..............................37
|
|||
|
5.1. Status Codes ..............................................38
|
|||
|
5.2. Additional Method Preconditions ...........................38
|
|||
|
5.2.1. CALDAV:valid-scheduling-message Precondition .......38
|
|||
|
5.2.2. CALDAV:valid-organizer Precondition ................39
|
|||
|
6. Scheduling Privileges ..........................................39
|
|||
|
6.1. Privileges on Scheduling Inbox Collections ................39
|
|||
|
6.1.1. CALDAV:schedule-deliver Privilege ..................40
|
|||
|
6.1.2. CALDAV:schedule-deliver-invite Privilege ...........40
|
|||
|
6.1.3. CALDAV:schedule-deliver-reply Privilege ............40
|
|||
|
6.1.4. CALDAV:schedule-query-freebusy Privilege ...........40
|
|||
|
6.2. Privileges on Scheduling Outbox Collections ...............40
|
|||
|
6.2.1. CALDAV:schedule-send Privilege .....................41
|
|||
|
6.2.2. CALDAV:schedule-send-invite Privilege ..............41
|
|||
|
6.2.3. CALDAV:schedule-send-reply Privilege ...............41
|
|||
|
6.2.4. CALDAV:schedule-send-freebusy Privilege ............41
|
|||
|
6.3. Aggregation of Scheduling Privileges ......................42
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 3]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
7. Additional iCalendar Property Parameters .......................42
|
|||
|
7.1. Schedule Agent Parameter ..................................42
|
|||
|
7.2. Schedule Force Send Parameter .............................44
|
|||
|
7.3. Schedule Status Parameter .................................45
|
|||
|
8. Additional Message Header Fields ...............................46
|
|||
|
8.1. Schedule-Reply Request Header .............................46
|
|||
|
8.2. Schedule-Tag Response Header ..............................46
|
|||
|
8.3. If-Schedule-Tag-Match Request Header ......................47
|
|||
|
9. Additional WebDAV Properties ...................................47
|
|||
|
9.1. CALDAV:schedule-calendar-transp Property ..................47
|
|||
|
9.2. CALDAV:schedule-default-calendar-URL Property .............48
|
|||
|
9.3. CALDAV:schedule-tag Property ..............................49
|
|||
|
10. XML Element Definitions .......................................50
|
|||
|
10.1. CALDAV:schedule-response XML Element .....................50
|
|||
|
10.2. CALDAV:response XML Element ..............................50
|
|||
|
10.3. CALDAV:recipient XML Element .............................50
|
|||
|
10.4. CALDAV:request-status XML Element ........................51
|
|||
|
11. Security Considerations .......................................51
|
|||
|
11.1. Preventing Denial-of-Service Attacks .....................51
|
|||
|
11.2. Verifying Scheduling Operations ..........................52
|
|||
|
11.3. Verifying Busy Time Information Requests .................52
|
|||
|
11.4. Privacy Issues ...........................................53
|
|||
|
11.5. Mitigation of iTIP Threats ...............................53
|
|||
|
12. IANA Considerations ...........................................54
|
|||
|
12.1. Message Header Field Registrations .......................54
|
|||
|
12.1.1. Schedule-Reply ....................................54
|
|||
|
12.1.2. Schedule-Tag ......................................54
|
|||
|
12.1.3. If-Schedule-Tag-Match .............................54
|
|||
|
12.2. iCalendar Property Parameter Registrations ...............55
|
|||
|
12.3. iCalendar REQUEST-STATUS Value Registrations .............55
|
|||
|
12.4. Additional iCalendar Elements Registries .................55
|
|||
|
12.4.1. Schedule Agent Values Registry ....................56
|
|||
|
12.4.2. Schedule Force Send Values Registry ...............56
|
|||
|
13. Acknowledgements ..............................................56
|
|||
|
14. References ....................................................57
|
|||
|
14.1. Normative References .....................................57
|
|||
|
14.2. Informative References ...................................58
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 4]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Appendix A. Scheduling Privileges Summary .........................59
|
|||
|
A.1. Scheduling Inbox Privileges ................................59
|
|||
|
A.2. Scheduling Outbox Privileges ...............................60
|
|||
|
Appendix B. Example Scheduling Operations .........................60
|
|||
|
B.1. Example: "Organizer" Inviting Multiple "Attendees" .........61
|
|||
|
B.2. Example: "Attendee" Receiving an Invitation ................63
|
|||
|
B.3. Example: "Attendee" Replying to an Invitation ..............64
|
|||
|
B.4. Example: "Organizer" Receiving a Reply to an Invitation ....66
|
|||
|
B.5. Example: "Organizer" Requesting Busy Time Information ......69
|
|||
|
B.6. Example: User Attempting to Invite "Attendee" on
|
|||
|
Behalf of "Organizer" ......................................71
|
|||
|
B.7. Example: "Attendee" Declining an Instance of a
|
|||
|
Recurring Event ............................................72
|
|||
|
B.8. Example: "Attendee" Removing an Instance of a
|
|||
|
Recurring Event ............................................75
|
|||
|
|
|||
|
1. Introduction
|
|||
|
|
|||
|
This document specifies extensions to the CalDAV "calendar-access"
|
|||
|
[RFC4791] feature to enable scheduling of iCalendar-based [RFC5545]
|
|||
|
calendar components between calendar users.
|
|||
|
|
|||
|
This extension leverages the scheduling methods defined in the
|
|||
|
iCalendar Transport-independent Interoperability Protocol (iTIP)
|
|||
|
[RFC5546] to permit calendar users to perform scheduling operations
|
|||
|
such as schedule, reschedule, respond to scheduling request, or
|
|||
|
cancel calendar components, as well as search for busy time
|
|||
|
information. However, the following iTIP [RFC5546] features are not
|
|||
|
covered: publishing, countering, delegating, refreshing, and
|
|||
|
forwarding calendar components, as well as replacing the "Organizer"
|
|||
|
of a calendar component. It is expected that future extensions will
|
|||
|
be developed to address these.
|
|||
|
|
|||
|
This specification defines a client/server scheduling protocol, where
|
|||
|
the server is made responsible for sending scheduling messages and
|
|||
|
processing incoming scheduling messages. The client operations of
|
|||
|
creating, modifying, or deleting a calendar component in a calendar
|
|||
|
are enough to trigger the server to deliver the necessary scheduling
|
|||
|
messages to the appropriate calendar users. This approach is
|
|||
|
sometimes referred to as "implicit scheduling".
|
|||
|
|
|||
|
This specification only addresses how scheduling occurs with users on
|
|||
|
a single system (i.e., scheduling between CalDAV servers, or some
|
|||
|
other calendaring and scheduling system, is not defined). However,
|
|||
|
this specification is compatible with servers being able to send or
|
|||
|
receive scheduling messages with "external" users (e.g., using the
|
|||
|
iCalendar Message-Based Interoperability Protocol (iMIP) [RFC6047]).
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 5]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Section 3 defines the automated "Scheduling Operations" that allow a
|
|||
|
client to store iCalendar data on a CalDAV server, with the server
|
|||
|
taking specific actions in response. One of three scheduling
|
|||
|
operations can take place -- "create", "modify", or "remove", based
|
|||
|
on the HTTP method used for the request -- in addition to a
|
|||
|
comparison between any existing and any new iCalendar data.
|
|||
|
|
|||
|
Section 4 defines how the server processes scheduling messages sent
|
|||
|
as the result of a scheduling operation.
|
|||
|
|
|||
|
Section 5 defines how freebusy requests with an immediate response
|
|||
|
are accomplished.
|
|||
|
|
|||
|
Section 6 defines access control privileges for the scheduling
|
|||
|
operations defined in this specification.
|
|||
|
|
|||
|
For the majority of the following discussion, scheduling of events
|
|||
|
will be discussed. However, scheduling of to-dos is also fully
|
|||
|
supported by this specification.
|
|||
|
|
|||
|
This specification has been under development for a number of years,
|
|||
|
and most current implementations of CalDAV support it. With the
|
|||
|
publication of this document, it is expected that all new CalDAV
|
|||
|
implementations will support it by default. Interoperability tests
|
|||
|
have been performed regularly. Significant issues with incompatible
|
|||
|
CalDAV implementations are not anticipated.
|
|||
|
|
|||
|
1.1. Terminology
|
|||
|
|
|||
|
This specification reuses much of the same terminology as iCalendar
|
|||
|
[RFC5545], iTIP [RFC5546], WebDAV [RFC4918], and CalDAV [RFC4791].
|
|||
|
Additional terms used by this specification are as follows:
|
|||
|
|
|||
|
Scheduling object resource: A calendar object resource contained in
|
|||
|
a calendar collection for which the server will take care of
|
|||
|
sending scheduling messages on behalf of the owner of the calendar
|
|||
|
collection.
|
|||
|
|
|||
|
Organizer scheduling object resource: A scheduling object resource
|
|||
|
owned by the "Organizer".
|
|||
|
|
|||
|
Attendee scheduling object resource: A scheduling object resource
|
|||
|
owned by an "Attendee".
|
|||
|
|
|||
|
Scheduling operation: Add, change, or remove operations on a
|
|||
|
scheduling object resource for which the server will deliver
|
|||
|
scheduling messages to other calendar users.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 6]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Scheduling message: A calendar object that describes a scheduling
|
|||
|
operation such as schedule, reschedule, reply, or cancel.
|
|||
|
|
|||
|
Scheduling Outbox collection: A resource at which busy time
|
|||
|
information requests are targeted.
|
|||
|
|
|||
|
Scheduling Inbox collection: A collection in which incoming
|
|||
|
scheduling messages are delivered.
|
|||
|
|
|||
|
1.2. Notational Conventions
|
|||
|
|
|||
|
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].
|
|||
|
|
|||
|
The Augmented BNF (ABNF) syntax used by this document to specify the
|
|||
|
format definition of new iCalendar elements is defined in [RFC5234].
|
|||
|
|
|||
|
The ABNF syntax used by this document to specify the format
|
|||
|
definition of new message header fields to be used with the HTTP/1.1
|
|||
|
protocol is described in Section 2.1 of [RFC2616]. Since this
|
|||
|
Augmented BNF uses the basic production rules provided in Section 2.2
|
|||
|
of [RFC2616], these rules apply to this document as well.
|
|||
|
|
|||
|
The term "protected" is used in the Conformance field of WebDAV
|
|||
|
property definitions as defined in Section 15 of [RFC4918].
|
|||
|
|
|||
|
Calendaring and scheduling roles are referred to in quoted-strings of
|
|||
|
text with the first character of each word in uppercase. For
|
|||
|
example, "Organizer" refers to a role of a calendar user within the
|
|||
|
scheduling protocol defined by [RFC5546].
|
|||
|
|
|||
|
1.3. XML Namespaces and Processing
|
|||
|
|
|||
|
This document uses XML DTD fragments ([W3C.REC-xml-20081126],
|
|||
|
Section 3.2) 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 that specification use the XML
|
|||
|
namespace name "DAV:". In particular,
|
|||
|
|
|||
|
1. element names use the "DAV:" namespace,
|
|||
|
|
|||
|
2. element ordering is irrelevant unless explicitly stated,
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 7]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3. extension elements (elements not already defined as valid child
|
|||
|
elements) can be added anywhere, except when explicitly stated
|
|||
|
otherwise, and
|
|||
|
|
|||
|
4. extension attributes (attributes not already defined as valid for
|
|||
|
this element) can be added anywhere, except when explicitly
|
|||
|
stated otherwise.
|
|||
|
|
|||
|
The XML elements specified in this document are defined in the
|
|||
|
"urn:ietf:params:xml:ns:caldav" XML namespace registered by CalDAV
|
|||
|
[RFC4791].
|
|||
|
|
|||
|
When XML element types in the namespaces "DAV:" and
|
|||
|
"urn:ietf:params:xml:ns:caldav" are referenced in this document
|
|||
|
outside of the context of an XML fragment, the strings "DAV:" and
|
|||
|
"CALDAV:" will be prefixed to the element types, respectively.
|
|||
|
|
|||
|
This document inherits, and sometimes extends, DTD productions from
|
|||
|
Section 14 of [RFC4918].
|
|||
|
|
|||
|
Also note that some CalDAV XML element names are identical to WebDAV
|
|||
|
XML element names, though their namespace differs. Care needs to be
|
|||
|
taken not to confuse the two sets of names.
|
|||
|
|
|||
|
2. Scheduling Support
|
|||
|
|
|||
|
A server that supports the features described in this document is
|
|||
|
REQUIRED to support the CalDAV "calendar-access" [RFC4791] feature.
|
|||
|
Servers include "calendar-auto-schedule" as a field in the DAV
|
|||
|
response header from an OPTIONS request on any resource that supports
|
|||
|
any scheduling operations, properties, privileges, or methods.
|
|||
|
|
|||
|
This specification introduces new collection resource types that are
|
|||
|
used to manage scheduling object resources, and scheduling privileges
|
|||
|
(as per Section 6), as well as provide scheduling functionality. It
|
|||
|
is the server's responsibility to create these collection resources,
|
|||
|
and clients have no way to create or delete them.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 8]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
2.1. Scheduling Outbox Collection
|
|||
|
|
|||
|
A scheduling Outbox collection is used as the target for busy time
|
|||
|
information requests, and to manage privileges that apply to outgoing
|
|||
|
scheduling requests.
|
|||
|
|
|||
|
A scheduling Outbox collection MUST report the DAV:collection and
|
|||
|
CALDAV:schedule-outbox XML elements in the value of the DAV:
|
|||
|
resourcetype property. The element type declaration for CALDAV:
|
|||
|
schedule-outbox is
|
|||
|
|
|||
|
<!ELEMENT schedule-outbox EMPTY>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<D:resourcetype xmlns:D="DAV:">
|
|||
|
<D:collection/>
|
|||
|
<C:schedule-outbox xmlns:C="urn:ietf:params:xml:ns:caldav"/>
|
|||
|
</D:resourcetype>
|
|||
|
|
|||
|
A scheduling Outbox collection MUST NOT be a child (at any depth) of
|
|||
|
a calendar collection resource.
|
|||
|
|
|||
|
The following WebDAV properties specified in CalDAV "calendar-access"
|
|||
|
[RFC4791] MAY also be defined on scheduling Outbox collections and
|
|||
|
apply to scheduling messages submitted to the scheduling Outbox
|
|||
|
collection with the POST method:
|
|||
|
|
|||
|
o CALDAV:supported-calendar-component-set
|
|||
|
|
|||
|
o CALDAV:supported-calendar-data
|
|||
|
|
|||
|
o CALDAV:max-resource-size
|
|||
|
|
|||
|
o CALDAV:min-date-time
|
|||
|
|
|||
|
o CALDAV:max-date-time
|
|||
|
|
|||
|
o CALDAV:max-attendees-per-instance
|
|||
|
|
|||
|
The use of child resources in a scheduling Outbox collection is
|
|||
|
reserved for future revisions or extensions of this specification.
|
|||
|
|
|||
|
The following WebDAV property is defined on principal resources and
|
|||
|
used to locate the corresponding Outbox collection for the associated
|
|||
|
principal.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 9]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
2.1.1. CALDAV:schedule-outbox-URL Property
|
|||
|
|
|||
|
Name: schedule-outbox-URL
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Identify the URL of the scheduling Outbox collection owned
|
|||
|
by the associated principal resource.
|
|||
|
|
|||
|
Protected: This property MAY be protected.
|
|||
|
|
|||
|
PROPFIND behavior: This property SHOULD NOT be returned by a
|
|||
|
PROPFIND DAV:allprop request (as defined in Section 14.2 of
|
|||
|
[RFC4918]).
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value SHOULD be preserved in COPY
|
|||
|
and MOVE operations.
|
|||
|
|
|||
|
Description: This property is needed for a client to determine where
|
|||
|
the scheduling Outbox collection of the current user is located so
|
|||
|
that sending of scheduling messages can occur. If not present,
|
|||
|
then the associated calendar user is not enabled for the sending
|
|||
|
of scheduling messages on the server.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-outbox-URL (DAV:href)>
|
|||
|
|
|||
|
2.2. Scheduling Inbox Collection
|
|||
|
|
|||
|
A scheduling Inbox collection contains copies of incoming scheduling
|
|||
|
messages. These can be requests sent by an "Organizer", or replies
|
|||
|
sent by an "Attendee" in response to a request. The scheduling Inbox
|
|||
|
collection is also used to manage scheduling privileges.
|
|||
|
|
|||
|
A scheduling Inbox collection MUST report the DAV:collection and
|
|||
|
CALDAV:schedule-inbox XML elements in the value of the DAV:
|
|||
|
resourcetype property. The element type declaration for CALDAV:
|
|||
|
schedule-inbox is
|
|||
|
|
|||
|
<!ELEMENT schedule-inbox EMPTY>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<D:resourcetype xmlns:D="DAV:">
|
|||
|
<D:collection/>
|
|||
|
<C:schedule-inbox xmlns:C="urn:ietf:params:xml:ns:caldav"/>
|
|||
|
</D:resourcetype>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 10]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Scheduling Inbox collections MUST only contain calendar object
|
|||
|
resources that obey the restrictions specified in iTIP [RFC5546].
|
|||
|
Consequently, scheduling Inbox collections MUST NOT contain any types
|
|||
|
of collection resources. Restrictions defined in Section 4.1 of
|
|||
|
CalDAV "calendar-access" [RFC4791] on calendar object resources
|
|||
|
contained in calendar collections (e.g., Unique Identifier ("UID")
|
|||
|
uniqueness) do not apply to calendar object resources contained in a
|
|||
|
scheduling Inbox collection. Thus, multiple calendar object
|
|||
|
resources contained in a scheduling Inbox collection can have the
|
|||
|
same "UID" property value (i.e., multiple scheduling messages for the
|
|||
|
same calendar component).
|
|||
|
|
|||
|
A scheduling Inbox collection MUST NOT be a child (at any depth) of a
|
|||
|
calendar collection resource.
|
|||
|
|
|||
|
The following WebDAV properties specified in CalDAV "calendar-access"
|
|||
|
[RFC4791] MAY also be defined on scheduling Inbox collections and
|
|||
|
apply to scheduling messages delivered to the collection:
|
|||
|
|
|||
|
o CALDAV:supported-calendar-component-set
|
|||
|
|
|||
|
o CALDAV:supported-calendar-data
|
|||
|
|
|||
|
o CALDAV:max-resource-size
|
|||
|
|
|||
|
o CALDAV:min-date-time
|
|||
|
|
|||
|
o CALDAV:max-date-time
|
|||
|
|
|||
|
o CALDAV:max-instances
|
|||
|
|
|||
|
o CALDAV:max-attendees-per-instance
|
|||
|
|
|||
|
o CALDAV:calendar-timezone
|
|||
|
|
|||
|
The following WebDAV property is defined on principal resources and
|
|||
|
used to locate the corresponding Inbox collection for the associated
|
|||
|
principal.
|
|||
|
|
|||
|
2.2.1. CALDAV:schedule-inbox-URL Property
|
|||
|
|
|||
|
Name: schedule-inbox-URL
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Identify the URL of the scheduling Inbox collection owned
|
|||
|
by the associated principal resource.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 11]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Protected: This property MAY be protected.
|
|||
|
|
|||
|
PROPFIND behavior: This property SHOULD NOT be returned by a
|
|||
|
PROPFIND DAV:allprop request (as defined in Section 14.2 of
|
|||
|
[RFC4918]).
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value SHOULD be preserved in COPY
|
|||
|
and MOVE operations.
|
|||
|
|
|||
|
Description: This property allows a client to determine where the
|
|||
|
scheduling Inbox collection of the current user is located so that
|
|||
|
processing of scheduling messages can occur. If not present, then
|
|||
|
the associated calendar user is not enabled for reception of
|
|||
|
scheduling messages on the server.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-inbox-URL (DAV:href)>
|
|||
|
|
|||
|
2.3. Calendaring Reports Extensions
|
|||
|
|
|||
|
This specification extends the CALDAV:calendar-query and CALDAV:
|
|||
|
calendar-multiget REPORTs to return results for calendar object
|
|||
|
resources in scheduling Inbox collections.
|
|||
|
|
|||
|
When a CALDAV:calendar-query REPORT includes a time-range query and
|
|||
|
targets a scheduling Inbox collection, if any calendar object
|
|||
|
resources contain "VEVENT" calendar components that do not include a
|
|||
|
"DTSTART" iCalendar property (as allowed by iTIP [RFC5546]) then such
|
|||
|
components MUST always match the time-range query test.
|
|||
|
|
|||
|
Note that the CALDAV:free-busy-query REPORT is not supported on
|
|||
|
scheduling Inbox collections.
|
|||
|
|
|||
|
2.4. Additional Principal Properties
|
|||
|
|
|||
|
This section defines new properties for WebDAV principal resources as
|
|||
|
defined in [RFC3744]. These properties are likely to be protected,
|
|||
|
but the server MAY allow them to be written by appropriate users.
|
|||
|
|
|||
|
2.4.1. CALDAV:calendar-user-address-set Property
|
|||
|
|
|||
|
Name: calendar-user-address-set
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Identify the calendar addresses of the associated principal
|
|||
|
resource.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 12]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Protected: This property MAY be protected.
|
|||
|
|
|||
|
PROPFIND behavior: This property SHOULD NOT be returned by a
|
|||
|
PROPFIND DAV:allprop request (as defined in Section 14.2 of
|
|||
|
[RFC4918]).
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value SHOULD be preserved in COPY
|
|||
|
and MOVE operations.
|
|||
|
|
|||
|
Description: Support for this property is REQUIRED. This property
|
|||
|
is needed to map calendar user addresses in iCalendar data to
|
|||
|
principal resources and their associated scheduling Inbox and
|
|||
|
Outbox collections. In the event that a user has no well-defined
|
|||
|
identifier for his calendar user address, the URI of his principal
|
|||
|
resource can be used. This property SHOULD be searchable using
|
|||
|
the DAV:principal-property-search REPORT. The DAV:principal-
|
|||
|
search-property-set REPORT SHOULD identify this property as such.
|
|||
|
If not present, then the associated calendar user is not enabled
|
|||
|
for scheduling on the server.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT calendar-user-address-set (DAV:href*)>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:calendar-user-address-set xmlns:D="DAV:"
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<D:href>mailto:bernard@example.com</D:href>
|
|||
|
<D:href>mailto:bernard.desruisseaux@example.com</D:href>
|
|||
|
</C:calendar-user-address-set>
|
|||
|
|
|||
|
2.4.2. CALDAV:calendar-user-type Property
|
|||
|
|
|||
|
Name: calendar-user-type
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Identifies the calendar user type of the associated
|
|||
|
principal resource.
|
|||
|
|
|||
|
Value: Same values allowed for the iCalendar "CUTYPE" property
|
|||
|
parameter defined in Section 3.2.3 of [RFC5545].
|
|||
|
|
|||
|
Protected: This property MAY be protected.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 13]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
PROPFIND behavior: This property SHOULD NOT be returned by a
|
|||
|
PROPFIND DAV:allprop request (as defined in Section 14.2 of
|
|||
|
[RFC4918]).
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value SHOULD be preserved in COPY
|
|||
|
and MOVE operations.
|
|||
|
|
|||
|
Description: Clients can query principal resources in order to look
|
|||
|
up "Attendees" available on the server. When doing this, it is
|
|||
|
useful to know, or restrict the query to, certain types of
|
|||
|
calendar users (e.g., only search for "people", or only search for
|
|||
|
"rooms"). This property MAY be defined on principal resources to
|
|||
|
indicate the type of calendar user associated with the principal
|
|||
|
resource. Its value is the same as the iCalendar "CUTYPE"
|
|||
|
property parameter that can be used on "ATTENDEE" properties.
|
|||
|
This property SHOULD be searchable using the DAV:principal-
|
|||
|
property-search REPORT. The DAV:principal-search-property-set
|
|||
|
REPORT SHOULD identify this property as such.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT calendar-user-type (#PCDATA)>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:calendar-user-type
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">INDIVIDUAL<
|
|||
|
/C:calendar-user-type>
|
|||
|
|
|||
|
3. Scheduling Operations
|
|||
|
|
|||
|
When a calendar object resource is created, modified, or removed from
|
|||
|
a calendar collection, the server examines the calendar data and
|
|||
|
checks to see whether the data represents a scheduling object
|
|||
|
resource. If it does, the server will automatically attempt to
|
|||
|
deliver a scheduling message to the appropriate calendar users.
|
|||
|
Several types of scheduling operations can occur in this case,
|
|||
|
equivalent to iTIP "REQUEST", "REPLY", "CANCEL", and "ADD"
|
|||
|
operations.
|
|||
|
|
|||
|
3.1. Identifying Scheduling Object Resources
|
|||
|
|
|||
|
Calendar object resources on which the server performs scheduling
|
|||
|
operations are referred to as scheduling object resources. There are
|
|||
|
two types of scheduling object resources: organizer scheduling object
|
|||
|
resources, and attendee scheduling object resources.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 14]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
A calendar object resource is considered to be a valid organizer
|
|||
|
scheduling object resource if the "ORGANIZER" iCalendar property is
|
|||
|
present and set in all the calendar components to a value that
|
|||
|
matches one of the calendar user addresses of the owner of the
|
|||
|
calendar collection.
|
|||
|
|
|||
|
A calendar object resource is considered to be a valid attendee
|
|||
|
scheduling object resource if the "ORGANIZER" iCalendar property is
|
|||
|
present and set in all the calendar components to the same value and
|
|||
|
doesn't match one of the calendar user addresses of the owner of the
|
|||
|
calendar collection, and if at least one of the "ATTENDEE" iCalendar
|
|||
|
property values matches one of the calendar user addresses of the
|
|||
|
owner of the calendar collection.
|
|||
|
|
|||
|
The creation of attendee scheduling object resources is typically
|
|||
|
done by the server, with the resource being created in an appropriate
|
|||
|
calendar collection (see Section 4.3).
|
|||
|
|
|||
|
3.2. Handling Scheduling Object Resources
|
|||
|
|
|||
|
The server's behavior when processing a scheduling object resource
|
|||
|
depends on whether it is owned by the "Organizer" or an "Attendee"
|
|||
|
specified in the calendar data.
|
|||
|
|
|||
|
3.2.1. Organizer Scheduling Object Resources
|
|||
|
|
|||
|
An "Organizer" can create, modify, or remove a scheduling object
|
|||
|
resource, subject to access privileges, preconditions, and the
|
|||
|
restrictions defined in Section 4.1 of [RFC4791]. These operations
|
|||
|
are each described next, and how they are invoked via HTTP requests
|
|||
|
is described in Section 3.2.3.
|
|||
|
|
|||
|
The "Organizer" of a calendar component can also be an "Attendee" of
|
|||
|
that calendar component. In such cases, the server MUST NOT send a
|
|||
|
scheduling message to the "Attendee" that matches the "Organizer".
|
|||
|
|
|||
|
The server SHOULD reject any attempt to set the "PARTSTAT" iCalendar
|
|||
|
property parameter value of the "ATTENDEE" iCalendar property of
|
|||
|
other users in the calendar object resource to a value other than
|
|||
|
"NEEDS-ACTION" if the "SCHEDULE-AGENT" property parameter value is
|
|||
|
not present or set to the value "SERVER".
|
|||
|
|
|||
|
The server MAY reject attempts to create a scheduling object resource
|
|||
|
that specifies a "UID" property value already specified in a
|
|||
|
scheduling object resource contained in another calendar collection
|
|||
|
of the "Organizer".
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 15]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.1.1. Create
|
|||
|
|
|||
|
When an "Organizer" creates a scheduling object resource, the server
|
|||
|
MUST inspect each "ATTENDEE" property to determine whether to send a
|
|||
|
scheduling message. The table below indicates the appropriate iTIP
|
|||
|
method used by the server, taking into account any "SCHEDULE-AGENT"
|
|||
|
property parameter (see Section 7.1) specified on each "ATTENDEE"
|
|||
|
property.
|
|||
|
|
|||
|
+------------------+-------------+
|
|||
|
| SCHEDULE-AGENT | iTIP METHOD |
|
|||
|
+------------------+-------------+
|
|||
|
| SERVER (default) | REQUEST |
|
|||
|
| | |
|
|||
|
| CLIENT | -- |
|
|||
|
| | |
|
|||
|
| NONE | -- |
|
|||
|
+------------------+-------------+
|
|||
|
|
|||
|
"SCHEDULE-STATUS" iCalendar property parameters are added or changed
|
|||
|
on "ATTENDEE" iCalendar properties in the scheduling object resource
|
|||
|
being created as described in Section 7.3, with the value set as
|
|||
|
described in Section 3.2.9. This will result in the created calendar
|
|||
|
object resource differing from the calendar data sent in the HTTP
|
|||
|
request. As a result, clients MAY reload the calendar data from the
|
|||
|
server in order to update to the new server-generated state
|
|||
|
information.
|
|||
|
|
|||
|
The server MUST add a "SCHEDULE-STATUS" iCalendar property parameter
|
|||
|
(see Section 7.3) to the "ATTENDEE" iCalendar property in the
|
|||
|
scheduling object resource being created, and set its value as
|
|||
|
described in Section 3.2.9. This will result in the created calendar
|
|||
|
object resource differing from the calendar data sent in the HTTP
|
|||
|
request. As a result, clients MAY reload the calendar data from the
|
|||
|
server in order to update to the new server-generated state
|
|||
|
information. Servers MUST NOT set the "SCHEDULE-STATUS" property
|
|||
|
parameter on the "ATTENDEE" property of "Attendees" for which it did
|
|||
|
not attempt to deliver a scheduling message.
|
|||
|
|
|||
|
The server MUST return an error with the CALDAV:allowed-organizer-
|
|||
|
scheduling-object-change precondition code (Section 3.2.4.3) when the
|
|||
|
"Organizer" attempts to change the iCalendar data in a manner that is
|
|||
|
forbidden.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 16]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.1.2. Modify
|
|||
|
|
|||
|
When an "Organizer" modifies a scheduling object resource, the server
|
|||
|
MUST inspect each "ATTENDEE" property in both the original and
|
|||
|
modified iCalendar data on a per-instance basis to determine whether
|
|||
|
to send a scheduling message. The table below indicates the
|
|||
|
appropriate iTIP method used by the server, taking into account any
|
|||
|
"SCHEDULE-AGENT" property parameter (see Section 7.1) specified on
|
|||
|
each "ATTENDEE" property. The values "SERVER", "CLIENT", and "NONE"
|
|||
|
in the top and left titles of the table refer to the "SCHEDULE-AGENT"
|
|||
|
parameter value of the "ATTENDEE" property, and the values "<Absent>"
|
|||
|
and "<Removed>" are used to cover the cases where the "ATTENDEE"
|
|||
|
property is not present (Original) or is being removed (Modified).
|
|||
|
|
|||
|
+---------------+-----------------------------------------------+
|
|||
|
| | Modified |
|
|||
|
| +-----------+-----------+-----------+-----------+
|
|||
|
| | <Removed> | SERVER | CLIENT | NONE |
|
|||
|
| | | (default) | | |
|
|||
|
+===+===========+===========+===========+===========+===========+
|
|||
|
| | <Absent> | -- | REQUEST / | -- | -- |
|
|||
|
| O | | | ADD | | |
|
|||
|
| r +-----------+-----------+-----------+-----------+-----------+
|
|||
|
| i | SERVER | CANCEL | REQUEST | CANCEL | CANCEL |
|
|||
|
| g | (default) | | | | |
|
|||
|
| i +-----------+-----------+-----------+-----------+-----------+
|
|||
|
| n | CLIENT | -- | REQUEST / | -- | -- |
|
|||
|
| a | | | ADD | | |
|
|||
|
| l +-----------+-----------+-----------+-----------+-----------+
|
|||
|
| | NONE | -- | REQUEST / | -- | -- |
|
|||
|
| | | | ADD | | |
|
|||
|
+---+-----------+-----------+-----------+-----------+-----------+
|
|||
|
|
|||
|
"SCHEDULE-STATUS" iCalendar property parameters are added or changed
|
|||
|
on "ATTENDEE" iCalendar properties in the scheduling object resource
|
|||
|
being modified as described in Section 7.3, with the value set as
|
|||
|
described in Section 3.2.9. This will result in the created calendar
|
|||
|
object resource differing from the calendar data sent in the HTTP
|
|||
|
request. As a result, clients MAY reload the calendar data from the
|
|||
|
server in order to update to the new server-generated state
|
|||
|
information.
|
|||
|
|
|||
|
The server MUST return an error with the CALDAV:allowed-organizer-
|
|||
|
scheduling-object-change precondition code (Section 3.2.4.3) when the
|
|||
|
"Organizer" attempts to change the iCalendar data in a manner that is
|
|||
|
forbidden.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 17]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.1.3. Remove
|
|||
|
|
|||
|
When an "Organizer" removes a scheduling object resource, the server
|
|||
|
MUST inspect each "ATTENDEE" property to determine whether to send a
|
|||
|
scheduling message. The table below indicates the appropriate iTIP
|
|||
|
method used by the server, taking into account any "SCHEDULE-AGENT"
|
|||
|
property parameter (see Section 7.1) specified on each "ATTENDEE"
|
|||
|
property.
|
|||
|
|
|||
|
+------------------+-------------+
|
|||
|
| SCHEDULE-AGENT | iTIP METHOD |
|
|||
|
+------------------+-------------+
|
|||
|
| SERVER (default) | CANCEL |
|
|||
|
| | |
|
|||
|
| CLIENT | -- |
|
|||
|
| | |
|
|||
|
| NONE | -- |
|
|||
|
+------------------+-------------+
|
|||
|
|
|||
|
3.2.2. Attendee Scheduling Object Resources
|
|||
|
|
|||
|
An "Attendee" can create, modify, or remove a scheduling object
|
|||
|
resource. These operations are each described next, and how they are
|
|||
|
invoked via HTTP requests is described in Section 3.2.3.
|
|||
|
|
|||
|
3.2.2.1. Allowed "Attendee" Changes
|
|||
|
|
|||
|
"Attendees" are allowed to make some changes to a scheduling object
|
|||
|
resource, though key properties such as start time, end time,
|
|||
|
location, and summary are typically under the control of the
|
|||
|
"Organizer".
|
|||
|
|
|||
|
Servers MUST allow "Attendees" to make the following iCalendar data
|
|||
|
changes, subject to other restrictions, such as access privileges and
|
|||
|
preconditions:
|
|||
|
|
|||
|
1. change their own "PARTSTAT" iCalendar property parameter value.
|
|||
|
|
|||
|
2. add, modify, or remove any "TRANSP" iCalendar properties.
|
|||
|
|
|||
|
3. add, modify, or remove any "PERCENT-COMPLETE" iCalendar
|
|||
|
properties.
|
|||
|
|
|||
|
4. add, modify, or remove any "COMPLETED" iCalendar properties.
|
|||
|
|
|||
|
5. add, modify, or remove any "VALARM" iCalendar components.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 18]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
6. add, modify, or remove the "CALSCALE" iCalendar property within
|
|||
|
the top-level "VCALENDAR" component.
|
|||
|
|
|||
|
7. modify the "PRODID" iCalendar property within the top-level
|
|||
|
"VCALENDAR" component.
|
|||
|
|
|||
|
8. add "EXDATE" iCalendar properties and possibly remove components
|
|||
|
for overridden recurrence instances.
|
|||
|
|
|||
|
9. add, modify, or remove any "CREATED", "DTSTAMP", and
|
|||
|
"LAST-MODIFIED" iCalendar properties.
|
|||
|
|
|||
|
10. add, modify, or remove "SCHEDULE-STATUS" iCalendar property
|
|||
|
parameters on "ATTENDEE" properties that have a "SCHEDULE-AGENT"
|
|||
|
parameter set to "CLIENT".
|
|||
|
|
|||
|
11. add new components to represent overridden recurrence instances,
|
|||
|
provided the only changes to the recurrence instance follow the
|
|||
|
rules above.
|
|||
|
|
|||
|
The server MUST return an error with the CALDAV:allowed-attendee-
|
|||
|
scheduling-object-change precondition code (Section 3.2.4.4) when the
|
|||
|
"Attendee" attempts to change the iCalendar data in a manner
|
|||
|
forbidden by the server.
|
|||
|
|
|||
|
3.2.2.2. Create
|
|||
|
|
|||
|
Typically, an "Attendee" does not create scheduling object resources,
|
|||
|
as scheduling messages delivered to him on the server are
|
|||
|
automatically processed by the server and placed on one of his
|
|||
|
calendars (see Section 4). However, in some cases, a scheduling
|
|||
|
message can get delivered directly to the client (e.g., via email
|
|||
|
[RFC6047]), and the "Attendee" might wish to store that on the
|
|||
|
server. In that case, the client creates a scheduling object
|
|||
|
resource in a calendar belonging to the "Attendee". It can then set
|
|||
|
the "SCHEDULE-AGENT" iCalendar property parameter on all "ORGANIZER"
|
|||
|
iCalendar properties in the resource to determine how the server
|
|||
|
treats the resource. The value of the "SCHEDULE-AGENT" iCalendar
|
|||
|
property parameter on all "ORGANIZER" iCalendar properties MUST be
|
|||
|
the same.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 19]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SCHEDULE-AGENT | Action |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SERVER | The server will attempt to process changes to |
|
|||
|
| (default) | the resource using the normal rules for attendee |
|
|||
|
| | scheduling object resources. |
|
|||
|
| | |
|
|||
|
| CLIENT | The server does no special processing of the |
|
|||
|
| | resource. The client is assumed to be handling |
|
|||
|
| | "Attendee" replies, etc. |
|
|||
|
| | |
|
|||
|
| NONE | The server does no special processing of the |
|
|||
|
| | resource. |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
|
|||
|
"SCHEDULE-STATUS" iCalendar property parameters are added or changed
|
|||
|
on "ORGANIZER" iCalendar properties in the scheduling object resource
|
|||
|
being created as described in Section 7.3, with the value set as
|
|||
|
described in Section 3.2.9.
|
|||
|
|
|||
|
3.2.2.3. Modify
|
|||
|
|
|||
|
When a scheduling object resource is modified by an "Attendee", the
|
|||
|
server's behavior depends on the value of the "SCHEDULE-AGENT"
|
|||
|
iCalendar property parameter on the "ORGANIZER" iCalendar properties:
|
|||
|
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SCHEDULE-AGENT | Action |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SERVER | The server will attempt to process the update |
|
|||
|
| (default) | using the behavior listed below. |
|
|||
|
| | |
|
|||
|
| CLIENT | The server does no special processing of the |
|
|||
|
| | resource. The client is assumed to be handling |
|
|||
|
| | any "Attendee" replies, etc. |
|
|||
|
| | |
|
|||
|
| NONE | The server does no special processing of the |
|
|||
|
| | resource. |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
|
|||
|
The server will inspect the changes by comparing the new scheduling
|
|||
|
object resource with the existing scheduling object resource.
|
|||
|
|
|||
|
If the "Attendee" changes one or more "PARTSTAT" iCalendar property
|
|||
|
values on any component, or adds an overridden component with a
|
|||
|
changed "PARTSTAT" property, then the server MUST deliver an iTIP
|
|||
|
"REPLY" scheduling message to the "Organizer" to indicate the new
|
|||
|
participation status of the "Attendee".
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 20]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
If the "Attendee" adds an "EXDATE" property value to effectively
|
|||
|
remove a recurrence instance, the server MUST deliver an iTIP "REPLY"
|
|||
|
scheduling message to the "Organizer" to indicate that the "Attendee"
|
|||
|
has declined the instance.
|
|||
|
|
|||
|
"SCHEDULE-STATUS" iCalendar property parameters are added or changed
|
|||
|
on "ORGANIZER" iCalendar properties in the scheduling object resource
|
|||
|
being modified as described in Section 7.3, with the value set as
|
|||
|
described in Section 3.2.9. This will result in the updated calendar
|
|||
|
object resource differing from the calendar data sent in the HTTP
|
|||
|
request. As a result, clients MAY reload the calendar data from the
|
|||
|
server in order to update to the new server-generated state
|
|||
|
information.
|
|||
|
|
|||
|
3.2.2.4. Remove
|
|||
|
|
|||
|
When a scheduling object resource is removed by an "Attendee", the
|
|||
|
server's behavior depends on the value of the "SCHEDULE-AGENT"
|
|||
|
iCalendar property parameter on the "ORGANIZER" iCalendar properties:
|
|||
|
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SCHEDULE-AGENT | Action |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
| SERVER | The server will attempt to process the removal, |
|
|||
|
| (default) | taking into account any "Schedule-Reply" request |
|
|||
|
| | header as per Section 8.1. |
|
|||
|
| | |
|
|||
|
| CLIENT | The server does no special processing of the |
|
|||
|
| | resource. The client is assumed to be handling |
|
|||
|
| | any "Attendee" replies, etc. |
|
|||
|
| | |
|
|||
|
| NONE | The server does no special processing of the |
|
|||
|
| | resource. |
|
|||
|
+----------------+--------------------------------------------------+
|
|||
|
|
|||
|
3.2.3. HTTP Methods
|
|||
|
|
|||
|
This section describes how the use of various HTTP [RFC2616] and
|
|||
|
WebDAV [RFC4918] methods on a scheduling object resource will cause a
|
|||
|
create, modify, or remove operation on that resource as described
|
|||
|
above. The use of these methods is subject to the restrictions in
|
|||
|
[RFC4791], in addition to what is described below.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 21]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.3.1. PUT
|
|||
|
|
|||
|
When the server receives a PUT method request, it MUST execute the
|
|||
|
following operations, provided all appropriate preconditions are met:
|
|||
|
|
|||
|
+------------------------+--------------------------+---------------+
|
|||
|
| Existing Destination | Resulting Destination | Server |
|
|||
|
| Resource | Resource | Operation |
|
|||
|
+------------------------+--------------------------+---------------+
|
|||
|
| None | Calendar object resource | None |
|
|||
|
| | | |
|
|||
|
| None | Scheduling object | Create |
|
|||
|
| | resource | |
|
|||
|
| | | |
|
|||
|
| Calendar object | Calendar object resource | None |
|
|||
|
| resource | | |
|
|||
|
| | | |
|
|||
|
| Calendar object | Scheduling object | Create |
|
|||
|
| resource | resource | |
|
|||
|
| Scheduling object | Calendar object resource | Remove |
|
|||
|
| resource | | |
|
|||
|
| | | |
|
|||
|
| Scheduling object | Scheduling object | Modify |
|
|||
|
| resource | resource | |
|
|||
|
+------------------------+--------------------------+---------------+
|
|||
|
|
|||
|
3.2.3.2. DELETE
|
|||
|
|
|||
|
When the server receives a DELETE method request targeted at a
|
|||
|
scheduling object resource, it MUST execute the Remove operation.
|
|||
|
|
|||
|
When the server receives a DELETE method request targeted at a
|
|||
|
calendar collection, it MUST execute the Remove operation on all
|
|||
|
scheduling object resources contained in the calendar collection.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 22]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.3.3. COPY
|
|||
|
|
|||
|
When the server receives a COPY method request, it MUST execute the
|
|||
|
following operations based on the source and destination collections
|
|||
|
in the request:
|
|||
|
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
| Source Collection | Destination Collection | Server Operation |
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
| Non-calendar | Non-calendar | None |
|
|||
|
| collection | collection | |
|
|||
|
| | | |
|
|||
|
| Non-calendar | Calendar collection | (1) |
|
|||
|
| collection | | |
|
|||
|
| | | |
|
|||
|
| Calendar collection | Non-calendar | None |
|
|||
|
| | collection | |
|
|||
|
| | | |
|
|||
|
| Calendar collection | Calendar collection | (2) |
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
|
|||
|
Note (1): The rules in Section 3.2.3.1 are applied for the
|
|||
|
destination of the COPY request.
|
|||
|
|
|||
|
Note (2): The server MAY reject this as per Section 3.2.4.1;
|
|||
|
otherwise, None.
|
|||
|
|
|||
|
The behavior of a COPY method request on a calendar collection is
|
|||
|
undefined.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 23]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.3.4. MOVE
|
|||
|
|
|||
|
When the server receives a MOVE method request, it MUST execute the
|
|||
|
following operations based on the source and destination collections
|
|||
|
in the request:
|
|||
|
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
| Source Collection | Destination Collection | Server Operation |
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
| Non-calendar | Non-calendar | None |
|
|||
|
| collection | collection | |
|
|||
|
| | | |
|
|||
|
| Non-calendar | Calendar collection | (1) |
|
|||
|
| collection | | |
|
|||
|
| | | |
|
|||
|
| Calendar collection | Non-calendar | (2) |
|
|||
|
| | collection | |
|
|||
|
| | | |
|
|||
|
| Calendar collection | Calendar collection | None |
|
|||
|
+-----------------------+------------------------+------------------+
|
|||
|
|
|||
|
Note (1): The rules in Section 3.2.3.1 are applied for the
|
|||
|
destination of the MOVE request.
|
|||
|
|
|||
|
Note (2): The rules in Section 3.2.3.2 are applied for the source of
|
|||
|
the MOVE request.
|
|||
|
|
|||
|
The behavior of a MOVE method request on a calendar collection is
|
|||
|
undefined.
|
|||
|
|
|||
|
3.2.4. Additional Method Preconditions
|
|||
|
|
|||
|
This specification defines method preconditions (see Section 16 of
|
|||
|
WebDAV [RFC4918]), in addition to those in [RFC4791], to provide
|
|||
|
machine-parseable information in error responses.
|
|||
|
|
|||
|
3.2.4.1. CALDAV:unique-scheduling-object-resource Precondition
|
|||
|
|
|||
|
Name: unique-scheduling-object-resource
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: PUT, COPY, and MOVE
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 24]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Purpose: (precondition) -- Servers MAY reject requests to create a
|
|||
|
scheduling object resource with an iCalendar "UID" property value
|
|||
|
already in use by another scheduling object resource owned by the
|
|||
|
same user in other calendar collections. Servers SHOULD report
|
|||
|
the URL of the scheduling object resource that is already making
|
|||
|
use of the same "UID" property value in the DAV:href element.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT unique-scheduling-object-resource (DAV:href?)>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:unique-scheduling-object-resource xmlns:D="DAV:"
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<D:href>/home/bernard/calendars/personal/abc123.ics</D:href>
|
|||
|
</C:unique-scheduling-object-resource>
|
|||
|
|
|||
|
3.2.4.2. CALDAV:same-organizer-in-all-components Precondition
|
|||
|
|
|||
|
Name: same-organizer-in-all-components
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: PUT, COPY, and MOVE
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
Purpose: (precondition) -- All the calendar components in a
|
|||
|
scheduling object resource MUST contain the same "ORGANIZER"
|
|||
|
property value when present.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT same-organizer-in-all-components EMPTY>
|
|||
|
|
|||
|
3.2.4.3. CALDAV:allowed-organizer-scheduling-object-change Precondition
|
|||
|
|
|||
|
Name: allowed-organizer-scheduling-object-change
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: PUT, COPY, and MOVE
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 25]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Purpose: (precondition) -- Servers MAY impose restrictions on
|
|||
|
modifications allowed by an "Organizer". For instance, servers
|
|||
|
MAY prevent the "Organizer" from setting the "PARTSTAT" property
|
|||
|
parameter to a value other than "NEEDS-ACTION" if the
|
|||
|
corresponding "ATTENDEE" property has the "SCHEDULE-AGENT"
|
|||
|
property parameter set to "SERVER", or does not have the
|
|||
|
"SCHEDULE-AGENT" property parameter. See Section 3.2.1.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT allowed-organizer-scheduling-object-change EMPTY>
|
|||
|
|
|||
|
3.2.4.4. CALDAV:allowed-attendee-scheduling-object-change Precondition
|
|||
|
|
|||
|
Name: allowed-attendee-scheduling-object-change
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: PUT, COPY, and MOVE
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
Purpose: (precondition) -- Servers MAY impose restrictions on
|
|||
|
modifications allowed by an "Attendee", subject to the allowed
|
|||
|
changes specified in Section 3.2.2.1.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT allowed-attendee-scheduling-object-change EMPTY>
|
|||
|
|
|||
|
3.2.5. DTSTAMP and SEQUENCE Properties
|
|||
|
|
|||
|
The server MUST ensure that a "DTSTAMP" iCalendar property is present
|
|||
|
and set the value to the UTC time that the scheduling message was
|
|||
|
generated (as required by iCalendar).
|
|||
|
|
|||
|
The server MUST ensure that for each type of scheduling operation,
|
|||
|
the "SEQUENCE" iCalendar property value is updated as per iTIP
|
|||
|
[RFC5546].
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 26]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.6. Restrict Recurrence Instances Sent to "Attendees"
|
|||
|
|
|||
|
Servers MUST ensure that "Attendees" only get information about
|
|||
|
recurrence instances that explicitly include them as an "Attendee",
|
|||
|
when delivering scheduling messages for recurring calendar
|
|||
|
components.
|
|||
|
|
|||
|
For example, if an "Attendee" is invited to only a single instance of
|
|||
|
a recurring event, the organizer scheduling object resource will
|
|||
|
contain an overridden instance in the form of a separate calendar
|
|||
|
component. That separate calendar component will include the
|
|||
|
"ATTENDEE" property referencing the "one-off" "Attendee". That
|
|||
|
"Attendee" will not be listed in any other calendar components in the
|
|||
|
scheduling object resource. Any scheduling messages delivered to the
|
|||
|
"Attendee" will only contain information about this overridden
|
|||
|
instance.
|
|||
|
|
|||
|
As another example, an "Attendee" could be excluded from one instance
|
|||
|
of a recurring event. In that case, the organizer scheduling object
|
|||
|
resource will include an overridden instance with an "ATTENDEE" list
|
|||
|
that does not include the "Attendee" being excluded. Any scheduling
|
|||
|
messages delivered to the "Attendee" will not specify the overridden
|
|||
|
instance but rather will include an "EXDATE" property in the "master"
|
|||
|
component that defines the recurrence set.
|
|||
|
|
|||
|
3.2.7. Forcing the Server to Send a Scheduling Message
|
|||
|
|
|||
|
The iCalendar property parameter "SCHEDULE-FORCE-SEND", defined in
|
|||
|
Section 7.2, can be used by a calendar user to force the server to
|
|||
|
send a scheduling message to an "Attendee" or the "Organizer" in a
|
|||
|
situation where the server would not normally send a scheduling
|
|||
|
message. For instance, an "Organizer" could use this property
|
|||
|
parameter to request an "Attendee" that previously declined an
|
|||
|
invitation to reconsider his participation status without being
|
|||
|
forced to modify the event.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 27]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.8. "Attendee" Participation Status
|
|||
|
|
|||
|
This section specifies additional requirements on the handling of the
|
|||
|
"PARTSTAT" property parameter when the "SCHEDULE-AGENT" property
|
|||
|
parameter on the corresponding "ATTENDEE" property is set to the
|
|||
|
value "SERVER" or is not present.
|
|||
|
|
|||
|
A reschedule occurs when any "DTSTART", "DTEND", "DURATION", "DUE",
|
|||
|
"RRULE", "RDATE", or "EXDATE" property changes in a calendar
|
|||
|
component such that existing recurrence instances are impacted by the
|
|||
|
changes, as shown in the table below. Servers MUST reset the
|
|||
|
"PARTSTAT" property parameter value of all "ATTENDEE" properties,
|
|||
|
except the one that corresponds to the "Organizer", to "NEEDS-ACTION"
|
|||
|
for each calendar component change that causes any instance to be
|
|||
|
rescheduled.
|
|||
|
|
|||
|
+-----------+-------------------------------------------------------+
|
|||
|
| Property | Server Action |
|
|||
|
+-----------+-------------------------------------------------------+
|
|||
|
| DTSTART, | Any change to these properties results in "PARTSTAT" |
|
|||
|
| DTEND, | being set to "NEEDS-ACTION". |
|
|||
|
| DURATION, | |
|
|||
|
| DUE | |
|
|||
|
| | |
|
|||
|
| RRULE | A change to or addition of this property that results |
|
|||
|
| | in the addition of new recurring instances or a |
|
|||
|
| | change in time for existing recurring instances |
|
|||
|
| | results in "PARTSTAT" being reset to "NEEDS-ACTION" |
|
|||
|
| | on each affected component. |
|
|||
|
| | |
|
|||
|
| RDATE | A change to or addition of this property that results |
|
|||
|
| | in the addition of new recurring instances or a |
|
|||
|
| | change in time for existing recurring instances |
|
|||
|
| | results in "PARTSTAT" being reset to "NEEDS-ACTION" |
|
|||
|
| | on each affected component. |
|
|||
|
| | |
|
|||
|
| EXDATE | A change to or removal of this property that results |
|
|||
|
| | in the reinstatement of recurring instances results |
|
|||
|
| | in "PARTSTAT" being set to "NEEDS-ACTION" on each |
|
|||
|
| | affected component. |
|
|||
|
+-----------+-------------------------------------------------------+
|
|||
|
|
|||
|
The server MAY allow the "Organizer's" client to change an
|
|||
|
"Attendee's" "PARTSTAT" property parameter value to "NEEDS-ACTION" at
|
|||
|
any other time (e.g., when the "LOCATION" property value changes, an
|
|||
|
"Organizer" might wish to re-invite "Attendees" who might be impacted
|
|||
|
by the change).
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 28]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3.2.9. Schedule Status Values
|
|||
|
|
|||
|
When scheduling with an "Attendee", there are two types of status
|
|||
|
information that can be returned during the operation. The first
|
|||
|
type of status information is a "delivery" status that indicates
|
|||
|
whether the scheduling message from the "Organizer" to the "Attendee"
|
|||
|
was delivered or not, or what the current status of delivery is. The
|
|||
|
second type of status information is a "reply" status corresponding
|
|||
|
to the "Attendee's" own "REQUEST-STATUS" information from the
|
|||
|
scheduling message reply that is sent back to the "Organizer".
|
|||
|
|
|||
|
Similarly, when an "Attendee" sends a reply back to the "Organizer",
|
|||
|
there will be "delivery" status information for the scheduling
|
|||
|
message sent to the "Organizer". However, there is no
|
|||
|
"REQUEST-STATUS" sent back by the "Organizer", so there is no
|
|||
|
equivalent of the "reply" status as per scheduling messages to
|
|||
|
"Attendees".
|
|||
|
|
|||
|
The "delivery" status information on an "ORGANIZER" or "ATTENDEE"
|
|||
|
iCalendar property is conveyed in the "SCHEDULE-STATUS" property
|
|||
|
parameter value (Section 7.3). The status code value for "delivery"
|
|||
|
status can be one of the following:
|
|||
|
|
|||
|
+----------+--------------------------------------------------------+
|
|||
|
| Delivery | Description |
|
|||
|
| Status | |
|
|||
|
| Code | |
|
|||
|
+----------+--------------------------------------------------------+
|
|||
|
| 1.0 | The scheduling message is pending. That is, the |
|
|||
|
| | server is still in the process of sending the message. |
|
|||
|
| | The status code value can be expected to change once |
|
|||
|
| | the server has completed its sending and delivery |
|
|||
|
| | attempts. |
|
|||
|
| | |
|
|||
|
| 1.1 | The scheduling message has been successfully sent. |
|
|||
|
| | However, the server does not have explicit information |
|
|||
|
| | about whether the scheduling message was successfully |
|
|||
|
| | delivered to the recipient. This state can occur with |
|
|||
|
| | "store and forward" style scheduling protocols such as |
|
|||
|
| | iMIP [RFC6047] (iTIP using email). |
|
|||
|
| | |
|
|||
|
| 1.2 | The scheduling message has been successfully |
|
|||
|
| | delivered. |
|
|||
|
| | |
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 29]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
| 3.7 | The scheduling message was not delivered because the |
|
|||
|
| | server did not recognize the calendar user address as |
|
|||
|
| | a valid calendar user. Note that this code applies to |
|
|||
|
| | both "Organizer" and "Attendee" calendar user |
|
|||
|
| | addresses. |
|
|||
|
| | |
|
|||
|
| 3.8 | The scheduling message was not delivered due to |
|
|||
|
| | insufficient privileges. Note that this code applies |
|
|||
|
| | to privileges granted by both the "Organizer" and |
|
|||
|
| | "Attendee" calendar users. |
|
|||
|
| | |
|
|||
|
| 5.1 | The scheduling message was not delivered because the |
|
|||
|
| | server could not complete delivery of the message. |
|
|||
|
| | This is likely due to a temporary failure, and the |
|
|||
|
| | originator can try to send the message again at a |
|
|||
|
| | later time. |
|
|||
|
| | |
|
|||
|
| 5.2 | The scheduling message was not delivered because the |
|
|||
|
| | server was not able to find a way to deliver the |
|
|||
|
| | message. This is likely a permanent failure, and the |
|
|||
|
| | originator ought not try to send the message again, at |
|
|||
|
| | least without verifying/correcting the calendar user |
|
|||
|
| | address of the recipient. |
|
|||
|
| | |
|
|||
|
| 5.3 | The scheduling message was not delivered and was |
|
|||
|
| | rejected because scheduling with that recipient is not |
|
|||
|
| | allowed. This is likely a permanent failure, and the |
|
|||
|
| | originator ought not try to send the message again. |
|
|||
|
+----------+--------------------------------------------------------+
|
|||
|
|
|||
|
The status code for "reply" status can be any of the valid iTIP
|
|||
|
[RFC5546] "REQUEST-STATUS" values.
|
|||
|
|
|||
|
The 1.xx "REQUEST-STATUS" codes are new. This specification modifies
|
|||
|
item (2) of Section 3.6 of [RFC5546] by adding the following
|
|||
|
restriction:
|
|||
|
|
|||
|
For a 1.xx code, all components MUST have exactly the same code.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 30]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Definition of the new 1.xx codes is as follows:
|
|||
|
|
|||
|
3.2.9.1. Status Code 1.0
|
|||
|
|
|||
|
Status Code: 1.0
|
|||
|
|
|||
|
Status Description: Pending.
|
|||
|
|
|||
|
Status Exception Data: None.
|
|||
|
|
|||
|
Description: Delivery of the iTIP message is pending.
|
|||
|
|
|||
|
3.2.9.2. Status Code 1.1
|
|||
|
|
|||
|
Status Code: 1.1
|
|||
|
|
|||
|
Status Description: Sent.
|
|||
|
|
|||
|
Status Exception Data: None.
|
|||
|
|
|||
|
Description: The iTIP message has been sent, though no information
|
|||
|
about successful delivery is known.
|
|||
|
|
|||
|
3.2.9.3. Status Code 1.2
|
|||
|
|
|||
|
Status Code: 1.2
|
|||
|
|
|||
|
Status Description: Delivered.
|
|||
|
|
|||
|
Status Exception Data: None.
|
|||
|
|
|||
|
Description: The iTIP message has been sent and delivered.
|
|||
|
|
|||
|
3.2.10. Avoiding Conflicts when Updating Scheduling Object Resources
|
|||
|
|
|||
|
Scheduling object resources on the server might change frequently as
|
|||
|
"Attendees" change their participation status, triggering updates to
|
|||
|
the "Organizer", and refreshes of other "Attendees'" copies of the
|
|||
|
scheduling object resource. This can lead to an "inconsequential"
|
|||
|
change to a calendar user's data -- one that does not directly impact
|
|||
|
the user's own participation status. When this occurs, clients have
|
|||
|
to reload calendar data and reconcile with changes being made by
|
|||
|
calendar users. To avoid the need for this, the server can instead
|
|||
|
merge calendar data changes from a client with changes made as a
|
|||
|
result of a scheduling operation carried out by some other calendar
|
|||
|
user.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 31]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
This specification introduces a new WebDAV resource property CALDAV:
|
|||
|
schedule-tag with a corresponding response header "Schedule-Tag", and
|
|||
|
a new "If-Schedule-Tag-Match" request header to allow client changes
|
|||
|
to be appropriately merged with server changes in the case where the
|
|||
|
changes on the server were the result of an "inconsequential"
|
|||
|
scheduling message update (one that simply updates the status
|
|||
|
information of "Attendees" due to a reply from another "Attendee").
|
|||
|
|
|||
|
Servers MUST automatically resolve conflicts with "inconsequential"
|
|||
|
changes done to scheduling object resources when the "If-Schedule-
|
|||
|
Tag-Match" request header is specified. The If-Schedule-Tag-Match
|
|||
|
request header applies only to the Request-URI, and not to the
|
|||
|
destination of a COPY or MOVE.
|
|||
|
|
|||
|
A response to any successful GET or PUT request targeting a
|
|||
|
scheduling object resource MUST include a Schedule-Tag response
|
|||
|
header with the value set to the same value as the CALDAV:schedule-
|
|||
|
tag WebDAV property of the resource.
|
|||
|
|
|||
|
A response to any successful COPY or MOVE request that specifies a
|
|||
|
Destination request header targeting a scheduling object resource
|
|||
|
MUST include a Schedule-Tag response header with the value set to the
|
|||
|
same value as the CALDAV:schedule-tag WebDAV property of the
|
|||
|
destination resource.
|
|||
|
|
|||
|
Clients SHOULD use the If-Schedule-Tag-Match header on requests that
|
|||
|
update scheduling object resources, instead of HTTP ETag-based
|
|||
|
precondition tests (e.g., If-Match). Normal ETag-based precondition
|
|||
|
tests are used in all other cases, e.g., for synchronization.
|
|||
|
|
|||
|
The value of the CALDAV:schedule-tag property changes according to
|
|||
|
these rules:
|
|||
|
|
|||
|
o For an "Organizer's" copy of a scheduling object resource:
|
|||
|
|
|||
|
1. The server MUST NOT change the CALDAV:schedule-tag property
|
|||
|
value when the scheduling object resource is updated as the
|
|||
|
result of automatically processing a scheduling message reply
|
|||
|
from an "Attendee". For instance, when an "Attendee" replies
|
|||
|
to the "Organizer", the CALDAV:schedule-tag property is
|
|||
|
unchanged after the "Organizer's" scheduling object resource
|
|||
|
has been automatically updated by the server with the
|
|||
|
"Attendee's" new participation status.
|
|||
|
|
|||
|
2. The server MUST change the CALDAV:schedule-tag property value
|
|||
|
when the scheduling object resource is changed directly via an
|
|||
|
HTTP request (e.g., PUT, COPY, or MOVE).
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 32]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
o For an "Attendee's" copy of a scheduling object resource:
|
|||
|
|
|||
|
1. The server MUST change the CALDAV:schedule-tag property value
|
|||
|
when the scheduling object resource is changed as the result
|
|||
|
of processing a scheduling message update from an "Organizer"
|
|||
|
that contains changes other than just the participation status
|
|||
|
of "Attendees".
|
|||
|
|
|||
|
2. The server MUST NOT change the CALDAV:schedule-tag property
|
|||
|
value when the scheduling object resource is changed as the
|
|||
|
result of processing a scheduling message update from an
|
|||
|
"Organizer" that only specifies changes in the participation
|
|||
|
status of "Attendees". For instance, when "Attendee" "A"
|
|||
|
replies to "Organizer" "O", and "Attendee" "B" receives a
|
|||
|
scheduling message update from "Organizer" "O" with the new
|
|||
|
participation status of "Attendee" "A", the CALDAV:schedule-
|
|||
|
tag property of "Attendee" "B"'s scheduling object resource
|
|||
|
would remain the same.
|
|||
|
|
|||
|
3. The server MUST change the CALDAV:schedule-tag property value
|
|||
|
when the scheduling object resource is changed directly via an
|
|||
|
HTTP request (e.g., PUT, COPY, or MOVE).
|
|||
|
|
|||
|
3.2.10.1. PUT
|
|||
|
|
|||
|
Clients MAY use the If-Schedule-Tag-Match request header to do a PUT
|
|||
|
request that ensures that "inconsequential" changes on the server do
|
|||
|
not result in a precondition error. The value of the request header
|
|||
|
is set to the last Schedule-Tag value received for the resource being
|
|||
|
modified. If the value of the If-Schedule-Tag-Match header matches
|
|||
|
the current value of the CALDAV:schedule-tag property, the server
|
|||
|
MUST take any "ATTENDEE" property changes for all "Attendees" other
|
|||
|
than the owner of the scheduling object resource and apply those to
|
|||
|
the new resource being stored. Otherwise, the server MUST fail the
|
|||
|
request with a 412 Precondition Failed status code.
|
|||
|
|
|||
|
3.2.10.2. DELETE, COPY, or MOVE
|
|||
|
|
|||
|
Clients MAY use the If-Schedule-Tag-Match request header to do a
|
|||
|
DELETE, COPY, or MOVE request that ensures that "inconsequential"
|
|||
|
changes on the server do not result in a precondition error. The
|
|||
|
value of the request header is set to the last Schedule-Tag value
|
|||
|
received for the resource being deleted. If the value of the
|
|||
|
If-Schedule-Tag-Match header matches the current value of the CALDAV:
|
|||
|
schedule-tag property, the server performs the normal DELETE, COPY,
|
|||
|
or MOVE request processing for the resource. Otherwise, the server
|
|||
|
MUST fail the request with a 412 Precondition Failed status code.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 33]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
4. Processing Incoming Scheduling Messages
|
|||
|
|
|||
|
Scheduling operations can cause the delivery of a scheduling message
|
|||
|
into an "Organizer's" or "Attendee's" scheduling Inbox collection.
|
|||
|
Servers MUST automatically process incoming scheduling messages using
|
|||
|
the rules defined by [RFC5546], by creating or updating the
|
|||
|
corresponding scheduling object resources on calendars owned by the
|
|||
|
owner of the scheduling Inbox collection. In addition, the
|
|||
|
scheduling message is stored in the scheduling Inbox collection as an
|
|||
|
indicator to the client that a scheduling operation has taken place.
|
|||
|
Scheduling messages are typically removed from the scheduling Inbox
|
|||
|
collection by the client once the calendar user has acknowledged the
|
|||
|
change.
|
|||
|
|
|||
|
The server MUST take into account privileges on the scheduling Inbox
|
|||
|
collection when processing incoming scheduling messages, to determine
|
|||
|
whether delivery of the scheduling message is allowed. Privileges on
|
|||
|
calendars containing any matching scheduling object resource are not
|
|||
|
considered in this case (i.e., a schedule message from another user
|
|||
|
can cause modifications to resources in calendar collections that the
|
|||
|
other user would not normally have read or write access to).
|
|||
|
Additionally, servers MUST take into account any scheduling Inbox
|
|||
|
collection preconditions (see Section 2.2) when delivering the
|
|||
|
scheduling message, and MUST take into account the similar
|
|||
|
preconditions on any calendar collection that contains, or would
|
|||
|
contain, the corresponding scheduling object resource.
|
|||
|
|
|||
|
4.1. Processing "Organizer" Requests, Additions, and Cancellations
|
|||
|
|
|||
|
For a scheduling message sent by an "Organizer", the server first
|
|||
|
tries to locate a corresponding scheduling object resource belonging
|
|||
|
to the "Attendee". If no matching scheduling object resource exists,
|
|||
|
the server treats the scheduling message as a new message; otherwise,
|
|||
|
it is treated as an update.
|
|||
|
|
|||
|
In the case of a new message, the server processes the scheduling
|
|||
|
message and creates a new scheduling object resource as per
|
|||
|
Section 4.3.
|
|||
|
|
|||
|
In the case of an update, the server processes the scheduling message
|
|||
|
and updates the matching scheduling object resource belonging to the
|
|||
|
"Attendee" to reflect the changes sent by the "Organizer".
|
|||
|
|
|||
|
In each case, the scheduling message MUST only appear in the
|
|||
|
"Attendee's" scheduling Inbox collection once all automatic
|
|||
|
processing has been done.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 34]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
4.2. Processing "Attendee" Replies
|
|||
|
|
|||
|
For a scheduling message reply sent by an "Attendee", the server
|
|||
|
first locates the corresponding scheduling object resource belonging
|
|||
|
to the "Organizer". If the corresponding scheduling object resource
|
|||
|
cannot be found, the server SHOULD ignore the scheduling message.
|
|||
|
|
|||
|
The server MUST then update the "PARTSTAT" iCalendar property
|
|||
|
parameter value of each "ATTENDEE" iCalendar property in the
|
|||
|
scheduling object resource to match the changes indicated in the
|
|||
|
reply (taking into account the fact that an "Attendee" could have
|
|||
|
created a new overridden iCalendar component to indicate different
|
|||
|
participation status on one or more instances of a recurring event).
|
|||
|
|
|||
|
The server MUST also update or add the "SCHEDULE-STATUS" property
|
|||
|
parameter on each matching "ATTENDEE" iCalendar property and set its
|
|||
|
value to that of the "REQUEST-STATUS" property in the reply, or to
|
|||
|
"2.0" if "REQUEST-STATUS" is not present (also taking into account
|
|||
|
recurrence instances). If there are multiple "REQUEST-STATUS"
|
|||
|
properties in the reply, the "SCHEDULE-STATUS" property parameter
|
|||
|
value is set to a comma-separated list of status codes, one from each
|
|||
|
"REQUEST-STATUS" property.
|
|||
|
|
|||
|
The server SHOULD send scheduling messages to all the other
|
|||
|
"Attendees" indicating the change in participation status of the
|
|||
|
"Attendee" replying, subject to the recurrence requirements of
|
|||
|
Section 3.2.6.
|
|||
|
|
|||
|
The scheduling message MUST only appear in the "Organizer's"
|
|||
|
scheduling Inbox collection once all automatic processing has been
|
|||
|
done.
|
|||
|
|
|||
|
4.3. Default Calendar Collection
|
|||
|
|
|||
|
The server processes scheduling messages received for an "Attendee"
|
|||
|
by creating a new scheduling object resource in a calendar collection
|
|||
|
belonging to the "Attendee", when one does not already exist. A
|
|||
|
calendar user that is an "Attendee" in a scheduling operation MUST
|
|||
|
have at least one valid calendar collection available. If there is
|
|||
|
no valid calendar collection, then the server MUST reject the attempt
|
|||
|
to deliver the scheduling message to the "Attendee".
|
|||
|
|
|||
|
Servers MAY provide support for a default calendar collection -- that
|
|||
|
is, the calendar collection in which new scheduling object resources
|
|||
|
will be created. The CALDAV:schedule-default-calendar-URL WebDAV
|
|||
|
property, which can be present on the scheduling Inbox collection of
|
|||
|
a calendar user, specifies whether this calendar user has a default
|
|||
|
calendar collection. See Section 9.2.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 35]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Servers SHOULD create new scheduling object resources in the default
|
|||
|
calendar collection, if the CALDAV:schedule-default-calendar-URL
|
|||
|
WebDAV property is set.
|
|||
|
|
|||
|
Servers MAY allow clients to change the default calendar collection
|
|||
|
by changing the value of the CALDAV:schedule-default-calendar-URL
|
|||
|
WebDAV property on the scheduling Inbox collection. However, the
|
|||
|
server MUST ensure that any new value for that property refers to a
|
|||
|
valid calendar collection belonging to the owner of the scheduling
|
|||
|
Inbox collection.
|
|||
|
|
|||
|
Servers MUST reject any attempt to delete the default calendar
|
|||
|
collection.
|
|||
|
|
|||
|
4.3.1. Additional Method Preconditions
|
|||
|
|
|||
|
This specification defines additional method preconditions (see
|
|||
|
Section 16 of WebDAV [RFC4918]) to provide machine-parseable
|
|||
|
information in error responses.
|
|||
|
|
|||
|
4.3.1.1. CALDAV:default-calendar-needed Precondition
|
|||
|
|
|||
|
Name: default-calendar-needed
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: DELETE
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
Purpose: (precondition) -- The client attempted to delete the
|
|||
|
calendar collection currently referenced by the CALDAV:schedule-
|
|||
|
default-calendar-URL property, or attempted to remove the CALDAV:
|
|||
|
schedule-default-calendar-URL property on the scheduling Inbox
|
|||
|
collection on a server that doesn't allow such operations.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT default-calendar-needed EMPTY>
|
|||
|
|
|||
|
4.3.1.2. CALDAV:valid-schedule-default-calendar-URL Precondition
|
|||
|
|
|||
|
Name: valid-schedule-default-calendar-URL
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: PROPPATCH
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 36]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
Purpose: (precondition) -- The client attempted to set the CALDAV:
|
|||
|
schedule-default-calendar-URL property to a DAV:href element that
|
|||
|
doesn't reference a valid calendar collection. Note: Servers that
|
|||
|
do not allow clients to change the CALDAV:schedule-default-
|
|||
|
calendar-URL property would simply return the DAV:cannot-modify-
|
|||
|
protected-property precondition defined in Section 16 of WebDAV
|
|||
|
[RFC4918].
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT valid-schedule-default-calendar-URL EMPTY>
|
|||
|
|
|||
|
5. Request for Busy Time Information
|
|||
|
|
|||
|
Busy time information of one or more calendar users can be determined
|
|||
|
by submitting a POST request targeted at the scheduling Outbox
|
|||
|
collection of the calendar user requesting the information (the
|
|||
|
"Organizer"). To accomplish this, the request body MUST contain a
|
|||
|
"VFREEBUSY" calendar component with the "METHOD" iCalendar property
|
|||
|
set to the value "REQUEST" as specified in Section 3.3.2 of iTIP
|
|||
|
[RFC5546]. The resource identified by the Request-URI MUST be a
|
|||
|
resource collection of type CALDAV:schedule-outbox (Section 2.1).
|
|||
|
The "ORGANIZER" property value in the "VFREEBUSY" component MUST
|
|||
|
match one of the calendar user addresses of the owner of the Outbox
|
|||
|
collection.
|
|||
|
|
|||
|
A response to a busy time request that indicates status for one or
|
|||
|
more calendar users MUST be an XML document with a CALDAV:schedule-
|
|||
|
response XML element as its root element. This element MUST contain
|
|||
|
one CALDAV:response element for each calendar user, with each such
|
|||
|
element in turn containing elements that indicate which calendar user
|
|||
|
they correspond to, the scheduling status for that calendar user, any
|
|||
|
error codes, and an optional description. For a successful busy time
|
|||
|
request, a CALDAV:calendar-data element is also present for each
|
|||
|
calendar user, containing the actual busy time information (i.e., an
|
|||
|
iCalendar "VFREEBUSY" component). See Section 10 for details on the
|
|||
|
child elements. See Appendix B.5 for an example busy time request
|
|||
|
and response.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 37]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
5.1. Status Codes
|
|||
|
|
|||
|
The list below summarizes the most common status codes used for this
|
|||
|
method. However, clients need to be prepared to handle other
|
|||
|
2/3/4/5xx series status codes as well.
|
|||
|
|
|||
|
200 (OK) - The command succeeded.
|
|||
|
|
|||
|
204 (No Content) - The command succeeded.
|
|||
|
|
|||
|
400 (Bad Request) - The client has provided an invalid scheduling
|
|||
|
message.
|
|||
|
|
|||
|
403 (Forbidden) - The client cannot submit a scheduling message to
|
|||
|
the specified Request-URI.
|
|||
|
|
|||
|
404 (Not Found) - The URL in the Request-URI was not present.
|
|||
|
|
|||
|
423 (Locked) - The specified resource is locked, and the client
|
|||
|
either is not a lock owner or the lock type requires a lock token
|
|||
|
to be submitted and the client did not submit it.
|
|||
|
|
|||
|
5.2. Additional Method Preconditions
|
|||
|
|
|||
|
The following are existing preconditions that are reused for the POST
|
|||
|
method on an Outbox collection.
|
|||
|
|
|||
|
o DAV:need-privileges [RFC3744]
|
|||
|
|
|||
|
o CALDAV:supported-calendar-data [RFC4791]
|
|||
|
|
|||
|
o CALDAV:valid-calendar-data [RFC4791]
|
|||
|
|
|||
|
o CALDAV:max-resource-size [RFC4791]
|
|||
|
|
|||
|
The following are new method preconditions for the POST method on an
|
|||
|
Outbox collection.
|
|||
|
|
|||
|
5.2.1. CALDAV:valid-scheduling-message Precondition
|
|||
|
|
|||
|
Name: valid-scheduling-message
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: POST
|
|||
|
|
|||
|
Use with: 400 Bad Request
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 38]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Purpose: (precondition) -- The resource submitted in the POST
|
|||
|
request MUST obey all the restrictions specified in Section 3.3.2
|
|||
|
of iTIP [RFC5546].
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT valid-scheduling-message EMPTY>
|
|||
|
|
|||
|
5.2.2. CALDAV:valid-organizer Precondition
|
|||
|
|
|||
|
Name: valid-organizer
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Apply to: POST
|
|||
|
|
|||
|
Use with: 403 Forbidden
|
|||
|
|
|||
|
Purpose: (precondition) -- The "ORGANIZER" property value in the
|
|||
|
POST request's scheduling message MUST match one of the calendar
|
|||
|
user addresses of the owner of the scheduling Outbox collection
|
|||
|
being targeted by the request.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT valid-organizer EMPTY>
|
|||
|
|
|||
|
6. Scheduling Privileges
|
|||
|
|
|||
|
New scheduling privileges are defined in this section. All the
|
|||
|
scheduling privileges MUST be non-abstract and MUST appear in the
|
|||
|
DAV:supported-privilege-set property of scheduling Outbox and Inbox
|
|||
|
collections on which they are defined.
|
|||
|
|
|||
|
The tables specified in Appendix A clarify which scheduling methods
|
|||
|
(e.g., "REQUEST", "REPLY", etc.) are controlled by each scheduling
|
|||
|
privilege defined in this section.
|
|||
|
|
|||
|
6.1. Privileges on Scheduling Inbox Collections
|
|||
|
|
|||
|
This section defines new WebDAV Access Control List (ACL) [RFC3744]
|
|||
|
privileges that are defined for use on scheduling Inbox collections.
|
|||
|
These privileges determine whether delivery of scheduling messages
|
|||
|
from a calendar user is allowed by the calendar user who "owns" the
|
|||
|
scheduling Inbox collection. This allows calendar users to choose
|
|||
|
which other calendar users can schedule with them.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 39]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Note that when a scheduling message is delivered to a calendar user,
|
|||
|
in addition to a scheduling object resource being created in the
|
|||
|
calendar user's scheduling Inbox collection, a new scheduling object
|
|||
|
resource might be created or an existing one updated in a calendar
|
|||
|
belonging to the calendar user. In that case, the ability to create
|
|||
|
or update the scheduling object resource in the calendar is
|
|||
|
controlled by the privileges assigned to the scheduling Inbox
|
|||
|
collection.
|
|||
|
|
|||
|
The privileges defined in this section are ignored if applied to a
|
|||
|
resource other than a scheduling Inbox collection.
|
|||
|
|
|||
|
6.1.1. CALDAV:schedule-deliver Privilege
|
|||
|
|
|||
|
CALDAV:schedule-deliver is an aggregate privilege as per Section 6.3.
|
|||
|
|
|||
|
<!ELEMENT schedule-deliver EMPTY>
|
|||
|
|
|||
|
6.1.2. CALDAV:schedule-deliver-invite Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-deliver-invite privilege controls the processing
|
|||
|
and delivery of scheduling messages coming from an "Organizer".
|
|||
|
|
|||
|
<!ELEMENT schedule-deliver-invite EMPTY>
|
|||
|
|
|||
|
6.1.3. CALDAV:schedule-deliver-reply Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-deliver-reply privilege controls the processing
|
|||
|
and delivery of scheduling messages coming from an "Attendee".
|
|||
|
|
|||
|
<!ELEMENT schedule-deliver-reply EMPTY>
|
|||
|
|
|||
|
6.1.4. CALDAV:schedule-query-freebusy Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-query-freebusy privilege controls freebusy
|
|||
|
requests targeted at the owner of the scheduling Inbox collection.
|
|||
|
|
|||
|
<!ELEMENT schedule-query-freebusy EMPTY>
|
|||
|
|
|||
|
6.2. Privileges on Scheduling Outbox Collections
|
|||
|
|
|||
|
This section defines new WebDAV ACL [RFC3744] privileges that are
|
|||
|
defined for use on scheduling Outbox collections. These privileges
|
|||
|
determine which calendar users are allowed to send scheduling
|
|||
|
messages on behalf of the calendar user who "owns" the scheduling
|
|||
|
Outbox collection. This allows calendar users to choose other
|
|||
|
calendar users who can act on their behalf (e.g., assistants working
|
|||
|
on behalf of their boss).
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 40]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
The privileges defined in this section are ignored if applied to a
|
|||
|
resource other than a scheduling Outbox collection.
|
|||
|
|
|||
|
6.2.1. CALDAV:schedule-send Privilege
|
|||
|
|
|||
|
CALDAV:schedule-send is an aggregate privilege as per Section 6.3.
|
|||
|
|
|||
|
<!ELEMENT schedule-send EMPTY>
|
|||
|
|
|||
|
6.2.2. CALDAV:schedule-send-invite Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-send-invite privilege controls the sending of
|
|||
|
scheduling messages by "Organizers".
|
|||
|
|
|||
|
Users granted the DAV:bind privilege on a calendar collection, or the
|
|||
|
DAV:write privilege on scheduling object resources, will also need
|
|||
|
the CALDAV:schedule-send-invite privilege granted on the scheduling
|
|||
|
Outbox collection of the owner of the calendar collection or
|
|||
|
scheduling object resource in order to be allowed to create, modify,
|
|||
|
or delete scheduling object resources in a way that will trigger the
|
|||
|
CalDAV server to deliver scheduling messages to "Attendees".
|
|||
|
|
|||
|
<!ELEMENT schedule-send-invite EMPTY>
|
|||
|
|
|||
|
6.2.3. CALDAV:schedule-send-reply Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-send-reply privilege controls the sending of
|
|||
|
scheduling messages by "Attendees".
|
|||
|
|
|||
|
Users granted the DAV:bind privilege on a calendar collection, or the
|
|||
|
DAV:write privilege on scheduling object resources, will also need
|
|||
|
the CALDAV:schedule-send-reply privilege granted on the scheduling
|
|||
|
Outbox collection of the owner of the calendar collection or
|
|||
|
scheduling object resource in order to be allowed to create, modify,
|
|||
|
or delete scheduling object resources in a way that will trigger the
|
|||
|
CalDAV server to deliver scheduling message replies to the
|
|||
|
"Organizer".
|
|||
|
|
|||
|
<!ELEMENT schedule-send-reply EMPTY>
|
|||
|
|
|||
|
6.2.4. CALDAV:schedule-send-freebusy Privilege
|
|||
|
|
|||
|
The CALDAV:schedule-send-freebusy privilege controls the use of the
|
|||
|
POST method to submit scheduling messages that specify the scheduling
|
|||
|
method "REQUEST" with a "VFREEBUSY" calendar component.
|
|||
|
|
|||
|
<!ELEMENT schedule-send-freebusy EMPTY>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 41]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
6.3. Aggregation of Scheduling Privileges
|
|||
|
|
|||
|
Server implementations MUST aggregate the scheduling privileges as
|
|||
|
follows:
|
|||
|
|
|||
|
DAV:all contains CALDAV:schedule-deliver and CALDAV:schedule-send;
|
|||
|
|
|||
|
CALDAV:schedule-deliver contains CALDAV:schedule-deliver-invite,
|
|||
|
CALDAV:schedule-deliver-reply, and CALDAV:schedule-query-freebusy;
|
|||
|
|
|||
|
CALDAV:schedule-send contains CALDAV:schedule-send-invite, CALDAV:
|
|||
|
schedule-send-reply, and CALDAV:schedule-send-freebusy.
|
|||
|
|
|||
|
The following diagram illustrates how scheduling privileges are
|
|||
|
aggregated according to the above requirements.
|
|||
|
|
|||
|
[DAV:all] (aggregate)
|
|||
|
|
|
|||
|
+-- [CALDAV:schedule-deliver] (aggregate)
|
|||
|
| |
|
|||
|
| +-- [CALDAV:schedule-deliver-invite]
|
|||
|
| +-- [CALDAV:schedule-deliver-reply]
|
|||
|
| +-- [CALDAV:schedule-query-freebusy]
|
|||
|
|
|
|||
|
+-- [CALDAV:schedule-send] (aggregate)
|
|||
|
|
|
|||
|
+-- [CALDAV:schedule-send-invite]
|
|||
|
+-- [CALDAV:schedule-send-reply]
|
|||
|
+-- [CALDAV:schedule-send-freebusy]
|
|||
|
|
|||
|
7. Additional iCalendar Property Parameters
|
|||
|
|
|||
|
This specification defines additional iCalendar property parameters
|
|||
|
to support the CalDAV scheduling extensions.
|
|||
|
|
|||
|
7.1. Schedule Agent Parameter
|
|||
|
|
|||
|
Parameter Name: SCHEDULE-AGENT
|
|||
|
|
|||
|
Purpose: To specify the agent expected to deliver scheduling
|
|||
|
messages to the corresponding "Organizer" or "Attendee".
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 42]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Format Definition: This property parameter is defined by the
|
|||
|
following notation:
|
|||
|
|
|||
|
scheduleagentparam = "SCHEDULE-AGENT" "="
|
|||
|
("SERVER" ; The server handles scheduling
|
|||
|
/ "CLIENT" ; The client handles scheduling
|
|||
|
/ "NONE" ; No scheduling
|
|||
|
/ x-name ; Experimental type
|
|||
|
/ iana-token) ; Other IANA-registered type
|
|||
|
;
|
|||
|
; If the parameter is not present, its value defaults to SERVER.
|
|||
|
; "x-name" and "iana-token" are defined in Section 3.1 of
|
|||
|
; [RFC5545].
|
|||
|
|
|||
|
Description: This property parameter MAY be specified on "ORGANIZER"
|
|||
|
or "ATTENDEE" iCalendar properties. In the absence of this
|
|||
|
parameter, the value "SERVER" MUST be used for the default
|
|||
|
behavior. The value determines whether or not a scheduling
|
|||
|
operation on a server will cause a scheduling message to be sent
|
|||
|
to the corresponding calendar user identified by the "ORGANIZER"
|
|||
|
or "ATTENDEE" property value. When the value "SERVER" is
|
|||
|
specified, or the parameter is absent, then it is the server's
|
|||
|
responsibility to send a scheduling message as part of a
|
|||
|
scheduling operation. When the value "CLIENT" is specified, that
|
|||
|
indicates that the client is handling scheduling messages with the
|
|||
|
calendar user itself. When "NONE" is specified, no scheduling
|
|||
|
messages are being sent to the calendar user.
|
|||
|
|
|||
|
Servers MUST NOT include this parameter in any scheduling messages
|
|||
|
sent as the result of a scheduling operation.
|
|||
|
|
|||
|
Clients MUST NOT include this parameter in any scheduling messages
|
|||
|
that they themselves send.
|
|||
|
|
|||
|
The parameter value MUST be the same on every "ORGANIZER" property
|
|||
|
in a scheduling object resource.
|
|||
|
|
|||
|
The parameter value MUST be the same on each "ATTENDEE" property
|
|||
|
whose values match in a scheduling object resource.
|
|||
|
|
|||
|
Servers and clients MUST treat x-name and iana-token values they
|
|||
|
do not recognize the same way as they would the "NONE" value.
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
ORGANIZER;SCHEDULE-AGENT=SERVER:mailto:bernard@example.com
|
|||
|
ATTENDEE;SCHEDULE-AGENT=NONE:mailto:cyrus@example.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 43]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
7.2. Schedule Force Send Parameter
|
|||
|
|
|||
|
Parameter Name: SCHEDULE-FORCE-SEND
|
|||
|
|
|||
|
Purpose: To force a scheduling message to be sent to the calendar
|
|||
|
user specified by the property.
|
|||
|
|
|||
|
Format Definition: This property parameter is defined by the
|
|||
|
following notation:
|
|||
|
|
|||
|
scheduleforcesendparam = "SCHEDULE-FORCE-SEND" "="
|
|||
|
("REQUEST" ; Force a "REQUEST"
|
|||
|
/ "REPLY" ; Force a "REPLY"
|
|||
|
/ iana-token)
|
|||
|
;
|
|||
|
; "iana-token" is defined in Section 3.1 of [RFC5545]. Its value
|
|||
|
; MUST be an IANA-registered iCalendar "METHOD" property value.
|
|||
|
|
|||
|
Description: This property parameter MAY be specified on "ATTENDEE"
|
|||
|
and "ORGANIZER" properties on which the "SCHEDULE-AGENT" property
|
|||
|
parameter is set to the value "SERVER" or is not specified. This
|
|||
|
property parameter is used to force a server to send a scheduling
|
|||
|
message to a specific calendar user in situations where the server
|
|||
|
would not send a scheduling message otherwise (e.g., when no
|
|||
|
change that warrants the delivery of a new scheduling message was
|
|||
|
performed on the scheduling object resource). An "Organizer" MAY
|
|||
|
specify this parameter on an "ATTENDEE" property with the value
|
|||
|
"REQUEST" to force a "REQUEST" scheduling message to be sent to
|
|||
|
this "Attendee". An "Attendee" MAY specify this parameter on the
|
|||
|
"ORGANIZER" with the value "REPLY" to force a "REPLY" scheduling
|
|||
|
message to be sent to the "Organizer".
|
|||
|
|
|||
|
Servers MUST NOT preserve this property parameter in scheduling
|
|||
|
object resources, nor include it in any scheduling messages sent
|
|||
|
as the result of a scheduling operation.
|
|||
|
|
|||
|
Clients MUST NOT include this parameter in any scheduling messages
|
|||
|
that they themselves send.
|
|||
|
|
|||
|
Servers MUST set the "SCHEDULE-STATUS" parameter of the "ATTENDEE"
|
|||
|
or "ORGANIZER" to 2.3 (i.e., "Success; invalid property parameter
|
|||
|
ignored"; see Section 3.6 of [RFC5546]) when the "SCHEDULE-FORCE-
|
|||
|
SEND" parameter is set to an iana-token value they do not
|
|||
|
recognize.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 44]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
ORGANIZER;SCHEDULE-FORCE-SEND=REPLY:mailto:cyrus@example.com
|
|||
|
ATTENDEE;SCHEDULE-FORCE-SEND=REQUEST:mailto:bernard@example.com
|
|||
|
|
|||
|
7.3. Schedule Status Parameter
|
|||
|
|
|||
|
Parameter Name: SCHEDULE-STATUS
|
|||
|
|
|||
|
Purpose: To specify the status codes returned from processing of the
|
|||
|
most recent scheduling message sent to the corresponding
|
|||
|
"Attendee", or received from the corresponding "Organizer".
|
|||
|
|
|||
|
Format Definition: This property parameter is defined by the
|
|||
|
following notation:
|
|||
|
|
|||
|
schedulestatusparam = "SCHEDULE-STATUS" "="
|
|||
|
( statcode
|
|||
|
/ DQUOTE statcode *("," statcode) DQUOTE)
|
|||
|
;
|
|||
|
; "statcode" is defined in Section 3.8.8.3 of [RFC5545]. The
|
|||
|
; value is a single "statcode" or a comma-separated list of
|
|||
|
; "statcode" values.
|
|||
|
|
|||
|
Description: This property parameter MAY be specified on the
|
|||
|
"ATTENDEE" and "ORGANIZER" properties.
|
|||
|
|
|||
|
Servers MUST only add or change this property parameter on any
|
|||
|
"ATTENDEE" properties corresponding to calendar users who were
|
|||
|
sent a scheduling message via a scheduling operation. Clients
|
|||
|
SHOULD NOT change or remove this parameter if it was provided by
|
|||
|
the server. In the case where the client is handling the
|
|||
|
scheduling, the client MAY add, change, or remove this parameter
|
|||
|
to indicate the last scheduling message status it received.
|
|||
|
|
|||
|
Servers MUST add this parameter to any "ORGANIZER" properties
|
|||
|
corresponding to calendar users who were sent a scheduling message
|
|||
|
reply by an "Attendee" via a scheduling operation. Clients SHOULD
|
|||
|
NOT change or remove this parameter if it was provided by the
|
|||
|
server. In the case where the client is handling the scheduling,
|
|||
|
the client MAY add, change, or remove this parameter to indicate
|
|||
|
the last scheduling message status it received.
|
|||
|
|
|||
|
Servers MUST NOT include this parameter in any scheduling messages
|
|||
|
sent as the result of a scheduling operation.
|
|||
|
|
|||
|
Clients MUST NOT include this parameter in any scheduling messages
|
|||
|
that they themselves send.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 45]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Values for this property parameter are described in Section 3.2.9.
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
ATTENDEE;SCHEDULE-STATUS="2.0":mailto:bernard@example.com
|
|||
|
ATTENDEE;SCHEDULE-STATUS="2.0,2.4":mailto:cyrus@example.com
|
|||
|
|
|||
|
8. Additional Message Header Fields
|
|||
|
|
|||
|
This specification defines additional HTTP request and response
|
|||
|
headers for use with CalDAV.
|
|||
|
|
|||
|
8.1. Schedule-Reply Request Header
|
|||
|
|
|||
|
Schedule-Reply = "Schedule-Reply" ":" ("T" | "F")
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
Schedule-Reply: F
|
|||
|
|
|||
|
When an "Attendee" removes a scheduling object resource as per
|
|||
|
Section 3.2.2.4, and the Schedule-Reply header is set to the value
|
|||
|
"T" (true) or is not present, the server MUST send an appropriate
|
|||
|
reply scheduling message with the "Attendee's" "PARTSTAT" iCalendar
|
|||
|
property parameter value set to "DECLINED" as part of its normal
|
|||
|
scheduling operation processing.
|
|||
|
|
|||
|
When the Schedule-Reply header is set to the value "F" (false), the
|
|||
|
server MUST NOT send a scheduling message as part of its normal
|
|||
|
scheduling operation processing.
|
|||
|
|
|||
|
The Schedule-Reply request header is used by a client to indicate to
|
|||
|
a server whether or not a scheduling operation ought to occur when an
|
|||
|
"Attendee" deletes a scheduling object resource. In particular, it
|
|||
|
controls whether a reply scheduling message is sent to the
|
|||
|
"Organizer" as a result of the removal. There are situations in
|
|||
|
which unsolicited scheduling messages need to be silently removed (or
|
|||
|
ignored) for security or privacy reasons. This request header allows
|
|||
|
the scheduling object resource to be removed if such a need arises.
|
|||
|
|
|||
|
8.2. Schedule-Tag Response Header
|
|||
|
|
|||
|
The Schedule-Tag response header provides the current value of the
|
|||
|
CALDAV:schedule-tag property value. The behavior of this response
|
|||
|
header is described in Section 3.2.10.
|
|||
|
|
|||
|
All scheduling object resources MUST support the Schedule-Tag header.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 46]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Schedule-Tag = "Schedule-Tag" ":" opaque-tag
|
|||
|
; "opaque-tag" is defined in Section 3.11 of [RFC2616].
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
Schedule-Tag: "12ab34-cd56ef"
|
|||
|
|
|||
|
8.3. If-Schedule-Tag-Match Request Header
|
|||
|
|
|||
|
The If-Schedule-Tag-Match request header field is used with a method
|
|||
|
to make it conditional. Clients can set this header to the value
|
|||
|
returned in the Schedule-Tag response header, or the CALDAV:schedule-
|
|||
|
tag property, of a scheduling object resource previously retrieved
|
|||
|
from the server to avoid overwriting "consequential" changes to the
|
|||
|
scheduling object resource.
|
|||
|
|
|||
|
All scheduling object resources MUST support the If-Schedule-Tag-
|
|||
|
Match header.
|
|||
|
|
|||
|
If-Schedule-Tag-Match = "If-Schedule-Tag-Match" ":" opaque-tag
|
|||
|
; "opaque-tag" is defined in Section 3.11 of [RFC2616].
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
If-Schedule-Tag-Match: "12ab34-cd56ef"
|
|||
|
|
|||
|
9. Additional WebDAV Properties
|
|||
|
|
|||
|
This specification defines the following new WebDAV properties for
|
|||
|
use with CalDAV.
|
|||
|
|
|||
|
9.1. CALDAV:schedule-calendar-transp Property
|
|||
|
|
|||
|
Name: schedule-calendar-transp
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Determines whether the calendar object resources in a
|
|||
|
calendar collection will affect the owner's busy time information.
|
|||
|
|
|||
|
Protected: This property MAY be protected and SHOULD NOT be returned
|
|||
|
by a PROPFIND DAV:allprop request (as defined in Section 14.2 of
|
|||
|
[RFC4918]).
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value SHOULD be kept during a MOVE
|
|||
|
operation, and SHOULD be copied and preserved in a COPY.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 47]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Description: This property SHOULD be defined on all calendar
|
|||
|
collections. If present, it contains one of two XML elements that
|
|||
|
indicate whether the calendar object resources in the calendar
|
|||
|
collection ought to contribute to the owner's busy time. When the
|
|||
|
CALDAV:opaque element is used, all calendar object resources in
|
|||
|
the corresponding calendar collection MUST contribute to busy
|
|||
|
time, assuming that access privileges and other iCalendar
|
|||
|
properties allow it to. When the CALDAV:transparent XML element
|
|||
|
is used, the calendar object resources in the corresponding
|
|||
|
calendar collection MUST NOT contribute to busy time.
|
|||
|
|
|||
|
If this property is not present on a calendar collection, then the
|
|||
|
default value CALDAV:opaque MUST be assumed.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-calendar-transp (opaque | transparent)>
|
|||
|
|
|||
|
<!ELEMENT opaque EMPTY>
|
|||
|
<!-- Affects busy time searches -->
|
|||
|
|
|||
|
<!ELEMENT transparent EMPTY>
|
|||
|
<!-- Invisible to busy time searches -->
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:schedule-calendar-transp
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<C:opaque/>
|
|||
|
</C:schedule-calendar-transp>
|
|||
|
|
|||
|
9.2. CALDAV:schedule-default-calendar-URL Property
|
|||
|
|
|||
|
Name: schedule-default-calendar-URL
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Specifies a default calendar for an "Attendee" where new
|
|||
|
scheduling object resources are created.
|
|||
|
|
|||
|
Protected: This property MAY be protected in the case where a server
|
|||
|
does not support changing the default calendar, or does not
|
|||
|
support a default calendar.
|
|||
|
|
|||
|
COPY/MOVE behavior: This property is only defined on a scheduling
|
|||
|
Inbox collection that cannot be moved or copied.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 48]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Description: This property MAY be defined on a scheduling Inbox
|
|||
|
collection. If present, it contains zero or one DAV:href XML
|
|||
|
elements. When a DAV:href element is present, its value indicates
|
|||
|
a URL to a calendar collection that is used as the default
|
|||
|
calendar. When no DAV:href element is present, it indicates that
|
|||
|
there is no default calendar. In the absence of this property,
|
|||
|
there is no default calendar. When there is no default calendar,
|
|||
|
the server is free to choose the calendar in which a new
|
|||
|
scheduling object resource is created. See Section 4.3.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-default-calendar-URL (DAV:href?)>
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:schedule-default-calendar-URL xmlns:D="DAV:"
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<D:href>/home/cyrus/calendars/work/</D:href>
|
|||
|
</C:schedule-default-calendar-URL>
|
|||
|
|
|||
|
9.3. CALDAV:schedule-tag Property
|
|||
|
|
|||
|
Name: schedule-tag
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Indicates whether a scheduling object resource has had a
|
|||
|
"consequential" change made to it.
|
|||
|
|
|||
|
Value: opaque-tag (defined in Section 3.11 of [RFC2616])
|
|||
|
|
|||
|
Protected: This property MUST be protected, as only the server can
|
|||
|
update the value.
|
|||
|
|
|||
|
COPY/MOVE behavior: This property value is determined by the server
|
|||
|
and MAY be different from the value on the source resource.
|
|||
|
|
|||
|
Description: The CALDAV:schedule-tag property MUST be defined on all
|
|||
|
scheduling object resources. This property is described in
|
|||
|
Section 3.2.10.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-tag (#PCDATA)>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 49]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
<C:schedule-tag xmlns:C="urn:ietf:params:xml:ns:caldav"
|
|||
|
>"12345-67890"</C:schedule-tag>
|
|||
|
|
|||
|
10. XML Element Definitions
|
|||
|
|
|||
|
10.1. CALDAV:schedule-response XML Element
|
|||
|
|
|||
|
Name: schedule-response
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Contains the set of responses for a POST method request.
|
|||
|
|
|||
|
Description: See Section 5.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT schedule-response (response*)>
|
|||
|
|
|||
|
10.2. CALDAV:response XML Element
|
|||
|
|
|||
|
Name: response
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: Contains a single response for a POST method request.
|
|||
|
|
|||
|
Description: See Section 5.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT response (recipient,
|
|||
|
request-status,
|
|||
|
calendar-data?,
|
|||
|
DAV:error?,
|
|||
|
DAV:responsedescription?)>
|
|||
|
|
|||
|
<!-- CALDAV:calendar-data is defined in Section 9.6 of
|
|||
|
RFC 4791 and when used here uses the definition with
|
|||
|
content (#PCDATA) only. -->
|
|||
|
|
|||
|
10.3. CALDAV:recipient XML Element
|
|||
|
|
|||
|
Name: recipient
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 50]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Purpose: The calendar user address that the enclosing response for a
|
|||
|
POST method request is for.
|
|||
|
|
|||
|
Description: See Section 5.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT recipient (DAV:href)>
|
|||
|
|
|||
|
10.4. CALDAV:request-status XML Element
|
|||
|
|
|||
|
Name: request-status
|
|||
|
|
|||
|
Namespace: urn:ietf:params:xml:ns:caldav
|
|||
|
|
|||
|
Purpose: The iTIP "REQUEST-STATUS" property value for this response.
|
|||
|
|
|||
|
Description: See Section 5.
|
|||
|
|
|||
|
Definition:
|
|||
|
|
|||
|
<!ELEMENT request-status (#PCDATA)>
|
|||
|
|
|||
|
11. Security Considerations
|
|||
|
|
|||
|
The process of scheduling involves the sending and receiving of
|
|||
|
scheduling messages. As a result, the security problems related to
|
|||
|
messaging in general are relevant here. In particular, the
|
|||
|
authenticity of the scheduling messages needs to be verified.
|
|||
|
Servers and clients MUST use an HTTP connection protected with
|
|||
|
Transport Layer Security (TLS) as defined in [RFC2818] for all
|
|||
|
scheduling operations. Clients MUST use the procedures detailed in
|
|||
|
Section 6 of [RFC6125] to verify the authenticity of the server.
|
|||
|
Servers MUST make use of HTTP authentication [RFC2617] to verify the
|
|||
|
authenticity of the calendar user for whom the client is sending
|
|||
|
requests.
|
|||
|
|
|||
|
11.1. Preventing Denial-of-Service Attacks
|
|||
|
|
|||
|
Servers MUST ensure that clients cannot consume excessive server
|
|||
|
resources by carrying out "large" scheduling operations. In
|
|||
|
particular, servers SHOULD enforce CALDAV:max-resource-size, CALDAV:
|
|||
|
max-instances, and CALDAV:max-attendees-per-instance preconditions as
|
|||
|
applicable for scheduling Inbox and Outbox collections.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 51]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
11.2. Verifying Scheduling Operations
|
|||
|
|
|||
|
When handling a scheduling operation:
|
|||
|
|
|||
|
1. Servers MUST verify that the principal associated with the DAV:
|
|||
|
owner of the calendar collection in which a scheduling object
|
|||
|
resource is being manipulated contains a CALDAV:schedule-outbox-
|
|||
|
URL property value.
|
|||
|
|
|||
|
2. Servers MUST verify that the currently authenticated user has the
|
|||
|
CALDAV:schedule-send privilege, or a sub-privilege aggregated
|
|||
|
under this privilege, on the scheduling Outbox collection of the
|
|||
|
DAV:owner of the calendar collection in which a scheduling object
|
|||
|
resource is being manipulated.
|
|||
|
|
|||
|
3. Servers MUST only deliver scheduling messages to recipients when
|
|||
|
the CALDAV:schedule-deliver privilege, or a sub-privilege
|
|||
|
aggregated under this privilege, is granted on the recipient's
|
|||
|
scheduling Inbox collection for the principal associated with the
|
|||
|
DAV:owner of the calendar collection in which a scheduling object
|
|||
|
resource is being manipulated.
|
|||
|
|
|||
|
4. To prevent impersonation of calendar users, the server MUST
|
|||
|
verify that the "ORGANIZER" property in an organizer scheduling
|
|||
|
object resource matches one of the calendar user addresses of the
|
|||
|
DAV:owner of the calendar collection in which the resource is
|
|||
|
stored.
|
|||
|
|
|||
|
5. To prevent spoofing of an existing scheduling object resource,
|
|||
|
servers MUST verify that the "UID" iCalendar property value in a
|
|||
|
new scheduling object resource does not match that of an existing
|
|||
|
scheduling object resource with a different "ORGANIZER" property
|
|||
|
value.
|
|||
|
|
|||
|
11.3. Verifying Busy Time Information Requests
|
|||
|
|
|||
|
When handling a POST request on a scheduling Outbox collection:
|
|||
|
|
|||
|
1. Servers MUST verify that the principal associated with the
|
|||
|
calendar user address specified in the "ORGANIZER" property of
|
|||
|
the scheduling message data in the request contains a CALDAV:
|
|||
|
schedule-outbox-URL property value that matches the scheduling
|
|||
|
Outbox collection targeted by the request.
|
|||
|
|
|||
|
2. Servers MUST verify that the currently authenticated user has the
|
|||
|
CALDAV:schedule-send privilege, or a sub-privilege aggregated
|
|||
|
under this privilege, on the scheduling Outbox collection
|
|||
|
targeted by the request.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 52]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
3. Servers MUST only return valid freebusy information for
|
|||
|
recipients when the CALDAV:schedule-deliver privilege, or a
|
|||
|
sub-privilege aggregated under this privilege, is granted on the
|
|||
|
recipient's scheduling Inbox collection for the principal
|
|||
|
associated with the DAV:owner of the scheduling Outbox collection
|
|||
|
targeted by the request.
|
|||
|
|
|||
|
11.4. Privacy Issues
|
|||
|
|
|||
|
This specification only defines how calendar users on the same server
|
|||
|
are able to schedule with each other -- unauthenticated users have no
|
|||
|
way to carry out scheduling operations. Access control privileges
|
|||
|
(as per Section 6) can control which of those users can schedule with
|
|||
|
others. Calendar users not wishing to expose their calendar
|
|||
|
information to other users can do so by denying privileges to
|
|||
|
specific users, or all users, for all scheduling operations, or
|
|||
|
perhaps only freebusy.
|
|||
|
|
|||
|
"Attendees" can also use the Schedule-Reply request header
|
|||
|
(Section 8.1) with the value set to "F" to prevent notification to an
|
|||
|
"Organizer" that a scheduling object resource was deleted. This
|
|||
|
allows "Attendees" to remove unwanted scheduling messages without any
|
|||
|
response to the "Organizer".
|
|||
|
|
|||
|
Servers MUST NOT expose any private iCalendar data, or WebDAV
|
|||
|
resource state information (URLs, WebDAV properties, etc.) for one
|
|||
|
calendar user to another via scheduling messages or error responses
|
|||
|
to scheduling operations. In particular, as per Section 8.1 of
|
|||
|
[RFC4918], authorization errors MUST take preference over other
|
|||
|
errors.
|
|||
|
|
|||
|
11.5. Mitigation of iTIP Threats
|
|||
|
|
|||
|
Section 6.1 of iTIP [RFC5546] defines a set of potential threats in a
|
|||
|
scheduling system, and Section 6.2 of [RFC5546] defines
|
|||
|
recommendations on how those can be addressed in protocols using
|
|||
|
iTIP. This specification addresses the iTIP threats in the following
|
|||
|
manner:
|
|||
|
|
|||
|
Spoofing the "Organizer": Addressed by item 4 in Section 11.2.
|
|||
|
|
|||
|
Spoofing the "Attendee": Addressed by Section 3.2.2.1 and item 2 in
|
|||
|
Section 11.2.
|
|||
|
|
|||
|
Unauthorized Replacement of the "Organizer": Addressed by item 5 in
|
|||
|
Section 11.2.
|
|||
|
|
|||
|
Eavesdropping and Data Integrity: Addressed by requiring TLS.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 53]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Flooding a Calendar: Addressed by requirements in Section 11.1.
|
|||
|
|
|||
|
Unauthorized REFRESH Requests: This specification does not support
|
|||
|
the REFRESH method.
|
|||
|
|
|||
|
12. IANA Considerations
|
|||
|
|
|||
|
12.1. Message Header Field Registrations
|
|||
|
|
|||
|
The message header fields below have been added to the Permanent
|
|||
|
Message Header Field Registry (see [RFC3864]).
|
|||
|
|
|||
|
12.1.1. Schedule-Reply
|
|||
|
|
|||
|
Header field name: Schedule-Reply
|
|||
|
|
|||
|
Applicable protocol: http
|
|||
|
|
|||
|
Status: standard
|
|||
|
|
|||
|
Author/Change controller: IETF
|
|||
|
|
|||
|
Specification document(s): this specification (Section 8.1)
|
|||
|
|
|||
|
Related information: none
|
|||
|
|
|||
|
12.1.2. Schedule-Tag
|
|||
|
|
|||
|
Header field name: Schedule-Tag
|
|||
|
|
|||
|
Applicable protocol: http
|
|||
|
|
|||
|
Status: standard
|
|||
|
|
|||
|
Author/Change controller: IETF
|
|||
|
|
|||
|
Specification document(s): this specification (Section 8.2)
|
|||
|
|
|||
|
Related information: none
|
|||
|
|
|||
|
12.1.3. If-Schedule-Tag-Match
|
|||
|
|
|||
|
Header field name: If-Schedule-Tag-Match
|
|||
|
|
|||
|
Applicable protocol: http
|
|||
|
|
|||
|
Status: standard
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 54]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Author/Change controller: IETF
|
|||
|
|
|||
|
Specification document(s): this specification (Section 8.3)
|
|||
|
|
|||
|
Related information: none
|
|||
|
|
|||
|
12.2. iCalendar Property Parameter Registrations
|
|||
|
|
|||
|
The following iCalendar property parameter names have been added to
|
|||
|
the iCalendar Parameters Registry defined in Section 8.3.3 of
|
|||
|
[RFC5545].
|
|||
|
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
| Parameter | Status | Reference |
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
| SCHEDULE-AGENT | Current | RFC 6638, Section 7.1 |
|
|||
|
| | | |
|
|||
|
| SCHEDULE-STATUS | Current | RFC 6638, Section 7.3 |
|
|||
|
| | | |
|
|||
|
| SCHEDULE-FORCE-SEND | Current | RFC 6638, Section 7.2 |
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
|
|||
|
12.3. iCalendar REQUEST-STATUS Value Registrations
|
|||
|
|
|||
|
The following iCalendar "REQUEST-STATUS" values have been added to
|
|||
|
the iCalendar REQUEST-STATUS Value Registry defined in Section 7.3 of
|
|||
|
[RFC5546].
|
|||
|
|
|||
|
+-------------+---------+---------------------------+
|
|||
|
| Status Code | Status | Reference |
|
|||
|
+-------------+---------+---------------------------+
|
|||
|
| 1.0 | Current | RFC 6638, Section 3.2.9.1 |
|
|||
|
| | | |
|
|||
|
| 1.1 | Current | RFC 6638, Section 3.2.9.2 |
|
|||
|
| | | |
|
|||
|
| 1.2 | Current | RFC 6638, Section 3.2.9.3 |
|
|||
|
+-------------+---------+---------------------------+
|
|||
|
|
|||
|
12.4. Additional iCalendar Elements Registries
|
|||
|
|
|||
|
Per this specification, two new IANA registries for iCalendar
|
|||
|
elements have been added. Additional codes MAY be used, provided the
|
|||
|
process described in Section 8.2.1 of [RFC5545] is used to register
|
|||
|
them.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 55]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
12.4.1. Schedule Agent Values Registry
|
|||
|
|
|||
|
The following table has been used to initialize the Schedule Agent
|
|||
|
Values Registry.
|
|||
|
|
|||
|
+----------------+---------+-----------------------+
|
|||
|
| Schedule Agent | Status | Reference |
|
|||
|
+----------------+---------+-----------------------+
|
|||
|
| SERVER | Current | RFC 6638, Section 7.1 |
|
|||
|
| | | |
|
|||
|
| CLIENT | Current | RFC 6638, Section 7.1 |
|
|||
|
| | | |
|
|||
|
| NONE | Current | RFC 6638, Section 7.1 |
|
|||
|
+----------------+---------+-----------------------+
|
|||
|
|
|||
|
12.4.2. Schedule Force Send Values Registry
|
|||
|
|
|||
|
The following table has been used to initialize the Schedule Force
|
|||
|
Send Values Registry.
|
|||
|
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
| Schedule Force Send | Status | Reference |
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
| REQUEST | Current | RFC 6638, Section 7.2 |
|
|||
|
| | | |
|
|||
|
| REPLY | Current | RFC 6638, Section 7.2 |
|
|||
|
+---------------------+---------+-----------------------+
|
|||
|
|
|||
|
13. Acknowledgements
|
|||
|
|
|||
|
The authors would like to thank the following individuals for
|
|||
|
contributing their ideas and support for writing this specification:
|
|||
|
Mike Douglass, Lisa Dusseault, Red Dutta, Jacob Farkas, Jeffrey
|
|||
|
Harris, Helge Hess, Eliot Lear, Andrew McMillan, Alexey Melnikov,
|
|||
|
Arnaud Quillaud, Julian F. Reschke, Wilfredo Sanchez Vega, and Simon
|
|||
|
Vaillancourt.
|
|||
|
|
|||
|
The authors would also like to thank the Calendaring and Scheduling
|
|||
|
Consortium for advice with this specification, and for organizing
|
|||
|
interoperability testing events to help refine it.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 56]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
14. References
|
|||
|
|
|||
|
14.1. 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.
|
|||
|
|
|||
|
[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.
|
|||
|
|
|||
|
[RFC2818] Rescorla, E., "HTTP Over TLS", RFC 2818, May 2000.
|
|||
|
|
|||
|
[RFC3744] Clemm, G., Reschke, J., Sedlar, E., and J. Whitehead, "Web
|
|||
|
Distributed Authoring and Versioning (WebDAV)
|
|||
|
Access Control Protocol", RFC 3744, May 2004.
|
|||
|
|
|||
|
[RFC3864] Klyne, G., Nottingham, M., and J. Mogul, "Registration
|
|||
|
Procedures for Message Header Fields", BCP 90, RFC 3864,
|
|||
|
September 2004.
|
|||
|
|
|||
|
[RFC4791] Daboo, C., Desruisseaux, B., and L. Dusseault,
|
|||
|
"Calendaring Extensions to WebDAV (CalDAV)", RFC 4791,
|
|||
|
March 2007.
|
|||
|
|
|||
|
[RFC4918] Dusseault, L., Ed., "HTTP Extensions for Web Distributed
|
|||
|
Authoring and Versioning (WebDAV)", RFC 4918, June 2007.
|
|||
|
|
|||
|
[RFC5234] Crocker, D., Ed., and P. Overell, "Augmented BNF for
|
|||
|
Syntax Specifications: ABNF", STD 68, RFC 5234,
|
|||
|
January 2008.
|
|||
|
|
|||
|
[RFC5545] Desruisseaux, B., Ed., "Internet Calendaring and
|
|||
|
Scheduling Core Object Specification (iCalendar)",
|
|||
|
RFC 5545, September 2009.
|
|||
|
|
|||
|
[RFC5546] Daboo, C., Ed., "iCalendar Transport-Independent
|
|||
|
Interoperability Protocol (iTIP)", RFC 5546,
|
|||
|
December 2009.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 57]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
[RFC6125] Saint-Andre, P. and J. Hodges, "Representation and
|
|||
|
Verification of Domain-Based Application Service Identity
|
|||
|
within Internet Public Key Infrastructure Using X.509
|
|||
|
(PKIX) Certificates in the Context of Transport Layer
|
|||
|
Security (TLS)", RFC 6125, March 2011.
|
|||
|
|
|||
|
[W3C.REC-xml-20081126]
|
|||
|
Bray, T., Paoli, J., Sperberg-McQueen, C., Maler, E.,
|
|||
|
and F. Yergeau, "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>.
|
|||
|
|
|||
|
14.2. Informative References
|
|||
|
|
|||
|
[RFC6047] Melnikov, A., Ed., "iCalendar Message-Based
|
|||
|
Interoperability Protocol (iMIP)", RFC 6047,
|
|||
|
December 2010.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 58]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Appendix A. Scheduling Privileges Summary
|
|||
|
|
|||
|
A.1. Scheduling Inbox Privileges
|
|||
|
|
|||
|
The following tables specify which scheduling privileges grant the
|
|||
|
right to a calendar user to deliver a scheduling message to the
|
|||
|
scheduling Inbox collection of another calendar user. The
|
|||
|
appropriate behavior depends on the calendar component type as well
|
|||
|
as the scheduling "METHOD" specified in the scheduling message.
|
|||
|
|
|||
|
+--------------------------------+
|
|||
|
| METHOD for VEVENT and VTODO |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
| Scheduling Inbox Privilege | REQUEST | REPLY | ADD | CANCEL |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
| schedule-deliver | * | * | * | * |
|
|||
|
| schedule-deliver-invite | * | | * | * |
|
|||
|
| schedule-deliver-reply | | * | | |
|
|||
|
| schedule-query-freebusy | | | | |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
|
|||
|
|
|||
|
+----------------------+
|
|||
|
| METHOD for VFREEBUSY |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
| Scheduling Inbox Privilege | REQUEST |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
| schedule-deliver | * |
|
|||
|
| schedule-deliver-invite | |
|
|||
|
| schedule-deliver-reply | |
|
|||
|
| schedule-query-freebusy | * |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 59]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
A.2. Scheduling Outbox Privileges
|
|||
|
|
|||
|
The following tables specify which scheduling privileges grant the
|
|||
|
right to a calendar user to perform busy time information requests
|
|||
|
and to submit scheduling messages to other calendar users as the
|
|||
|
result of a scheduling operation. The appropriate behavior depends
|
|||
|
on the calendar component type as well as the scheduling "METHOD"
|
|||
|
specified in the scheduling message.
|
|||
|
|
|||
|
+--------------------------------+
|
|||
|
| METHOD for VEVENT and VTODO |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
| Scheduling Outbox Privilege | REQUEST | REPLY | ADD | CANCEL |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
| schedule-send | * | * | * | * |
|
|||
|
| schedule-send-invite | * | | * | * |
|
|||
|
| schedule-send-reply | | * | | |
|
|||
|
| schedule-send-freebusy | | | | |
|
|||
|
+-----------------------------+---------+-------+-----+--------+
|
|||
|
|
|||
|
|
|||
|
+----------------------+
|
|||
|
| METHOD for VFREEBUSY |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
| Scheduling Outbox Privilege | REQUEST |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
| schedule-send | * |
|
|||
|
| schedule-send-invite | |
|
|||
|
| schedule-send-reply | |
|
|||
|
| schedule-send-freebusy | * |
|
|||
|
+-----------------------------+----------------------+
|
|||
|
|
|||
|
Appendix B. Example Scheduling Operations
|
|||
|
|
|||
|
This section describes some example scheduling operations that give a
|
|||
|
general idea of how scheduling is carried out between CalDAV clients
|
|||
|
and servers from the perspective of meeting "Organizers" and
|
|||
|
"Attendees".
|
|||
|
|
|||
|
The server is assumed to be hosted in the "example.com" domain, and
|
|||
|
users whose email addresses are at the "example.com" domain are
|
|||
|
assumed to be hosted by the server. In addition, the email addresses
|
|||
|
in the "example.net" domain are also valid email addresses for
|
|||
|
calendar users hosted by the server. Calendar users with an email
|
|||
|
address at the "example.org" domain are assumed to not be hosted by
|
|||
|
the server.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 60]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
In the following examples, the requests and responses are incomplete
|
|||
|
and are only for illustrative purposes. In particular, HTTP
|
|||
|
authentication headers and behaviors are not shown, even though they
|
|||
|
are required in normal operation.
|
|||
|
|
|||
|
B.1. Example: "Organizer" Inviting Multiple "Attendees"
|
|||
|
|
|||
|
In the following example, Cyrus invites Wilfredo, Bernard, and Mike
|
|||
|
to a single instance event by simply creating a new scheduling object
|
|||
|
resource in one of his calendar collections by using the PUT method.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PUT /home/cyrus/calendars/work/9263504FD3AD.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
If-None-Match: *
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185254Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:wilfredo@
|
|||
|
example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@ex
|
|||
|
ample.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE:mailto:mike@example.org
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 201 Created
|
|||
|
Content-Length: 0
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 61]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Date: Tue, 02 Jun 2009 18:52:54 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:52:54 GMT
|
|||
|
ETag: "d85561cfe74a4e785eb4639451b434fb"
|
|||
|
Schedule-Tag: "488177c8-2ea7-4176-a6cb-fab8cfccdea2"
|
|||
|
|
|||
|
Once the event creation has been completed, Cyrus's client will
|
|||
|
retrieve the event back from the server to get the schedule status of
|
|||
|
each "Attendee", as well as record the Schedule-Tag value for future
|
|||
|
use. In this example, the server reports that a scheduling message
|
|||
|
was delivered to Wilfredo, a scheduling message is still pending for
|
|||
|
Bernard, and the server was unable to deliver a scheduling message to
|
|||
|
Mike.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/cyrus/calendars/work/9263504FD3AD.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
ETag: "eb897deabc8939589da116714bc99265"
|
|||
|
Schedule-Tag: "488177c8-2ea7-4176-a6cb-fab8cfccdea2"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185300Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE;SCHEDULE-STATUS=
|
|||
|
1.2:mailto:wilfredo@e
|
|||
|
xample.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 62]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE;SCHEDULE-STATUS=
|
|||
|
1.0:mailto:bernard@example.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE;SCHEDULE-STATUS=3.7:mailto:mike@example.org
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
B.2. Example: "Attendee" Receiving an Invitation
|
|||
|
|
|||
|
In the following example, Wilfredo's client retrieves and deletes the
|
|||
|
new scheduling message that appeared in his scheduling Inbox
|
|||
|
collection after the server automatically processed it and created a
|
|||
|
new scheduling object resource in his default calendar collection.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/wilfredo/calendars/inbox/27d93fc0a58c.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 18:59:58 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:59:58 GMT
|
|||
|
ETag: "da116714bc9926c89395895eb897deab"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
METHOD:REQUEST
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185254Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:wilfredo@
|
|||
|
example.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 63]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@ex
|
|||
|
ample.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE:mailto:mike@example.org
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
DELETE /home/wilfredo/calendars/inbox/27d93fc0a58c.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 204 No Content
|
|||
|
Date: Tue, 02 Jun 2009 20:40:36 GMT
|
|||
|
|
|||
|
B.3. Example: "Attendee" Replying to an Invitation
|
|||
|
|
|||
|
In the following example, Wilfredo accepts Cyrus's invitation and
|
|||
|
sets an alarm reminder on the event. It uses the If-Schedule-Tag-
|
|||
|
Match precondition behavior to ensure it does not overwrite any
|
|||
|
significant changes from the "Organizer" that might have occurred
|
|||
|
after it retrieved the initial resource data.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PUT /home/wilfredo/calendars/work/BB64861C2228.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
If-Schedule-Tag-Match: "e78f23ed-0188-4bab-938d-2aeb3324c7e8"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185254Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 64]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=ACCEPTED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:wilfredo@exam
|
|||
|
ple.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@ex
|
|||
|
ample.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE:mailto:mike@example.org
|
|||
|
BEGIN:VALARM
|
|||
|
TRIGGER:-PT15M
|
|||
|
ACTION:DISPLAY
|
|||
|
DESCRIPTION:Reminder
|
|||
|
END:VALARM
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Content-Length: 0
|
|||
|
Date: Tue, 02 Jun 2009 18:57:54 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:57:54 GMT
|
|||
|
ETag: "eb4639451b434fbd85561cfe74a4e785"
|
|||
|
Schedule-Tag: "8893ee45-eb9d-428f-b53c-c777daf19e41"
|
|||
|
|
|||
|
Once the event modification has been completed, Wilfredo's client
|
|||
|
will retrieve the event back from the server to get the schedule
|
|||
|
status of the "Organizer".
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/wilfredo/calendars/work/BB64861C2228.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 19:03:03 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 19:02:21 GMT
|
|||
|
ETag: "5eb897deabda116714bc9926c8939589"
|
|||
|
Schedule-Tag: "8893ee45-eb9d-428f-b53c-c777daf19e41"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 65]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T190221Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo";SCHEDULE-STATUS=1.2:mailto:cyrus@ex
|
|||
|
ample.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=ACCEPTED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:wilfredo@exam
|
|||
|
ple.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@ex
|
|||
|
ample.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE:mailto:mike@example.org
|
|||
|
BEGIN:VALARM
|
|||
|
TRIGGER:-PT15M
|
|||
|
ACTION:DISPLAY
|
|||
|
DESCRIPTION:Reminder
|
|||
|
END:VALARM
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
B.4. Example: "Organizer" Receiving a Reply to an Invitation
|
|||
|
|
|||
|
On reception of Wilfredo's reply, Cyrus's server will automatically
|
|||
|
update Cyrus's scheduling object resource, make Wilfredo's scheduling
|
|||
|
message available in Cyrus's scheduling Inbox collection, and deliver
|
|||
|
an updated scheduling message to Bernard to share Wilfredo's updated
|
|||
|
participation status. In this example, Cyrus's client retrieves and
|
|||
|
deletes this scheduling message in his scheduling Inbox collection.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/cyrus/calendars/inbox/c0a58c27d93f.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 66]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 19:05:02 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 19:04:20 GMT
|
|||
|
ETag: "9265eb897deabc8939589da116714bc9"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
METHOD:REPLY
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185754Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";PARTSTAT=ACCEPTED:mailto:w
|
|||
|
ilfredo@example.com
|
|||
|
REQUEST-STATUS:2.0;Success
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
DELETE /home/cyrus/calendars/inbox/c0a58c27d93f.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 204 No Content
|
|||
|
Date: Tue, 02 Jun 2009 19:05:05 GMT
|
|||
|
|
|||
|
Cyrus's client then retrieves the event back from the server with
|
|||
|
Wilfredo's updated participation status.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/cyrus/calendars/work/9263504FD3AD.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 67]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 19:05:02 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 19:04:20 GMT
|
|||
|
ETag: "eb897deabc8939589da116714bc99265"
|
|||
|
Schedule-Tag: "132cab27-1fe3-67ab-de13-abd348d1dee3"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T190420Z
|
|||
|
DTSTART:20090602T160000Z
|
|||
|
DTEND:20090602T170000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Lunch
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT
|
|||
|
=ACCEPTED;ROLE=REQ-PARTICIPANT;RSVP=TRUE;SCHEDULE-STATUS=2.0:
|
|||
|
mailto:wilfredo@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
NEEDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE;SCHEDULE-STATUS=1
|
|||
|
.0:mailto:bernard@example.net
|
|||
|
ATTENDEE;CN="Mike Douglass";CUTYPE=INDIVIDUAL;PARTSTAT=NEEDS-A
|
|||
|
CTION;RSVP=TRUE;SCHEDULE-STATUS=3.7:mailto:mike@example.org
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 68]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
B.5. Example: "Organizer" Requesting Busy Time Information
|
|||
|
|
|||
|
In this example, Cyrus requests the busy time information of
|
|||
|
Wilfredo, Bernard, and Mike.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
POST /home/cyrus/calendars/outbox/ HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
METHOD:REQUEST
|
|||
|
BEGIN:VFREEBUSY
|
|||
|
UID:4FD3AD926350
|
|||
|
DTSTAMP:20090602T190420Z
|
|||
|
DTSTART:20090602T000000Z
|
|||
|
DTEND:20090604T000000Z
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega":mailto:wilfredo@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux":mailto:bernard@example.net
|
|||
|
ATTENDEE;CN="Mike Douglass":mailto:mike@example.org
|
|||
|
END:VFREEBUSY
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 20:07:34 GMT
|
|||
|
Content-Type: application/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<C:schedule-response xmlns:D="DAV:"
|
|||
|
xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<C:response>
|
|||
|
<C:recipient>
|
|||
|
<D:href>mailto:wilfredo@example.com</D:href>
|
|||
|
</C:recipient>
|
|||
|
<C:request-status>2.0;Success</C:request-status>
|
|||
|
<C:calendar-data>BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
METHOD:REPLY
|
|||
|
BEGIN:VFREEBUSY
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 69]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
UID:4FD3AD926350
|
|||
|
DTSTAMP:20090602T200733Z
|
|||
|
DTSTART:20090602T000000Z
|
|||
|
DTEND:20090604T000000Z
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega":mailto:wilfredo@example.com
|
|||
|
FREEBUSY;FBTYPE=BUSY:20090602T110000Z/20090602T120000Z
|
|||
|
FREEBUSY;FBTYPE=BUSY:20090603T170000Z/20090603T180000Z
|
|||
|
END:VFREEBUSY
|
|||
|
END:VCALENDAR
|
|||
|
</C:calendar-data>
|
|||
|
</C:response>
|
|||
|
<C:response>
|
|||
|
<C:recipient>
|
|||
|
<D:href>mailto:bernard@example.net</D:href>
|
|||
|
</C:recipient>
|
|||
|
<C:request-status>2.0;Success</C:request-status>
|
|||
|
<C:calendar-data>BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Server//EN
|
|||
|
METHOD:REPLY
|
|||
|
BEGIN:VFREEBUSY
|
|||
|
UID:4FD3AD926350
|
|||
|
DTSTAMP:20090602T200733Z
|
|||
|
DTSTART:20090602T000000Z
|
|||
|
DTEND:20090604T000000Z
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux":mailto:bernard@example.net
|
|||
|
FREEBUSY;FBTYPE=BUSY:20090602T150000Z/20090602T160000Z
|
|||
|
FREEBUSY;FBTYPE=BUSY:20090603T090000Z/20090603T100000Z
|
|||
|
FREEBUSY;FBTYPE=BUSY:20090603T180000Z/20090603T190000Z
|
|||
|
END:VFREEBUSY
|
|||
|
END:VCALENDAR
|
|||
|
</C:calendar-data>
|
|||
|
</C:response>
|
|||
|
<C:response>
|
|||
|
<C:recipient>
|
|||
|
<D:href>mailto:mike@example.org</D:href>
|
|||
|
</C:recipient>
|
|||
|
<C:request-status>3.7;Invalid calendar user</C:request-status>
|
|||
|
</C:response>
|
|||
|
</C:schedule-response>
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 70]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
B.6. Example: User Attempting to Invite "Attendee" on Behalf of
|
|||
|
"Organizer"
|
|||
|
|
|||
|
In the following example, Cyrus attempts to create, on behalf of
|
|||
|
Wilfredo, an event with Bernard specified as an "Attendee". The
|
|||
|
request fails, since Wilfredo didn't grant Cyrus the right to invite
|
|||
|
other calendar users on his behalf.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PUT /home/wilfredo/calendars/work/def456.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
If-None-Match: *
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:3504F926D3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T190221Z
|
|||
|
DTSTART:20090602T230000Z
|
|||
|
DTEND:20090603T000000Z
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Dinner
|
|||
|
ORGANIZER;CN="Wilfredo Sanchez Vega":mailto:wilfredo@example.com
|
|||
|
ATTENDEE;CN="Wilfredo Sanchez Vega";CUTYPE=INDIVIDUAL;PARTSTAT=A
|
|||
|
CCEPTED:mailto:wilfredo@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=NE
|
|||
|
EDS-ACTION;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@exampl
|
|||
|
e.net
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 71]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 403 Forbidden
|
|||
|
Content-Type: application/xml; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
<?xml version="1.0" encoding="utf-8" ?>
|
|||
|
<D:error xmlns:D="DAV:" xmlns:C="urn:ietf:params:xml:ns:caldav">
|
|||
|
<D:need-privileges>
|
|||
|
<D:resource>
|
|||
|
<D:href>/home/wilfredo/calendars/outbox/</D:href>
|
|||
|
<D:privilege><C:schedule-send-invite/></D:privilege>
|
|||
|
</D:resource>
|
|||
|
</D:need-privileges>
|
|||
|
</D:error>
|
|||
|
|
|||
|
B.7. Example: "Attendee" Declining an Instance of a Recurring Event
|
|||
|
|
|||
|
In the following example, Bernard declines the second recurrence
|
|||
|
instance of a daily recurring event he's been invited to by Cyrus.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PUT /home/bernard/calendars/work/4FD3AD926350.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
If-Schedule-Tag-Match: "7775FB30-7534-489E-A79A-0EA147B933EB"
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VTIMEZONE
|
|||
|
TZID:America/Montreal
|
|||
|
BEGIN:STANDARD
|
|||
|
DTSTART:20071104T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
|
|||
|
TZNAME:EST
|
|||
|
TZOFFSETFROM:-0400
|
|||
|
TZOFFSETTO:-0500
|
|||
|
END:STANDARD
|
|||
|
BEGIN:DAYLIGHT
|
|||
|
DTSTART:20070311T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
|
|||
|
TZNAME:EDT
|
|||
|
TZOFFSETFROM:-0500
|
|||
|
TZOFFSETTO:-0400
|
|||
|
END:DAYLIGHT
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 72]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
END:VTIMEZONE
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185254Z
|
|||
|
DTSTART;TZID=America/Montreal:20090601T150000
|
|||
|
DTEND;TZID=America/Montreal:20090601T160000
|
|||
|
RRULE:FREQ=DAILY;INTERVAL=1;COUNT=5
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
ACCEPTED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@exampl
|
|||
|
e.net
|
|||
|
END:VEVENT
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090603T183823Z
|
|||
|
RECURRENCE-ID;TZID=America/Montreal:20090602T150000
|
|||
|
DTSTART;TZID=America/Montreal:20090602T150000
|
|||
|
DTEND;TZID=America/Montreal:20090602T160000
|
|||
|
TRANSP:TRANSPARENT
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
DECLINED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@exampl
|
|||
|
e.net
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Content-Length: 0
|
|||
|
Date: Tue, 02 Jun 2009 18:52:54 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:52:54 GMT
|
|||
|
ETag: "d85561cfe74a4e785eb4639451b434fb"
|
|||
|
Schedule-Tag: "488177c8-2ea7-4176-a6cb-fab8cfccdea2"
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 73]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Bernard's participation status update will cause his server to
|
|||
|
deliver a scheduling message to Cyrus. Cyrus's client will find the
|
|||
|
following reply message from Bernard in Cyrus's scheduling Inbox
|
|||
|
collection:
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/cyrus/calendars/inbox/9263504FD3AD.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
ETag: "eb897deabc8939589da116714bc99265"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
METHOD:REPLY
|
|||
|
BEGIN:VTIMEZONE
|
|||
|
TZID:America/Montreal
|
|||
|
BEGIN:STANDARD
|
|||
|
DTSTART:20071104T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
|
|||
|
TZNAME:EST
|
|||
|
TZOFFSETFROM:-0400
|
|||
|
TZOFFSETTO:-0500
|
|||
|
END:STANDARD
|
|||
|
BEGIN:DAYLIGHT
|
|||
|
DTSTART:20070311T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
|
|||
|
TZNAME:EDT
|
|||
|
TZOFFSETFROM:-0500
|
|||
|
TZOFFSETTO:-0400
|
|||
|
END:DAYLIGHT
|
|||
|
END:VTIMEZONE
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090603T183823Z
|
|||
|
RECURRENCE-ID;TZID=America/Montreal:20090602T150000
|
|||
|
DTSTART;TZID=America/Montreal:20090602T150000
|
|||
|
DTEND;TZID=America/Montreal:20090602T160000
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 74]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";PARTSTAT=DECLINED:
|
|||
|
mailto:bernard@example.net
|
|||
|
REQUEST-STATUS:2.0;Success
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
B.8. Example: "Attendee" Removing an Instance of a Recurring Event
|
|||
|
|
|||
|
In the following example, Bernard removes from his calendar the third
|
|||
|
recurrence instance of a daily recurring event he's been invited to
|
|||
|
by Cyrus. This is accomplished by the addition of an "EXDATE"
|
|||
|
property to the scheduling object resource stored by Bernard.
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
PUT /home/bernard/calendars/work/4FD3AD926350.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
If-Schedule-Tag-Match: "488177c8-2ea7-4176-a6cb-fab8cfccdea2"
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
BEGIN:VTIMEZONE
|
|||
|
TZID:America/Montreal
|
|||
|
BEGIN:STANDARD
|
|||
|
DTSTART:20071104T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
|
|||
|
TZNAME:EST
|
|||
|
TZOFFSETFROM:-0400
|
|||
|
TZOFFSETTO:-0500
|
|||
|
END:STANDARD
|
|||
|
BEGIN:DAYLIGHT
|
|||
|
DTSTART:20070311T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
|
|||
|
TZNAME:EDT
|
|||
|
TZOFFSETFROM:-0500
|
|||
|
TZOFFSETTO:-0400
|
|||
|
END:DAYLIGHT
|
|||
|
END:VTIMEZONE
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090602T185254Z
|
|||
|
DTSTART;TZID=America/Montreal:20090601T150000
|
|||
|
DTEND;TZID=America/Montreal:20090601T160000
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 75]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
RRULE:FREQ=DAILY;INTERVAL=1;COUNT=5
|
|||
|
EXDATE;TZID=America/Montreal:20090603T150000
|
|||
|
TRANSP:OPAQUE
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
ACCEPTED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@exampl
|
|||
|
e.net
|
|||
|
END:VEVENT
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090603T183823Z
|
|||
|
RECURRENCE-ID;TZID=America/Montreal:20090602T150000
|
|||
|
DTSTART;TZID=America/Montreal:20090602T150000
|
|||
|
DTEND;TZID=America/Montreal:20090602T160000
|
|||
|
TRANSP:TRANSPARENT
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Cyrus Daboo";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED:
|
|||
|
mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";CUTYPE=INDIVIDUAL;PARTSTAT=
|
|||
|
DECLINED;ROLE=REQ-PARTICIPANT;RSVP=TRUE:mailto:bernard@exampl
|
|||
|
e.net
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
Bernard's deletion of a recurrence instance will cause his server to
|
|||
|
deliver a scheduling message to Cyrus. Cyrus's client will find the
|
|||
|
following reply message from Bernard in Cyrus's scheduling Inbox
|
|||
|
collection:
|
|||
|
|
|||
|
>> Request <<
|
|||
|
|
|||
|
GET /home/cyrus/calendars/inbox/6504923FD3AD.ics HTTP/1.1
|
|||
|
Host: cal.example.com
|
|||
|
|
|||
|
>> Response <<
|
|||
|
|
|||
|
HTTP/1.1 200 OK
|
|||
|
Date: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
Last-Modified: Tue, 02 Jun 2009 18:52:58 GMT
|
|||
|
ETag: "eb897deabc8939589da116714bc99265"
|
|||
|
Content-Type: text/calendar; charset="utf-8"
|
|||
|
Content-Length: xxxx
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 76]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
BEGIN:VCALENDAR
|
|||
|
VERSION:2.0
|
|||
|
PRODID:-//Example Corp.//CalDAV Client//EN
|
|||
|
METHOD:REPLY
|
|||
|
BEGIN:VTIMEZONE
|
|||
|
TZID:America/Montreal
|
|||
|
BEGIN:STANDARD
|
|||
|
DTSTART:20071104T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=11;BYDAY=1SU
|
|||
|
TZNAME:EST
|
|||
|
TZOFFSETFROM:-0400
|
|||
|
TZOFFSETTO:-0500
|
|||
|
END:STANDARD
|
|||
|
BEGIN:DAYLIGHT
|
|||
|
DTSTART:20070311T020000
|
|||
|
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=2SU
|
|||
|
TZNAME:EDT
|
|||
|
TZOFFSETFROM:-0500
|
|||
|
TZOFFSETTO:-0400
|
|||
|
END:DAYLIGHT
|
|||
|
END:VTIMEZONE
|
|||
|
BEGIN:VEVENT
|
|||
|
UID:9263504FD3AD
|
|||
|
SEQUENCE:0
|
|||
|
DTSTAMP:20090603T183823Z
|
|||
|
RECURRENCE-ID;TZID=America/Montreal:20090603T150000
|
|||
|
DTSTART;TZID=America/Montreal:20090603T150000
|
|||
|
DTEND;TZID=America/Montreal:20090603T160000
|
|||
|
SUMMARY:Review Internet-Draft
|
|||
|
ORGANIZER;CN="Cyrus Daboo":mailto:cyrus@example.com
|
|||
|
ATTENDEE;CN="Bernard Desruisseaux";PARTSTAT=DECLINED:
|
|||
|
mailto:bernard@example.net
|
|||
|
REQUEST-STATUS:2.0;Success
|
|||
|
END:VEVENT
|
|||
|
END:VCALENDAR
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 77]
|
|||
|
|
|||
|
RFC 6638 CalDAV Scheduling June 2012
|
|||
|
|
|||
|
|
|||
|
Authors' Addresses
|
|||
|
|
|||
|
Cyrus Daboo
|
|||
|
Apple Inc.
|
|||
|
1 Infinite Loop
|
|||
|
Cupertino, CA 95014
|
|||
|
USA
|
|||
|
|
|||
|
EMail: cyrus@daboo.name
|
|||
|
URI: http://www.apple.com/
|
|||
|
|
|||
|
|
|||
|
Bernard Desruisseaux
|
|||
|
Oracle Corporation
|
|||
|
600 Blvd. de Maisonneuve West
|
|||
|
Suite 1900
|
|||
|
Montreal, QC H3A 3J2
|
|||
|
CANADA
|
|||
|
|
|||
|
EMail: bernard.desruisseaux@oracle.com
|
|||
|
URI: http://www.oracle.com/
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Daboo & Desruisseaux Standards Track [Page 78]
|
|||
|
|