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

Prototype OID-based versioning #3

Open
kriskwiatkowski opened this issue Nov 5, 2022 · 6 comments
Open

Prototype OID-based versioning #3

kriskwiatkowski opened this issue Nov 5, 2022 · 6 comments
Labels
future-work This might be worked on sometime

Comments

@kriskwiatkowski
Copy link
Collaborator

kriskwiatkowski commented Nov 5, 2022

OID

We suggest having the following format of an OID x.y.z.A.V.P, where:

  • x.y.z: OID prefix - to be decided
  • A: identifier of an algorithm
  • V: version of an algorithm specification. Value is scheme specific, 0 is used in case specification has no version.
  • P: parameter set (a.k.a. NIST security level)

Example: Let say we have following OID 1.3.6.1.4.1.2.9.31.3, then:

  • 1.3.6.1.4.1.2 is a common prefix for all PQ schemes (x.y.z). Actual value to be decided.
  • 9 identifier of PQ scheme (let say Dilithium)
  • 31 version of a specification (here Dilithium 3.1)
  • 3 parameter set (here, Dilithium 3)
@pkelsey
Copy link
Collaborator

pkelsey commented Nov 5, 2022

The interpretation of the value of the version arc should be scheme-specific, so as not to assume that every version of every PQ scheme will be identifiable by a major.minor version number where minor <= 9.

@kriskwiatkowski
Copy link
Collaborator Author

@pkelsey Agreed. That is the assumption - the value V is specific to a scheme. I've added explenation above.

@kriskwiatkowski
Copy link
Collaborator Author

Question: Schemes they have their own versioning, but IETF drafts also have versioning. ASN.1 structures may differ between draft versions. For better interoperability, I wonder if OID should also contain a version of a draft? Thoughts?

@baentsch
Copy link
Collaborator

baentsch commented Nov 6, 2022

if OID should also contain a version of a draft?

If different draft versions change anything that's externally represented/persistent (certs, keys, etc), then I'd say so.

For interop testing, though, I'd find a mapping "generally accepted algorithm name (and version)" <-> OID <-> "implementation algorithm name" (the latter mapping in combination with the ability to set OIDs dynamically) most helpful.

@johngray-dev
Copy link
Collaborator

I agree with these comments. So I think we should propose a set of OIDs that follow this convention. We can discuss this at our next monthly meeting on December 5th.

@baentsch baentsch added future-work This might be worked on sometime and removed future-work This might be worked on sometime labels Jan 9, 2023
@johngray-dev johngray-dev changed the title OID-based versioning Prototype OID-based versioning Jan 6, 2025
@johngray-dev
Copy link
Collaborator

We now have a mix of standard OIDs (For ML-KEM, ML-DSA, SLH-DSA) and prototype OIDs for the up coming algorithms.

We have essentially been using the rule:

"The first implementation to submit an algorithm that requires a prototype OID gets to decide the prototype OID".

That has helped to make it easier to manage through multiple changes as we don't have to force the implementer to change their OIDs, and in fact we wouldn't have a way to force them to change them anyway because we don't have control over their implementation. For example, LibOQS or bouncy castle API's had defined some prototype OIDs for their own implementations out of need, and it just ended up being easier for this group to agree to adopt those OIDs for interop testing.

So I think we can suggest that when prototype OIDs are selected by an implementation, these rules get adopted but we can easily accomodate when they don't.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
future-work This might be worked on sometime
Projects
None yet
Development

No branches or pull requests

4 participants