| Internet-Draft | Use of HPKE in JOSE | October 2025 | 
| Reddy, et al. | Expires 22 April 2026 | [Page] | 
This specification defines Hybrid Public Key Encryption (HPKE) for use with JSON Object Signing and Encryption (JOSE). HPKE offers a variant of public key encryption of arbitrary-sized plaintexts for a recipient public key, and provides security against adaptive chosen ciphertext attacks (IND-CCA2-secure).¶
HPKE also includes a variant that authenticates possession of a pre-shared key. HPKE works for any combination of an asymmetric KEM, key derivation function (KDF), and authenticated encryption with additional data (AEAD) encryption function.¶
This document defines the use of HPKE with JOSE. The specification chooses a specific subset of the HPKE features to use with JOSE.¶
This note is to be removed before publishing as an RFC.¶
The latest revision of this draft can be found at https://ietf-wg-jose.github.io/draft-ietf-jose-hpke-encrypt/draft-ietf-jose-hpke-encrypt.html. Status information for this document may be found at https://datatracker.ietf.org/doc/draft-ietf-jose-hpke-encrypt/.¶
Discussion of this document takes place on the jose Working Group mailing list (mailto:jose@ietf.org), which is archived at https://mailarchive.ietf.org/arch/browse/jose/. Subscribe at https://www.ietf.org/mailman/listinfo/jose/.¶
Source for this draft and an issue tracker can be found at https://github.com/ietf-wg-jose/draft-ietf-jose-hpke-encrypt.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 22 April 2026.¶
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://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.¶
Hybrid Public Key Encryption (HPKE) [I-D.ietf-hpke-hpke] is a public key encryption (PKE) scheme that provides encryption of arbitrary-sized plaintexts given a recipient's public key.¶
This specification enables JSON Web Encryption (JWE) to leverage HPKE, bringing support for KEMs and the possibility of Hybrid KEMs to JWE.¶
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.¶
This specification uses the following abbreviations and terms:¶
Hybrid Public Key Encryption (HPKE) is defined in [I-D.ietf-hpke-hpke].¶
pkR is the public key of the recipient, as defined in [I-D.ietf-hpke-hpke].¶
skR is the private key of the recipient, as defined in [I-D.ietf-hpke-hpke].¶
Key Encapsulation Mechanism (KEM), see [I-D.ietf-hpke-hpke].¶
Key Derivation Function (KDF), see [I-D.ietf-hpke-hpke].¶
Authenticated Encryption with Associated Data (AEAD), see [I-D.ietf-hpke-hpke] and [RFC7516].¶
Additional Authenticated Data (AAD), see [I-D.ietf-hpke-hpke] and [RFC7516].¶
This specification defines two modes of use for HPKE in JWE:¶
HPKE JWE Integrated Encryption, where HPKE is used to encrypt the plaintext.¶
HPKE JWE Key Encryption, where HPKE is used to encrypt a content encryption key (CEK) and the CEK is subsequently used to encrypt the plaintext.¶
When "alg" is a JOSE-HPKE algorithm:¶
If "enc" is "int", HPKE JWE Integrated Encryption is used.¶
If "enc" is an AEAD algorithm, the recipient Key Management mode is Key Encryption.¶
The HPKE KEM, KDF, and AEAD used depend on the JOSE-HPKE algorithm used. This HPKE AEAD is used internally by HPKE and is distinct from the AEAD algorithm specified in "enc".¶
HPKE supports two modes, which are described in Table 1 of [I-D.ietf-hpke-hpke].¶
In JOSE-HPKE, both "mode_base" and "mode_psk" are supported. When "psk_id" JOSE Header parameter is present the mode is "mode_psk", otherwise the mode is "mode_base".¶
JWE supports different serializations, including Compact JWE Serialization as described in Section 3.1 of [RFC7516], General JWE JSON Serialization as described in Section 3.2 of [RFC7516].¶
Certain JWE features are only supported in specific serializations.¶
For example Compact JWE Serialization does not support the following:¶
HPKE JWE Key Encryption can be used with "aad" but only when not expressed with Compact JWE Serialization.¶
Single recipient HPKE JWE Key Encryption with no "aad" can be expressed in Compact JWE Serialization, so long as the recipient and sender use the same HPKE Setup process as described in Section 5 of [I-D.ietf-hpke-hpke].¶
This specification updates the "enc" definition in Section 4.1.2 of [RFC7516] by allowing the "enc" value "int" when the "alg" value is a JOSE-HPKE algorithm. When "alg" is not a JOSE-HPKE algorithm and the "enc" value is "int", the input MUST NOT be used and MUST be rejected.¶
The HPKE "aad parameter" for Open() and Seal() specified in Section 8.1 of [I-D.ietf-hpke-hpke] is used with both HPKE JWE Integrated Encryption and HPKE JWE Key Encryption. Its value is the Additional Authenticated Data encryption parameter value computed in Step 14 of Section 5.1 of [RFC7518] (Message Encryption).¶
Despite similarities to ECDH-ES,
this specification does not use the apu and apv header parameters,
which are described in Section 4.6.1 of [RFC7518].¶
HPKE encapsulated key is defined in Section 5 of [I-D.ietf-hpke-hpke].¶
In HPKE JWE Integrated Encryption, the JWE Encrypted Key of the sole recipient is the HPKE encapsulated key.¶
In HPKE JWE Key Encryption, each recipient JWE Encrypted Key is the encrypted content encryption key, and the value of JOSE Header parameter "ek" is base64url-encoded HPKE encapsulated key.¶
In HPKE JWE Integrated Encryption:¶
The protected header MUST contain an "alg" that is JOSE-HPKE algorithm.¶
The protected header MUST contain an "enc" with value "int". This is an explicit exception to requirement in Section 4.1.2 of [RFC7516] that "enc" must be an AEAD algorithm. This is appropriate, as HPKE will perform plaintext encryption.¶
The protected header parameters "psk_id" MAY be present.¶
The protected header parameter "ek" MUST NOT be present.¶
There MUST be exactly one recipient.¶
The JWE Encrypted Key MUST be encapsulated key, as defined in Section 5 of [I-D.ietf-hpke-hpke].¶
The JWE Initialization Vector and JWE Authentication Tag MUST be the empty octet sequence.¶
The JWE AAD MAY be present when using the JWE JSON Serialization.¶
The JWE Ciphertext is the ciphertext defined in Section 5.2 of [I-D.ietf-hpke-hpke].¶
The HPKE info parameter defaults to the empty string; mutually known private information MAY be used instead. The concept of mutually known private information is defined in [NIST.SP.800-56Ar3] as an input to the key derivation function.¶
The HPKE aad parameter MUST be set to the "Additional Authenticated Data encryption parameter", as specified in Step 14 of Section 5.1 of [RFC7516].¶
Then follow Steps 11-19 of Section 5.1 of [RFC7516] (Message Encryption).¶
When decrypting, the checks in Section 5.2 of [RFC7516], Steps 1 through 5 MUST be performed. The JWE Encrypted Key in Step 2 is the base64url-encoded encapsulated key.¶
Below is an example of a Compact JWE using HPKE integrated encryption:¶
=============== NOTE: '\' line wrapping per RFC 8792 ================
eyJhbGciOiAiSFBLRS0wIiwgImVuYyI6ICJpbnQiLCAia2lkIjogIkc1Tl9fQ3FNdl9r\
SkdpZUdTRnVBdWd2bDBqclFKQ1ozeUt3Vks2c1VNNG8ifQ.BIh6I40uiBbK8-\
UK7nHdo3ISEfgwJ_MF3zWjQzLt00GhFF2-\
1VgWKHSYLXdeVeRV7AinyocYiCYmISvW0yqiDmc..Ov-\
                                    llz6VUyiw8nZL0OPGLGZckLTm5UcTZFg.
