| 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| 2 | /* ASN.1 Object identifier (OID) registry |
| 3 | * |
| 4 | * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved. |
| 5 | * Written by David Howells (dhowells@redhat.com) |
| 6 | */ |
| 7 | |
| 8 | #ifndef _LINUX_OID_REGISTRY_H |
| 9 | #define _LINUX_OID_REGISTRY_H |
| 10 | |
| 11 | #include <linux/types.h> |
| 12 | |
| 13 | /* |
| 14 | * OIDs are turned into these values if possible, or OID__NR if not held here. |
| 15 | * |
| 16 | * NOTE! Do not mess with the format of each line as this is read by |
| 17 | * build_OID_registry.pl to generate the data for look_up_OID(). |
| 18 | */ |
| 19 | enum OID { |
| 20 | OID_id_dsa_with_sha1, /* 1.2.840.10030.4.3 */ |
| 21 | OID_id_dsa, /* 1.2.840.10040.4.1 */ |
| 22 | OID_id_ecPublicKey, /* 1.2.840.10045.2.1 */ |
| 23 | OID_id_prime192v1, /* 1.2.840.10045.3.1.1 */ |
| 24 | OID_id_prime256v1, /* 1.2.840.10045.3.1.7 */ |
| 25 | OID_id_ecdsa_with_sha1, /* 1.2.840.10045.4.1 */ |
| 26 | OID_id_ecdsa_with_sha224, /* 1.2.840.10045.4.3.1 */ |
| 27 | OID_id_ecdsa_with_sha256, /* 1.2.840.10045.4.3.2 */ |
| 28 | OID_id_ecdsa_with_sha384, /* 1.2.840.10045.4.3.3 */ |
| 29 | OID_id_ecdsa_with_sha512, /* 1.2.840.10045.4.3.4 */ |
| 30 | |
| 31 | /* PKCS#1 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-1(1)} */ |
| 32 | OID_rsaEncryption, /* 1.2.840.113549.1.1.1 */ |
| 33 | OID_sha1WithRSAEncryption, /* 1.2.840.113549.1.1.5 */ |
| 34 | OID_sha256WithRSAEncryption, /* 1.2.840.113549.1.1.11 */ |
| 35 | OID_sha384WithRSAEncryption, /* 1.2.840.113549.1.1.12 */ |
| 36 | OID_sha512WithRSAEncryption, /* 1.2.840.113549.1.1.13 */ |
| 37 | OID_sha224WithRSAEncryption, /* 1.2.840.113549.1.1.14 */ |
| 38 | /* PKCS#7 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-7(7)} */ |
| 39 | OID_data, /* 1.2.840.113549.1.7.1 */ |
| 40 | OID_signed_data, /* 1.2.840.113549.1.7.2 */ |
| 41 | /* PKCS#9 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-9(9)} */ |
| 42 | OID_email_address, /* 1.2.840.113549.1.9.1 */ |
| 43 | OID_contentType, /* 1.2.840.113549.1.9.3 */ |
| 44 | OID_messageDigest, /* 1.2.840.113549.1.9.4 */ |
| 45 | OID_signingTime, /* 1.2.840.113549.1.9.5 */ |
| 46 | OID_smimeCapabilites, /* 1.2.840.113549.1.9.15 */ |
| 47 | OID_smimeAuthenticatedAttrs, /* 1.2.840.113549.1.9.16.2.11 */ |
| 48 | |
| 49 | OID_mskrb5, /* 1.2.840.48018.1.2.2 */ |
| 50 | OID_krb5, /* 1.2.840.113554.1.2.2 */ |
| 51 | OID_krb5u2u, /* 1.2.840.113554.1.2.2.3 */ |
| 52 | |
| 53 | /* Microsoft Authenticode & Software Publishing */ |
| 54 | OID_msIndirectData, /* 1.3.6.1.4.1.311.2.1.4 */ |
| 55 | OID_msStatementType, /* 1.3.6.1.4.1.311.2.1.11 */ |
| 56 | OID_msSpOpusInfo, /* 1.3.6.1.4.1.311.2.1.12 */ |
| 57 | OID_msPeImageDataObjId, /* 1.3.6.1.4.1.311.2.1.15 */ |
| 58 | OID_msIndividualSPKeyPurpose, /* 1.3.6.1.4.1.311.2.1.21 */ |
| 59 | OID_msOutlookExpress, /* 1.3.6.1.4.1.311.16.4 */ |
| 60 | |
| 61 | OID_ntlmssp, /* 1.3.6.1.4.1.311.2.2.10 */ |
| 62 | OID_negoex, /* 1.3.6.1.4.1.311.2.2.30 */ |
| 63 | |
| 64 | OID_spnego, /* 1.3.6.1.5.5.2 */ |
| 65 | |
| 66 | OID_IAKerb, /* 1.3.6.1.5.2.5 */ |
| 67 | OID_PKU2U, /* 1.3.5.1.5.2.7 */ |
| 68 | OID_Scram, /* 1.3.6.1.5.5.14 */ |
| 69 | OID_certAuthInfoAccess, /* 1.3.6.1.5.5.7.1.1 */ |
| 70 | OID_sha1, /* 1.3.14.3.2.26 */ |
| 71 | OID_id_ansip384r1, /* 1.3.132.0.34 */ |
| 72 | OID_id_ansip521r1, /* 1.3.132.0.35 */ |
| 73 | OID_sha256, /* 2.16.840.1.101.3.4.2.1 */ |
| 74 | OID_sha384, /* 2.16.840.1.101.3.4.2.2 */ |
| 75 | OID_sha512, /* 2.16.840.1.101.3.4.2.3 */ |
| 76 | OID_sha224, /* 2.16.840.1.101.3.4.2.4 */ |
| 77 | |
| 78 | /* Distinguished Name attribute IDs [RFC 2256] */ |
| 79 | OID_commonName, /* 2.5.4.3 */ |
| 80 | OID_surname, /* 2.5.4.4 */ |
| 81 | OID_countryName, /* 2.5.4.6 */ |
| 82 | OID_locality, /* 2.5.4.7 */ |
| 83 | OID_stateOrProvinceName, /* 2.5.4.8 */ |
| 84 | OID_organizationName, /* 2.5.4.10 */ |
| 85 | OID_organizationUnitName, /* 2.5.4.11 */ |
| 86 | OID_title, /* 2.5.4.12 */ |
| 87 | OID_description, /* 2.5.4.13 */ |
| 88 | OID_name, /* 2.5.4.41 */ |
| 89 | OID_givenName, /* 2.5.4.42 */ |
| 90 | OID_initials, /* 2.5.4.43 */ |
| 91 | OID_generationalQualifier, /* 2.5.4.44 */ |
| 92 | |
| 93 | /* Certificate extension IDs */ |
| 94 | OID_subjectKeyIdentifier, /* 2.5.29.14 */ |
| 95 | OID_keyUsage, /* 2.5.29.15 */ |
| 96 | OID_subjectAltName, /* 2.5.29.17 */ |
| 97 | OID_issuerAltName, /* 2.5.29.18 */ |
| 98 | OID_basicConstraints, /* 2.5.29.19 */ |
| 99 | OID_crlDistributionPoints, /* 2.5.29.31 */ |
| 100 | OID_certPolicies, /* 2.5.29.32 */ |
| 101 | OID_authorityKeyIdentifier, /* 2.5.29.35 */ |
| 102 | OID_extKeyUsage, /* 2.5.29.37 */ |
| 103 | |
| 104 | /* Heimdal mechanisms */ |
| 105 | OID_NetlogonMechanism, /* 1.2.752.43.14.2 */ |
| 106 | OID_appleLocalKdcSupported, /* 1.2.752.43.14.3 */ |
| 107 | |
| 108 | /* EC-RDSA */ |
| 109 | OID_gostCPSignA, /* 1.2.643.2.2.35.1 */ |
| 110 | OID_gostCPSignB, /* 1.2.643.2.2.35.2 */ |
| 111 | OID_gostCPSignC, /* 1.2.643.2.2.35.3 */ |
| 112 | OID_gost2012PKey256, /* 1.2.643.7.1.1.1.1 */ |
| 113 | OID_gost2012PKey512, /* 1.2.643.7.1.1.1.2 */ |
| 114 | OID_gost2012Digest256, /* 1.2.643.7.1.1.2.2 */ |
| 115 | OID_gost2012Digest512, /* 1.2.643.7.1.1.2.3 */ |
| 116 | OID_gost2012Signature256, /* 1.2.643.7.1.1.3.2 */ |
| 117 | OID_gost2012Signature512, /* 1.2.643.7.1.1.3.3 */ |
| 118 | OID_gostTC26Sign256A, /* 1.2.643.7.1.2.1.1.1 */ |
| 119 | OID_gostTC26Sign256B, /* 1.2.643.7.1.2.1.1.2 */ |
| 120 | OID_gostTC26Sign256C, /* 1.2.643.7.1.2.1.1.3 */ |
| 121 | OID_gostTC26Sign256D, /* 1.2.643.7.1.2.1.1.4 */ |
| 122 | OID_gostTC26Sign512A, /* 1.2.643.7.1.2.1.2.1 */ |
| 123 | OID_gostTC26Sign512B, /* 1.2.643.7.1.2.1.2.2 */ |
| 124 | OID_gostTC26Sign512C, /* 1.2.643.7.1.2.1.2.3 */ |
| 125 | |
| 126 | /* OSCCA */ |
| 127 | OID_sm2, /* 1.2.156.10197.1.301 */ |
| 128 | OID_sm3, /* 1.2.156.10197.1.401 */ |
| 129 | OID_SM2_with_SM3, /* 1.2.156.10197.1.501 */ |
| 130 | OID_sm3WithRSAEncryption, /* 1.2.156.10197.1.504 */ |
| 131 | |
| 132 | /* TCG defined OIDS for TPM based keys */ |
| 133 | OID_TPMLoadableKey, /* 2.23.133.10.1.3 */ |
| 134 | OID_TPMImportableKey, /* 2.23.133.10.1.4 */ |
| 135 | OID_TPMSealedData, /* 2.23.133.10.1.5 */ |
| 136 | |
| 137 | /* CSOR FIPS-202 SHA-3 */ |
| 138 | OID_sha3_256, /* 2.16.840.1.101.3.4.2.8 */ |
| 139 | OID_sha3_384, /* 2.16.840.1.101.3.4.2.9 */ |
| 140 | OID_sha3_512, /* 2.16.840.1.101.3.4.2.10 */ |
| 141 | OID_id_ecdsa_with_sha3_256, /* 2.16.840.1.101.3.4.3.10 */ |
| 142 | OID_id_ecdsa_with_sha3_384, /* 2.16.840.1.101.3.4.3.11 */ |
| 143 | OID_id_ecdsa_with_sha3_512, /* 2.16.840.1.101.3.4.3.12 */ |
| 144 | OID_id_rsassa_pkcs1_v1_5_with_sha3_256, /* 2.16.840.1.101.3.4.3.14 */ |
| 145 | OID_id_rsassa_pkcs1_v1_5_with_sha3_384, /* 2.16.840.1.101.3.4.3.15 */ |
| 146 | OID_id_rsassa_pkcs1_v1_5_with_sha3_512, /* 2.16.840.1.101.3.4.3.16 */ |
| 147 | |
| 148 | OID__NR |
| 149 | }; |
| 150 | |
| 151 | extern enum OID look_up_OID(const void *data, size_t datasize); |
| 152 | extern int parse_OID(const void *data, size_t datasize, enum OID *oid); |
| 153 | extern int sprint_oid(const void *, size_t, char *, size_t); |
| 154 | |
| 155 | #endif /* _LINUX_OID_REGISTRY_H */ |
| 156 | |