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. |