rfc9553.original   rfc9553.txt 
Calendaring Extensions R. Stepanek Internet Engineering Task Force (IETF) R. Stepanek
Internet-Draft Fastmail Request for Comments: 9553 Fastmail
Intended status: Standards Track M. Loffredo Category: Standards Track M. Loffredo
Expires: 12 May 2024 IIT-CNR ISSN: 2070-1721 IIT-CNR
9 November 2023 March 2024
JSContact: A JSON representation of contact data JSContact: A JSON Representation of Contact Data
draft-ietf-calext-jscontact-16
Abstract Abstract
This specification defines a data model and JSON representation of This specification defines a data model and JavaScript Object
contact card information that can be used for data storage and Notation (JSON) representation of contact card information that can
exchange in address book or directory applications. It aims to be an be used for data storage and exchange in address book or directory
alternative to the vCard data format and to be unambiguous, applications. It aims to be an alternative to the vCard data format
extendable and simple to process. In contrast to the JSON-based and to be unambiguous, extendable, and simple to process. In
jCard format, it is not a direct mapping from the vCard data model contrast to the JSON-based jCard format, it is not a direct mapping
and expands semantics where appropriate. from the vCard data model and expands semantics where appropriate.
Two additional specifications define new vCard elements and how to
convert between JSContact and vCard.
Status of This Memo Status of This Memo
This Internet-Draft is submitted in full conformance with the This is an Internet Standards Track document.
provisions of BCP 78 and BCP 79.
Internet-Drafts are working documents of the Internet Engineering
Task Force (IETF). Note that other groups may also distribute
working documents as Internet-Drafts. The list of current Internet-
Drafts is at https://datatracker.ietf.org/drafts/current/.
Internet-Drafts are draft documents valid for a maximum of six months This document is a product of the Internet Engineering Task Force
and may be updated, replaced, or obsoleted by other documents at any (IETF). It represents the consensus of the IETF community. It has
time. It is inappropriate to use Internet-Drafts as reference received public review and has been approved for publication by the
material or to cite them other than as "work in progress." Internet Engineering Steering Group (IESG). Further information on
Internet Standards is available in Section 2 of RFC 7841.
This Internet-Draft will expire on 12 May 2024. Information about the current status of this document, any errata,
and how to provide feedback on it may be obtained at
https://www.rfc-editor.org/info/rfc9553.
Copyright Notice Copyright Notice
Copyright (c) 2023 IETF Trust and the persons identified as the Copyright (c) 2024 IETF Trust and the persons identified as the
document authors. All rights reserved. document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal This document is subject to BCP 78 and the IETF Trust's Legal
Provisions Relating to IETF Documents (https://trustee.ietf.org/ Provisions Relating to IETF Documents
license-info) in effect on the date of publication of this document. (https://trustee.ietf.org/license-info) in effect on the date of
Please review these documents carefully, as they describe your rights publication of this document. Please review these documents
and restrictions with respect to this document. Code Components carefully, as they describe your rights and restrictions with respect
extracted from this document must include Revised BSD License text as to this document. Code Components extracted from this document must
described in Section 4.e of the Trust Legal Provisions and are include Revised BSD License text as described in Section 4.e of the
provided without warranty as described in the Revised BSD License. Trust Legal Provisions and are provided without warranty as described
in the Revised BSD License.
Table of Contents Table of Contents
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 4 1. Introduction
1.1. Motivation and Relation to vCard, jCard and xCard . . . . 5 1.1. Motivation and Relation to vCard, jCard, and xCard
1.2. Notational Conventions . . . . . . . . . . . . . . . . . 5 1.2. Notational Conventions
1.3. Data Type Notations . . . . . . . . . . . . . . . . . . . 6 1.3. Data Type Notations
1.3.1. Objects and Properties . . . . . . . . . . . . . . . 6 1.3.1. Objects and Properties
1.3.2. Type Signatures . . . . . . . . . . . . . . . . . . . 7 1.3.2. Type Signatures
1.3.3. Property Attributes . . . . . . . . . . . . . . . . . 7 1.3.3. Property Attributes
1.3.4. The @type Property . . . . . . . . . . . . . . . . . 8 1.3.4. The @type Property
1.4. Common Data Types . . . . . . . . . . . . . . . . . . . . 8 1.4. Common Data Types
1.4.1. Id . . . . . . . . . . . . . . . . . . . . . . . . . 9 1.4.1. Id
1.4.2. Int and UnsignedInt . . . . . . . . . . . . . . . . . 9 1.4.2. Int and UnsignedInt
1.4.3. PatchObject . . . . . . . . . . . . . . . . . . . . . 9 1.4.3. PatchObject
1.4.4. Resource . . . . . . . . . . . . . . . . . . . . . . 10 1.4.4. Resource
1.4.5. UTCDateTime . . . . . . . . . . . . . . . . . . . . . 11 1.4.5. UTCDateTime
1.5. Common Properties . . . . . . . . . . . . . . . . . . . . 12 1.5. Common Properties
1.5.1. contexts . . . . . . . . . . . . . . . . . . . . . . 12 1.5.1. contexts
1.5.2. extra . . . . . . . . . . . . . . . . . . . . . . . . 12 1.5.2. label
1.5.3. label . . . . . . . . . . . . . . . . . . . . . . . . 12 1.5.3. pref
1.5.4. pref . . . . . . . . . . . . . . . . . . . . . . . . 13 1.5.4. phonetic
1.5.5. phonetic . . . . . . . . . . . . . . . . . . . . . . 13 1.6. Internationalization
1.6. Internationalization . . . . . . . . . . . . . . . . . . 14 1.6.1. Free-Form Text
1.6.1. Free-form text . . . . . . . . . . . . . . . . . . . 14 1.6.2. URIs
1.6.2. URIs . . . . . . . . . . . . . . . . . . . . . . . . 15 1.7. Validating JSContact
1.7. Validating JSContact . . . . . . . . . . . . . . . . . . 15 1.7.1. Case-Sensitivity
1.7.1. Case-Sensitivity . . . . . . . . . . . . . . . . . . 15 1.7.2. IANA-Registered Properties
1.7.2. IANA-registered Properties . . . . . . . . . . . . . 16 1.7.3. Reserved Properties
1.7.3. Unknown Properties . . . . . . . . . . . . . . . . . 16 1.7.4. Unknown Properties
1.7.4. Enumerated Values . . . . . . . . . . . . . . . . . . 16 1.7.5. Enumerated Values
1.8. Vendor-Specific Extensions . . . . . . . . . . . . . . . 17 1.8. Vendor-Specific Extensions
1.8.1. Vendor-specific Properties . . . . . . . . . . . . . 17 1.8.1. Vendor-Specific Properties
1.8.2. Vendor-specific Values . . . . . . . . . . . . . . . 18 1.8.2. Vendor-Specific Values
1.9. Versioning . . . . . . . . . . . . . . . . . . . . . . . 19 1.9. Versioning
1.9.1. Version Format and Requirements . . . . . . . . . . . 19 1.9.1. Version Format and Requirements
1.9.2. Current Version . . . . . . . . . . . . . . . . . . . 19 1.9.2. Current Version
2. Card . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 2. Card
2.1. Metadata Properties . . . . . . . . . . . . . . . . . . . 20 2.1. Metadata Properties
2.1.1. @type . . . . . . . . . . . . . . . . . . . . . . . . 20 2.1.1. @type
2.1.2. version . . . . . . . . . . . . . . . . . . . . . . . 20 2.1.2. version
2.1.3. created . . . . . . . . . . . . . . . . . . . . . . . 20 2.1.3. created
2.1.4. kind . . . . . . . . . . . . . . . . . . . . . . . . 21 2.1.4. kind
2.1.5. language . . . . . . . . . . . . . . . . . . . . . . 21 2.1.5. language
2.1.6. members . . . . . . . . . . . . . . . . . . . . . . . 21 2.1.6. members
2.1.7. prodId . . . . . . . . . . . . . . . . . . . . . . . 22 2.1.7. prodId
2.1.8. relatedTo . . . . . . . . . . . . . . . . . . . . . . 22 2.1.8. relatedTo
2.1.9. uid . . . . . . . . . . . . . . . . . . . . . . . . . 24 2.1.9. uid
2.1.10. updated . . . . . . . . . . . . . . . . . . . . . . . 24 2.1.10. updated
2.2. Name and Organization Properties . . . . . . . . . . . . 25 2.2. Name and Organization Properties
2.2.1. name . . . . . . . . . . . . . . . . . . . . . . . . 25 2.2.1. name
2.2.2. organizations . . . . . . . . . . . . . . . . . . . . 30 2.2.2. nicknames
2.2.3. speakToAs . . . . . . . . . . . . . . . . . . . . . . 31 2.2.3. organizations
2.2.4. titles . . . . . . . . . . . . . . . . . . . . . . . 32 2.2.4. speakToAs
2.3. Contact Properties . . . . . . . . . . . . . . . . . . . 33 2.2.5. titles
2.3.1. emails . . . . . . . . . . . . . . . . . . . . . . . 33 2.3. Contact Properties
2.3.2. onlineServices . . . . . . . . . . . . . . . . . . . 34 2.3.1. emails
2.3.3. phones . . . . . . . . . . . . . . . . . . . . . . . 35 2.3.2. onlineServices
2.3.4. preferredLanguages . . . . . . . . . . . . . . . . . 37 2.3.3. phones
2.4. Calendaring and Scheduling Properties . . . . . . . . . . 38 2.3.4. preferredLanguages
2.4.1. calendars . . . . . . . . . . . . . . . . . . . . . . 38 2.4. Calendaring and Scheduling Properties
2.4.2. schedulingAddresses . . . . . . . . . . . . . . . . . 38 2.4.1. calendars
2.5. Address and Location Properties . . . . . . . . . . . . . 39 2.4.2. schedulingAddresses
2.5.1. addresses . . . . . . . . . . . . . . . . . . . . . . 39 2.5. Address and Location Properties
2.6. Resource Properties . . . . . . . . . . . . . . . . . . . 44 2.5.1. addresses
2.6.1. cryptoKeys . . . . . . . . . . . . . . . . . . . . . 45 2.6. Resource Properties
2.6.2. directories . . . . . . . . . . . . . . . . . . . . . 45 2.6.1. cryptoKeys
2.6.3. links . . . . . . . . . . . . . . . . . . . . . . . . 46 2.6.2. directories
2.6.4. media . . . . . . . . . . . . . . . . . . . . . . . . 47 2.6.3. links
2.7. Multilingual Properties . . . . . . . . . . . . . . . . . 48 2.6.4. media
2.7.1. localizations . . . . . . . . . . . . . . . . . . . . 48 2.7. Multilingual Properties
2.8. Additional Properties . . . . . . . . . . . . . . . . . . 50 2.7.1. localizations
2.8.1. anniversaries . . . . . . . . . . . . . . . . . . . . 50 2.8. Additional Properties
2.8.2. keywords . . . . . . . . . . . . . . . . . . . . . . 52 2.8.1. anniversaries
2.8.3. notes . . . . . . . . . . . . . . . . . . . . . . . . 52 2.8.2. keywords
2.8.4. personalInfo . . . . . . . . . . . . . . . . . . . . 53 2.8.3. notes
3. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 54 2.8.4. personalInfo
3.1. Media Type Registration . . . . . . . . . . . . . . . . . 54 3. IANA Considerations
3.2. Creation of the "JSContact" Registry Group . . . . . . . 56 3.1. Media Type Registration
3.3. Registry Policy and Change Procedures . . . . . . . . . . 56 3.2. Creation of the JSContact Registry Group
3.3.1. Preliminary Community Review . . . . . . . . . . . . 57 3.3. Registry Policy and Change Procedures
3.3.2. Submit Request to IANA . . . . . . . . . . . . . . . 57 3.3.1. Preliminary Community Review
3.3.3. Designated Expert Review . . . . . . . . . . . . . . 57 3.3.2. Submit Request to IANA
3.3.4. Change Procedures . . . . . . . . . . . . . . . . . . 58 3.3.3. Designated Expert Review
3.4. Creation of the "JSContact Version" Registry . . . . . . 58 3.3.4. Change Procedures
3.4.1. "JSContact Version" Registry Template . . . . . . . . 58 3.4. Creation of the JSContact Version Registry
3.4.2. Initial Contents for the "JSContact Version" 3.4.1. JSContact Version Registry Template
Registry . . . . . . . . . . . . . . . . . . . . . . 59 3.4.2. Initial Contents of the JSContact Version Registry
3.5. Creation of the JSContact Properties Registry
3.5. Creation of the "JSContact Properties" Registry . . . . . 59 3.5.1. JSContact Properties Registry Template
3.5.1. "JSContact Properties" Registry Template . . . . . . 59 3.5.2. Initial Contents of the JSContact Properties Registry
3.5.2. Initial Contents for the "JSContact Properties" 3.6. Creation of the JSContact Types Registry
Registry . . . . . . . . . . . . . . . . . . . . . . 60 3.6.1. JSContact Types Registry Template
3.6. Creation of the "JSContact Types" Registry . . . . . . . 69 3.6.2. Initial Contents of the JSContact Types Registry
3.6.1. "JSContact Types" Registry Template . . . . . . . . . 69 3.7. Creation of the JSContact Enum Values Registry
3.6.2. Initial Contents for the "JSContact Types" 3.7.1. JSContact Enum Values Registry Property Template
Registry . . . . . . . . . . . . . . . . . . . . . . 70 3.7.2. JSContact Enum Values Registry Value Template
3.7. Creation of the "JSContact Enum Values" Registry . . . . 72 3.7.3. Initial Contents of the JSContact Enum Values Registry
3.7.1. "JSContact Enum Values" Registry Property Template . 72 4. Security Considerations
3.7.2. "JSContact Enum Values" Registry Value Template . . . 73 4.1. JSON Parsing
3.7.3. Initial Contents for the "JSContact Enum Values" 4.2. URI Values
Registry . . . . . . . . . . . . . . . . . . . . . . 73 5. References
4. Security Considerations . . . . . . . . . . . . . . . . . . . 82 5.1. Normative References
4.1. JSON Parsing . . . . . . . . . . . . . . . . . . . . . . 82 5.2. Informative References
4.2. URI Values . . . . . . . . . . . . . . . . . . . . . . . 83 Authors' Addresses
5. References . . . . . . . . . . . . . . . . . . . . . . . . . 83
5.1. Normative References . . . . . . . . . . . . . . . . . . 83
5.2. Informative References . . . . . . . . . . . . . . . . . 85
Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . 87
1. Introduction 1. Introduction
This document defines a data model for contact card data normally This document defines a data model for contact card data normally
used in address book or directory applications and services. It aims used in address book or directory applications and services. It aims
to be an alternative to the vCard data format [RFC6350]. to be an alternative to the vCard data format [RFC6350].
The key design considerations for this data model are as follows: The key design considerations for this data model are as follows:
* The data model and set of attributes should mostly be compatible * The data model and set of attributes should be mostly compatible
with the one defined for the vCard data format [RFC6350] and with the model defined for the vCard data format [RFC6350] and
extensions ([RFC6473], [RFC6474], [RFC6715], [RFC6869], extensions [RFC6473] [RFC6474] [RFC6715] [RFC6869] [RFC8605]. The
[RFC8605]). The specification should add new attributes or value specification should add new attributes or value types where
types where appropriate. Not all existing vCard definitions need appropriate. Not all existing vCard definitions need an
an equivalent in JSContact, especially if the vCard definition is equivalent in JSContact, especially if the vCard definition is
considered to be obsolete or otherwise inappropriate. Conversion considered to be obsolete or otherwise inappropriate. Conversion
between the data formats need not fully preserve semantic meaning. between the data formats need not fully preserve semantic meaning.
* The attributes of the card data represented must be described as * The attributes of the card data must be described as simple key-
simple key-value pairs, reducing complexity of their value pairs to reduce the complexity of the representation of the
representation. card data.
* The data model should avoid all ambiguities and make it difficult * The data model should avoid all ambiguities and make it difficult
to make mistakes during implementation. to make mistakes during implementation.
* Extensions, such as new properties and components, MUST NOT lead * Extensions, such as new properties and components, MUST NOT lead
to requiring an update to this document. to a required update of this document.
The representation of this data model is defined in the I-JSON format The representation of this data model is defined in the Internet JSON
[RFC7493], which is a strict subset of the JavaScript Object Notation (I-JSON) format [RFC7493], which is a strict subset of the JSON data
(JSON) Data Interchange Format [RFC8259]. Using JSON is mostly a interchange format [RFC8259]. Using JSON is mostly a pragmatic
pragmatic choice: its widespread use makes JSContact easier to adopt, choice: its widespread use makes JSContact easier to adopt, and the
and the availability of production-ready JSON implementations availability of production-ready JSON implementations eliminates a
eliminates a whole category of parser-related interoperability whole category of parser-related interoperability issues.
issues.
1.1. Motivation and Relation to vCard, jCard and xCard 1.1. Motivation and Relation to vCard, jCard, and xCard
The vCard data format [RFC6350] is an interchange format for contacts The vCard data format [RFC6350] is an interchange format for contacts
data between address book service providers and vendors. However, data between address book service providers and vendors. However,
this format has gone through multiple specifications iterations with this format has gone through multiple specification iterations with
only a subset of its deprecated version 3 [RFC2426] being widely in only a subset of its deprecated version 3 [RFC2426] being widely in
use. Consequently, products and services internally use a richer use. Consequently, products and services use an internal contact
contact data model than they expose when serializing that information data model that is richer than what they expose when serializing that
to vCard. In addition, service providers often use a proprietary information to vCard. In addition, service providers often use a
JSON representation of contact data in their APIs. proprietary JSON representation of contact data in their APIs.
JSContact provides a standard JSON-based data model and JSContact provides a standard JSON-based data model and
representation of contact data as an alternative to proprietary representation of contact data as an alternative to proprietary
formats. formats.
While writing this document, several features missing in vCard were At the time of writing this document, several missing features in
brought to the attention of the authors, such as social media vCard were brought to the attention of the authors such as social
contacts, gender pronouns and others. This highlights how vCard is media contacts, gender pronouns, and others. This highlights how
not perceived as an evolving format and consequently hasn't been vCard is not perceived as an evolving format and, consequently,
updated since close to ten years. JSContact addresses these unmet hasn't been updated for about ten years. JSContact addresses these
demands and defines new vCard properties and parameters to allow unmet demands and defines new vCard properties and parameters to
interchanging them in both formats. allow interchanging them in both formats.
Two additional documents define the relation of JSContact and vCard:
[RFC9554] defines new vCard properties and parameters, and [RFC9555]
defines how to convert JSContact data from and to vCard.
The xCard [RFC6351] and jCard [RFC7095] specifications define The xCard [RFC6351] and jCard [RFC7095] specifications define
alternative representations for vCard data, in XML and JSON format alternative representations for vCard data in XML and JSON formats,
respectively. Both explicitly aim to not change the underlying data respectively. Both explicitly aim to not change the underlying data
model. Accordingly, they are regarded as equal to vCard in the model. Accordingly, they are regarded as equal to vCard in the
context of this document. context of this document.
1.2. Notational Conventions 1.2. Notational Conventions
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
"OPTIONAL" in this document are to be interpreted as described in "OPTIONAL" in this document are to be interpreted as described in BCP
BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all 14 [RFC2119] [RFC8174] when, and only when, they appear in all
capitals, as shown here. capitals, as shown here.
The ABNF definitions in this document use the notations of [RFC5234]. The ABNF definitions in this document use the notations of [RFC5234].
ABNF rules not defined in this document either are defined in ABNF rules not defined in this document are defined in either
[RFC5234] (such as the ABNF for CRLF, WSP, DQUOTE, VCHAR, ALPHA, and [RFC5234] (such as the ABNF for CRLF, WSP, DQUOTE, VCHAR, ALPHA, and
DIGIT) or [RFC6350]. DIGIT) or [RFC6350].
1.3. Data Type Notations 1.3. Data Type Notations
This section introduces the notations and terminology used to define This section introduces the notations and terminology used to define
data types in JSContact. data types in JSContact.
The underlying format for JSContact is JSON and so also its data The underlying format for JSContact is JSON, so its data types also
types build on JSON values. The terms "object" and "array" as well build on JSON values. The terms "object" and "array" as well as the
as the four primitive types ("strings", "numbers", "booleans", and four primitive types ("strings", "numbers", "booleans", and "null")
"null") are to be interpreted as described in Section 1 of [RFC8259]. are to be interpreted as described in Section 1 of [RFC8259]. All
All JSContact data MUST be valid according to the constraints given JSContact data MUST be valid according to the constraints given in
in I-JSON [RFC7493]. Unless otherwise noted, all member names in I-JSON [RFC7493]. Unless otherwise noted, all member names in JSON
JSON objects and all string values are case-sensitive. Within objects and all string values are case-sensitive. Within the context
context of JSON objects, the term "key" is synonymous with "member of JSON objects, the term "key" is synonymous with "member name" as
name" as defined in Section 1 of [RFC8259]. defined in Section 1 of [RFC8259].
1.3.1. Objects and Properties 1.3.1. Objects and Properties
JSContact defines data types for contact information such as JSContact defines data types for contact information such as
addresses or names. This information typically consists of multiple addresses or names. This information typically consists of multiple
related elements, for example a personal name and surname together related elements; for example, a personal name and surname together
form a name. These related elements are organized in JSContact form a name. These related elements are organized in JSContact
objects. A JSContact object is a JSON object which: objects. A JSContact object is a JSON object that has the following:
1. Has a unique type name registered in the IANA JSContact Types 1. A unique type name registered in the IANA "JSContact Types"
Registry (Section 3.6). registry (Section 3.6).
2. Has one or more object members for which the name and allowed 2. One or more object members for which the name and allowed value
value types are specified. Such members are called "properties". types are specified. Such members are called "properties".
3. Has one property named @type with a string value that matches the 3. One property named @type with a string value that matches the
type name of this JSContact object. In general, this property type name of the JSContact object. In general, this property
does not need to be set explicitly as outlined in Section 1.3.4. does not need to be set explicitly as outlined in Section 1.3.4.
The following sections specify how to define JSContact object types. The following sections specify how to define JSContact object types.
Section 1.7 and Section 1.8 then define the exact requirements for Sections 1.7 and 1.8 then define the exact requirements for property
property names. names.
The next paragraph illustrates how a JSContact object is defined: The next paragraph illustrates how a JSContact object is defined.
The names "Foo" and "baz" are only for demonstration and have no
meaning outside the example.
| A Foo object has the following properties: A Foo object has the following properties:
|
| * qux: Number (mandatory). Defines the qux-ishness of this
| contact. The value MUST be an integer greater than 0 and less
| than 10.
Here, a JSContact object type named Foo is defined. In addition to @type: String. The JSContact type of the object. The value MUST
its @type property it has a property named qux for which values MUST be "Foo", if set.
be valid according to the definition of the Number type. The
property has one attribute, mandatory, which specifies that the baz: Number (mandatory). The baz level of the contact. The value
property MUST be present for an instance of this JSContact object to MUST be an integer greater than 0 and less than 10.
be valid. Finally, a free-text description describes the semantics
and further restrictions. The above paragraph illustrates the following:
* It defines a JSContact object type named "Foo" that has two
properties, named "@type" and "baz".
* The @type property adheres to the rules outlined in Section 1.3.4.
Because of this, it is neither defined to be mandatory nor
optional, as this depends on how the Foo object type is used.
* The baz property value MUST be valid according to the definition
of the Number type.
* The property has one attribute, "mandatory", which specifies that
the property MUST be present for a value of the Foo object type to
be valid.
* The free-text description of the baz property describes the
semantics and further restrictions for its values.
1.3.2. Type Signatures 1.3.2. Type Signatures
Type signatures are given for all JSON values and JSContact Type signatures are given for all JSON values and JSContact
definitions in this document. The following conventions are used: definitions in this document. The following conventions are used:
* String - The JSON string type. String: The JSON string type.
* Number - The JSON number type. Number: The JSON number type.
* Boolean - The JSON boolean type. Boolean: The JSON boolean type.
* A[B] - A JSON object where the keys are all of the type A, and the A[B]: A JSON object where all keys are of type A and all values are
values are all of the type B. of type B.
* A[] - A JSON array of values of type A. A[]: A JSON array of values of type A.
* A|B - The value is either of type A or of type B. A|B: The value is either of type A or of type B.
* * - The type is undefined (the value could be any type, although *: The type is undefined (the value could be any type, although
permitted values may be constrained by the context of this value). permitted values may be constrained by the context of this value).
Section 1.4 defines common data types, including signed or unsigned Section 1.4 defines common data types, including signed or unsigned
integers and dates. integers and dates.
1.3.3. Property Attributes 1.3.3. Property Attributes
Object properties may also have a set of attributes defined along Object properties may also have a set of attributes defined along
with the type signature. These have the following meanings: with the type signature. These have the following meanings:
* mandatory: The property MUST be set for an instance of this object mandatory: The property MUST be set for an instance of this object
to be valid. to be valid.
* optional: The property can but not need be set for an instance of optional: The property can, but need not, be set for an instance of
this object to be valid. this object to be valid.
* default: This is followed by a JSON value. That value will be default: This is followed by a JSON value. That value will be used
used for this property if it is omitted. for this property if it is omitted.
* defaultType: This is followed by the name of a JSContact object defaultType: This is followed by the name of a JSContact object
type. A property value of JSContact object type is expected to be type. A property value of JSContact object type is expected to be
of this named type, in case it omits the @type property. of this named type, in case it omits the @type property.
1.3.4. The @type Property 1.3.4. The @type Property
This property is defined as: @type: String. The JSContact type of a JSON object. It MUST match
the type name of the JSContact object of which the JSON object is
* @type: String. Specifies the type of this object. This MUST an instance of.
match the type name of the JSContact object of which this JSON
object is an instance of.
The purpose of this property is to help implementations identify The purpose of the @type property is to help implementations identify
which JSContact object type a given JSON object represents. which JSContact object type a given JSON object represents.
Implementations MUST validate that JSON objects with this property Implementations MUST validate that JSON objects with this property
conform to the specification of the JSContact object type of that conform to the specification of the JSContact object type of that
name. name.
In many cases the @type property value is implied by where its object In many cases, the @type property value is implied by where its
occurs in JSContact data. Assuming that both A and B are JSContact object occurs in JSContact data. Assuming that both A and B are
object types: JSContact object types:
* An object that is set as the value for a property with type * An object that is set as the value for a property with type
signature A MAY have the @type property set. If the @type signature "A" MAY have the @type property set. If the @type
property is not set then its value is implied to be A by the property is not set, then its value is implied to be A by the
property definition. property definition.
* An object that is set as the value for a property with type * An object that is set as the value for a property with type
signature A|B (defaultType: A) MAY have the @type property set if signature "A|B (defaultType: A)" MAY have the @type property set
it is an instance of A. It MUST have the @type property set if it if it is an instance of A. It MUST have the @type property set if
is an instance of B. If instead the defaultType attribute is not it is an instance of B. If, instead, the defaultType attribute is
defined then the @type property MUST also be set for A. not defined, then the @type property MUST also be set for A.
* An object that is not the value of a property, such as the root of * An object that is not the value of a property, such as the topmost
JSON data (directly or as member of an array), MUST have the @type object in JSON data (directly or as a member of an array), MUST
property set. have the @type property set.
1.4. Common Data Types 1.4. Common Data Types
In addition to the standard JSON data types, a couple of additional In addition to the standard JSON data types, a couple of additional
data types are common to the definitions of JSContact objects and data types are common to the definitions of JSContact objects and
properties. properties.
1.4.1. Id 1.4.1. Id
Where Id is given as a data type, it means a String of at least 1 and Where "Id" is given as a data type, it means a String of at least 1
a maximum of 255 octets in size, and it MUST only contain characters and a maximum of 255 octets in size, and it MUST only contain
from the URL and Filename Safe base64url alphabet, as defined in characters from the "URL and Filename Safe" base64url alphabet, as
Section 5 of [RFC4648], excluding the pad character (=). This means defined in Section 5 of [RFC4648], excluding the pad character ("=").
the allowed characters are the ASCII alphanumeric characters (A-Za- This means the allowed characters are the ASCII alphanumeric
z0-9), hyphen (-), and underscore (_). characters ("A-Za-z0-9"), hyphen ("-"), and underscore ("_").
In many places in JSContact a JSON map is used where the map keys are In many places in JSContact, a JSON map is used where the map keys
of type Id and the map values are all the same type of object. This are of type Id and the map values are all the same type of object.
construction represents an unordered set of objects, with the added This construction represents an unordered set of objects, with the
advantage that each entry has a name (the corresponding map key). added advantage that each entry has a name (the corresponding map
This allows for more concise patching of objects, and, when key). This allows for more concise patching of objects and, when
applicable, for the objects in question to be referenced from other applicable, for the objects in question to be referenced from other
objects within the JSContact object. The map keys MUST be preserved objects within the JSContact object. The map keys MUST be preserved
across multiple versions of the JSContact object. across multiple versions of the JSContact object.
Unless otherwise specified for a particular property, there are no Unless otherwise specified for a particular property, there are no
uniqueness constraints on an Id value (other than, of course, the uniqueness constraints on an Id value (other than, of course, the
requirement that you cannot have two values with the same key within requirement that you cannot have two values with the same key within
a single JSON map). For example, two Card (Section 2) objects might a single JSON map). For example, two Card (Section 2) objects might
use the same Ids in their respective photos properties. Or within use the same Ids in their respective photos properties. Or within
the same Card the same Id could appear in the emails and phones the same Card, the same Id could appear in the emails and phones
properties. These situations do not imply any semantic connections properties. These situations do not imply any semantic connections
among the objects. among the objects.
1.4.2. Int and UnsignedInt 1.4.2. Int and UnsignedInt
Where Int is given as a data type, it means an integer in the range Where "Int" is given as a data type, it means an integer in the range
-2^53+1 <= value <= 2^53-1, the safe range for integers stored in a -2^53+1 <= value <= 2^53-1, which is the safe range for integers
floating-point double, represented as a JSON Number. stored in a floating-point double, represented as a JSON Number.
Where UnsignedInt is given as a data type, it means an integer in the Where "UnsignedInt" is given as a data type, it means an integer in
range 0 <= value <= 2^53-1, represented as a JSON Number. the range 0 <= value <= 2^53-1 represented as a JSON Number.
1.4.3. PatchObject 1.4.3. PatchObject
A PatchObject is of type String[*], and represents an unordered set A PatchObject is of type "String[*]" and represents an unordered set
of patches on a JSON object. Each key is a path represented in a of patches on a JSON object. Each key is a path represented in a
subset of JSON pointer format [RFC6901]. The paths have an implicit subset of the JSON Pointer format [RFC6901]. The paths have an
leading /, so each key is prefixed with / before applying the JSON implicit leading "/", so each key is prefixed with "/" before
pointer evaluation algorithm. applying the JSON Pointer evaluation algorithm.
A patch within a PatchObject is only valid if all the following A patch within a PatchObject is only valid if all the following
conditions apply: conditions apply:
1. The pointer MAY reference inside an array but if the last 1. The pointer MAY reference inside an array, but if the last
reference token in the pointer is an array index, then the patch reference token in the pointer is an array index, then the patch
value MUST NOT be null. The pointer MUST NOT use "-" as an array value MUST NOT be null. The pointer MUST NOT use "-" as an array
index in any of its reference tokens (i.e., you MUST NOT insert/ index in any of its reference tokens (i.e., you MUST NOT insert/
delete from an array, but you MAY replace the contents of its delete from an array, but you MAY replace the contents of its
existing members. To add or remove members, one needs to replace existing members. To add or remove members, one needs to replace
the complete array value). the complete array value).
2. All reference tokens prior to the last (i.e., the value after the 2. All reference tokens prior to the last (i.e., the value after the
final slash) MUST already exist as values in the object being final slash) MUST already exist as values in the object being
patched. If the last reference token is an array index, then a patched. If the last reference token is an array index, then a
member at this index MUST already exist in the referenced array. member at this index MUST already exist in the referenced array.
3. There MUST NOT be two patches in the PatchObject where the 3. There MUST NOT be two patches in the PatchObject where the
pointer of one is the prefix of the pointer of the other, e.g., pointer of one is the prefix of the pointer of the other, e.g.,
addresses/1/city and addresses. "addresses/1/city" and "addresses".
4. The value for the patch MUST be valid for the property being set 4. The value for the patch MUST be valid for the property being set
(of the correct type and obeying any other applicable (of the correct type and obeying any other applicable
restrictions), or if null the property MUST be optional. restrictions), or if null, the property MUST be optional.
The value associated with each pointer determines how to apply that The value associated with each pointer determines how to apply that
patch: patch:
* If null, remove the property from the patched object. If the key * If null, remove the property from the patched object. If the key
is not present in the parent, this is a no-op. is not present in the parent, this is a no-op.
* If non-null, set the value given as the value for this property * If non-null, set the value given as the value for this property
(this may be a replacement or addition to the object being (this may be a replacement or addition to the object being
patched). patched).
A PatchObject does not define its own @type (Section 1.3.4) property. A PatchObject does not define its own @type (Section 1.3.4) property.
Instead, a @type property in a patch MUST be handled as any other Instead, the @type property in a patch MUST be handled as any other
patched property value. patched property value.
Implementations MUST reject in its entirety a PatchObject if any of Implementations MUST reject a PatchObject in its entirety if any of
its patches are invalid. Implementations MUST NOT apply partial its patches are invalid. Implementations MUST NOT apply partial
patches. patches.
1.4.4. Resource 1.4.4. Resource
This data type defines a resource associated with the entity The Resource data type defines a resource associated with the entity
represented by this Card, identified by a URI [RFC3986]. Several represented by the Card, identified by a URI [RFC3986]. Later in
property definitions later in this document refer to the Resource this document, several property definitions refer to the Resource
data type as the basis for their property-specific value types. The type as the basis for their property-specific value types. The
Resource data type defines the properties that are common to all of Resource type defines the properties that are common to all of them.
them. Property definitions making use of Resource MAY define Property definitions making use of Resource MAY define additional
additional properties for their value types. properties for their value types.
The @type property value MUST NOT be Resource, instead it MUST be the A Resource object has the following properties:
name of a concrete resource type (see Section 2.6). A Resource
object has the following properties.
* @type: String. Specifies the type of this resource object. The @type: String. The JSContact type of the object. The value MUST NOT
allowed value is defined in later sections of this document for be "Resource"; instead, the value MUST be the name of a concrete
each concrete resource type (Section 2.6). resource type (see Section 2.6).
* kind: String (optional). The kind of the resource. The allowed kind: String (optional). The kind of the resource. The allowed
values are defined in the property definition that makes use of values are defined in the property definition that makes use of
the Resource type. Some property definitions may change this the Resource type. Some property definitions may change this
property from being optional to mandatory. property from being optional to mandatory.
* uri: String (mandatory). The resource value. This MUST be a uri: String (mandatory). The resource value. This MUST be a _URI_
_URI_ as defined in Section 3 of [RFC3986]. as defined in Section 3 of [RFC3986].
* mediaType: String (optional). Used for URI resource values. mediaType: String (optional). The media type [RFC2046] of the
Provides the media type [RFC2046] of the resource identified by resource identified by the uri property value.
the URI.
* contexts: String[Boolean] (optional). The contexts in which to contexts: String[Boolean] (optional). The contexts in which to use
use this resource. Also see Section 1.5.1. this resource. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this resource in pref: UnsignedInt (optional). The preference of the resource in
relation to other resources. Also see Section 1.5.4. relation to other resources. Also see Section 1.5.3.
* label: String (optional). A custom label for the value, see label: String (optional). A custom label for the value. Also see
Section 1.5.3. Section 1.5.2.
1.4.5. UTCDateTime 1.4.5. UTCDateTime
This is a string in [RFC3339] date-time format, with the further The UTCDateTime type is a String in "date-time" format [RFC3339],
restrictions that any letters MUST be in uppercase, and the time with further restrictions that any letters MUST be in uppercase and
offset MUST be the character Z. Fractional second values MUST NOT be the time offset MUST be the character "Z". Fractional second values
included unless non-zero and MUST NOT have trailing zeros, to ensure MUST NOT be included unless they are non-zero, and they MUST NOT have
there is only a single representation for each date-time. trailing zeros to ensure there is only a single representation for
each date-time.
For example, 2010-10-10T10:10:10.003Z is conformant, but For example, "2010-10-10T10:10:10.003Z" is conformant, but
2010-10-10T10:10:10.000Z is invalid and is correctly encoded as "2010-10-10T10:10:10.000Z" is invalid; the correct encoding is
2010-10-10T10:10:10Z. "2010-10-10T10:10:10Z".
1.5. Common Properties 1.5. Common Properties
Most of the properties in this document are specific to a single Most of the properties in this document are specific to a single
JSContact object type. Such properties are defined along with the JSContact object type. Such properties are defined along with the
respective object type. The properties in this section are common to respective object type. The properties in this section are common to
multiple data types and are defined here to avoid repetition. Note multiple data types and are defined here to avoid repetition. Note
that these properties MUST only be set for a JSContact object if they that these properties MUST only be set for a JSContact object if they
are explicitly mentioned to be allowed for this object type. are explicitly mentioned as allowable for this object type.
1.5.1. contexts 1.5.1. contexts
Type: String[Boolean] contexts: String[Boolean]. The contexts in which to use the contact
information. For example, someone might have distinct phone
This property associates contact information with one or more numbers for work and private contexts and may set the desired
contexts in which it should be used. For example, someone might have context on the respective phone number in the phones
distinct phone numbers for work and private contexts, and may set the (Section 2.3.3) property.
desired context on the respective phone number in the phones
(Section 2.3.3) property.
This section defines common contexts. Additional contexts may be
defined in the properties or data types that make use of this
property. The enumerated (Section 1.7.4) common context values are:
* private: the contact information may be used in a private context.
* work: the contact information may be used in a professional
context.
1.5.2. extra
This is a reserved property name. Implementations MUST NOT set this This section defines common contexts. Additional contexts may be
property in a JSContact object. Any JSContact object including a defined in the properties or data types that make use of this
property with this name MUST be considered invalid. property. The enumerated (Section 1.7.5) common context values
are:
The purpose of this reserved property name is to provide implementors * private: the contact information that may be used in a private
with a name which is certain to never occur as a property name in a context.
JSContact object. Implementations might want to map unknown or
vendor-specific properties to a variable with this name, but this is
implementation-specific.
1.5.3. label * work: the contact information that may be used in a
professional context.
Type: String 1.5.2. label
This property allows associating contact data with user-defined
labels. Such labels may be set for phone numbers, email addresses
and resources. Typically, these labels are displayed along with
their associated contact data in graphical user interfaces. Such
labels best be succinct to properly display on small graphical
interfaces and screens.
1.5.4. pref label: String. The labels associated with the contact data. Such
labels may be set for phone numbers, email addresses, and other
resources. Typically, these labels are displayed along with their
associated contact data in graphical user interfaces. Note that
succinct labels are best for proper display on small graphical
interfaces and screens.
Type: UnsignedInt 1.5.3. pref
This property allows defining a preference order for contact pref: UnsignedInt. A preference order for contact information. For
information. For example, a person may have two email addresses and example, a person may have two email addresses and prefer to be
prefer to be contacted with one of them. contacted with one of them.
Its value MUST be in the range 1 and 100. Lower values correspond to The value MUST be in the range of 1 to 100. Lower values
a higher level of preference, with 1 being most preferred. If no correspond to a higher level of preference, with 1 being most
preference is set, then the contact information MUST be interpreted preferred. If no preference is set, then the contact information
as being least preferred. MUST be interpreted as being least preferred.
Note that the preference only is defined in relation to contact Note that the preference is only defined in relation to contact
information of the same type. For example, the preference orders information of the same type. For example, the preference orders
within emails and phone numbers are independent of each other. within emails and phone numbers are independent of each other.
1.5.5. phonetic 1.5.4. phonetic
This property defines how to pronounce a value in the language The following properties define how to pronounce a value in the
indicated in the Card language (Section 2.1.5) property or the language indicated in the Card language (Section 2.1.5) property or
language tag of its localizations (Section 2.7.1). Exemplary uses the language tag of its localizations (Section 2.7.1). Exemplary
are to define how to pronounce Japanese names, or for romanization of uses of these properties are defining how to pronounce Japanese names
Mandarin or Cantonese name and address components. The properties and romanizing Mandarin or Cantonese name and address components.
are defined as follows: The properties are defined as follows:
* phonetic: String. Contains the phonetic representation of a phonetic: String. The phonetic representation of a value. Any
value. Any script language subtag in the Card language script language subtag in the Card language (Section 2.1.5)
(Section 2.1.5) property MUST be ignored for use with the phonetic property MUST be ignored and not used with the phonetic property.
property. If this property is set, then at least one of the If this property is set, then at least one of the phoneticScript
phoneticScript or phoneticSystem properties that relate to this or phoneticSystem properties that relate to this value MUST be
value MUST be set. set.
* phoneticScript: String. The script used in the value of the phoneticScript: String. The script used in the value of the related
related phonetic property. This MUST be a valid script subtag as phonetic property. This MUST be a valid script subtag as defined
defined in Section 2.2.3 of [RFC5646]. in Section 2.2.3 of [RFC5646].
* phoneticSystem: String. The phonetic system used in the related phoneticSystem: String. The phonetic system used in the related
value of the phonetic property. The enumerated values value of the phonetic property. The enumerated (Section 1.7.5)
(Section 1.7.4) are: values are:
- ipa: denotes the International Phonetic Alphabet [IPA]. * ipa: denotes the International Phonetic Alphabet [IPA].
- jyut: denotes the Cantonese romanization system "Jyutping". * jyut: denotes the Cantonese romanization system "Jyutping".
- piny: denotes the Standard Mandarin romanization system "Hanyu * piny: denotes the Standard Mandarin romanization system "Hanyu
Pinyin". Pinyin".
The relation between the phoneticSystem, phoneticScript and phonetic The relation between the phoneticSystem, phoneticScript, and phonetic
properties is type-specific. This specification defines this properties is type-specific. This specification defines this
relation in the Name (Section 2.2.1) and Address (Section 2.5.1) relation in the Name (Section 2.2.1.1) and Address (Section 2.5.1.1)
object types, respectively. object types, respectively.
The following example illustrates the phonetic property for a name The following example illustrates the phonetic property for a name
(Section 2.2.1): (Section 2.2.1):
"name": { "name": {
"components": [{ "components": [{
"kind": "given", "kind": "given",
"value": "John", "value": "John",
"phonetic": "/ˈdʒɑːn/" "phonetic": "/ˈdʒɑːn/"
}, { }, {
"kind": "surname", "kind": "surname",
"value": "Smith", "value": "Smith",
"phonetic": "/smɪθ/" "phonetic": "/smɪθ/"
}], }],
"phoneticSystem": "ipa" "phoneticSystem": "ipa"
} }
Figure 1: Example of phonetic for the name "John Smith" as Figure 1: Example of a phonetic Property for the Name "John Smith" as
pronounced in the USA. Pronounced in the USA
1.6. Internationalization 1.6. Internationalization
JSContact aims to be used for international contacts and addressbook JSContact aims to be used for international contacts and address book
data. Notably text values such as names and addresses are likely to data. Notably, text values such as names and addresses are likely to
cover a wide range of languages and cultures. This section describes cover a wide range of languages and cultures. This section describes
internationalization for free-form text values, as well as for internationalization for free-form text values as well as Uniform
Uniform Resource Identifiers (URIs). Resource Identifiers (URIs).
1.6.1. Free-form text 1.6.1. Free-Form Text
Properties having free-form text values MAY contain any valid Properties having free-form text values MAY contain any valid
sequence of Unicode characters encoded as a JSON string. Such values sequence of Unicode characters encoded as a JSON string. Such values
can contain unidirectional left-to-right and right-to-left text, as can contain unidirectional left-to-right and right-to-left text, as
well as bidirectional text using Unicode Directional Formatting well as bidirectional text using Unicode Directional Formatting
Characters described in Section 2 of [UBiDi]. Implementations Characters as described in Section 2 of [UBiDi]. Implementations
setting bidirectional text MUST make sure that each property value setting bidirectional text MUST make sure that each property value
complies with the requirements of the Unicode Bidirectional complies with the requirements of the Unicode Bidirectional
Algorithm. Implementations MUST NOT assume that text values of Algorithm. Implementations MUST NOT assume that text values of
adjacent properties are processed or displayed as a combined string, adjacent properties are processed or displayed as a combined string;
for example the values of a given name component and a surname for example, the values of a given name component and a surname
component may or may not to be rendered together. component may or may not be rendered together.
1.6.2. URIs 1.6.2. URIs
Several properties require their string value to be a URI as defined Several properties require their string value to be a URI as defined
in [RFC3986]. Implementations MUST make sure to use proper percent- in [RFC3986]. Implementations MUST make sure to use proper percent-
encoding for URIs that can not be represented using unreserved URI encoding for URIs that cannot be represented using unreserved URI
characters. Section 3.1 of [RFC3987] defines how to convert characters. Section 3.1 of [RFC3987] defines how to convert
Internationalized Resource Identifiers to URIs. JSContact makes no Internationalized Resource Identifiers to URIs. JSContact makes no
recommendation how to display URIs, but section "4.8.3 recommendation on how to display URIs, but the WHATWG URL Living
Internationalization and special characters" of the W3C URL Standard Standard (see "Internationalization and special characters"
[W3C-URL] provides guidance for URLs found in context of a web (Section 4.8.3) of [WHATWG-URL]) provides guidance for URLs found in
browser. the context of a web browser.
1.7. Validating JSContact 1.7. Validating JSContact
This specification distinguishes between three kinds of properties This specification distinguishes between three kinds of properties
regarding validation: IANA-registered properties and unknown regarding validation: IANA-registered properties and unknown
properties are defined in this section, while vendor-specific properties, which are defined in this section, and vendor-specific
properties are defined in Section 1.8.1. A JSContact object is properties, which are defined in Section 1.8.1. A JSContact object
invalid if any of its properties are invalid. is invalid if any of its properties are invalid.
This document defines for each property if it is mandatory or This document defines whether each property is mandatory or optional.
optional. A mandatory property MUST be present for a JSContact A mandatory property MUST be present for a JSContact object to be
object to be valid. An optional property does not need to be valid. An optional property does not need to be present. The values
present. The values of both required and optional properties MUST of both required and optional properties MUST adhere to the data type
adhere to the data type and definition of that property. and definition of that property.
1.7.1. Case-Sensitivity 1.7.1. Case-Sensitivity
All property names, object type names and enumerated values are case- All property names, object type names, and enumerated values are
sensitive, if not explicitly stated otherwise in their according case-sensitive, unless explicitly stated otherwise in their
definition. Implementations MUST handle a JSContact object as definitions. Implementations MUST handle a JSContact object as
invalid if a type name, property name or enumerated value only invalid if a type name, property name, or enumerated value only
differs in case from one defined for any JSContact version known to differs in case from one defined for any JSContact version known to
that implementation. This applies regardless of what JSContact that implementation. This applies regardless of what JSContact
version the Card object defines in its version (Section 2.1.2) version the Card object defines in its version (Section 2.1.2)
property. Section 1.7.3 defines how to handle unknown properties. property. Section 1.7.4 defines how to handle unknown properties.
1.7.2. IANA-registered Properties 1.7.2. IANA-Registered Properties
An IANA-registered property is any property that has been registered An IANA-registered property is any property that has been registered
according to the IANA property registry rules as outlined in according to the IANA property registry rules as outlined in
Section 3. All properties defined in this specification, including Section 3. All properties defined in this specification, including
their object value types and enumerated values, are registered at their object value types and enumerated values, are registered at
IANA. IANA.
Implementations MUST validate IANA-registered properties in JSContact Implementations MUST validate IANA-registered properties in JSContact
data, unless they are unknown to the implementation (see data, unless they are unknown to the implementation (Section 1.7.4).
Section 1.7.3). They MUST reject invalid IANA-registered properties. They MUST reject invalid IANA-registered properties. A property is
A property is invalid if its name matches the name of an IANA- invalid if its name matches the name of an IANA-registered property
registered property but the value violates its definition according but the value violates its definition according to the JSContact
to the JSContact specification version defined in the Card version specification version defined in the Card version (Section 2.1.2)
property (Section 2.1.2). property.
IANA-registered property names MUST NOT contain US-ASCII control IANA-registered property names MUST NOT contain ASCII control
characters (U+0000 to U+001F, U+007F), the COLON (U+003A) or characters (U+0000 to U+001F, U+007F), the COLON (U+003A), or the
QUOTATION MARK (U+0022) characters. They MUST only contain US-ASCII QUOTATION MARK (U+0022). They MUST only contain ASCII alphanumeric
alphanumeric characters that match the ALPHA and DIGIT rules defined characters that match the ALPHA and DIGIT rules defined in
in Appendix B.1 of [RFC5234]) or the COMMERCIAL AT (U+0040) Appendix B.1 of [RFC5234] or the COMMERCIAL AT (U+0040) character.
character. IANA-registered property names MUST be notated in lower IANA-registered property names MUST be notated in lower camel case.
camel case.
1.7.3. Unknown Properties 1.7.3. Reserved Properties
IANA-registered properties can be reserved (Section 3.3).
Implementations MUST NOT set properties having a reserved name in
JSContact objects for which this property is reserved or all objects
if the property context in the registry is "not applicable".
Reserved properties have no type, and their type signature is "not
applicable". Any JSContact object including a property that is
reserved in context of this object MUST be considered invalid.
This document reserves one property:
1.7.3.1. extra
extra: not applicable. The reserved property "extra" provides
implementors with a property name that is certain to never occur
as a property in any JSContact object. Implementations might want
to map unknown or vendor-specific properties to a variable with
this name, but this is implementation-specific.
1.7.4. Unknown Properties
Implementations may encounter JSContact data where a property name is Implementations may encounter JSContact data where a property name is
unknown to that implementation, but the name adheres to the syntactic unknown to that implementation but the name adheres to the syntactic
restrictions of IANA-registered property names. Implementations MUST restrictions of IANA-registered property names. Implementations MUST
make sure that such a name does not violate the case-sensitivity make sure that such a name does not violate the case-sensitivity
rules defined in Section 1.7.1. If the property name is valid, then rules defined in Section 1.7.1. If the property name is valid, then
implementations MUST NOT treat such properties as invalid. Instead, implementations MUST NOT treat such properties as invalid. Instead,
they MUST preserve them in the JSContact object. they MUST preserve them in the JSContact object.
Implementations that create or update JSContact data MUST only set Implementations that create or update JSContact data MUST only set
IANA-registered properties or vendor-specific properties. Preserving IANA-registered properties or vendor-specific properties. Preserving
properties that are unknown to the implementation, is to allow properties that are unknown to the implementation is to allow
applications and services to interoperate without data loss, even if applications and services to interoperate without data loss, even if
not all of them implement the same set of JSContact extensions. not all of them implement the same set of JSContact extensions.
1.7.4. Enumerated Values 1.7.5. Enumerated Values
Several properties in this document restrict their allowed values to Several properties in this document restrict their allowed values to
be from a list of String values. These values are case-sensitive. a list of String values. These values are case-sensitive. If not
If not noted otherwise for a specific property, the initial list of noted otherwise for a specific property, the initial list of values
values for such properties is registered at IANA in the JSContact for such properties is registered at IANA in the "JSContact Enum
Enum Values Registry (Section 3.7). Implementations MUST only set Values" registry (Section 3.7). Implementations MUST only set IANA-
IANA-registered or vendor-specific (Section 1.8.2) values for such registered or vendor-specific (Section 1.8.2) values for such
properties. properties.
1.8. Vendor-Specific Extensions 1.8. Vendor-Specific Extensions
Vendors may extend properties and values for experimentation or to Vendors may extend properties and values for experimentation or to
store contacts data that only is useful for a single service or store contacts data that is only useful for a single service or
application. Such extensions are not meant for interoperation. If application. Such extensions are not meant for interoperation. If,
instead interoperation is desired, vendors are strongly encouraged to instead, interoperation is desired, vendors are strongly encouraged
define and register new properties, types and values at IANA. to define and register new properties, types, and values at IANA as
Section 3 defines how to register new properties, types or values at defined in Section 3. Section 1.7.2 defines the naming conventions
IANA. Section 1.7.2 defines the naming conventions for IANA- for IANA-registered elements.
registered elements.
1.8.1. Vendor-specific Properties 1.8.1. Vendor-Specific Properties
Vendor-specific property names MUST start with a vendor-specific Vendor-specific property names MUST start with a vendor-specific
prefix followed by a name, as produced by the v-extension ABNF below. prefix followed by a name, as produced by the "v-extension" ABNF
The prefix and name together form the property name. The vendor- below. The prefix and name together form the property name. The
specific prefix MUST be a domain name under control of the service or vendor-specific prefix MUST be a domain name under control of the
application that sets the property, but it need not resolve in the service or application that sets the property, but it need not
Domain Name System [RFC1034] and [RFC1035]. The prefix ietf.org and resolve in the Domain Name System [RFC1034] [RFC1035]. The prefix
its subdomain names are reserved for IETF specifications. The name "ietf.org" and its subdomain names are reserved for IETF
MUST NOT contain the TILDE (U+007E) and SOLIDUS (U+002F) characters, specifications. The name MUST NOT contain the TILDE (U+007E) and
as these require special-escaping when encoding a JSON Pointer SOLIDUS (U+002F) characters, as these require special escaping when
[RFC6901] for that property. encoding a JSON Pointer [RFC6901] for that property.
Vendor-specific properties MAY be set in any JSContact object. Vendor-specific properties MAY be set in any JSContact object.
Implementations MUST preserve vendor-specific properties in JSContact Implementations MUST preserve vendor-specific properties in JSContact
data, irrespective if they know their use. They MUST NOT reject the data, irrespective if they know their use. They MUST NOT reject the
property value as invalid, unless they are in control of the vendor- property value as invalid, unless they are in control of the vendor-
specific property as outlined in the above paragraph. specific property as outlined in the above paragraph.
The ABNF rule v-extension formally defines valid vendor-specific The ABNF rule "v-extension" formally defines valid vendor-specific
property names. Note that the vendor prefix allows for more values property names. Note that the vendor prefix allows for more values
than are allowed as Internationalized Domain Names (IDN) [RFC8499]. than Internationalized Domain Names (IDNs) [RFC8499]; therefore,
This is to allow JSContact implementations simply validate property JSContact implementations can simply validate property names without
names without implementing the full set of rules that apply to domain implementing the full set of rules that apply to domain names.
names.
v-extension = v-prefix ":" v-name v-extension = v-prefix ":" v-name
v-prefix = v-label *("." v-label) v-prefix = v-label *("." v-label)
v-label = alnum-int / alnum-int *(alnum-int / "-") alnum-int v-label = alnum-int / alnum-int *(alnum-int / "-") alnum-int
alnum-int = ALPHA / DIGIT / NON-ASCII alnum-int = ALPHA / DIGIT / NON-ASCII
; see RFC 6350 Section 3.3 ; see RFC 6350, Section 3.3
v-name = 1*(WSP / "!" / %x23-2e / %x30-7d / NON-ASCII) v-name = 1*(WSP / "!" / %x23-2e / %x30-7d / NON-ASCII)
; any characters except CTLs, DQUOTE, SOLIDUS and TILDE ; any characters except CTLs, DQUOTE, SOLIDUS, and TILDE
Figure 2: ABNF rules for vendor-specific property names Figure 2: ABNF Rules for Vendor-Specific Property Names
The value of vendor-specific properties can be any valid JSON value, The value of vendor-specific properties can be any valid JSON value,
and naming restrictions do not apply to such values. Specifically, and naming restrictions do not apply to such values. Specifically,
if the property value is a JSON object then the keys of such objects if the property value is a JSON object, then the keys of such objects
need not be named as vendor-specific properties. The example in need not be named as vendor-specific properties, as illustrated in
Figure 3 illustrates this: Figure 3:
"example.com:foo": "bar", "example.com:foo": "bar",
"example.com:foo2": { "example.com:foo2": {
"bar": "baz" "bar": "baz"
} }
Figure 3: Examples of vendor-specific properties Figure 3: Examples of Vendor-Specific Properties
1.8.2. Vendor-specific Values 1.8.2. Vendor-Specific Values
Some JSContact IANA-registered properties allow their values to be Some JSContact IANA-registered properties allow their values to be
vendor-specific. One such example is the kind property vendor-specific. One such example is the "kind" (Section 2.1.4)
Section 2.1.4, which enumerates its standard values but also allows property, which enumerates its standard values but also allows for
for arbitrary vendor-specific values. Such vendor-specific values arbitrary vendor-specific values. Such vendor-specific values MUST
MUST be valid v-extension values as defined in Section 1.8.1. The be valid "v-extension" values as defined in Section 1.8.1. The
example in Figure 4 illustrates this: example in Figure 4 illustrates this:
"kind": "example.com:baz" "kind": "example.com:baz"
Figure 4: Example of a vendor-specific value Figure 4: Example of a Vendor-Specific Value
Vendors are strongly encouraged to specify a new standard value once Vendors are strongly encouraged to specify a new standard value once
a vendor-specific one turns out to be useful also for other systems. a vendor-specific one turns out to also be useful for other systems.
1.9. Versioning 1.9. Versioning
Every instance of a JSContact Card (Section 2) indicates which Every instance of a JSContact Card (Section 2) indicates which
JSContact version its IANA-registered properties and values are based JSContact version its IANA-registered properties and values are based
on. The version is indicated both in the version (Section 2.1.2) on. The version is indicated both in the version (Section 2.1.2)
property within the Card and in the version (Section 3.1) parameter property within the Card and in the version (Section 3.1) parameter
of the JSContact MIME content type. All IANA-registered elements of the JSContact media type. All IANA-registered elements indicate
indicate the version at which they got introduced or obsoleted. the version at which they were introduced or obsoleted.
1.9.1. Version Format and Requirements
A JSContact version consists of a numeric major and minor version,
separated by the FULL STOP character (U+002E). Later versions are
numerically higher than former versions, with the major version being
more significant than the minor version. A version value is produced
by the ABNF
jsversion = 1*DIGIT "." 1*DIGIT A JSContact version consists of a major and minor version.
Differing major version values indicate substantial differences in Differing major version values indicate substantial differences in
JSContact semantics and format. Implementations MUST be prepared JSContact semantics and format. Implementations MUST be prepared for
that property definitions and other JSContact elements differ in a property definitions and other JSContact elements that differ in a
backwards-incompatible manner. backwards-incompatible manner.
Differing minor version values indicate additions that enrich Differing minor version values indicate additions that enrich
JSContact data, but do not introduce backwards-incompatible changes. JSContact data but do not introduce backwards-incompatible changes.
Typically, these are new property enum values or properties with Typically, these are new property enum values or properties with a
narrow semantic scope. A new minor version MUST NOT require narrow semantic scope. A new minor version MUST NOT require
implementations to change their processing of JSContact data. implementations to change their processing of JSContact data.
Changing the major version number resets the minor version number to Changing the major version number resets the minor version number to
zero. zero.
1.9.1. Version Format and Requirements
A version value starts with the numeric major version, followed by
the FULL STOP character (U+002E), followed by the numeric minor
version. Later versions are numerically higher than former versions,
with the major version being more significant than the minor version.
A version value is produced by the following ABNF:
jsversion = 1*DIGIT "." 1*DIGIT
Figure 5: The ABNF for JSContact Version Values
1.9.2. Current Version 1.9.2. Current Version
This specification registers JSContact version value 1.0 (Table 1). This specification registers JSContact version value "1.0" (Table 1).
2. Card 2. Card
This section defines the JSContact object type Card. A Card stores This section defines the JSContact object type Card. A Card stores
contact information, typically that of a person, organization or contact information, typically that of a person, organization, or
company. company.
Its media type is defined in Section 3.1. Its media type is defined in Section 3.1.
Figure 5 basic Card for the person "John Doe". As the object is the Figure 6 shows a basic Card for the person "John Doe". As the object
topmost object in the JSON data it has the @type property set is the topmost object in the JSON data, it has the @type property set
according to the rules defined Section 1.3.4. according to the rules defined in Section 1.3.4.
{ {
"@type": "Card", "@type": "Card",
"version": "1.0", "version": "1.0",
"uid": "22B2C7DF-9120-4969-8460-05956FE6B065", "uid": "22B2C7DF-9120-4969-8460-05956FE6B065",
"kind": "individual", "kind": "individual",
"name": { "name": {
"components": [ "components": [
{ "kind": "given", "value": "John" }, { "kind": "given", "value": "John" },
{ "kind": "surname", "value": "Doe" } { "kind": "surname", "value": "Doe" }
], ],
"isOrdered": true "isOrdered": true
} }
} }
Figure 5: Example of a basic Card Figure 6: Example of a Basic Card
2.1. Metadata Properties 2.1. Metadata Properties
This section defines properties about this instance of a Card, such This section defines properties about this instance of a Card such as
as its unique identifier, its creation date, how it relates to other its unique identifier, its creation date, and how it relates to other
Cards and other metadata information. Cards and other metadata information.
2.1.1. @type 2.1.1. @type
Type: String (mandatory). @type: String (mandatory). The JSContact type of the Card object.
The value MUST be "Card".
This MUST be Card, if set.
2.1.2. version 2.1.2. version
Type: String (mandatory). version: String (mandatory). The JSContact version of this Card.
The value MUST be one of the IANA-registered JSContact Version
Specifies the JSContact version used to define this Card. The value values for the version property. Also see Section 1.9.2.
MUST be one of the IANA-registered JSContact Enum Values for the
version property. Also see Section 1.9.2.
"version": "1.0" "version": "1.0"
Figure 6: version example Figure 7: Example for the version Property
2.1.3. created 2.1.3. created
Type: UTCDateTime (optional). created: UTCDateTime (optional). The date and time when the Card was
created.
The date and time when this Card was created.
"created": "2022-09-30T14:35:10Z" "created": "2022-09-30T14:35:10Z"
Figure 7: created example
Figure 8: Example for the created Property
2.1.4. kind 2.1.4. kind
Type: String (optional, default: individual). The kind of the entity kind: String (optional; default: "individual"). The kind of the
the Card represents. entity the Card represents.
The enumerated (Section 1.7.4) values are: The enumerated (Section 1.7.5) values are:
* individual: a single person * individual: a single person
* group: a group person of persons or entities * group: a group of people or entities
* org: an organization * org: an organization
* location: a named location * location: a named location
* device: a device, such as appliances, computers, or network * device: a device such as an appliance, a computer, or a network
elements element
* application: a software application * application: a software application
"kind": "individual" "kind": "individual"
Figure 8: kind example Figure 9: Example for the kind Property
2.1.5. language 2.1.5. language
Type: String (optional). language: String (optional). The language tag, as defined in
[RFC5646], that best describes the language used for text in the
This is the language tag, as defined in [RFC5646], that best Card, optionally including additional information such as the
describes the language used for text in the Card, optionally script. Note that values MAY be localized in the localizations
including additional information such as the script. Note that (Section 2.7.1) property.
values MAY be localized in the localizations property Section 2.7.1.
"language": "de-AT" "language": "de-AT"
Figure 9: language example Figure 10: Example for the language Property
2.1.6. members 2.1.6. members
Type: String[Boolean] (optional). members: String[Boolean] (optional). The set of Cards that are
members of this group Card. Each key in the set is the uid
This identifies the set of Cards that are members of this group Card. property value of the member, and each boolean value MUST be
Each key in the set is the uid property value of the member, each "true". If this property is set, then the value of the kind
boolean value MUST be true. If this property is set, then the value property MUST be "group".
of the kind property MUST be group.
The opposite is not true. A group Card will usually contain the The opposite is not true. A group Card will usually contain the
members property to specify the members of the group, but it is not members property to specify the members of the group, but it is
required to. A group Card without the members property can be not required to. A group Card without the members property can be
considered an abstract grouping, or one whose members are known considered an abstract grouping or one whose members are known
empirically (e.g., "IETF Participants"). empirically (e.g., "IETF Participants").
"kind": "group", "kind": "group",
"name": { "name": {
"full": "The Doe family" "full": "The Doe family"
}, },
"uid": "urn:uuid:ab4310aa-fa43-11e9-8f0b-362b9e155667", "uid": "urn:uuid:ab4310aa-fa43-11e9-8f0b-362b9e155667",
"members": { "members": {
"urn:uuid:03a0e51f-d1aa-4385-8a53-e29025acd8af": true, "urn:uuid:03a0e51f-d1aa-4385-8a53-e29025acd8af": true,
"urn:uuid:b8767877-b4a1-4c70-9acc-505d3819e519": true "urn:uuid:b8767877-b4a1-4c70-9acc-505d3819e519": true
} }
Figure 10: members example Figure 11: Example for the members Property
2.1.7. prodId 2.1.7. prodId
Type: String (optional). prodId: String (optional). The identifier for the product that
created the Card. If set, the value MUST be at least one
The identifier for the product that created the Card. If set, the character long.
value MUST be at least one character long.
"prodId": "ACME Contacts App version 1.23.5" "prodId": "ACME Contacts App version 1.23.5"
Figure 11: prodId example Figure 12: Example for the prodId Property
2.1.8. relatedTo 2.1.8. relatedTo
Type: String[Relation] (optional). relatedTo: String[Relation] (optional). The set of Card objects that
relate to the Card. The value is a map, where each key is the uid
property value of the related Card, and the value defines the
relation.
Relates the object to other Cards. This is represented as a map, The Relation object has the following properties:
where each key is the uid of the related Card and the value defines
the relation. The Relation object has the following properties:
* @type: String. This MUST be Relation, if set. @type: String. The JSContact type of the object. The value MUST be
"Relation", if set.
* relation: String[Boolean] (optional, default: empty Object) relation: String[Boolean] (optional; default: empty Object). The rel
Describes how the linked object is related to the linking object. ationship of the related Card to the Card, defined as a set of
The relation is defined as a set of relation types. The key in relation types. The keys in the set define the relation type; the
the set defines the relation type, the value for each key in the values for each key in the set MUST be "true". The relationship
set MUST be true. The relationship between the two objects is between the two objects is undefined if the set is empty.
undefined if the set is empty.
The initial list of enumerated (Section 1.7.4) relation types The initial list of enumerated (Section 1.7.5) relation types
matches the IANA-registered TYPE parameter [IANAvCard] values of matches the IANA-registered TYPE [IANA-vCard] parameter values of
the vCard RELATED property (Section 6.6.6 of [RFC6350]): the vCard RELATED property (Section 6.6.6 of [RFC6350]):
- acquaintance * acquaintance
- agent * agent
- child * child
- colleague * co-resident
- contact * co-worker
- co-resident * colleague
- co-worker * contact
- crush * crush
- date * date
- emergency * emergency
- friend * friend
- kin * kin
- me * me
- met * met
- muse * muse
- neighbor * neighbor
- parent * parent
- sibling * sibling
- spouse * spouse
- sweetheart * sweetheart
"relatedTo": { "relatedTo": {
"urn:uuid:f81d4fae-7dec-11d0-a765-00a0c91e6bf6": { "urn:uuid:f81d4fae-7dec-11d0-a765-00a0c91e6bf6": {
"relation": { "relation": {
"friend": true "friend": true
} }
}, },
"8cacdfb7d1ffdb59@example.com": { "8cacdfb7d1ffdb59@example.com": {
"relation": {} "relation": {}
} }
} }
Figure 12: relatedTo example Figure 13: Example for the relatedTo Property
2.1.9. uid 2.1.9. uid
Type: String (mandatory). uid: String (mandatory). An identifier that associates the object as
the same across different systems, address books, and views. The
value SHOULD be a URN [RFC8141], but for compatibility with
[RFC6350], it MAY also be a URI [RFC3986] or free-text value. The
value of the URN SHOULD be in the "uuid" namespace [RFC4122].
An identifier, used to associate the object as the same across As of this writing, a revision [UUID] of the Universally Unique
different systems, address books and views. The value SHOULD be a Identifier (UUID) Standards Track document [RFC4122] is in
URN [RFC8141] but for compatibility with [RFC6350] it MAY also be a progress and will likely introduce new UUID versions and best
URI [RFC3986] or free-text value. The value of the URN SHOULD be in practices to generate global unique identifiers. Implementors
the uuid namespace [RFC4122]. As of this writing, a revision SHOULD follow any recommendations described there. Until then,
[I-D.ietf-uuidrev-rfc4122bis] of the UUID standard document is being implementations SHOULD generate identifiers using the random or
worked on and is likely to introduce new UUID versions and best pseudorandom UUID version described in Section 4.4 of [RFC4122].
practices to generate global unique identifiers. Implementors SHOULD
follow any recommendations described there. Until then,
implementations SHOULD generate identifiers using the random or
pseudo-random UUID version described in Section 4.4 of [RFC4122].
"uid": "urn:uuid:f81d4fae-7dec-11d0-a765-00a0c91e6bf6" "uid": "urn:uuid:f81d4fae-7dec-11d0-a765-00a0c91e6bf6"
Figure 13: uid example Figure 14: Example for the uid Property
2.1.10. updated 2.1.10. updated
Type: UTCDateTime (optional). updated: UTCDateTime (optional). The date and time when the data in
the Card was last modified.
The date and time when the data in this Card was last modified.
"updated": "2021-10-31T22:27:10Z" "updated": "2021-10-31T22:27:10Z"
Figure 14: updated example Figure 15: Example for the updated Property
2.2. Name and Organization Properties 2.2. Name and Organization Properties
This section defines properties that name the entity represented by This section defines properties that name the entity represented by
this Card, its related organizations and roles, as well as how to the Card and its related organizations and roles. It also describes
refer the entity represented by this Card in spoken or written how to refer to the entity represented by the Card in spoken or
language. written language.
2.2.1. name 2.2.1. name
Type: Name (optional). name: Name (optional). The name of the entity represented by the
Card. This can be any type of name, e.g., it can, but need not,
The name of the entity represented by this Card. This can be any be the legal name of a person.
type of name, e.g., it can but need not be the legal name of a
person.
2.2.1.1. Name object 2.2.1.1. Name Object
A Name object has the following properties A Name object has the following properties:
* @type: String. This MUST be Name, if set. @type: String. The JSContact type of the object. The value MUST be
"Name", if set.
* components: NameComponent[] (optional). The components components: NameComponent[] (optional). The components
(Section 2.2.1.2) making up this name. This property MUST be set (Section 2.2.1.2) making up this name. The components property
if the full property is not set, otherwise it SHOULD be set. The MUST be set if the full property is not set; otherwise, it SHOULD
component list MUST have at least one entry having a different be set. The component list MUST have at least one entry having a
kind than separator. different kind property value than "separator".
Name components SHOULD be ordered such that their values joined as Name components SHOULD be ordered such that when their values are
a String produce a valid full name of this entity. If so, joined as a String, a valid full name of the entity is produced.
implementations MUST set the isOrdered property value to true. If so, implementations MUST set the isOrdered property value to
"true".
If the name components are ordered, then the defaultSeparator If the name components are ordered, then the defaultSeparator
property and name components of kind separator give guidance on property and name components with the kind property value set to
what characters to insert between components, but implementations "separator" give guidance on what characters to insert between
are free to choose any others. In lack of a separator, inserting components, but implementations are free to choose any others.
a single Space character in between name component values is a When lacking a separator, inserting a single space character in
good choice. between the name component values is a good choice.
If instead the name components follow no particular order, then If, instead, the name components follow no particular order, then
the isOrdered property value MUST be false, the components the isOrdered property value MUST be "false", the components
property MUST NOT contain a NameComponent of kind separator and property MUST NOT contain a NameComponent with the kind property
the defaultSeparator property MUST NOT be set. value set to "separator", and the defaultSeparator property MUST
NOT be set.
Figure 15 is an example for the name "Vincent van Gogh". Note how Figure 16 shows an example for the name "Vincent van Gogh". Note
a single name component value may consist of multiple words. how a single name component value may consist of multiple words.
Figure 16 illustrates a name with a second surname, such as a
Spanish name. Additional examples are shown in Figure 18 and
Figure 38.
"name": { "name": {
"components": [ "components": [
{ "kind": "given", "value": "Vincent" }, { "kind": "given", "value": "Vincent" },
{ "kind": "surname", "value": "van Gogh" } { "kind": "surname", "value": "van Gogh" }
], ],
"isOrdered": true "isOrdered": true
} }
Figure 15: Example for a surname with two words Figure 16: Example of a Surname with Two Words
Figure 17 illustrates a name with a second surname such as a
Spanish name. Additional examples are shown in Figures 19 and 39.
"name": { "name": {
"components": [ "components": [
{ "kind": "given", "value": "Diego" }, { "kind": "given", "value": "Diego" },
{ "kind": "surname", "value": "Rivera" }, { "kind": "surname", "value": "Rivera" },
{ "kind": "surname2", "value": "Barrientos" } { "kind": "surname2", "value": "Barrientos" }
], ],
"isOrdered": true "isOrdered": true
} }
Figure 16: Example for a second surname Figure 17: Example of a Second Surname
* isOrdered: Boolean (optional, default: false). This indicates if isOrdered: Boolean (optional; default: "false"). The indicator if
the name component sequence in the components property is ordered. the name components in the components property are ordered.
* defaultSeparator: String (optional). The default separator to defaultSeparator: String (optional). The default separator to insert
insert between name component values when concatenating all name between name component values when concatenating all name
component values to a single String. Also see the definition of component values to a single String. Also see the definition of
the separator kind for the NameComponent object. This property the kind property value "separator" for the NameComponent
MUST NOT be set if the Name isOrdered property value is false or (Section 2.2.1.2) object. The defaultSeparator property MUST NOT
if the components property is not set. be set if the Name isOrdered property value is "false" or if the
components property is not set.
* full: String (optional). This is the full name representation of full: String (optional). The full name representation of the Name.
this Name. This property MUST be set if the components property The full property MUST be set if the components property is not
is not set. set.
"full": "Mr. John Q. Public, Esq." "full": "Mr. John Q. Public, Esq."
Figure 17: full example Figure 18: Example for the full Property
* sortAs: String[String] (optional).
This defines how this name lexicographically sorts in relation to sortAs: String[String] (optional). The value to lexicographically
other names when compared by a name component type. The key in sort the name in relation to other names when compared by a name
the map defines the name component type. The value for that key component type. The keys in the map define the name component
defines the verbatim string to compare when sorting by this name type. The values define the verbatim string to compare when
component type. Absence of a key indicates that this name sorting by the name component type. Absence of a key indicates
component type SHOULD NOT be considered during sort. Sorting by that the name component type SHOULD NOT be considered during sort.
that missing name component type or if the sortAs property is not Sorting by that missing name component type, or if the sortAs
set is implementation-specific. This property MUST NOT be set if property is not set, is implementation-specific. The sortAs
the components property is not set. property MUST NOT be set if the components property is not set.
Each key in the map MUST be a valid name component type value as Each key in the map MUST be a valid name component type value as
defined for the kind property of the NameComponent object (see defined for the kind property of the NameComponent object (see
below). For each key in the map there MUST exist at least one below). For each key in the map, there MUST exist at least one
NameComponent object having that type in the components property NameComponent object that has the type in the components property
of this name. of the name.
Figure 18 illustrates the use of sortAs. The property value Figure 19 illustrates the use of the sortAs property. The
indicates that the middle name followed by both surnames should be property value indicates that the middle name followed by both
used when sorting this name by surname. The absence of the middle surnames should be used when sorting the name by surname. The
indicates that the middle name on its own should be disregarded absence of "middle" indicates that the middle name on its own
during sort. Even though the name only contains one name should be disregarded during sort. Even though the name only
component for the given name, the sortAs property still explicitly contains one name component for the given name, the sortAs
defines how to sort by given name as otherwise sorting by it would property still explicitly defines how to sort by the given name;
be undefined. otherwise, sorting by it would be undefined.
* phoneticScript: String (optional). The script used in the value phoneticScript: String (optional). The script used in the value of
of the NameComponent phonetic property. Also see Section 1.5.5. the NameComponent phonetic property. See Section 1.5.4 for more
See Figure 19 for an example. information and Figure 20 for an example.
* phoneticSystem: String (optional). The phonetic system used in phoneticSystem: String (optional). The phonetic system used in the
the NameComponent phonetic property. Also see Section 1.5.5. See NameComponent phonetic property. See Section 1.5.4 for more
Figure 19 for an example. information and Figure 20 for an example.
"name": { "name": {
"components": [ "components": [
{ "kind": "given", "value": "Robert" }, { "kind": "given", "value": "Robert" },
{ "kind": "given2", "value": "Pau" }, { "kind": "given2", "value": "Pau" },
{ "kind": "surname", "value": "Shou Chang" } { "kind": "surname", "value": "Shou Chang" }
], ],
"sortAs": { "sortAs": {
"surname": "Pau Shou Chang", "surname": "Pau Shou Chang",
"given": "Robert" "given": "Robert"
}, },
"isOrdered": true "isOrdered": true
} }
Figure 18: Example for sortAs Figure 19: Example for the sortAs Property
{ {
"@type": "Card", "@type": "Card",
"language": "zh-Hant", "language": "zh-Hant",
"name": { "name": {
"components": [ "components": [
{ "kind": "surname", "value": "孫" }, { "kind": "surname", "value": "孫" },
{ "kind": "given", "value": "中山" }, { "kind": "given", "value": "中山" },
{ "kind": "given2", "value": "文" }, { "kind": "given2", "value": "文" },
{ "kind": "given2", "value": "逸仙" } { "kind": "given2", "value": "逸仙" }
skipping to change at page 28, line 28 skipping to change at line 1266
"name/phoneticSystem": "jyut", "name/phoneticSystem": "jyut",
"name/phoneticScript": "Latn", "name/phoneticScript": "Latn",
"name/components/0/phonetic": "syun1", "name/components/0/phonetic": "syun1",
"name/components/1/phonetic": "zung1saan1", "name/components/1/phonetic": "zung1saan1",
"name/components/2/phonetic": "man4", "name/components/2/phonetic": "man4",
"name/components/3/phonetic": "jat6sin1" "name/components/3/phonetic": "jat6sin1"
} }
} }
} }
Figure 19: Example for phonetic and localizations Figure 20: Example for the phonetic and localizations Properties
2.2.1.2. NameComponent 2.2.1.2. NameComponent
A NameComponent object has the following properties: A NameComponent object has the following properties:
* @type: String. This MUST be NameComponent, if set. @type: String. The JSContact type of the object. The value MUST be
"NameComponent", if set.
* value: String (mandatory). The value of this name component. value: String (mandatory). The value of the name component. This
This can be composed of one or multiple words, such as "Poe" or can be composed of one or multiple words such as "Poe" or "van
"van Gogh". Gogh".
* kind: String (mandatory). The kind of this name component. The kind: String (mandatory). The kind of the name component. The
enumerated (Section 1.7.4) values are: enumerated (Section 1.7.5) values are:
- title: an honorific title or prefix, e.g., "Mr", "Ms", "Dr". * title: an honorific title or prefix, e.g., "Mr.", "Ms.", or
"Dr.".
- given: a given name, also known as "first name", "personal * given: a given name, also known as "first name" or "personal
name". name".
- given2: a name that appears between the given and surname, such * given2: a name that appears between the given and surname such
as a middle name or patronymic name. as a middle name or patronymic name.
- surname: a surname, also known as "last name", "family name". * surname: a surname, also known as "last name" or "family name".
- surname2: a secondary surname (used in some cultures), also * surname2: a secondary surname (used in some cultures), also
known as "maternal surname". known as "maternal surname".
- credential: a credential, also known as "accreditation * credential: a credential, also known as "accreditation
qualifier" or "honorific suffix", e.g., "B.A.", "Esq.". qualifier" or "honorific suffix", e.g., "B.A.", "Esq.".
- generation: a generation marker or qualifier, e.g., “Jr.” or * generation: a generation marker or qualifier, e.g., "Jr." or
“III”. "III".
- separator: a formatting separator between two ordered name non- * separator: a formatting separator between two ordered name non-
separator components. The value property of the component separator components. The value property of the component
includes the verbatim separator, for example a hyphen character includes the verbatim separator, for example, a hyphen
or even an empty string. This value has higher precedence than character or even an empty string. This value has higher
the defaultSeparator property of the Name. Implementations precedence than the defaultSeparator property of the Name.
MUST NOT insert two consecutive separator components, instead Implementations MUST NOT insert two consecutive separator
they SHOULD insert a single separator component with the components; instead, they SHOULD insert a single separator
combined value. This component kind MUST NOT be set if the component with the combined value. This component kind MUST
Name isOrdered property value is false. NOT be set if the Name isOrdered property value is "false".
* phonetic: String (optional). This defines how to pronounce this phonetic: String (optional). The pronounciation of the name
name component. If this property is set, then at least one of the component. If this property is set, then at least one of the Name
Name object phoneticSystem or phoneticScript properties MUST be object properties, phoneticSystem or phoneticScript, MUST be set.
set. Also see Section 1.5.5. Also see Section 1.5.4.
2.2.1.3. nicknames 2.2.2. nicknames
Type: Id[Nickname] (optional). nicknames: Id[Nickname] (optional). The nicknames of the entity
represented by the Card.
The nicknames of the entity represented by this Card. A Nickname A Nickname object has the following properties:
object has the following properties:
* @type: String. This MUST be Nickname, if set. @type: String. The JSContact type of the object. The value MUST be
"Nickname", if set.
* name: String (mandatory). The nickname. name: String (mandatory). The nickname.
* contexts: String[Boolean] (optional) The contexts in which to use contexts: String[Boolean] (optional). The contexts in which to use
this nickname. Also see Section 1.5.1. the nickname. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this nickname in pref: UnsignedInt (optional). The preference of the nickname in
relation to other nicknames. Also see Section 1.5.4. relation to other nicknames. Also see Section 1.5.3.
"nicknames": { "nicknames": {
"k391": { "k391": {
"name": "Johnny" "name": "Johnny"
} }
} }
Figure 20: nicknames example Figure 21: Example for the nicknames Property
2.2.2. organizations 2.2.3. organizations
Type: Id[Organization] (optional). organizations: Id[Organization] (optional). The company or
organization names and units associated with the Card.
The companies or organizations names and units associated with this An Organization object has the following properties, of which at
Card. An Organization object has the following properties, of which least one of the name and units properties MUST be set:
at least one of the name and units properties MUST be set:
* @type: String. This MUST be Organization, if set. @type: String. The JSContact type of the object. The value MUST be
"Organization", if set.
* name: String (optional). The name of this organization. name: String (optional). The name of the organization.
* units: OrgUnit[] (optional). A list of organizational units, units: OrgUnit[] (optional). A list of organizational units, ordered
ordered descending by hierarchy (e.g., a geographic or functional as descending by hierarchy (e.g., a geographic or functional
division sorts before a department within that division). If set, division sorts before a department within that division). If set,
the list MUST contain at least one entry. the list MUST contain at least one entry.
* sortAs: String (optional). This defines how this organization sortAs: String (optional). The value to lexicographically sort the
name lexicographically sorts in relation to other organizations organization in relation to other organizations when compared by
when compared by name. The value defines the verbatim string name. The value defines the verbatim string value to compare. In
value to compare. In absence of this property, the name property absence of this property, the name property value MAY be used for
value MAY be used for comparison. comparison.
* contexts: String[Boolean] (optional). The contexts in which contexts: String[Boolean] (optional). The contexts in which
association with this organization apply. For example, membership association with the organization applies. For example,
in a choir may only apply in a private context. Also see membership in a choir may only apply in a private context. Also
Section 1.5.1. see Section 1.5.1.
A OrgUnit object has the following properties: An OrgUnit object has the following properties:
* @type: String. This MUST be OrgUnit, if set. @type: String. The JSContact type of the object. The value MUST be
"OrgUnit", if set.
* name: String (mandatory). The name of this organizational unit. name: String (mandatory). The name of the organizational unit.
* sortAs: String (optional). This defines how this organization sortAs: String (optional). The value to lexicographically sort the
unit name lexicographically sorts in relation to other organizational unit in relation to other organizational units of
organizational units of the same level when compared by name. The the same level when compared by name. The level is defined by the
level is defined by the array index of this organizational unit in array index of the organizational unit in the units property of
the units property of the Organization object. The property value the Organization object. The property value defines the verbatim
defines the verbatim string value to compare. In absence of this string value to compare. In absence of this property, the name
property, the name property value MAY be used for comparison. property value MAY be used for comparison.
"organizations": { "organizations": {
"o1": { "o1": {
"name": "ABC, Inc.", "name": "ABC, Inc.",
"units": [ "units": [
{ "name": "North American Division" }, { "name": "North American Division" },
{ "name": "Marketing" } { "name": "Marketing" }
], ],
"sortAs": "ABC" "sortAs": "ABC"
} }
} }
Figure 21: organizations example Figure 22: Example for the organizations Property
2.2.3. speakToAs
Type: SpeakToAs (optional).
Provides information how to address, speak to or refer to the entity
that is represented by this Card. A SpeakToAs object has the
following properties, of which at least one of the grammaticalGender
and pronouns properties MUST be set:
* @type: String. This MUST be SpeakToAs, if set.
* grammaticalGender: String (optional). Defines which grammatical
gender to use in salutations and other grammatical constructs.
For example, the German language distinguishes by grammatical
gender in salutations such as "Sehr geehrte" (feminine) and "Sehr
geehrter" (masculine). The enumerated (Section 1.7.4) values are:
- animate 2.2.4. speakToAs
- common speakToAs: SpeakToAs (optional). The information how to address,
speak to, or refer to the entity that is represented by the Card.
- feminine A SpeakToAs object has the following properties, of which at least
one of the grammaticalGender and pronouns properties MUST be set:
- inanimate @type: String. The JSContact type of the object. The value MUST be
"SpeakToAs", if set.
- masculine grammaticalGender: String (optional). The grammatical gender to use
in salutations and other grammatical constructs. For example, the
German language distinguishes by grammatical gender in salutations
such as "Sehr geehrte" (feminine) and "Sehr geehrter" (masculine).
The enumerated (Section 1.7.5) values are:
- neuter * animate
* common
* feminine
* inanimate
* masculine
* neuter
Note that the grammatical gender does not allow inferring the Note that the grammatical gender does not allow inferring the
gender identities or assigned sex of the contact. gender identities or assigned sex of the contact.
* pronouns: Id[Pronouns] (optional). Defines the pronouns that the pronouns: Id[Pronouns] (optional). The pronouns that the contact
contact chooses to use for themselves. chooses to use for themselves.
A Pronouns object has the following properties: A Pronouns object has the following properties:
* @type: String. This MUST be Pronouns, if set. @type: String. The JSContact type of the object. The value MUST be
"Pronouns", if set.
* pronouns: String (mandatory). Defines the pronouns. Any value or pronouns: String (mandatory). The pronouns. Any value or form is
form is allowed. Examples in English include she/her and allowed. Examples in English include "she/her" and "they/them/
they/them/theirs. The value MAY be overridden in the theirs". The value MAY be overridden in the localizations
localizations property (Section 2.7.1). (Section 2.7.1) property.
* contexts: String[Boolean] (optional). The contexts in which to contexts: String[Boolean] (optional). The contexts in which to use
use these pronouns. Also see Section 1.5.1. the pronouns. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of these pronouns in pref: UnsignedInt (optional). The preference of the pronouns in
relation to other pronouns in the same context. Also see relation to other pronouns in the same context. Also see
Section 1.5.4. Section 1.5.3.
"speakToAs": { "speakToAs": {
"grammaticalGender": "neuter", "grammaticalGender": "neuter",
"pronouns": { "pronouns": {
"k19": { "k19": {
"pronouns": "they/them", "pronouns": "they/them",
"pref": 2 "pref": 2
}, },
"k32": { "k32": {
"pronouns": "xe/xir", "pronouns": "xe/xir",
"pref": 1 "pref": 1
} }
} }
} }
Figure 22: speakToAs example Figure 23: Example for the speakToAs Property
2.2.4. titles
Type : Id[Title] (optional). 2.2.5. titles
The job titles or functional positions of the entity represented by titles: Id[Title] (optional). The job titles or functional positions
this Card. A Title object has the following properties: of the entity represented by the Card.
* @type: String. This MUST be Title, if set. A Title object has the following properties:
* name: String (mandatory). The title or role name of the entity @type: String. The JSContact type of the object. The value MUST be
represented by this Card. "Title", if set.
* kind: String (optional, default title). Describes the name: String (mandatory). The title or role name of the entity
organizational or situational kind of this title. Some represented by the Card.
organizations and individuals distinguish between _titles_ as
organizational positions and _roles_ as more temporary
assignments, such as in project management.
The enumerated (Section 1.7.4) values are: kind: String (optional; default: "title"). The organizational or
situational kind of the title. Some organizations and individuals
distinguish between _titles_ as organizational positions and
_roles_ as more temporary assignments such as in project
management.
- title The enumerated (Section 1.7.5) values are:
- role * title
* role
* organizationId: Id (optional). The identifier of the organization organizationId: Id (optional). The identifier of the organization in
in which this title is held. which this title is held.
"titles": { "titles": {
"le9": { "le9": {
"kind": "title", "kind": "title",
"name": "Research Scientist" "name": "Research Scientist"
}, },
"k2": { "k2": {
"kind": "role", "kind": "role",
"name": "Project Leader", "name": "Project Leader",
"organizationId": "o2" "organizationId": "o2"
} }
}, },
"organizations": { "organizations": {
"o2": { "o2": {
"name": "ABC, Inc." "name": "ABC, Inc."
} }
} }
Figure 23: titles example Figure 24: Example for the titles Property
2.3. Contact Properties 2.3. Contact Properties
This section defines properties how to contact the entity represented This section defines how properties contact the entity represented by
by this Card. the Card.
2.3.1. emails 2.3.1. emails
Type: Id[EmailAddress] (optional). emails: Id[EmailAddress] (optional). The email addresses in which to
contact the entity represented by the Card.
The email addresses to contact the entity represented by this Card.
An EmailAddress object has the following properties: An EmailAddress object has the following properties:
* @type: String. This MUST be EmailAddress, if set. @type: String. The JSContact type of the object. The value MUST be
"EmailAddress", if set.
* address: String (mandatory). The email address. This MUST be an address: String (mandatory). The email address. This MUST be an
_addr-spec_ value as defined in Section 3.4.1 of [RFC5322]. _addr-spec_ value as defined in Section 3.4.1 of [RFC5322].
* contexts: String[Boolean] (optional). The contexts in which to contexts: String[Boolean] (optional). The contexts in which to use
use this email address. Also see Section 1.5.1. this email address. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this email pref: UnsignedInt (optional). The preference of the email address in
address in relation to other email addresses. Also see relation to other email addresses. Also see Section 1.5.3.
Section 1.5.4.
* label: String (optional). A custom label for the value, see label: String (optional). A custom label for the value. Also see
Section 1.5.3. Section 1.5.2.
"emails": { "emails": {
"e1": { "e1": {
"contexts": { "contexts": {
"work": true "work": true
}, },
"address": "jqpublic@xyz.example.com" "address": "jqpublic@xyz.example.com"
}, },
"e2": { "e2": {
"address": "jane_doe@example.com", "address": "jane_doe@example.com",
"pref": 1 "pref": 1
} }
} }
Figure 24: emails example Figure 25: Example for the emails Property
2.3.2. onlineServices 2.3.2. onlineServices
Type: Id[OnlineService] (optional). onlineServices: Id[OnlineService] (optional). The online services
that are associated with the entity represented by the Card. This
can be messaging services, social media profiles, and other.
The online services that are associated with the entity represented An OnlineService object has the following properties, of which at
by this Card. This can be messaging services, social media profiles, least the uri or user property MUST be set:
and other. An OnlineService object has the following properties, of
which at least the uri or user property MUST be set:
* @type: String. This MUST be OnlineService, if set. @type: String. The JSContact type of the object. The value MUST be
"OnlineService", if set.
* service: String (optional). The name of the online service or service: String (optional). The name of the online service or
protocol. The name MAY be capitalized the same as on the protocol. The name MAY be capitalized the same as on the
service's website, app or publishing material, but names MUST be service's website, app, or publishing material, but names MUST be
considered equal is they match case-insensitively. Examples are considered equal if they match case-insensitively. Examples are
GitHub, kakao, Mastodon. "GitHub", "kakao", and "Mastodon".
* uri: String (optional). This identifies the entity represented by uri: String (optional). The identifier for the entity represented by
this card at the online service. This MUST be a _URI_ as defined the Card at the online service. This MUST be a _URI_ as defined
in Section 3 of [RFC3986]. in Section 3 of [RFC3986].
* user: String (optional). This names the entity represented by user: String (optional). The name the entity represented by the Card
this Card at the online service. Any free-text value is allowed. at the online service. Any free-text value is allowed. The
The service property SHOULD be set. service property SHOULD be set.
* contexts: String[Boolean] (optional). The contexts in which to contexts: String[Boolean] (optional). The contexts in which to use
use this service. Also see Section 1.5.1. the service. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this service in pref: UnsignedInt (optional). The preference of the service in
relation to other services. Also see Section 1.5.4. relation to other services. Also see Section 1.5.3.
* label: String (optional). A custom label for the value, see label: String (optional). A custom label for the value. Also see
Section 1.5.3. Section 1.5.2.
"onlineServices": { "onlineServices": {
"x1": { "x1": {
"uri": "xmpp:alice@example.com" "uri": "xmpp:alice@example.com"
}, },
"x2": { "x2": {
"service": "Mastodon", "service": "Mastodon",
"user": "@alice@example2.com", "user": "@alice@example2.com",
"uri": "https://example2.com/@alice" "uri": "https://example2.com/@alice"
} }
} }
Figure 25: onlineServices example Figure 26: Example for the onlineServices Property
2.3.3. phones 2.3.3. phones
Type: Id[Phone] (optional). phones: Id[Phone] (optional). The phone numbers by which to contact
the entity represented by the Card.
The phone numbers to contact the entity represented by this Card. A
Phone object has the following properties: Phone object has the following properties:
* @type: String. This MUST be Phone, if set. @type: String. The JSContact type of the object. The value MUST be
"Phone", if set.
* number: String (mandatory). The phone number, as either a URI or number: String (mandatory). The phone number as either a URI or free
free-text. Typical URI schemes are the [RFC3966] tel or [RFC3261] text. Typical URI schemes are "tel" [RFC3966] or "sip" [RFC3261],
sip schemes, but any URI scheme is allowed. but any URI scheme is allowed.
* features: String[Boolean] (optional). The set of contact features features: String[Boolean] (optional). The set of contact features
that this phone number may be used for. The set is represented as that the phone number may be used for. The set is represented as
an object, with each key being a method type. The boolean value an object, with each key being a method type. The boolean value
MUST be true. The enumerated (Section 1.7.4) method type values MUST be "true". The enumerated (Section 1.7.5) method type values
are: are:
- mobile: the number is for a mobile phone. * mobile: this number is for a mobile phone.
* voice: this number supports calling by voice.
- voice: the number is for calling by voice. * text: this number supports text messages (SMS).
* video: this number supports video conferencing.
- text: the number supports text messages (SMS). * main-number: this number is a main phone number such as the
number of the front desk at a company, as opposed to a direct-
- video: the number supports video conferencing.
- main-number: this number is the main phone number, such as the
number of the front-desk at a company, as opposed to a direct-
dial number of an individual employee. dial number of an individual employee.
* textphone: this number is for a device for people with hearing
- textphone: the number is for a device for people with hearing
or speech difficulties. or speech difficulties.
* fax: this number supports sending faxes.
* pager: this number is for a pager or beeper.
- fax: the number is for sending faxes. contexts: String[Boolean] (optional). The contexts in which to use
the number. Also see Section 1.5.1.
- pager: the number is for a pager or beeper.
* contexts: String[Boolean] (optional). The contexts in which to
use this number. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this number in pref: UnsignedInt (optional). The preference of the number in
relation to other numbers. Also see Section 1.5.4. relation to other numbers. Also see Section 1.5.3.
* label: String (optional). A custom label for the value, see label: String (optional). A custom label for the value. Also see
Section 1.5.3. Section 1.5.2.
"phones": { "phones": {
"tel0": { "tel0": {
"contexts": { "contexts": {
"private": true "private": true
}, },
"features": { "features": {
"voice": true "voice": true
}, },
"number": "tel:+1-555-555-5555;ext=5555", "number": "tel:+1-555-555-5555;ext=5555",
"pref": 1 "pref": 1
}, },
"tel3": { "tel3": {
"contexts": { "contexts": {
"work": true "work": true
}, },
"number": "tel:+1-201-555-0123" "number": "tel:+1-201-555-0123"
} }
} }
Figure 26: phones example Figure 27: Example for the phones Property
2.3.4. preferredLanguages 2.3.4. preferredLanguages
Type : Id[LanguagePref] (optional). preferredLanguages : Id[LanguagePref] (optional). The preferred
languages for contacting the entity associated with the Card.
Defines the preferred languages for contacting the entity associated
with this Card.
A LanguagePref object has the following properties: A LanguagePref object has the following properties:
* @type: String. This MUST be LanguagePref, if set. @type: String. The JSContact type of the object. The value MUST be
"LanguagePref", if set.
* language: String (mandatory). The preferred language. This MUST language: String (mandatory). The preferred language. This MUST be
a language tag as defined in [RFC5646]. a language tag as defined in [RFC5646] .
* contexts: String[Boolean] (optional). Defines the contexts in contexts: String[Boolean] (optional). The contexts in which to use
which to use this language. Also see Section 1.5.1. the language. Also see Section 1.5.1.
* pref: UnsignedInt (optional). Defines the preference of this pref: UnsignedInt (optional). The preference of the language in
language in relation to other languages of the same contexts. relation to other languages of the same contexts. Also see
Also see Section 1.5.4. Section 1.5.3.
"preferredLanguages": { "preferredLanguages": {
"l1": { "l1": {
"language": "en", "language": "en",
"contexts": { "contexts": {
"work": true "work": true
}, },
"pref": 1 "pref": 1
}, },
"l2": { "l2": {
skipping to change at page 37, line 49 skipping to change at line 1704
"pref": 2 "pref": 2
}, },
"l3": { "l3": {
"language": "fr", "language": "fr",
"contexts": { "contexts": {
"private": true "private": true
} }
} }
} }
Figure 27: preferredLanguages example Figure 28: Example for the preferredLanguages Property
2.4. Calendaring and Scheduling Properties 2.4. Calendaring and Scheduling Properties
This section defines properties how to schedule calendar events with This section defines properties for scheduling calendar events with
the entity represented by this Card. the entity represented by the Card.
2.4.1. calendars 2.4.1. calendars
Type: Id[Calendar] (optional). calendars: Id[Calendar] (optional). The calendaring resources of the
entity represented by the Card, such as to look up free-busy
information.
These are resources for calendaring, such as calendars to lookup A Calendar object has all properties of the Resource (Section 1.4.4)
free-busy information for the entity represented by this Card. A
Calendar object has all properties of the Resource (Section 1.4.4)
data type, with the following additional definitions: data type, with the following additional definitions:
* The @type property value MUST be Calendar, if set. * The @type property value MUST be "Calendar", if set.
* The kind property is mandatory. Its enumerated (Section 1.7.4) * The kind property is mandatory. Its enumerated (Section 1.7.5)
values are: values are:
- calendar: the resource is a calendar that contains entries such - calendar: The resource is a calendar that contains entries such
as calendar events or tasks. as calendar events or tasks.
- freeBusy: the resource allows for free-busy lookups, for - freeBusy: The resource allows for free-busy lookups, for
example to schedule group events. example, to schedule group events.
"calendars": { "calendars": {
"calA": { "calA": {
"kind": "calendar", "kind": "calendar",
"uri": "webcal://calendar.example.com/calA.ics" "uri": "webcal://calendar.example.com/calA.ics"
}, },
"project-a": { "project-a": {
"kind": "freeBusy", "kind": "freeBusy",
"uri": "https://calendar.example.com/busy/project-a" "uri": "https://calendar.example.com/busy/project-a"
} }
} }
Figure 28: calendars example Figure 29: Example for the calendars Property
2.4.2. schedulingAddresses 2.4.2. schedulingAddresses
Type: Id[SchedulingAddress] (optional). schedulingAddresses: Id[SchedulingAddress] (optional). The
scheduling addresses by which the entity may receive calendar
scheduling invitations.
The scheduling addresses by which the entity may receive calendar A SchedulingAddress object has the following properties:
scheduling invitations. A SchedulingAddress object has the following
properties:
* @type: String. This MUST be SchedulingAddress, if set. @type: String. The JSContact type of the object. The value MUST be
"SchedulingAddress", if set.
* uri: String (mandatory). The address to use for calendar uri: String (mandatory). The address to use for calendar scheduling
scheduling with this contact. This MUST be a URI as defined in with the contact. This MUST be a URI as defined in Section 3 of
Section 3 of [RFC3986]. [RFC3986].
* contexts: String[Boolean] (optional). The contexts in which to contexts: String[Boolean] (optional). The contexts in which to use
use this scheduling address. Also see Section 1.5.1. the scheduling address. Also see Section 1.5.1.
* pref: UnsignedInt (optional). The preference of this scheduling pref: UnsignedInt (optional). The preference of the scheduling
address in relation to other scheduling address. Also see address in relation to other scheduling addresses. Also see
Section 1.5.4. Section 1.5.3.
* label: String (optional). A custom label for the scheduling label: String (optional). A custom label for the scheduling address.
address, see Section 1.5.3. Also see Section 1.5.2.
"schedulingAddresses": { "schedulingAddresses": {
"sched1": { "sched1": {
"uri": "mailto:janedoe@example.com" "uri": "mailto:janedoe@example.com"
} }
} }
Figure 29: schedulingAddresses example Figure 30: Example for the schedulingAddresses Property
2.5. Address and Location Properties 2.5. Address and Location Properties
This section defines properties for postal addresses and geographical This section defines properties for postal addresses and geographical
locations associated with the entity represented by this Card. locations associated with the entity represented by the Card.
2.5.1. addresses 2.5.1. addresses
Type: Id[Address] (optional). addresses: Id[Address] (optional). The addresses of the entity
represented by the Card, such as postal addresses or geographic
A map of address identifiers to Address objects, containing physical locations.
locations.
2.5.1.1. Address object 2.5.1.1. Address Object
An Address object has the following properties: An Address object has the following properties, of which at least one
of components, coordinates, countryCode, full or timeZone MUST be
set:
* @type: String. This MUST be Address, if set. @type: String. The JSContact type of the object. The value MUST be
"Address", if set.
* components: AddressComponent[] (optional). The components components: AddressComponent[] (optional). The components
(Section 2.5.1.2) making up this address. This property MUST be (Section 2.5.1.2) that make up the address. The component list
set if the full property is not set, otherwise it SHOULD be set. MUST have at least one entry that has a kind property value other
The component list MUST have at least one entry having a different than "separator".
kind than separator.
Address components SHOULD be ordered such that their values joined Address components SHOULD be ordered such that when their values
as a String produce a valid full address. If so, implementations are joined as a String, a valid full address is produced. If so,
MUST set the isOrdered property value to true. implementations MUST set the isOrdered property value to "true".
If the address components are ordered, then the defaultSeparator If the address components are ordered, then the defaultSeparator
property and address components of kind separator give guidance property and address components with the kind property value set
what characters to insert between components, but implementations to "separator" give guidance on what characters to insert between
are free to choose any others. In lack of a separator, inserting components, but implementations are free to choose any others.
a single Space character in between address component values is a When lacking a separator, inserting a single space character in
good choice. between address component values is a good choice.
If instead the address components follow no particular order, then If, instead, the address components follow no particular order,
the isOrdered property value MUST be false, the components then the isOrdered property value MUST be "false", the components
property MUST NOT contain a AddressComponent of kind separator and property MUST NOT contain an AddressComponent with the kind
the defaultSeparator property MUST NOT be set. property value set to "separator", and the defaultSeparator
property MUST NOT be set.
* isOrdered: Boolean (optional, default: false). This indicates if isOrdered: Boolean (optional; default: "false"). The indicator if
the address component sequence in the components property is the address components in the components property are ordered.
ordered.
* countryCode: String (optional). The Alpha-2 country code countryCode: String (optional). The Alpha-2 country code
[ISO.3166-1.2006]. [ISO.3166-1].
* coordinates: String (optional). A [RFC5870] "geo:" URI for the coordinates: String (optional). A "geo:" URI [RFC5870] for the
address. address.
* timeZone: String (optional). Identifies the time zone this timeZone: String (optional). The time zone in which the address is
address is located in. This MUST be a time zone name registered located. This MUST be a time zone name registered in the IANA
in the IANA Time Zone Database [IANATZ]. Time Zone Database [IANA-TZ].
* contexts: String[Boolean] (optional). The contexts of the address
information. The boolean value MUST be true. In addition to the
common contexts (Section 1.5.1), allowed key values are:
- billing: an address to be used for billing. contexts: String[Boolean] (optional). The contexts in which to use
this address. The boolean value MUST be "true". In addition to
the common contexts (Section 1.5.1), allowed key values are:
- delivery: an address to be used for delivering physical items. * billing: an address to be used for billing.
* delivery: an address to be used for delivering physical items.
* full: String (optional). This is the full address, including full: String (optional). The full address, including street, region,
street, region or country. The purpose of this property is to or country. The purpose of this property is to define an address,
define an address, even if the individual address components are even if the individual address components are not known.
not known. If the street property is set, the full property
SHOULD NOT be set.
* defaultSeparator: String (optional). The default separator to defaultSeparator: String (optional). The default separator to insert
insert between address component values when concatenating all between address component values when concatenating all address
address component values to a single String. Also see the component values to a single String. Also see the definition of
definition of the separator kind for the AddressComponent object. the kind property value "separator" for the AddressComponent
This property MUST NOT be set if the Address isOrdered property (Section 2.5.1.2) object. The defaultSeparator property MUST NOT
value is false or if the components property is not set. be set if the Address isOrdered property value is "false" or if
the components property is not set.
* pref: UnsignedInt (optional). The preference of this address in pref: UnsignedInt (optional). The preference of the address in
relation to other addresses. Also see Section 1.5.4. relation to other addresses. Also see Section 1.5.3.
* phoneticScript: String (optional). The script used in the value phoneticScript: String (optional). The script used in the value of
of the AddressComponent phonetic property. Also see the AddressComponent phonetic property. Also see Section 1.5.4.
Section 1.5.5.
* phoneticSystem: String (optional). The phonetic system used in phoneticSystem: String (optional). The phonetic system used in the
the AddressComponent phonetic property. Also see Section 1.5.5. AddressComponent phonetic property. Also see Section 1.5.4.
The following example illustrates the use of the address property. The following example illustrates the use of the address property for
Additional examples are in Section 2.5.1.3. "54321 Oak St, Reston, CA 20190, USA". Additional examples are shown
in Section 2.5.1.3.
"addresses": { "addresses": {
"k23": { "k23": {
"contexts": { "contexts": {
"work": true "work": true
}, },
"components": [ "components": [
{ "kind": "number", "value": "54321" }, { "kind": "number", "value": "54321" },
{ "kind": "separator", "value": " " }, { "kind": "separator", "value": " " },
{ "kind": "name", "value": "Oak St" }, { "kind": "name", "value": "Oak St" },
skipping to change at page 41, line 46 skipping to change at line 1885
{ "kind": "separator", "value": " " }, { "kind": "separator", "value": " " },
{ "kind": "postcode", "value": "20190" }, { "kind": "postcode", "value": "20190" },
{ "kind": "country", "value": "USA" } { "kind": "country", "value": "USA" }
], ],
"countryCode": "US", "countryCode": "US",
"defaultSeparator": ", ", "defaultSeparator": ", ",
"isOrdered": true "isOrdered": true
} }
} }
Figure 30: Example of the address "54321 Oak St, Reston, VA Figure 31: Example of an Address in the USA
20190, USA"
2.5.1.2. AddressComponent object 2.5.1.2. AddressComponent Object
An AddressComponent object has the following properties: An AddressComponent object has the following properties:
* @type: String. This MUST be AddressComponent, if set. @type: String. The JSContact type of the object. The value MUST be
"AddressComponent", if set.
* value: String (mandatory). The value of this address component.
* kind: String (mandatory). The kind of this address component.
The enumerated (Section 1.7.4) values are:
- room: the room or suite number or identifier.
- apartment: the extension designation, such as apartment number value: String (mandatory). The value of the address component.
or unit or box number.
- floor: the floor or level this address is located on. kind: String (mandatory). The kind of the address component. The
enumerated (Section 1.7.5) values are:
- building: the building, tower, or condominium this address is * room: the room, suite number, or identifier.
* apartment: the extension designation such as the apartment
number, unit, or box number.
* floor: the floor or level the address is located on.
* building: the building, tower, or condominium the address is
located in. located in.
* number: the street number, e.g., "123". This value is not
- number: the street number, e.g., "123". This value is not restricted to numeric values and can include any value such as
restricted to numeric values, and can include any value such as number ranges ("112-10"), grid style ("39.2 RD"), alphanumerics
number ranges ("112–10"), grid style ("39.2 RD"), alphanumerics ("N6W23001"), or fractionals ("123 1/2").
("N6W23001") or fractionals ("123 1/2"). * name: the street name.
* block: the block name or number.
- name: the street name. * subdistrict: the subdistrict, ward, or other subunit of a
- block: the block name or number.
- subdistrict: the subdistrict, ward or other subunit of a
district. district.
* district: the district name.
- district: the district name. * locality: the municipality, city, town, village, post town, or
other locality.
- locality: the municipality, city, town, village, post-town, or * region: the administrative area such as province, state,
another locality. prefecture, county, or canton.
* postcode: the postal code, post code, ZIP code, or other short
- region: the administrative area, such as province, state,
prefecture, county, canton.
- postcode: the postal code, post code, ZIP code or other short
code associated with the address by the relevant country's code associated with the address by the relevant country's
postal system. postal system.
* country: the country name.
- country: the country name. * direction: the cardinal direction or quadrant, e.g., "north".
* landmark: the publicly known prominent feature that can
- direction: the Cardinal direction or quadrant, e.g., "North". substitute the street name and number, e.g., "White House" or
"Taj Mahal".
- landmark: the publicly known prominent feature that can * postOfficeBox: the post office box number or identifier.
substitute the street name and number, e.g., White House, Taj * separator: a formatting separator between two ordered address
Mahal.
- postOfficeBox: the post office box number or identifier.
- separator: a formatting separator between two ordered address
non-separator components. The value property of the component non-separator components. The value property of the component
includes the verbatim separator, for example a hyphen character includes the verbatim separator, for example, a hyphen
or even an empty string. This value has higher precedence than character or even an empty string. This value has higher
the defaultSeparator property of the Address. Implementations precedence than the defaultSeparator property of the Address.
MUST NOT insert two consecutive separator components, instead Implementations MUST NOT insert two consecutive separator
they SHOULD insert a single separator component with the components; instead, they SHOULD insert a single separator
combined value. This component kind MUST NOT be set if the component with the combined value. This component kind MUST
Address isOrdered property value is false. NOT be set if the Address isOrdered property value is "false".
* phonetic: String (optional). This defines how to pronounce this phonetic: String (optional). The pronounciation of the name
name component. If this property is set, then at least one of the component. If this property is set, then at least one of the
Address object phoneticSystem or phoneticScript properties MUST be Address object phoneticSystem or phoneticScript properties MUST be
set. Also see Section 1.5.5. set. Also see Section 1.5.4.
2.5.1.3. Address examples 2.5.1.3. Additional Address Examples
The following are examples of addresses, in addition to Figure 30. The following example illustrates the use of the address property for
"46, 1 Sukhumvit 51 Alley, Khlong Tan Nuea, Watthana, Bangkok 10110,
Thailand".
"addresses": { "addresses": {
"k25": { "k25": {
"components": [ "components": [
{ "kind": "number", "value": "46" }, { "kind": "number", "value": "46" },
{ "kind": "name", "value": "1 Sukhumvit 51 Alley" }, { "kind": "name", "value": "1 Sukhumvit 51 Alley" },
{ "kind": "subdistrict", "value": "Khlong Tan Nuea" }, { "kind": "subdistrict", "value": "Khlong Tan Nuea" },
{ "kind": "district", "value": " Watthana" }, { "kind": "district", "value": " Watthana" },
{ "kind": "locality", "value": "Bangkok" }, { "kind": "locality", "value": "Bangkok" },
{ "kind": "country", "value": "Thailand" }, { "kind": "country", "value": "Thailand" },
{ "kind": "postcode", "value": "10110" } { "kind": "postcode", "value": "10110" }
], ],
"defaultSeparator": ", ", "defaultSeparator": ", ",
"isOrdered": true "isOrdered": true
} }
} }
Figure 31: Example of the address "46, 1 Sukhumvit 51 Alley, Figure 32: Example of an Address in Thailand
Khlong Tan Nuea, Watthana, Bangkok 10110, Thailand"
The following example illustrates the use of the address property for
"2-7-2 Marunouchi, Chiyoda-ku, Tokyo 100-8994" and its Japanese
localization (Section 2.7.1).
"addresses": { "addresses": {
"k26": { "k26": {
"components": [ "components": [
{ "kind": "block", "value": "2-7" }, { "kind": "block", "value": "2-7" },
{ "kind": "separator", "value": "-" }, { "kind": "separator", "value": "-" },
{ "kind": "number", "value": "2" }, { "kind": "number", "value": "2" },
{ "kind": "separator", "value": " " }, { "kind": "separator", "value": " " },
{ "kind": "district", "value": "Marunouchi" }, { "kind": "district", "value": "Marunouchi" },
{ "kind": "locality", "value": "Chiyoda-ku" }, { "kind": "locality", "value": "Chiyoda-ku" },
skipping to change at page 44, line 42 skipping to change at line 2007
{ "kind": "number", "value": "2" }, { "kind": "number", "value": "2" },
{ "kind": "postcode", "value": "〒100-8994" } { "kind": "postcode", "value": "〒100-8994" }
], ],
"defaultSeparator": "", "defaultSeparator": "",
"full": "〒100-8994東京都千代田区丸ノ内2-7-2", "full": "〒100-8994東京都千代田区丸ノ内2-7-2",
"isOrdered": true "isOrdered": true
} }
} }
} }
Figure 32: Example of an address in Tokyo and its localization Figure 33: Example of an Address in Tokyo and Its Localization in
Section 2.7.1 in Japanese. Japanese
2.6. Resource Properties 2.6. Resource Properties
This section defines properties for digital resources associated with This section defines properties for digital resources associated with
the entity represented by this Card. the entity represented by the Card.
2.6.1. cryptoKeys 2.6.1. cryptoKeys
Type: Id[CryptoKey] (optional). cryptoKeys: Id[CryptoKey] (optional). The cryptographic resources
such as public keys and certificates associated with the entity
represented by the Card.
These are cryptographic resources such as public keys and A CryptoKey object has all properties of the Resource (Section 1.4.4)
certificates associated with the entity represented by this Card. A data type, with the following additional definition:
CryptoKey object has all properties of the Resource (Section 1.4.4)
data type, with the following additional definitions:
* The @type property value MUST be CryptoKey, if set. * The @type property value MUST be "CryptoKey", if set.
The following example shows how refer to an external cryptographic The following example shows how to refer to an external cryptographic
resource. resource.
"cryptoKeys": { "cryptoKeys": {
"mykey1": { "mykey1": {
"uri": "https://www.example.com/keys/jdoe.cer" "uri": "https://www.example.com/keys/jdoe.cer"
} }
} }
Figure 33: cryptoKeys example with external data Figure 34: Example of cryptoKeys with External Data
The following example shows how to embed key data in the CryptoKey. The following example shows how to embed key data in the CryptoKey.
The key data is depicted in multiple lines only for demonstration The key data is depicted in multiple lines only for demonstration
purposes. purposes.
"cryptoKeys": { "cryptoKeys": {
"mykey2": { "mykey2": {
"uri": "data:application/pgp-keys;base64,LS0tLS1CRUdJTiBSU0EgUFVCTElDIEtF "uri": "data:application/pgp-keys;base64,LS0tLS1CRUdJTiBSU0EgUFVC
WS0tLS0tCk1JSUJDZ0tDQVFFQSt4R1ovd2N6OXVnRnBQMDdOc3BvNlUxN2wwWWhGa TElDIEtFWS0tLS0tCk1JSUJDZ0tDQVFFQSt4R1ovd2N6OXVnRnBQMDdOc
UZweHhVNHBUazNMaWZ6OVIzenNJc3UKRVJ3dGE3K2ZXSWZ4T28yMDhldHQvamhza2 3BvNlUxN2wwWWhGaUZweHhVNHBUazNMaWZ6OVIzenNJc3UKRVJ3dGE3K2
lWb2RTRXQzUUJHaDRYQmlweVdvcEt3WjkzSEhhRFZaQUFMaS8yQQoreFRCdFdkRW8 ZXSWZ4T28yMDhldHQvamhza2lWb2RTRXQzUUJHaDRYQmlweVdvcEt3Wjk
3WEdVdWpLRHZDMi9hWkt1a2ZqcE9pVUk4QWhMQWZqbWxjRC9VWjFRUGgwbUhzZ2xS zSEhhRFZaQUFMaS8yQQoreFRCdFdkRW83WEdVdWpLRHZDMi9hWkt1a2Zq
TkNtcEN3Cm13U1hBOVZObWh6K1BpQitEbWw0V1duS1cvVkhvMnVqVFh4cTcrZWZNV cE9pVUk4QWhMQWZqbWxjRC9VWjFRUGgwbUhzZ2xSTkNtcEN3Cm13U1hBO
TRIMmZueTNTZTNLWU9zRlBGR1oxVE4KUVNZbEZ1U2hXckhQdGlMbVVkUG9QNkNWMm VZObWh6K1BpQitEbWw0V1duS1cvVkhvMnVqVFh4cTcrZWZNVTRIMmZueT
1NTDF0aytsN0RJSXFYclFoTFVLREFDZU01cm9NeDBrTGhVV0I4UAorMHVqMUNObE5 NTZTNLWU9zRlBGR1oxVE4KUVNZbEZ1U2hXckhQdGlMbVVkUG9QNkNWMm1
ONEpSWmxDN3hGZnFpTWJGUlU5WjRONll3SURBUUFCCi0tLS0tRU5EIFJTQSBQVUJM NTDF0aytsN0RJSXFYclFoTFVLREFDZU01cm9NeDBrTGhVV0I4UAorMHVq
SUMgS0VZLS0tLS0K" MUNObE5ONEpSWmxDN3hGZnFpTWJGUlU5WjRONll3SURBUUFCCi0tLS0tR
U5EIFJTQSBQVUJMSUMgS0VZLS0tLS0K"
} }
} }
Figure 34: cryptoKeys example with embedded data Figure 35: Example of cryptoKeys with Embedded Data
2.6.2. directories 2.6.2. directories
Type: Id[Directory] (optional). directories: Id[Directory] (optional). The directories containing
information about the entitity represented by the Card.
These are directory service resources, such as entries in a directory A Directory object has all properties of the Resource (Section 1.4.4)
or organizational directories for lookup. A Directory object has all data type, with the following additional definitions:
properties of the Resource (Section 1.4.4) data type, with the
following additional definitions:
* The @type property value MUST be Directory, if set. * The @type property value MUST be "Directory", if set.
* The kind property is mandatory. Its enumerated (Section 1.7.4) * The kind property is mandatory. Its enumerated (Section 1.7.5)
values are: values are:
- directory: the resource is a directory service where the entity - directory: the resource is a directory service that the entity
represented by this Card is part of. This typically is an represented by the Card is a part of. This typically is an
organizational directory that also contains associated organizational directory that also contains associated
entities, e.g., co-workers and management in a company entities, e.g., co-workers and management in a company
directory. directory.
- entry: the resource is a directory entry of the entity - entry: the resource is a directory entry of the entity
represented by this Card. In contrast to the directory type, represented by the Card. In contrast to the "directory" type,
this is the specific URI for the entity _within_ a directory. this is the specific URI for the entity _within_ a directory.
In addition, the Directory object has the following property: In addition, the Directory object has the following property:
* listAs: UnsignedInt (optional). This defines the position of this listAs: UnsignedInt (optional). The position of the directory
directory resource in the list of all Directory objects having the resource in the list of all Directory objects having the same kind
same kind in this Card. If set, the listAs value MUST be higher property value in the Card. If set, the listAs value MUST be
than zero. Multiple directory resources MAY have the same listAs higher than zero. Multiple directory resources MAY have the same
property value, or none. Sorting such entries is implementation- listAs property value or none. Sorting such same-valued entries
specific. is implementation-specific.
"directories": { "directories": {
"dir1": { "dir1": {
"kind": "entry", "kind": "entry",
"uri": "https://dir.example.com/addrbook/jdoe/Jean%20Dupont.vcf" "uri": "https://dir.example.com/addrbook/jdoe/Jean%20Dupont.vcf"
}, },
"dir2": { "dir2": {
"kind": "directory", "kind": "directory",
"uri": "ldap://ldap.example/o=Example%20Tech,ou=Engineering", "uri": "ldap://ldap.example/o=Example%20Tech,ou=Engineering",
"pref": 1 "pref": 1
} }
Figure 35: directories example Figure 36: Example for the directories Property
2.6.3. links 2.6.3. links
Type: Id[Link] (optional). links: Id[Link] (optional). The links to resources that do not fit
any of the other use-case-specific resource properties.
These are links to resources that do not fit any of the other use- A Link object has all properties of the Resource (Section 1.4.4) data
case specific resource properties. A Link object has all properties type, with the following additional definitions:
of the Resource (Section 1.4.4) data type, with the following
additional definitions:
* The @type property value MUST be Link, if set. * The @type property value MUST be "Link", if set.
* The kind property is optional. Its enumerated (Section 1.7.4) * The kind property is optional. Its enumerated (Section 1.7.5)
values are: values are:
- contact: the resource is a URI by which the entity represented - contact: the resource is a URI by which the entity represented
by this Card may be contacted, including web forms or other by the Card may be contacted; this includes web forms or other
media that require user interaction. media that require user interaction.
"links": { "links": {
"link3": { "link3": {
"kind": "contact", "kind": "contact",
"uri": "mailto:contact@example.com", "uri": "mailto:contact@example.com",
"pref": 1 "pref": 1
} }
} }
Figure 36: links example Figure 37: Example for the links Property
2.6.4. media 2.6.4. media
Type: Id[Media] (optional). media: Id[Media] (optional). The media resources such as
photographs, avatars, or sounds that are associated with the
entity represented by the Card.
These are media resources such as photographs, avatars, or sounds A Media object has all properties of the Resource (Section 1.4.4)
associated with the entity represented by this Card. A Media object data type, with the following additional definitions:
has all properties of the Resource (Section 1.4.4) data type, with
the following additional definitions:
* The @type property value MUST be Media, if set. * The @type property value MUST be "Media", if set.
* The kind property is mandatory. Its enumerated (Section 1.7.4) * The kind property is mandatory. Its enumerated (Section 1.7.5)
values are: values are:
- photo: the resource is a photograph or avatar. - photo: the resource is a photograph or avatar.
- sound: the resource is audio media, e.g., to specify the proper - sound: the resource is audio media, e.g., to specify the proper
pronunciation of the name property contents. pronunciation of the name property contents.
- logo: the resource is a graphic image or logo associated with - logo: the resource is a graphic image or logo associated with
the entity represented by this Card. the entity represented by the Card.
"media": { "media": {
"res45": { "res45": {
"kind": "sound", "kind": "sound",
"uri": "CID:JOHNQ.part8.19960229T080000.xyzMail@example.com" "uri": "CID:JOHNQ.part8.19960229T080000.xyzMail@example.com"
}, },
"res47": { "res47": {
"kind": "logo", "kind": "logo",
"uri": "https://www.example.com/pub/logos/abccorp.jpg" "uri": "https://www.example.com/pub/logos/abccorp.jpg"
}, },
"res1": { "res1": {
"kind": "photo", "kind": "photo",
"uri": "..." "uri": "..."
} }
} }
Figure 37: media example Figure 38: Example for the media Property
2.7. Multilingual Properties 2.7. Multilingual Properties
This section defines properties how to localize the content of this This section defines properties for localizing the content of the
Card in human languages. Card in human languages.
2.7.1. localizations 2.7.1. localizations
Type: String[PatchObject] (optional). localizations: String[PatchObject] (optional). The property values
localized to languages other than the main language
This localizes property values in this Card to languages other than (Section 2.1.5) of the Card. Localizations provide language-
the main language. Localizations provide language-specific specific alternatives for existing property values and SHOULD NOT
alternatives for existing property values and SHOULD NOT add new add new properties. The keys in the localizations property value
properties. are language tags [RFC5646]; the values are of type PatchObject
and localize the Card in that language tag. The paths in the
The keys in the localizations property object are language tags PatchObject are relative to the Card that includes the
[RFC5646]. The values are patch objects which localize the Card in localizations property. A patch MUST NOT target the localizations
the respective language tag. The paths in the PatchObject are property.
relative to the Card that includes the localizations property. A
patch MUST NOT target the localizations property.
Conceptually, a Card is localized as follows: Conceptually, a Card is localized as follows:
* Determine the language tag in which this Card should be localized * Determine the language tag in which the Card should be localized.
in.
* If the localizations property includes a key for that language, * If the localizations property includes a key for that language,
obtain the PatchObject value. If there is no such key, stop. obtain the PatchObject value. If there is no such key, stop.
* Create a copy of the Card, but do not copy the localizations * Create a copy of the Card, but do not copy the localizations
property. property.
* Apply all patches in the PatchObject to the copy of the Card. * Apply all patches in the PatchObject to the copy of the Card.
* Optionally, set the language property in the copy of the Card. * Optionally, set the language property in the copy of the Card.
* Use the patched copy of the Card as the localized variant of the * Use the patched copy of the Card as the localized variant of the
original Card. original Card.
A patch in the PatchObject may contain any value type. Its value A patch in the PatchObject may contain any value type. Its value
MUST be a valid value according to the definition of the patched MUST be a valid value according to the definition of the patched
property. property.
Figure 38 localizes the name property by completely replacing its Figure 39 localizes the name property by completely replacing its
contents in Ukrainian language with Cyrillic script. contents in Ukrainian language with Cyrillic script.
{ {
"name": { "name": {
"components": [ "components": [
{ "kind": "title", "value": "Mr." }, { "kind": "title", "value": "Mr." },
{ "kind": "given", "value": "Ivan" }, { "kind": "given", "value": "Ivan" },
{ "kind": "given2", "value": "Petrovich" }, { "kind": "given2", "value": "Petrovich" },
{ "kind": "surname", "value": "Vasiliev" } { "kind": "surname", "value": "Vasiliev" }
] ]
skipping to change at page 49, line 42 skipping to change at line 2235
{ "kind": "title", "value": "г-н" }, { "kind": "title", "value": "г-н" },
{ "kind": "given", "value": "Иван" }, { "kind": "given", "value": "Иван" },
{ "kind": "given2", "value": "Петрович" }, { "kind": "given2", "value": "Петрович" },
{ "kind": "surname", "value": "Васильев" } { "kind": "surname", "value": "Васильев" }
] ]
} }
} }
} }
} }
Figure 38: Example for localizing a top-level property Figure 39: Example of Localizing a Top-Level Property
Figure 39 localizes the title name by patching _inside_ the titles Figure 40 localizes the title name by patching _inside_ the titles
property. All properties but the name property in the Title object property. All properties, except the name property in the Title
are left as-is. object, are left as is.
"name": { "name": {
"full": "Gabriel García Márquez" "full": "Gabriel García Márquez"
}, },
"titles": { "titles": {
"t1": { "t1": {
"kind": "title", "kind": "title",
"name": "novelist" "name": "novelist"
} }
}, },
"localizations": { "localizations": {
"es": { "es": {
"titles/t1/name": "autor" "titles/t1/name": "escritor"
} }
} }
Figure 39: Example for localizing a nested property Figure 40: Example of Localizing a Nested Property
2.8. Additional Properties 2.8. Additional Properties
This section defines properties for which none of the previous This section defines properties for which none of the previous
sections are appropriate. sections are appropriate.
2.8.1. anniversaries 2.8.1. anniversaries
Type : Id[Anniversary] (optional). anniversaries: Id[Anniversary] (optional). The memorable dates and
events for the entity represented by the Card.
These are memorable dates and events for the entity represented by
this Card. An Anniversary object has the following properties:
* @type: String. This MUST be Anniversary, if set.
* kind: String (mandatory). Specifies the kind of the anniversary.
The enumerated (Section 1.7.4) values are:
- birth: a birthday anniversary An Anniversary object has the following properties:
- death: a deathday anniversary @type: String. The JSContact type of the object. The value MUST be
"Anniversary", if set.
- wedding: a wedding day anniversary kind: String (mandatory). The kind of anniversary. The enumerated
(Section 1.7.5) values are:
* date: PartialDate|Timestamp (mandatory, defaultType: PartialDate). * birth: a birthday anniversary
* death: a deathday anniversary
* wedding: a wedding day anniversary
The date of this anniversary in the Gregorian calendar. This MUST date: PartialDate|Timestamp (mandatory; defaultType: PartialDate). T
either be a whole or partial calendar date or a complete UTC he date of the anniversary in the Gregorian calendar. This MUST
be either a whole or partial calendar date or a complete UTC
timestamp (see the definition of the Timestamp and PartialDate timestamp (see the definition of the Timestamp and PartialDate
object types below). object types below).
* place: Address (optional). An address associated with this place: Address (optional). An address associated with this
anniversary, e.g., the place of birth or death. anniversary, e.g., the place of birth or death.
A PartialDate object represents a complete or partial calendar date A PartialDate object represents a complete or partial calendar date
in the Gregorian calendar. It represents either a complete date, or in the Gregorian calendar. It represents a complete date, a year, a
a year, or a month in a year, or a day in a month. It has the month in a year, or a day in a month. It has the following
following properties, of which at least year or month and day MUST be properties:
set:
* @type: String. This MUST be PartialDate, if set. @type: String. The JSContact type of the object. The value MUST be
"PartialDate", if set.
* year: UnsignedInt (optional). This is the calendar year. year: UnsignedInt (optional). The calendar year.
* month: UnsignedInt (optional). This is the calendar month, month: UnsignedInt (optional). The calendar month, represented as
represented as the integers 1 <= month <= 12. If this property is the integers 1 <= month <= 12. If this property is set, then
set then either year or day MUST be set. either the year or the day property MUST be set.
* day: UnsignedInt (optional). This is the calendar month day, day: UnsignedInt (optional). The calendar month day, represented as
represented as the integers 1 <= day <= 31, depending on the the integers 1 <= day <= 31, depending on the validity within the
validity within the month and year. If this property is set then month and year. If this property is set, then the month property
month MUST be set. MUST be set.
* calendarScale: String (optional). This is the calendar system in calendarScale: String (optional). The calendar system in which this
which this date occurs, in lowercase. This MUST be either a CLDR- date occurs, in lowercase. This MUST be either a calendar system
registered calendar system name [RFC7529] or a vendor-specific name registered as a Common Locale Data Repository (CLDR)
value. The year, month and day still MUST be represented in the [RFC7529] or a vendor-specific value. The year, month, and day
Gregorian calendar. Note that the year property might be required still MUST be represented in the Gregorian calendar. Note that
to convert the date between the Gregorian calendar and the the year property might be required to convert the date between
respective calendar system. the Gregorian calendar and the respective calendar system.
A Timestamp object has the following properties: A Timestamp object has the following properties:
* @type: String. This MUST be Timestamp, if set. @type: String. The JSContact type of the object. The value MUST be
"Timestamp", if set.
* utc: UTCDateTime (mandatory). Specifies the point in time in UTC utc: UTCDateTime (mandatory). The point in time in UTC time.
time.
Figure 40 illustrates anniversaries with partial dates and timestamp. Figure 41 illustrates anniversaries with partial dates and a
Note how the @type property is set for the Timestamp object value timestamp. Note how the @type property is set for the Timestamp
according to the rules defined Section 1.3.4. object value according to the rules defined in Section 1.3.4.
"anniversaries": { "anniversaries": {
"k8": { "k8": {
"kind": "birth", "kind": "birth",
"date": { "date": {
"year": 1953, "year": 1953,
"month": 4, "month": 4,
"day": 15 "day": 15
} }
}, },
skipping to change at page 52, line 26 skipping to change at line 2348
"date": { "date": {
"@type": "Timestamp", "@type": "Timestamp",
"utc": "2019-10-15T23:10:00Z" "utc": "2019-10-15T23:10:00Z"
}, },
"place": { "place": {
"full": "4445 Tree Street\nNew England, ND 58647\nUSA" "full": "4445 Tree Street\nNew England, ND 58647\nUSA"
} }
} }
} }
Figure 40: anniversaries example Figure 41: Example for the anniversaries Property
2.8.2. keywords 2.8.2. keywords
Type: String[Boolean] (optional). A set of free-text keywords, also keywords: String[Boolean] (optional). The set of free-text keywords,
known as _tags_. The set is represented as an object, with each key also known as _tags_. Each key in the set is a keyword, each
being a keyword. The boolean value MUST be true. boolean value MUST be "true".
"keywords": { "keywords": {
"internet": true, "internet": true,
"IETF": true "IETF": true
} }
Figure 41: keywords example Figure 42: Example for the keywords Property
2.8.3. notes 2.8.3. notes
Type: Id[Note] (optional). notes: Id[Note] (optional). The free-text notes that are associated
with the Card.
Free-text notes associated with this Card. A Note object has the A Note object has the following properties:
following properties:
* @type: String. This MUST be Note, if set. @type: String. The JSContact type of the object. The value MUST be
"Note", if set.
* note: String (mandatory). The free text value of this note. note: String (mandatory). The free-text value of this note.
* created: UTCDateTime (optional). The date and time when this note created: UTCDateTime (optional). The date and time when this note
was created. was created.
* author: Author (optional). The author of this note. author: Author (optional). The author of this note.
An Author object has the following properties, of which at least one An Author object has the following properties, of which at least one
other than @type MUST be set: property other than @type MUST be set:
* @type: String. This MUST be Author, if set. @type: String. The JSContact type of the object. The value MUST be
"Author", if set.
* name: String (optional). The name of this author. name: String (optional). The name of this author.
* uri: String (optional). A URI value that identifies the author. uri: String (optional). The URI value that identifies the author.
"notes": { "notes": {
"n1": { "n1": {
"note": "Open office hours are 1600 to 1715 EST, Mon-Fri", "note": "Open office hours are 1600 to 1715 EST, Mon-Fri",
"created": "2022-11-23T15:01:32Z", "created": "2022-11-23T15:01:32Z",
"author": { "author": {
"name": "John" "name": "John"
} }
} }
} }
Figure 42: notes example Figure 43: Example for the notes Property
2.8.4. personalInfo 2.8.4. personalInfo
Type: Id[PersonalInfo] (optional). personalInfo: Id[PersonalInfo] (optional). The personal information
of the entity represented by the Card.
Defines personal information about the entity represented by this A PersonalInfo object has the following properties:
Card. A PersonalInfo object has the following properties:
* @type: String. This MUST be PersonalInfo, if set. @type: String. The JSContact type of the object. The value MUST be
"PersonalInfo", if set.
* kind: String (mandatory). Specifies the kind of this personal kind: String (mandatory). The kind of personal information. The
information. The enumerated (Section 1.7.4) values are: enumerated (Section 1.7.5) values are:
- expertise: a field of expertise or credential * expertise: a field of expertise or a credential
- hobby: a hobby * hobby: a hobby
- interest: an interest * interest: an interest
* value: String (mandatory). The actual information. value: String (mandatory). The actual information.
* level: String (optional). Indicates the level of expertise, or level: String (optional). The level of expertise or engagement in
engagement in hobby or interest. The enumerated (Section 1.7.4) hobby or interest. The enumerated (Section 1.7.5) values are:
values are:
- high * high
- medium * medium
- low * low
* listAs: UnsignedInt (optional). This defines the position of this listAs: UnsignedInt (optional). The position of the personal
personal information in the list of all PersonalInfo objects information in the list of all PersonalInfo objects that have the
having the same kind in this Card. If set, the listAs value MUST same kind property value in the Card. If set, the listAs value
be higher than zero. Multiple personal information entries MAY MUST be higher than zero. Multiple personal information entries
have the same listAs property value, or none. Sorting such MAY have the same listAs property value or none. Sorting such
entries is implementation-specific. same-valued entries is implementation-specific.
* label: String (optional). A custom label. See Section 1.5.3. label: String (optional). A custom label. See Section 1.5.2.
"personalInfo": { "personalInfo": {
"pi2": { "pi2": {
"kind": "expertise", "kind": "expertise",
"value": "chemistry", "value": "chemistry",
"level": "high" "level": "high"
}, },
"pi1": { "pi1": {
"kind": "hobby", "kind": "hobby",
"value": "reading", "value": "reading",
"level": "high" "level": "high"
}, },
"pi6": { "pi6": {
"kind": "interest", "kind": "interest",
"value": "r&b music", "value": "r&b music",
"level": "medium" "level": "medium"
} }
} }
Figure 43: personalInfo example Figure 44: Example for the personalInfo Property
3. IANA Considerations 3. IANA Considerations
3.1. Media Type Registration 3.1. Media Type Registration
[I-D.ietf-calext-jscontact] defines a media type for use with This document defines a media type for use with JSContact data
JSContact data formatted in JSON. formatted in JSON.
Type name: Type name: application
application
Subtype name: Subtype name: jscontact+json
jscontact+json
Required parameters: Required parameters: None
None
Optional parameters: Optional parameters: version
version This parameter conveys the version of the JSContact data
in the body part. It MUST NOT occur more than once. If this
parameter is set, then the values of all JSContact version
(Table 2) properties in the body part MUST match the parameter
value.
Encoding considerations: This parameter conveys the version of the JSContact data in the
This is the same as the encoding considerations of application/ body part. It MUST NOT occur more than once. If this parameter
json, as specified in Section 11 of [RFC8259]. is set, then the values of all JSContact version (Table 2)
properties in the body part MUST match the parameter value.
Security considerations: Encoding considerations: This is the same as the encoding
See Section 4 of [I-D.ietf-calext-jscontact]. considerations of application/json, as specified in Section 11 of
[RFC8259].
Interoperability considerations: Security considerations: See Section 4 of RFC 9553.
While JSContact is designed to avoid ambiguities as much as
possible, when converting objects from other contact formats to/
from JSContact, it is possible that differing representations for
the same logical data or ambiguities in interpretation might
arise. The semantic equivalence of two JSContact objects may be
determined differently by different applications, for example,
where URL values differ in case between the two objects.
Published specification: Interoperability considerations: While JSContact is designed to
TBD avoid ambiguities as much as possible, when converting objects
from other contact formats to/from JSContact, it is possible that
differing representations for the same logical data or ambiguities
in interpretation might arise. The semantic equivalence of two
JSContact objects may be determined differently by different
applications, for example, where URL values differ in case between
the two objects.
Applications that use this media type: Published specification: RFC 9553
Applications that currently make use of the text/vcard media type
can use this as an alternative.
Fragment identifier considerations: Applications that use this media type: Applications that currently
A JSON Pointer fragment identifier may be used, as defined in make use of the text/vCard media type can use this as an
[RFC6901], Section 6. alternative.
Fragment identifier considerations: A JSON Pointer fragment
identifier may be used, as defined in [RFC6901], Section 6.
Additional information: Additional information:
Magic number(s): N/A
Magic number(s): N/A
File extensions(s): N/A File extensions(s): N/A
Macintosh file type code(s): N/A Macintosh file type code(s): N/A
Person & email address to contact for further information: Person & email address to contact for further information:
calsify@ietf.org calsify@ietf.org
Intended usage: Intended usage: COMMON
COMMON
Restrictions on usage: Restrictions on usage: N/A
N/A
Author: Author: See the "Authors' Addresses" section of RFC 9553.
See the "Author's Address" section of [I-D.ietf-calext-jscontact].
Change controller: Change controller: IETF
IETF
3.2. Creation of the "JSContact" Registry Group 3.2. Creation of the JSContact Registry Group
IANA is asked to create the "JSContact" registry group. The new IANA has created the "JSContact" registry group. The new registry
registry definitions in the following sections all belong to that definitions in the following sections all belong to that group.
group.
3.3. Registry Policy and Change Procedures 3.3. Registry Policy and Change Procedures
Registry assignments that introduce backwards-incompatible Registry assignments that introduce backwards-incompatible
(Section 1.9) changes require the JSContact major version to change, (Section 1.9) changes require the JSContact major version to change;
other changes only require to change the minor version. The registry other changes only require a change to the minor version. The
policy for assignments that require the JSContact major version to registry policy for assignments that require the JSContact major
change is Standards Action ([RFC8126], Section 4.9). The registry version to change is Standards Action ([RFC8126], Section 4.9). The
policy for other assignments is Specification Required ([RFC8126], registry policy for other assignments is Specification Required
Section 4.6). ([RFC8126], Section 4.6).
The Designated Expert decides if a major or minor version change is The designated expert (DE) decides if a major or minor version change
required and assigns the new version to the Version Registry is required and assigns the new version to the "JSContact Version"
(Section 3.4). Version numbers increment by one, and a major version registry (Section 3.4). Version numbers increment by one, and a
change resets the minor version to zero. An assignment may apply major version change resets the minor version to zero. An assignment
multiple changes and to more than one registry at once, in which case may apply multiple changes and to more than one registry at once, in
a single version change is sufficient. If the registry policy is which case a single version change is sufficient. If the registry
Specification Required, then the Designated Expert may decide that it policy is Specification Required, then the DE may decide that it is
is enough to document the new assignment in the Description item of enough to document the new assignment in the Description item of the
the respective registry. respective registry.
A registration MUST have an intended usage of common, reserved, or A registration MUST have an intended usage of "common", "reserved",
obsolete. or "obsolete".
* A common usage denotes an item with shared semantics and syntax * A "common" usage denotes an item with shared semantics and syntax
across systems. Up-to-date systems MUST expect such items to across systems. Up-to-date systems MUST expect such items to
occur in JSContact data. occur in JSContact data.
* A reserved usage reserves an item in the registry without * A "reserved" usage reserves an item in the registry without
assigning semantics to avoid name collisions with future assigning semantics to avoid name collisions with future
extensions or protocol use. extensions or protocol use. Implementations MUST NOT expect or
add items with such names outside the protocols or extensions that
use them; otherwise, any such JSContact data is invalid.
* An obsolete usage denotes an item that is no longer expected to be * An "obsolete" usage denotes an item that is no longer expected to
added by up-to-date systems. A new assignment has probably been be added by up-to-date systems. A new assignment has probably
defined covering the obsolete item's semantics. been defined, covering the obsolete item's semantics.
Implementations MUST expect such items to occur in JSContact data
up to the "Until Version" registry field, inclusively. They MUST
NOT add such items for any version after which the item got
obsolete; otherwise, any such JSContact data is invalid.
The intended usage of registry items may change between versions, but
the DE must carefully consider the impact on existing implementations
and standards before doing so.
The registration procedure is not a formal standards process but The registration procedure is not a formal standards process but
rather an administrative procedure intended to allow community rather an administrative procedure intended to allow community
comment and check whether it is coherent without excessive time comments and to check whether it is coherent without excessive time
delay. It is designed to encourage vendors to document and register delay. It is designed to encourage vendors to document and register
new items they add for use cases not covered by the original new items they add for use cases not covered by the original
specification, leading to increased interoperability. specification, leading to increased interoperability.
3.3.1. Preliminary Community Review 3.3.1. Preliminary Community Review
Notice of a potential new registration MUST be sent to the Calext Notice of a potential new registration MUST be sent to the Calext WG
mailing list <calsify@ietf.org> for review. This mailing list is mailing list <calsify@ietf.org> for review. This mailing list is
appropriate to solicit community feedback on a proposed registry appropriate for soliciting community feedback on a proposed registry
assignment. assignment.
The intent of the public posting to this list is to solicit comments The intent of the public posting to this list is to solicit comments
and feedback on the choice of the item name or value, the unambiguity and feedback on the choice of the item name or value, the unambiguity
of its description, and a review of any interoperability or security of its description, and a review of any interoperability or security
considerations. The submitter may submit a revised registration considerations. The submitter may submit a revised registration
proposal or abandon the registration completely at any time. proposal or abandon the registration completely at any time.
3.3.2. Submit Request to IANA 3.3.2. Submit Request to IANA
Registration requests can be sent to <iana@iana.org>. Registration requests can be sent to IANA <iana@iana.org>.
3.3.3. Designated Expert Review 3.3.3. Designated Expert Review
The primary concern of the designated expert (DE) is preventing name The primary concern of the DE is preventing name collisions and
collisions and encouraging the submitter to document security and encouraging the submitter to document security and privacy
privacy considerations. considerations.
A new type name, property name or enumerated value MUST NOT differ A new type name, property name, or enumerated value MUST NOT differ
only in case from an already registered name or value. only in case from an already-registered name or value.
For a common-use registration, the DE is expected to confirm that For a common-use registration, the DE is expected to confirm that
suitable documentation is available to ensure interoperability. The suitable documentation is available to ensure interoperability. The
DE should also verify that the new assignment does not conflict with DE should also verify that the new assignment does not conflict with
work that is active or already published within the IETF. work that is active or already published within the IETF.
The DE will either approve or deny the registration request and The DE will either approve or deny the registration request and
publish a notice of the decision to the Calext WG mailing list or its publish a notice of the decision to the Calext WG mailing list or its
successor, as well as inform IANA. A denial notice must be justified successor, as well as inform IANA. A denial notice must be justified
by an explanation, and, in the cases where it is possible, concrete by an explanation, and in the cases where it is possible, concrete
suggestions on how the request can be modified to become acceptable suggestions on how the request can be modified to become acceptable
should be provided. should be provided.
3.3.4. Change Procedures 3.3.4. Change Procedures
Once a JSContact registry group item has been published by IANA, the Once a JSContact registry group item has been published by IANA, the
change controller may request a change to its definition. The same Change Controller may request a change to its definition. The same
procedure that would be appropriate for the original registration procedure that would be appropriate for the original registration
request is used to process a change request. request is used to process a change request.
JSContact registrations dot not get deleted; instead, items that are JSContact registrations do not get deleted; instead, items that are
no longer believed appropriate for use are declared obsolete by a no longer believed appropriate for use are declared obsolete by a
change to their "intended usage" field; such items will be clearly change to their "Intended Usage" field; such items will be clearly
marked in the IANA registry. marked in the IANA registry.
Significant changes to a JSContact registry item's definition should Significant changes to a JSContact registry item's definition should
be requested only when there are serious omissions or errors in the be requested only when there are serious omissions or errors in the
published specification, as such changes may cause interoperability published specification, as such changes may cause interoperability
issues. When review is required, a change request may be denied if issues. When review is required, a change request may be denied if
it renders entities that were valid under the previous definition it renders entities that were valid under the previous definition
invalid under the new definition. invalid under the new definition.
3.4. Creation of the "JSContact Version" Registry 3.4. Creation of the JSContact Version Registry
IANA is asked to create the "JSContact Version" registry. The IANA has created the "JSContact Version" registry. The purpose of
purpose of this new registry is to define the allowed value range of this new registry is to define the allowed value range of JSContact
JSContact major and minor version numbers. major and minor version numbers.
The registry entries sort numerically ascending by the "Major The registry entries sort numerically in ascending order by the
Version" column. "Major Version" column, entries with equal "Major Version" sort
numerically in ascending order by the "Minor Version" column.
The registry process is outlined in Section 3.3. The registry process is outlined in Section 3.3.
3.4.1. "JSContact Version" Registry Template 3.4.1. JSContact Version Registry Template
Major Version: This is the numeric value of a JSContact major Major Version: The numeric value of a JSContact major version
version number. It MUST be a positive integer. number. It MUST be a positive integer.
Highest Minor Version: This is the maximum numeric value of a Highest Minor Version: The maximum numeric value of a JSContact
JSContact minor version for the given major version. It MUST be minor version for the given major version. It MUST be zero or a
zero or a positive integer. All numbers less than or equal this positive integer. All numbers less than or equal to this value
value are valid minor version values for the given major version. are valid minor version values for the given major version.
3.4.2. Initial Contents for the "JSContact Version" Registry 3.4.2. Initial Contents of the JSContact Version Registry
The following table lists the initial valid major and minor version The following table lists the initial valid major and minor version
number ranges. number ranges.
+===============+=======================+ +===============+=======================+===========+
| Major Version | Highest Minor Version | | Major Version | Highest Minor Version | Reference |
+===============+=======================+ +===============+=======================+===========+
| 1 | 0 | | 1 | 0 | RFC 9553 |
+---------------+-----------------------+ +---------------+-----------------------+-----------+
Table 1: JSContact Versions Table 1: JSContact Version Registry
3.5. Creation of the "JSContact Properties" Registry 3.5. Creation of the JSContact Properties Registry
IANA is asked to create the "JSContact Properties" registry. The IANA has created the "JSContact Properties" registry. The purpose of
purpose of this new registry is to allow interoperability of this new registry is to allow interoperability of extensions to
extensions to JSContact objects JSContact objects.
The registry entries sort alphabetically ascending by the "Property The registry entries sort alphabetically in ascending order by the
Name" column first, "Property Context" second, "Since Version" third. following columns: "Property Name" first, "Property Context" second,
Equal entries sort in any order. and "Since Version" third. Equal entries sort in any order.
The registry process for a new property is outlined in Section 3.3. The registry process for a new property is outlined in Section 3.3.
3.5.1. "JSContact Properties" Registry Template 3.5.1. JSContact Properties Registry Template
Property Name: This is the name of the property. The property name Property Name: The name of the property. The property name MUST NOT
MUST NOT already be registered for any of the object types listed already be registered for any of the object types listed in the
in the "Property Context" field of this registration. Other "Property Context" field of this registration. Other object types
object types MAY already have registered a different property with MAY have already registered a different property with the same
the same name; however, the same name MUST only be used when the name; however, the same name MUST only be used when the semantics
semantics are analogous. are analogous.
Property Type: This is the type of this property, using type Property Type: For properties with intended usage other than
signatures, as specified in Section 1.3.2. The property type MUST "reserved", this is the type of this property, using type
be registered in the "JSContact Types" registry. signatures as specified in Section 1.3.2. The property type MUST
be registered in the "JSContact Types" registry. For reserved
property names, the value MUST be the verbatim string "not
applicable".
Property Context: This is a comma-separated list of JSContact object Property Context: A comma-separated list of JSContact object types
types (Section 3.6.2) that contain this property. (Section 3.6.2) that contain the property. For reserved property
names, the value MAY be the verbatim string "not applicable".
Reference or Description: This is a brief description or RFC number Intended Usage: May be "common", "reserved", or "obsolete".
and section reference where the property is specified (omitted for
"reserved" property names). This must include references to all
RFC documents where this property is introduced or updated.
Intended Usage: This may be "common", "reserved", or "obsolete". Since Version: The JSContact version on which the property
definition is based. The version MUST be one of the allowed
values of the version property in the "JSContact Version" registry
(see Table 1).
Since Version: This defines the JSContact version on which this Until Version: The JSContact version after which the property was
property definition is based on. The version MUST be one of the obsoleted; therefore, it MUST NOT be used in later versions. The
allowed values of the version property in the JSContact Enum Value Until Version value either MUST NOT be set or MUST be one of the
allowed values of the version property in the "JSContact Version"
registry (see Table 1). registry (see Table 1).
Until Version: This defines the JSContact version after which this Change Controller: Person or entity responsible for requesting a
property got obsoleted and MUST NOT be used in later versions. change to the entry's definition ("IETF" for RFCs from the IETF
The Until Version value either MUST NOT be set, or be one of the stream).
allowed values of the version property in the JSContact Enum Value
registry (see Table 1).
Change Controller: This is who may request a change to this entry's Reference or Description: A brief description or RFC number and
definition (IETF for RFCs from the IETF stream). section reference where the property is specified. This must
include references to all RFC documents where this property is
introduced or updated. For reserved property names, the reference
or description MAY be omitted.
3.5.2. Initial Contents for the "JSContact Properties" Registry 3.5.2. Initial Contents of the JSContact Properties Registry
The following table lists the initial common usage entries of the The following table lists the initial "common" usage entries of the
"JSContact Properties" registry. The Since Version for all "JSContact Properties" registry. For all properties, the Since
properties is 1.0. The Until Version for all properties is not set. Version is "1.0", the Until Version is not set, the Change Controller
All RFC section references are for [I-D.ietf-calext-jscontact]. The is "IETF", and RFC section references are for RFC 9553.
change controller for all these properties is IETF.
+===================+=====================+=========================+============+ +=====================+=======================+====================+
|Property Name |Property Type |Property Context |Reference or| | Property Name | Property Type | Property Context |
| | | |Description | +=====================+=======================+====================+
+===================+=====================+=========================+============+ | @type | String | Address |
|@type |String |Address, |Section | | | | (Section 2.5.1.1), |
| | |AddressComponent, |2.5.1, | | | | AddressComponent |
| | |Anniversary, Author, |Section | | | | (Section 2.5.1.2), |
| | |Card, Calendar, |2.8.1, | | | | Anniversary |
| | |CryptoKey, Directory, |Section | | | | (Section 2.8.1), |
| | |EmailAddress, |2.1.1, | | | | Author |
| | |LanguagePref, Link, |Section | | | | (Section 2.8.3), |
| | |Media, Name, |2.4.1, | | | | Card |
| | |NameComponent, Nickname, |Section | | | | (Section 2.1.1), |
| | |Note, OnlineService, |2.6.1, | | | | Calendar |
| | |Organization, OrgUnit, |Section | | | | (Section 2.4.1), |
| | |PartialDate,PersonalInfo,|2.6.2, | | | | CryptoKey |
| | |Phone, Pronouns, |Section | | | | (Section 2.6.1), |
| | |Relation, |2.3.1, | | | | Directory |
| | |SchedulingAddress, |Section | | | | (Section 2.6.2), |
| | |SpeakToAs, Timestamp, |2.3.4, | | | | EmailAddress |
| | |Title |Section | | | | (Section 2.3.1), |
| | | |2.6.3, | | | | LanguagePref |
| | | |Section | | | | (Section 2.3.4), |
| | | |2.6.4, | | | | Link |
| | | |Section | | | | Section 2.6.3), |
| | | |2.2.1, | | | | Media |
| | | |Section | | | | (Section 2.6.4), |
| | | |2.2.1.3, | | | | Name |
| | | |Section | | | | (Section 2.2.1.1), |
| | | |2.8.3, | | | | NameComponent |
| | | |Section | | | | (Section 2.2.1.2), |
| | | |2.3.2, | | | | Nickname |
| | | |Section | | | | (Section 2.2.2), |
| | | |2.2.2, | | | | Note |
| | | |Section | | | | (Section 2.8.3), |
| | | |2.8.4, | | | | OnlineService |
| | | |Section | | | | (Section 2.3.2), |
| | | |2.3.3, | | | | Organization |
| | | |Section | | | | (Section 2.2.3), |
| | | |2.2.3, | | | | OrgUnit |
| | | |Section | | | | (Section 2.2.3), |
| | | |2.1.8, | | | | PartialDate |
| | | |Section | | | | (Section 2.8.1), |
| | | |2.4.2, | | | | PersonalInfo |
| | | |Section | | | | (Section 2.8.4), |
| | | |2.2.4 | | | | Phone |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.3), |
|version |String |Card |Section | | | | Pronouns |
| | | |2.1.2 | | | | (Section 2.2.4), |
+-------------------+---------------------+-------------------------+------------+ | | | Relation |
|address |String |EmailAddress |Section | | | | (Section 2.1.8), |
| | | |2.3.1 | | | | SchedulingAddress |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.4.2), |
|addresses |Id[Address] |Card |Section | | | | SpeakToAs |
| | | |2.5.1 | | | | (Section 2.2.4), |
+-------------------+---------------------+-------------------------+------------+ | | | Timestamp |
|anniversaries |Id[Anniversary] |Card |Section | | | | (Section 2.8.1), |
| | | |2.8.1 | | | | Title |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.5) |
|author |Author |Note |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.3 | | address | String | EmailAddress |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.1) |
|calendars |Id[Calendar] |Card |Section | +---------------------+-----------------------+--------------------+
| | | |2.4.1 | | addresses | Id[Address] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.5.1.1) |
|calendarScale |String |PartialDate |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.1 | | anniversaries | Id[Anniversary] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.1) |
|components |AddressComponent[] |Address |Section | +---------------------+-----------------------+--------------------+
| | | |2.5.1 | | author | Author | Note |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.3) |
|components |NameComponent[] |Name |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1 | | calendars | Id[Calendar] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.4.1) |
|contexts |String[Boolean] |Address, Calendar, |Section | +---------------------+-----------------------+--------------------+
| | |CryptoKey, Directory, |1.5.1, | | calendarScale | String | PartialDate |
| | |EmailAddress, |Section | | | | (Section 2.8.1) |
| | |LanguagePref, Link, |2.5.1, | +---------------------+-----------------------+--------------------+
| | |Media, Nickname, |Section | | components | AddressComponent[] | Address |
| | |OnlineService, |2.4.1, | | | | (Section 2.5.1.1) |
| | |Organization, Phone, |Section | +---------------------+-----------------------+--------------------+
| | |Pronouns, |2.6.1, | | components | NameComponent[] | Name |
| | |SchedulingAddress |Section | | | | (Section 2.2.1.2) |
| | | |2.6.2, | +---------------------+-----------------------+--------------------+
| | | |Section | | contexts | String[Boolean] | Address |
| | | |2.3.1, | | | | (Section 2.5.1.1), |
| | | |Section | | | | Calendar |
| | | |2.3.4, | | | | (Section 2.4.1), |
| | | |Section | | | | CryptoKey |
| | | |2.6.3, | | | | (Section 2.6.1), |
| | | |Section | | | | Directory |
| | | |2.6.4, | | | | (Section 2.6.2), |
| | | |Section | | | | EmailAddress |
| | | |2.2.1.3, | | | | (Section 2.3.1), |
| | | |Section | | | | LanguagePref |
| | | |2.3.2, | | | | (Section 2.3.4), |
| | | |Section | | | | Link |
| | | |2.2.2, | | | | (Section 2.6.3), |
| | | |Section | | | | Media |
| | | |2.3.3, | | | | (Section 2.6.4), |
| | | |Section | | | | Nickname |
| | | |2.2.3, | | | | (Section 2.2.2), |
| | | |Section | | | | OnlineService |
| | | |2.4.2Section| | | | (Section 2.3.2), |
| | | |1.4.4 | | | | Organization |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.3), |
|coordinates |String |Address |Section | | | | Phone |
| | | |2.5.1 | | | | (Section 2.3.3), |
+-------------------+---------------------+-------------------------+------------+ | | | Pronouns |
|countryCode |String |Address |Section | | | | (Section 2.2.4), |
| | | |2.5.1 | | | | SchedulingAddress |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.4.2). |
|created |UTCDateTime |Card, Note |Section | | | | Also see Sections |
| | | |2.1.3, | | | | 1.4.4 and 1.5.1. |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.3 | | coordinates | String | Address |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.5.1.1) |
|date |PartialDate|Timestamp|Anniversary |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.1 | | countryCode | String | Address |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.5.1.1) |
|day |UnsignedInt |PartialDate |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.1 | | created | UTCDateTime | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.1.3), |
|defaultSeparator |String |Address, Name |Section | | | | Note |
| | | |2.5.1, | | | | (Section 2.8.3) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1 | | date | PartialDate|Timestamp | Anniversary |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.1) |
|directories |Id[Directory] |Card |Section | +---------------------+-----------------------+--------------------+
| | | |2.6.2 | | day | UnsignedInt | PartialDate |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.1) |
|emails |Id[EmailAddress] |Card |Section | +---------------------+-----------------------+--------------------+
| | | |2.3.1 | | defaultSeparator | String | Address |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.5.1.1), |
|features |String[Boolean] |Phone |Section | | | | Name |
| | | |2.3.3 | | | | (Section 2.2.1.1) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|full |String |Address, Name |Section | | directories | Id[Directory] | Card |
| | | |2.5.1, | | | | (Section 2.6.2) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1 | | emails | Id[EmailAddress] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.1) |
|grammaticalGender |String |SpeakToAs |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.3 | | features | String[Boolean] | Phone |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.3) |
|isOrdered |Boolean |Address, Name |Section | +---------------------+-----------------------+--------------------+
| | | |2.5.1, | | full | String | Address |
| | | |Section | | | | (Section 2.5.1.1), |
| | | |2.2.1 | | | | Name |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.1.1) |
|keywords |String[Boolean] |Card |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.2 | | grammaticalGender | String | SpeakToAs |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.4) |
|kind |String |AddressComponent, |Section | +---------------------+-----------------------+--------------------+
| | |Anniversary, Calendar, |2.5.1, | | isOrdered | Boolean | Address |
| | |Card, CryptoKey, |Section | | | | (Section 2.5.1.1), |
| | |Directory, Link, Media, |2.8.1, | | | | Name |
| | |NameComponent, |Section | | | | (Section 2.2.1.1) |
| | |PersonalInfo, Title |2.4.1, | +---------------------+-----------------------+--------------------+
| | | |Section | | keywords | String[Boolean] | Card |
| | | |2.1.4, | | | | (Section 2.8.2) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.6.1, | | kind | String | AddressComponent |
| | | |Section | | | | (Section 2.5.1.2), |
| | | |2.6.2, | | | | Anniversary |
| | | |Section | | | | (Section 2.8.1), |
| | | |2.6.3, | | | | Calendar |
| | | |Section | | | | (Section 2.4.1), |
| | | |2.6.4, | | | | Card |
| | | |Section | | | | (Section 2.1.4), |
| | | |2.2.1, | | | | CryptoKey |
| | | |Section | | | | (Section 2.6.1), |
| | | |2.8.4, | | | | Directory |
| | | |Section | | | | (Section 2.6.2), |
| | | |2.2.4 | | | | Link |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.6.3), |
|label |String |Calendar, CryptoKey, |Section | | | | Media |
| | |Directory, EmailAddress, |1.5.3, | | | | (Section 2.6.4), |
| | |Link, Media, |Section | | | | NameComponent |
| | |OnlineService, |2.4.1, | | | | (Section 2.2.1.2), |
| | |PersonalInfo, Phone, |Section | | | | PersonalInfo |
| | |SchedulingAddress |2.6.1, | | | | (Section 2.8.4), |
| | | |Section | | | | Title |
| | | |2.6.2, | | | | (Section 2.2.5) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.3.1, | | label | String | Calendar |
| | | |Section | | | | (Section 2.4.1), |
| | | |2.6.3, | | | | CryptoKey |
| | | |Section | | | | (Section 2.6.1), |
| | | |2.6.4, | | | | Directory |
| | | |Section | | | | (Section 2.6.2), |
| | | |2.3.2, | | | | EmailAddress |
| | | |Section | | | | (Section 2.3.1), |
| | | |2.8.4, | | | | Link |
| | | |Section | | | | (Section 2.6.3), |
| | | |2.3.3, | | | | Media |
| | | |Section | | | | (Section 2.6.4), |
| | | |2.4.2, | | | | OnlineService |
| | | |Section | | | | (Section 2.3.2), |
| | | |1.4.4 | | | | PersonalInfo |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.4), |
|language |String |Card, LanguagePref |Section | | | | Phone |
| | | |2.1.5, | | | | (Section 2.3.3), |
| | | |Section | | | | SchedulingAddress |
| | | |2.3.4 | | | | (Section 2.4.2). |
+-------------------+---------------------+-------------------------+------------+ | | | Also see Sections |
|level |String |PersonalInfo |Section | | | | 1.4.4 and 1.5.2. |
| | | |2.8.4 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | language | String | Card |
|links |Id[Link] |Card |Section | | | | (Section 2.1.5), |
| | | |2.6.3 | | | | LanguagePref |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.4) |
|listAs |UnsignedInt |Directory, PersonalInfo |Section | +---------------------+-----------------------+--------------------+
| | | |2.6.2, | | level | String | PersonalInfo |
| | | |Section | | | | (Section 2.8.4) |
| | | |2.8.4 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | links | Id[Link] | Card |
|localizations |String[PatchObject] |Card |Section | | | | (Section 2.6.3) |
| | | |2.7.1 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | listAs | UnsignedInt | Directory |
|media |Id[Media] |Card |Section | | | | (Section 2.6.2), |
| | | |2.6.4 | | | | PersonalInfo |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.4) |
|mediaType |String |Calendar, CryptoKey, |Section | +---------------------+-----------------------+--------------------+
| | |Directory, Link, Media |1.4.4, | | localizations | String[PatchObject] | Card |
| | | |Section | | | | (Section 2.7.1) |
| | | |2.4.1, | +---------------------+-----------------------+--------------------+
| | | |Section | | media | Id[Media] | Card |
| | | |2.6.1, | | | | (Section 2.6.4) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.6.2, | | mediaType | String | Calendar |
| | | |Section | | | | (Section 2.4.1), |
| | | |2.6.3, | | | | CryptoKey |
| | | |Section | | | | (Section 2.6.1), |
| | | |2.6.4 | | | | Directory |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.6.2), |
|members |String[Boolean] |Card |Section | | | | Link |
| | | |2.1.6 | | | | (Section 2.6.3), |
+-------------------+---------------------+-------------------------+------------+ | | | Media |
|month |UnsignedInt |PartialDate |Section | | | | (Section 2.6.4). |
| | | |2.8.1 | | | | Also see |
+-------------------+---------------------+-------------------------+------------+ | | | Section 1.4.4. |
|name |Name |Card |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1 | | members | String[Boolean] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.1.6) |
|name |String |Author, Nickname, |Section | +---------------------+-----------------------+--------------------+
| | |Organization, OrgUnit, |2.8.3, | | month | UnsignedInt | PartialDate |
| | |Title |Section | | | | (Section 2.8.1) |
| | | |2.2.1.3, | +---------------------+-----------------------+--------------------+
| | | |Section | | name | Name | Card |
| | | |2.2.2, | | | | (Section 2.2.1.1) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.4 | | name | String | Author |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.3), |
|nicknames |Id[Nickname] |Card |Section | | | | Nickname |
| | | |2.2.1.3 | | | | (Section 2.2.2), |
+-------------------+---------------------+-------------------------+------------+ | | | Organization |
|note |String |Note |Section | | | | (Section 2.2.3), |
| | | |2.8.3 | | | | OrgUnit |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.3), |
|notes |Id[Note] |Card |Section | | | | Title |
| | | |2.8.3 | | | | (Section 2.2.5) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|number |String |Phone |Section | | nicknames | Id[Nickname] | Card |
| | | |2.3.3 | | | | (Section 2.2.2) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|onlineServices |Id[OnlineService] |Card |Section | | note | String | Note |
| | | |2.3.2 | | | | (Section 2.8.3) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|organizationId |String |Title |Section | | notes | Id[Note] | Card |
| | | |2.2.4 | | | | (Section 2.8.3) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|organizations |Id[Organization] |Card |Section | | number | String | Phone |
| | | |2.2.2 | | | | (Section 2.3.3) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|personalInfo |Id[PersonalInfo] |Card |Section | | onlineServices | Id[OnlineService] | Card |
| | | |2.8.4 | | | | (Section 2.3.2) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|phones |Id[Phone] |Card |Section | | organizationId | String | Title |
| | | |2.3.3 | | | | (Section 2.2.5) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|phonetic |String |AddressComponent, |Section | | organizations | Id[Organization] | Card |
| | |NameComponent |2.5.1.2, | | | | (Section 2.2.3) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1.2 | | personalInfo | Id[PersonalInfo] | Card |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.4) |
|phoneticScript |String |Address, Name |Section | +---------------------+-----------------------+--------------------+
| | | |2.2.1, | | phones | Id[Phone] | Card |
| | | |Section | | | | (Section 2.3.3) |
| | | |2.5.1 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | phonetic | String | AddressComponent |
|phoneticSystem |String |Address, Name |Section | | | | (Section 2.5.1.2), |
| | | |2.2.1, | | | | NameComponent |
| | | |Section | | | | (Section 2.2.1.2) |
| | | |2.5.1 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | phoneticScript | String | Address |
|place |Address |Anniversary |Section | | | | (Section 2.5.1.1), |
| | | |2.8.1 | | | | Name |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.2.1.1) |
|pref |UnsignedInt |Address, Calendar, |Section | +---------------------+-----------------------+--------------------+
| | |CryptoKey, Directory, |1.5.4, | | phoneticSystem | String | Address (2.5.1.1), |
| | |EmailAddress, |Section | | | | Name |
| | |LanguagePref, Link, |2.5.1, | | | | (Section 2.2.1.1) |
| | |Media, Nickname, |Section | +---------------------+-----------------------+--------------------+
| | |OnlineService, Phone, |2.4.1, | | place | Address | Anniversary |
| | |Pronouns, |Section | | | | (Section 2.8.1) |
| | |SchedulingAddress |2.6.1, | +---------------------+-----------------------+--------------------+
| | | |Section | | pref | UnsignedInt | Address |
| | | |2.6.2, | | | | (Section 2.5.1.1), |
| | | |Section | | | | Calendar |
| | | |2.3.1, | | | | (Section 2.4.1), |
| | | |Section | | | | CryptoKey |
| | | |2.3.4, | | | | (Section 2.6.1), |
| | | |Section | | | | Directory |
| | | |2.6.3, | | | | (Section 2.6.2), |
| | | |Section | | | | EmailAddress |
| | | |2.6.4, | | | | (Section 2.3.1), |
| | | |Section | | | | LanguagePref |
| | | |2.2.1.3, | | | | (Section 2.3.4), |
| | | |Section | | | | Link |
| | | |2.3.2, | | | | (Section 2.6.3), |
| | | |Section | | | | Media |
| | | |2.3.3, | | | | (Section 2.6.4), |
| | | |Section | | | | Nickname |
| | | |2.2.3, | | | | (Section 2.2.2), |
| | | |Section | | | | OnlineService |
| | | |2.4.2, | | | | (Section 2.3.2), |
| | | |Section | | | | Phone |
| | | |1.4.4 | | | | (Section 2.3.3), |
+-------------------+---------------------+-------------------------+------------+ | | | Pronouns |
|preferredLanguages |String[LanguagePref] |Card |Section | | | | (Section 2.2.4), |
| | | |2.3.4 | | | | SchedulingAddress |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.4.2). |
|prodId |String |Card |Section | | | | Also see Sections |
| | | |2.1.7 | | | | 1.4.4 and 1.5.3. |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|pronouns |Id[Pronouns] |SpeakToAs |Section | | preferredLanguages | String[LanguagePref] | Card |
| | | |2.2.3 | | | | (Section 2.3.4) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|relatedTo |String[Relation] |Card |Section | | prodId | String | Card |
| | | |2.1.8 | | | | (Section 2.1.7) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|relation |String[Boolean] |Relation |Section | | pronouns | Id[Pronouns] | SpeakToAs |
| | | |2.1.8 | | | | (Section 2.2.4) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|schedulingAddresses|Id[SchedulingAddress]|Card |Section | | relatedTo | String[Relation] | Card |
| | | |2.4.2 | | | | (Section 2.1.8) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|service |String |OnlineService |Section | | relation | String[Boolean] | Relation |
| | | |2.3.2 | | | | (Section 2.1.8) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|sortAs |String[String] |Name |Section | | schedulingAddresses | Id[SchedulingAddress] | Card |
| | | |2.2.1 | | | | (Section 2.4.2) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|sortAs |String |Organization, OrgUnit |Section | | service | String | OnlineService |
| | | |2.2.2 | | | | (Section 2.3.2) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|speakToAs |SpeakToAs |Card |Section | | sortAs | String[String] | Name |
| | | |2.2.3 | | | | (Section 2.2.1.1) |
+-------------------+---------------------+-------------------------+------------+ +---------------------+-----------------------+--------------------+
|timeZone |String |Address |Section | | sortAs | String | Organization |
| | | |2.5.1 | | | | (Section 2.2.3), |
+-------------------+---------------------+-------------------------+------------+ | | | OrgUnit |
|titles |Id[Title] |Card |Section | | | | (Section 2.2.3) |
| | | |2.2.4 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | speakToAs | SpeakToAs | Card |
|uid |String |Card |Section | | | | (Section 2.2.4) |
| | | |2.1.9 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | timeZone | String | Address |
|units |OrgUnit[] |Organization |Section | | | | (Section 2.5.1.1) |
| | | |2.2.2 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | titles | Id[Title] | Card |
|updated |UTCDateTime |Card |Section | | | | (Section 2.2.5) |
| | | |2.1.10 | +---------------------+-----------------------+--------------------+
+-------------------+---------------------+-------------------------+------------+ | uid | String | Card |
|uri |String |Author, Calendar, |Section | | | | (Section 2.1.9) |
| | |CryptoKey, Directory, |2.8.3, | +---------------------+-----------------------+--------------------+
| | |Link, Media, |Section | | units | OrgUnit[] | Organization |
| | |OnlineService, |1.4.4, | | | | (Section 2.2.3) |
| | |SchedulingAddress |Section | +---------------------+-----------------------+--------------------+
| | | |2.4.1, | | updated | UTCDateTime | Card |
| | | |Section | | | | (Section 2.1.10) |
| | | |2.6.1, | +---------------------+-----------------------+--------------------+
| | | |Section | | uri | String | Author |
| | | |2.6.2, | | | | (Section 2.8.3), |
| | | |Section | | | | Calendar |
| | | |2.6.3, | | | | (Section 2.4.1), |
| | | |Section | | | | CryptoKey |
| | | |2.6.4, | | | | (Section 2.6.1), |
| | | |Section | | | | Directory |
| | | |2.3.2, | | | | (Section 2.6.2), |
| | | |Section | | | | Link |
| | | |2.4.2 | | | | (Section 2.6.3), |
+-------------------+---------------------+-------------------------+------------+ | | | Media |
|user |String |OnlineService |Section | | | | (Section 2.6.4), |
| | | |2.3.2 | | | | OnlineService |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.3.2), |
|utc |UTCDateTime |Timestamp |Section | | | | SchedulingAddress |
| | | |2.8.1 | | | | (Section 2.4.2). |
+-------------------+---------------------+-------------------------+------------+ | | | Also see |
|value |String |AddressComponent, |Section | | | | Section 1.4.4. |
| | |NameComponent, |2.5.1, | +---------------------+-----------------------+--------------------+
| | |PersonalInfo |Section | | user | String | OnlineService |
| | | |2.2.1, | | | | (Section 2.3.2) |
| | | |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.4 | | utc | UTCDateTime | Timestamp |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.8.1) |
|year |UnsignedInt |PartialDate |Section | +---------------------+-----------------------+--------------------+
| | | |2.8.1 | | value | String | AddressComponent |
+-------------------+---------------------+-------------------------+------------+ | | | (Section 2.5.1.2), |
Table 2: JSContact Properties with "common" usage | | | NameComponent |
| | | (Section 2.2.1.2), |
| | | PersonalInfo |
| | | (Section 2.8.4) |
+---------------------+-----------------------+--------------------+
| version | String | Card |
| | | (Section 2.1.2) |
+---------------------+-----------------------+--------------------+
| year | UnsignedInt | PartialDate |
| | | (Section 2.8.1) |
+---------------------+-----------------------+--------------------+
The following table lists the initial reserved usage entries of the Table 2: JSContact Properties with "common" Usage
"JSContact Properties" registry. All RFC section references are for
[I-D.ietf-calext-jscontact]. The change controller for all these
properties is IETF.
+===============+============+============+==============+==========+ The following table lists the initial "reserved" usage entries of the
| Property | Property | Property | Reference or | Intended | "JSContact Properties" registry. For this property, the Change
| Name | Type | Context | Description | Usage | Controller is "IETF", and the RFC section reference is for RFC 9553.
+===============+============+============+==============+==========+
| extra | not | not | Section | reserved |
| | applicable | applicable | 1.5.2 | |
+---------------+------------+------------+--------------+----------+
Table 3: JSContact Properties with "reserved" usage +===============+============+============+=============+==========+
| Property Name | Property | Property | Reference/ | Intended |
| | Type | Context | Description | Usage |
+===============+============+============+=============+==========+
| extra | not | not | Section | reserved |
| | applicable | applicable | 1.7.3.1 | |
+---------------+------------+------------+-------------+----------+
3.6. Creation of the "JSContact Types" Registry Table 3: JSContact Properties with "reserved" Usage
IANA is asked to create the "JSContact Types" registry. The purpose 3.6. Creation of the JSContact Types Registry
of this new registry is to avoid name collisions for JSContact type
names and provide a complete reference for all data types used for
JSContact property values.
The registry entries sort alphabetically ascending by the "Type Name" IANA has created the "JSContact Types" registry. The purpose of this
column. Equal entries sort in any order. new registry is to avoid name collisions for JSContact type names and
provide a complete reference for all data types used for JSContact
property values.
The registry entries sort alphabetically in ascending order by the
"Type Name" column. Equal entries sort in any order.
The registry process for a new type is outlined in Section 3.3. The registry process for a new type is outlined in Section 3.3.
3.6.1. "JSContact Types" Registry Template 3.6.1. JSContact Types Registry Template
Type Name: the name of the type Type Name: The name of the type.
Reference or Description: a brief description or RFC number and Intended Usage: May be "common", "reserved", or "obsolete".
section reference where the Type is specified (may be omitted for
"reserved" type names)
Intended Usage: common, reserved, or obsolete Since Version: The JSContact version on which this type definition
is based. The version MUST be one of the allowed values of the
version property in the "JSContact Version" registry (see
Table 1).
Since Version: This defines the JSContact version on which this type Until Version: The JSContact version after which the type definition
definition is based on. The version MUST be one of the allowed was obsoleted; therefore, it MUST NOT be used in later versions.
values of the version property in the JSContact Enum Value The Until Version value either MUST NOT be set or MUST be one of
registry (see Table 1). the allowed values of the version property in the "JSContact
Version" registry (see Table 1).
Until Version: This defines the JSContact version after which this Change Controller: Person or entity responsible for requesting a
type definition got obsoleted and MUST NOT be used in later change to the entry's definition ("IETF" for RFCs from the IETF
versions. The Until Version value either MUST be not set, or one stream).
of the allowed values of the version property in the JSContact
Enum Value registry (see Table 1).
Change Controller: This is who may request a change to this entry's Reference or Description: A brief description or RFC number and
definition (IETF for RFCs from the IETF stream). section reference where the Type is specified. For reserved type
names, the reference or description MAY be omitted.
3.6.2. Initial Contents for the "JSContact Types" Registry 3.6.2. Initial Contents of the JSContact Types Registry
The following table lists the initial common usage entries of the The following table lists the initial "common" usage entries in the
JSContact Types registry. The Since Version for all types is 1.0. "JSContact Types" registry. For all of these types, the Since
The Until Version for all types is not set. All RFC section Version is "1.0", the Until Version is not set, the Change Controller
references are for [I-D.ietf-calext-jscontact]. The change is "IETF", and RFC section references are for RFC 9553.
controller for all these properties is IETF.
+===================+==========================+ +===================+==========================+
| Type Name | Reference or Description | | Type Name | Reference or Description |
+===================+==========================+ +===================+==========================+
| Address | Section 2.5.1 | | Address | Section 2.5.1.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| AddressComponent | Section 2.5.1 | | AddressComponent | Section 2.5.1.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Anniversary | Section 2.8.1 | | Anniversary | Section 2.8.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Author | Section 2.8.3 | | Author | Section 2.8.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Boolean | Section 1.3.2 | | Boolean | Section 1.3.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Calendar | Section 2.4.1 | | Calendar | Section 2.4.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Card | Section 2 | | Card | Section 2 |
skipping to change at page 71, line 5 skipping to change at line 3248
| Id | Section 1.4.1 | | Id | Section 1.4.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Int | Section 1.4.2 | | Int | Section 1.4.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| LanguagePref | Section 2.3.4 | | LanguagePref | Section 2.3.4 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Link | Section 2.6.3 | | Link | Section 2.6.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Media | Section 2.6.4 | | Media | Section 2.6.4 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Name | Section 2.2.1 | | Name | Section 2.2.1.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| NameComponent | Section 2.2.1 | | NameComponent | Section 2.2.1.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Nickname | Section 2.2.1.3 | | Nickname | Section 2.2.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Note | Section 2.8.3 | | Note | Section 2.8.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Number | Section 1.3.2 | | Number | Section 1.3.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| OnlineService | Section 2.3.2 | | OnlineService | Section 2.3.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Organization | Section 2.2.2 | | Organization | Section 2.2.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| OrgUnit | Section 2.2.2 | | OrgUnit | Section 2.2.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| PartialDate | Section 2.8.1 | | PartialDate | Section 2.8.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| PatchObject | Section 1.4.3 | | PatchObject | Section 1.4.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| PersonalInfo | Section 2.8.4 | | PersonalInfo | Section 2.8.4 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Phone | Section 2.3.3 | | Phone | Section 2.3.3 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Pronouns | Section 2.2.3 | | Pronouns | Section 2.2.4 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Relation | Section 2.1.8 | | Relation | Section 2.1.8 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| SchedulingAddress | Section 2.4.2 | | SchedulingAddress | Section 2.4.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| SpeakToAs | Section 2.2.3 | | SpeakToAs | Section 2.2.4 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| String | Section 1.3.2 | | String | Section 1.3.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Timestamp | Section 2.8.1 | | Timestamp | Section 2.8.1 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| Title | Section 2.2.4 | | Title | Section 2.2.5 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| UnsignedInt | Section 1.4.2 | | UnsignedInt | Section 1.4.2 |
+-------------------+--------------------------+ +-------------------+--------------------------+
| UTCDateTime | Section 1.4.5 | | UTCDateTime | Section 1.4.5 |
+-------------------+--------------------------+ +-------------------+--------------------------+
Table 4: JSContact Types with "common" usage Table 4: JSContact Types with "common" Usage
The following table lists the initial reserved usage entries of the The following table lists the initial "reserved" usage entry of the
JSContact Types registry. All types are for version 1.0. All RFC "JSContact Types" registry. For this type, the version is "1.0", the
section references are for [I-D.ietf-calext-jscontact]. The change Change Controller is "IETF", and the RFC section reference is for RFC
controller for all these properties is IETF. 9553.
+===========+==========================+ +===========+==========================+
| Type Name | Reference or Description | | Type Name | Reference or Description |
+===========+==========================+ +===========+==========================+
| Resource | Section 1.4.4 | | Resource | Section 1.4.4 |
+-----------+--------------------------+ +-----------+--------------------------+
Table 5: JSContact Types with Table 5: JSContact Types with
"reserved" usage "reserved" Usage
3.7. Creation of the "JSContact Enum Values" Registry 3.7. Creation of the JSContact Enum Values Registry
IANA is asked to create the "JSContact Enum Values" registry. The IANA has created the "JSContact Enum Values" registry. The purpose
purpose of the new registry is to allow interoperable extension of of the new registry is to allow interoperable extension of semantics
semantics for JSContact properties with enumerable values. Each such for JSContact properties with enumerable values. Each such property
property will have a subregistry of allowed values. will have a subregistry of allowed values.
The registry entries sort alphabetically ascending by the "Property The registry entries sort alphabetically in ascending order by the
Name" column first, "Property Context" second, "Since Version" third. following columns: "Property Name" first, "Property Context" second,
The enum values sort alphabetically ascending. Equal entries sort in and "Since Version" third. The enum values sort alphabetically in
any order. ascending order. Equal entries sort in any order.
The registry process for a new enum value or adding a new enumerable The registry process for a new enum value or adding a new enumerable
property is outlined in Section 3.3. property is outlined in Section 3.3.
3.7.1. "JSContact Enum Values" Registry Property Template 3.7.1. JSContact Enum Values Registry Property Template
This template is for adding a subregistry for a new enumerable This template is for adding a subregistry for a new enumerable
property to the "JSContact Enum" registry. property to the "JSContact Enum Values" registry.
Property Name: These are the name(s) of the property or properties Property Name: The name(s) of the property or properties where these
where these values may be used. This MUST be registered in the values may be used. This MUST be registered in the "JSContact
"JSContact Properties" registry. Properties" registry.
Context: This is the list of allowed object types where the property Context: The list of allowed object types where the property or
or properties may appear, as registered in the "JSContact properties may appear, as registered in the "JSContact Properties"
Properties" registry. This disambiguates where there may be two registry. This disambiguates where there may be two distinct
distinct properties with the same name in different contexts. properties with the same name in different contexts.
Since Version: This defines the JSContact version on which this enum Since Version: The JSContact version on which the enum value
value definition is based on. The version MUST be one of the definition is based. The version MUST be one of the allowed
allowed values of the version property in the JSContact Enum Value values of the version property in the "JSContact Version" registry
registry (see Table 1). (see Table 1).
Until Version: This defines the JSContact version after which this Until Version: The JSContact version after which the enum value
enum value definition got obsoleted and MUST NOT be used in later definition was obsoleted; therefore, the enum value definition
versions. The Until Version value either MUST be not set, or one MUST NOT be used in later versions. The Until Version value
of the allowed values of the version property in the JSContact either MUST NOT be set or MUST be one of the allowed values of the
Enum Value registry (see Table 1). version property in the "JSContact Version" registry (see
Table 1).
Change Controller: This is who may request a change to this entry's Change Controller: Person or entity responsible for requesting a
definition (IETF for RFCs from the IETF stream). change to the entry's definition ("IETF" for RFCs from the IETF
stream).
Initial Contents: This is the initial list of defined values for Reference or Description: A brief description or RFC number and
this enum, using the template defined in Section 3.7.2. A section reference for the semantics of the value.
subregistry will be created with these values for this property
name/context tuple.
3.7.2. "JSContact Enum Values" Registry Value Template Note that the initial contents will be the initial list of defined
values for the enum, using the template defined in Section 3.7.2. A
subregistry will be created with these values for this property name/
context tuple.
3.7.2. JSContact Enum Values Registry Value Template
This template is for adding a new enum value to a subregistry in the This template is for adding a new enum value to a subregistry in the
JSContact Enum registry. "JSContact Enum Values" registry.
Enum Value: The verbatim value of the enum. Enum Value: The verbatim value of the enum.
Reference or Description: A brief description or RFC number and
section reference for the semantics of this value.
Since Version: The JSContact version on which the enum value Since Version: The JSContact version on which the enum value
definition is based on. The version MUST be one of the allowed definition is based. The version MUST be one of the allowed
values of the version property in the JSContact Enum Value values of the version property in the "JSContact Version" registry
registry (see Table 1). (see Table 1).
Until Version: The JSContact version after which this enum value got Until Version: The JSContact version after which the enum value was
obsoleted and MUST NOT be used in later versions. The Until obsoleted; therefore, the enum value MUST NOT be used in later
Version value either MUST be not set, or one of the allowed values versions. The Until Version value either MUST NOT be set or MUST
of the version property in the JSContact Enum Value registry (see be one of the allowed values of the version property in the
Table 1). "JSContact Version" registry (see Table 1).
3.7.3. Initial Contents for the "JSContact Enum Values" Registry Change Controller: Person or entity responsible for requesting a
change to the entry's definition ("IETF" for RFCs from the IETF
stream).
For each subregistry created in this section, all RFC section Reference or Description: A brief description or RFC number and
references are for [I-D.ietf-calext-jscontact]. For all entries, the section reference for the semantics of the value.
Since Version is 1.0, the Until Version is not set, the Change
Controller is IETF. 3.7.3. Initial Contents of the JSContact Enum Values Registry
For all entries in each subregistry created in this section, the
Since Version is "1.0", the Until Version is not set, the Change
Controller is "IETF", and RFC section references are for RFC 9553.
Property Name: contexts Property Name: contexts
Context: Address Context: Address
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+============+==========================+ +============+==========================+
| billing | Section 2.5.1 | | billing | Section 2.5.1.1 |
+------------+--------------------------+ +------------+--------------------------+
| delivery | Section 2.5.1 | | delivery | Section 2.5.1.1 |
+------------+--------------------------+ +------------+--------------------------+
| private | Section 1.5.1 | | private | Section 1.5.1 |
+------------+--------------------------+ +------------+--------------------------+
| work | Section 1.5.1 | | work | Section 1.5.1 |
+------------+--------------------------+ +------------+--------------------------+
Table 6: JSContact Enum Values for Table 6: JSContact Enum Values for
contexts (Context: Address) contexts (Context: Address)
Property Name: contexts Property Name: contexts
skipping to change at page 75, line 34 skipping to change at line 3462
Table 8: JSContact Enum Values for Table 8: JSContact Enum Values for
features (Context: Phone) features (Context: Phone)
Property Name: grammaticalGender Property Name: grammaticalGender
Context: SpeakToAs Context: SpeakToAs
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+============+==========================+ +============+==========================+
| animate | Section 2.2.3 | | animate | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
| common | Section 2.2.3 | | common | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
| feminine | Section 2.2.3 | | feminine | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
| inanimate | Section 2.2.3 | | inanimate | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
| masculine | Section 2.2.3 | | masculine | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
| neuter | Section 2.2.3 | | neuter | Section 2.2.4 |
+------------+--------------------------+ +------------+--------------------------+
Table 9: JSContact Enum Values for Table 9: JSContact Enum Values for
kind (Context: SpeakToAs) grammaticalGender (Context:
SpeakToAs)
Property Name: kind Property Name: kind
Context: AddressComponent Context: AddressComponent
Initial Contents: Initial Contents:
+===============+==========================+ +===============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+===============+==========================+ +===============+==========================+
| apartment | Section 2.5.1 | | apartment | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| block | Section 2.5.1 | | block | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| building | Section 2.5.1 | | building | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| country | Section 2.5.1 | | country | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| direction | Section 2.5.1 | | direction | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| district | Section 2.5.1 | | district | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| floor | Section 2.5.1 | | floor | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| landmark | Section 2.5.1 | | landmark | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| locality | Section 2.5.1 | | locality | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| name | Section 2.5.1 | | name | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| number | Section 2.5.1 | | number | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| postcode | Section 2.5.1 | | postcode | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| postOfficeBox | Section 2.5.1 | | postOfficeBox | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| region | Section 2.5.1 | | region | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| room | Section 2.5.1 | | room | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| separator | Section 2.5.1 | | separator | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
| subdistrict | Section 2.5.1 | | subdistrict | Section 2.5.1.2 |
+---------------+--------------------------+ +---------------+--------------------------+
Table 10: JSContact Enum Values for kind Table 10: JSContact Enum Values for kind
(Context: AddressComponent) (Context: AddressComponent)
Property Name: kind Property Name: kind
Context: Anniversary Context: Anniversary
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+============+==========================+ +============+==========================+
| birth | Section 2.8.1 | | birth | Section 2.8.1 |
+------------+--------------------------+ +------------+--------------------------+
| death | Section 2.8.1 | | death | Section 2.8.1 |
+------------+--------------------------+ +------------+--------------------------+
| wedding | Section 2.8.1 | | wedding | Section 2.8.1 |
+------------+--------------------------+ +------------+--------------------------+
skipping to change at page 79, line 4 skipping to change at line 3620
+------------+--------------------------+ +------------+--------------------------+
| sound | Section 2.6.4 | | sound | Section 2.6.4 |
+------------+--------------------------+ +------------+--------------------------+
Table 16: JSContact Enum Values for Table 16: JSContact Enum Values for
kind (Context: Media) kind (Context: Media)
Property Name: kind Property Name: kind
Context: NameComponent Context: NameComponent
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+============+==========================+ +============+==========================+
| credential | Section 2.2.1 | | credential | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| generation | Section 2.2.1 | | generation | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| given | Section 2.2.1 | | given | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| given2 | Section 2.2.1 | | given2 | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| separator | Section 2.2.1 | | separator | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| surname | Section 2.2.1 | | surname | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| surname2 | Section 2.2.1 | | surname2 | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
| title | Section 2.2.1 | | title | Section 2.2.1.2 |
+------------+--------------------------+ +------------+--------------------------+
Table 17: JSContact Enum Values for Table 17: JSContact Enum Values for
kind (Context: NameComponent) kind (Context: NameComponent)
Property Name: kind Property Name: kind
Context: PersonalInfo Context: PersonalInfo
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
skipping to change at page 80, line 4 skipping to change at line 3662
+------------+--------------------------+ +------------+--------------------------+
| interest | Section 2.8.4 | | interest | Section 2.8.4 |
+------------+--------------------------+ +------------+--------------------------+
Table 18: JSContact Enum Values for Table 18: JSContact Enum Values for
kind (Context: PersonalInfo) kind (Context: PersonalInfo)
Property Name: kind Property Name: kind
Context: Title Context: Title
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+============+==========================+ +============+==========================+
| role | Section 2.2.4 | | role | Section 2.2.5 |
+------------+--------------------------+ +------------+--------------------------+
| title | Section 2.2.4 | | title | Section 2.2.5 |
+------------+--------------------------+ +------------+--------------------------+
Table 19: JSContact Enum Values for Table 19: JSContact Enum Values for
kind (Context: Title) kind (Context: Title)
Property Name: level Property Name: level
Context: PersonalInfo Context: PersonalInfo
Initial Contents: Initial Contents:
+============+==========================+ +============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
skipping to change at page 80, line 32 skipping to change at line 3689
| high | Section 2.8.4 | | high | Section 2.8.4 |
+------------+--------------------------+ +------------+--------------------------+
| low | Section 2.8.4 | | low | Section 2.8.4 |
+------------+--------------------------+ +------------+--------------------------+
| medium | Section 2.8.4 | | medium | Section 2.8.4 |
+------------+--------------------------+ +------------+--------------------------+
Table 20: JSContact Enum Values for Table 20: JSContact Enum Values for
level (Context: PersonalInfo) level (Context: PersonalInfo)
Property Name: phoneticSystem
Context: Address, Name
Initial Contents:
+============+==========================+
| Enum Value | Reference or Description |
+============+==========================+
| ipa | Section 1.5.4 |
+------------+--------------------------+
| jyut | Section 1.5.4 |
+------------+--------------------------+
| piny | Section 1.5.4 |
+------------+--------------------------+
Table 21: JSContact Enum Values for
phoneticSystem (Context: Address,
Name)
Property Name: relation Property Name: relation
Context: Relation Context: Relation
Initial Contents: Initial Contents:
+==============+==========================+ +==============+==========================+
| Enum Value | Reference or Description | | Enum Value | Reference or Description |
+==============+==========================+ +==============+==========================+
| acquaintance | Section 2.1.8 | | acquaintance | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| agent | Section 2.1.8 | | agent | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| child | Section 2.1.8 | | child | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| colleague | Section 2.1.8 | | colleague | Section 2.1.8 |
skipping to change at page 81, line 49 skipping to change at line 3753
+--------------+--------------------------+ +--------------+--------------------------+
| parent | Section 2.1.8 | | parent | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| sibling | Section 2.1.8 | | sibling | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| spouse | Section 2.1.8 | | spouse | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
| sweetheart | Section 2.1.8 | | sweetheart | Section 2.1.8 |
+--------------+--------------------------+ +--------------+--------------------------+
Table 21: JSContact Enum Values for Table 22: JSContact Enum Values for
relation (Context: Relation) relation (Context: Relation)
Property Name: phoneticSystem
Context: Address, Name
Initial Contents:
+============+==========================+
| Enum Value | Reference or Description |
+============+==========================+
| ipa | Section 1.5.5 |
+------------+--------------------------+
| jyut | Section 1.5.5 |
+------------+--------------------------+
| piny | Section 1.5.5 |
+------------+--------------------------+
Table 22: JSContact Enum Values for
phoneticSystem (Context: Address,
Name)
4. Security Considerations 4. Security Considerations
Contact information is very privacy-sensitive. It can reveal the Contact information is very privacy sensitive. It can reveal the
identity, location and credentials information, employment status, identity, location, credentials information, employment status,
interests and hobbies, and social network of a user. Its interests and hobbies, and social network of a user. Its
transmission and storage must be done carefully to protect it from transmission and storage must be done carefully to protect it from
possible threats, such as eavesdropping, replay, message insertion, possible threats such as eavesdropping, replay, message insertion,
deletion, modification, and on-path attacks. deletion, modification, and on-path attacks.
The data being stored and transmitted may be used in systems with The data being stored and transmitted may be used in systems with
real-world consequences. For example, a malicious actor might real-world consequences. For example, a malicious actor might
provide JSContact data that uses the name of another person but provide JSContact data that uses the name of another person but
insert their contact details to impersonate the unknown victim. Such insert their contact details to impersonate the unknown victim. Such
systems must be careful to authenticate all data they receive to systems must be careful to authenticate all data they receive to
prevent them from being subverted and ensure the change comes from an prevent them from being subverted and ensure the change comes from an
authorized entity. authorized entity.
skipping to change at page 83, line 45 skipping to change at line 3829
number of URIs. In the case of published address books with a large number of URIs. In the case of published address books with a large
number of subscribers, such objects could be widely distributed. number of subscribers, such objects could be widely distributed.
Implementations should be careful to limit the automatic fetching of Implementations should be careful to limit the automatic fetching of
linked resources to reduce the risk of this being an amplification linked resources to reduce the risk of this being an amplification
vector for a denial-of-service attack. vector for a denial-of-service attack.
5. References 5. References
5.1. Normative References 5.1. Normative References
[IANATZ] "IANA Time Zone Database", [IANA-TZ] IANA, "Time Zone Database",
<https://www.iana.org/time-zones>. <https://www.iana.org/time-zones>.
[IANAvCard] [IANA-vCard]
"IANA vCard Elements", <https://www.iana.org/assignments/ IANA, "vCard Elements",
vcard-elements/vcard-elements.xhtml>. <https://www.iana.org/assignments/vcard-elements>.
[ISO.3166-1.2006] [ISO.3166-1]
International Organization for Standardization, "Codes for International Organization for Standardization, "Codes for
the representation of names of countries, 3rd edition", the representation of names of countries and their
ISO Standard 3166-1, 2006. subdivisions -- Part 1: Country codes", ISO 3166-1:2020,
August 2020.
[RFC1034] Mockapetris, P., "Domain names - concepts and facilities", [RFC1034] Mockapetris, P., "Domain names - concepts and facilities",
STD 13, RFC 1034, DOI 10.17487/RFC1034, November 1987, STD 13, RFC 1034, DOI 10.17487/RFC1034, November 1987,
<https://www.rfc-editor.org/info/rfc1034>. <https://www.rfc-editor.org/info/rfc1034>.
[RFC1035] Mockapetris, P., "Domain names - implementation and [RFC1035] Mockapetris, P., "Domain names - implementation and
specification", STD 13, RFC 1035, DOI 10.17487/RFC1035, specification", STD 13, RFC 1035, DOI 10.17487/RFC1035,
November 1987, <https://www.rfc-editor.org/info/rfc1035>. November 1987, <https://www.rfc-editor.org/info/rfc1035>.
[RFC2046] Freed, N. and N. Borenstein, "Multipurpose Internet Mail [RFC2046] Freed, N. and N. Borenstein, "Multipurpose Internet Mail
skipping to change at page 86, line 5 skipping to change at line 3934
2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174, 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
May 2017, <https://www.rfc-editor.org/info/rfc8174>. May 2017, <https://www.rfc-editor.org/info/rfc8174>.
[RFC8259] Bray, T., Ed., "The JavaScript Object Notation (JSON) Data [RFC8259] Bray, T., Ed., "The JavaScript Object Notation (JSON) Data
Interchange Format", STD 90, RFC 8259, Interchange Format", STD 90, RFC 8259,
DOI 10.17487/RFC8259, December 2017, DOI 10.17487/RFC8259, December 2017,
<https://www.rfc-editor.org/info/rfc8259>. <https://www.rfc-editor.org/info/rfc8259>.
5.2. Informative References 5.2. Informative References
[I-D.ietf-calext-jscontact] [IPA] IPA, "International Phonetic Alphabet",
Stepanek, R. and M. Loffredo, "JSContact: A JSON
representation of contact data", Work in Progress,
Internet-Draft, draft-ietf-calext-jscontact-15, 18
September 2023, <https://datatracker.ietf.org/doc/html/
draft-ietf-calext-jscontact-15>.
[I-D.ietf-uuidrev-rfc4122bis]
Davis, K. R., Peabody, B., and P. Leach, "Universally
Unique IDentifiers (UUID)", Work in Progress, Internet-
Draft, draft-ietf-uuidrev-rfc4122bis-14, 6 November 2023,
<https://datatracker.ietf.org/doc/html/draft-ietf-uuidrev-
rfc4122bis-14>.
[IPA] "International Phonetic Alphabet",
<https://www.internationalphoneticalphabet.org/>. <https://www.internationalphoneticalphabet.org/>.
[RFC3261] Rosenberg, J., Schulzrinne, H., Camarillo, G., Johnston, [RFC3261] Rosenberg, J., Schulzrinne, H., Camarillo, G., Johnston,
A., Peterson, J., Sparks, R., Handley, M., and E. A., Peterson, J., Sparks, R., Handley, M., and E.
Schooler, "SIP: Session Initiation Protocol", RFC 3261, Schooler, "SIP: Session Initiation Protocol", RFC 3261,
DOI 10.17487/RFC3261, June 2002, DOI 10.17487/RFC3261, June 2002,
<https://www.rfc-editor.org/info/rfc3261>. <https://www.rfc-editor.org/info/rfc3261>.
[RFC3966] Schulzrinne, H., "The tel URI for Telephone Numbers", [RFC3966] Schulzrinne, H., "The tel URI for Telephone Numbers",
RFC 3966, DOI 10.17487/RFC3966, December 2004, RFC 3966, DOI 10.17487/RFC3966, December 2004,
skipping to change at page 87, line 28 skipping to change at line 3992
[RFC8499] Hoffman, P., Sullivan, A., and K. Fujiwara, "DNS [RFC8499] Hoffman, P., Sullivan, A., and K. Fujiwara, "DNS
Terminology", BCP 219, RFC 8499, DOI 10.17487/RFC8499, Terminology", BCP 219, RFC 8499, DOI 10.17487/RFC8499,
January 2019, <https://www.rfc-editor.org/info/rfc8499>. January 2019, <https://www.rfc-editor.org/info/rfc8499>.
[RFC8605] Hollenbeck, S. and R. Carney, "vCard Format Extensions: [RFC8605] Hollenbeck, S. and R. Carney, "vCard Format Extensions:
ICANN Extensions for the Registration Data Access Protocol ICANN Extensions for the Registration Data Access Protocol
(RDAP)", RFC 8605, DOI 10.17487/RFC8605, May 2019, (RDAP)", RFC 8605, DOI 10.17487/RFC8605, May 2019,
<https://www.rfc-editor.org/info/rfc8605>. <https://www.rfc-editor.org/info/rfc8605>.
[UBiDi] "Unicode® Standard Annex #9: Unicode Bidirectional [RFC9554] Stepanek, R. and M. Loffredo, "vCard Format Extension for
Algorithm", <https://www.unicode.org/reports/tr9/>. JSContact", RFC 9554, DOI 10.17487/RFC9554, March 2024,
<https://www.rfc-editor.org/info/rfc9554>.
[W3C-URL] "W3C WG URL - Living Standard — Last Updated 21 August [RFC9555] Stepanek, R. and M. Loffredo, "vCard Format Extension for
2023", <https://url.spec.whatwg.org>. JSContact", RFC 9555, DOI 10.17487/RFC9555, March 2024,
<https://www.rfc-editor.org/info/rfc9555>.
[UBiDi] The Unicode Consortium, "Unicode Standard Annex #9:
Unicode Bidirectional Algorithm", Revision 48,
Unicode 15.1.0, August 2023,
<https://www.unicode.org/reports/tr9/>.
[UUID] Davis, K. R., Peabody, B. G., and P. Leach, "Universally
Unique IDentifiers (UUID)", Work in Progress, Internet-
Draft, draft-ietf-uuidrev-rfc4122bis-14, 6 November 2023,
<https://datatracker.ietf.org/doc/html/draft-ietf-uuidrev-
rfc4122bis-14>.
[WHATWG-URL]
WHATWG, "URL Living Standard", January 2024,
<https://url.spec.whatwg.org>.
Authors' Addresses Authors' Addresses
Robert Stepanek Robert Stepanek
Fastmail Fastmail
PO Box 234, Collins St West PO Box 234
Melbourne VIC 8007 Collins St. West
Melbourne VIC 8007
Australia Australia
Email: rsto@fastmailteam.com Email: rsto@fastmailteam.com
Mario Loffredo Mario Loffredo
IIT-CNR IIT-CNR
Via Moruzzi,1 Via Moruzzi, 1
56124 Pisa 56124 Pisa
Italy Italy
Email: mario.loffredo@iit.cnr.it Email: mario.loffredo@iit.cnr.it
 End of changes. 604 change blocks. 
1923 lines changed or deleted 1935 lines changed or added

This html diff was produced by rfcdiff 1.48.