summaryrefslogtreecommitdiff
path: root/doc/rfc/rfc9399.txt
diff options
context:
space:
mode:
authorThomas Voss <mail@thomasvoss.com> 2024-11-27 20:54:24 +0100
committerThomas Voss <mail@thomasvoss.com> 2024-11-27 20:54:24 +0100
commit4bfd864f10b68b71482b35c818559068ef8d5797 (patch)
treee3989f47a7994642eb325063d46e8f08ffa681dc /doc/rfc/rfc9399.txt
parentea76e11061bda059ae9f9ad130a9895cc85607db (diff)
doc: Add RFC documents
Diffstat (limited to 'doc/rfc/rfc9399.txt')
-rw-r--r--doc/rfc/rfc9399.txt2202
1 files changed, 2202 insertions, 0 deletions
diff --git a/doc/rfc/rfc9399.txt b/doc/rfc/rfc9399.txt
new file mode 100644
index 0000000..89277ec
--- /dev/null
+++ b/doc/rfc/rfc9399.txt
@@ -0,0 +1,2202 @@
+
+
+
+
+Internet Engineering Task Force (IETF) S. Santesson
+Request for Comments: 9399 IDsec Solutions
+Obsoletes: 3709, 6170 R. Housley
+Category: Standards Track Vigil Security
+ISSN: 2070-1721 T. Freeman
+ Amazon Web Services
+ L. Rosenthol
+ Adobe
+ May 2023
+
+
+ Internet X.509 Public Key Infrastructure: Logotypes in X.509
+ Certificates
+
+Abstract
+
+ This document specifies a certificate extension for including
+ logotypes in public key certificates and attribute certificates.
+ This document obsoletes RFCs 3709 and 6170.
+
+Status of This Memo
+
+ This is an Internet Standards Track document.
+
+ 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
+ Internet Standards 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://www.rfc-editor.org/info/rfc9399.
+
+Copyright Notice
+
+ 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.
+
+Table of Contents
+
+ 1. Introduction
+ 1.1. Certificate-Based Identification
+ 1.2. Selection of Certificates
+ 1.3. Combination of Verification Techniques
+ 1.4. Requirements Language
+ 2. Different Types of Logotypes in Certificates
+ 3. Logotype Data
+ 4. Logotype Certificate Extension
+ 4.1. Extension Format
+ 4.2. Conventions for LogotypeImageInfo
+ 4.3. Embedded Images
+ 4.4. Other Logotypes
+ 4.4.1. Loyalty Logotype
+ 4.4.2. Certificate Background Logotype
+ 4.4.3. Certificate Image Logotype
+ 5. Type of Certificates
+ 6. Use in Clients
+ 7. Image Formats
+ 8. Audio Formats
+ 9. Security Considerations
+ 10. Privacy Considerations
+ 11. IANA Considerations
+ 12. References
+ 12.1. Normative References
+ 12.2. Informative References
+ Appendix A. ASN.1 Modules
+ A.1. ASN.1 Modules with 1988 Syntax
+ A.2. ASN.1 Module with 2002 Syntax
+ Appendix B. Examples
+ B.1. Example from RFC 3709
+ B.2. Issuer Organization Logotype Example
+ B.3. Embedded Image Example
+ B.4. Embedded Certificate Image Example
+ B.5. Full Certificate Example
+ Appendix C. Changes since RFCs 3709 and 6170
+ Acknowledgments
+ Authors' Addresses
+
+1. Introduction
+
+ This specification supplements [RFC5280], which profiles public key
+ certificates and certificate revocation lists (CRLs) for use in the
+ Internet, and it supplements [RFC5755], which profiles attribute
+ certificates for use in the Internet.
+
+ This document obsoletes [RFC3709] and [RFC6170]. Appendix C provides
+ a summary of the changes since the publication of [RFC3709] and
+ [RFC6170].
+
+ The basic function of a certificate is to bind a public key to the
+ identity of an entity (the subject). From a strictly technical
+ viewpoint, this goal could be achieved by signing the identity of the
+ subject together with its public key. However, the art of Public Key
+ Infrastructure (PKI) has developed certificates far beyond this
+ functionality in order to meet the needs of modern global networks
+ and heterogeneous information and operational technology structures.
+
+ Certificate users must be able to determine certificate policies,
+ appropriate key usage, assurance level, and name form constraints.
+ Before a relying party can make an informed decision whether a
+ particular certificate is trustworthy and relevant for its intended
+ usage, a certificate may be examined from several different
+ perspectives.
+
+ Systematic processing is necessary to determine whether a particular
+ certificate meets the predefined prerequisites for an intended usage.
+ Much of the information contained in certificates is appropriate and
+ effective for machine processing; however, this information is not
+ suitable for a corresponding human trust and recognition process.
+
+ Humans prefer to structure information into categories and symbols.
+ Most humans associate complex structures of reality with easily
+ recognizable logotypes and marks. Humans tend to trust things that
+ they recognize from previous experiences. Humans may examine
+ information to confirm their initial reaction. Very few consumers
+ actually read all terms and conditions they agree to in accepting a
+ service; instead, they commonly act on trust derived from previous
+ experience and recognition.
+
+ A big part of this process is branding. Service providers and
+ product vendors invest a lot of money and resources into creating a
+ strong relation between positive user experiences and easily
+ recognizable trademarks, servicemarks, and logotypes.
+
+ Branding is also pervasive in identification instruments, including
+ identification cards, passports, driver's licenses, credit cards,
+ gasoline cards, and loyalty cards. Identification instruments are
+ intended to identify the holder as a particular person or as a member
+ of the community. The community may represent the subscribers of a
+ service or any other group. Identification instruments, in physical
+ form, commonly use logotypes and symbols, solely to enhance human
+ recognition and trust in the identification instrument itself. They
+ may also include a registered trademark to allow legal recourse for
+ unauthorized duplication.
+
+ Since certificates play an equivalent role in electronic exchanges,
+ we examine the inclusion of logotypes in certificates. We consider
+ certificate-based identification and certificate selection.
+
+1.1. Certificate-Based Identification
+
+ The need for human recognition depends on the manner in which
+ certificates are used and whether certificates need to be visible to
+ human users. If certificates are to be used in open environments and
+ in applications that bring the user in conscious contact with the
+ result of a certificate-based identification process, then human
+ recognition is highly relevant and may be a necessity.
+
+ Examples of such applications include:
+
+ * Web server identification where a user identifies the owner of the
+ website.
+
+ * Peer email exchange in business-to-business (B2B), business-to-
+ consumer (B2C), and private communications.
+
+ * Exchange of medical records and system for medical prescriptions.
+
+ * Unstructured e-business applications (i.e., non-EDI applications).
+
+ * Wireless client authenticating to a service provider.
+
+ Most applications provide the human user with an opportunity to view
+ the results of a successful certificate-based identification process.
+ When the user takes the steps necessary to view these results, the
+ user is presented with a view of a certificate. This solution has
+ two major problems. First, the function to view a certificate is
+ often rather hard to find for a non-technical user. Second, the
+ presentation of the certificate is too technical and is not user
+ friendly. It contains no graphic symbols or logotypes to enhance
+ human recognition.
+
+ Many investigations have shown that users of today's applications do
+ not take the steps necessary to view certificates. This could be due
+ to poor user interfaces. Further, many applications are structured
+ to hide certificates from users. The application designers do not
+ want to expose certificates to users at all.
+
+1.2. Selection of Certificates
+
+ One situation where software applications must expose human users to
+ certificates is when the user must select a single certificate from a
+ portfolio of certificates. In some cases, the software application
+ can use information within the certificates to filter the list for
+ suitability; however, the user must be queried if more than one
+ certificate is suitable. The human user must select one of them.
+
+ This situation is comparable to a person selecting a suitable plastic
+ card from their wallet. In this situation, substantial assistance is
+ provided by card color, location, and branding.
+
+ In order to provide similar support for certificate selection, the
+ users need tools to easily recognize and distinguish certificates.
+ Introduction of logotypes into certificates provides the necessary
+ graphic.
+
+1.3. Combination of Verification Techniques
+
+ The use of logotypes will, in many cases, affect the user's decision
+ to trust and use a certificate. It is therefore important that there
+ be a distinct and clear architectural and functional distinction
+ between the processes and objectives of the automated certificate
+ verification and human recognition.
+
+ Since logotypes are only aimed for human interpretation and contain
+ data that is inappropriate for computer-based verification schemes,
+ the logotype certificate extension MUST NOT be an active component in
+ automated certification path validation, as specified in Section 6 of
+ [RFC5280].
+
+ Automated certification path verification determines whether the end
+ entity certificate can be verified according to defined policy. The
+ algorithm for this verification is specified in [RFC5280].
+
+ The automated processing provides assurance that the certificate is
+ valid. It does not indicate whether the subject is entitled to any
+ particular information or whether the subject ought to be trusted to
+ perform a particular service. These are authorization decisions.
+ Automatic processing will make some authorization decisions, but
+ others, depending on the application context, involve the human user.
+
+ In some situations, where automated procedures have failed to
+ establish the suitability of the certificate to the task, the human
+ user is the final arbitrator of the post certificate verification
+ authorization decisions. In the end, the human will decide whether
+ or not to accept an executable email attachment, to release personal
+ information, or to follow the instructions displayed by a web
+ browser. This decision will often be based on recognition and
+ previous experience.
+
+ The distinction between systematic processing and human processing is
+ rather straightforward. They can be complementary. While the
+ systematic process is focused on certification path construction and
+ verification, the human acceptance process is focused on recognition
+ and related previous experience.
+
+ There are some situations where systematic processing and human
+ processing interfere with each other. These issues are discussed in
+ the Section 9.
+
+1.4. 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. Different Types of Logotypes in Certificates
+
+ This specification defines the inclusion of three standard logotype
+ types:
+
+ * community logotype
+
+ * issuer organization logotype
+
+ * subject organization logotype
+
+ The community logotype is the general mark for a community. It
+ identifies a service concept for entity identification and
+ certificate issuance. Many issuers may use a community logotype to
+ co-brand with a global community in order to gain global recognition
+ of its local service provision. This type of community branding is
+ very common in the credit card business, where local independent card
+ issuers include a globally recognized brand (such as Visa and
+ Mastercard). Certificate issuers may include more than one community
+ logotype to indicate participation in more than one global community.
+
+ The issuer organization logotype is a logotype representing the
+ organization identified as part of the issuer name in the
+ certificate.
+
+ The subject organization logotype is a logotype representing the
+ organization identified in the subject name in the certificate.
+
+ In addition to the standard logotype types, this specification
+ accommodates inclusion of other logotype types where each class of
+ logotype is defined by an object identifier. The object identifier
+ can be either locally defined or an identifier defined in Section 4.4
+ of this document.
+
+3. Logotype Data
+
+ This specification defines two types of logotype data: image data and
+ audio data. Implementations MUST support image data; however,
+ support for audio data is OPTIONAL.
+
+ Image and audio data for logotypes can be provided by reference by
+ including a URI that identifies the location to the logotype data and
+ a one-way hash of the referenced data in the certificate. The
+ privacy-related properties for remote logotype data depend on four
+ parties: the certificate relying parties that use the information in
+ the certificate extension to fetch the logotype data, the certificate
+ issuers that populate the certificate extension, certificate
+ subscribers that request certificates that include the certificate
+ extension, and server operators that provide the logotype data.
+
+ Alternatively, embedding the logotype data in the certificate with
+ direct addressing (as defined in Section 4.3) provides improved
+ privacy properties and depends upon fewer parties. However, this
+ approach can significantly increase the size of the certificate.
+
+ Several image objects, representing the same visual content in
+ different formats, sizes, and color palates, may represent each
+ logotype image. At least one of the image objects representing a
+ logotype SHOULD contain an image with a width between 60 pixels and
+ 200 pixels and a height between 45 pixels and 150 pixels.
+
+ Several instances of audio data may further represent the same audio
+ sequence in different formats, resolutions, and languages. At least
+ one of the audio objects representing a logotype SHOULD provide text-
+ based audio data suitable for processing by text-to-speech software.
+
+ A typical use of text-based audio data is inclusion in web
+ applications where the audio text is placed as the "alt" attribute
+ value of an HTML image (img) element, and the language value obtained
+ from LogotypeAudioInfo is included as the "lang" attribute of that
+ image.
+
+ If a logotype of a certain type (as defined in Section 2) is
+ represented by more than one image object, then each image object
+ MUST contain variants of roughly the same visual content. Likewise,
+ if a logotype of a certain type is represented by more than one audio
+ object, then the audio objects MUST contain variants of the same
+ audio information. A spoken message in different languages is
+ considered a variation of the same audio information. When more than
+ one image object or more than one audio object for the same logotype
+ type is included in the certificate, the certificate issuer is
+ responsible for ensuring that the objects contain roughly the same
+ content. Compliant applications MUST NOT display more than one of
+ the image objects and MUST NOT play more than one of the audio
+ objects for any logotype type (see Section 2) at the same time.
+
+ A client MAY simultaneously display multiple logotypes of different
+ logotype types. For example, it may display one subject organization
+ logotype while also displaying a community logotype, but it MUST NOT
+ display multiple image variants of the same community logotype.
+
+ Each logotype present in a certificate MUST be represented by at
+ least one image data object.
+
+ Client applications SHOULD enhance processing and off-line
+ functionality by caching logotype data.
+
+4. Logotype Certificate Extension
+
+ This section specifies the syntax and semantics of the logotype
+ certificate extension.
+
+4.1. Extension Format
+
+ The logotype certificate extension MAY be included in public key
+ certificates [RFC5280] or attribute certificates [RFC5755]. The
+ logotype certificate extension MUST be identified by the following
+ object identifier:
+
+ id-pe-logotype OBJECT IDENTIFIER ::=
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-pe(1) 12 }
+
+ This extension MUST NOT be marked critical.
+
+ Logotype data may be referenced through either direct or indirect
+ addressing. Client applications SHOULD support both direct and
+ indirect addressing. Certificate issuing applications MUST support
+ direct addressing, and certificate issuing applications SHOULD
+ support indirect addressing.
+
+ The direct addressing includes information about each logotype in the
+ certificate, and URIs point to the image and audio data object.
+ Multiple URIs MAY be included for locations for obtaining the same
+ logotype object. Multiple hash values MAY be included, each computed
+ with a different one-way hash function. Direct addressing supports
+ cases where just one or a few alternative images and audio objects
+ are referenced.
+
+ The indirect addressing includes one or more references to an
+ external hashed data structure that contains information on the type,
+ content, and location of each image and audio object. Indirect
+ addressing supports cases where each logotype is represented by many
+ alternative audio or image objects.
+
+ Both direct and indirect addressing accommodate alternative URIs to
+ obtain exactly the same logotype data. This opportunity for
+ replication is intended to improve availability. Therefore, if a
+ client is unable to fetch the item from one URI, the client SHOULD
+ try another URI in the sequence. All direct addressing URIs SHOULD
+ use the HTTPS scheme (https://...), the HTTP scheme (http://...), or
+ the DATA scheme (data://...) [RFC3986]. However, the "data" URI
+ scheme MUST NOT be used with the indirect addressing. Clients MUST
+ support retrieval of the referenced LogotypeData with HTTP [RFC9110],
+ HTTP with TLS [RFC8446], or subsequent versions of these protocols.
+ Client applications SHOULD also support the "data" URI scheme
+ [RFC2397] for direct addressing with embedded logotype data within
+ the extension.
+
+ Note that the HTTPS scheme (https://...) requires the validation of
+ other certificates to establish a secure connection. For this
+ reason, the HTTP scheme (http://...) may be easier for a client to
+ handle. Also, the hash of the logotype data provides data integrity.
+
+ The logotype certificate extension MUST have the following syntax:
+
+ LogotypeExtn ::= SEQUENCE {
+ communityLogos [0] EXPLICIT SEQUENCE OF LogotypeInfo OPTIONAL,
+ issuerLogo [1] EXPLICIT LogotypeInfo OPTIONAL,
+ subjectLogo [2] EXPLICIT LogotypeInfo OPTIONAL,
+ otherLogos [3] EXPLICIT SEQUENCE OF OtherLogotypeInfo
+ OPTIONAL }
+
+ LogotypeInfo ::= CHOICE {
+ direct [0] LogotypeData,
+ indirect [1] LogotypeReference }
+
+ LogotypeData ::= SEQUENCE {
+ image SEQUENCE OF LogotypeImage OPTIONAL,
+ audio [1] SEQUENCE OF LogotypeAudio OPTIONAL }
+
+ LogotypeImage ::= SEQUENCE {
+ imageDetails LogotypeDetails,
+ imageInfo LogotypeImageInfo OPTIONAL }
+
+ LogotypeAudio ::= SEQUENCE {
+ audioDetails LogotypeDetails,
+ audioInfo LogotypeAudioInfo OPTIONAL }
+
+ LogotypeDetails ::= SEQUENCE {
+ mediaType IA5String, -- Media type name and optional
+ -- parameters
+ logotypeHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ logotypeURI SEQUENCE SIZE (1..MAX) OF IA5String }
+
+ LogotypeImageInfo ::= SEQUENCE {
+ type [0] LogotypeImageType DEFAULT color,
+ fileSize INTEGER, -- In octets, 0=unspecified
+ xSize INTEGER, -- Horizontal size in pixels
+ ySize INTEGER, -- Vertical size in pixels
+ resolution LogotypeImageResolution OPTIONAL,
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ LogotypeImageType ::= INTEGER { grayScale(0), color(1) }
+
+ LogotypeImageResolution ::= CHOICE {
+ numBits [1] INTEGER, -- Resolution in bits per pixel
+ tableSize [2] INTEGER } -- Number of colors or grey tones
+
+ LogotypeAudioInfo ::= SEQUENCE {
+ fileSize INTEGER, -- In octets, 0=unspecified
+ playTime INTEGER, -- In milliseconds, 0=unspecified
+ channels INTEGER, -- 0=unspecified,
+ -- 1=mono, 2=stereo, 4=quad
+ sampleRate [3] INTEGER OPTIONAL, -- Samples per second
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ OtherLogotypeInfo ::= SEQUENCE {
+ logotypeType OBJECT IDENTIFIER,
+ info LogotypeInfo }
+
+ LogotypeReference ::= SEQUENCE {
+ refStructHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ refStructURI SEQUENCE SIZE (1..MAX) OF IA5String }
+ -- Places to get the same LogotypeData
+ -- image or audio object
+
+ HashAlgAndValue ::= SEQUENCE {
+ hashAlg AlgorithmIdentifier,
+ hashValue OCTET STRING }
+
+ When using indirect addressing, the URI (refStructURI) pointing to
+ the external data structure MUST point to a resource that contains
+ the DER-encoded data with the syntax LogotypeData.
+
+ At least one of the optional elements in the LogotypeExtn structure
+ MUST be present.
+
+ When using direct addressing, at least one of the optional elements
+ in the LogotypeData structure MUST be present.
+
+ The LogotypeReference and LogotypeDetails structures explicitly
+ identify one or more one-way hash functions employed to authenticate
+ referenced image or audio objects. Certification Authorities (CAs)
+ MUST include a hash value for each referenced object, calculated on
+ the whole object. CAs MUST use the one-way hash function that is
+ associated with the certificate signature to compute one hash value,
+ and CAs MAY include other hash values. Clients MUST compute a one-
+ way hash value using one of the identified functions, and clients
+ MUST discard the logotype data if the computed hash value does not
+ match the hash value in the certificate extension.
+
+ A media type is used to specify the format of the image or audio
+ object containing the logotype data. The mediaType field MUST
+ contain a string that is constructed according to the ABNF [RFC5234]
+ rule for media-type provided in Section 8.3.1 of [RFC9110]. Media
+ types MAY include parameters. To keep the mediaType field as small
+ as possible, optional whitespace SHOULD NOT be included.
+
+ Image format requirements are specified in Section 7, and audio
+ format requirements are specified in Section 8.
+
+ When language is specified, the language tag MUST use the syntax in
+ [RFC5646].
+
+ The following logotype types are defined in this specification:
+
+ * community logotype: If communityLogos is present, the logotypes
+ MUST represent one or more communities with which the certificate
+ issuer is affiliated. The communityLogos MAY be present in an end
+ entity certificate, a CA certificate, or an attribute certificate.
+ The communityLogos contains a sequence of community logotypes,
+ each representing a different community. If more than one
+ community logotype is present, they MUST be placed in order of
+ preferred appearance. Some clients MAY choose to display a subset
+ of the present community logos; therefore, the placement within
+ the sequence aids the client selection. The most preferred
+ logotype MUST be first in the sequence, and the least preferred
+ logotype MUST be last in the sequence.
+
+ * issuer organization logotype: If issuerLogo is present, the
+ logotype MUST represent the issuer's organization. The logotype
+ MUST be consistent with, and require the presence of, an
+ organization name stored in the organization attribute in the
+ issuer field (for either a public key certificate or attribute
+ certificate). The issuerLogo MAY be present in an end entity
+ certificate, a CA certificate, or an attribute certificate.
+
+ * subject organization logotype: If subjectLogo is present, the
+ logotype MUST represent the subject's organization. The logotype
+ MUST be consistent with, and require the presence of, an
+ organization name stored in the organization attribute in the
+ subject field (for either a public key certificate or attribute
+ certificate). The subjectLogo MAY be present in an end entity
+ certificate, a CA certificate, or an attribute certificate.
+
+ The relationship between the subject organization and the subject
+ organization logotype, and the relationship between the issuer and
+ either the issuer organization logotype or the community logotype,
+ are relationships asserted by the issuer. The policies and practices
+ employed by the issuer that check subject organization logotypes or
+ claims about its issuer and community logotypes are outside the scope
+ of this document.
+
+4.2. Conventions for LogotypeImageInfo
+
+ When the optional LogotypeImageInfo is included with a logotype
+ image, the parameters MUST be used with the following semantics and
+ restrictions.
+
+ The xSize and ySize fields represent the recommended display size for
+ the logotype image. When a value of 0 (zero) is present, no
+ recommended display size is specified. When non-zero values are
+ present and these values differ from corresponding size values in the
+ referenced image object, then the referenced image SHOULD be scaled
+ to fit within the size parameters of LogotypeImageInfo while
+ preserving the x and y ratio. Dithering may produce a more
+ appropriate image than linear scaling.
+
+ The resolution field is redundant for all logotype image formats
+ listed in Section 7. The optional resolution field SHOULD be omitted
+ when the image format already contains this information.
+
+4.3. Embedded Images
+
+ If the logotype image is provided through direct addressing, then the
+ image MAY be stored within the logotype certificate extension using
+ the "data" scheme [RFC2397]. The syntax of the "data" URI scheme is
+ shown below, which incorporates Errata ID 2045 and uses modern ABNF
+ [RFC5234]:
+
+ dataurl = "data:" [ media-type ] [ ";base64" ] "," data
+ data = *(reserved / unreserved / escaped)
+ reserved = ";" / "/" / "?" / ":" / "@" / "&" / "=" / "+" /
+ "$" / ","
+ unreserved = alphanum / mark
+ alphanum = ALPHA / DIGIT
+ mark = "-" / "_" / "." / "!" / "~" / "*" / "'" / "(" / ")"
+ escaped = "%" hex hex
+ hex = HEXDIG / "a" / "b" / "c" / "d" / "e" / "f"
+
+ where media-type is defined in Section 8.3.1 of [RFC9110] and ALPHA,
+ DIGIT, and HEXDIG are defined in Appendix B.1 of [RFC5234].
+
+ When including the image data in the logotype certificate extension
+ using the "data" URI scheme, the following conventions apply:
+
+ * The value of mediaType in LogotypeDetails MUST be identical to the
+ media type value in the "data" URL.
+
+ * The hash of the image MUST be included in logotypeHash and MUST be
+ calculated over the same data as it would have been if the image
+ had been referenced through a link to an external resource.
+
+ | NOTE: As the "data" URI scheme is processed as a data source
+ | rather than as a URL, the image data is typically not limited
+ | by any URL length limit settings that otherwise apply to URLs
+ | in general.
+ |
+ | NOTE: Implementations need to be cautious about the size of
+ | images included in a certificate in order to ensure that the
+ | size of the certificate does not prevent the certificate from
+ | being used as intended.
+
+4.4. Other Logotypes
+
+ Logotypes identified by otherLogos (as defined in Section 4.1) can be
+ used to enhance the display of logotypes and marks that represent
+ partners, products, services, or any other characteristic associated
+ with the certificate or its intended application environment when the
+ standard logotype types are insufficient.
+
+ The conditions and contexts of the intended use of these logotypes
+ are defined at the discretion of the local client application.
+
+ Three other logotype types are defined in the follow subsections.
+
+4.4.1. Loyalty Logotype
+
+ When a loyalty logotype appears in otherLogos, it MUST be identified
+ by the id-logo-loyalty object identifier.
+
+ id-logo OBJECT IDENTIFIER ::= { id-pkix 20 }
+
+ id-logo-loyalty OBJECT IDENTIFIER ::= { id-logo 1 }
+
+ A loyalty logotype, if present, MUST contain a logotype associated
+ with a loyalty program related to the certificate or its use. The
+ relation between the certificate and the identified loyalty program
+ is beyond the scope of this document. The logotype certificate
+ extension MAY contain more than one loyalty logotype.
+
+ If more than one loyalty logotype is present, they MUST be placed in
+ order of preferred appearance. Some clients MAY choose to display a
+ subset of the present loyalty logotype data; therefore, the placement
+ within the sequence aids the client selection. The most preferred
+ loyalty logotype data MUST be first in the sequence, and the least
+ preferred loyalty logotype data MUST be last in the sequence.
+
+4.4.2. Certificate Background Logotype
+
+ When a certificate background logotype appears in otherLogos, it MUST
+ be identified by the id-logo-background object identifier.
+
+ id-logo-background OBJECT IDENTIFIER ::= { id-logo 2 }
+
+ The certificate background logotype, if present, MUST contain a
+ graphical image intended as a background image for the certificate
+ and/or a general audio sequence for the certificate. The background
+ image MUST allow black text to be clearly read when placed on top of
+ the background image. The logotype certificate extension MUST NOT
+ contain more than one certificate background logotype.
+
+4.4.3. Certificate Image Logotype
+
+ When a certificate image logotype appears in otherLogos, it MUST be
+ identified by the id-logo-certImage object identifier.
+
+ id-logo-certImage OBJECT IDENTIFIER ::= { id-logo 3 }
+
+ The certificate image logotype, if present, aids human interpretation
+ of a certificate by providing meaningful visual information to the
+ user interface (UI). The logotype certificate extension MUST NOT
+ contain more than one certificate image logotype.
+
+ Typical situations when a human needs to examine the visual
+ representation of a certificate are:
+
+ * A person establishes a secured channel with an authenticated
+ service. The person needs to determine the identity of the
+ service based on the authenticated credentials.
+
+ * A person validates the signature on critical information, such as
+ signed executable code, and needs to determine the identity of the
+ signer based on the signer's certificate.
+
+ * A person is required to select an appropriate certificate to be
+ used when authenticating to a service or identity management
+ infrastructure. The person needs to see the available
+ certificates in order to distinguish between them in the selection
+ process.
+
+ The display of certificate information to humans is challenging due
+ to lack of well-defined semantics for critical identity attributes.
+ Unless the application has out-of-band knowledge about a particular
+ certificate, the application will not know the exact nature of the
+ data stored in common identification attributes, such as
+ serialNumber, organizationName, country, etc. Consequently, the
+ application can display the actual data but faces the problem of
+ labeling that data in the UI and informing the human about the exact
+ nature (semantics) of that data. It is also challenging for the
+ application to determine which identification attributes are
+ important to display and how to organize them in a logical order.
+
+ When present, the certificate image MUST be a complete visual
+ representation of the certificate. This means that the display of
+ this certificate image represents all information about the
+ certificate that the issuer subjectively defines as relevant to show
+ to a typical human user within the typical intended use of the
+ certificate, giving adequate information about at least the following
+ three aspects of the certificate:
+
+ * certificate context
+
+ * certificate issuer
+
+ * certificate subject
+
+ Certificate context information is visual marks and/or textual
+ information that helps the typical user to understand the typical
+ usage and/or purpose of the certificate.
+
+ It is up to the issuer to decide what information -- in the form of
+ text, graphical symbols, and elements -- represents a complete visual
+ representation of the certificate. However, the visual
+ representation of certificate subject and certificate issuer
+ information from the certificate MUST have the same meaning as the
+ textual representation of that information in the certificate itself.
+
+ Applications providing a Graphical User Interface (GUI) to the
+ certificate user MAY present a certificate image as the only visual
+ representation of a certificate; however, the certificate user SHOULD
+ be able to easily obtain the details of the certificate content.
+
+5. Type of Certificates
+
+ Logotypes MAY be included in public key certificates and attribute
+ certificates at the discretion of the certificate issuer; however,
+ the relying party MUST NOT use the logotypes as part of certification
+ path validation or automated trust decisions. The sole purpose of
+ logotypes is to enhance the display of a particular certificate,
+ regardless of its position in a certification path.
+
+6. Use in Clients
+
+ All PKI implementations require relying party software to have some
+ mechanism to determine whether a trusted CA issues a particular
+ certificate. This is an issue for certification path validation,
+ including consistent policy and name checking.
+
+ After a certification path is successfully validated, the replying
+ party trusts the information that the CA includes in the certificate,
+ including any certificate extensions. The client software can choose
+ to make use of such information, or the client software can ignore
+ it. If the client is unable to support a provided logotype, the
+ client MUST NOT report an error; instead, the client MUST behave as
+ though no logotype certificate extension was included in the
+ certificate. Current standards do not provide any mechanism for
+ cross-certifying CAs to constrain subordinate CAs from including
+ private extensions (see Section 9).
+
+ Consequently, if relying party software accepts a CA, then it should
+ be prepared to (unquestioningly) display the associated logotypes to
+ its human user, given that it is configured to do so. Information
+ about the logotypes is provided so that the replying party software
+ can select the one that will best meet the needs of the human user.
+ This choice depends on the abilities of the human user, as well as
+ the capabilities of the platform on which the replaying party
+ software is running. If none of the provided logotypes meets the
+ needs of the human user or matches the capabilities of the platform,
+ then the logotypes can be ignored.
+
+ A client MAY, subject to local policy, choose to display none, one,
+ or any number of the logotypes in the logotype certificate extension.
+ In many cases, a client will be used in an environment with a good
+ network connection and also used in an environment with little or no
+ network connectivity. For example, a laptop computer can be docked
+ with a high-speed LAN connection, or it can be disconnected from the
+ network altogether. In recognition of this situation, the client
+ MUST include the ability to disable the fetching of logotypes.
+ However, locally cached logotypes can still be displayed when the
+ user disables the fetching of additional logotypes.
+
+ A client MAY, subject to local policy, choose any combination of
+ audio and image presentation for each logotype. That is, the client
+ MAY display an image with or without playing a sound, and it MAY play
+ a sound with or without displaying an image. A client MUST NOT play
+ more than one logotype audio sequence at the same time.
+
+ The logotype is to be displayed in conjunction with other identity
+ information contained in the certificate. The logotype is not a
+ replacement for this identity information.
+
+ Care is needed when designing replying party software to ensure that
+ an appropriate context of logotype information is provided. This is
+ especially difficult with audio logotypes. It is important that the
+ human user be able to recognize the context of the logotype, even if
+ other audio streams are being played.
+
+ If the relying party software is unable to successfully validate a
+ particular certificate, then it MUST NOT display any logotype data
+ associated with that certificate.
+
+7. Image Formats
+
+ Animated images SHOULD NOT be used.
+
+ The following table lists common image formats and the corresponding
+ media type. The table also indicates the support requirements for
+ these image formats. The file name extensions commonly used for each
+ of these formats is also provided. Implementations MAY support other
+ image formats.
+
+ +========+==============+===========+============+============+
+ | Format | Media Type | Extension | References | Implement? |
+ +========+==============+===========+============+============+
+ | JPEG | image/jpeg | .jpg | [JPEG] | MUST |
+ | | | .jpeg | [RFC2046] | support |
+ +--------+--------------+-----------+------------+------------+
+ | GIF | image/gif | .gif | [GIF] | MUST |
+ | | | | [RFC2046] | support |
+ +--------+--------------+-----------+------------+------------+
+ | SVG | image/ | .svg | [SVGT] | SHOULD |
+ | | svg+xml | | [SVGR] | support |
+ +--------+--------------+-----------+------------+------------+
+ | SVG + | image/ | .svgz | [SVGT] | MUST |
+ | GZIP | svg+xml+gzip | .svg.gz | [SVGZR] | support |
+ +--------+--------------+-----------+------------+------------+
+ | PNG | image/png | .png | [ISO15948] | SHOULD |
+ | | | | [PNGR] | support |
+ +--------+--------------+-----------+------------+------------+
+ | PDF | application/ | .pdf | [ISO32000] | MAY |
+ | | pdf | | [ISO19005] | support |
+ | | | | [RFC8118] | |
+ +--------+--------------+-----------+------------+------------+
+
+ Table 1: Image Formats
+
+ | NOTE: The image/svg+xml-compressed media type is widely
+ | implemented, but it has not yet been registered with IANA.
+
+ When a Scalable Vector Graphics (SVG) image is used, whether the
+ image is compressed or not, the SVG Tiny profile [SVGT] MUST be
+ followed, with these additional restrictions:
+
+ * The SVG image MUST NOT contain any Internationalized Resource
+ Identifier (IRI) references to information stored outside of the
+ SVG image of type B, C, or D, according to Section 14.1.4 of
+ [SVGT].
+
+ * The SVG image MUST NOT contain any script element, according to
+ Section 15.2 of [SVGT].
+
+ * The XML structure in the SVG file MUST use linefeed (0x0A) as the
+ end-of-line (EOL) character when calculating a hash over the SVG
+ image.
+
+ When a GZIP-compressed SVG image is fetched with HTTP, the client
+ will receive a response that includes these headers:
+
+ Content-Type: image/svg+xml
+ Content-Encoding: gzip
+
+ In this case, the octet stream of type image/svg+xml is compressed
+ with GZIP [RFC1952], as specified in [SVGR].
+
+ When an uncompressed SVG image is fetched with HTTP, the client will
+ receive a response with the same Content-Type header but no Content-
+ Encoding header.
+
+ Whether the SVG image is GZIP-compressed or uncompressed, the hash
+ value for the SVG image is calculated over the uncompressed SVG
+ content with canonicalized EOL characters, as specified above.
+
+ When an SVG image is embedded in the certificate extension using the
+ "data" URL scheme, the SVG image data MUST be provided in GZIP-
+ compressed form, and the XML structure, prior to compression, SHOULD
+ use linefeed (0x0A) as the end-of-line (EOL) character.
+
+ When a bitmap image is used, the PNG [ISO15948] format SHOULD be
+ used.
+
+ According to [ISO32000], when a Portable Document Format (PDF)
+ document is used, it MUST also be formatted according to the profile
+ PDF/A [ISO19005].
+
+8. Audio Formats
+
+ Implementations that support audio MUST support the MP3 audio format
+ [MP3] with a media type of "audio/mpeg" [RFC3003]. Implementations
+ SHOULD support text-based audio data with a media type of "text/
+ plain;charset=UTF-8". Implementations MAY support other audio
+ formats.
+
+ Text-based audio data using the media type of "text/
+ plain;charset=UTF-8" is intended to be used by text-to-speech
+ software. When this audio type is used, the following requirements
+ apply:
+
+ * LogotypeAudioInfo MUST be present and specify the language of the
+ text.
+
+ * The fileSize, playTime, and channels elements of LogotypeAudioInfo
+ MUST have the value of 0.
+
+ * The sampleRate element of LogotypeAudioInfo MUST be absent.
+
+9. Security Considerations
+
+ Implementations that simultaneously display multiple logotype types
+ (subject organization, issuer organization, community, or other) MUST
+ ensure that there is no ambiguity as to the binding between the image
+ and the type of logotype that the image represents. "Logotype type"
+ is defined in Section 1.1, and it refers to the type of entity or
+ affiliation represented by the logotype, not the of binary format of
+ the image or audio.
+
+ Logotypes are very difficult to securely and accurately define.
+ Names are also difficult in this regard, but logotypes are even
+ worse. It is quite difficult to specify what is, and what is not, a
+ legitimate logotype of an organization. There is an entire legal
+ structure around this issue, and it will not be repeated here.
+ However, issuers should be aware of the implications of including
+ images associated with a trademark or servicemark before doing so.
+ As logotypes can be difficult (and sometimes expensive) to verify,
+ the possibility of errors related to assigning wrong logotypes to
+ organizations is increased.
+
+ This is not a new issue for electronic identification instruments.
+ It is already dealt with in a number of similar situations in the
+ physical world, including physical employee identification cards. In
+ addition, there are situations where identification of logotypes is
+ rather simple and straightforward, such as logotypes for well-known
+ industries and institutes. These issues should not stop those
+ service providers who want to issue logotypes from doing so, where
+ relevant.
+
+ It is impossible to prevent fraudulent creation of certificates by
+ dishonest or badly performing issuers, containing names and logotypes
+ that the issuer has no claim to or has failed to check correctly.
+ Such certificates could be created in an attempt to socially engineer
+ a user into accepting a certificate. The premise used for the
+ logotype work is thus that logotype graphics in a certificate are
+ trusted only if the certificate is successfully validated within a
+ valid path. It is thus imperative that the representation of any
+ certificate that fails to validate is not enhanced in any way by
+ using the logotype data.
+
+ This underlines the necessity for CAs to provide reliable services
+ and the relying party's responsibility and need to carefully select
+ which CAs are trusted to provide public key certificates.
+
+ This also underlines the general necessity for relying parties to use
+ up-to-date software libraries to render or dereference data from
+ external sources, including logotype data in certificates, to
+ minimize risks related to processing potentially malicious data
+ before it has been adequately verified and validated. Implementers
+ should review the guidance in Section 7 of [RFC3986].
+
+ Referenced image objects are hashed in order to bind the image to the
+ signature of the certificate. Some image types, such as SVG, allow
+ part of the image to be collected from an external source by
+ incorporating a reference to an external file that contains the
+ image. If this feature were used within a logotype image, the hash
+ of the image would only cover the URI reference to the external image
+ file but not the referenced image data. Clients SHOULD verify that
+ SVG images meet all requirements listed in Section 7 and reject
+ images that contain references to external data.
+
+ CAs issuing certificates with embedded logotype images should be
+ cautious when accepting graphics from the certificate requester for
+ inclusion in the certificate if the hash algorithm used to sign the
+ certificate is vulnerable to collision attacks, as described in
+ [RFC6151]. In such a case, the accepted image may contain data that
+ could help an attacker to obtain colliding certificates with
+ identical certificate signatures.
+
+ Certification paths may also impose name constraints that are
+ systematically checked during certification path processing, which,
+ in theory, may be circumvented by logotypes.
+
+ Certificate path processing, as defined in [RFC5280], does not
+ constrain the inclusion of logotype data in certificates. A parent
+ CA can constrain certification path validation such that subordinate
+ CAs cannot issue valid certificates to end entities outside a limited
+ name space or outside specific certificate policies. A malicious CA
+ can comply with these name and policy requirements and still include
+ inappropriate logotypes in the certificates that it issues. These
+ certificates will pass the certification path validation algorithm,
+ which means the client will trust the logotypes in the certificates.
+ Since there is no technical mechanism to prevent or control
+ subordinate CAs from including the logotype certificate extension or
+ its contents, where appropriate, a parent CA could employ a legal
+ agreement to impose a suitable restriction on the subordinate CA.
+ This situation is not unique to the logotype certificate extension.
+
+ When a relying party fetches remote logotype data, a mismatch between
+ the media type provided in the mediaType field of the LogotypeDetails
+ and the Content-Type HTTP header of the retrieved object MUST be
+ treated as a failure, and the fetched logotype data should not be
+ presented to the user. However, if more than one location for the
+ remote logotype data is provided in the certificate extension, the
+ relying party MAY try to fetch the remote logotype data from an
+ alternate location to resolve the failure.
+
+ When a subscriber requests the inclusion of remote logotype data in a
+ certificate, the CA cannot be sure that any logotype data will be
+ available at the provided URI for the entire validity period of the
+ certificate. To mitigate this concern, the CA may provide the
+ logotype data from a server under its control, rather than a
+ subscriber-controlled server.
+
+ The controls available to a parent CA to protect itself from rogue
+ subordinate CAs are non-technical. They include:
+
+ * Contractual agreements of suitable behavior, including terms of
+ liability in case of material breach.
+
+ * Control mechanisms and procedures to monitor and follow the
+ behavior of subordinate CAs, including Certificate Transparency
+ [RFC9162].
+
+ * Use of certificate policies to declare an assurance level of
+ logotype data, as well as to guide applications on how to treat
+ and display logotypes.
+
+ * Use of revocation functions to revoke any misbehaving CA.
+
+ There is not a simple, straightforward, and absolute technical
+ solution. Rather, involved parties must settle some aspects of PKI
+ outside the scope of technical controls. As such, issuers need to
+ clearly identify and communicate the associated risks.
+
+10. Privacy Considerations
+
+ Certificates are commonly public objects, so the inclusion of
+ privacy-sensitive information in certificates should be avoided. The
+ more information that is included in a certificate, the greater the
+ likelihood that the certificate will reveal privacy-sensitive
+ information. The inclusion of logotype data needs to be considered
+ in this context.
+
+ Logotype data might be fetched from a server when it is needed. By
+ watching activity on the network, an observer can determine which
+ clients are making use of certificates that contain particular
+ logotype data. Since clients are expected to locally cache logotype
+ data, network traffic to the server containing the logotype data will
+ not be generated every time the certificate is used. Further, when
+ logotype data is not cached, activity on the network might reveal
+ certificate usage frequency. Even when logotype data is cached,
+ regardless of whether direct or indirect addressing is employed,
+ network traffic monitoring could reveal when logotype data is fetched
+ for the first time. Implementations MAY encrypt fetches of logotype
+ data using HTTPS, padding the data to a common size to reduce
+ visibility into the data that is being fetched. Likewise, servers
+ MAY reduce visibility into the data that is being returned by
+ encrypting with HTTPS and padding to a few common sizes.
+
+ Similarly, when fetching logotype data from a server, the server
+ operator can determine which clients are making use of certificates
+ that contain particular logotype data. As above, locally caching
+ logotype data will eliminate the need to fetch the logotype data each
+ time the certificate is used, and lack of caching would reveal usage
+ frequency. Even when implementations cache logotype data, regardless
+ of whether direct or indirect addressing is employed, the server
+ operator could observe when logotype data is fetched for the first
+ time.
+
+ In addition, the use of an encrypted DNS mechanism, such as DNS over
+ TLS (DoT) [RFC7858] or DNS over HTTPS (DoH) [RFC9230], hides the name
+ resolution traffic, which is usually a first step in fetching remote
+ logotype objects.
+
+ When the "data" URI scheme is used with direct addressing, there is
+ no network traffic to fetch logotype data, which avoids the
+ observations of network traffic or server operations described above.
+ To obtain this benefit, the certificate will be larger than one that
+ contains a URL. Due to the improved privacy posture, the "data" URI
+ scheme with direct addressing will be the only one that is supported
+ by some CAs. Privacy-aware certificate subscribers MAY wish to
+ insist that logotype data is embedded in the certificate with the
+ "data" URI scheme with direct addressing.
+
+ In cases where logotype data is cached by the relying party, the
+ cache index should include the hash values of the associated logotype
+ data with the goal of fetching the logotype data only once, even when
+ it is referenced by multiple URIs. The index should include hash
+ values for all supported hash algorithms. The cached data should
+ include the media type as well as the logotype data. Implementations
+ should give preference to logotype data that is already in the cache
+ when multiple alternatives are offered in the LogotypeExtn
+ certificate extension.
+
+ When the "data" URI scheme is used, the relying party MAY add the
+ embedded logotype data to the local cache, which could avoid the need
+ to fetch the logotype data if it is referenced by a URL in another
+ certificate.
+
+ When fetching remote logotype data, relying parties should use the
+ most privacy-preserving options that are available to minimize the
+ opportunities for servers to "fingerprint" clients. For example,
+ avoid cookies, ETags, and client certificates.
+
+ When a relying party encounters a new certificate, the lack of
+ network traffic to fetch logotype data might indicate that a
+ certificate with references to the same logotype data has been
+ previously processed and cached.
+
+ TLS 1.3 [RFC8446] includes the ability to encrypt the server's
+ certificate in the TLS handshake, which helps hide the server's
+ identity from anyone that is watching activity on the network. If
+ the server's certificate includes remote logotype data, the client
+ fetching that data might disclose the otherwise protected server
+ identity.
+
+11. IANA Considerations
+
+ For the new ASN.1 module in Appendix A.2, IANA has assigned the
+ following OID in the "SMI Security for PKIX Module Identifier"
+ registry (1.3.6.1.5.5.7.0):
+
+ +=========+======================+============+
+ | Decimal | Description | References |
+ +=========+======================+============+
+ | 107 | id-mod-logotype-2022 | RFC 9399 |
+ +---------+----------------------+------------+
+
+ Table 2
+
+ IANA has updated the entries in the "Structure of Management
+ Information (SMI) Numbers" registry that referred to [RFC3709] or
+ [RFC6170] to refer to this document. These entries are noted in the
+ tables below.
+
+ From the "SMI Security for PKIX Module Identifier" registry
+ (1.3.6.1.5.5.7.0):
+
+ +=========+===========================+============+
+ | Decimal | Description | References |
+ +=========+===========================+============+
+ | 22 | id-mod-logotype | RFC 9399 |
+ +---------+---------------------------+------------+
+ | 68 | id-mod-logotype-certimage | RFC 9399 |
+ +---------+---------------------------+------------+
+
+ Table 3
+
+ From the "SMI Security for PKIX Certificate Extension" registry
+ (1.3.6.1.5.5.7.1):
+
+ +=========+================+============+
+ | Decimal | Description | References |
+ +=========+================+============+
+ | 12 | id-pe-logotype | RFC 9399 |
+ +---------+----------------+------------+
+
+ Table 4
+
+ From the "SMI Security for PKIX Other Logotype Identifiers" registry
+ (1.3.6.1.5.5.7.20):
+
+ +=========+====================+============+
+ | Decimal | Description | References |
+ +=========+====================+============+
+ | 1 | id-logo-loyalty | RFC 9399 |
+ +---------+--------------------+------------+
+ | 2 | id-logo-background | RFC 9399 |
+ +---------+--------------------+------------+
+ | 3 | id-logo-certImage | RFC 9399 |
+ +---------+--------------------+------------+
+
+ Table 5
+
+12. References
+
+12.1. Normative References
+
+ [GIF] CompuServe Incorporated, "Graphics Interchange Format",
+ Version 89a, July 1990,
+ <https://www.w3.org/Graphics/GIF/spec-gif89a.txt>.
+
+ [ISO15948] ISO/IEC, "Information technology -- Computer graphics and
+ image processing -- Portable Network Graphics (PNG):
+ Functional specification", ISO/IEC 15948:2004, March 2004.
+
+ [JPEG] ITU-T, "Information technology -- Digital compression and
+ coding of continuous-tone still images: JPEG File
+ Interchange Format (JFIF)", ITU-T Recommendation T.871,
+ ISO/IEC 10918-5:2013, May 2013.
+
+ [MP3] ISO/IEC, "Information technology -- Generic coding of
+ moving pictures and associated audio information -- Part
+ 3: Audio", ISO/IEC 13818-3:1998, April 1998.
+
+ [NEW-ASN1] ITU-T, "Information technology -- Abstract Syntax Notation
+ One (ASN.1): Specification of basic notation", ITU-T
+ Recommendation X.680, ISO/IEC 8824-1:2021, February 2021,
+ <https://www.itu.int/rec/T-REC-X.680>.
+
+ [RFC1952] Deutsch, P., "GZIP file format specification version 4.3",
+ RFC 1952, DOI 10.17487/RFC1952, May 1996,
+ <https://www.rfc-editor.org/info/rfc1952>.
+
+ [RFC2046] Freed, N. and N. Borenstein, "Multipurpose Internet Mail
+ Extensions (MIME) Part Two: Media Types", RFC 2046,
+ DOI 10.17487/RFC2046, November 1996,
+ <https://www.rfc-editor.org/info/rfc2046>.
+
+ [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
+ Requirement Levels", BCP 14, RFC 2119,
+ DOI 10.17487/RFC2119, March 1997,
+ <https://www.rfc-editor.org/info/rfc2119>.
+
+ [RFC2397] Masinter, L., "The "data" URL scheme", RFC 2397,
+ DOI 10.17487/RFC2397, August 1998,
+ <https://www.rfc-editor.org/info/rfc2397>.
+
+ [RFC3003] Nilsson, M., "The audio/mpeg Media Type", RFC 3003,
+ DOI 10.17487/RFC3003, November 2000,
+ <https://www.rfc-editor.org/info/rfc3003>.
+
+ [RFC3986] Berners-Lee, T., Fielding, R., and L. Masinter, "Uniform
+ Resource Identifier (URI): Generic Syntax", STD 66,
+ RFC 3986, DOI 10.17487/RFC3986, January 2005,
+ <https://www.rfc-editor.org/info/rfc3986>.
+
+ [RFC5234] Crocker, D., Ed. and P. Overell, "Augmented BNF for Syntax
+ Specifications: ABNF", STD 68, RFC 5234,
+ DOI 10.17487/RFC5234, January 2008,
+ <https://www.rfc-editor.org/info/rfc5234>.
+
+ [RFC5280] Cooper, D., Santesson, S., Farrell, S., Boeyen, S.,
+ Housley, R., and W. Polk, "Internet X.509 Public Key
+ Infrastructure Certificate and Certificate Revocation List
+ (CRL) Profile", RFC 5280, DOI 10.17487/RFC5280, May 2008,
+ <https://www.rfc-editor.org/info/rfc5280>.
+
+ [RFC5646] Phillips, A., Ed. and M. Davis, Ed., "Tags for Identifying
+ Languages", BCP 47, RFC 5646, DOI 10.17487/RFC5646,
+ September 2009, <https://www.rfc-editor.org/info/rfc5646>.
+
+ [RFC5755] Farrell, S., Housley, R., and S. Turner, "An Internet
+ Attribute Certificate Profile for Authorization",
+ RFC 5755, DOI 10.17487/RFC5755, January 2010,
+ <https://www.rfc-editor.org/info/rfc5755>.
+
+ [RFC8174] Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC
+ 2119 Key Words", BCP 14, RFC 8174, DOI 10.17487/RFC8174,
+ May 2017, <https://www.rfc-editor.org/info/rfc8174>.
+
+ [RFC8446] Rescorla, E., "The Transport Layer Security (TLS) Protocol
+ Version 1.3", RFC 8446, DOI 10.17487/RFC8446, August 2018,
+ <https://www.rfc-editor.org/info/rfc8446>.
+
+ [RFC9110] Fielding, R., Ed., Nottingham, M., Ed., and J. Reschke,
+ Ed., "HTTP Semantics", STD 97, RFC 9110,
+ DOI 10.17487/RFC9110, June 2022,
+ <https://www.rfc-editor.org/info/rfc9110>.
+
+ [SVGT] World Wide Web Consortium, "Scalable Vector Graphics (SVG)
+ Tiny 1.2 Specification", W3C REC-SVGTiny12-20081222,
+ December 2008,
+ <http://www.w3.org/TR/2008/REC-SVGTiny12-20081222/>.
+
+12.2. Informative References
+
+ [ISO19005] ISO, "Document management -- Electronic document file
+ format for long-term preservation -- Part 1: Use of PDF
+ 1.4 (PDF/A-1)", ISO 19005-1:2005, October 2005.
+
+ [ISO32000] ISO, "Document management -- Portable document format --
+ Part 1: PDF 1.7", ISO 32000-1:2008, July 2008.
+
+ [OLD-ASN1] CCITT, "Specification of Abstract Syntax Notation One
+ (ASN.1)", CCITT Recommendation X.208, November 1988,
+ <https://www.itu.int/rec/T-REC-X.208/en>.
+
+ [PNGR] World Wide Web Consortium, "Media Type Registration for
+ image/png",
+ <https://www.iana.org/assignments/media-types/image/png>.
+
+ [RFC3709] Santesson, S., Housley, R., and T. Freeman, "Internet
+ X.509 Public Key Infrastructure: Logotypes in X.509
+ Certificates", RFC 3709, DOI 10.17487/RFC3709, February
+ 2004, <https://www.rfc-editor.org/info/rfc3709>.
+
+ [RFC5912] Hoffman, P. and J. Schaad, "New ASN.1 Modules for the
+ Public Key Infrastructure Using X.509 (PKIX)", RFC 5912,
+ DOI 10.17487/RFC5912, June 2010,
+ <https://www.rfc-editor.org/info/rfc5912>.
+
+ [RFC6151] Turner, S. and L. Chen, "Updated Security Considerations
+ for the MD5 Message-Digest and the HMAC-MD5 Algorithms",
+ RFC 6151, DOI 10.17487/RFC6151, March 2011,
+ <https://www.rfc-editor.org/info/rfc6151>.
+
+ [RFC6170] Santesson, S., Housley, R., Bajaj, S., and L. Rosenthol,
+ "Internet X.509 Public Key Infrastructure -- Certificate
+ Image", RFC 6170, DOI 10.17487/RFC6170, May 2011,
+ <https://www.rfc-editor.org/info/rfc6170>.
+
+ [RFC6268] Schaad, J. and S. Turner, "Additional New ASN.1 Modules
+ for the Cryptographic Message Syntax (CMS) and the Public
+ Key Infrastructure Using X.509 (PKIX)", RFC 6268,
+ DOI 10.17487/RFC6268, July 2011,
+ <https://www.rfc-editor.org/info/rfc6268>.
+
+ [RFC7858] Hu, Z., Zhu, L., Heidemann, J., Mankin, A., Wessels, D.,
+ and P. Hoffman, "Specification for DNS over Transport
+ Layer Security (TLS)", RFC 7858, DOI 10.17487/RFC7858, May
+ 2016, <https://www.rfc-editor.org/info/rfc7858>.
+
+ [RFC8118] Hardy, M., Masinter, L., Markovic, D., Johnson, D., and M.
+ Bailey, "The application/pdf Media Type", RFC 8118,
+ DOI 10.17487/RFC8118, March 2017,
+ <https://www.rfc-editor.org/info/rfc8118>.
+
+ [RFC9162] Laurie, B., Messeri, E., and R. Stradling, "Certificate
+ Transparency Version 2.0", RFC 9162, DOI 10.17487/RFC9162,
+ December 2021, <https://www.rfc-editor.org/info/rfc9162>.
+
+ [RFC9216] Gillmor, D. K., Ed., "S/MIME Example Keys and
+ Certificates", RFC 9216, DOI 10.17487/RFC9216, April 2022,
+ <https://www.rfc-editor.org/info/rfc9216>.
+
+ [RFC9230] Kinnear, E., McManus, P., Pauly, T., Verma, T., and C.A.
+ Wood, "Oblivious DNS over HTTPS", RFC 9230,
+ DOI 10.17487/RFC9230, June 2022,
+ <https://www.rfc-editor.org/info/rfc9230>.
+
+ [SVGR] World Wide Web Consortium, "Media Type Registration for
+ image/svg+xml", <https://www.iana.org/assignments/media-
+ types/image/svg+xml>.
+
+ [SVGZR] "A separate MIME type for svgz files is needed",
+ <https://github.com/w3c/svgwg/issues/701>.
+
+Appendix A. ASN.1 Modules
+
+A.1. ASN.1 Modules with 1988 Syntax
+
+ This appendix contains two ASN.1 modules, both using the old syntax
+ [OLD-ASN1].
+
+ The first ASN.1 module provides the syntax for the logotype
+ certificate extension. Only comments have changed in the module from
+ [RFC3709] and the IMPORTS now come from [RFC5280].
+
+ The second ASN.1 module provides the certificate image object
+ identifier. The module is unchanged from [RFC6170].
+
+ <CODE BEGINS>
+ LogotypeCertExtn
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-mod-logotype(22) }
+
+ DEFINITIONS IMPLICIT TAGS ::=
+ BEGIN
+
+ IMPORTS
+ AlgorithmIdentifier FROM PKIX1Explicit88 -- RFC 5280
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-pkix1-explicit(18) };
+
+ -- Logotype Certificate Extension OID
+
+ id-pe-logotype OBJECT IDENTIFIER ::=
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-pe(1) 12 }
+
+
+ -- Logotype Certificate Extension Syntax
+
+ LogotypeExtn ::= SEQUENCE {
+ communityLogos [0] EXPLICIT SEQUENCE OF LogotypeInfo OPTIONAL,
+ issuerLogo [1] EXPLICIT LogotypeInfo OPTIONAL,
+ subjectLogo [2] EXPLICIT LogotypeInfo OPTIONAL,
+ otherLogos [3] EXPLICIT SEQUENCE OF OtherLogotypeInfo
+ OPTIONAL }
+
+ -- Note: At least one of the OPTIONAL components MUST be present
+
+ LogotypeInfo ::= CHOICE {
+ direct [0] LogotypeData,
+ indirect [1] LogotypeReference }
+
+ LogotypeData ::= SEQUENCE {
+ image SEQUENCE OF LogotypeImage OPTIONAL,
+ audio [1] SEQUENCE OF LogotypeAudio OPTIONAL }
+
+ -- Note: At least one of the OPTIONAL components MUST be present
+
+ LogotypeImage ::= SEQUENCE {
+ imageDetails LogotypeDetails,
+ imageInfo LogotypeImageInfo OPTIONAL }
+
+ LogotypeAudio ::= SEQUENCE {
+ audioDetails LogotypeDetails,
+ audioInfo LogotypeAudioInfo OPTIONAL }
+
+ LogotypeDetails ::= SEQUENCE {
+ mediaType IA5String, -- Media type name and optional
+ -- parameters
+ logotypeHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ logotypeURI SEQUENCE SIZE (1..MAX) OF IA5String }
+
+ LogotypeImageInfo ::= SEQUENCE {
+ type [0] LogotypeImageType DEFAULT color,
+ fileSize INTEGER, -- In octets, 0=unspecified
+ xSize INTEGER, -- Horizontal size in pixels
+ ySize INTEGER, -- Vertical size in pixels
+ resolution LogotypeImageResolution OPTIONAL,
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ LogotypeImageType ::= INTEGER { grayScale(0), color(1) }
+
+ LogotypeImageResolution ::= CHOICE {
+ numBits [1] INTEGER, -- Resolution in bits per pixel
+ tableSize [2] INTEGER } -- Number of colors or grey tones
+
+ LogotypeAudioInfo ::= SEQUENCE {
+ fileSize INTEGER, -- In octets, 0=unspecified
+ playTime INTEGER, -- In milliseconds, 0=unspecified
+ channels INTEGER, -- 0=unspecified,
+ -- 1=mono, 2=stereo, 4=quad
+ sampleRate [3] INTEGER OPTIONAL, -- Samples per second
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ OtherLogotypeInfo ::= SEQUENCE {
+ logotypeType OBJECT IDENTIFIER,
+ info LogotypeInfo }
+
+ LogotypeReference ::= SEQUENCE {
+ refStructHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ refStructURI SEQUENCE SIZE (1..MAX) OF IA5String }
+ -- Places to get the same LogotypeData
+ -- image or audio object
+
+ -- Note: The referenced LogotypeData binary file contains a
+ -- DER-encoded LogotypeData type
+
+ HashAlgAndValue ::= SEQUENCE {
+ hashAlg AlgorithmIdentifier,
+ hashValue OCTET STRING }
+
+ -- Other logotype type OIDs
+
+ id-logo OBJECT IDENTIFIER ::= { iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7) 20 }
+
+ id-logo-loyalty OBJECT IDENTIFIER ::= { id-logo 1 }
+
+ id-logo-background OBJECT IDENTIFIER ::= { id-logo 2 }
+
+ END
+
+
+ CERT-IMAGE-MODULE { iso(1) identified-organization(3) dod(6)
+ internet(1) security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-mod-logotype-certimage(68) }
+
+ DEFINITIONS EXPLICIT TAGS ::=
+ BEGIN
+
+ EXPORTS ALL; -- export all items from this module
+
+ id-logo-certImage OBJECT IDENTIFIER ::=
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-logo(20) 3 }
+
+ END
+ <CODE ENDS>
+
+A.2. ASN.1 Module with 2002 Syntax
+
+ Some developers like to use the latest version of ASN.1 standards.
+ This appendix provides an ASN.1 module to assist in that goal. It
+ uses the ASN.1 syntax defined in [NEW-ASN1], and it follows the
+ conventions established in [RFC5912] and [RFC6268].
+
+ This ASN.1 module incorporates the module from [RFC3709] and the
+ module from [RFC6170].
+
+ Note that [NEW-ASN1] was published in 2021, and all of the features
+ used in this module are backward compatible with the specification
+ that was published in 2002.
+
+ <CODE BEGINS>
+ LogotypeCertExtn-2022
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-mod-logotype-2022(107) }
+
+ DEFINITIONS IMPLICIT TAGS ::=
+ BEGIN
+
+ IMPORTS
+ EXTENSION
+ FROM PKIX-CommonTypes-2009 -- RFC 5912
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-mod-pkixCommon-02(57) }
+
+ AlgorithmIdentifier{}, DIGEST-ALGORITHM
+ FROM AlgorithmInformation-2009
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-mod(0)
+ id-mod-algorithmInformation-02(58) } ;
+
+
+ -- Logotype Certificate Extension
+
+ ext-logotype EXTENSION ::= {
+ SYNTAX LogotypeExtn
+ IDENTIFIED BY id-pe-logotype }
+
+ -- Logotype Certificate Extension OID
+
+ id-pe-logotype OBJECT IDENTIFIER ::=
+ { iso(1) identified-organization(3) dod(6) internet(1)
+ security(5) mechanisms(5) pkix(7) id-pe(1) 12 }
+
+ -- Logotype Certificate Extension Syntax
+
+ LogotypeExtn ::= SEQUENCE {
+ communityLogos [0] EXPLICIT SEQUENCE OF LogotypeInfo OPTIONAL,
+ issuerLogo [1] EXPLICIT LogotypeInfo OPTIONAL,
+ subjectLogo [2] EXPLICIT LogotypeInfo OPTIONAL,
+ otherLogos [3] EXPLICIT SEQUENCE OF OtherLogotypeInfo
+ OPTIONAL }
+ -- At least one of the OPTIONAL components MUST be present
+ ( WITH COMPONENTS { ..., communityLogos PRESENT } |
+ WITH COMPONENTS { ..., issuerLogo PRESENT } |
+ WITH COMPONENTS { ..., subjectLogo PRESENT } |
+ WITH COMPONENTS { ..., otherLogos PRESENT } )
+
+ LogotypeInfo ::= CHOICE {
+ direct [0] LogotypeData,
+ indirect [1] LogotypeReference }
+
+ LogotypeData ::= SEQUENCE {
+ image SEQUENCE OF LogotypeImage OPTIONAL,
+ audio [1] SEQUENCE OF LogotypeAudio OPTIONAL }
+ -- At least one image component MUST be present
+ ( WITH COMPONENTS { ..., image PRESENT } )
+
+ LogotypeImage ::= SEQUENCE {
+ imageDetails LogotypeDetails,
+ imageInfo LogotypeImageInfo OPTIONAL }
+
+ LogotypeAudio ::= SEQUENCE {
+ audioDetails LogotypeDetails,
+ audioInfo LogotypeAudioInfo OPTIONAL }
+
+ LogotypeDetails ::= SEQUENCE {
+ mediaType IA5String, -- Media type name and optional
+ -- parameters
+ logotypeHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ logotypeURI SEQUENCE SIZE (1..MAX) OF IA5String }
+
+ LogotypeImageInfo ::= SEQUENCE {
+ type [0] LogotypeImageType DEFAULT color,
+ fileSize INTEGER, -- In octets, 0=unspecified
+ xSize INTEGER, -- Horizontal size in pixels
+ ySize INTEGER, -- Vertical size in pixels
+ resolution LogotypeImageResolution OPTIONAL,
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ LogotypeImageType ::= INTEGER { grayScale(0), color(1) }
+
+ LogotypeImageResolution ::= CHOICE {
+ numBits [1] INTEGER, -- Resolution in bits
+ tableSize [2] INTEGER } -- Number of colors or grey tones
+
+ LogotypeAudioInfo ::= SEQUENCE {
+ fileSize INTEGER, -- In octets, 0=unspecified
+ playTime INTEGER, -- In milliseconds, 0=unspecified
+ channels INTEGER, -- 0=unspecified
+ -- 1=mono, 2=stereo, 4=quad
+ sampleRate [3] INTEGER OPTIONAL, -- Samples per second
+ language [4] IA5String OPTIONAL } -- RFC 5646 Language Tag
+
+ OtherLogotypeInfo ::= SEQUENCE {
+ logotypeType OBJECT IDENTIFIER,
+ info LogotypeInfo }
+
+ LogotypeReference ::= SEQUENCE {
+ refStructHash SEQUENCE SIZE (1..MAX) OF HashAlgAndValue,
+ refStructURI SEQUENCE SIZE (1..MAX) OF IA5String }
+ -- Places to get the same LogotypeData
+ -- image or audio object
+
+ -- Note: The referenced LogotypeData binary file contains a
+ -- DER-encoded LogotypeData type
+
+ HashAlgAndValue ::= SEQUENCE {
+ hashAlg AlgorithmIdentifier{DIGEST-ALGORITHM, {...}},
+ hashValue OCTET STRING }
+
+ -- Other logotype type OIDs
+
+ id-logo OBJECT IDENTIFIER ::= { iso(1) identified-organization(3)
+ dod(6) internet(1) security(5) mechanisms(5) pkix(7) 20 }
+
+ id-logo-loyalty OBJECT IDENTIFIER ::= { id-logo 1 }
+
+ id-logo-background OBJECT IDENTIFIER ::= { id-logo 2 }
+
+ id-logo-certImage OBJECT IDENTIFIER ::= { id-logo 3 }
+
+ END
+ <CODE ENDS>
+
+Appendix B. Examples
+
+B.1. Example from RFC 3709
+
+ The following example displays a logotype certificate extension
+ containing one issuer organization logotype using direct addressing.
+ The issuer organization logotype image is of the type image/gif. The
+ logotype image is referenced through one URI, and the image is hashed
+ with SHA-256. This example is changed from [RFC3709] to use SHA-256
+ instead of SHA-1.
+
+ The values on the left are the ASN.1 tag (in hexadecimal) and the
+ length (in decimal).
+
+ 30 122: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER logotype (1 3 6 1 5 5 7 1 12)
+ 04 110: OCTET STRING, encapsulates {
+ 30 108: SEQUENCE {
+ A1 106: [1] {
+ A0 104: [0] {
+ 30 102: SEQUENCE {
+ 30 100: SEQUENCE {
+ 30 98: SEQUENCE {
+ 16 9: IA5String 'image/gif'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : 6A 58 50 2E 59 67 F9 DD D1 8A FE BD 0D B1 FE 60
+ : A5 13 1B DF 0F B2 BE F0 B5 73 45 50 BA 1B BF 19
+ : }
+ : }
+ 30 34: SEQUENCE {
+ 16 32: IA5String 'http://logo.example.com/logo.gif'
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+
+B.2. Issuer Organization Logotype Example
+
+ The following example displays a logotype certificate extension
+ containing one issuer organization logotype using direct addressing.
+ The issuer organization logotype image is of the type image/jpeg.
+ The logotype image is referenced through one URI, and the image is
+ hashed with SHA-256.
+
+ The values on the left are the ASN.1 tag (in hexadecimal) and the
+ length (in decimal).
+
+ 30 124: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER logotype (1 3 6 1 5 5 7 1 12)
+ 04 112: OCTET STRING, encapsulates {
+ 30 110: SEQUENCE {
+ A1 108: [1] {
+ A0 106: [0] {
+ 30 104: SEQUENCE {
+ 30 102: SEQUENCE {
+ 30 100: SEQUENCE {
+ 16 10: IA5String 'image/jpeg'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : 1E 8F 96 FD D3 50 53 EF C6 1C 9F FC F0 00 2E 53
+ : B4 9C 24 9A 32 C5 E9 0C 2C 39 39 D3 AD 6D A9 09
+ : }
+ : }
+ 30 35: SEQUENCE {
+ 16 33: IA5String 'http://logo.example.com/logo.jpeg'
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+
+B.3. Embedded Image Example
+
+ The following example displays a logotype certificate extension
+ containing one subject organization logotype using direct addressing.
+ The subject organization logotype image uses image/svg+xml+gzip. The
+ logotype image is embedded in the certificate extension with a
+ "data:" URI, and the image is hashed by SHA-256. This technique
+ produces a large certificate extension but offers reduced latency and
+ improved privacy.
+
+ The values on the left are the ASN.1 tag (in hexadecimal) and the
+ length (in decimal).
+
+ 30 2148: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER logotype (1 3 6 1 5 5 7 1 12)
+ 04 2134: OCTET STRING, encapsulates {
+ 30 2130: SEQUENCE {
+ A2 2126: [2] {
+ A0 2122: [0] {
+ 30 2118: SEQUENCE {
+ 30 2114: SEQUENCE {
+ 30 2110: SEQUENCE {
+ 16 18: IA5String 'image/svg+xml+gzip'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : C5 AC 94 1A 0A 25 1F B3 16 6F 97 C5 52 40 9B 49
+ : 9E 7B 92 61 5A B0 A2 6C 19 BF B9 D8 09 C5 D9 E7
+ : }
+ : }
+ 30 2035: SEQUENCE {
+ 16 2031: IA5String
+ : ''
+ : '28tY29weS5zdmcApVbbbhs3EH3nV0y3Lw2Q9fK2JLewHDROU'
+ : 'BRo2iBxW+RRlTa2UFkypIWV5ut7zlB2UqF9cuLlUktyLmfOz'
+ : 'PD8xafbtdyPu/1qu5k17sw2sp/mm+V8vd2Ms2azbV5cmPNvX'
+ : 'v16efXh7WvZ31/L299e/vzTpTRt1/0RLrvu1dUref/7j+Ktd'
+ : 'Xawsete/9IYaW6m6e77rjscDmeHcLbdXXdX7zpu6t69vmxxo'
+ : 'n08AREdRDt7tpyWDRRSz7+tgp2b/ew/hEKI5WGoPKyW082s8'
+ : 'SmeWf13NzVyM66ub6ZZk+xXH+9X4+Hl9tOssWLly3553ARpd'
+ : '7txP+7uxx/2d+NiejefVttZ8+nNavkBj9yO40RLb8dpvpxP8'
+ : 'wtzuRvn07iUP/+Wu+20my9GcWfOPpfDbjVN44YLb8dp3Mn7c'
+ : 'b3aXGNCAICCc+a8+yLo/FpwfLP/uN3dzhqdriH5uwfbnj9a+'
+ : 'Uz2i/maK66utA+zZ435uFqvZ823R38Q1t32Lw3pZqThd/PpR'
+ : 'paz5o2LNkocvCzaIm0vrQvSpog359lLy3my0ga+e3Hp+B4In'
+ : 'jVFPD9awdhnrGEFW30Sl/Pnpvta2QBVxUEVxFbJ2VUFfYC01'
+ : 'pUs+O4GK84V/k6CHUFyhvhiDVQF8Y5aPDbmnsrXbS74DANjg'
+ : 'uwgENZLPwjUYVTRJQgEpiLR0ctiWj+Ig8rCvZAArxKExEEWM'
+ : 'JLqMA1F+ggnsQDXgpQeomJPCVhtCRycNrAWxgAI+g1Qsr6IU'
+ : 'xlomBswjydYBEgOeVCDoRreBjiFjX2SdSA60BP5DgQM63xoP'
+ : 'lWHbNq+egAEeAzxyNAdCQz+sDEMOhaGisKJdSlS6gtWWm4M1'
+ : 'rQwP0egEBIhhFLoXuCJhR4mT5RJBaiLKqqFROUEzYr1idG0g'
+ : 'ahwCzEnk+AMJLdp0FevQQ6VZ+SKOwGlOIJOh1MVjo0eB6DRA'
+ : '10SRpSY6il/eFFKAm+MKSIWNFqSo4OFnORfwH5wJHCMNM0ql'
+ : 'DRlcIwUEkDlgiSBhiEpBgMKOx5FdAYqI3KYewKKkAItTABTk'
+ : 'p5khI86kgbOgRywEBR0VGcwAjf8t9wqvdUMG6gLAbI0QQ8Cb'
+ : 'zCTtCSn/DEhCbm++duQaiRG1mQkdWHnminHA+r5wpLvsJbCA'
+ : 'LUKsDW5NAj43J+AD5vpfamUzJqiRJACmCWwIMhQq4HmYGKai'
+ : 'iJPmIvpS80UzTtAjdSraApQZogslgFcJHw0y5WoEXDYr/aTq'
+ : 'fxk2qhcg3z6ETQL+S18llvHOZQvlEOVEVpzqCozE9V6JZhh/'
+ : 'lCslg7mUFY4AR7IlcApmgV6gz3DCSDe56fQ0SRS7el0NJWO8'
+ : 'mQ6mkc6ylPpaL7QUZ5IR/M/dEwoJiEp+L6iT4cdSyIp4ljDk'
+ : 'oaZpQlgMoz0ApahjTiTWbZYu9v+MUqVjY61j2Bxr68bPF3uS'
+ : '1232qAyAQDMhr4MRyVZq5l2QcuwgY/oTozbgoIKycH+yQxhz'
+ : 'QsPJQ/ne9OmRKvYH1AeKA/EQRtzrmaYUiHUhpJOW4breSaxZ'
+ : '/TVc3ZAQJKOagAJiw6pRHVkBMIBa5E+SUMWi0ZNW1Rfn/xQX'
+ : 'ywHXyMHN5G8WF6gZ2IVjANHMIJQ1lAJQE8MJjZHJiUtQZAWz'
+ : 'mkisDywTVWSqLkkQG2NNB3wwyaerqRGLNKpvwUOhaQFiYcqv'
+ : 'iSjvp1n8WnRRzXFs9IXDxiiDd8HU/ROoAGn9+QgTPEVu6HaN'
+ : '6i0VPuv1SCzwyZeHwBA1EjFYoAk2jJ3OFeJ5Gp1E+3Dlf3Aj'
+ : '70bbvmag5oyKHunVyGPq6+EnvTua/JUn3iadMHlqUapsK2T8'
+ : 'SwCBJUF1JnEmhu0ntBthJoQpZqumsBk5mA1hRc0LR5ZFerdj'
+ : 'ksaCqt3IUWXcXW16vb6xdWyHLTgCaKXWKUKK1kOp9HK5B3EL'
+ : 'jSdXb0loB5RYtS01L6h9yTPW51Wpqwgosr5I927aw6401+Yf'
+ : 'wDria4WoQwAAA=='
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+
+B.4. Embedded Certificate Image Example
+
+ The following example displays a logotype certificate extension
+ containing one certificate image logotype using direct addressing.
+ The certificate image logotype uses image/svg+xml+gzip. The logotype
+ image is embedded in the certificate extension with a "data:" URI,
+ and the image is hashed by SHA-256. This example contains the image
+ from Appendix B of [RFC6170]; however, the media type used here is
+ explicit about the use of GZIP compression [RFC1952].
+
+ The values on the left are the ASN.1 tag (in hexadecimal) and the
+ length (in decimal).
+
+ 30 2902: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER logotype (1 3 6 1 5 5 7 1 12)
+ 04 2888: OCTET STRING, encapsulates {
+ 30 2884: SEQUENCE {
+ A3 2880: [3] {
+ 30 2876: SEQUENCE {
+ 30 2872: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER '1 3 6 1 5 5 7 20 3'
+ A0 2858: [0] {
+ 30 2854: SEQUENCE {
+ 30 2850: SEQUENCE {
+ 30 2846: SEQUENCE {
+ 16 18: IA5String 'image/svg+xml+gzip'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : 83 14 B3 26 9B D3 8B 0B 2A E6 6E 42 74 E2 A7 57
+ : 7A 40 B7 E1 2E 53 42 44 CC 7C AE 14 68 1B 0E B6
+ : }
+ : }
+ 30 2771: SEQUENCE {
+ 16 2767: IA5String
+ : ''
+ : 'nRJbWFnZURlbW8uc3ZnANVaW2/bOBZ+n19BqBigwdoS7xK9j'
+ : 'meapB0EWHQHzez2WZZoR1tZMiQ5jvvr95CSL7Gl1Em8C9d9i'
+ : 'ERSPOd85+O5EB3+9jhL0YMuyiTPLh3iYgfpLMrjJJteOv/66'
+ : '1M/cFBZhVkcpnmmL50sd34b/TIsH6YoiS+da11UySSJwkqj2'
+ : '1k41Q6CDbNyUMSTS+e+quYDz1sul+6SuXkx9YhSysPUo7QPK'
+ : '/rlKqvCx35Wvmu+a/uGYow9EOigh0Qvr/LHSwcjjDjGiGHQ9'
+ : '14n0/sKlMf4Vwctk7i6X7/sGEYdNA5L/WeRT5IUDKmSbLVWN'
+ : 'oo2cqNCh1XyoKN8Nsuz0iqwVW8Qb1fOF0Vqp+PI06me6awqP'
+ : 'eISzxn9goYzXYVxWIUWpfWLCMwcGoLpgy83n8wzGkbR4Gtef'
+ : 'ENmMBznC7DEroKpOBpM8mIWVqPEYGtA+BvoMfS2E5uF1Wqu7'
+ : 'R6FLvNFEelWReNolpiV3l2VpGntMW9nk6RKdf0+9BrFrMbeV'
+ : 'uWhtzbHvMR6UlobPyVpBWjXBk7six2vH5nCwY6nXCo5xb7Yu'
+ : 'svFVPqCOGh16fSxSxglmPkScLfvmDDmC4FlDc1wov8IF2WZh'
+ : 'NlVumgEPRliimDD3PhGPyTgUUMC6lKqKAjxaptq1boUJvQFs'
+ : 'vi+LOJyxZkPE/vCwHuAmXmoj1AarnRBatzqkbv7cK5Ls2ORf'
+ : 'wM/vsOG5lURZqXxOnDXPKZw5t5jVzIhFKO0B6D6hARSXDR6F'
+ : 'zqq7H7mQeJAOQiUSPvFIrUHOfuui3zrFI5dYVeAmpcOcOb9u'
+ : '63vLjae4kYX4yRifYPrTa2SlMigYdO+cEWeGADMLZLH96SH4'
+ : 'R9xRYApl6q3Y02f+NzlRAl+cZSKhB6qSIVa80fsqMnWOqZJp'
+ : 'msXwAPoyNaQ95uNIGasKPwhxGzQzOXzMIIzBKabmLIil470z'
+ : 'fSjWWn+kvpvLQ9g1l3yRIc8gukz0uysEcakcDfy3KMk+l0SO'
+ : 'XlOopltJL7EPtUlzZfP4tnM70k8xkKCySt92MwfIXPoTe0pn'
+ : 'u4dYbp7hJ/kxWySN0ey0o/1qbiCsxDXJMWWo37QekBcAUFPS'
+ : 'GkPCnUJF5wwBacDK5cGlEp4BC2lYoJcrNNGVc7DzIqxT4CKs'
+ : 'PlrAG8mL8whRejiQe9EmImIAoz3sds9NxP4RZEzugqzb7c3Q'
+ : '89u3WQKY9aegbsA/AUJB/bJs6pfJt9BHFEuk5DWITzOH5uZS'
+ : 'ThLUsDjQ5GE6RMsyihMTaQLfA6BIiAQMAhnHHN1sd61WtUhD'
+ : 'VJiuhkrdBXd740+hLB9Vm1HjQe4ywLOBLWOMMiyQAXNB8sm9'
+ : 'Gx2qdGgGkMG6wY8aLfqgH4dfnmrVc+pPrE/Z/QnZOs8C1Okb'
+ : '2/ggwLdxlDC1D6DFPZDD98txv8xQf5TEc7Ax6ZyaDf6BC4Sy'
+ : 'lWKCMqtizp80+UMchATal63qHq0M3ZTs83Ob/XO6LYsFzpGV'
+ : 'Y5+iLxdWvwY+NaKoR/0iJIXL3dBjT2hG+wO+NXm53XStSh1e'
+ : 'ogfeojV35BTOaqh/cmPUe2Mdp91pQp2CjWOO2k7OamhjU1HB'
+ : '3DLGm66n6iajz4bqn2oICmNFxDR/x2mC5s+rKhlkUA3Ne3P8'
+ : 'lgP0qJfjf9uvu+HWXSfFwNoH4uqGUmTadYMtOc7yjEEd9EUh'
+ : 'kwEEOcDSHKQ+yhnSvUYRH8miQo2FK5TCjWZZGWKB8iHPud16'
+ : 'wApnCvTOzjIFAj9TQdCxa+ddOTizaa1xJvD0qMrKx+Ydaj6i'
+ : 'wJQG0vaSdYWpTv4HwVRAP3Z6ONjOJunEIeKRVmhujpA2+wPm'
+ : 'QR9WFQAFhh9bGQzFEXX+WwOnXq8pV35P2Acdn0pGebcMg7Og'
+ : 'QKaEdOKEAkFlk/9HuEKGBVwucc4AjnJ/LBYU09hVwWY1F0Hl'
+ : 'BUC2lbyIuYF58O8p+adMwUt9YAoX/IwRtAC9NAdBAyGuEB3V'
+ : 'R59u8/TGYx9/Xjz8bPB/Z/F9B0SghBK+4xxfiwtr0GXECqed'
+ : 'QQ9PRVpEAQ+26MidbGSmPm8RwRzcQsT17EPSmoorH3+av4Jc'
+ : 'j78O/vIp/uzMEkHKAE6/F7VHHSj8HddR0Q3ymcGZfRVjwfmO'
+ : 'nNn3GuWR+FzhcPmPqiptHcayacT28T8j3Cs0/LQCwo6J2iYx'
+ : 'P4R58AsobjFegusoJhuq7VNS2evRPcqASvQki+gbkBYwETNP'
+ : 't/1A2pT6UErR1zMzUITZRvF5Lp5basO1fk2U4aBSjkji8quL'
+ : '3cDyW7TpI3unxezMcSTNhQJhfpGctKgKN2Amo7/7ShSev4oX'
+ : 'icPSYS+6GkCm9a1Qw3VEchCUA+z5HtTcbQhK6F14YFUp+Yn7'
+ : 'WgmzwpZCDf5DDiXT9B7U6RdHAHpdb7IqmLVjqZSLnTW61zjQ'
+ : '7/G7D3hm9E846uTDZoNMADmLlm7IG2ieXfUtu1US9TeNGUHi'
+ : 'bE9Nv//2jRJGZfQmK3v7ykJJOv1IXjBsDCPpmgWppe6sHxR3'
+ : 'KVSQKqp+WIqammuJbtqkxZmMHry4oS/9pLhdCXKq8uR0R+LD'
+ : 'EqCKRxqc5VXdvPvIP+ggwR0RkyBfO9iKZvrWGAKVdz31cuoc'
+ : 'voO/qemClFMYEFEH7oI+vpkek4s4bCMBqK+5mHQUlDpE/oyl'
+ : 'py+2/6pWXK31PEYagP04epV1cE50UMy6IQZeQM7+Ol74Z+eH'
+ : 'fpHNc7OjffQ/HeV0X8BopoDkGEkAAA='
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+
+B.5. Full Certificate Example
+
+ The following example contains a certificate for Alice; it is
+ essentially a renewal of the certificate that appears in [RFC9216].
+ Of course, the serial number and issue dates are different. In
+ addition, Alice's certificate now has a logotype certificate
+ extension. The extension contains URLs for two community logotype
+ images, both at fictional URLs. The extension also contains URLs for
+ two subject organization logotype images, both at fictional URLs. An
+ implementation would display at most three of these images, both of
+ the community logotype images and one of the subject organization
+ logotype images. Direct addressing is used for all of the images,
+ and the images are hashed by SHA-256.
+
+ -----BEGIN CERTIFICATE-----
+ MIIFpTCCBI2gAwIBAgITN0EFee11f0Kpolw69Phqzpqx1zANBgkqhkiG9w0BAQ0F
+ ADBVMQ0wCwYDVQQKEwRJRVRGMREwDwYDVQQLEwhMQU1QUyBXRzExMC8GA1UEAxMo
+ U2FtcGxlIExBTVBTIFJTQSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAgFw0yMjA2
+ MTUxODE4MThaGA8yMDUyMDkyNzA2NTQxOFowOzENMAsGA1UEChMESUVURjERMA8G
+ A1UECxMITEFNUFMgV0cxFzAVBgNVBAMTDkFsaWNlIExvdmVsYWNlMIIBIjANBgkq
+ hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAtPSJ6Fg4Fj5Nmn9PkrYo0jTkfCv4TfA/
+ pdO/KLpZbJOAEr0sI7AjaO7B1GuMUFJeSTulamNfCwDcDkY63PQWl+DILs7GxVwX
+ urhYdZlaV5hcUqVAckPvedDBc/3rz4D/esFfs+E7QMFtmd+K04s+A8TCNO12DRVB
+ DpbP4JFD9hsc8prDtpGmFk7rd0q8gqnhxBW2RZAeLqzJOMayCQtws1q7ktkNBR2w
+ ZX5ICjecF1YJFhX4jrnHwp/iELGqqaNXd3/Y0pG7QFecN7836IPPdfTMSiPR+peC
+ rhJZwLSewbWXLJe3VMvbvQjoBMpEYlaJBUIKkO1zQ1Pq90njlsJLOwIDAQABo4IC
+ hDCCAoAwDAYDVR0TAQH/BAIwADAXBgNVHSAEEDAOMAwGCmCGSAFlAwIBMAEwHgYD
+ VR0RBBcwFYETYWxpY2VAc21pbWUuZXhhbXBsZTATBgNVHSUEDDAKBggrBgEFBQcD
+ BDAOBgNVHQ8BAf8EBAMCBsAwHQYDVR0OBBYEFLv2zLItHQYSHJeuKWqQENMgZmZz
+ MB8GA1UdIwQYMBaAFJEwjnwHFwyn8QkoZTYaZxxodvRZMIIB0AYIKwYBBQUHAQwE
+ ggHCMIIBvqCB4zCB4KBvMG0wazBpFgppbWFnZS9qcGVnMDEwLzALBglghkgBZQME
+ AgEEIK/8EBZGy1YltJl95Yk+rjqEb1oC04LW2o7U7vh8vR3tMCgWJmh0dHA6Ly93
+ d3cuZXhhbXBsZS5uZXQvaW1hZ2VzL2xvZ28uanBnoG0wazBpMGcWCWltYWdlL2dp
+ ZjAxMC8wCwYJYIZIAWUDBAIBBCCIkIGBrftmri9m0EmgTY6g7E6oZEI4WzZKvyyL
+ 0unpZjAnFiVodHRwOi8vd3d3LmV4YW1wbGUub3JnL2xvZ28taW1hZ2UuZ2lmooHV
+ oIHSMIHPMGUwYxYJaW1hZ2UvZ2lmMDEwLzALBglghkgBZQMEAgEEIGpYUC5ZZ/nd
+ 0Yr+vQ2x/mClExvfD7K+8LVzRVC6G78ZMCMWIWh0dHA6Ly93d3cuc21pbWUuZXhh
+ bXBsZS9sb2dvLmdpZjBmMGQWCmltYWdlL2pwZWcwMTAvMAsGCWCGSAFlAwQCAQQg
+ vct7dXJtjBszpCzerHly2krZ8nmEClhYas4vAoDq16UwIxYhaHR0cDovL3d3dy5z
+ bWltZS5leGFtcGxlL2xvZ28uanBnMA0GCSqGSIb3DQEBDQUAA4IBAQBbjdCNVFA/
+ emCc5uKX5WSPrdvRFZSs57SEhE0odxvhTrOs13VM8Om0TxhNJ0Pl6d9CJdbUxtFw
+ SSnSu9fnghDO7OZDJnPiIYLNY5eTTzY6sx85mde9TLaBTE7RZf0W7NV0hqDqcfM+
+ 9HnQrU4TtPSvtPS5rr5SvqkaMM0k89bpbkgZlh9HH14+x+DIeT0dLythiXJvkVod
+ qEfyZTcdplQHQ4szWO7lsjmvHrUIbS1tdAJnah8AZRZfqiJEFeiUp06hvAWnPc3y
+ 1TMwYI8onfwPIVzyT6YLgjiT6PuLwSB/wtlhI+vWfdINaHdotegjawLm/3jZ+ceN
+ tu39FvbV0uKJ
+ -----END CERTIFICATE-----
+
+ The following displays the logotype certificate extension from
+ Alice's certificate. The values on the left are the ASN.1 tag (in
+ hexadecimal) and the length (in decimal).
+
+ 30 464: SEQUENCE {
+ 06 8: OBJECT IDENTIFIER logotype (1 3 6 1 5 5 7 1 12)
+ 04 450: OCTET STRING, encapsulates {
+ 30 446: SEQUENCE {
+ A0 227: [0] {
+ 30 224: SEQUENCE {
+ A0 111: [0] {
+ 30 109: SEQUENCE {
+ 30 107: SEQUENCE {
+ 30 105: SEQUENCE {
+ 16 10: IA5String 'image/jpeg'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : AF FC 10 16 46 CB 56 25 B4 99 7D E5 89 3E AE 3A
+ : 84 6F 5A 02 D3 82 D6 DA 8E D4 EE F8 7C BD 1D ED
+ : }
+ : }
+ 30 40: SEQUENCE {
+ 16 38: IA5String 'http://www.example.net/images/logo.jpg'
+ : }
+ : }
+ : }
+ : }
+ : }
+ A0 109: [0] {
+ 30 107: SEQUENCE {
+ 30 105: SEQUENCE {
+ 30 103: SEQUENCE {
+ 16 9: IA5String 'image/gif'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : 88 90 81 81 AD FB 66 AE 2F 66 D0 49 A0 4D 8E A0
+ : EC 4E A8 64 42 38 5B 36 4A BF 2C 8B D2 E9 E9 66
+ : }
+ : }
+ 30 39: SEQUENCE {
+ 16 37: IA5String 'http://www.example.org/logo-image.gif'
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ A2 213: [2] {
+ A0 210: [0] {
+ 30 207: SEQUENCE {
+ 30 101: SEQUENCE {
+ 30 99: SEQUENCE {
+ 16 9: IA5String 'image/gif'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : 6A 58 50 2E 59 67 F9 DD D1 8A FE BD 0D B1 FE 60
+ : A5 13 1B DF 0F B2 BE F0 B5 73 45 50 BA 1B BF 19
+ : }
+ : }
+ 30 35: SEQUENCE {
+ 16 33: IA5String 'http://www.smime.example/logo.gif'
+ : }
+ : }
+ : }
+ 30 102: SEQUENCE {
+ 30 100: SEQUENCE {
+ 16 10: IA5String 'image/jpeg'
+ 30 49: SEQUENCE {
+ 30 47: SEQUENCE {
+ 30 11: SEQUENCE {
+ 06 9: OBJECT IDENTIFIER
+ : sha-256 (2 16 840 1 101 3 4 2 1)
+ : }
+ 04 32: OCTET STRING
+ : BD CB 7B 75 72 6D 8C 1B 33 A4 2C DE AC 79 72 DA
+ : 4A D9 F2 79 84 0A 58 58 6A CE 2F 02 80 EA D7 A5
+ : }
+ : }
+ 30 35: SEQUENCE {
+ 16 33: IA5String 'http://www.smime.example/logo.jpg'
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+ : }
+
+Appendix C. Changes since RFCs 3709 and 6170
+
+ This appendix summarizes the changes since [RFC3709]. The changes
+ are:
+
+ * Combine RFCs 3709 and 6170 into one document, and encourage
+ implementers to support the "data" URI scheme (data:...) that was
+ originally specified in RFC 6170. Merging RFCs 3709 and 6170 led
+ to many editorial changes throughout the document.
+
+ * Drop SHA-1 as the mandatory-to-implement hash algorithm, and
+ encourage use of the one-way hash function that is employed by the
+ certificate signature algorithm.
+
+ * RFC 3709 required client applications to support both direct and
+ indirect addressing. This requirement is changed to SHOULD
+ support both direct and indirect addressing to allow
+ implementations to be more privacy preserving.
+
+ * Update the reference for language tags to be RFC 5646 instead of
+ the now obsolete RFC 3066.
+
+ * Update the reference for the URI Generic Syntax to be RFC 3986
+ instead of the now obsolete RFC 2396.
+
+ * Update the reference for the application/pdf media type to be RFC
+ 8118 instead of the now obsolete RFC 3778.
+
+ * No longer require support for the FTP scheme (ftp://...) URI.
+
+ * Require support for the HTTP scheme (http://...) URI and the HTTPS
+ scheme (https://...) URI.
+
+ * Provide syntax of the "data" URI scheme using modern ABNF.
+
+ * Require support for the compressed SVG image format with the
+ image/svg+xml+gzip media type.
+
+ * Media types MUST follow the ABNF [RFC5234] that is provided in
+ Section 8.3.1 of [RFC9110]. This change resolves Errata ID 2679.
+
+ * Remove the requirement that the LogotypeData file name have a file
+ extension of ".LTD". This change resolves Errata ID 2325.
+
+ * Encourage, instead of requiring, each logotype to be represented
+ by at least one image.
+
+ * Encourage the inclusion of text-based audio data suitable for
+ processing by a text-to-speech software using the media type of
+ "text/plain;charset=UTF-8".
+
+ * Encourage the use of dithering if an image needs to be scaled.
+
+ * Require that the logotype certificate extension not contain more
+ than one certificate image logotype.
+
+ * Privacy-related topics that were previously discussed in the
+ Security Considerations section are now covered in a separate
+ Privacy Considerations section. Additional topics are covered in
+ both sections.
+
+ * Provide ASN.1 modules for both the older syntax [OLD-ASN1] and the
+ most recent ASN.1 syntax [NEW-ASN1].
+
+ * Provide additional references.
+
+ * Provide additional examples.
+
+ * Several editorial changes to improve clarity.
+
+ * The example in Appendix B.1 was changed to use SHA-256 instead of
+ SHA-1.
+
+Acknowledgments
+
+ * Acknowledgments from RFC 3709
+
+ This document is the result of contributions from many
+ professionals. The authors appreciate contributions from all
+ members of the IETF PKIX Working Group. We extend a special
+ thanks to Al Arsenault, David Cross, Tim Polk, Russel Weiser,
+ Terry Hayes, Alex Deacon, Andrew Hoag, Randy Sabett, Denis Pinkas,
+ Magnus Nystrom, Ryan Hurst, and Phil Griffin for their efforts and
+ support.
+
+ Russ Housley thanks the management at RSA Laboratories, especially
+ Burt Kaliski, who supported the development of this specification.
+ The vast majority of the work on this specification was done while
+ Russ was employed at RSA Laboratories.
+
+ * Acknowledgments from RFC 6170
+
+ The authors recognize valuable contributions from members of the
+ PKIX working group, the CA Browser Forum, and James Manger, for
+ their review and sample data.
+
+ * Additional Acknowledgments
+
+ Combining RFCs 3709 and 6170 has produced an improved
+ specification. The authors appreciate contributions from all
+ members of the IETF LAMPS Working Group. We extend a special
+ thanks to Alexey Melnikov for his guidance on media types. We
+ extend a special thanks to Tim Geiser for his careful checking of
+ the new examples in Appendices B.4 and B.5. We extend a special
+ thanks to Corey Bonnell, Daniel Kahn Gillmor, Roman Danyliw, Paul
+ Wouters, Paul Kyzivat, Shuping Peng, Sheng Jiang, Rob Wilton, Éric
+ Vyncke, Donald Eastlake 3rd, and Dan Harkins for their careful
+ review and helpful comments.
+
+Authors' Addresses
+
+ Stefan Santesson
+ IDsec Solutions AB
+ Forskningsbyn Ideon
+ SE-223 70 Lund
+ Sweden
+ Email: sts@aaa-sec.com
+
+
+ Russ Housley
+ Vigil Security, LLC
+ 516 Dranesville Road
+ Herndon, VA 20170
+ United States of America
+ Email: housley@vigilsec.com
+
+
+ Trevor Freeman
+ Amazon Web Services
+ 1918 8th Ave
+ Seattle, WA 98101
+ United States of America
+ Email: frtrevor@amazon.com
+
+
+ Leonard Rosenthol
+ Adobe
+ 345 Park Avenue
+ San Jose, CA 95110
+ United States of America
+ Email: lrosenth@adobe.com