#oid #iso #iso-iec #itu #iec #embedded

no-std const-oid

Const-friendly implementation of the ISO/IEC Object Identifier (OID) standard as defined in ITU X.660, with support for BER/DER encoding/decoding as well as heapless no_std (i.e. embedded) support

30 releases

0.10.0-rc.3 Nov 3, 2024
0.10.0-rc.0 Jul 26, 2024
0.10.0-pre.2 Jan 5, 2024
0.10.0-pre.0 Oct 8, 2023
0.2.0 Sep 5, 2020

#32 in Encoding

Download history 995074/week @ 2024-09-23 987160/week @ 2024-09-30 1031886/week @ 2024-10-07 1029253/week @ 2024-10-14 1105874/week @ 2024-10-21 1058981/week @ 2024-10-28 1086881/week @ 2024-11-04 1074344/week @ 2024-11-11 1129860/week @ 2024-11-18 963485/week @ 2024-11-25 1106281/week @ 2024-12-02 1250967/week @ 2024-12-09 1152835/week @ 2024-12-16 466054/week @ 2024-12-23 637356/week @ 2024-12-30 1172886/week @ 2025-01-06

3,479,971 downloads per month
Used in 5,486 crates (45 directly)

Apache-2.0 OR MIT

320KB
6.5K SLoC

RustCrypto: Object Identifiers (OIDs)

crate Docs Build Status Apache2/MIT licensed Rust Version Project Chat

Const-friendly implementation of the ISO/IEC Object Identifier (OID) standard as defined in ITU X.660, with support for BER/DER encoding/decoding as well as heapless no_std (i.e. embedded) environments.

Documentation

About OIDs

Object Identifiers, a.k.a. OIDs, are an International Telecommunications Union (ITU) and ISO/IEC standard for naming any object, concept, or "thing" with a globally unambiguous persistent name.

The ITU's X.660 standard provides the OID specification. Every OID is part of a hierarchical namespace which begins with a root OID, which is either the ITU's root OID (0), the ISO's root OID (1), or the joint ISO/ITU root OID (2).

The following is an example of an OID, in this case identifying the rsaEncryption algorithm:

1.2.840.113549.1.1.1

For more information, see: https://en.wikipedia.org/wiki/Object_identifier

Implementation

This library supports parsing OIDs in const contexts, e.g.:

use const_oid::ObjectIdentifier;

pub const MY_OID: ObjectIdentifier = ObjectIdentifier::new_unwrap("1.2.840.113549.1.1.1");

The OID parser is implemented entirely in terms of const fn and without the use of proc macros.

Additionally, it also includes a const fn OID serializer, and stores the OIDs parsed from const contexts encoded using the BER/DER serialization (sans header).

This allows ObjectIdentifier to impl AsRef<[u8]> which can be used to obtain the BER/DER serialization of an OID, even one declared const.

Additionally, it impls FromStr and TryFrom<&[u8]> and functions just as well as a runtime OID library.

Minimum Supported Rust Version

This crate requires Rust 1.81 at a minimum.

We may change the MSRV in the future, but it will be accompanied by a minor version bump.

License

Licensed under either of:

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~130KB