RFC 9694: BCP 13: Guidelines for the Definition of New Top-Level Media Types
- M.J. Dürst
Abstract
This document defines best practices for defining new top-level media types. It also introduces a registry for top-level media types, and contains a short history of top-level media types. It updates RFC 6838.¶
Status of This Memo
This memo documents an Internet Best Current Practice.¶
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). Further information on BCPs is available in Section 2 of RFC 7841.¶
Information about the current status of this document, any
errata, and how to provide feedback on it may be obtained at
https://
Copyright Notice
Copyright (c) 2025 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://
1. Introduction
This document defines best practices for defining new top-level media types.
Top-level media types ('top-level types' for short) appear to the left of the slash in a media type,
examples being 'text/...', 'application
1.1. Background
New top-level types are rare enough and different enough from each other that each application needs to be evaluated separately. The main protocol extension point for media types are subtypes below each of the main types. For formats that do not fit below any other top-level type, the 'application' top-level type can always be used.¶
The main function of media types and subtypes is the dispatch of data formats to application code. In most cases, this requires and is done using the full type (i.e., including the subtype, and often some parameters). The top-level type can occasionally serve as a fallback for the tentative dispatch to applications handling a very wide range of related formats. Please note that assumptions about the correctness of a media type must be made carefully, as it could be under the control of an attacker.¶
In some older scenarios, it may also have been possible to identify a device (e.g., a phone for audio messages, a printer or fax device for images, a video recorder for videos, a computer for 'application' subtypes). However, the current hardware landscape, where computers and smartphones can handle a very wide variety of media, makes such a scenario look somewhat far-fetched.¶
The top-level type can be used for user-directed information. Besides direct inspection of the type string by the user, this includes using different types of default icons for different top-level types.¶
1.2. Requirements Language
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
2. Rules and Criteria for the Registration of New Top-Level Media Types
This section describes the rules and criteria for new top-level media types, including criteria already defined in RFC 6838 [RFC6838].¶
2.1. Required Criteria
The following is the list of required criteria for the definition of a new top-level type. Motivations for the requirements are also included.¶
2.2. Additional Considerations
2.3. Negative Criteria
This subsection lists negative criteria for top-level types; it identifies criteria that are explicitly not reasons for a top-level type registration.¶
3. Top-Level Media Type History
This section briefly describes the history of top-level types. The emphasis is on the aspects of the history that are relevant to the adoption of new top-level types.¶
RFC 1341 [RFC1341] first defined the structuring of content types into (top-level) type and subtype, and introduced the 'text', 'multipart', 'message', 'image', 'audio', 'video', and 'application' top-level types. That specification also allowed top-level types starting with 'X-'. With respect to new top-level types, it said the following:¶
An initial set of seven Content-Types is defined by this document. This set of top-level names is intended to be substantially complete. It is expected that additions to the larger set of supported types can generally be accomplished by the creation of new subtypes of these initial types. In the future, more top-level types may be defined only by an extension to this standard. If another primary type is to be used for any reason, it must be given a name starting with "X-" to indicate its non-standard status and to avoid a potential conflict with a future official name.¶
RFC 1437 [RFC1437] defined the first additional top-level type; however, it was not registered because RFC 1437 is an April Fools RFC that was published purely for entertainment purposes.¶
RFC 2046 [RFC2046] discouraged the use of "X-" for (new) top-level types, with the following words:¶
In general, the use of "X-" top-level types is strongly discouraged. Implementors should invent subtypes of the existing types whenever possible. In many cases, a subtype of "application" will be more appropriate than a new top-level type.¶
RFC 2048 [RFC2048], published at the same time as RFC 2046 [RFC2046], defined requirements for the definition of new top-level types:¶
In some cases a new media type may not "fit" under any currently defined top-level content type. Such cases are expected to be quite rare. However, if such a case arises a new top-level type can be defined to accommodate it. Such a definition must be done via standards-track RFC; no other mechanism can be used to define additional top-level content types.¶
The 'model' top-level type was introduced by RFC 2077 [RFC2077] in 1997.¶
RFC 4735 [RFC4735] introduced the 'example' top-level type for use in documentation examples.¶
The 'font' top-level type was defined in RFC 8081 [RFC8081], a work of the 'justfont' IETF WG, in 2017. This was formalizing the widespread use of the unofficial 'font' top-level type that people were using in preference to official, registered types.¶
RFC 9695 [RFC9695] defines a new 'haptics' top-level type. RFC 9695 and this document were developed in parallel, and RFC 9695 was used to cross-check the considerations and procedures defined in this document.¶
The "Chemical file format" Wikipedia page [CHEMICAL] reports the unofficial use of a 'chemical' top-level type. This top-level type was proposed by Peter Murray-Rust and Henry Rzepa at a workshop at the First WWW conference in May 1994 [CHEMIME]. It is in widespread use but remains unregistered.¶
Some Linux desktop logic uses what looks like a top-level type
of 'x
The document that previously defined the requirements for new top-level media types was RFC 6838 [RFC6838]. Of particular relevance to the work in the current document are Sections 4.2.5 (Application Media Types) and 4.2.7 (Additional Top-Level Types) of [RFC6838]. These two sections are not strictly aligned, because the first says that anything that doesn't go under a more specific type can go under the 'application' top-level type, while the later section allows for new top-level types.¶
4. IANA Considerations
4.1. Registration of Top-level Media Types
Registrations of new top-level types follow the "Standards Action" policy (see Section 4.9 of RFC 8126 [RFC8126]).¶
Registrations of new top-level types have to provide the name of the top-level type, the defining specification (RFC, or the respective draft during the approval process), and, if applicable, some comments. The defining specification has to contain an "IANA Considerations" section requesting addition to the registry of top-level media types, and has to document security considerations for the top-level type they register.¶
The comments field is empty or contains short comments about the usage of the type. Comments can be added or updated by the experts for subtype registrations under the respective top-level type, and by IANA itself.¶
There should be at least one subtype, except for registrations that are for demonstration purposes only (e.g. the example top-level type).¶
4.2. Initialization of the Registry of Top-Level Media Types
IANA has created the "Top-Level Media Types" registry and populated it with the values in Table 1. IANA also added a pointer to this registry from the "Media Types" registry group, and they added pointers to this document and to the "Top-Level Media Types" registry in the application for a media
type at <https://
For each top-level media type, the registry contains the name of the type, a pointer to the RFC defining the type, a pointer to IANA's registry of subtypes for that type, and a comment field.¶
The initial state of the registry is as follows:¶
5. Security Considerations
This document itself is not expected to introduce any security issues. The security issues related to introducing a new top-level media type MUST be evaluated and documented carefully.¶
Acknowledgements
Continuous encouragement for writing this document came from Harald Alvestrand. Further encouragement was provided by Murray S. Kucherawy. Both Harald and Murray also provided ideas for actual text. Without them, this memo would never have reached even the first draft stage. Alexey Melnikov provided the difficult to find pointer to RFC 2077 [RFC2077] and examples for applications dispatching on top-level types. Additional information and comments were received from Chris Lilley, Graham Kline, Henry S. Rzepa, Francesca Palombini, Zaheduzzaman Sarker, Amanda Baber, Paul Wouters, Roman Danyliw, John Scudder, Radia Perlman, Lars Eggert, and Antoine Fressancourt. Inspiration for negative criteria or examples was provided by Phillip Hallam-Baker, Donald E. Eastlake 3rd, Petter Reinholdtsen, and Christian Heller.¶
References
Normative References
- [RFC2119]
-
Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, DOI 10
.17487 , , <https:///RFC2119 www >..rfc -editor .org /info /rfc2119 - [RFC6838]
-
Freed, N., Klensin, J., and T. Hansen, "Media Type Specifications and Registration Procedures", BCP 13, RFC 6838, DOI 10
.17487 , , <https:///RFC6838 www >..rfc -editor .org /info /rfc6838 - [RFC8126]
-
Cotton, M., Leiba, B., and T. Narten, "Guidelines for Writing an IANA Considerations Section in RFCs", BCP 26, RFC 8126, DOI 10
.17487 , , <https:///RFC8126 www >..rfc -editor .org /info /rfc8126 - [RFC8174]
-
Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words", BCP 14, RFC 8174, DOI 10
.17487 , , <https:///RFC8174 www >..rfc -editor .org /info /rfc8174
Informative References
- [CHEMICAL]
-
Wikipedia, "Chemical file format", , <https://
en >..wikipedia .org /w /index .php ?title =Chemical _file _format &oldid =1235421631 - [CHEMIME]
-
Rzepa, H.S., Murray-Rust, P., and B. Whitaker, "The Application of Chemical Multipurpose Internet Mail Extensions (Chemical MIME) Internet Standards to Electronic Mail and World Wide Web Information Exchange", Journal of Chemical Information Computer Science, vol. 38, no. 6, pp. 976-982, DOI 10
.1021 , , <https:///ci9803233 pubs >..acs .org /doi /10 .1021 /ci9803233 - [RDF]
-
Cyganiak, R., Wood, D., and M. Lanthaler, "RDF 1.1 Concepts and Abstract Syntax", W3C Recommendation, , <https://
www >..w3 .org /TR /2014 /REC -rdf11 -concepts -20140225 / - [RFC1341]
-
Borenstein, N. and N. Freed, "MIME (Multipurpose Internet Mail Extensions): Mechanisms for Specifying and Describing the Format of Internet Message Bodies", RFC 1341, DOI 10
.17487 , , <https:///RFC1341 www >..rfc -editor .org /info /rfc1341 - [RFC1437]
-
Borenstein, N. and M. Linimon, "The Extension of MIME Content-Types to a New Medium", RFC 1437, DOI 10
.17487 , , <https:///RFC1437 www >..rfc -editor .org /info /rfc1437 - [RFC2046]
-
Freed, N. and N. Borenstein, "Multipurpose Internet Mail Extensions (MIME) Part Two: Media Types", RFC 2046, DOI 10
.17487 , , <https:///RFC2046 www >..rfc -editor .org /info /rfc2046 - [RFC2048]
-
Freed, N., Klensin, J., and J. Postel, "Multipurpose Internet Mail Extensions (MIME) Part Four: Registration Procedures", RFC 2048, DOI 10
.17487 , , <https:///RFC2048 www >..rfc -editor .org /info /rfc2048 - [RFC2077]
-
Nelson, S., Parks, C., and Mitra, "The Model Primary Content Type for Multipurpose Internet Mail Extensions", RFC 2077, DOI 10
.17487 , , <https:///RFC2077 www >..rfc -editor .org /info /rfc2077 - [RFC4735]
-
Taylor, T., "Example Media Types for Use in Documentation", RFC 4735, DOI 10
.17487 , , <https:///RFC4735 www >..rfc -editor .org /info /rfc4735 - [RFC6648]
-
Saint-Andre, P., Crocker, D., and M. Nottingham, "Deprecating the "X-" Prefix and Similar Constructs in Application Protocols", BCP 178, RFC 6648, DOI 10
.17487 , , <https:///RFC6648 www >..rfc -editor .org /info /rfc6648 - [RFC8081]
-
Lilley, C., "The "font" Top-Level Media Type", RFC 8081, DOI 10
.17487 , , <https:///RFC8081 www >..rfc -editor .org /info /rfc8081 - [RFC9695]
-
Muthusamy, Y. K. and C. Ullrich, "The 'haptics' Top-Level Media Type", RFC 9695, DOI 10
.17487 , , <https:///RFC9695 www >..rfc -editor .org /info /rfc9695