From d5c377c7f00410a4eb45b0d647869edb5b05cc09 Mon Sep 17 00:00:00 2001 From: Tony Arcieri Date: Fri, 1 Nov 2024 14:44:08 -0600 Subject: [PATCH] const-oid: improve rustdoc on `Arc` Note that we follow Mozilla conventions using maximum 32-bit arcs, linking to a survey of various OID libraries and how they handle various sized arcs. Also notes we deliberatly do not support UUIDs-as-OIDs, since they're not important (at least within the scope of what we currently implement) to cryptographic use cases this library is intended for. --- const-oid/src/arcs.rs | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/const-oid/src/arcs.rs b/const-oid/src/arcs.rs index 20ebcb862..f245845fa 100644 --- a/const-oid/src/arcs.rs +++ b/const-oid/src/arcs.rs @@ -5,16 +5,17 @@ use crate::{Error, Result}; #[cfg(doc)] use crate::ObjectIdentifier; -/// Type alias used to represent an "arc" (i.e. integer identifier value). +/// Type alias used to represent an "arc", i.e. integer identifier value, where an OID comprises a +/// sequence of arcs. /// -/// X.660 does not define a maximum size of an arc. +/// X.660 does not define a maximum size of an arc. We instead follow Mozilla* conventions for +/// maximum values of an arc, with a maximum value of 2^32-1 (4294967295), a.k.a. [`u32::MAX`] +/// with [`Arc`] being a type alias for [`u32`]. /// -/// The current representation is `u32`, which has been selected as being -/// sufficient to cover the current PKCS/PKIX use cases this library has been -/// used in conjunction with. +/// Note that this means we deliberately do *NOT* support UUIDs used as OIDs. /// -/// Future versions may potentially make it larger if a sufficiently important -/// use case is discovered. +/// *NOTE: please see this study for a survey of how various OID libraries handle maximum arcs: +/// pub type Arc = u32; /// Maximum value of the first arc in an OID. @@ -24,6 +25,9 @@ pub(crate) const ARC_MAX_FIRST: Arc = 2; pub(crate) const ARC_MAX_SECOND: Arc = 39; /// Maximum number of bytes supported in an arc. +/// +/// Note that OIDs are LEB128 encoded (i.e. base 128), so we must consider how many bytes are +/// required when each byte can only represent 7-bits of the input. const ARC_MAX_BYTES: usize = (Arc::BITS as usize).div_ceil(7); /// Maximum value of the last byte in an arc.