Skip to content

Commit

Permalink
Move examples (#48)
Browse files Browse the repository at this point in the history
* Move examples

Moved the examples to an Appendix.

* fix {} count

Co-authored-by: Daniel Van Geest <[email protected]>

* fix spelling

Co-authored-by: Daniel Van Geest <[email protected]>

* fix {} count

Co-authored-by: Daniel Van Geest <[email protected]>

* example is 768

* example is 768

* example is 768

---------

Co-authored-by: Daniel Van Geest <[email protected]>
  • Loading branch information
seanturner and danvangeest authored Oct 18, 2024
1 parent 9b3b175 commit 05a1475
Showing 1 changed file with 50 additions and 54 deletions.
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

0 comments on commit 05a1475

Please sign in to comment.