mbed TLS v2.16.3
oid.h
Go to the documentation of this file.
1 
6 /*
7  * Copyright (C) 2006-2015, ARM Limited, All Rights Reserved
8  * SPDX-License-Identifier: Apache-2.0
9  *
10  * Licensed under the Apache License, Version 2.0 (the "License"); you may
11  * not use this file except in compliance with the License.
12  * You may obtain a copy of the License at
13  *
14  * http://www.apache.org/licenses/LICENSE-2.0
15  *
16  * Unless required by applicable law or agreed to in writing, software
17  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
18  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19  * See the License for the specific language governing permissions and
20  * limitations under the License.
21  *
22  * This file is part of mbed TLS (https://tls.mbed.org)
23  */
24 #ifndef MBEDTLS_OID_H
25 #define MBEDTLS_OID_H
26 
27 #if !defined(MBEDTLS_CONFIG_FILE)
28 #include "config.h"
29 #else
30 #include MBEDTLS_CONFIG_FILE
31 #endif
32 
33 #include "asn1.h"
34 #include "pk.h"
35 
36 #include <stddef.h>
37 
38 #if defined(MBEDTLS_CIPHER_C)
39 #include "cipher.h"
40 #endif
41 
42 #if defined(MBEDTLS_MD_C)
43 #include "md.h"
44 #endif
45 
46 #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C)
47 #include "x509.h"
48 #endif
49 
50 #define MBEDTLS_ERR_OID_NOT_FOUND -0x002E
51 #define MBEDTLS_ERR_OID_BUF_TOO_SMALL -0x000B
53 /*
54  * Top level OID tuples
55  */
56 #define MBEDTLS_OID_ISO_MEMBER_BODIES "\x2a" /* {iso(1) member-body(2)} */
57 #define MBEDTLS_OID_ISO_IDENTIFIED_ORG "\x2b" /* {iso(1) identified-organization(3)} */
58 #define MBEDTLS_OID_ISO_CCITT_DS "\x55" /* {joint-iso-ccitt(2) ds(5)} */
59 #define MBEDTLS_OID_ISO_ITU_COUNTRY "\x60" /* {joint-iso-itu-t(2) country(16)} */
60 
61 /*
62  * ISO Member bodies OID parts
63  */
64 #define MBEDTLS_OID_COUNTRY_US "\x86\x48" /* {us(840)} */
65 #define MBEDTLS_OID_ORG_RSA_DATA_SECURITY "\x86\xf7\x0d" /* {rsadsi(113549)} */
66 #define MBEDTLS_OID_RSA_COMPANY MBEDTLS_OID_ISO_MEMBER_BODIES MBEDTLS_OID_COUNTRY_US \
67  MBEDTLS_OID_ORG_RSA_DATA_SECURITY /* {iso(1) member-body(2) us(840) rsadsi(113549)} */
68 #define MBEDTLS_OID_ORG_ANSI_X9_62 "\xce\x3d" /* ansi-X9-62(10045) */
69 #define MBEDTLS_OID_ANSI_X9_62 MBEDTLS_OID_ISO_MEMBER_BODIES MBEDTLS_OID_COUNTRY_US \
70  MBEDTLS_OID_ORG_ANSI_X9_62
71 
72 /*
73  * ISO Identified organization OID parts
74  */
75 #define MBEDTLS_OID_ORG_DOD "\x06" /* {dod(6)} */
76 #define MBEDTLS_OID_ORG_OIW "\x0e"
77 #define MBEDTLS_OID_OIW_SECSIG MBEDTLS_OID_ORG_OIW "\x03"
78 #define MBEDTLS_OID_OIW_SECSIG_ALG MBEDTLS_OID_OIW_SECSIG "\x02"
79 #define MBEDTLS_OID_OIW_SECSIG_SHA1 MBEDTLS_OID_OIW_SECSIG_ALG "\x1a"
80 #define MBEDTLS_OID_ORG_CERTICOM "\x81\x04" /* certicom(132) */
81 #define MBEDTLS_OID_CERTICOM MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_CERTICOM
82 #define MBEDTLS_OID_ORG_TELETRUST "\x24" /* teletrust(36) */
83 #define MBEDTLS_OID_TELETRUST MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_TELETRUST
84 
85 /*
86  * ISO ITU OID parts
87  */
88 #define MBEDTLS_OID_ORGANIZATION "\x01" /* {organization(1)} */
89 #define MBEDTLS_OID_ISO_ITU_US_ORG MBEDTLS_OID_ISO_ITU_COUNTRY MBEDTLS_OID_COUNTRY_US MBEDTLS_OID_ORGANIZATION /* {joint-iso-itu-t(2) country(16) us(840) organization(1)} */
90 
91 #define MBEDTLS_OID_ORG_GOV "\x65" /* {gov(101)} */
92 #define MBEDTLS_OID_GOV MBEDTLS_OID_ISO_ITU_US_ORG MBEDTLS_OID_ORG_GOV /* {joint-iso-itu-t(2) country(16) us(840) organization(1) gov(101)} */
93 
94 #define MBEDTLS_OID_ORG_NETSCAPE "\x86\xF8\x42" /* {netscape(113730)} */
95 #define MBEDTLS_OID_NETSCAPE MBEDTLS_OID_ISO_ITU_US_ORG MBEDTLS_OID_ORG_NETSCAPE /* Netscape OID {joint-iso-itu-t(2) country(16) us(840) organization(1) netscape(113730)} */
96 
97 /* ISO arc for standard certificate and CRL extensions */
98 #define MBEDTLS_OID_ID_CE MBEDTLS_OID_ISO_CCITT_DS "\x1D"
100 #define MBEDTLS_OID_NIST_ALG MBEDTLS_OID_GOV "\x03\x04"
107 #define MBEDTLS_OID_PKIX MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_DOD "\x01\x05\x05\x07"
108 
109 /*
110  * Arc for standard naming attributes
111  */
112 #define MBEDTLS_OID_AT MBEDTLS_OID_ISO_CCITT_DS "\x04"
113 #define MBEDTLS_OID_AT_CN MBEDTLS_OID_AT "\x03"
114 #define MBEDTLS_OID_AT_SUR_NAME MBEDTLS_OID_AT "\x04"
115 #define MBEDTLS_OID_AT_SERIAL_NUMBER MBEDTLS_OID_AT "\x05"
116 #define MBEDTLS_OID_AT_COUNTRY MBEDTLS_OID_AT "\x06"
117 #define MBEDTLS_OID_AT_LOCALITY MBEDTLS_OID_AT "\x07"
118 #define MBEDTLS_OID_AT_STATE MBEDTLS_OID_AT "\x08"
119 #define MBEDTLS_OID_AT_ORGANIZATION MBEDTLS_OID_AT "\x0A"
120 #define MBEDTLS_OID_AT_ORG_UNIT MBEDTLS_OID_AT "\x0B"
121 #define MBEDTLS_OID_AT_TITLE MBEDTLS_OID_AT "\x0C"
122 #define MBEDTLS_OID_AT_POSTAL_ADDRESS MBEDTLS_OID_AT "\x10"
123 #define MBEDTLS_OID_AT_POSTAL_CODE MBEDTLS_OID_AT "\x11"
124 #define MBEDTLS_OID_AT_GIVEN_NAME MBEDTLS_OID_AT "\x2A"
125 #define MBEDTLS_OID_AT_INITIALS MBEDTLS_OID_AT "\x2B"
126 #define MBEDTLS_OID_AT_GENERATION_QUALIFIER MBEDTLS_OID_AT "\x2C"
127 #define MBEDTLS_OID_AT_UNIQUE_IDENTIFIER MBEDTLS_OID_AT "\x2D"
128 #define MBEDTLS_OID_AT_DN_QUALIFIER MBEDTLS_OID_AT "\x2E"
129 #define MBEDTLS_OID_AT_PSEUDONYM MBEDTLS_OID_AT "\x41"
131 #define MBEDTLS_OID_DOMAIN_COMPONENT "\x09\x92\x26\x89\x93\xF2\x2C\x64\x01\x19"
133 /*
134  * OIDs for standard certificate extensions
135  */
136 #define MBEDTLS_OID_AUTHORITY_KEY_IDENTIFIER MBEDTLS_OID_ID_CE "\x23"
137 #define MBEDTLS_OID_SUBJECT_KEY_IDENTIFIER MBEDTLS_OID_ID_CE "\x0E"
138 #define MBEDTLS_OID_KEY_USAGE MBEDTLS_OID_ID_CE "\x0F"
139 #define MBEDTLS_OID_CERTIFICATE_POLICIES MBEDTLS_OID_ID_CE "\x20"
140 #define MBEDTLS_OID_POLICY_MAPPINGS MBEDTLS_OID_ID_CE "\x21"
141 #define MBEDTLS_OID_SUBJECT_ALT_NAME MBEDTLS_OID_ID_CE "\x11"
142 #define MBEDTLS_OID_ISSUER_ALT_NAME MBEDTLS_OID_ID_CE "\x12"
143 #define MBEDTLS_OID_SUBJECT_DIRECTORY_ATTRS MBEDTLS_OID_ID_CE "\x09"
144 #define MBEDTLS_OID_BASIC_CONSTRAINTS MBEDTLS_OID_ID_CE "\x13"
145 #define MBEDTLS_OID_NAME_CONSTRAINTS MBEDTLS_OID_ID_CE "\x1E"
146 #define MBEDTLS_OID_POLICY_CONSTRAINTS MBEDTLS_OID_ID_CE "\x24"
147 #define MBEDTLS_OID_EXTENDED_KEY_USAGE MBEDTLS_OID_ID_CE "\x25"
148 #define MBEDTLS_OID_CRL_DISTRIBUTION_POINTS MBEDTLS_OID_ID_CE "\x1F"
149 #define MBEDTLS_OID_INIHIBIT_ANYPOLICY MBEDTLS_OID_ID_CE "\x36"
150 #define MBEDTLS_OID_FRESHEST_CRL MBEDTLS_OID_ID_CE "\x2E"
152 /*
153  * Netscape certificate extensions
154  */
155 #define MBEDTLS_OID_NS_CERT MBEDTLS_OID_NETSCAPE "\x01"
156 #define MBEDTLS_OID_NS_CERT_TYPE MBEDTLS_OID_NS_CERT "\x01"
157 #define MBEDTLS_OID_NS_BASE_URL MBEDTLS_OID_NS_CERT "\x02"
158 #define MBEDTLS_OID_NS_REVOCATION_URL MBEDTLS_OID_NS_CERT "\x03"
159 #define MBEDTLS_OID_NS_CA_REVOCATION_URL MBEDTLS_OID_NS_CERT "\x04"
160 #define MBEDTLS_OID_NS_RENEWAL_URL MBEDTLS_OID_NS_CERT "\x07"
161 #define MBEDTLS_OID_NS_CA_POLICY_URL MBEDTLS_OID_NS_CERT "\x08"
162 #define MBEDTLS_OID_NS_SSL_SERVER_NAME MBEDTLS_OID_NS_CERT "\x0C"
163 #define MBEDTLS_OID_NS_COMMENT MBEDTLS_OID_NS_CERT "\x0D"
164 #define MBEDTLS_OID_NS_DATA_TYPE MBEDTLS_OID_NETSCAPE "\x02"
165 #define MBEDTLS_OID_NS_CERT_SEQUENCE MBEDTLS_OID_NS_DATA_TYPE "\x05"
166 
167 /*
168  * OIDs for CRL extensions
169  */
170 #define MBEDTLS_OID_PRIVATE_KEY_USAGE_PERIOD MBEDTLS_OID_ID_CE "\x10"
171 #define MBEDTLS_OID_CRL_NUMBER MBEDTLS_OID_ID_CE "\x14"
173 /*
174  * X.509 v3 Extended key usage OIDs
175  */
176 #define MBEDTLS_OID_ANY_EXTENDED_KEY_USAGE MBEDTLS_OID_EXTENDED_KEY_USAGE "\x00"
178 #define MBEDTLS_OID_KP MBEDTLS_OID_PKIX "\x03"
179 #define MBEDTLS_OID_SERVER_AUTH MBEDTLS_OID_KP "\x01"
180 #define MBEDTLS_OID_CLIENT_AUTH MBEDTLS_OID_KP "\x02"
181 #define MBEDTLS_OID_CODE_SIGNING MBEDTLS_OID_KP "\x03"
182 #define MBEDTLS_OID_EMAIL_PROTECTION MBEDTLS_OID_KP "\x04"
183 #define MBEDTLS_OID_TIME_STAMPING MBEDTLS_OID_KP "\x08"
184 #define MBEDTLS_OID_OCSP_SIGNING MBEDTLS_OID_KP "\x09"
186 /*
187  * PKCS definition OIDs
188  */
189 
190 #define MBEDTLS_OID_PKCS MBEDTLS_OID_RSA_COMPANY "\x01"
191 #define MBEDTLS_OID_PKCS1 MBEDTLS_OID_PKCS "\x01"
192 #define MBEDTLS_OID_PKCS5 MBEDTLS_OID_PKCS "\x05"
193 #define MBEDTLS_OID_PKCS9 MBEDTLS_OID_PKCS "\x09"
194 #define MBEDTLS_OID_PKCS12 MBEDTLS_OID_PKCS "\x0c"
196 /*
197  * PKCS#1 OIDs
198  */
199 #define MBEDTLS_OID_PKCS1_RSA MBEDTLS_OID_PKCS1 "\x01"
200 #define MBEDTLS_OID_PKCS1_MD2 MBEDTLS_OID_PKCS1 "\x02"
201 #define MBEDTLS_OID_PKCS1_MD4 MBEDTLS_OID_PKCS1 "\x03"
202 #define MBEDTLS_OID_PKCS1_MD5 MBEDTLS_OID_PKCS1 "\x04"
203 #define MBEDTLS_OID_PKCS1_SHA1 MBEDTLS_OID_PKCS1 "\x05"
204 #define MBEDTLS_OID_PKCS1_SHA224 MBEDTLS_OID_PKCS1 "\x0e"
205 #define MBEDTLS_OID_PKCS1_SHA256 MBEDTLS_OID_PKCS1 "\x0b"
206 #define MBEDTLS_OID_PKCS1_SHA384 MBEDTLS_OID_PKCS1 "\x0c"
207 #define MBEDTLS_OID_PKCS1_SHA512 MBEDTLS_OID_PKCS1 "\x0d"
209 #define MBEDTLS_OID_RSA_SHA_OBS "\x2B\x0E\x03\x02\x1D"
210 
211 #define MBEDTLS_OID_PKCS9_EMAIL MBEDTLS_OID_PKCS9 "\x01"
213 /* RFC 4055 */
214 #define MBEDTLS_OID_RSASSA_PSS MBEDTLS_OID_PKCS1 "\x0a"
215 #define MBEDTLS_OID_MGF1 MBEDTLS_OID_PKCS1 "\x08"
217 /*
218  * Digest algorithms
219  */
220 #define MBEDTLS_OID_DIGEST_ALG_MD2 MBEDTLS_OID_RSA_COMPANY "\x02\x02"
221 #define MBEDTLS_OID_DIGEST_ALG_MD4 MBEDTLS_OID_RSA_COMPANY "\x02\x04"
222 #define MBEDTLS_OID_DIGEST_ALG_MD5 MBEDTLS_OID_RSA_COMPANY "\x02\x05"
223 #define MBEDTLS_OID_DIGEST_ALG_SHA1 MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_OIW_SECSIG_SHA1
224 #define MBEDTLS_OID_DIGEST_ALG_SHA224 MBEDTLS_OID_NIST_ALG "\x02\x04"
225 #define MBEDTLS_OID_DIGEST_ALG_SHA256 MBEDTLS_OID_NIST_ALG "\x02\x01"
227 #define MBEDTLS_OID_DIGEST_ALG_SHA384 MBEDTLS_OID_NIST_ALG "\x02\x02"
229 #define MBEDTLS_OID_DIGEST_ALG_SHA512 MBEDTLS_OID_NIST_ALG "\x02\x03"
231 #define MBEDTLS_OID_HMAC_SHA1 MBEDTLS_OID_RSA_COMPANY "\x02\x07"
233 #define MBEDTLS_OID_HMAC_SHA224 MBEDTLS_OID_RSA_COMPANY "\x02\x08"
235 #define MBEDTLS_OID_HMAC_SHA256 MBEDTLS_OID_RSA_COMPANY "\x02\x09"
237 #define MBEDTLS_OID_HMAC_SHA384 MBEDTLS_OID_RSA_COMPANY "\x02\x0A"
239 #define MBEDTLS_OID_HMAC_SHA512 MBEDTLS_OID_RSA_COMPANY "\x02\x0B"
241 /*
242  * Encryption algorithms
243  */
244 #define MBEDTLS_OID_DES_CBC MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_OIW_SECSIG_ALG "\x07"
245 #define MBEDTLS_OID_DES_EDE3_CBC MBEDTLS_OID_RSA_COMPANY "\x03\x07"
246 #define MBEDTLS_OID_AES MBEDTLS_OID_NIST_ALG "\x01"
248 /*
249  * Key Wrapping algorithms
250  */
251 /*
252  * RFC 5649
253  */
254 #define MBEDTLS_OID_AES128_KW MBEDTLS_OID_AES "\x05"
255 #define MBEDTLS_OID_AES128_KWP MBEDTLS_OID_AES "\x08"
256 #define MBEDTLS_OID_AES192_KW MBEDTLS_OID_AES "\x19"
257 #define MBEDTLS_OID_AES192_KWP MBEDTLS_OID_AES "\x1c"
258 #define MBEDTLS_OID_AES256_KW MBEDTLS_OID_AES "\x2d"
259 #define MBEDTLS_OID_AES256_KWP MBEDTLS_OID_AES "\x30"
260 /*
261  * PKCS#5 OIDs
262  */
263 #define MBEDTLS_OID_PKCS5_PBKDF2 MBEDTLS_OID_PKCS5 "\x0c"
264 #define MBEDTLS_OID_PKCS5_PBES2 MBEDTLS_OID_PKCS5 "\x0d"
265 #define MBEDTLS_OID_PKCS5_PBMAC1 MBEDTLS_OID_PKCS5 "\x0e"
267 /*
268  * PKCS#5 PBES1 algorithms
269  */
270 #define MBEDTLS_OID_PKCS5_PBE_MD2_DES_CBC MBEDTLS_OID_PKCS5 "\x01"
271 #define MBEDTLS_OID_PKCS5_PBE_MD2_RC2_CBC MBEDTLS_OID_PKCS5 "\x04"
272 #define MBEDTLS_OID_PKCS5_PBE_MD5_DES_CBC MBEDTLS_OID_PKCS5 "\x03"
273 #define MBEDTLS_OID_PKCS5_PBE_MD5_RC2_CBC MBEDTLS_OID_PKCS5 "\x06"
274 #define MBEDTLS_OID_PKCS5_PBE_SHA1_DES_CBC MBEDTLS_OID_PKCS5 "\x0a"
275 #define MBEDTLS_OID_PKCS5_PBE_SHA1_RC2_CBC MBEDTLS_OID_PKCS5 "\x0b"
277 /*
278  * PKCS#8 OIDs
279  */
280 #define MBEDTLS_OID_PKCS9_CSR_EXT_REQ MBEDTLS_OID_PKCS9 "\x0e"
282 /*
283  * PKCS#12 PBE OIDs
284  */
285 #define MBEDTLS_OID_PKCS12_PBE MBEDTLS_OID_PKCS12 "\x01"
287 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC4_128 MBEDTLS_OID_PKCS12_PBE "\x01"
288 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC4_40 MBEDTLS_OID_PKCS12_PBE "\x02"
289 #define MBEDTLS_OID_PKCS12_PBE_SHA1_DES3_EDE_CBC MBEDTLS_OID_PKCS12_PBE "\x03"
290 #define MBEDTLS_OID_PKCS12_PBE_SHA1_DES2_EDE_CBC MBEDTLS_OID_PKCS12_PBE "\x04"
291 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC2_128_CBC MBEDTLS_OID_PKCS12_PBE "\x05"
292 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC2_40_CBC MBEDTLS_OID_PKCS12_PBE "\x06"
294 /*
295  * EC key algorithms from RFC 5480
296  */
297 
298 /* id-ecPublicKey OBJECT IDENTIFIER ::= {
299  * iso(1) member-body(2) us(840) ansi-X9-62(10045) keyType(2) 1 } */
300 #define MBEDTLS_OID_EC_ALG_UNRESTRICTED MBEDTLS_OID_ANSI_X9_62 "\x02\01"
301 
302 /* id-ecDH OBJECT IDENTIFIER ::= {
303  * iso(1) identified-organization(3) certicom(132)
304  * schemes(1) ecdh(12) } */
305 #define MBEDTLS_OID_EC_ALG_ECDH MBEDTLS_OID_CERTICOM "\x01\x0c"
306 
307 /*
308  * ECParameters namedCurve identifiers, from RFC 5480, RFC 5639, and SEC2
309  */
310 
311 /* secp192r1 OBJECT IDENTIFIER ::= {
312  * iso(1) member-body(2) us(840) ansi-X9-62(10045) curves(3) prime(1) 1 } */
313 #define MBEDTLS_OID_EC_GRP_SECP192R1 MBEDTLS_OID_ANSI_X9_62 "\x03\x01\x01"
314 
315 /* secp224r1 OBJECT IDENTIFIER ::= {
316  * iso(1) identified-organization(3) certicom(132) curve(0) 33 } */
317 #define MBEDTLS_OID_EC_GRP_SECP224R1 MBEDTLS_OID_CERTICOM "\x00\x21"
318 
319 /* secp256r1 OBJECT IDENTIFIER ::= {
320  * iso(1) member-body(2) us(840) ansi-X9-62(10045) curves(3) prime(1) 7 } */
321 #define MBEDTLS_OID_EC_GRP_SECP256R1 MBEDTLS_OID_ANSI_X9_62 "\x03\x01\x07"
322 
323 /* secp384r1 OBJECT IDENTIFIER ::= {
324  * iso(1) identified-organization(3) certicom(132) curve(0) 34 } */
325 #define MBEDTLS_OID_EC_GRP_SECP384R1 MBEDTLS_OID_CERTICOM "\x00\x22"
326 
327 /* secp521r1 OBJECT IDENTIFIER ::= {
328  * iso(1) identified-organization(3) certicom(132) curve(0) 35 } */
329 #define MBEDTLS_OID_EC_GRP_SECP521R1 MBEDTLS_OID_CERTICOM "\x00\x23"
330 
331 /* secp192k1 OBJECT IDENTIFIER ::= {
332  * iso(1) identified-organization(3) certicom(132) curve(0) 31 } */
333 #define MBEDTLS_OID_EC_GRP_SECP192K1 MBEDTLS_OID_CERTICOM "\x00\x1f"
334 
335 /* secp224k1 OBJECT IDENTIFIER ::= {
336  * iso(1) identified-organization(3) certicom(132) curve(0) 32 } */
337 #define MBEDTLS_OID_EC_GRP_SECP224K1 MBEDTLS_OID_CERTICOM "\x00\x20"
338 
339 /* secp256k1 OBJECT IDENTIFIER ::= {
340  * iso(1) identified-organization(3) certicom(132) curve(0) 10 } */
341 #define MBEDTLS_OID_EC_GRP_SECP256K1 MBEDTLS_OID_CERTICOM "\x00\x0a"
342 
343 /* RFC 5639 4.1
344  * ecStdCurvesAndGeneration OBJECT IDENTIFIER::= {iso(1)
345  * identified-organization(3) teletrust(36) algorithm(3) signature-
346  * algorithm(3) ecSign(2) 8}
347  * ellipticCurve OBJECT IDENTIFIER ::= {ecStdCurvesAndGeneration 1}
348  * versionOne OBJECT IDENTIFIER ::= {ellipticCurve 1} */
349 #define MBEDTLS_OID_EC_BRAINPOOL_V1 MBEDTLS_OID_TELETRUST "\x03\x03\x02\x08\x01\x01"
350 
351 /* brainpoolP256r1 OBJECT IDENTIFIER ::= {versionOne 7} */
352 #define MBEDTLS_OID_EC_GRP_BP256R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x07"
353 
354 /* brainpoolP384r1 OBJECT IDENTIFIER ::= {versionOne 11} */
355 #define MBEDTLS_OID_EC_GRP_BP384R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x0B"
356 
357 /* brainpoolP512r1 OBJECT IDENTIFIER ::= {versionOne 13} */
358 #define MBEDTLS_OID_EC_GRP_BP512R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x0D"
359 
360 /*
361  * SEC1 C.1
362  *
363  * prime-field OBJECT IDENTIFIER ::= { id-fieldType 1 }
364  * id-fieldType OBJECT IDENTIFIER ::= { ansi-X9-62 fieldType(1)}
365  */
366 #define MBEDTLS_OID_ANSI_X9_62_FIELD_TYPE MBEDTLS_OID_ANSI_X9_62 "\x01"
367 #define MBEDTLS_OID_ANSI_X9_62_PRIME_FIELD MBEDTLS_OID_ANSI_X9_62_FIELD_TYPE "\x01"
368 
369 /*
370  * ECDSA signature identifiers, from RFC 5480
371  */
372 #define MBEDTLS_OID_ANSI_X9_62_SIG MBEDTLS_OID_ANSI_X9_62 "\x04" /* signatures(4) */
373 #define MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 MBEDTLS_OID_ANSI_X9_62_SIG "\x03" /* ecdsa-with-SHA2(3) */
374 
375 /* ecdsa-with-SHA1 OBJECT IDENTIFIER ::= {
376  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4) 1 } */
377 #define MBEDTLS_OID_ECDSA_SHA1 MBEDTLS_OID_ANSI_X9_62_SIG "\x01"
378 
379 /* ecdsa-with-SHA224 OBJECT IDENTIFIER ::= {
380  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
381  * ecdsa-with-SHA2(3) 1 } */
382 #define MBEDTLS_OID_ECDSA_SHA224 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x01"
383 
384 /* ecdsa-with-SHA256 OBJECT IDENTIFIER ::= {
385  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
386  * ecdsa-with-SHA2(3) 2 } */
387 #define MBEDTLS_OID_ECDSA_SHA256 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x02"
388 
389 /* ecdsa-with-SHA384 OBJECT IDENTIFIER ::= {
390  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
391  * ecdsa-with-SHA2(3) 3 } */
392 #define MBEDTLS_OID_ECDSA_SHA384 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x03"
393 
394 /* ecdsa-with-SHA512 OBJECT IDENTIFIER ::= {
395  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
396  * ecdsa-with-SHA2(3) 4 } */
397 #define MBEDTLS_OID_ECDSA_SHA512 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x04"
398 
399 #ifdef __cplusplus
400 extern "C" {
401 #endif
402 
407 {
408  const char *asn1;
409  size_t asn1_len;
410  const char *name;
411  const char *description;
413 
425 int mbedtls_oid_get_numeric_string( char *buf, size_t size, const mbedtls_asn1_buf *oid );
426 
427 #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C)
428 
436 int mbedtls_oid_get_x509_ext_type( const mbedtls_asn1_buf *oid, int *ext_type );
437 #endif
438 
448 int mbedtls_oid_get_attr_short_name( const mbedtls_asn1_buf *oid, const char **short_name );
449 
459 
470  const char **oid, size_t *olen );
471 
472 #if defined(MBEDTLS_ECP_C)
473 
482 
493  const char **oid, size_t *olen );
494 #endif /* MBEDTLS_ECP_C */
495 
496 #if defined(MBEDTLS_MD_C)
497 
507  mbedtls_md_type_t *md_alg, mbedtls_pk_type_t *pk_alg );
508 
517 int mbedtls_oid_get_sig_alg_desc( const mbedtls_asn1_buf *oid, const char **desc );
518 
530  const char **oid, size_t *olen );
531 
541 
551 #endif /* MBEDTLS_MD_C */
552 
561 int mbedtls_oid_get_extended_key_usage( const mbedtls_asn1_buf *oid, const char **desc );
562 
572 int mbedtls_oid_get_oid_by_md( mbedtls_md_type_t md_alg, const char **oid, size_t *olen );
573 
574 #if defined(MBEDTLS_CIPHER_C)
575 
584 #endif /* MBEDTLS_CIPHER_C */
585 
586 #if defined(MBEDTLS_PKCS12_C)
587 
598  mbedtls_cipher_type_t *cipher_alg );
599 #endif /* MBEDTLS_PKCS12_C */
600 
601 #ifdef __cplusplus
602 }
603 #endif
604 
605 #endif /* oid.h */
mbedtls_md_type_t
mbedtls_md_type_t
Supported message digests.
Definition: md.h:58
mbedtls_oid_get_cipher_alg
int mbedtls_oid_get_cipher_alg(const mbedtls_asn1_buf *oid, mbedtls_cipher_type_t *cipher_alg)
Translate encryption algorithm OID into cipher_type.
mbedtls_oid_get_extended_key_usage
int mbedtls_oid_get_extended_key_usage(const mbedtls_asn1_buf *oid, const char **desc)
Translate Extended Key Usage OID into description.
md.h
This file contains the generic message-digest wrapper.
mbedtls_oid_get_sig_alg_desc
int mbedtls_oid_get_sig_alg_desc(const mbedtls_asn1_buf *oid, const char **desc)
Translate SignatureAlgorithm OID into description.
mbedtls_oid_descriptor_t::asn1_len
size_t asn1_len
Definition: oid.h:409
mbedtls_oid_get_oid_by_ec_grp
int mbedtls_oid_get_oid_by_ec_grp(mbedtls_ecp_group_id grp_id, const char **oid, size_t *olen)
Translate EC group identifier into NamedCurve OID.
mbedtls_oid_get_numeric_string
int mbedtls_oid_get_numeric_string(char *buf, size_t size, const mbedtls_asn1_buf *oid)
Translate an ASN.1 OID into its numeric representation (e.g. "\x2A\x86\x48\x86\xF7\x0D" into "1....
mbedtls_oid_descriptor_t
Base OID descriptor structure.
Definition: oid.h:406
mbedtls_oid_get_x509_ext_type
int mbedtls_oid_get_x509_ext_type(const mbedtls_asn1_buf *oid, int *ext_type)
Translate an X.509 extension OID into local values.
mbedtls_oid_get_attr_short_name
int mbedtls_oid_get_attr_short_name(const mbedtls_asn1_buf *oid, const char **short_name)
Translate an X.509 attribute type OID into the short name (e.g. the OID for an X520 Common Name into ...
cipher.h
This file contains an abstraction interface for use with the cipher primitives provided by the librar...
mbedtls_ecp_group_id
mbedtls_ecp_group_id
Definition: ecp.h:77
mbedtls_oid_descriptor_t::description
const char * description
Definition: oid.h:411
mbedtls_oid_get_ec_grp
int mbedtls_oid_get_ec_grp(const mbedtls_asn1_buf *oid, mbedtls_ecp_group_id *grp_id)
Translate NamedCurve OID into an EC group identifier.
mbedtls_oid_get_sig_alg
int mbedtls_oid_get_sig_alg(const mbedtls_asn1_buf *oid, mbedtls_md_type_t *md_alg, mbedtls_pk_type_t *pk_alg)
Translate SignatureAlgorithm OID into md_type and pk_type.
mbedtls_pk_type_t
mbedtls_pk_type_t
Public key types.
Definition: pk.h:78
mbedtls_oid_descriptor_t::asn1
const char * asn1
Definition: oid.h:408
mbedtls_oid_descriptor_t
struct mbedtls_oid_descriptor_t mbedtls_oid_descriptor_t
Base OID descriptor structure.
mbedtls_oid_get_md_alg
int mbedtls_oid_get_md_alg(const mbedtls_asn1_buf *oid, mbedtls_md_type_t *md_alg)
Translate hash algorithm OID into md_type.
mbedtls_oid_get_md_hmac
int mbedtls_oid_get_md_hmac(const mbedtls_asn1_buf *oid, mbedtls_md_type_t *md_hmac)
Translate hmac algorithm OID into md_type.
mbedtls_oid_descriptor_t::name
const char * name
Definition: oid.h:410
mbedtls_oid_get_pk_alg
int mbedtls_oid_get_pk_alg(const mbedtls_asn1_buf *oid, mbedtls_pk_type_t *pk_alg)
Translate PublicKeyAlgorithm OID into pk_type.
pk.h
Public Key abstraction layer.
mbedtls_oid_get_oid_by_sig_alg
int mbedtls_oid_get_oid_by_sig_alg(mbedtls_pk_type_t pk_alg, mbedtls_md_type_t md_alg, const char **oid, size_t *olen)
Translate md_type and pk_type into SignatureAlgorithm OID.
config.h
Configuration options (set of defines)
md_hmac
#define md_hmac
Definition: compat-1.3.h:2026
mbedtls_oid_get_pkcs12_pbe_alg
int mbedtls_oid_get_pkcs12_pbe_alg(const mbedtls_asn1_buf *oid, mbedtls_md_type_t *md_alg, mbedtls_cipher_type_t *cipher_alg)
Translate PKCS#12 PBE algorithm OID into md_type and cipher_type.
mbedtls_asn1_buf
Definition: asn1.h:134
mbedtls_oid_get_oid_by_md
int mbedtls_oid_get_oid_by_md(mbedtls_md_type_t md_alg, const char **oid, size_t *olen)
Translate md_type into hash algorithm OID.
mbedtls_oid_get_oid_by_pk_alg
int mbedtls_oid_get_oid_by_pk_alg(mbedtls_pk_type_t pk_alg, const char **oid, size_t *olen)
Translate pk_type into PublicKeyAlgorithm OID.
mbedtls_cipher_type_t
mbedtls_cipher_type_t
Supported {cipher type, cipher mode} pairs.
Definition: cipher.h:104
asn1.h
Generic ASN.1 parsing.
x509.h
X.509 generic defines and structures.