mbed TLS v2.16.11
oid.h
Go to the documentation of this file.
1 
6 /*
7  * Copyright The Mbed TLS Contributors
8  * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
9  *
10  * This file is provided under the Apache License 2.0, or the
11  * GNU General Public License v2.0 or later.
12  *
13  * **********
14  * Apache License 2.0:
15  *
16  * Licensed under the Apache License, Version 2.0 (the "License"); you may
17  * not use this file except in compliance with the License.
18  * You may obtain a copy of the License at
19  *
20  * http://www.apache.org/licenses/LICENSE-2.0
21  *
22  * Unless required by applicable law or agreed to in writing, software
23  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
24  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
25  * See the License for the specific language governing permissions and
26  * limitations under the License.
27  *
28  * **********
29  *
30  * **********
31  * GNU General Public License v2.0 or later:
32  *
33  * This program is free software; you can redistribute it and/or modify
34  * it under the terms of the GNU General Public License as published by
35  * the Free Software Foundation; either version 2 of the License, or
36  * (at your option) any later version.
37  *
38  * This program is distributed in the hope that it will be useful,
39  * but WITHOUT ANY WARRANTY; without even the implied warranty of
40  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
41  * GNU General Public License for more details.
42  *
43  * You should have received a copy of the GNU General Public License along
44  * with this program; if not, write to the Free Software Foundation, Inc.,
45  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
46  *
47  * **********
48  */
49 #ifndef MBEDTLS_OID_H
50 #define MBEDTLS_OID_H
51 
52 #if !defined(MBEDTLS_CONFIG_FILE)
53 #include "config.h"
54 #else
55 #include MBEDTLS_CONFIG_FILE
56 #endif
57 
58 #include "asn1.h"
59 #include "pk.h"
60 
61 #include <stddef.h>
62 
63 #if defined(MBEDTLS_CIPHER_C)
64 #include "cipher.h"
65 #endif
66 
67 #if defined(MBEDTLS_MD_C)
68 #include "md.h"
69 #endif
70 
71 #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C)
72 #include "x509.h"
73 #endif
74 
75 #define MBEDTLS_ERR_OID_NOT_FOUND -0x002E
76 #define MBEDTLS_ERR_OID_BUF_TOO_SMALL -0x000B
78 /*
79  * Top level OID tuples
80  */
81 #define MBEDTLS_OID_ISO_MEMBER_BODIES "\x2a" /* {iso(1) member-body(2)} */
82 #define MBEDTLS_OID_ISO_IDENTIFIED_ORG "\x2b" /* {iso(1) identified-organization(3)} */
83 #define MBEDTLS_OID_ISO_CCITT_DS "\x55" /* {joint-iso-ccitt(2) ds(5)} */
84 #define MBEDTLS_OID_ISO_ITU_COUNTRY "\x60" /* {joint-iso-itu-t(2) country(16)} */
85 
86 /*
87  * ISO Member bodies OID parts
88  */
89 #define MBEDTLS_OID_COUNTRY_US "\x86\x48" /* {us(840)} */
90 #define MBEDTLS_OID_ORG_RSA_DATA_SECURITY "\x86\xf7\x0d" /* {rsadsi(113549)} */
91 #define MBEDTLS_OID_RSA_COMPANY MBEDTLS_OID_ISO_MEMBER_BODIES MBEDTLS_OID_COUNTRY_US \
92  MBEDTLS_OID_ORG_RSA_DATA_SECURITY /* {iso(1) member-body(2) us(840) rsadsi(113549)} */
93 #define MBEDTLS_OID_ORG_ANSI_X9_62 "\xce\x3d" /* ansi-X9-62(10045) */
94 #define MBEDTLS_OID_ANSI_X9_62 MBEDTLS_OID_ISO_MEMBER_BODIES MBEDTLS_OID_COUNTRY_US \
95  MBEDTLS_OID_ORG_ANSI_X9_62
96 
97 /*
98  * ISO Identified organization OID parts
99  */
100 #define MBEDTLS_OID_ORG_DOD "\x06" /* {dod(6)} */
101 #define MBEDTLS_OID_ORG_OIW "\x0e"
102 #define MBEDTLS_OID_OIW_SECSIG MBEDTLS_OID_ORG_OIW "\x03"
103 #define MBEDTLS_OID_OIW_SECSIG_ALG MBEDTLS_OID_OIW_SECSIG "\x02"
104 #define MBEDTLS_OID_OIW_SECSIG_SHA1 MBEDTLS_OID_OIW_SECSIG_ALG "\x1a"
105 #define MBEDTLS_OID_ORG_CERTICOM "\x81\x04" /* certicom(132) */
106 #define MBEDTLS_OID_CERTICOM MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_CERTICOM
107 #define MBEDTLS_OID_ORG_TELETRUST "\x24" /* teletrust(36) */
108 #define MBEDTLS_OID_TELETRUST MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_TELETRUST
109 
110 /*
111  * ISO ITU OID parts
112  */
113 #define MBEDTLS_OID_ORGANIZATION "\x01" /* {organization(1)} */
114 #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)} */
115 
116 #define MBEDTLS_OID_ORG_GOV "\x65" /* {gov(101)} */
117 #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)} */
118 
119 #define MBEDTLS_OID_ORG_NETSCAPE "\x86\xF8\x42" /* {netscape(113730)} */
120 #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)} */
121 
122 /* ISO arc for standard certificate and CRL extensions */
123 #define MBEDTLS_OID_ID_CE MBEDTLS_OID_ISO_CCITT_DS "\x1D"
125 #define MBEDTLS_OID_NIST_ALG MBEDTLS_OID_GOV "\x03\x04"
132 #define MBEDTLS_OID_PKIX MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_ORG_DOD "\x01\x05\x05\x07"
133 
134 /*
135  * Arc for standard naming attributes
136  */
137 #define MBEDTLS_OID_AT MBEDTLS_OID_ISO_CCITT_DS "\x04"
138 #define MBEDTLS_OID_AT_CN MBEDTLS_OID_AT "\x03"
139 #define MBEDTLS_OID_AT_SUR_NAME MBEDTLS_OID_AT "\x04"
140 #define MBEDTLS_OID_AT_SERIAL_NUMBER MBEDTLS_OID_AT "\x05"
141 #define MBEDTLS_OID_AT_COUNTRY MBEDTLS_OID_AT "\x06"
142 #define MBEDTLS_OID_AT_LOCALITY MBEDTLS_OID_AT "\x07"
143 #define MBEDTLS_OID_AT_STATE MBEDTLS_OID_AT "\x08"
144 #define MBEDTLS_OID_AT_ORGANIZATION MBEDTLS_OID_AT "\x0A"
145 #define MBEDTLS_OID_AT_ORG_UNIT MBEDTLS_OID_AT "\x0B"
146 #define MBEDTLS_OID_AT_TITLE MBEDTLS_OID_AT "\x0C"
147 #define MBEDTLS_OID_AT_POSTAL_ADDRESS MBEDTLS_OID_AT "\x10"
148 #define MBEDTLS_OID_AT_POSTAL_CODE MBEDTLS_OID_AT "\x11"
149 #define MBEDTLS_OID_AT_GIVEN_NAME MBEDTLS_OID_AT "\x2A"
150 #define MBEDTLS_OID_AT_INITIALS MBEDTLS_OID_AT "\x2B"
151 #define MBEDTLS_OID_AT_GENERATION_QUALIFIER MBEDTLS_OID_AT "\x2C"
152 #define MBEDTLS_OID_AT_UNIQUE_IDENTIFIER MBEDTLS_OID_AT "\x2D"
153 #define MBEDTLS_OID_AT_DN_QUALIFIER MBEDTLS_OID_AT "\x2E"
154 #define MBEDTLS_OID_AT_PSEUDONYM MBEDTLS_OID_AT "\x41"
156 #define MBEDTLS_OID_DOMAIN_COMPONENT "\x09\x92\x26\x89\x93\xF2\x2C\x64\x01\x19"
158 /*
159  * OIDs for standard certificate extensions
160  */
161 #define MBEDTLS_OID_AUTHORITY_KEY_IDENTIFIER MBEDTLS_OID_ID_CE "\x23"
162 #define MBEDTLS_OID_SUBJECT_KEY_IDENTIFIER MBEDTLS_OID_ID_CE "\x0E"
163 #define MBEDTLS_OID_KEY_USAGE MBEDTLS_OID_ID_CE "\x0F"
164 #define MBEDTLS_OID_CERTIFICATE_POLICIES MBEDTLS_OID_ID_CE "\x20"
165 #define MBEDTLS_OID_POLICY_MAPPINGS MBEDTLS_OID_ID_CE "\x21"
166 #define MBEDTLS_OID_SUBJECT_ALT_NAME MBEDTLS_OID_ID_CE "\x11"
167 #define MBEDTLS_OID_ISSUER_ALT_NAME MBEDTLS_OID_ID_CE "\x12"
168 #define MBEDTLS_OID_SUBJECT_DIRECTORY_ATTRS MBEDTLS_OID_ID_CE "\x09"
169 #define MBEDTLS_OID_BASIC_CONSTRAINTS MBEDTLS_OID_ID_CE "\x13"
170 #define MBEDTLS_OID_NAME_CONSTRAINTS MBEDTLS_OID_ID_CE "\x1E"
171 #define MBEDTLS_OID_POLICY_CONSTRAINTS MBEDTLS_OID_ID_CE "\x24"
172 #define MBEDTLS_OID_EXTENDED_KEY_USAGE MBEDTLS_OID_ID_CE "\x25"
173 #define MBEDTLS_OID_CRL_DISTRIBUTION_POINTS MBEDTLS_OID_ID_CE "\x1F"
174 #define MBEDTLS_OID_INIHIBIT_ANYPOLICY MBEDTLS_OID_ID_CE "\x36"
175 #define MBEDTLS_OID_FRESHEST_CRL MBEDTLS_OID_ID_CE "\x2E"
177 /*
178  * Netscape certificate extensions
179  */
180 #define MBEDTLS_OID_NS_CERT MBEDTLS_OID_NETSCAPE "\x01"
181 #define MBEDTLS_OID_NS_CERT_TYPE MBEDTLS_OID_NS_CERT "\x01"
182 #define MBEDTLS_OID_NS_BASE_URL MBEDTLS_OID_NS_CERT "\x02"
183 #define MBEDTLS_OID_NS_REVOCATION_URL MBEDTLS_OID_NS_CERT "\x03"
184 #define MBEDTLS_OID_NS_CA_REVOCATION_URL MBEDTLS_OID_NS_CERT "\x04"
185 #define MBEDTLS_OID_NS_RENEWAL_URL MBEDTLS_OID_NS_CERT "\x07"
186 #define MBEDTLS_OID_NS_CA_POLICY_URL MBEDTLS_OID_NS_CERT "\x08"
187 #define MBEDTLS_OID_NS_SSL_SERVER_NAME MBEDTLS_OID_NS_CERT "\x0C"
188 #define MBEDTLS_OID_NS_COMMENT MBEDTLS_OID_NS_CERT "\x0D"
189 #define MBEDTLS_OID_NS_DATA_TYPE MBEDTLS_OID_NETSCAPE "\x02"
190 #define MBEDTLS_OID_NS_CERT_SEQUENCE MBEDTLS_OID_NS_DATA_TYPE "\x05"
191 
192 /*
193  * OIDs for CRL extensions
194  */
195 #define MBEDTLS_OID_PRIVATE_KEY_USAGE_PERIOD MBEDTLS_OID_ID_CE "\x10"
196 #define MBEDTLS_OID_CRL_NUMBER MBEDTLS_OID_ID_CE "\x14"
198 /*
199  * X.509 v3 Extended key usage OIDs
200  */
201 #define MBEDTLS_OID_ANY_EXTENDED_KEY_USAGE MBEDTLS_OID_EXTENDED_KEY_USAGE "\x00"
203 #define MBEDTLS_OID_KP MBEDTLS_OID_PKIX "\x03"
204 #define MBEDTLS_OID_SERVER_AUTH MBEDTLS_OID_KP "\x01"
205 #define MBEDTLS_OID_CLIENT_AUTH MBEDTLS_OID_KP "\x02"
206 #define MBEDTLS_OID_CODE_SIGNING MBEDTLS_OID_KP "\x03"
207 #define MBEDTLS_OID_EMAIL_PROTECTION MBEDTLS_OID_KP "\x04"
208 #define MBEDTLS_OID_TIME_STAMPING MBEDTLS_OID_KP "\x08"
209 #define MBEDTLS_OID_OCSP_SIGNING MBEDTLS_OID_KP "\x09"
211 /*
212  * PKCS definition OIDs
213  */
214 
215 #define MBEDTLS_OID_PKCS MBEDTLS_OID_RSA_COMPANY "\x01"
216 #define MBEDTLS_OID_PKCS1 MBEDTLS_OID_PKCS "\x01"
217 #define MBEDTLS_OID_PKCS5 MBEDTLS_OID_PKCS "\x05"
218 #define MBEDTLS_OID_PKCS9 MBEDTLS_OID_PKCS "\x09"
219 #define MBEDTLS_OID_PKCS12 MBEDTLS_OID_PKCS "\x0c"
221 /*
222  * PKCS#1 OIDs
223  */
224 #define MBEDTLS_OID_PKCS1_RSA MBEDTLS_OID_PKCS1 "\x01"
225 #define MBEDTLS_OID_PKCS1_MD2 MBEDTLS_OID_PKCS1 "\x02"
226 #define MBEDTLS_OID_PKCS1_MD4 MBEDTLS_OID_PKCS1 "\x03"
227 #define MBEDTLS_OID_PKCS1_MD5 MBEDTLS_OID_PKCS1 "\x04"
228 #define MBEDTLS_OID_PKCS1_SHA1 MBEDTLS_OID_PKCS1 "\x05"
229 #define MBEDTLS_OID_PKCS1_SHA224 MBEDTLS_OID_PKCS1 "\x0e"
230 #define MBEDTLS_OID_PKCS1_SHA256 MBEDTLS_OID_PKCS1 "\x0b"
231 #define MBEDTLS_OID_PKCS1_SHA384 MBEDTLS_OID_PKCS1 "\x0c"
232 #define MBEDTLS_OID_PKCS1_SHA512 MBEDTLS_OID_PKCS1 "\x0d"
234 #define MBEDTLS_OID_RSA_SHA_OBS "\x2B\x0E\x03\x02\x1D"
235 
236 #define MBEDTLS_OID_PKCS9_EMAIL MBEDTLS_OID_PKCS9 "\x01"
238 /* RFC 4055 */
239 #define MBEDTLS_OID_RSASSA_PSS MBEDTLS_OID_PKCS1 "\x0a"
240 #define MBEDTLS_OID_MGF1 MBEDTLS_OID_PKCS1 "\x08"
242 /*
243  * Digest algorithms
244  */
245 #define MBEDTLS_OID_DIGEST_ALG_MD2 MBEDTLS_OID_RSA_COMPANY "\x02\x02"
246 #define MBEDTLS_OID_DIGEST_ALG_MD4 MBEDTLS_OID_RSA_COMPANY "\x02\x04"
247 #define MBEDTLS_OID_DIGEST_ALG_MD5 MBEDTLS_OID_RSA_COMPANY "\x02\x05"
248 #define MBEDTLS_OID_DIGEST_ALG_SHA1 MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_OIW_SECSIG_SHA1
249 #define MBEDTLS_OID_DIGEST_ALG_SHA224 MBEDTLS_OID_NIST_ALG "\x02\x04"
250 #define MBEDTLS_OID_DIGEST_ALG_SHA256 MBEDTLS_OID_NIST_ALG "\x02\x01"
252 #define MBEDTLS_OID_DIGEST_ALG_SHA384 MBEDTLS_OID_NIST_ALG "\x02\x02"
254 #define MBEDTLS_OID_DIGEST_ALG_SHA512 MBEDTLS_OID_NIST_ALG "\x02\x03"
256 #define MBEDTLS_OID_HMAC_SHA1 MBEDTLS_OID_RSA_COMPANY "\x02\x07"
258 #define MBEDTLS_OID_HMAC_SHA224 MBEDTLS_OID_RSA_COMPANY "\x02\x08"
260 #define MBEDTLS_OID_HMAC_SHA256 MBEDTLS_OID_RSA_COMPANY "\x02\x09"
262 #define MBEDTLS_OID_HMAC_SHA384 MBEDTLS_OID_RSA_COMPANY "\x02\x0A"
264 #define MBEDTLS_OID_HMAC_SHA512 MBEDTLS_OID_RSA_COMPANY "\x02\x0B"
266 /*
267  * Encryption algorithms
268  */
269 #define MBEDTLS_OID_DES_CBC MBEDTLS_OID_ISO_IDENTIFIED_ORG MBEDTLS_OID_OIW_SECSIG_ALG "\x07"
270 #define MBEDTLS_OID_DES_EDE3_CBC MBEDTLS_OID_RSA_COMPANY "\x03\x07"
271 #define MBEDTLS_OID_AES MBEDTLS_OID_NIST_ALG "\x01"
273 /*
274  * Key Wrapping algorithms
275  */
276 /*
277  * RFC 5649
278  */
279 #define MBEDTLS_OID_AES128_KW MBEDTLS_OID_AES "\x05"
280 #define MBEDTLS_OID_AES128_KWP MBEDTLS_OID_AES "\x08"
281 #define MBEDTLS_OID_AES192_KW MBEDTLS_OID_AES "\x19"
282 #define MBEDTLS_OID_AES192_KWP MBEDTLS_OID_AES "\x1c"
283 #define MBEDTLS_OID_AES256_KW MBEDTLS_OID_AES "\x2d"
284 #define MBEDTLS_OID_AES256_KWP MBEDTLS_OID_AES "\x30"
285 /*
286  * PKCS#5 OIDs
287  */
288 #define MBEDTLS_OID_PKCS5_PBKDF2 MBEDTLS_OID_PKCS5 "\x0c"
289 #define MBEDTLS_OID_PKCS5_PBES2 MBEDTLS_OID_PKCS5 "\x0d"
290 #define MBEDTLS_OID_PKCS5_PBMAC1 MBEDTLS_OID_PKCS5 "\x0e"
292 /*
293  * PKCS#5 PBES1 algorithms
294  */
295 #define MBEDTLS_OID_PKCS5_PBE_MD2_DES_CBC MBEDTLS_OID_PKCS5 "\x01"
296 #define MBEDTLS_OID_PKCS5_PBE_MD2_RC2_CBC MBEDTLS_OID_PKCS5 "\x04"
297 #define MBEDTLS_OID_PKCS5_PBE_MD5_DES_CBC MBEDTLS_OID_PKCS5 "\x03"
298 #define MBEDTLS_OID_PKCS5_PBE_MD5_RC2_CBC MBEDTLS_OID_PKCS5 "\x06"
299 #define MBEDTLS_OID_PKCS5_PBE_SHA1_DES_CBC MBEDTLS_OID_PKCS5 "\x0a"
300 #define MBEDTLS_OID_PKCS5_PBE_SHA1_RC2_CBC MBEDTLS_OID_PKCS5 "\x0b"
302 /*
303  * PKCS#8 OIDs
304  */
305 #define MBEDTLS_OID_PKCS9_CSR_EXT_REQ MBEDTLS_OID_PKCS9 "\x0e"
307 /*
308  * PKCS#12 PBE OIDs
309  */
310 #define MBEDTLS_OID_PKCS12_PBE MBEDTLS_OID_PKCS12 "\x01"
312 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC4_128 MBEDTLS_OID_PKCS12_PBE "\x01"
313 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC4_40 MBEDTLS_OID_PKCS12_PBE "\x02"
314 #define MBEDTLS_OID_PKCS12_PBE_SHA1_DES3_EDE_CBC MBEDTLS_OID_PKCS12_PBE "\x03"
315 #define MBEDTLS_OID_PKCS12_PBE_SHA1_DES2_EDE_CBC MBEDTLS_OID_PKCS12_PBE "\x04"
316 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC2_128_CBC MBEDTLS_OID_PKCS12_PBE "\x05"
317 #define MBEDTLS_OID_PKCS12_PBE_SHA1_RC2_40_CBC MBEDTLS_OID_PKCS12_PBE "\x06"
319 /*
320  * EC key algorithms from RFC 5480
321  */
322 
323 /* id-ecPublicKey OBJECT IDENTIFIER ::= {
324  * iso(1) member-body(2) us(840) ansi-X9-62(10045) keyType(2) 1 } */
325 #define MBEDTLS_OID_EC_ALG_UNRESTRICTED MBEDTLS_OID_ANSI_X9_62 "\x02\01"
326 
327 /* id-ecDH OBJECT IDENTIFIER ::= {
328  * iso(1) identified-organization(3) certicom(132)
329  * schemes(1) ecdh(12) } */
330 #define MBEDTLS_OID_EC_ALG_ECDH MBEDTLS_OID_CERTICOM "\x01\x0c"
331 
332 /*
333  * ECParameters namedCurve identifiers, from RFC 5480, RFC 5639, and SEC2
334  */
335 
336 /* secp192r1 OBJECT IDENTIFIER ::= {
337  * iso(1) member-body(2) us(840) ansi-X9-62(10045) curves(3) prime(1) 1 } */
338 #define MBEDTLS_OID_EC_GRP_SECP192R1 MBEDTLS_OID_ANSI_X9_62 "\x03\x01\x01"
339 
340 /* secp224r1 OBJECT IDENTIFIER ::= {
341  * iso(1) identified-organization(3) certicom(132) curve(0) 33 } */
342 #define MBEDTLS_OID_EC_GRP_SECP224R1 MBEDTLS_OID_CERTICOM "\x00\x21"
343 
344 /* secp256r1 OBJECT IDENTIFIER ::= {
345  * iso(1) member-body(2) us(840) ansi-X9-62(10045) curves(3) prime(1) 7 } */
346 #define MBEDTLS_OID_EC_GRP_SECP256R1 MBEDTLS_OID_ANSI_X9_62 "\x03\x01\x07"
347 
348 /* secp384r1 OBJECT IDENTIFIER ::= {
349  * iso(1) identified-organization(3) certicom(132) curve(0) 34 } */
350 #define MBEDTLS_OID_EC_GRP_SECP384R1 MBEDTLS_OID_CERTICOM "\x00\x22"
351 
352 /* secp521r1 OBJECT IDENTIFIER ::= {
353  * iso(1) identified-organization(3) certicom(132) curve(0) 35 } */
354 #define MBEDTLS_OID_EC_GRP_SECP521R1 MBEDTLS_OID_CERTICOM "\x00\x23"
355 
356 /* secp192k1 OBJECT IDENTIFIER ::= {
357  * iso(1) identified-organization(3) certicom(132) curve(0) 31 } */
358 #define MBEDTLS_OID_EC_GRP_SECP192K1 MBEDTLS_OID_CERTICOM "\x00\x1f"
359 
360 /* secp224k1 OBJECT IDENTIFIER ::= {
361  * iso(1) identified-organization(3) certicom(132) curve(0) 32 } */
362 #define MBEDTLS_OID_EC_GRP_SECP224K1 MBEDTLS_OID_CERTICOM "\x00\x20"
363 
364 /* secp256k1 OBJECT IDENTIFIER ::= {
365  * iso(1) identified-organization(3) certicom(132) curve(0) 10 } */
366 #define MBEDTLS_OID_EC_GRP_SECP256K1 MBEDTLS_OID_CERTICOM "\x00\x0a"
367 
368 /* RFC 5639 4.1
369  * ecStdCurvesAndGeneration OBJECT IDENTIFIER::= {iso(1)
370  * identified-organization(3) teletrust(36) algorithm(3) signature-
371  * algorithm(3) ecSign(2) 8}
372  * ellipticCurve OBJECT IDENTIFIER ::= {ecStdCurvesAndGeneration 1}
373  * versionOne OBJECT IDENTIFIER ::= {ellipticCurve 1} */
374 #define MBEDTLS_OID_EC_BRAINPOOL_V1 MBEDTLS_OID_TELETRUST "\x03\x03\x02\x08\x01\x01"
375 
376 /* brainpoolP256r1 OBJECT IDENTIFIER ::= {versionOne 7} */
377 #define MBEDTLS_OID_EC_GRP_BP256R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x07"
378 
379 /* brainpoolP384r1 OBJECT IDENTIFIER ::= {versionOne 11} */
380 #define MBEDTLS_OID_EC_GRP_BP384R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x0B"
381 
382 /* brainpoolP512r1 OBJECT IDENTIFIER ::= {versionOne 13} */
383 #define MBEDTLS_OID_EC_GRP_BP512R1 MBEDTLS_OID_EC_BRAINPOOL_V1 "\x0D"
384 
385 /*
386  * SEC1 C.1
387  *
388  * prime-field OBJECT IDENTIFIER ::= { id-fieldType 1 }
389  * id-fieldType OBJECT IDENTIFIER ::= { ansi-X9-62 fieldType(1)}
390  */
391 #define MBEDTLS_OID_ANSI_X9_62_FIELD_TYPE MBEDTLS_OID_ANSI_X9_62 "\x01"
392 #define MBEDTLS_OID_ANSI_X9_62_PRIME_FIELD MBEDTLS_OID_ANSI_X9_62_FIELD_TYPE "\x01"
393 
394 /*
395  * ECDSA signature identifiers, from RFC 5480
396  */
397 #define MBEDTLS_OID_ANSI_X9_62_SIG MBEDTLS_OID_ANSI_X9_62 "\x04" /* signatures(4) */
398 #define MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 MBEDTLS_OID_ANSI_X9_62_SIG "\x03" /* ecdsa-with-SHA2(3) */
399 
400 /* ecdsa-with-SHA1 OBJECT IDENTIFIER ::= {
401  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4) 1 } */
402 #define MBEDTLS_OID_ECDSA_SHA1 MBEDTLS_OID_ANSI_X9_62_SIG "\x01"
403 
404 /* ecdsa-with-SHA224 OBJECT IDENTIFIER ::= {
405  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
406  * ecdsa-with-SHA2(3) 1 } */
407 #define MBEDTLS_OID_ECDSA_SHA224 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x01"
408 
409 /* ecdsa-with-SHA256 OBJECT IDENTIFIER ::= {
410  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
411  * ecdsa-with-SHA2(3) 2 } */
412 #define MBEDTLS_OID_ECDSA_SHA256 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x02"
413 
414 /* ecdsa-with-SHA384 OBJECT IDENTIFIER ::= {
415  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
416  * ecdsa-with-SHA2(3) 3 } */
417 #define MBEDTLS_OID_ECDSA_SHA384 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x03"
418 
419 /* ecdsa-with-SHA512 OBJECT IDENTIFIER ::= {
420  * iso(1) member-body(2) us(840) ansi-X9-62(10045) signatures(4)
421  * ecdsa-with-SHA2(3) 4 } */
422 #define MBEDTLS_OID_ECDSA_SHA512 MBEDTLS_OID_ANSI_X9_62_SIG_SHA2 "\x04"
423 
424 #ifdef __cplusplus
425 extern "C" {
426 #endif
427 
432 {
433  const char *asn1;
434  size_t asn1_len;
435  const char *name;
436  const char *description;
438 
450 int mbedtls_oid_get_numeric_string( char *buf, size_t size, const mbedtls_asn1_buf *oid );
451 
452 #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C)
453 
461 int mbedtls_oid_get_x509_ext_type( const mbedtls_asn1_buf *oid, int *ext_type );
462 #endif
463 
473 int mbedtls_oid_get_attr_short_name( const mbedtls_asn1_buf *oid, const char **short_name );
474 
484 
495  const char **oid, size_t *olen );
496 
497 #if defined(MBEDTLS_ECP_C)
498 
507 
518  const char **oid, size_t *olen );
519 #endif /* MBEDTLS_ECP_C */
520 
521 #if defined(MBEDTLS_MD_C)
522 
532  mbedtls_md_type_t *md_alg, mbedtls_pk_type_t *pk_alg );
533 
542 int mbedtls_oid_get_sig_alg_desc( const mbedtls_asn1_buf *oid, const char **desc );
543 
555  const char **oid, size_t *olen );
556 
566 
576 #endif /* MBEDTLS_MD_C */
577 
586 int mbedtls_oid_get_extended_key_usage( const mbedtls_asn1_buf *oid, const char **desc );
587 
597 int mbedtls_oid_get_oid_by_md( mbedtls_md_type_t md_alg, const char **oid, size_t *olen );
598 
599 #if defined(MBEDTLS_CIPHER_C)
600 
609 #endif /* MBEDTLS_CIPHER_C */
610 
611 #if defined(MBEDTLS_PKCS12_C)
612 
623  mbedtls_cipher_type_t *cipher_alg );
624 #endif /* MBEDTLS_PKCS12_C */
625 
626 #ifdef __cplusplus
627 }
628 #endif
629 
630 #endif /* oid.h */
mbedtls_md_type_t
mbedtls_md_type_t
Supported message digests.
Definition: md.h:83
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:434
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:432
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:103
mbedtls_oid_descriptor_t::description
const char * description
Definition: oid.h:436
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:103
mbedtls_oid_descriptor_t::asn1
const char * asn1
Definition: oid.h:433
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:435
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:2051
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:160
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:129
asn1.h
Generic ASN.1 parsing.
x509.h
X.509 generic defines and structures.