mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2024-11-25 10:23:40 +00:00
1235 lines
33 KiB
Text
1235 lines
33 KiB
Text
|
||
|
||
|
||
|
||
|
||
|
||
Internet Engineering Task Force (IETF) S. Perreault
|
||
Request for Comments: 6351 Viagenie
|
||
Category: Standards Track August 2011
|
||
ISSN: 2070-1721
|
||
|
||
|
||
xCard: vCard XML Representation
|
||
|
||
Abstract
|
||
|
||
This document defines the XML schema of the vCard data format.
|
||
|
||
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/rfc6351.
|
||
|
||
Copyright Notice
|
||
|
||
Copyright (c) 2011 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.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 1]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
Table of Contents
|
||
|
||
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 2
|
||
2. Conventions . . . . . . . . . . . . . . . . . . . . . . . . . 2
|
||
3. The Schema . . . . . . . . . . . . . . . . . . . . . . . . . . 2
|
||
4. Example: Author's XML vCard . . . . . . . . . . . . . . . . . 3
|
||
5. Design Considerations . . . . . . . . . . . . . . . . . . . . 4
|
||
5.1. Extensibility . . . . . . . . . . . . . . . . . . . . . . 6
|
||
5.2. Limitations . . . . . . . . . . . . . . . . . . . . . . . 7
|
||
6. Format Conversions . . . . . . . . . . . . . . . . . . . . . . 8
|
||
7. Security Considerations . . . . . . . . . . . . . . . . . . . 10
|
||
8. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 11
|
||
8.1. Registration of the XML Namespace . . . . . . . . . . . . 11
|
||
8.2. Media Type . . . . . . . . . . . . . . . . . . . . . . . . 11
|
||
9. Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . 12
|
||
10. References . . . . . . . . . . . . . . . . . . . . . . . . . . 12
|
||
10.1. Normative References . . . . . . . . . . . . . . . . . . . 12
|
||
10.2. Informative References . . . . . . . . . . . . . . . . . . 13
|
||
Appendix A. Relax NG Schema . . . . . . . . . . . . . . . . . . . 14
|
||
|
||
1. Introduction
|
||
|
||
vCard [RFC6350] is a data format for representing and exchanging
|
||
information about individuals and other entities. It is a text-based
|
||
format (as opposed to a binary format). This document defines xCard,
|
||
an XML [W3C.REC-xml-20081126] representation for vCard. The
|
||
underlying data structure is exactly the same, enabling a 1-to-1
|
||
mapping between the original vCard format and the XML representation.
|
||
The XML formatting may be preferred in some contexts where an XML
|
||
engine is readily available and may be reused instead of writing a
|
||
standalone vCard parser.
|
||
|
||
Earlier work on an XML format for vCard was started in 1998 by Frank
|
||
Dawson [VCARD-DTD]. Sadly, it did not take over the world.
|
||
|
||
2. 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].
|
||
|
||
3. The Schema
|
||
|
||
The schema is expressed in the RELAX NG language [ISO.19757-2.2008]
|
||
and is found in Appendix A.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 2]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
4. Example: Author's XML vCard
|
||
|
||
<?xml version="1.0" encoding="UTF-8"?>
|
||
<vcards xmlns="urn:ietf:params:xml:ns:vcard-4.0">
|
||
<vcard>
|
||
<fn><text>Simon Perreault</text></fn>
|
||
<n>
|
||
<surname>Perreault</surname>
|
||
<given>Simon</given>
|
||
<additional/>
|
||
<prefix/>
|
||
<suffix>ing. jr</suffix>
|
||
<suffix>M.Sc.</suffix>
|
||
</n>
|
||
<bday><date>--0203</date></bday>
|
||
<anniversary>
|
||
<date-time>20090808T1430-0500</date-time>
|
||
</anniversary>
|
||
<gender><sex>M</sex></gender>
|
||
<lang>
|
||
<parameters><pref><integer>1</integer></pref></parameters>
|
||
<language-tag>fr</language-tag>
|
||
</lang>
|
||
<lang>
|
||
<parameters><pref><integer>2</integer></pref></parameters>
|
||
<language-tag>en</language-tag>
|
||
</lang>
|
||
<org>
|
||
<parameters><type><text>work</text></type></parameters>
|
||
<text>Viagenie</text>
|
||
</org>
|
||
<adr>
|
||
<parameters>
|
||
<type><text>work</text></type>
|
||
<label><text>Simon Perreault
|
||
2875 boul. Laurier, suite D2-630
|
||
Quebec, QC, Canada
|
||
G1V 2M2</text></label>
|
||
</parameters>
|
||
<pobox/>
|
||
<ext/>
|
||
<street>2875 boul. Laurier, suite D2-630</street>
|
||
<locality>Quebec</locality>
|
||
<region>QC</region>
|
||
<code>G1V 2M2</code>
|
||
<country>Canada</country>
|
||
</adr>
|
||
<tel>
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 3]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
<parameters>
|
||
<type>
|
||
<text>work</text>
|
||
<text>voice</text>
|
||
</type>
|
||
</parameters>
|
||
<uri>tel:+1-418-656-9254;ext=102</uri>
|
||
</tel>
|
||
<tel>
|
||
<parameters>
|
||
<type>
|
||
<text>work</text>
|
||
<text>text</text>
|
||
<text>voice</text>
|
||
<text>cell</text>
|
||
<text>video</text>
|
||
</type>
|
||
</parameters>
|
||
<uri>tel:+1-418-262-6501</uri>
|
||
</tel>
|
||
<email>
|
||
<parameters><type><text>work</text></type></parameters>
|
||
<text>simon.perreault@viagenie.ca</text>
|
||
</email>
|
||
<geo>
|
||
<parameters><type><text>work</text></type></parameters>
|
||
<uri>geo:46.766336,-71.28955</uri>
|
||
</geo>
|
||
<key>
|
||
<parameters><type><text>work</text></type></parameters>
|
||
<uri>http://www.viagenie.ca/simon.perreault/simon.asc</uri>
|
||
</key>
|
||
<tz><text>America/Montreal</text></tz>
|
||
<url>
|
||
<parameters><type><text>home</text></type></parameters>
|
||
<uri>http://nomis80.org</uri>
|
||
</url>
|
||
</vcard>
|
||
</vcards>
|
||
|
||
5. Design Considerations
|
||
|
||
The general idea is to map vCard parameters, properties, and value
|
||
types to XML elements. For example, the "FN" property is mapped to
|
||
the "fn" element. In turn, that element contains a text element
|
||
whose content corresponds to the vCard property's value.
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 4]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
vCard parameters are also mapped to XML elements. They are contained
|
||
in the <parameters> element, which is contained in property elements.
|
||
For example, the "TYPE" parameter applied to the "TEL" property would
|
||
look like the following in XML:
|
||
|
||
<tel>
|
||
<parameters>
|
||
<type>
|
||
<text>voice</text>
|
||
<text>video</text>
|
||
</type>
|
||
</parameters>
|
||
<uri>tel:+1-555-555-555</uri>
|
||
</tel>
|
||
|
||
Parameters taking a list of values are simply repeated multiple
|
||
times, once for each value in the list.
|
||
|
||
Properties having structured values (e.g., the "N" property) are
|
||
expressed by XML element trees. Element names in that tree (e.g.,
|
||
"surname", "given", etc.) do not have a vCard equivalent since they
|
||
are identified by position in plain vCard.
|
||
|
||
Line folding is a non-issue in XML. Therefore, the mapping from
|
||
vCard to XML is done after the unfolding procedure is carried out.
|
||
Conversely, the mapping from XML to vCard is done before the folding
|
||
procedure is carried out.
|
||
|
||
A top-level <vcards> element is used as root. It contains one or
|
||
more <vcard> elements, each representing a complete vCard. The
|
||
<vcards> element MUST be present even when only a single vCard is
|
||
present in an XML document.
|
||
|
||
The group construct (Section 3.2 in [RFC6350]) is represented with
|
||
the <group> element. The "name" attribute contains the group's name.
|
||
For example:
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 5]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
<vcards>
|
||
<vcard>
|
||
<group name="contact">
|
||
<fn>...</fn>
|
||
<email>...</email>
|
||
</group>
|
||
<group name="media">
|
||
<photo>...</photo>
|
||
</group>
|
||
<categories>...</categories>
|
||
</vcard>
|
||
</vcards>
|
||
|
||
is equivalent to:
|
||
|
||
BEGIN:VCARD
|
||
VERSION:4.0
|
||
contact.FN=...
|
||
contact.EMAIL=...
|
||
media.PHOTO=...
|
||
CATEGORIES=...
|
||
END:VCARD
|
||
|
||
5.1. Extensibility
|
||
|
||
The original vCard format is extensible. New properties, parameters,
|
||
data types and values (collectively known as vCard elements, not to
|
||
be confused with XML elements) can be registered with IANA (see
|
||
[RFC6350], Section 10.2). It is expected that these vCard extensions
|
||
will also specify extensions to the XML format described in this
|
||
document.
|
||
|
||
New XML vCard property and parameter element names MUST be lower-
|
||
case. This is necessary to ensure that round-tripping between XML
|
||
and plain-text vCard works correctly.
|
||
|
||
Unregistered extensions (i.e., those starting with "X-" and
|
||
"VND-...-") are expressed in XML by using elements starting with "x-"
|
||
and "vnd-...-". Usage of XML namespaces [W3C.REC-xml-names-20091208]
|
||
for extensibility is RECOMMENDED for extensions that have no
|
||
equivalent in plain-text vCard. Refer to Section 6 for the
|
||
implications when converting between plain-text vCard and XML.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 6]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
Examples:
|
||
|
||
<x-my-prop>
|
||
<parameters>
|
||
<pref><integer>1</integer></pref>
|
||
</parameters>
|
||
<text>value goes here</text>
|
||
</x-my-prop>
|
||
|
||
<ext:my-prop
|
||
ext:xmlns="http://example.com/extensions/my-vcard">
|
||
<parameters>
|
||
<pref><integer>1</integer></pref>
|
||
</parameters> <!-- Core vCard elements -->
|
||
<text>value goes here</text> <!-- are still accessible -->
|
||
</ext:my-prop>
|
||
|
||
Note that extension elements do not need the "X-" or "VND-" prefix in
|
||
XML. The XML namespace mechanism is sufficient.
|
||
|
||
A vCard XML parser MUST ignore XML elements and attributes for which
|
||
it doesn't recognize the expanded name. The normal behavior of
|
||
ignoring XML processing instructions whose target is not recognized
|
||
MUST also be followed.
|
||
|
||
In the original vCard format, the "VERSION" property was mandatory
|
||
and played a role in extensibility. In XML, this property is absent.
|
||
Its role is played by the vCard core namespace identifier, which
|
||
includes the version number. vCard revisions will use a different
|
||
namespace.
|
||
|
||
Parameters containing a list of values are expressed using a list of
|
||
elements in XML (e.g., the <type> element).
|
||
|
||
5.2. Limitations
|
||
|
||
The schema does not validate the cardinality of properties. This is
|
||
a limitation of the schema definition language. Cardinalities of the
|
||
original vCard format [RFC6350] MUST still be respected.
|
||
|
||
Some constructs (e.g., value enumerations in type parameters) have
|
||
additional ordering constraints in XML. This is a result of
|
||
limitations of the schema definition language, and the order is
|
||
arbitrary. The order MUST be respected in XML for the vCard to be
|
||
valid. However, reordering as part of conversion to or from plain
|
||
vCard MAY happen.
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 7]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
6. Format Conversions
|
||
|
||
When new properties or "X-" properties are used, a vCard<->xCard
|
||
converter might not recognize them or know what the appropriate
|
||
default value types are, yet they need to be able to preserve the
|
||
values. A similar issue arises for unrecognized property parameters.
|
||
As a result, the following rules are applied when dealing with
|
||
unrecognized properties and property parameters:
|
||
|
||
o When converting from vCard to xCard:
|
||
|
||
* Any property that does not include a "VALUE" parameter and
|
||
whose default value type is not known MUST be converted using
|
||
the value type XML element <unknown>. The content of that
|
||
element is the unprocessed value text.
|
||
|
||
* Any unrecognized property parameter MUST be converted using the
|
||
value type XML element <unknown>, with its content set to the
|
||
parameter value text, treated as if it were a text value, or
|
||
list of text values.
|
||
|
||
* The content of "XML" properties is copied as is to XML.
|
||
|
||
* Property and parameter XML element names are converted to
|
||
lower-case.
|
||
|
||
* Property value escaping is undone. For example, "\n" becomes a
|
||
NEWLINE character (ASCII decimal 10).
|
||
|
||
* Double-quoting of parameter values, as well as backslash
|
||
escaping in parameter values, is undone. For example,
|
||
PARAM="\"foo\",\"bar\"" becomes <param>"foo","bar"</param>.
|
||
|
||
o When converting xCard to vCard:
|
||
|
||
* Properties in the vCard 4 namespace:
|
||
|
||
+ If the converter knows of a specific plain-text
|
||
representation for this property, it uses it. For example,
|
||
the <adr> element corresponds to the "ADR" property, which
|
||
is encoded using comma-separated lists separated by
|
||
semicolons.
|
||
|
||
+ Otherwise, the property name is taken from the element name,
|
||
property parameters are taken from the <parameters> element,
|
||
and the content of the property is taken from the content of
|
||
the value element. If the property element has attributes
|
||
or contains other XML elements, they are dropped.
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 8]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
+ If a standard property's XML element contains XML elements
|
||
and attributes for which the converter doesn't recognize the
|
||
expanded name, they are dropped. Therefore, it is
|
||
RECOMMENDED to limit extensions to the property level to
|
||
ensure that all data is preserved intact in round-trip
|
||
conversions.
|
||
|
||
* Properties in other namespaces are wrapped as is inside an
|
||
"XML" property.
|
||
|
||
* Any <unknown> property value XML elements are converted
|
||
directly into vCard values. The containing property MUST NOT
|
||
have a "VALUE" parameter.
|
||
|
||
* Any <unknown> parameter value XML elements are converted as if
|
||
they were <text> value type XML elements.
|
||
|
||
* Property and parameter names are converted to upper-case.
|
||
|
||
* Property value escaping (Section 3.3 of [RFC6350]) is carried
|
||
out. For example, a NEWLINE character (ASCII decimal 10)
|
||
becomes "\n".
|
||
|
||
* Double-quoting of parameter values, as well as backslash
|
||
escaping in parameter values, is carried out. For example,
|
||
<param>"foo","bar"</param> becomes PARAM="\"foo\",\"bar\"".
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 9]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
For example, these two vCards are equivalent:
|
||
|
||
<?xml version="1.0"?>
|
||
<vcards xmlns="urn:ietf:params:xml:ns:vcard-4.0">
|
||
<vcard>
|
||
<fn><text>J. Doe</text></fn>
|
||
<n>
|
||
<surname>Doe</surname>
|
||
<given>J.</given>
|
||
<additional/>
|
||
<prefix/>
|
||
<suffix/>
|
||
</n>
|
||
<x-file>
|
||
<parameters>
|
||
<mediatype><text>image/jpeg</text></mediatype>
|
||
</parameters>
|
||
<unknown>alien.jpg</unknown>
|
||
</x-file>
|
||
<a xmlns="http://www.w3.org/1999/xhtml"
|
||
href="http://www.example.com">My web page!</a>
|
||
</vcard>
|
||
</vcards>
|
||
|
||
|
||
BEGIN:VCARD
|
||
VERSION:4.0
|
||
FN:J. Doe
|
||
N:Doe;J.;;
|
||
X-FILE;MEDIATYPE=image/jpeg:alien.jpg
|
||
XML:<a xmlns="http://www.w3.org/1999/xhtml"\n
|
||
href="http://www.example.com">My web page!</a>
|
||
END:VCARD
|
||
|
||
7. Security Considerations
|
||
|
||
All the security considerations applicable to plain vCard [RFC6350]
|
||
are applicable to this document as well.
|
||
|
||
XML Signature [W3C.CR-xmldsig-core1-20110303] and XML Encryption
|
||
[W3C.CR-xmlenc-core1-20110303] can be used with xCard to provide
|
||
authentication and confidentiality.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 10]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
8. IANA Considerations
|
||
|
||
8.1. Registration of the XML Namespace
|
||
|
||
URI: urn:ietf:params:xml:ns:vcard-4.0
|
||
|
||
Registrant Contact: The IESG <iesg@ietf.org>
|
||
|
||
XML: None. Namespace URIs do not represent an XML specification.
|
||
|
||
8.2. Media Type
|
||
|
||
This section defines the MIME media type [RFC4288] for use with
|
||
vCard-in-XML data.
|
||
|
||
To: ietf-types@iana.org
|
||
|
||
Subject: Registration of media type application/vcard+xml
|
||
|
||
Type name: application
|
||
|
||
Subtype name: vcard+xml
|
||
|
||
Required parameters: none
|
||
|
||
Optional parameters: charset as defined for application/xml in
|
||
[RFC3023]; per [RFC3023], use of the charset parameter with the
|
||
value "utf-8" is "STRONGLY RECOMMENDED".
|
||
|
||
Encoding considerations: Same as encoding considerations of
|
||
application/xml as specified in [RFC3023].
|
||
|
||
Security considerations: This media type has all of the security
|
||
considerations described in [RFC3023], plus those listed in
|
||
Section 7.
|
||
|
||
Interoperability considerations: This media type provides an
|
||
alternative syntax to vCard data [RFC6350] based on XML.
|
||
|
||
Published specification: This specification.
|
||
|
||
Applications that use this media type: Applications that currently
|
||
make use of the text/vcard media type can use this as an
|
||
alternative. In general, applications that maintain or process
|
||
contact information can use this media type.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 11]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
Additional information:
|
||
|
||
Magic number(s): none
|
||
|
||
File extension(s): XML data should use ".xml" as the file
|
||
extension.
|
||
|
||
Macintosh file type code(s): none
|
||
|
||
Person & email address to contact for further information: Simon
|
||
Perreault <simon.perreault@viagenie.ca>
|
||
|
||
Intended usage: COMMON
|
||
|
||
Restrictions on usage: none
|
||
|
||
Author: Simon Perreault
|
||
|
||
Change controller: IETF
|
||
|
||
9. Acknowledgments
|
||
|
||
Thanks to the following people for their input:
|
||
|
||
Alexey Melnikov, Barry Leiba, Bjorn Hoehrmann, Cyrus Daboo, Joe
|
||
Hildebrand, Joseph Smarr, Marc Blanchet, Mike Douglass, Peter Saint-
|
||
Andre, Robins George, Zahhar Kirillov, Zoltan Ordogh.
|
||
|
||
|
||
10. References
|
||
|
||
10.1. Normative References
|
||
|
||
[ISO.19757-2.2008]
|
||
International Organization for Standardization,
|
||
"Information technology -- Document Schema Definition
|
||
Language (DSDL) -- Part 2: Regular-grammar-based
|
||
validation -- RELAX NG", ISO International
|
||
Standard 19757-2, October 2008.
|
||
|
||
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
|
||
Requirement Levels", BCP 14, RFC 2119, March 1997.
|
||
|
||
[RFC3023] Murata, M., St. Laurent, S., and D. Kohn, "XML Media
|
||
Types", RFC 3023, January 2001.
|
||
|
||
[RFC6350] Perreault, S., "vCard Format Specification", RFC 6350,
|
||
August 2011.
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 12]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
[W3C.REC-xml-20081126]
|
||
Paoli, J., Yergeau, F., Maler, E., Bray, T., and C.
|
||
Sperberg-McQueen, "Extensible Markup Language (XML) 1.0
|
||
(Fifth Edition)", World Wide Web Consortium
|
||
Recommendation REC-xml-20081126, November 2008,
|
||
<http://www.w3.org/TR/2008/REC-xml-20081126>.
|
||
|
||
[W3C.REC-xml-names-20091208]
|
||
Bray, T., Hollander, D., Layman, A., Tobin, R., and H.
|
||
Thompson, "Namespaces in XML 1.0 (Third Edition)", World
|
||
Wide Web Consortium Recommendation REC-xml-names-20091208,
|
||
December 2009,
|
||
<http://www.w3.org/TR/2009/REC-xml-names-20091208>.
|
||
|
||
10.2. Informative References
|
||
|
||
[RFC4288] Freed, N. and J. Klensin, "Media Type Specifications and
|
||
Registration Procedures", BCP 13, RFC 4288, December 2005.
|
||
|
||
[VCARD-DTD]
|
||
Dawson, F., "The vCard v3.0 XML DTD", Work in Progress,
|
||
June 1998.
|
||
|
||
[W3C.CR-xmldsig-core1-20110303]
|
||
Roessler, T., Solo, D., Yiu, K., Reagle, J., Hirsch, F.,
|
||
Eastlake, D., and M. Nystroem, "XML Signature Syntax and
|
||
Processing Version 1.1", World Wide Web Consortium CR CR-
|
||
xmldsig-core1-20110303, March 2011,
|
||
<http://www.w3.org/TR/2011/CR-xmldsig-core1-20110303>.
|
||
|
||
[W3C.CR-xmlenc-core1-20110303]
|
||
Eastlake, D., Reagle, J., Roessler, T., and F. Hirsch,
|
||
"XML Encryption Syntax and Processing Version 1.1", World
|
||
Wide Web Consortium CR CR-xmlenc-core1-20110303,
|
||
March 2011,
|
||
<http://www.w3.org/TR/2011/CR-xmlenc-core1-20110303>.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 13]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
Appendix A. Relax NG Schema
|
||
|
||
default namespace = "urn:ietf:params:xml:ns:vcard-4.0"
|
||
|
||
### Section 3.3: vCard Format Specification
|
||
#
|
||
# 3.3
|
||
iana-token = xsd:string { pattern = "[a-zA-Z0-9-]+" }
|
||
x-name = xsd:string { pattern = "x-[a-zA-Z0-9-]+" }
|
||
|
||
### Section 4: Value types
|
||
#
|
||
# 4.1
|
||
value-text = element text { text }
|
||
value-text-list = value-text+
|
||
|
||
# 4.2
|
||
value-uri = element uri { xsd:anyURI }
|
||
|
||
# 4.3.1
|
||
value-date = element date {
|
||
xsd:string { pattern = "\d{8}|\d{4}-\d\d|--\d\d(\d\d)?|---\d\d" }
|
||
}
|
||
|
||
# 4.3.2
|
||
value-time = element time {
|
||
xsd:string { pattern = "(\d\d(\d\d(\d\d)?)?|-\d\d(\d\d?)|--\d\d)"
|
||
~ "(Z|[+\-]\d\d(\d\d)?)?" }
|
||
}
|
||
|
||
# 4.3.3
|
||
value-date-time = element date-time {
|
||
xsd:string { pattern = "(\d{8}|--\d{4}|---\d\d)T\d\d(\d\d(\d\d)?)?"
|
||
~ "(Z|[+\-]\d\d(\d\d)?)?" }
|
||
}
|
||
|
||
# 4.3.4
|
||
value-date-and-or-time = value-date | value-date-time | value-time
|
||
|
||
# 4.3.5
|
||
value-timestamp = element timestamp {
|
||
xsd:string { pattern = "\d{8}T\d{6}(Z|[+\-]\d\d(\d\d)?)?" }
|
||
}
|
||
|
||
# 4.4
|
||
value-boolean = element boolean { xsd:boolean }
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 14]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 4.5
|
||
value-integer = element integer { xsd:integer }
|
||
|
||
# 4.6
|
||
value-float = element float { xsd:float }
|
||
|
||
# 4.7
|
||
value-utc-offset = element utc-offset {
|
||
xsd:string { pattern = "[+\-]\d\d(\d\d)?" }
|
||
}
|
||
|
||
# 4.8
|
||
value-language-tag = element language-tag {
|
||
xsd:string { pattern = "([a-z]{2,3}((-[a-z]{3}){0,3})?|[a-z]{4,8})"
|
||
~ "(-[a-z]{4})?(-([a-z]{2}|\d{3}))?"
|
||
~ "(-([0-9a-z]{5,8}|\d[0-9a-z]{3}))*"
|
||
~ "(-[0-9a-wyz](-[0-9a-z]{2,8})+)*"
|
||
~ "(-x(-[0-9a-z]{1,8})+)?|x(-[0-9a-z]{1,8})+|"
|
||
~ "[a-z]{1,3}(-[0-9a-z]{2,8}){1,2}" }
|
||
}
|
||
|
||
### Section 5: Parameters
|
||
#
|
||
# 5.1
|
||
param-language = element language { value-language-tag }?
|
||
|
||
# 5.2
|
||
param-pref = element pref {
|
||
element integer {
|
||
xsd:integer { minInclusive = "1" maxInclusive = "100" }
|
||
}
|
||
}?
|
||
|
||
# 5.4
|
||
param-altid = element altid { value-text }?
|
||
|
||
# 5.5
|
||
param-pid = element pid {
|
||
element text { xsd:string { pattern = "\d+(\.\d+)?" } }+
|
||
}?
|
||
|
||
# 5.6
|
||
param-type = element type { element text { "work" | "home" }+ }?
|
||
|
||
# 5.7
|
||
param-mediatype = element mediatype { value-text }?
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 15]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 5.8
|
||
param-calscale = element calscale { element text { "gregorian" } }?
|
||
|
||
# 5.9
|
||
param-sort-as = element sort-as { value-text+ }?
|
||
|
||
# 5.10
|
||
param-geo = element geo { value-uri }?
|
||
|
||
# 5.11
|
||
param-tz = element tz { value-text | value-uri }?
|
||
|
||
### Section 6: Properties
|
||
#
|
||
# 6.1.3
|
||
property-source = element source {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-mediatype },
|
||
value-uri
|
||
}
|
||
|
||
# 6.1.4
|
||
property-kind = element kind {
|
||
element text { "individual" | "group" | "org" | "location" |
|
||
x-name | iana-token }*
|
||
}
|
||
|
||
# 6.2.1
|
||
property-fn = element fn {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type }?,
|
||
value-text
|
||
}
|
||
|
||
# 6.2.2
|
||
property-n = element n {
|
||
element parameters { param-language, param-sort-as, param-altid }?,
|
||
element surname { text }+,
|
||
element given { text }+,
|
||
element additional { text }+,
|
||
element prefix { text }+,
|
||
element suffix { text }+
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 16]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 6.2.3
|
||
property-nickname = element nickname {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type }?,
|
||
value-text-list
|
||
}
|
||
|
||
# 6.2.4
|
||
property-photo = element photo {
|
||
element parameters { param-altid, param-pid, param-pref, param-type,
|
||
param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.2.5
|
||
property-bday = element bday {
|
||
element parameters { param-altid, param-calscale }?,
|
||
(value-date-and-or-time | value-text)
|
||
}
|
||
|
||
# 6.2.6
|
||
property-anniversary = element anniversary {
|
||
element parameters { param-altid, param-calscale }?,
|
||
(value-date-and-or-time | value-text)
|
||
}
|
||
|
||
# 6.2.7
|
||
property-gender = element gender {
|
||
element sex { "" | "M" | "F" | "O" | "N" | "U" },
|
||
element identity { text }?
|
||
}
|
||
|
||
# 6.3.1
|
||
param-label = element label { value-text }?
|
||
property-adr = element adr {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type, param-geo, param-tz,
|
||
param-label }?,
|
||
element pobox { text }+,
|
||
element ext { text }+,
|
||
element street { text }+,
|
||
element locality { text }+,
|
||
element region { text }+,
|
||
element code { text }+,
|
||
element country { text }+
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 17]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 6.4.1
|
||
property-tel = element tel {
|
||
element parameters {
|
||
param-altid,
|
||
param-pid,
|
||
param-pref,
|
||
element type {
|
||
element text { "work" | "home" | "text" | "voice"
|
||
| "fax" | "cell" | "video" | "pager"
|
||
| "textphone" }+
|
||
}?,
|
||
param-mediatype
|
||
}?,
|
||
(value-text | value-uri)
|
||
}
|
||
|
||
# 6.4.2
|
||
property-email = element email {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type }?,
|
||
value-text
|
||
}
|
||
|
||
# 6.4.3
|
||
property-impp = element impp {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.4.4
|
||
property-lang = element lang {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type }?,
|
||
value-language-tag
|
||
}
|
||
|
||
# 6.5.1
|
||
property-tz = element tz {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
(value-text | value-uri | value-utc-offset)
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 18]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 6.5.2
|
||
property-geo = element geo {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.6.1
|
||
property-title = element title {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type }?,
|
||
value-text
|
||
}
|
||
|
||
# 6.6.2
|
||
property-role = element role {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type }?,
|
||
value-text
|
||
}
|
||
|
||
# 6.6.3
|
||
property-logo = element logo {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.6.4
|
||
property-org = element org {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type, param-sort-as }?,
|
||
value-text-list
|
||
}
|
||
|
||
# 6.6.5
|
||
property-member = element member {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 19]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 6.6.6
|
||
property-related = element related {
|
||
element parameters {
|
||
param-altid,
|
||
param-pid,
|
||
param-pref,
|
||
element type {
|
||
element text {
|
||
"work" | "home" | "contact" | "acquaintance" |
|
||
"friend" | "met" | "co-worker" | "colleague" | "co-resident" |
|
||
"neighbor" | "child" | "parent" | "sibling" | "spouse" |
|
||
"kin" | "muse" | "crush" | "date" | "sweetheart" | "me" |
|
||
"agent" | "emergency"
|
||
}+
|
||
}?,
|
||
param-mediatype
|
||
}?,
|
||
(value-uri | value-text)
|
||
}
|
||
|
||
# 6.7.1
|
||
property-categories = element categories {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type }?,
|
||
value-text-list
|
||
}
|
||
|
||
# 6.7.2
|
||
property-note = element note {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type }?,
|
||
value-text
|
||
}
|
||
|
||
# 6.7.3
|
||
property-prodid = element prodid { value-text }
|
||
|
||
# 6.7.4
|
||
property-rev = element rev { value-timestamp }
|
||
|
||
# 6.7.5
|
||
property-sound = element sound {
|
||
element parameters { param-language, param-altid, param-pid,
|
||
param-pref, param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 20]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# 6.7.6
|
||
property-uid = element uid { value-uri }
|
||
|
||
# 6.7.7
|
||
property-clientpidmap = element clientpidmap {
|
||
element sourceid { xsd:positiveInteger },
|
||
value-uri
|
||
}
|
||
|
||
# 6.7.8
|
||
property-url = element url {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.8.1
|
||
property-key = element key {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
(value-uri | value-text)
|
||
}
|
||
|
||
# 6.9.1
|
||
property-fburl = element fburl {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.9.2
|
||
property-caladruri = element caladruri {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
# 6.9.3
|
||
property-caluri = element caluri {
|
||
element parameters { param-altid, param-pid, param-pref,
|
||
param-type, param-mediatype }?,
|
||
value-uri
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 21]
|
||
|
||
RFC 6351 xCard August 2011
|
||
|
||
|
||
# Top-level grammar
|
||
property = property-adr | property-anniversary | property-bday
|
||
| property-caladruri | property-caluri | property-categories
|
||
| property-clientpidmap | property-email | property-fburl
|
||
| property-fn | property-geo | property-impp | property-key
|
||
| property-kind | property-lang | property-logo
|
||
| property-member | property-n | property-nickname
|
||
| property-note | property-org | property-photo
|
||
| property-prodid | property-related | property-rev
|
||
| property-role | property-gender | property-sound
|
||
| property-source | property-tel | property-title
|
||
| property-tz | property-uid | property-url
|
||
start = element vcards {
|
||
element vcard {
|
||
(property
|
||
| element group {
|
||
attribute name { text },
|
||
property*
|
||
})+
|
||
}+
|
||
}
|
||
|
||
Author's Address
|
||
|
||
Simon Perreault
|
||
Viagenie
|
||
2600 boul. Laurier, Suite 625
|
||
Quebec, QC G1V 4W1
|
||
Canada
|
||
|
||
Phone: +1 418 656 9254
|
||
EMail: simon.perreault@viagenie.ca
|
||
URI: http://www.viagenie.ca
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Perreault Standards Track [Page 22]
|
||
|