| Internet-Draft | Updating the NTP Registries | June 2023 | 
| Salz | Expires 24 December 2023 | [Page] | 
The Network Time Protocol (NTP) and Network Time Security (NTS) documents define a number of assigned number registries, collectively called the NTP registries. Some registries have wrong values, some registries do not follow current common practice, and some are just right. For the sake of completeness, this document reviews all NTP and NTS registries, and makes updates where necessary.¶
This document updates RFC 5905, RFC 5906, RFC 8573, RFC 7822, and RFC 7821.¶
This note is to be removed before publishing as an RFC.¶
This document is a product of the NTP Working Group. Source for this draft and an issue tracker can be found at https://github.com/richsalz/draft-rsalz-update-registries.¶
RFC Editor: Please update 'this RFC' to refer to this document, once its RFC number is known, through the document.¶
This Internet-Draft is submitted in full conformance with the 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 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."¶
This Internet-Draft will expire on 24 December 2023.¶
Copyright (c) 2023 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 (https://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 Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
The Network Time Protocol (NTP) and Network Time Security (NTS) documents define a number of assigned number registries, collectively called the NTP registries. Some registries have wrong values, some registries do not follow current common practice, and some are just right. For the sake of completeness, this document reviews all NTP and NTS registries, and makes updates where necessary.¶
The bulk of this document can be divided into two parts:¶
This section describes the registries and the rules for them. It is intended to be a short summary of the syntax and registration requirements for each registry. The semantics and protocol processing rules for each registry -- that is, how an implementation acts when sending or receiving any of the fields -- are not described here.¶
[RFC5905] defined two registries; the Reference ID in Section 7.3, and the Kiss-o'-Death in Section 7.4. Both of these are allowed to be four ASCII characters; padded on the right with all-bits-zero if necessary. Entries that start with 0x58, the ASCII letter uppercase X, are reserved for Private or Experimental Use. Both registries are first-come first-served. The formal request to define the registries is in Section 16.¶
[RFC5905], Section 7.5 defined the on-the-wire format of extension fields but did not create a registry for them.¶
[RFC5906], Section 13 mentioned the Extension Field Types registry, and defined it indirectly by defining 30 extensions (10 each for request, response, and error response). It did not provide a formal definition of the columns in the registry. [RFC5906], Section 10 splits the Field Type into four subfields, only for use within the Autokey extensions.¶
[RFC7821] added a new entry, Checksum Complement, to the Extension Field Types registry.¶
[RFC7822] clarified the processing rules for Extension Field Types, particularly around the interaction with the Message Authentication Code (MAC) field.¶
[RFC8573] changed the cryptography used in the MAC field.¶
The following problems exists with the current registry:¶
[RFC8915] defines the NTS protocol. Its registries are listed here for completeness, but no changes to them are specified in this document.¶
Sections 7.1 through 7.5 (inclusive) added entries to existing registries.¶
Section 7.6 created a new registry, NTS Key Establishment Record Types, that partitions the assigned numbers into three different registration policies: IETF Review, Specification Required, and Private or Experimental Use.¶
Section 7.7 created a new registry, NTS Next Protocols, that similarly partitions the assigned numbers.¶
Section 7.8 created two new registries, NTS Error Codes and NTS Warning Codes. Both registries are also partitioned the same way.¶
The following general guidelines apply to all registries updated here:¶
Note that the second bullet removes the restrictions on fields starting with the 0x58, the ASCII uppercase letter X.¶
The IESG is requested to choose three designated experts, with two being required to approve a registry change. Guidance for such experts is given below.¶
Each entry described in the sub-sections below is intended to completely replace the existing entry with the same name.¶
The designated experts (DE) should be familiar with [RFC8126], particularly Section 5. As that reference suggests, the DE should ascertain the existence of a suitable specification, and verify that it is publicly available. The DE is also expected to check the clarity of purpose and use of the requested code points.¶
In addition, the DE is expected to be familiar with this document, specifically the history documented here. If reviewing a request to allocate a field value previously reserved for private or experimental use, but reallocated per this document, it is RECOMMENDED to seek the feedback of the NTP community via any of the regular working group participation mechanisms, such as by posting to the working group's mailing list.¶
The registration procedure is changed to Specification Required.¶
The Note is changed to read as follows:¶
The columns are defined as follows:¶
The existing entries are left unchanged.¶
The registration procedure is changed to Specification Required.¶
The Note is changed to read as follows:¶
The columns are defined as follows:¶
The existing entries are left unchanged.¶
The registration procedure is changed to Specification Required.¶
The reference [RFC5906] should be added, if possible.¶
The following two Notes are added:¶
The columns are defined as follows:¶
The table is replaced with the following entries.¶
| Field Type | Meaning | Reference | 
|---|---|---|
| 0x0002 | Reserved for historic reasons | This RFC | 
| 0x0102 | Reserved for historic reasons | This RFC | 
| 0x0104 | Unique Identifier | RFC 8915, Section 5.3 | 
| 0x0200 | No-Operation Request | RFC 5906 | 
| 0x0201 | Association Message Request | RFC 5906 | 
| 0x0202 | Certificate Message Request | RFC 5906 | 
| 0x0203 | Cookie Message Request | RFC 5906 | 
| 0x0204 | NTS Cookie | RFC 8915, Section 5.4 | 
| 0x0204 | Autokey Message Request | RFC 5906 | 
| 0x0205 | Leapseconds Message Request | RFC 5906 | 
| 0x0206 | Sign Message Request | RFC 5906 | 
| 0x0207 | IFF Identity Message Request | RFC 5906 | 
| 0x0208 | GQ Identity Message Request | RFC 5906 | 
| 0x0209 | MV Identity Message Request | RFC 5906 | 
| 0x0302 | Reserved for historic reasons | This RFC | 
| 0x0304 | NTS Cookie Placeholder | RFC 8915, Section 5.5 | 
| 0x0402 | Reserved for historic reasons | This RFC | 
| 0x0404 | NTS Authenticator and Encrypted Extension Fields | RFC 8915, Section 5.6 | 
| 0x0502 | Reserved for historic reasons | This RFC | 
| 0x0602 | Reserved for historic reasons | This RFC | 
| 0x0702 | Reserved for historic reasons | This RFC | 
| 0x2005 | UDP Checksum Complete | RFC 7821 | 
| 0x8002 | Reserved for historic reasons | This RFC | 
| 0x8102 | Reserved for historic reasons | This RFC | 
| 0x8200 | No-Operation Response | RFC 5906 | 
| 0x8201 | Association Message Response | RFC 5906 | 
| 0x8202 | Certificate Message Response | RFC 5906 | 
| 0x8203 | Cookie Message Response | RFC 5906 | 
| 0x8204 | Autokey Message Response | RFC 5906 | 
| 0x8205 | Leapseconds Message Response | RFC 5906 | 
| 0x8206 | Sign Message Response | RFC 5906 | 
| 0x8207 | IFF Identity Message Response | RFC 5906 | 
| 0x8208 | GQ Identity Message Response | RFC 5906 | 
| 0x8209 | MV Identity Message Response | RFC 5906 | 
| 0x8302 | Reserved for historic reasons | This RFC | 
| 0x8402 | Reserved for historic reasons | This RFC | 
| 0x8502 | Reserved for historic reasons | This RFC | 
| 0x8602 | Reserved for historic reasons | This RFC | 
| 0x8702 | Reserved for historic reasons | This RFC | 
| 0x8802 | Reserved for historic reasons | This RFC | 
| 0xC002 | Reserved for historic reasons | This RFC | 
| 0xC102 | Reserved for historic reasons | This RFC | 
| 0xC200 | No-Operation Error Response | RFC 5906 | 
| 0xC201 | Association Message Error Response | RFC 5906 | 
| 0xC202 | Certificate Message Error Response | RFC 5906 | 
| 0xC203 | Cookie Message Error Response | RFC 5906 | 
| 0xC204 | Autokey Message Error Response | RFC 5906 | 
| 0xC205 | Leapseconds Message Error Response | RFC 5906 | 
| 0xC206 | Sign Message Error Response | RFC 5906 | 
| 0xC207 | IFF Identity Message Error Response | RFC 5906 | 
| 0xC208 | GQ Identity Message Error Response | RFC 5906 | 
| 0xC209 | MV Identity Message Error Response | RFC 5906 | 
| 0xC302 | Reserved for historic reasons | This RFC | 
| 0xC402 | Reserved for historic reasons | This RFC | 
| 0xC502 | Reserved for historic reasons | This RFC | 
| 0xC602 | Reserved for historic reasons | This RFC | 
| 0xC702 | Reserved for historic reasons | This RFC | 
| 0xC802 | Reserved for historic reasons | This RFC | 
| 0x0902 | Reserved for historic reasons | This RFC | 
| 0x8902 | Reserved for historic reasons | This RFC | 
| 0xC902 | Reserved for historic reasons | This RFC | 
The members of the NTP Working Group helped a great deal. Notable contributors include:¶