diff options
Diffstat (limited to 'doc/rfc/rfc5874.txt')
| -rw-r--r-- | doc/rfc/rfc5874.txt | 1347 | 
1 files changed, 1347 insertions, 0 deletions
| diff --git a/doc/rfc/rfc5874.txt b/doc/rfc/rfc5874.txt new file mode 100644 index 0000000..a5e46f7 --- /dev/null +++ b/doc/rfc/rfc5874.txt @@ -0,0 +1,1347 @@ + + + + + + +Internet Engineering Task Force (IETF)                      J. Rosenberg +Request for Comments: 5874                                   jdrosen.net +Category: Standards Track                                  J. Urpalainen +ISSN: 2070-1721                                                    Nokia +                                                                May 2010 + + +        An Extensible Markup Language (XML) Document Format for +                         Indicating a Change in +           XML Configuration Access Protocol (XCAP) Resources + +Abstract + +   This specification defines a document format that can be used to +   indicate that a change has occurred in a document managed by the +   Extensible Markup Language (XML) Configuration Access Protocol +   (XCAP).  This format reports which document has changed and its +   former and new entity tags.  It can report the differences between +   versions of the document, using an XML patch format.  It can report +   existing element and attribute content when versions of an XCAP +   server document change.  XCAP diff documents can be delivered to diff +   clients using a number of means, including a Session Initiation +   Protocol (SIP) event package. + +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/rfc5874. + +Copyright Notice + +   Copyright (c) 2010 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 + + + +Rosenberg & Urpalainen       Standards Track                    [Page 1] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   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. + +   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 . . . . . . . . . . . . . . . . . . . . . . . . .  3 +   2.  Terminology  . . . . . . . . . . . . . . . . . . . . . . . . .  4 +   3.  Structure of an XCAP Diff Document . . . . . . . . . . . . . .  5 +   4.  XML Schema . . . . . . . . . . . . . . . . . . . . . . . . . .  8 +   5.  Example Document . . . . . . . . . . . . . . . . . . . . . . . 11 +   6.  Basic Requirements for a System Exchanging XCAP Diff +       Documents  . . . . . . . . . . . . . . . . . . . . . . . . . . 11 +   7.  Security Considerations  . . . . . . . . . . . . . . . . . . . 13 +   8.  IANA Considerations  . . . . . . . . . . . . . . . . . . . . . 14 +     8.1.  application/xcap-diff+xml MIME Type  . . . . . . . . . . . 14 +     8.2.  URN Sub-Namespace Registration for +           urn:ietf:params:xml:ns:xcap-diff . . . . . . . . . . . . . 15 +     8.3.  Schema Registration  . . . . . . . . . . . . . . . . . . . 15 +   9.  Acknowledgments  . . . . . . . . . . . . . . . . . . . . . . . 16 +   10. References . . . . . . . . . . . . . . . . . . . . . . . . . . 16 +     10.1. Normative References . . . . . . . . . . . . . . . . . . . 16 +     10.2. Informative References . . . . . . . . . . . . . . . . . . 17 +   Appendix A.  Informative Examples  . . . . . . . . . . . . . . . . 18 +     A.1.  Indicating Existing, Changed, or Removed Documents . . . . 18 +     A.2.  Indicating Actual Changes of Documents . . . . . . . . . . 21 +     A.3.  Indicating XCAP Component Contents . . . . . . . . . . . . 23 + + + + + + + + + + + +Rosenberg & Urpalainen       Standards Track                    [Page 2] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +1.  Introduction + +   The Extensible Markup Language (XML) Configuration Access Protocol +   (XCAP) [RFC4825] is a protocol that allows XCAP clients to manipulate +   XML documents stored on a server.  These XML documents serve as +   configuration information for application protocols.  As an example, +   resource list [RFC4662] subscriptions (also known as presence lists) +   allow a SIP client to have a single SIP subscription to a list of +   users, where the list is maintained on a server.  The server will +   obtain presence for those users and report it back to the SIP client. +   This application requires the server, called a Resource List Server +   (RLS), to have access to the list of presentities [RFC2778].  This +   list needs to be manipulated by XCAP clients so they can add and +   remove their friends as they desire. + +   Complexities arise when multiple XCAP clients attempt to +   simultaneously manipulate a document, such as a presence list. +   Frequently, an XCAP client will keep a copy of the current list in +   memory, so it can render it to users.  However, if another XCAP +   client modifies the document, the cached version becomes stale.  This +   modification event must be made known to all clients that have cached +   copies of the document, so that they can fetch the most recent one. + +   To deal with this problem, clients can use a Session Initiation +   Protocol (SIP) [RFC3261] event package [RFC3265] to subscribe to +   change events [RFC5875] in XCAP documents.  This notification needs +   to indicate the specific resource that changed and how it changed. +   One solution for the format of such a change notification would be a +   content indirection object [RFC4483].  Though content indirection can +   tell a client that a document has changed, it provides it with a MIME +   Content-ID indicating the new version of the document.  The MIME +   Content-ID is not the same as the entity tag, which is used by XCAP +   for document versioning.  As such, a client cannot easily ascertain +   whether an indication of a change in a document is due to a change it +   just made or due to a change another XCAP client made at around the +   same time.  Furthermore, content indirections don't indicate how a +   document changed; they are only able to indicate that it did change. + +   To resolve these problems, this document defines a data format that +   can convey the fact that an XML document managed by XCAP has changed. +   This data format is an XML document format, called an XCAP diff +   document.  This format reports which document has changed and its +   former and new entity tags.  It can report the differences between +   versions of the document, using an XML patch format [RFC5261], which +   indicate how to transform the locally cached XCAP document from the +   version prior to the change to the version after it.  Its intent is +   to reduce the required overall bandwidth and the number of separate + + + + +Rosenberg & Urpalainen       Standards Track                    [Page 3] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   transmissions.  It can also report existing element and attribute +   content when versions of an XML document change at an XCAP server. + +   XML documents that are equivalent for the purposes of many +   applications may differ in their physical representation.  Similar to +   XCAP, the canonical form with comments [W3C.REC-xml-c14n-20010315] of +   an XML document determines the logical equivalence when this format +   is used to patch locally cached XCAP documents. + +2.  Terminology + +   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 RFC 2119 [RFC2119] and +   indicate requirement levels for compliant implementations. + +   This specification also defines the following additional terms: + +   Document:  When the term document is used without the "(XCAP) diff" +      in front of it, it refers to the XCAP document resource about +      which the XCAP diff document is reporting a change. + +   Diff document:  The XML document defined by this specification that +      reports on a set of changes in an XCAP document resource.  It is +      delivered from a server to a diff client by a transport that is +      not defined by this specification. + +   XCAP server:  A protocol entity that manages XCAP documents and their +      entity tags.  It usually contains an integrated diff notifier. + +   Diff notifier:  This is the entity of a server that generates XCAP +      diff documents based on its knowledge of a set of XCAP documents +      and their changes, and it transmits the generated diff documents +      to a diff client within a session. + +   Diff client:  A client that consumes XCAP diff documents in order to +      construct a locally cached document that is equivalent to a +      specific version of a document resource stored at an XCAP server. +      It is typically a SIP User Agent (UA) and an XCAP client. + +   XCAP Client:  A client that updates and retrieves documents stored at +      an XCAP server.  It can also patch element and attribute content +      of XCAP documents located at an XCAP server. + +   Locally cached resource:  A resource that has typically been +      downloaded by HTTP from an XCAP server to a diff client.  It may +      have been patched locally by a diff client based on the XCAP diff +      document information.  It is equivalent to a single version in its + + + +Rosenberg & Urpalainen       Standards Track                    [Page 4] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +      change history at an XCAP server.  Version history of XCAP +      documents is indicated by HTTP entity tags (ETags). + +   ETag:  A strong HTTP entity tag whose value is set by an XCAP server. +      Documents at an XCAP server are updated by XCAP clients.  The XCAP +      server assigns a new ETag value to each document version according +      to the HTTP specification. + +3.  Structure of an XCAP Diff Document + +   An XCAP diff document is an XML [W3C.REC-xml-20060816] document that +   MUST be well-formed and SHOULD be valid.  XCAP diff documents MUST be +   based on XML 1.0 and MUST be encoded using UTF-8.  This specification +   makes use of XML namespaces for identifying XCAP diff documents and +   document fragments.  The namespace URI for elements defined by this +   specification is a URN [RFC2141], using the namespace identifier +   'ietf' defined by [RFC2648] and extended by [RFC3688].  This URN is: + +      urn:ietf:params:xml:ns:xcap-diff + +   An XCAP diff document begins with the root element tag <xcap-diff>. +   This element has a single mandatory attribute, "xcap-root".  The +   value of this attribute is the XCAP root URI for the documents in +   which the changes have taken place.  A single XCAP diff document can +   only represent changes in documents within the same XCAP root.  The +   content of the <xcap-diff> element is a sequence of <document>, +   <element>, and <attribute> elements followed by any number of +   elements from other namespaces for the purposes of extensibility. +   Wherever the XML schema (see Section 4) allows extension elements or +   attributes, any such unknown content MUST be ignored by the diff +   client. + +   Each <document> element specifies changes in a specific document +   within the XCAP root.  If several <document> elements pinpoint the +   same specific document, i.e., for example, the full entity tag (ETag) +   change history is indicated, the corresponding patches MUST be able +   to be applied in the given XCAP diff document order. + +      Note: This requirement simplifies applications that process XCAP +      diff documents since there's no need to sort patch instructions +      when applying them. + +   The <document> element has one mandatory attribute, "sel", and two +   optional attributes, "new-etag" and "previous-etag".  The "sel" +   attribute of the <document> element identifies the specific document +   within the XCAP root for which changes are indicated.  Its content +   MUST be a relative path reference, with the base URI being equal to +   the XCAP root URI.  The "new-etag" attribute provides the entity tag + + + +Rosenberg & Urpalainen       Standards Track                    [Page 5] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   (ETag) for the document after the application of the changes, +   assuming the document exists after those changes.  The "previous- +   etag" attribute provides an identifier for the document instance +   prior to the change.  If the change being reported is the removal of +   a document, only the "previous-etag" MUST be included and the "new- +   etag" attribute MUST NOT be present.  The "new-etag" attribute MUST +   only exist alone when the document either exists or it was just +   created (no patch included).  Both attributes are present when a +   patch (or series of XCAP operations) has been applied to the +   resource.  Also, both attributes MAY be used to indicate an ETag +   change without any document modifications (patches). + +   The "previous-etag" and "new-etag" need not have been sequentially +   assigned ETags at the server.  An XCAP diff document can indicate +   changes that have occurred over a series of XCAP operations.  The +   only requirement then is that the sequence of events, when executed +   serially, will result in the transformation of the document with the +   ETag "previous-etag" to the one whose ETag is "new-etag".  Also, the +   series of operations do not have to be the same exact series of +   operations that occurred at the server. + +   Each <document> element contains either a sequence of patching +   instructions or an indication that the body hasn't semantically +   changed.  The latter means that the document has been assigned a new +   ETag but its content is unchanged and it is indicated by the <body- +   not-changed> element.  Patching instructions are described by the +   <add>, <replace>, and <remove> elements.  These elements use the +   corresponding add, replace, and remove types defined in [RFC5261], +   and define a set of patch operations that can be applied to transform +   the locally cached document.  See [RFC5261] for instructions on how +   this transformation is effected.  The <document> element can also +   contain elements from other namespaces for the purposes of +   extensibility.  The <add>, <replace>, and <remove> elements allow +   extension attributes from any namespace. + +   Figure 1 shows <document> element content and how the corresponding +   resource or metadata changes.  In practice, an external document +   retrieval means HTTP GET requests for target resources.  The asterisk +   character '*' means that a <document> element has child element(s): +   <add>, <replace>, or <remove>, or alternatively only a <body-not- +   changed> element.  The hyphen character '-' means that the +   corresponding content (attribute or element) doesn't exist in a +   <document> element.  The 'xxx' and 'yyy' are values of entity tags +   (ETag) of an XCAP document. + + + + + + + +Rosenberg & Urpalainen       Standards Track                    [Page 6] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   +-----------+----------+-----------+----------+-------------------+ +   | previous- | new-     | <add>     | <body-   | locally cached    | +   | etag      | etag     | <replace> | not-     | XCAP resource/    | +   |           |          | <remove>  | changed> | metadata change   | +   +-----------+----------+-----------+----------+-------------------+ +   | xxx       | yyy      | *         | -        | resource patched, | +   |           |          |           |          | patch included    | +   +-----------+----------+-----------+----------+-------------------+ +   | xxx       | yyy      | -         | -        | resource patched, | +   |           |          |           |          | external document | +   |           |          |           |          | retrieval         | +   +-----------+----------+-----------+----------+-------------------+ +   | xxx       | yyy      | -         | *        | only ETag changed | +   +-----------+----------+-----------+----------+-------------------+ +   | -         | yyy      | -         | -        | resource created  | +   |           |          |           |          | or exists,        | +   |           |          |           |          | external document | +   |           |          |           |          | retrieval         | +   +-----------+----------+-----------+----------+-------------------+ +   | xxx       | -        | -         | -        | resource removed  | +   +-----------+----------+-----------+----------+-------------------+ + +   Figure 1: <document> element content / corresponding resource changes + +   Each <element> element indicates the existing element content of an +   XCAP document.  It has one mandatory attribute, "sel", and +   optionally, an "exists" attribute and extension attributes from any +   namespace.  The "sel" attribute of the <element> element identifies +   an XML element of an XCAP document.  It is a percent-encoded relative +   URI following XCAP conventions when selecting elements.  The XCAP +   Node Selector MUST always locate a unique node, the "exists" +   attribute thus shows whether an element exists or not in the XCAP +   document.  When the "exists" attribute is absent from the <element> +   element, the indicated element still exists in the XCAP document. +   The located element exists as a child element of the <element> +   element.  In a corner case where the content of this element cannot +   be presented for some reason (e.g., the payload is too large) +   although it exists in the XCAP document, the <element> element MUST +   NOT have any child nodes. + +   As the located XML element is typically namespace qualified, all +   needed namespace declarations MUST exist within the <xml-diff> +   document.  The possible local namespace declarations within the +   located element exist unmodified as in the source document, similar +   to XCAP conventions.  Other namespace references MUST be resolved +   from the context of the <element> or its parent elements.  The + + + + + +Rosenberg & Urpalainen       Standards Track                    [Page 7] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   prefixes of qualified names (QNames) [W3C.REC-xml-names-20060816] of +   XML nodes also remain as they originally exist in the source XCAP +   document. + +   Each <attribute> element indicates the existing attribute content of +   an XCAP document.  It has one mandatory attribute, "sel", and +   optionally, an "exists" attribute and extension attributes from any +   namespace.  The "sel" attribute of the <attribute> element identifies +   an XML attribute of an XCAP document.  It is a percent-encoded +   relative URI following XCAP conventions when selecting attributes. +   The "exists" attribute indicates whether or not an attribute exists +   in the XCAP document.  When the "exists" attribute is absent from the +   <attribute> element, the indicated attribute still exists in the XCAP +   document.  The child text node of the <attribute> element indicates +   the value of the located attribute.  Note that if the attribute is +   namespace qualified, the query parameter of the XCAP URI indicates +   the attached namespace URI and the prefix in the XCAP source +   document. + +   Namespaces of the "sel" attribute of the <attribute> and <element> +   elements MUST also be resolved properly.  Section 6.4. of [RFC4825] +   describes the rules when using namespace prefixes in XCAP Node +   Selectors.  Without a namespace prefix in an element selector, an +   XCAP Default Document Namespace MUST be applied.  The namespace +   resolving rules of Patch operation elements: <add>, <replace>, and +   <remove> are described in Section 4.2.1 of [RFC5261]. + +4.  XML Schema + +   The XML Schema for the XCAP diff format. + +     <?xml version="1.0" encoding="UTF-8"?> +     <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" +      xmlns="urn:ietf:params:xml:ns:xcap-diff" +      targetNamespace="urn:ietf:params:xml:ns:xcap-diff" +      elementFormDefault="qualified" +      attributeFormDefault="unqualified"> + +      <!-- include patch-ops --> +      <xs:include +       schemaLocation="urn:ietf:params:xml:schema:patch-ops"/> + +      <!-- document root --> +      <xs:element name="xcap-diff"> +       <xs:complexType> +        <xs:sequence minOccurs="0"> +         <xs:sequence minOccurs="0" maxOccurs="unbounded"> +          <xs:choice> + + + +Rosenberg & Urpalainen       Standards Track                    [Page 8] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +           <xs:element name="document" type="documentType"/> +           <xs:element name="element" type="elementType"/> +           <xs:element name="attribute" type="attributeType"/> +          </xs:choice> +         </xs:sequence> +         <xs:any namespace="##other" processContents="lax" +                 minOccurs="0" maxOccurs="unbounded"/> +        </xs:sequence> +        <xs:attribute name="xcap-root" type="xs:anyURI" use="required"/> +        <xs:anyAttribute processContents="lax"/> +       </xs:complexType> +      </xs:element> + +      <!-- xcap document type --> +      <xs:complexType name="documentType"> +       <xs:choice minOccurs="0"> +        <xs:element name="body-not-changed" type="emptyType"/> +        <xs:sequence minOccurs="0" maxOccurs="unbounded"> +         <xs:choice> +          <xs:element name="add"> +           <xs:complexType mixed="true"> +            <xs:complexContent> +             <xs:extension base="add"> +              <xs:anyAttribute processContents="lax"/> +             </xs:extension> +            </xs:complexContent> +           </xs:complexType> +          </xs:element> +          <xs:element name="remove"> +           <xs:complexType> +            <xs:complexContent> +             <xs:extension base="remove"> +              <xs:anyAttribute processContents="lax"/> +             </xs:extension> +            </xs:complexContent> +           </xs:complexType> +          </xs:element> +          <xs:element name="replace"> +           <xs:complexType mixed="true"> +            <xs:complexContent> +             <xs:extension base="replace"> +              <xs:anyAttribute processContents="lax"/> +             </xs:extension> +            </xs:complexContent> +           </xs:complexType> +          </xs:element> +          <xs:any namespace="##other" processContents="lax"/> +         </xs:choice> + + + +Rosenberg & Urpalainen       Standards Track                    [Page 9] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +        </xs:sequence> +       </xs:choice> +       <xs:attribute name="sel" type="xs:anyURI" use="required"/> +       <xs:attribute name="new-etag" type="xs:string"/> +       <xs:attribute name="previous-etag" type="xs:string"/> +       <xs:anyAttribute processContents="lax"/> +      </xs:complexType> + +      <!-- xcap element type --> +      <xs:complexType name="elementType"> +       <xs:complexContent mixed="true"> +        <xs:restriction base="xs:anyType"> +         <xs:sequence> +          <xs:any processContents="lax" namespace="##any" +                  minOccurs="0" maxOccurs="1"/> +         </xs:sequence> +         <xs:attribute name="sel" type="xs:string" +                       use="required"/> +         <xs:attribute name="exists" type="xs:boolean"/> +         <xs:anyAttribute processContents="lax"/> +        </xs:restriction> +       </xs:complexContent> +      </xs:complexType> + +      <!-- xcap attribute type --> +      <xs:complexType name="attributeType"> +       <xs:simpleContent> +        <xs:extension base="xs:string"> +         <xs:attribute name="sel" type="xs:string" +                       use="required"/> +         <xs:attribute name="exists" type="xs:boolean"/> +         <xs:anyAttribute processContents="lax"/> +        </xs:extension> +       </xs:simpleContent> +      </xs:complexType> + +      <!-- empty type --> +      <xs:complexType name="emptyType"/> +     </xs:schema> + + + + + + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 10] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +5.  Example Document + +   The following is an example of a document compliant to the schema. + +   <?xml version="1.0" encoding="UTF-8"?> +   <d:xcap-diff xmlns:d="urn:ietf:params:xml:ns:xcap-diff" +                xmlns="urn:ietf:params:xml:ns:rls-services" +                xcap-root="http://xcap.example.com/root/"> + +    <d:document new-etag="7ahggs" +              sel="resource-lists/users/sip:joe@example.com/coworkers" +              previous-etag="8a77f8d"/> + +    <d:element sel="rls-services/users/sip:joe@example.com/index/~~ +   /*/service%5b@uri='sip:marketing@example.com'%5d" +             xmlns:rl="urn:ietf:params:xml:ns:resource-lists" +       ><service uri="sip:marketing@example.com"> +         <list name="marketing"> +           <rl:entry uri="sip:joe@example.com"/> +           <rl:entry uri="sip:sudhir@example.com"/> +         </list> +         <packages> +           <package>presence</package> +         </packages> +       </service></d:element> + +    <d:attribute +    sel="rls-services/users/sip:joe@example.com/index/~~/*/service/@uri" +         >sip:marketing@example.com</d:attribute> + +   </d:xcap-diff> + +   This indicates that the document with the URI "http:// +   xcap.example.com/root/resource-lists/users/sip:joe@example.com/ +   coworkers" has changed.  Its previous entity tag is "8a77f8d" and its +   new one is "7ahggs", but actual changes are not shown.  The <service> +   element exists in the rls-services "index" document and its full +   content is shown.  Note that the <service> element is attached with a +   default namespace declaration within the original document. +   Similarly, "uri" attribute content is shown from the same "index" +   document as an illustrative example. + +6.  Basic Requirements for a System Exchanging XCAP Diff Documents + +   Documents at an XCAP server are identified by URIs, and updated by +   XCAP clients with HTTP (PUT and DELETE) methods.  The XCAP server +   assigns a new entity tag value for each document version.  An entity +   tag value is defined by Section 3.11 of RFC 2616 [RFC2616]: "An + + + +Rosenberg & Urpalainen       Standards Track                   [Page 11] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   entity tag MUST be unique across all versions of all entities +   associated with a particular resource".  These entity tags are used +   to protect requests from making overriding changes when multiple XCAP +   clients update the same XCAP document.  An entity tag value can be +   interpreted as a unique identifier to a specific version of an XCAP +   document in its change history. + +   The entity tag values of XCAP resources also enable a reliable way to +   update the locally cached XCAP resource copies in an XCAP diff +   implementation.  When a diff client applies XCAP diff document +   changes, it MUST apply a resource state change only if entity tag +   values match with octet-by-octet equivalence according to the table +   defined in Figure 1.  If a diff client notices inconsistencies and/or +   errors when it applies reported resource changes, it SHOULD tear down +   the session. + +   State changes of an XCAP document MUST be delivered reliably from a +   diff notifier to a diff client, and a diff client MUST be able to +   apply all changes of an XCAP document in the same chronological order +   that occurred at an XCAP server.  When using an unreliable transport +   with retransmissions, the application protocol used with the XCAP +   diff MUST ensure that duplicates are dropped.  If an XCAP diff +   delivery is lost, the diff session MUST be torn down.  Note that a +   diff notifier can easily notice a lost notification when a diff +   client must respond to each XCAP diff delivery. + +   A diff notifier doesn't necessarily report all of these XCAP document +   updates with ETags; it MAY skip over some intermediate version of a +   document, for example, with rapidly changing resources.  However, it +   MUST always report changes consistently to a diff client so that it +   can properly update the latest state (content and ETag) of its +   locally cached resources. + +      As an example, an XCAP document is updated by different 'a', 'b', +      and 'c' versions identified with the same corresponding ETag +      values in a relatively short period.  The first reported +      notification contains the 'a' "new-tag" information (no "previous- +      etag" attribute), and the diff notifier decides to skip the update +      notification identified by the 'b' ETag value.  The second +      notification to a diff client MUST then contain the 'a' "previous- +      etag" and 'c' "new-etag" values with optional corresponding +      content changes (from version 'a' to 'c'). + +   Since XCAP documents are typically confidential, diff notifiers MUST +   obey the XCAP authorization rules.  In practice, this means following +   the read privilege rules of XCAP resources when notifying the +   authenticated diff clients of changes.  Transport SHOULD be secured +   by encryption. + + + +Rosenberg & Urpalainen       Standards Track                   [Page 12] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +      Note: This format specification doesn't define how to select the +      resources whose differences a diff notifier should report.  It +      also doesn't define whether actual content changes should be +      reported.  Typically, however, a diff client starts a session by +      sending a resource listing request.  Then it compares the remote +      resource listings with locally cached ones, and probably downloads +      those resources that aren't locally cached or whose entity tags +      differ.  When a diff client receives an XCAP diff with a +      "previous-etag" value that matches its current cached copy of a +      document, it can apply the diffs to the cached copy.  As it takes +      some time to download reference documents, and diff notifications +      appear after actual resource state changes, several round trips +      may be needed before a full synchronization is achieved, +      especially with rapidly changing resources. + +7.  Security Considerations + +   XCAP diff documents can include changes from one version of a +   document to another version.  As a consequence, if the document +   itself is sensitive and requires confidentiality, integrity, or +   authentication, then the same applies to the XCAP diff format. +   Therefore, protocols that transport XCAP diff documents must provide +   sufficient security capabilities for transporting the document +   itself.  Confidential XCAP documents are typically transported using +   TLS-encrypted (Transport Layer Security) [RFC5246] communication; see +   RFC 4825 [RFC4825] for further security details. + +   When this format is used to report content changes of XCAP documents, +   all security considerations of RFC 5261 [RFC5261] apply.  Very +   frequent updates of XCAP documents and/or many diff clients per +   subscribed resource impose a Denial-of-Service attack possibility to +   the servers processing XCAP diff documents.  An efficient patch +   processing and throttling can, however, decrease the required overall +   processings and transactions. + +   The SIP event package framework specified in RFC 3265 [RFC3265] is +   the most typical use-case for this format.  Then, an end-to-end SIP +   encryption mechanism, such as Secure/Multipurpose Internet Mail +   Extensions (S/MIME) described in Section 26.2.4 of RFC 3261 +   [RFC3261], SHOULD be used.  If that is not available, it is +   RECOMMENDED that TLS [RFC5246] be used between elements to provide +   hop-by-hop authentication and encryption mechanisms as described in +   Section 26.2.2 ("SIPS URI Scheme") and Section 26.3.2.2 ("Interdomain +   Requests") of RFC 3261 [RFC3261].  Event packages MAY also have other +   specific threats that MUST be considered on an application-by- +   application basis. + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 13] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +8.  IANA Considerations + +   There are several IANA considerations associated with this +   specification. + +8.1.  application/xcap-diff+xml MIME Type + +   MIME media type name: application + +   MIME subtype name: xcap-diff+xml + +   Mandatory parameters: none + +   Optional parameters: Same as the charset parameter application/xml as +   specified in RFC 3023 [RFC3023]. + +   Encoding considerations: Same as the encoding considerations of +   application/xml as specified in RFC 3023 [RFC3023]. + +   Security considerations: See Section 10 of RFC 3023 [RFC3023] and +   Section 7 of RFC 5874. + +   Interoperability considerations: none. + +   Published specification: This document. + +   Applications that use this media type: This document type has been +   used to support manipulation of resource lists [RFC4826] using XCAP. + +   Additional Information: + +      Magic Number: None + +      File Extension: .xdf + +      Macintosh file type code: "TEXT" + +      Personal and email address for further information: Jonathan +      Rosenberg, jdrosen@jdrosen.net + +      Intended usage: COMMON + +      Author/Change controller: The IETF. + + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 14] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +8.2.  URN Sub-Namespace Registration for +      urn:ietf:params:xml:ns:xcap-diff + +   This section registers a new XML namespace, as per the guidelines in +   [RFC3688]. + +      URI: The URI for this namespace is +      urn:ietf:params:xml:ns:xcap-diff. + +      Registrant Contact: IETF, SIMPLE working group, (simple@ietf.org), +      Jonathan Rosenberg (jdrosen@jdrosen.net). + +      XML: + +  BEGIN +  <?xml version="1.0"?> +  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN" +       "http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd"> +  <html xmlns="http://www.w3.org/1999/xhtml"> +  <head> +    <meta http-equiv="content-type" +       content="text/html;charset=iso-8859-1"/> +    <title>XCAP Diff Namespace</title> +  </head> +  <body> +    <h1>Namespace for XCAP Diff</h1> +    <h2>urn:ietf:params:xml:ns:xcap-diff</h2> +    <p>See <a +       href="http://www.rfc-editor.org/rfc/rfc5874.txt">RFC5874</a>.</p> +  </body> +  </html> +  END + +8.3.  Schema Registration + +   This section registers a new XML schema per the procedures in +   [RFC3688]. + +      URI: urn:ietf:params:xml:schema:xcap-diff + +      Registrant Contact: IETF, SIMPLE working group, (simple@ietf.org), +      Jonathan Rosenberg (jdrosen@jdrosen.net). + +      The XML for this schema can be found as the sole content of +      Section 4. + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 15] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +9.  Acknowledgments + +   The authors would like to thank Pavel Dostal, Jeroen van Bemmel, +   Martin Hynar, Anders Lindgren, Mary Barnes, Ben Campbell, Francis +   Dupont, David Harrington, Alexey Melnikov, Dan Romascanu, and Robert +   Sparks for their valuable comments. + +10.  References + +10.1.  Normative References + +   [W3C.REC-xml-20060816] +             Paoli, J., Bray, T., Yergeau, F., Maler, E., and C. +             Sperberg-McQueen, "Extensible Markup Language (XML) 1.0 +             (Fourth Edition)", World Wide Web Consortium +             FirstEdition REC-xml- 20060816, August 2006, <http:// +             www.w3.org/TR/2006/REC-xml-20060816>. + +   [W3C.REC-xml-c14n-20010315] +             Boyer, J., "Canonical XML Version 1.0", World Wide Web +             Consortium Recommendation REC-xml-c14n-20010315, +             March 2001, <http://www.w3.org/TR/2001/ +             REC-xml-c14n-20010315>. + +   [W3C.REC-xml-names-20060816] +              Hollander, D., Layman, A., and T. Bray, "Namespaces in XML +             1.0 (Second Edition)", World Wide Web Consortium +             FirstEdition REC-xml-names-20060816, August 2006, +             <http://www.w3.org/TR/ 2006/REC-xml-names-20060816>. + +   [RFC2141] Moats, R., "URN Syntax", RFC 2141, May 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. + +   [RFC3023] Murata, M., St. Laurent, S., and D.  Kohn, "XML Media +             Types", RFC 3023, January 2001. + +   [RFC2648] Moats, R., "A URN Namespace for IETF Documents", RFC 2648, +             August 1999. + +   [RFC3688] Mealling, M., "The IETF XML Registry", BCP 81, RFC 3688, +             January 2004. + +   [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate +             Requirement Levels", BCP 14, RFC 2119, March 1997. + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 16] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   [RFC4825] Rosenberg, J., "The Extensible Markup Language (XML) +             Configuration Access Protocol (XCAP)", RFC 4825, May 2007. + +   [RFC5261] Urpalainen, J., "An Extensible Markup Language (XML) Patch +             Operations Framework Utilizing XML Path Language (XPath) +             Selectors", RFC 5261, September 2008. + +   [RFC5246] Dierks, T. and E. Rescorla, "The Transport Layer Security +             (TLS) Protocol Version 1.2", RFC 5246, August 2008. + +10.2.  Informative References + +   [RFC5875] Urpalainen, J. and D. Willis, "An Extensible Markup +             Language (XML) Configuration Access Protocol (XCAP) Diff +             Event Package", RFC 5875, May 2010. + +   [RFC2778] Day, M., Rosenberg, J., and H. Sugano, "A Model for +             Presence and Instant Messaging", RFC 2778, February 2000. + +   [RFC3261] Rosenberg, J., Schulzrinne, H., Camarillo, G., Johnston, +             A., Peterson, J., Sparks, R., Handley, M., and E. +             Schooler, "SIP: Session Initiation Protocol", RFC 3261, +             June 2002. + +   [RFC3265] Roach, A., "Session Initiation Protocol (SIP)-Specific +             Event Notification", RFC 3265, June 2002. + +   [RFC4662] Roach, A., Campbell, B., and J.  Rosenberg, "A Session +             Initiation Protocol (SIP) Event Notification Extension for +             Resource Lists", RFC 4662, August 2006. + +   [RFC4826] Rosenberg, J., "Extensible Markup Language (XML) Formats +             for Representing Resource Lists", RFC 4826, May 2007. + +   [RFC4483] Burger, E., "A Mechanism for Content Indirection in Session +             Initiation Protocol (SIP) Messages", RFC 4483, May 2006. + + + + + + + + + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 17] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +Appendix A.  Informative Examples + +   These informative examples illustrate basic features of XCAP diff +   format. + +   The following documents exist at an XCAP server (xcap.example.com) +   with an imaginary "tests" application usage (there's no default +   document namespace defined in this imaginary application usage). + +   http://xcap.example.com/tests/users/sip:joe@example.com/index: + +   <?xml version="1.0" encoding="UTF-8"?> +   <doc id="bar"> +     <note>This is a sample document</note> +   </doc> + +   and then + +   http://xcap.example.com/tests/users/sip:john@example.com/index: + +   <?xml version="1.0" encoding="UTF-8"?> +   <doc> +     <note>This is another sample document</note> +   </doc> + +A.1.  Indicating Existing, Changed, or Removed Documents + +   Firstly, an XCAP diff document can indicate what documents exist in a +   collection.  An XCAP diff document may then be: + +   <?xml version="1.0" encoding="UTF-8"?> +   <xcap-diff xmlns="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <document new-etag="7ahggs" +              sel="tests/users/sip:joe@example.com/index"/> + +    <document new-etag="terteer" +              sel="tests/users/sip:john@example.com/index"/> + +   </xcap-diff> + +   This listing indicates current ETags of existing documents and their +   relative URIs. + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 18] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   Let's say that Joe adds a new document to his collection: + +   PUT /tests/users/sip:joe@example.com/another_document HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Type: application/xml +   Content-Length: [XXX] + +   <?xml version="1.0" encoding="UTF-8"?> +   <doc> +     <note>This is another sample document</note> +   </doc> + +   The requests result header has an HTTP ETag "terteer" for this new +   document. + +   Then an XCAP diff document may then indicate only the creation of +   this single new document: + +   <?xml version="1.0" encoding="UTF-8"?> +   <xcap-diff xmlns="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <document new-etag="terteer" +              sel="tests/users/sip:joe@example.com/another_document"/> + +   </xcap-diff> + +   A "new-etag" without a "previous-etag" attribute indicates a creation +   of a new document. + +   Then Joe decides to modify an existing resource: + +   PUT /tests/users/sip:joe@example.com/another_document HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Type: application/xml +   Content-Length: [XXX] + +   <?xml version="1.0" encoding="UTF-8"?> +   <doc> +     <note>This is a modified document</note> +   </doc> + +   The reported new HTTP ETag is "huwiias". + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 19] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   Then an XCAP diff document may be: + +   <?xml version="1.0" encoding="UTF-8"?> +   <xcap-diff xmlns="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <document previous-etag="terteer" new-etag="huwiias" +              sel="tests/users/sip:joe@example.com/another_document"/> + +   </xcap-diff> + +   Both "previous-etag" and "new-etag" attributes signal that a +   modification has happened to a resource, but actual changes are not +   shown. + +   Let's say that Joe then removes a document from his collection: + +   DELETE /tests/users/sip:joe@example.com/another_document HTTP/1.1 +   Host: xcap.example.com + +   This HTTP DELETE request results in the unlinking of the resource, +   and the XCAP diff may be: + +   <?xml version="1.0" encoding="UTF-8"?> +   <xcap-diff xmlns="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <document previous-etag="huwiias" +              sel="tests/users/sip:joe@example.com/another_document"/> + +   </xcap-diff> + +   Thus, a "previous-etag" without a "new-etag" attribute indicates the +   removal of a resource. + + + + + + + + + + + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 20] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +A.2.  Indicating Actual Changes of Documents + +   Secondly, XCAP diff documents are capable of showing actual changes +   to documents with [RFC5261] patching semantics. + +   Now Joe's XCAP client utilizes the XCAP patching capability to add a +   new element to a document: + +   PUT /tests/users/sip:joe@example.com/index/~~/doc/foo HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Type: application/xcap-el+xml +   Content-Length: [XXX] + +   <foo>this is a new element</foo> + +   Since the insertion of the element is successful, Joe's XCAP client +   receives the new HTTP ETag "fgherhryt3" of the updated "index" +   document. + +   Immediately thereafter, Joe's XCAP client issues another HTTP request +   (this request could even be pipelined): + +   PUT /tests/users/sip:joe@example.com/index/~~/doc/bar HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Type: application/xcap-el+xml +   Content-Length: [XXX] + +   <bar>this is a bar element +   </bar> + +   The reported new HTTP ETag of "index" is now "dgdgdfgrrr". + +   And then Joe's XCAP client issues yet another HTTP request: + +   PUT /tests/users/sip:joe@example.com/index/~~/doc/foobar HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Type: application/xcap-el+xml +   Content-Length: [XXX] + +   <foobar>this is a foobar element</foobar> + +   The reported new ETag of "index" is now "63hjjsll". + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 21] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   XCAP diff format document may then indicate these XCAP component +   changes by: + +   <?xml version="1.0" encoding="UTF-8"?> +   <d:xcap-diff xmlns:d="urn:ietf:params:xml:ns:xcap-diff" +                xcap-root="http://xcap.example.com/"> + +    <d:document previous-etag="7ahggs3" +                sel="tests/users/sip:joe@example.com/index" +                new-etag="63hjjsll"> +     <d:add sel="*" +       ><foo>this is a new element</foo><bar>this is a bar element +   </bar><foobar>this is a foobar element</foobar></d:add> +    </d:document> + +   </d:xcap-diff> + +   Note how several XCAP component modifications were aggregated +   together, and full history information got lost. + +   Alternatively, the content could have been: + +   <?xml version="1.0" encoding="UTF-8"?> +   <d:xcap-diff xmlns:d="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <d:document previous-etag="7ahggs" +                sel="tests/users/sip:joe@example.com/index" +                new-etag="fgherhryt3"> +      <d:add sel="*" +       ><foo>this is a new element</foo></d:add></d:document> + +    <d:document previous-etag="fgherhryt3" +                sel="tests/users/sip:joe@example.com/index" +                new-etag="dgdgdfgrrr"> +      <d:add sel="*" +       ><bar>this is a bar element +   </bar></d:add></d:document> + +    <d:document previous-etag="dgdgdfgrrr" +                sel="tests/users/sip:joe@example.com/index" +                new-etag="63hjjsll"> +      <d:add sel="*" +       ><foobar>this is a foobar element</foobar></d:add></d:document> + +   </d:xcap-diff> + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 22] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +   This shows the full ETag change history of a document, and ETags +   change chronologically in the reported XML document order. + +A.3.  Indicating XCAP Component Contents + +   Lastly, the XCAP diff format can also indicate the existing full +   contents of XCAP components, i.e., elements or attributes: + +   <?xml version="1.0" encoding="UTF-8"?> +   <d:xcap-diff xmlns:d="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <d:attribute sel="tests/users/sip:joe@example.com/index/~~/doc/@id" +     >bar</d:attribute> + +    <d:element sel="tests/users/sip:joe@example.com/index/~~/*/foo" +       ><foo>this is a new element</foo></d:element> + +   </d:xcap-diff> + +   Note that the HTTP ETag value of the new document is not shown as it +   is irrelevant for this use-case. + +   Then Joe's XCAP client removes the "id" attribute: + +   DELETE /tests/users/sip:joe@example.com/index/~~/doc/@id HTTP/1.1 +   Host: xcap.example.com +   .... +   Content-Length: 0 + +   And the XCAP diff document may then be: + +   <?xml version="1.0" encoding="UTF-8"?> +   <xcap-diff xmlns="urn:ietf:params:xml:ns:xcap-diff" +              xcap-root="http://xcap.example.com/"> + +    <attribute sel="tests/users/sip:joe@example.com/index/~~/doc/@id" +     exists="0"/> + +   </xcap-diff> + +   This indicates that the subscribed attribute was removed from the +   document.  The element content in this use-case may be discarded from +   the XCAP diff document, for example, when the size of XCAP diff +   document would be impractically large to the transport layer. + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 23] + +RFC 5874                    XCAP Diff Format                    May 2010 + + +Authors' Addresses + +   Jonathan Rosenberg +   jdrosen.net +   Monmouth, NJ +   US + +   EMail: jdrosen@jdrosen.net +   URI:   http://www.jdrosen.net + + +   Jari Urpalainen +   Nokia +   Itamerenkatu 11-13 +   Helsinki  00180 +   Finland + +   Phone: +358 7180 37686 +   EMail: jari.urpalainen@nokia.com + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +Rosenberg & Urpalainen       Standards Track                   [Page 24] + |