This is a purely informative rendering of an RFC that includes verified errata. This rendering may not be used as a reference.

The following 'Verified' errata have been incorporated in this document: EID 3188, EID 3189
Internet Engineering Task Force (IETF)                       C. Ishikawa
Request for Comments: 6588                 YRP Ubiquitous Networking Lab
Category: Informational                                       April 2012
ISSN: 2070-1721


                       A URN Namespace for ucode

Abstract

   This document describes a Uniform Resource Name (URN) namespace for
   ucode, an identifier system for objects and places.  ucode technology
   is used in many applications, and this document provides a URN
   namespace for ucode to enable its use in Internet-related devices and
   software.

Status of This Memo

   This document is not an Internet Standards Track specification; it is
   published for informational purposes.

   This document is a product of the Internet Engineering Task Force
   (IETF).  It represents the consensus of the IETF community.  It has
   received public review and has been approved for publication by the
   Internet Engineering Steering Group (IESG).  Not all documents
   approved by the IESG are a candidate for any level of Internet
   Standard; see Section 2 of RFC 5741.

   Information about the current status of this document, any errata,
   and how to provide feedback on it may be obtained at
   http://www.rfc-editor.org/info/rfc6588.

Copyright Notice

   Copyright (c) 2012 IETF Trust and the persons identified as the
   document authors.  All rights reserved.

   This document is subject to BCP 78 and the IETF Trust's Legal
   Provisions Relating to IETF Documents
   (http://trustee.ietf.org/license-info) in effect on the date of
   publication of this document.  Please review these documents
   carefully, as they describe your rights and restrictions with respect
   to this document.  Code Components extracted from this document must
   include Simplified BSD License text as described in Section 4.e of
   the Trust Legal Provisions and are provided without warranty as
   described in the Simplified BSD License.

1.  Introduction

   ucode [UCODE] is an identifier to be stored in many types of tags
   (not limited to Radio Frequency Identification (RFID) tags).  Its
   allocation and management is handled by the Ubiquitous ID Center
   [UIDC].  The embedding of ucode in many types of tags (RFID tags,
   optical code, infrared markers, and even sound source) is also
   specified by the Ubiquitous ID Center.

   The basic length of ucode is 128 bits, but it is extensible in units
   of 128 bits if necessary.

   ucode has been devised to identify objects and places where existing
   standards do not fit the application needs or the scope of the
   applications or where the allocation policy of existing standards is
   too limited for Small and Medium Enterprises (SMEs), small-scale
   research laboratories at academic institutions, or individual users.

   Applications that use ucode take advantage of the Internet
   extensively.  Use of ucode is open to anybody.  Those who wish to
   have ucode allocated can do so either by having ucode subspace
   allocated to them directly from the Ubiquitous ID Center [UIDC] or by
   obtaining tags that have pre-stored ucode from so called "providers"
   [UCDMIP].  Such tags are certified as ucode tags [UIDTAG], and the
   reader specifications are published so that there will be many
   readers available for such tags.

   By having a URN for ucode, we can facilitate the use of ucode in many
   Internet-related devices and software for the benefit of existing and
   future users of ucode and people who will access such tags attached
   to objects and places.  Since an application based on ucode can run
   across organizational boundaries and spread across regions and
   countries, a formal URN Namespace Identifier (NID) assignment for
   'ucode' is requested.

2.  'ucode' Registration Template

   Namespace ID:

   'ucode' requested

   Registration Information:

   Registration Version Number: 1
   Registration Date: 2011-12-21

   Declared registrant of the namespace:

   T-Engine Forum
   2-20-1, Nishi-Gotanda
   Shinagawa, Tokyo, 141-0031
   Japan
   [email protected]
   Tel: +81-3-5437-0572

      Declaration of syntactic structure: 

   The structure of the namespace for 'ucode' using the hexadecimal
   representation of the identifier is as follows using ABNF [RFC5234].

   UCODE-URN    = "urn:ucode:" ucode-name
   ucode-name   = "_" ucode-number
   ucode-number = 1*ucode-value
|  ucode-value  = 32UCHEXDIG
|  UCHEXDIG     = %x30-39 / 0x41-46   ; digits 0..9, uppercase A..F
|
EID 3188 (Verified) is as follows:

Section: 2, pg.3

Original Text:

   Declaration of syntactic structure:

   The structure of the namespace for 'ucode' using the hexadecimal
   representation of the identifier is as follows using ABNF [RFC5234].

   UCODE-URN = "urn:ucode:" ucode-name
   ucode-name = "_" ucode-number
   ucode-number = 1*ucode-value
   ucode-value = 32HEXDIG
   HEXDIG         =  DIGIT / "A" / "B" / "C" / "D" / "E" / "F"
   DIGIT          =  %x30-39
                  ; 0-9

Corrected Text:

   Declaration of syntactic structure:

   The structure of the namespace for 'ucode' using the hexadecimal
   representation of the identifier is as follows using ABNF [RFC5234].

   UCODE-URN    = "urn:ucode:" ucode-name
   ucode-name   = "_" ucode-number
   ucode-number = 1*ucode-value
|  ucode-value  = 32UCHEXDIG
|  UCHEXDIG     = %x30-39 / 0x41-46   ; digits 0..9, uppercase A..F
|
Notes:
Note: The above clause is part of the 'ucode' URN Namespace
Registration Template, so the above correction needs
to be applied to the template archived at IANA as well.

Rationale: The maintainers of the namespace intended to admit
only uppercase letters in the hexadecimal representation,
in order to accomodate usage of assigned <ucode-value>s in
case-sensitive XML context; this is specified in other parts
of the RFC, but should be specified also in the formal definition.
According to the ABNF Standard, RFC 5234, string literals in ABNF
are explicitly case-insensitive (cf. page 5 of RFC 5234).
NOTE 1: "1*" at the start of the ucode-number definition is not a typo. Although the currently used ucode [UCODE] is 128 bits (16 octets), thus requiring 32 hexadecimal characters to represent serially, ucode is designed to be extensible in increments of 128 bits. So, in the distant future, we may need to repeat the chunks of 128 bits. This is why "1*" precedes ucode-value. NOTE 2: ucode-name starts with a "_" because it is also intended to be used as an identifier for XML [W3CXML]. Because an XML tag can't start with a digit, an "_" (underscore) is inserted at the beginning to make sure ucode-name starts with a non-digit. For example, the 128-bit ucode value 0123456789ABCDEF0123456789ABCDEF, expressed in a series of hexadecimal digits, is as follows: urn:ucode:_0123456789ABCDEF0123456789ABCDEF Relevant ancillary documentation: ucode, the identifier expressed by ucode-number, is managed by the Ubiquitous ID Center [UIDC], which is a sub-organization of the T-Engine Forum [TEF]. The document "Ubiquitous Code: ucode" [UCODE] defines this identifier system. Identifier uniqueness considerations: The 'ucode' namespace is managed by the Ubiquitous ID Center. The Ubiquitous ID Center assigns the identifier, ucode, in such a way that the uniqueness of the 'ucode' namespace will be maintained. Identifier persistence considerations: The assignment process guarantees that names are not reassigned and that the binding between the name and its resource is permanent, regardless of any standards or organizational changes or the assignment period. Process of identifier assignment: Names are assigned by the Ubiquitous ID Center and by any entities that are sub-delegated by the Ubiquitous ID Center. This assignment process is based on "ucode Management Implementing Procedures" [UCDMIP] established by the Ubiquitous ID Center. Process of identifier resolution: The process of identifier resolution is currently based on the "ucode Resolution Protocol" [UCSURP]. It will be enhanced by using newer recommendations from ITU-T and/or standards from ISO. Rules for lexical equivalence: | The Namespace-Specific String (NSS) in 'ucode' URNs | (i.e. the <ucode-name> in the ABNF) is case-sensitive. | So this namespace imposes no additional lexical equivalences | beyond what is specified in RFC 2141 (i.e., according to | RFC 2141, the "urn:ucode:" part is case-insensitive, the NSS | is not).
EID 3189 (Verified) is as follows:

Section: 2, pg.4

Original Text:

   Rules for lexical equivalence:

   The entire UCODE-URN is case-sensitive.

   NOTE: This is an additional restriction imposed on the ucode
   namespace by the requirements of some major applications of ucode in
   existence.  Only capital "A", "B", "C", ..., "F" are allowed as part
   of hexadecimal characters.

Corrected Text:

   Rules for lexical equivalence:

|  The Namespace-Specific String (NSS) in 'ucode' URNs
|  (i.e. the <ucode-name> in the ABNF) is case-sensitive.
|  So this namespace imposes no additional lexical equivalences
|  beyond what is specified in RFC 2141 (i.e., according to
|  RFC 2141, the "urn:ucode:" part is case-insensitive, the NSS
|  is not).
Notes:
Note: The above clause is part of the 'ucode' URN Namespace
Registration Template, so the above correction needs
to be applied to the template archived at IANA as well.

Rationale: The RFC text violates Section 5 of RFC 2141, which
specifies that the case-insensitivity of the URI Scheme ("URN")
and the URN Namespace ID (NID) cannot be overridden by a URN
Namespace registration.
It was the intent of the maintainers of the 'ucode' namespace
to follow RFC 2141, but the language in the RFC has happened
to indicate otherwise.

The correction of the ABNF recorded in Errata Note #3188 makes
the original NOTE superflous, since the corrected ABNF now
precisely specifies what this NOTE intended to superimpose on
the original ABNF in the RFC.
Conformance with URN syntax: There are no special reserved characters. The URN of this namespace conforms to RFC 2141 [RFC2141] and RFC 3986 [RFC3986]. Validation mechanism: No special considerations. Scope: Global. 3. IANA Considerations One URN Namespace registration for 'ucode' (46) has been entered into the IANA "Formal URN Namespaces" sub-registry for URN NIDs. 4. Namespace Considerations ucode, the identifier expressed by ucode-number, is a unique identification number to identify a tangible object or a place. Additionally, ucode can be assigned to "content" or "information" that does not exist in the real world or a "concept" that is yet more abstract. ucode has been devised to identify objects and places where existing standards do not fit the application needs or the scope of the applications or where the allocation policy of existing standards is too limited for SMEs, small-scale research laboratories at academic institutions, or individual users. ucode is only an identification number, and its value (or its sub- bitfields) does not contain any pre-assigned meaning. Any relevant information about the object or place to which a ucode is assigned is stored in a data server that can be reached after a "resolution process" [UCSURP]. This resolution process usually occurs over the Internet. ucode can be assigned to an object to be identified regardless of the type of application. ucode is expected to be stored in any kind of tags (2D optical code, RFID, etc.), and it provides a framework where anyone can obtain unique numbers for identification purposes. ucode has been designed to provide the services outlined in ITU-T Recommendation F.771 [ITU-T-F771] and to operate in the framework of ITU-T Recommendation H.621 [ITU-T-H621]. ucode architecture is general enough to cover many applications for the users. 5. Community Considerations This namespace enables ucode to be stored in tags that are designed to store URN. Also, ucode-related information can be described as metadata using the URN namespace. Thus, the namespace facilitates the exchange of descriptions regarding objects and places among multiple organizations. It is expected that many small-scale providers will offer ucode tags to small users and that large scale providers will hand out millions of tags to users. The resolution servers and applications will be available to general users with appropriate access control over the Internet. The published specification for resolver and access services for 'ucode' allows the creation of client software for many types of computers including small mobile terminals and ever-popular smartphones. 6. Security Considerations There are no additional security considerations other than those normally associated with the use and resolution of URNs in general. 7. References 7.1. Normative References [UCODE] T-Engine Forum, Ubiquitous ID Center, "ucode: Ubiquitous Code", UID-00010, <http://www.uidcenter.org/spec#UID-00010>. [UCDMIP] T-Engine Forum, Ubiquitous ID Center, "ucode Management Implementing Procedures", UID-00034, <http://www.uidcenter.org/spec#UID-00034>. [UCSURP] T-Engine Forum, Ubiquitous ID Center, "Simplified ucode Resolution Protocol", UID-00005, <http://www.uidcenter.org/spec#UID-00005>. [UIDTAG] T-Engine Forum, Ubiquitous ID Center, "ucode Tag Architecture", UID-00017, <http://www.uidcenter.org/spec#UID-00017>. [RFC2141] Moats, R., "URN Syntax", RFC 2141, May 1997. [RFC3986] Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, January 2005. [RFC5234] Crocker, D., Ed., and P. Overell, "Augmented BNF for Syntax Specifications: ABNF", STD 68, RFC 5234, January 2008. [ITU-T-F771] ITU-T, "Service description and requirements for multimedia information access triggered by tag-based identification", ITU-T Recommendation F.771, <http://www.itu.int/rec/T-REC-F.771-200808-I>. [ITU-T-H621] ITU-T, "Architecture of a system for multimedia information access triggered by tag-based identification", ITU-T Recommendation H.621, <http://www.itu.int/rec/T-REC-H.621-200808-I>. 7.2 Informative References [W3CXML] W3C, "Extensible Markup Language (XML) 1.1", <http://www.w3.org/TR/xml11/>. [UIDC] Ubiquitous ID Center, <http://www.uidcenter.org/>. [TEF] T-Engine Forum, <http://www.t-engine.org/>. 8. Acknowledgments The author would like to thank Peter Saint-Andre, the Document Shepherd/Responsible Area Director for this document, for providing valuable suggestions. The author would also like to thank the following people who helped to improve this document: Adrian Farrel David Harrington Pete Resnick Stephen Farrel Ted Hardie Wesley Eddy The author would also like to thank the members of T-Engine Forum who have built prototype and real-world applications using ucode and offered valuable feedback. Application examples from these members can be found on the Ubiquitous ID Center web site [UIDC] and on www.youtube.com (search for "uidcenter" without the quotes). 9. Contributors Ken Sakamura Noboru Koshizuka Katsunori Shindo Tomonori Usaka Past and current members of the uID architecture group at the University of Tokyo and the YRP Ubiquitous Networking Laboratory (YRP UNL) Author's Address Chiaki Ishikawa YRP Ubiquitous Networking Laboratory 2-20-1, Nishi-Gotanda Shinagawa, Tokyo, 141-0031 Japan Tel: +81-3-5437-2270 FAX: +81-3-5437-2271 EMail: [email protected]