view Side-By-Side changes
Network Working Group M. Mealling Internet-Draft VeriSign Expires:February 18,April 29, 2002 L. MasinterAT&T LabsAdobe Systems Incorporated T. Hardie Equinix G. KlyneContent Technologies Ltd. August 20,MIMEsweeper Group October 29, 2001 An IETF URN Sub-namespace for Registered Protocol Parametersdraft-mealling-iana-urn-01.txtdraft-mealling-iana-urn-02.txt Status of this Memo This document is an Internet-Draft and is in full conformance with all provisions of Section 10 of RFC2026. Internet-Drafts are working documents of the Internet Engineering Task Force (IETF), its areas, and its working groups. Note that other groups may also distribute working documents as Internet- Drafts. Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress." The list of current Internet-Drafts can be accessed at http://www.ietf.org/ietf/1id-abstracts.txt. The list of Internet-Draft Shadow Directories can be accessed at http://www.ietf.org/shadow.html. This Internet-Draft will expire onFebruary 18,April 29, 2002. Copyright Notice Copyright (C) The Internet Society (2001). All Rights Reserved. Abstract This document describes a new sub-delegation for the 'ietf' URN namespace for registered protocol items. The 'ietf' URN namespace is defined in RFC 2648 as a root forregistered protocol items. 1. Introduction From timepersistent URIs that refer totime IETF standards require the registration of variousIETF- defined resources. Mealling, et. al. ExpiresFebruary 18,April 29, 2002 [Page 1] Internet-Draft IANA URN NamespaceAugustOctober 2001 1. Introduction From time to time IETF standards require the registration of various protocol elements insomewell known central repository. The Internet Assigned Numbers Authority maintains this centralauthorityrepository and takes direction from the IETF on what, how and when to add items tothat registry.it. The IANA maintains lists of items such as all assigned port numbers, MIME media types, enterprise numbers, etc. Over time there has developed a need to be able to reference these elements as URIs in various schema. In the past this was done in a veryadhocad hoc way that easily led to interoperability problems. This document creates a new sub-delegation below the "ietf" [2]URN namespace [1] called 'params' which acts as a standardized mechanism for naming the items registered for IETF standards.2. Lessons Learned In the process of writing this document, the authors attempted to pre-assign as many names as possible. This involved a complete review of every item currentlyAny assignments below that are specified inthe IANA repository. There were several organizational issues that had direct impact on how well a URN could be assignedan RFC according toparticular existing entries intheregistry. As a result,IETF concensus process and which include theauthors have included a set of recommendations that could be made to document authors seeking to setup new registries. 2.1 Multiple Registries Per File The authorstemplate foundthat the practice of putting multiple registriesina single file onSection 3. 2. IETF Sub-namespace Specifics Sub-namespace name: "params" Declared registrant of theIANA ftp archive caused large amountsnamespace: The Internet Engineering Task Force Declaration ofconfusion. A good examplestructure: The namespace is primarily opaque. The IANA, as operator of theMobile IP Numbers registry. Dueregistry, may take suggestions for names tohaving several very different concepts inassign but they reserve thesame file it is very difficultright tounderstand where oneassign whatever name they desire, within guidelines setof parameters ends and another begins. The authors recommend that, in the future,by theIANA create subdirectories in which each separate registryIESG. The colon character (":") ismaintained in a separate file. Also, document authors are encouragedused tosuggestdenote adocument/directory structure to the IANA in their IANA considerations section. 2.2 Unclear Index Values In many cases the registry had no clearly unique value that could be used in the URN. An example here is the Public Data Network Numbers registry which isvery limited concept of hierarchy. If amapping between IP addresses and X.121 addresses. Itcolon isnot clear which value to use inpresent then thename.items on both sides of it are valid names. Inrecent history the IANA has begun assigning a simple index value to assignments and often this can be used in the URN. Document authors are encouraged to include some type of indexing value in their IANA considerations section so that some other entity can uniquely talk about a particular entry. Mealling, et. al. Expires February 18, 2002 [Page 2] Internet-Draft IANA URN Namespace August 2001 2.3 General Disorganization Due to historical neglect there are several registries that are in a general state of 'disrepair'. The Mobile IP Numbers registry above is a good example. Experts in this area are encouraged to produce new documents providing guidance to the IANA for how these registries should be organized for clarity. 2.4 Obsolete Registries While there have been a few registries that have been marked as obsolete (SGMP Vendor Specific Codes), there is a general lack of a way of moving an IANA registry to historical status. The authors recommend that the IESG create a method by which a document can request that an IANA registry be obsoleted. 3. Changes to RFC 2434 The authors realize that assigning URNs to new items in the registry with no guidance from those asking for the registry is an additional burden the IANA does not need. Thus the authors suggest that the following updates be made to RFC 2434: In the event that an RFC requests that the IANA maintain a registry, the IANA Considerations section of that document MUST include the following: o The top level registry name -- This is the unique string that goes between the third and fourth colons in the URN and is also used as the directory name in any network accessible repositories. For example, the registry name for the Socks Methods is found in the sub-directory called "socks-methods" on the IANA FTP site. This value is also used to assign the URN as "urn:ietf:params:socks- methods:". The requesting document MUST provide this value but the IANA SHOULD follow that recommendation. In the case where there is a conflict the IANA can assign another value. The intent here is that if the registry is simple then this value will be both the filename in which the IANA puts this information and the URN sub-namespace that is created. If the registry is complex and thus has sub-registries, then this value will be the directory name in the FTP archive. o sub-registry names -- In the case where a particular registry has sub-sections then the requesting document MUST provide names for these sub-registries. The intent is that these sub-registry names will be the filenames/sub-directories that exist under the registry directory as well as being the section name in the URN Mealling, et. al. Expires February 18, 2002 [Page 3] Internet-Draft IANA URN Namespace August 2001 that is assigned. The document author should ensure that for each sub-registry there is one and only one set of values and that an index value exists that is unique within that sub-registry. 4. Namespace Specifics Using the template in RFC 2611 as a guide, this is the specification for the 'params' sub-namespace: Sub-namespace name: "params" Declared registrant of the namespace: The Internet Engineering Task Force Declaration of structure: The namespace is primarily opaque. The IANA, as operator of the registry, may take suggestions for names to assign but they reserve the right to assign whatever name they desire, within guidelines set by the IESG. The colon character (":") is used to denote a very limited concept of hierarchy. If a colon is present then the items on both sides of it are valid names. In general, if a namegeneral, if a name has a colon then the item on the left hand side represents a class of those items that would contain other items of that class. For example, a name can be assigned to the entire list of DNS resource record type codes as well as for each individual code. The URN forthe list might look like this: urn:ietf:params:dns:rr-type-codes while the URN for the SOA records type codethe list might look like this:urn:ietf:params:dns:rr-type-codes:soaMealling, et. al. ExpiresFebruary 18,April 29, 2002 [Page4]2] Internet-Draft IANA URN NamespaceAugustOctober 2001 urn:ietf:params:dns:rr-type-codes while the URN for the SOA records type code might look like this: urn:ietf:params:dns:rr-type-codes:soa Relevant ancillary documentation:None.[3], [2], [1] Identifier uniqueness considerations: The IESG uses the IETF concensus process to ensure that sub- namespaces generate unique names within that sub-namespace. The IESG delegates to the IANAhas sole discretion for assigningthe task of ensuring that the sub- namespace names themselves are unique. Until andthus can guaranteeunless the IESG specifies differently, the IANA is directed to ensure uniqueness by comparing the name to be assigned with the list of previously assigned names. In the case of a conflict the IANA is to request a new string from the registrant until the conflict is resolved. Identifier persistence considerations:The IANAOnce a name hassole discretionbeen allocated it MUST NOT be re-allocated forassigning names and thus can guarantee persistence by comparinga different purpose. The rules provided for assignments of values within a sub-namespace MUST be constructed so that the meaning of values cannot change. This registration mechanism is not appropriate for naming values whose meaning may change over time. If a value that changes over time the assignment MUST name the container or concept that contains the value, not the value itself. For example, if a parameter called 'foo' has a value that changes over time, it is valid tobe assigned withcreate thelist of previously assigned names.name 'urn:ietf:params:foo-params:foo' that identifies that 'slot'. It is not valid to actually create a name that contains that value unless it is a persistent and unique value such as a version number. Process of identifier assignment: Mealling, et. al. Expires April 29, 2002 [Page 3] Identifiers are assigned only after a particular protocol element or number has been registered with the IANA using standard policies andprocedures. Once that element is assigned andprocedures, or documented in an RFC describing a standards track protocol. This means that therepository, the IANA will take requests'gating' function forthat element to have a name assigned. Theassignmentrequest can suggest a name to use butis theIANA may ignore that request."IETF Concensus" process documented in RFC 2434 [4]. Process of identifier resolution: At this time no resolution mechanism isdefined though one is expected.defined. Rules for Lexical Equivalence: Lexical equivalence is achieved by exact string match. Conformance with URNSyntax: There are no additional characters reserved. Mealling, et. al. Expires February 18, 2002 [Page 5] Internet-Draft IANA URN Namespace August 2001Syntax: There are no additional characters reserved. Validation mechanism: None. Scope: Global5.3. Assigning Names Theauthors originally attempted to pre-assign names for every item currently in the repository but found this a) difficult and b) of little current value. The solution is a template and process for requesting that a name by assigned to a particular registry entry. Thecreation of a new registry name will be simple for most flat registries. The only required elements will be the registry name(see recommended changes to RFC 2434 above),, a reference to relevant documents, a statement about which current/proposed document repositories contains the authoritative data for the registry, and a statement specifying which element in the registry is the value to be used in the URN. In most cases this last element will be the index value assigned by the IANA. More complex registries (DNS Parameters for example) will need to repeat that information for any sub-namespaces. It should also be clear as to whether or not a name is assigned to the sub-namespace itself (i.e. is 'urn:ietf:params:dns:rr-types' valid by itself and if so, what does it name?). Mealling, et. al. Expires April 29, 2002 [Page 4] Internet-Draft IANA URN Namespace October 2001 The template: Registry name: -- The name of the sub-namespace. In many cases this should be the same nameas whatthat the IANA calls the registry itself. Specification: -- Relevant IETF published documents that define the registry and the items in it. Repository: -- A pointer to the 'current' location of the registry in the protocol parametersrepository.repository or the relevant RFCs that document the items being named. This value will change over time as the entity that maintains the repository moves files and or fileservers. It is not meant as a permanent binding to the filename but as a hint to the IANA for what the initial mapping would be.Mealling, et. al. Expires February 18, 2002 [Page 6] Internet-Draft IANA URN Namespace August 2001Index value: --A statement specifying whichDescription of how a registered valuein the registryisthe indextoeach entry in that registry. This index value willbeusedembedded in theURN to name each entry. In some cases it can actuallyURI form. This MUST include details of any transformations that may be needed for thething being named, in others, where those values can change, it should be an indexresulting string to conform to URN syntax rules and and any canonicalization needed so that therecord instead of something incase-sensitive string comparison yields therecord itself.expected equivalences. The process for requesting that a URN be assigned is currently to put the above template or a reference to it in the IANA considerations section of the specifying document. Other more automated processes may be proposed at a latter time if demand requires it.6.4. Security Considerations None not already inherent to using URNs.7.5. IANA Considerations This document puts a new and significant burden on the IANA since it may require a additional assignment process to happen for each new IANA registry.It isTo minimize thehope ofadministrative burden on IANA, any parameter namespace registration is very clear about theauthorscriteria for inclusion in thatthe required strictnessnamespace. Defining a registry that fits the constraints of a URNassignment puts on the registering document authorsnamespace willactually make the IANA's job easier by taking the guess work outimpose extra discipline that should take some of the guess-work about creatinga newand maintaining that registry. References [1] Moats, R., "URN Syntax", RFC 2141, May 1997. Mealling, et. al. Expires April 29, 2002 [Page 5] Internet-Draft IANA URN Namespace October 2001 [2] Moats, R., "A URN Namespace for IETF Documents", RFC 2648, August 1999. [3] Daigle, L., van Gulik, D., Iannella, R. and P. Faltstrom, "URN Namespace Definition Mechanisms", BCP 33, RFC 2611, June 1999. [4] Narten, T. and H. Alvestrand, "Guidelines for Writing an IANA Considerations Section in RFCs", BCP 26, RFC 2434, October 1998. Authors' Addresses Michael Mealling VeriSign 505 Huntmar Park Drive Herndon, VA 22070 US Phone: +1 770 921 2251 EMail: michaelm@netsol.com URI: http://www.verisign.comMealling, et. al. Expires February 18, 2002 [Page 7] Internet-Draft IANA URN Namespace August 2001Larry MasinterAT&T Labs 75 Willow Road Menlo Park,Adobe Systems Incorporated 345 Park Ave San Jose, CA9402595110 US Phone: +1650 463 7059408 536-3024 EMail: LMM@acm.org URI: http://larry.masinter.net Ted Hardie Equinix 901 Marshall Street Redwood City, CA 94063 US EMail: hardie@equinix.com Mealling, et. al. Expires April 29, 2002 [Page 6] Internet-Draft IANA URN Namespace October 2001 Graham KlyneContent Technologies Ltd. 1220 Parkview,MIMEsweeper Group 1310 Waterside, Arlington Business Park Theale, Reading RG7 4SA UK Phone: +44 118 930 1300 EMail: GK@ACM.ORG Mealling, et. al. ExpiresFebruary 18,April 29, 2002 [Page8]7] Internet-Draft IANA URN NamespaceAugustOctober 2001 Full Copyright Statement Copyright (C) The Internet Society (2001). All Rights Reserved. This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this paragraph are included on all such copies and derivative works. However, this document itself may not be modified in any way, such as by removing the copyright notice or references to the Internet Society or other Internet organizations, except as needed for the purpose of developing Internet standards in which case the procedures for copyrights defined in the Internet Standards process must be followed, or as required to translate it into languages other than English. The limited permissions granted above are perpetual and will not be revoked by the Internet Society or its successors or assigns. This document and the information contained herein is provided on an "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Acknowledgement Funding for the RFC Editor function is currently provided by the Internet Society. Mealling, et. al. ExpiresFebruary 18,April 29, 2002 [Page9]8] ----