¶
The keys used for this example are in Appendix A.¶
When using the JWE JSON Serialization,
recipients using JOSE-HPKE can be added alongside other recipients
(e.g., those using ECDH-ES+A128KW or RSA-OAEP-256),
since HPKE is used to encrypt the Content Encryption Key,
which is then processed as specified in JWE.¶
The encoding of the protected header remains consistent with existing JWE rules.¶
In HPKE JWE Key Encryption:¶
The Key Management Mode is Key Encryption.¶
When all recipients use the same HPKE algorithm to secure the Content Encryption Key, the JWE Protected Header SHOULD contain "alg". Otherwise, the JWE Protected Header (and JWE Shared Unprotected Header) MUST NOT contain "alg".¶
JOSE Header parameter "alg" MUST be a JOSE-HPKE algorithm.¶
JOSE Header parameter "psk_id" MAY be present.¶
JOSE Header parameter "ek" MUST be present and contain the base64url-encoded HPKE encapsulated key.¶
Recipient JWE Encrypted Key MUST be the ciphertext from HPKE Encryption.¶
The HPKE info parameter contains the encoding of the Recipient_structure, which is described in Section 6.1.¶
The HPKE AAD parameter defaults to the empty string; externally provided information MAY be used instead.¶
THE HPKE plaintext MUST be set to the CEK.¶
The processing of "enc", "iv", "tag", "aad", and "ciphertext" is as already defined in [RFC7516]. Implementations process these parameters as defined in [RFC7516]; no additional processing requirements are introduced by HPKE-based key encryption.¶
The Recipient_structure is a JSON object with the following members:¶
context (string): This member MUST include the constant string value "JOSE HPKE Recipient".¶
next_layer_alg (string): Identifies the algorithm with which the HPKE-encrypted key MUST be used. Its value MUST match the "enc" (encryption algorithm) header parameter in the JWE protected header. This field is included for alignment with the COSE HPKE [I-D.ietf-cose-hpke] specification. Currently, there are no known attacks that allow a downgrade attack of the content encryption algorithm.¶
recipient_protected_header (object): This member contains the base64url-encoded JWE Per-Recipient Unprotected Header (see JWE JSON Serialization in Section 7.1 of [RFC7156] of the recipients member. To serialize this header member the procedure from Section 3.3 of RFC 7638 MUST be used. Unlike with RFC 7638, all members from this member are included except for the "ek" member. The inclusion of this data in the Recipient_structure allows context information to be included in the key derivation.¶
recipient_extra_info (string): Contains additional context information that the application includes in the key derivation via the HPKE info parameter. Mutually known private information, which is defined in [NIST.SP.800-56Ar3], MAY be used in this input parameter. If no additional context is provided, this value MUST be the empty string "".¶
info
          JSON texts that are semantically identical can serialize differently (e.g., member order, whitespace), which would lead to divergent info values and failed key agreement.¶
To produce the HPKE info byte string from a Recipient_structure, both sides MUST produce the deterministic JSON representation using the JSON Web Key (JWK) Thumbprint serialization rules [RFC7638]:¶
Construct the Recipient_structure JSON object exactly as defined Section 6.1.¶
Prepare the JSON structure based on Section 3.3 of RFC 7638.¶
Use the resulting JSON structure, base64url-encode it and use the octets as the HPKE info value.¶
The example below shows a pretty-printed JSON object with an empty recipient_extra_info member.¶
{
  "context": "JOSE HPKE Recipient",
  "next_layer_alg": "A128GCM",
  "recipient_protected_header": {
    "alg": "HPKE-0",
    "kid": "G5N__CqMv_kJGieGSFuAugvl0jrQJCZ3yKwVK6sUM4o"
  },
  "recipient_extra_info": ""
}
¶
The serialized JSON leads to:¶
=============== NOTE: '\' line wrapping per RFC 8792 ================
RFC7638-serialized recipient_protected_header (JSON string):
{"alg":"HPKE-0","kid":"G5N__CqMv_kJGieGSFuAugvl0jrQJCZ3yKwVK6sUM4o"}
RFC7638-serialized Recipient_structure (JSON string):
{"context":"JOSE HPKE Recipient","next_layer_alg":"A128GCM","\
recipient_extra_info":"","recipient_protected_header":"\
eyJhbGciOiJIUEtFLTAiLCJraWQiOiJHNU5fX0NxTXZfa0pHaWVHU0Z1QXVndmwwanJR\
                                            SkNaM3lLd1ZLNnNVTTRvIn0"}
HPKE info (base64url):
eyJjb250ZXh0IjoiSk9TRSBIUEtFIFJlY2lwaWVudCIsIm5leHRfbGF5ZXJfYWxnIjoi\
QTEyOEdDTSIsInJlY2lwaWVudF9leHRyYV9pbmZvIjoiIiwicmVjaXBpZW50X3Byb3Rl\
Y3RlZF9oZWFkZXIiOiJleUpoYkdjaU9pSklVRXRGTFRBaUxDSnJhV1FpT2lKSE5VNWZY\
ME54VFhaZmEwcEhhV1ZIVTBaMVFYVm5kbXd3YW5KUlNrTmFNM2xMZDFaTE5uTlZUVFJ2\
                                                              SW4wIn0
¶
The base64url-encoded JSON structure above is used as the HPKE info bytes.¶
Below is an example of a JWE using the JSON Serialization and HPKE key encryption:¶
=============== NOTE: '\' line wrapping per RFC 8792 ================
{
  "protected": "eyJlbmMiOiAiQTEyOEdDTSJ9",
  "ciphertext": "9AxOd65ROJY1cQ",
  "iv": "2u3NRi3CSr-x7Wuj",
  "tag": "1NKYSWVV4pw5thsq7t6m6Q",
  "recipients": [
    {
      "encrypted_key": "l9VRW1K5CA037fY2ZqVF4bDej413TaAtfjoe3k89-eI",
      "header": {
        "alg": "HPKE-0",
        "kid": "G5N__CqMv_kJGieGSFuAugvl0jrQJCZ3yKwVK6sUM4o",
        "ek": "BJl0V6KLl3HOAZbzFwiAL9eaYbFQPg7-\
             ROmIJpluIQjNS5zultZsC4rGhGzmW1GUWG8bzJUWLQtxFF9oze0AKhU"
      }
    }
  ]
}
¶
The keys used for this example are in Appendix A.¶
JWKs can be used to represent JOSE-HPKE private or public keys. For the algorithms defined in this document, the valid combinations of the JWE Algorithm, "kty", and "crv" are shown in Figure 1.¶
+---------------------+-----------------+ | JWE Algorithm | JWK | | | | kty | crv | +---------------------+-----+-----------+ | HPKE-0 | EC | P-256 | | HPKE-1 | EC | P-384 | | HPKE-2 | EC | P-521 | | HPKE-3, HPKE-4 | OKP | X25519 | | HPKE-5, HPKE-6 | OKP | X448 | +---------------------+-----+-----------+
The example below is a JWK representation of a JOSE-HPKE public and private key:¶
{
  "kty": "OKP",
  "crv": "X25519",
  "x": "3pPHgcHYVYpOpB6ISwHdoPRB6jNgd8mM4nRyyj4H3aE",
  "d": "nWGxne0tAiV8Hk6kcy4rN0wMskjl9yND0N3Xeho9n6g",
  "kid": "recipient-key-1",
  "alg": "HPKE-3",
  "key_ops": "encrypt"
}
¶
It uses the "key_ops" value of "encrypt", which is appropriate when using integrated encryption.¶
This specification is based on HPKE and the security considerations of [I-D.ietf-hpke-hpke] are therefore applicable also to this specification.¶
HPKE assumes the sender is in possession of the public key of the recipient and HPKE JOSE makes the same assumptions. Hence, some form of public key distribution mechanism is assumed to exist but outside the scope of this document.¶
HPKE in Base mode does not offer authentication as part of the HPKE KEM.¶
HPKE relies on a source of randomness being available on the device. In Key Agreement with Key Wrapping mode, the CEK has to be randomly generated. The guidance on randomness in [RFC4086] applies.¶
A single KEM key MUST NOT be used with multiple KEM algorithms. Each key and its associated algorithm suite, comprising the KEM, KDF, and AEAD, should be managed independently. This separation prevents unintended interactions or vulnerabilities between algorithms, ensuring the integrity and security guarantees of each algorithm are preserved. Additionally, the same key should not be used for both key encryption and integrated encryption, as it may introduce security risks. It creates algorithm confusion, increases the potential for key leakage, cross-suite attacks, and improper handling of the key.¶
The guidance in [RFC8725] about encryption is also pertinent to this specification.¶
This specification registers a number of ciphersuites for use with HPKE. A ciphersuite is a group of algorithms, often sharing component algorithms such as hash functions, targeting a security level. A JOSE-HPKE algorithm makes choices for the following HPKE parameters:¶
The "KEM", "KDF", and "AEAD" values are chosen from the IANA HPKE registry [IANA.HPKE].¶
All JOSE-HPKE algorithm identifiers registered by this specification begin with the string "HPKE-". Future JOSE-HPKE ciphersuite names registered MUST also follow this convention.¶
The following entries are added to the IANA "JSON Web Signature and Encryption Algorithms" registry [IANA.JOSE]:¶
Algorithm Name: HPKE-0¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(P-256, HKDF-SHA256) KEM, the HKDF-SHA256 KDF and the AES-128-GCM AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-1¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(P-384, HKDF-SHA384) KEM, the HKDF-SHA384 KDF, and the AES-256-GCM AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-2¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(P-521, HKDF-SHA512) KEM, the HKDF-SHA512 KDF, and the AES-256-GCM AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-3¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(X25519, HKDF-SHA256) KEM, the HKDF-SHA256 KDF, and the AES-128-GCM AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-4¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(X25519, HKDF-SHA256) KEM, the HKDF-SHA256 KDF, and the ChaCha20Poly1305 AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-5¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(X448, HKDF-SHA512) KEM, the HKDF-SHA512 KDF, and the AES-256-GCM AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
Algorithm Name: HPKE-6¶
Algorithm Description: Cipher suite for JOSE-HPKE using the DHKEM(X448, HKDF-SHA512) KEM, the HKDF-SHA512 KDF, and the ChaCha20Poly1305 AEAD¶
Algorithm Usage Location(s): "alg"¶
JOSE Implementation Requirements: Optional¶
Change Controller: IETF¶
Algorithm Analysis Documents(s): [I-D.ietf-hpke-hpke]¶
The following entries are added to the IANA "JSON Web Key Parameters" registry [IANA.JOSE]:¶
Header Parameter Name: "ek"¶
Header Parameter Description: A base64url-encoded encapsulated key, as defined in Section 5 of [I-D.ietf-hpke-hpke]¶
Header Parameter Usage Location(s): JWE¶
Change Controller: IETF¶
Specification Document(s): Section 4.2 of this specification¶
Header Parameter Name: "psk_id"¶
Header Parameter Description: A base64url-encoded key identifier (kid) for the pre-shared key, as defined in Section 5.1.2 of [I-D.ietf-hpke-hpke]¶
Header Parameter Usage Location(s): JWE¶
Change Controller: IETF¶
This private key and its implied public key are used the examples:¶
{
  "kty": "EC",
  "use": "enc",
  "alg": "HPKE-0",
  "kid": "G5N__CqMv_kJGieGSFuAugvl0jrQJCZ3yKwVK6sUM4o",
  "crv": "P-256",
  "x": "gixQJ0qg4Ag-6HSMaIEDL_zbDhoXavMyKlmdn__AQVE",
  "y": "ZxTgRLWaKONCL_GbZKLNPsW9EW6nBsN4AwQGEFAFFbM",
  "d": "g2DXtKapi2oN2zL_RCWX8D4bWURHCKN2-ZNGC05ZaR8"
}
¶
This specification leverages text from [I-D.ietf-cose-hpke]. We would like to thank Matt Chanda, Ilari Liusvaara, Neil Madden, Aaron Parecki, Filip Skokan, and Sebastian Stenzel for their contributions to the specification.¶
-13¶
Removed orphan text about AKP kty field¶
Fixed bug in "include-fold" syntax¶
Switched reference from RFC 9180 to draft-ietf-hpke-hpke¶
Editorial improvements to abstract and introduction.¶
Removed Section 8.2 "Static Asymmetric Authentication in HPKE"¶
-12¶
Added the recipient_structure¶
-11¶
Fix too long lines¶
-10¶
Addressed WGLC review comments by Neil Madden and Sebastian Stenzel.¶
-09¶
Corrected examples.¶
-08¶
Use "enc":"int" for integrated encryption.¶
Described reasons for excluding authenticated HPKE.¶
Stated that mutually known private information MAY be used as the HPKE info value.¶
-07¶
Clarifications¶
-06¶
Remove auth mode and auth_kid from the specification.¶
HPKE AAD for JOSE HPKE Key Encryption is now empty.¶
-05¶
Removed incorrect text about HPKE algorithm names.¶
Fixed #21: Comply with NIST SP 800-227 Recommendations for Key-Encapsulation Mechanisms.¶
Fixed #19: Binding the Application Context.¶
Fixed #18: Use of apu and apv in Recipient context.¶
Added new Section 7.1 (Authentication using an Asymmetric Key).¶
Updated Section 7.2 (Key Management) to prevent cross-protocol attacks.¶
Updated HPKE Setup info parameter to be empty.¶
Added details on HPKE AEAD AAD, compression and decryption for HPKE Integrated Encryption.¶
-04¶
Fixed #8: Use short algorithm identifiers, per the JOSE naming conventions.¶
-03¶
Added new section 7.1 to discuss Key Management.¶
HPKE Setup info parameter is updated to carry JOSE context-specific data for both modes.¶
-02¶
Fixed #4: HPKE Integrated Encryption "enc: dir".¶
Updated text on the use of HPKE Setup info parameter.¶
Added Examples in Sections 5.1, 5.2 and 6.1.¶
Use of registered HPKE "alg" value in the recipient unprotected header for Key Encryption.¶
-01¶
Apply feedback from call for adoption.¶
Provide examples of auth and psk modes for JSON and Compact Serializations¶
Simplify description of HPKE modes¶
Adjust IANA registration requests¶
Remove HPKE Mode from named algorithms¶
Fix AEAD named algorithms¶
-00¶
Created initial working group version from draft-rha-jose-hpke-encrypt-07¶