XCAP
XML Configuration Access Protocol - an application layer protocol that allows a client to read, write, and modify application configuration data stored in XML format on a server
XCAP features ● The following operations are supported via XCAP protocol in a client- server interaction: – Retrieve an item – Delete an item – Modify an item – Add an item ● The operations above can be executed on the following items: – Document – Element – Attribute
XCAP functional elements
HTTP URI
XML Basics ● XML is a mechanism for representing structured data ● Data is represented by a tree ● Each node in the tree is an element ● Elements have attributes – Attributes qualify the data ● “Leaf” Elements can contain text content Jonathan Rosenberg 600 Lanidex Pl Parsippany NJ USA
XML Namespaces ● Problem – Want to combine content from different systems into one document – What if both sources define the same name? ● Example – Add information to address book on whether data is synced with PC – synchronized – Which state is it? <!—This guy is a bozo -- Jonathan Rosenberg 600 Lanidex Pl Parsippany NJ USA
XML Namespaces ● Solution: XML Namespace ● Elements and attributes are bound to a namespace when defined ● Namespace is identified with a unique URI ● A prefix is bound to that URI through a declaration in the document ● Each element is named with its qualified name – The prefix, followed by a colon, followed by the local-name <?xml version="1.0" encoding="UTF-8"? xmlns:post=“ xmlns:sync=“ <!—This guy is a bozo -- Jonathan Rosenberg 600 Lanidex Pl Parsippany NJ USA synchronized
Positional Selectors ● What if there are multiple elements with that name? – Can supply predicates which select one of the matching ones – Predicates appear in square brackets ● One such predicate is position – Indicates which one by its place in the ordered sequence of matching elements ● Select second bar: foo/bar[2] ● Select first bar: foo/bar[1] Hello There
Select by Attribute Name ● You can select elements that have attributes with specific values Hi How Are
Selecting Attributes ● An attribute is selected by prefixing its name with an @bool ● The selected object is JUST the value – Different from elements – Name would be redundant Hi How Are
AUID ● Unique Identifier for each application ● Two sub-namespaces – IETF tree: tokens in RFC documents ● IANA Registry – Vendor tree: proprietary data ● Start with reverse DNS name of enterprise ● Examples – IETF Tree ● “resource-lists” draft-ietf-simple-xcap-list-usage ● “pidf-manipulation” draft-isomaki-simple-xcap-pidf-manipulation-usage-00 ● “rules” draft-rosenberg-simple-rules – Vendor Tree ● “com.example.customer-list”
AUID Grammar AUID = global-auid / vendor-auid global-auid = auid auid = alphanum / mark vendor-auid = rev-hostname "." auid rev-hostname = toplabel *( "." domainlabel ) domainlabel = alphanum / alphanum *( alphanum / "-" ) alphanum toplabel = ALPHA / ALPHA *( alphanum / "-" ) alphanum
Creating or replacing a complete XML document
Adding an element to an XML document
Deleting an XML document
Entity tags in HTML
HTTP conditional requests
Subscription to changes in XML documents
SUBSCRIBE request (1)
Diff-processing ● There are three possible values of the diff- processing parameter: – “no-patching” – “xcap-patching” – “aggregate”
Initial XCAP-Diff document included in a NOTIFY request (3)
Subsequent XCAP-Diff document included in a NOTIFY request (5)
XML Patch ● XML documents that offer a set of conventions to express changes incurred in other XML documents ● There are three patch operations: –
XML patch operations document
XDM
XDM (XML Document Management) ● XDM allows a user to: – modify XML documents stored in remote network servers. – synchronized the local copy of XML documents in the IMS terminal with the copy stored in network servers, so that if the user makes changes to one XML document from a given IMS terminal, other terminals are updated with the latest changes – searches of information stored in XML documents.
XDM architecture
XDM: basic GET operation
HTTP GET request (1)
HTTP 401 (Unauthorized) response (2)
HTTP GET request (3)
HTTP GET request (4)
200 (OK) response (5)
200 (OK) response (6)
Directory retrieval with XDM
Directory retrieval: HTTP GET request (1)
Directory retrieval: 200 (OK) response (5)
Directory retrieval: Aggregated 200 (OK) response (6)
Directory retrieval with XDM for a given XCAP application usage
Directory retrieval: HTTP GET request (1)
Directory retrieval : 200 (OK) response (3)
Searching data with XDM
Search operation: HTTP POST request (1) (part 1/2)
Search operation: HTTP POST request (1) (part 2/2)
Search operation: HTTP 200 (OK) response (4)
Sources ● The 3G IP Multimedia Subsystem (IMS) Third Edition, Gonzalo Camarillo and Miguel A. Garcia-Martin ● XCAP Tutorial, Jonathan Rosenberg ●