Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Move examples #48

Merged
merged 8 commits into from
Oct 18, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
104 changes: 50 additions & 54 deletions draft-ietf-lamps-kyber-certificates.md
Original file line number Diff line number Diff line change
Expand Up @@ -91,21 +91,10 @@ specifies algorithm identifiers and ASN.1 encoding format for ML-KEM in
public key certificates. The encoding for public and private keys are
also provided.

\[EDNOTE:
This document is not expected to be finalized before the NIST PQC
Project has standardized PQ algorithms. This specification will use
object identifiers for the new algorithms that are assigned by NIST,
and will use placeholders until these are released.]

--- middle

# Introduction

<aside markdown="block">
WARNING: This I-D includes examples. These examples were generated
prior to NIST finalizing [DRAFTFIPS203].
</aside>

The Module-Lattice-Based Key-Encapsulation Mechanism (ML-KEM) standardized
in {{!FIPS203=DOI.10.6028/NIST.FIPS.203}} is a quantum-resistant key-encapsulation mechanism (KEM)
standardized by the US National Institute of Standards and Technology (NIST)
Expand Down Expand Up @@ -244,20 +233,8 @@ The fields in SubjectPublicKeyInfo have the following meaning:
algorithms defined in this document always encode the public key
as TODO pick format e.g., exact multiple of 8 bits?.

The following is an example of a ML-KEM-512 public key encoded using the
textual encoding defined in {{?RFC7468}}:

<aside markdown="block">
WARNING: This example was generated prior to NIST
finalizing [DRAFTFIPS203].
</aside>

~~~
-----BEGIN PUBLIC KEY-----
TODO insert example public key
-----END PUBLIC KEY-------
~~~

{{example-public}} contains an example of an id-alg-ml-kem-768 public key
encoded using the textual encoding defined in {{?RFC7468}}.

# Private Key Format

Expand Down Expand Up @@ -310,35 +287,6 @@ PqckemPrivateKey object and wrapped by the OCTET STRING of the
PqckemPrivateKey ::= OCTET STRING
~~~

The following is an example of a ML-KEM-512 private key encoded using the
textual encoding defined in {{RFC7468}}:

<aside markdown="block">
WARNING: This example was generated prior to NIST
finalizing [DRAFTFIPS203].
</aside>

~~~
-----BEGIN PRIVATE KEY-----
TODO iser example private key
-----END PRIVATE KEY-------
~~~

The following example, in addition to encoding the ML-KEM-512 private key,
has an attribute included as well as the public key. As with the
prior example, the textual encoding defined in {{RFC7468}} is used:

<aside markdown="block">
WARNING: This example was generated prior to NIST
finalizing [DRAFTFIPS203].
</aside>

~~~
-----BEGIN PRIVATE KEY-----
TODO insert example private key with attribute
-----END PRIVATE KEY-------
~~~

<aside markdown="block">
NOTE: There exist some private key import functions that have not
implemented the new ASN.1 structure OneAsymmetricKey that is defined in
Expand All @@ -348,6 +296,9 @@ prior example, the textual encoding defined in {{RFC7468}} is used:
key pair and widest ability to import the key.
</aside>

{{example-private}} contains an example of an id-alg-ml-kem-768 private key
encoded using the textual encoding defined in {{?RFC7468}}.

# ASN.1 Module

TODO ASN.1 Module
Expand All @@ -368,6 +319,51 @@ This document will have some IANA actions.

--- back

# Examples {#examples}

This appendix contains examples of ML-KEM public keys, private keys and certificates.

## Example Public Key {#example-public}

The following is an example of a ML-KEM-768 public key:

~~~
-----BEGIN PUBLIC KEY-----
TODO insert example public key
-----END PUBLIC KEY-------
~~~

## Example Private Key {#example-private}

The following is an example of a ML-KEM-768 private key:

~~~
-----BEGIN PRIVATE KEY-----
TODO insert example private key
-----END PRIVATE KEY-------
~~~

The following example, in addition to encoding the ML-KEM-768 private key,
has an attribute included as well as the public key:

~~~
-----BEGIN PRIVATE KEY-----
TODO insert example private key with attribute
-----END PRIVATE KEY-------
~~~

## Example Certificate {#example-certificate}

~~~
TODO insert ASN.1 Pretty Print
~~~

~~~
-----BEGIN CERTIFICATE-----
TODO Certificate
-----END CERTIFICATE-------
~~~

# Acknowledgments
{:numbered="false"}

Expand Down