source: EcnlProtoTool/trunk/openssl-1.1.0e/include/openssl/objects.h@ 331

Last change on this file since 331 was 331, checked in by coas-nagasima, 6 years ago

prototoolに関連するプロジェクトをnewlibからmuslを使うよう変更・更新
ntshellをnewlibの下位の実装から、muslのsyscallの実装に変更・更新
以下のOSSをアップデート
・mruby-1.3.0
・musl-1.1.18
・onigmo-6.1.3
・tcc-0.9.27
以下のOSSを追加
・openssl-1.1.0e
・curl-7.57.0
・zlib-1.2.11
以下のmrbgemsを追加
・iij/mruby-digest
・iij/mruby-env
・iij/mruby-errno
・iij/mruby-iijson
・iij/mruby-ipaddr
・iij/mruby-mock
・iij/mruby-require
・iij/mruby-tls-openssl

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-chdr
File size: 43.8 KB
Line 
1/*
2 * Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved.
3 *
4 * Licensed under the OpenSSL license (the "License"). You may not use
5 * this file except in compliance with the License. You can obtain a copy
6 * in the file LICENSE in the source distribution or at
7 * https://www.openssl.org/source/license.html
8 */
9
10#ifndef HEADER_OBJECTS_H
11# define HEADER_OBJECTS_H
12
13# define USE_OBJ_MAC
14
15# ifdef USE_OBJ_MAC
16# include <openssl/obj_mac.h>
17# else
18# define SN_undef "UNDEF"
19# define LN_undef "undefined"
20# define NID_undef 0
21# define OBJ_undef 0L
22
23# define SN_Algorithm "Algorithm"
24# define LN_algorithm "algorithm"
25# define NID_algorithm 38
26# define OBJ_algorithm 1L,3L,14L,3L,2L
27
28# define LN_rsadsi "rsadsi"
29# define NID_rsadsi 1
30# define OBJ_rsadsi 1L,2L,840L,113549L
31
32# define LN_pkcs "pkcs"
33# define NID_pkcs 2
34# define OBJ_pkcs OBJ_rsadsi,1L
35
36# define SN_md2 "MD2"
37# define LN_md2 "md2"
38# define NID_md2 3
39# define OBJ_md2 OBJ_rsadsi,2L,2L
40
41# define SN_md5 "MD5"
42# define LN_md5 "md5"
43# define NID_md5 4
44# define OBJ_md5 OBJ_rsadsi,2L,5L
45
46# define SN_rc4 "RC4"
47# define LN_rc4 "rc4"
48# define NID_rc4 5
49# define OBJ_rc4 OBJ_rsadsi,3L,4L
50
51# define LN_rsaEncryption "rsaEncryption"
52# define NID_rsaEncryption 6
53# define OBJ_rsaEncryption OBJ_pkcs,1L,1L
54
55# define SN_md2WithRSAEncryption "RSA-MD2"
56# define LN_md2WithRSAEncryption "md2WithRSAEncryption"
57# define NID_md2WithRSAEncryption 7
58# define OBJ_md2WithRSAEncryption OBJ_pkcs,1L,2L
59
60# define SN_md5WithRSAEncryption "RSA-MD5"
61# define LN_md5WithRSAEncryption "md5WithRSAEncryption"
62# define NID_md5WithRSAEncryption 8
63# define OBJ_md5WithRSAEncryption OBJ_pkcs,1L,4L
64
65# define SN_pbeWithMD2AndDES_CBC "PBE-MD2-DES"
66# define LN_pbeWithMD2AndDES_CBC "pbeWithMD2AndDES-CBC"
67# define NID_pbeWithMD2AndDES_CBC 9
68# define OBJ_pbeWithMD2AndDES_CBC OBJ_pkcs,5L,1L
69
70# define SN_pbeWithMD5AndDES_CBC "PBE-MD5-DES"
71# define LN_pbeWithMD5AndDES_CBC "pbeWithMD5AndDES-CBC"
72# define NID_pbeWithMD5AndDES_CBC 10
73# define OBJ_pbeWithMD5AndDES_CBC OBJ_pkcs,5L,3L
74
75# define LN_X500 "X500"
76# define NID_X500 11
77# define OBJ_X500 2L,5L
78
79# define LN_X509 "X509"
80# define NID_X509 12
81# define OBJ_X509 OBJ_X500,4L
82
83# define SN_commonName "CN"
84# define LN_commonName "commonName"
85# define NID_commonName 13
86# define OBJ_commonName OBJ_X509,3L
87
88# define SN_countryName "C"
89# define LN_countryName "countryName"
90# define NID_countryName 14
91# define OBJ_countryName OBJ_X509,6L
92
93# define SN_localityName "L"
94# define LN_localityName "localityName"
95# define NID_localityName 15
96# define OBJ_localityName OBJ_X509,7L
97
98/* Postal Address? PA */
99
100/* should be "ST" (rfc1327) but MS uses 'S' */
101# define SN_stateOrProvinceName "ST"
102# define LN_stateOrProvinceName "stateOrProvinceName"
103# define NID_stateOrProvinceName 16
104# define OBJ_stateOrProvinceName OBJ_X509,8L
105
106# define SN_organizationName "O"
107# define LN_organizationName "organizationName"
108# define NID_organizationName 17
109# define OBJ_organizationName OBJ_X509,10L
110
111# define SN_organizationalUnitName "OU"
112# define LN_organizationalUnitName "organizationalUnitName"
113# define NID_organizationalUnitName 18
114# define OBJ_organizationalUnitName OBJ_X509,11L
115
116# define SN_rsa "RSA"
117# define LN_rsa "rsa"
118# define NID_rsa 19
119# define OBJ_rsa OBJ_X500,8L,1L,1L
120
121# define LN_pkcs7 "pkcs7"
122# define NID_pkcs7 20
123# define OBJ_pkcs7 OBJ_pkcs,7L
124
125# define LN_pkcs7_data "pkcs7-data"
126# define NID_pkcs7_data 21
127# define OBJ_pkcs7_data OBJ_pkcs7,1L
128
129# define LN_pkcs7_signed "pkcs7-signedData"
130# define NID_pkcs7_signed 22
131# define OBJ_pkcs7_signed OBJ_pkcs7,2L
132
133# define LN_pkcs7_enveloped "pkcs7-envelopedData"
134# define NID_pkcs7_enveloped 23
135# define OBJ_pkcs7_enveloped OBJ_pkcs7,3L
136
137# define LN_pkcs7_signedAndEnveloped "pkcs7-signedAndEnvelopedData"
138# define NID_pkcs7_signedAndEnveloped 24
139# define OBJ_pkcs7_signedAndEnveloped OBJ_pkcs7,4L
140
141# define LN_pkcs7_digest "pkcs7-digestData"
142# define NID_pkcs7_digest 25
143# define OBJ_pkcs7_digest OBJ_pkcs7,5L
144
145# define LN_pkcs7_encrypted "pkcs7-encryptedData"
146# define NID_pkcs7_encrypted 26
147# define OBJ_pkcs7_encrypted OBJ_pkcs7,6L
148
149# define LN_pkcs3 "pkcs3"
150# define NID_pkcs3 27
151# define OBJ_pkcs3 OBJ_pkcs,3L
152
153# define LN_dhKeyAgreement "dhKeyAgreement"
154# define NID_dhKeyAgreement 28
155# define OBJ_dhKeyAgreement OBJ_pkcs3,1L
156
157# define SN_des_ecb "DES-ECB"
158# define LN_des_ecb "des-ecb"
159# define NID_des_ecb 29
160# define OBJ_des_ecb OBJ_algorithm,6L
161
162# define SN_des_cfb64 "DES-CFB"
163# define LN_des_cfb64 "des-cfb"
164# define NID_des_cfb64 30
165/* IV + num */
166# define OBJ_des_cfb64 OBJ_algorithm,9L
167
168# define SN_des_cbc "DES-CBC"
169# define LN_des_cbc "des-cbc"
170# define NID_des_cbc 31
171/* IV */
172# define OBJ_des_cbc OBJ_algorithm,7L
173
174# define SN_des_ede "DES-EDE"
175# define LN_des_ede "des-ede"
176# define NID_des_ede 32
177/* ?? */
178# define OBJ_des_ede OBJ_algorithm,17L
179
180# define SN_des_ede3 "DES-EDE3"
181# define LN_des_ede3 "des-ede3"
182# define NID_des_ede3 33
183
184# define SN_idea_cbc "IDEA-CBC"
185# define LN_idea_cbc "idea-cbc"
186# define NID_idea_cbc 34
187# define OBJ_idea_cbc 1L,3L,6L,1L,4L,1L,188L,7L,1L,1L,2L
188
189# define SN_idea_cfb64 "IDEA-CFB"
190# define LN_idea_cfb64 "idea-cfb"
191# define NID_idea_cfb64 35
192
193# define SN_idea_ecb "IDEA-ECB"
194# define LN_idea_ecb "idea-ecb"
195# define NID_idea_ecb 36
196
197# define SN_rc2_cbc "RC2-CBC"
198# define LN_rc2_cbc "rc2-cbc"
199# define NID_rc2_cbc 37
200# define OBJ_rc2_cbc OBJ_rsadsi,3L,2L
201
202# define SN_rc2_ecb "RC2-ECB"
203# define LN_rc2_ecb "rc2-ecb"
204# define NID_rc2_ecb 38
205
206# define SN_rc2_cfb64 "RC2-CFB"
207# define LN_rc2_cfb64 "rc2-cfb"
208# define NID_rc2_cfb64 39
209
210# define SN_rc2_ofb64 "RC2-OFB"
211# define LN_rc2_ofb64 "rc2-ofb"
212# define NID_rc2_ofb64 40
213
214# define SN_sha "SHA"
215# define LN_sha "sha"
216# define NID_sha 41
217# define OBJ_sha OBJ_algorithm,18L
218
219# define SN_shaWithRSAEncryption "RSA-SHA"
220# define LN_shaWithRSAEncryption "shaWithRSAEncryption"
221# define NID_shaWithRSAEncryption 42
222# define OBJ_shaWithRSAEncryption OBJ_algorithm,15L
223
224# define SN_des_ede_cbc "DES-EDE-CBC"
225# define LN_des_ede_cbc "des-ede-cbc"
226# define NID_des_ede_cbc 43
227
228# define SN_des_ede3_cbc "DES-EDE3-CBC"
229# define LN_des_ede3_cbc "des-ede3-cbc"
230# define NID_des_ede3_cbc 44
231# define OBJ_des_ede3_cbc OBJ_rsadsi,3L,7L
232
233# define SN_des_ofb64 "DES-OFB"
234# define LN_des_ofb64 "des-ofb"
235# define NID_des_ofb64 45
236# define OBJ_des_ofb64 OBJ_algorithm,8L
237
238# define SN_idea_ofb64 "IDEA-OFB"
239# define LN_idea_ofb64 "idea-ofb"
240# define NID_idea_ofb64 46
241
242# define LN_pkcs9 "pkcs9"
243# define NID_pkcs9 47
244# define OBJ_pkcs9 OBJ_pkcs,9L
245
246# define SN_pkcs9_emailAddress "Email"
247# define LN_pkcs9_emailAddress "emailAddress"
248# define NID_pkcs9_emailAddress 48
249# define OBJ_pkcs9_emailAddress OBJ_pkcs9,1L
250
251# define LN_pkcs9_unstructuredName "unstructuredName"
252# define NID_pkcs9_unstructuredName 49
253# define OBJ_pkcs9_unstructuredName OBJ_pkcs9,2L
254
255# define LN_pkcs9_contentType "contentType"
256# define NID_pkcs9_contentType 50
257# define OBJ_pkcs9_contentType OBJ_pkcs9,3L
258
259# define LN_pkcs9_messageDigest "messageDigest"
260# define NID_pkcs9_messageDigest 51
261# define OBJ_pkcs9_messageDigest OBJ_pkcs9,4L
262
263# define LN_pkcs9_signingTime "signingTime"
264# define NID_pkcs9_signingTime 52
265# define OBJ_pkcs9_signingTime OBJ_pkcs9,5L
266
267# define LN_pkcs9_countersignature "countersignature"
268# define NID_pkcs9_countersignature 53
269# define OBJ_pkcs9_countersignature OBJ_pkcs9,6L
270
271# define LN_pkcs9_challengePassword "challengePassword"
272# define NID_pkcs9_challengePassword 54
273# define OBJ_pkcs9_challengePassword OBJ_pkcs9,7L
274
275# define LN_pkcs9_unstructuredAddress "unstructuredAddress"
276# define NID_pkcs9_unstructuredAddress 55
277# define OBJ_pkcs9_unstructuredAddress OBJ_pkcs9,8L
278
279# define LN_pkcs9_extCertAttributes "extendedCertificateAttributes"
280# define NID_pkcs9_extCertAttributes 56
281# define OBJ_pkcs9_extCertAttributes OBJ_pkcs9,9L
282
283# define SN_netscape "Netscape"
284# define LN_netscape "Netscape Communications Corp."
285# define NID_netscape 57
286# define OBJ_netscape 2L,16L,840L,1L,113730L
287
288# define SN_netscape_cert_extension "nsCertExt"
289# define LN_netscape_cert_extension "Netscape Certificate Extension"
290# define NID_netscape_cert_extension 58
291# define OBJ_netscape_cert_extension OBJ_netscape,1L
292
293# define SN_netscape_data_type "nsDataType"
294# define LN_netscape_data_type "Netscape Data Type"
295# define NID_netscape_data_type 59
296# define OBJ_netscape_data_type OBJ_netscape,2L
297
298# define SN_des_ede_cfb64 "DES-EDE-CFB"
299# define LN_des_ede_cfb64 "des-ede-cfb"
300# define NID_des_ede_cfb64 60
301
302# define SN_des_ede3_cfb64 "DES-EDE3-CFB"
303# define LN_des_ede3_cfb64 "des-ede3-cfb"
304# define NID_des_ede3_cfb64 61
305
306# define SN_des_ede_ofb64 "DES-EDE-OFB"
307# define LN_des_ede_ofb64 "des-ede-ofb"
308# define NID_des_ede_ofb64 62
309
310# define SN_des_ede3_ofb64 "DES-EDE3-OFB"
311# define LN_des_ede3_ofb64 "des-ede3-ofb"
312# define NID_des_ede3_ofb64 63
313
314/* I'm not sure about the object ID */
315# define SN_sha1 "SHA1"
316# define LN_sha1 "sha1"
317# define NID_sha1 64
318# define OBJ_sha1 OBJ_algorithm,26L
319/* 28 Jun 1996 - eay */
320/* #define OBJ_sha1 1L,3L,14L,2L,26L,05L <- wrong */
321
322# define SN_sha1WithRSAEncryption "RSA-SHA1"
323# define LN_sha1WithRSAEncryption "sha1WithRSAEncryption"
324# define NID_sha1WithRSAEncryption 65
325# define OBJ_sha1WithRSAEncryption OBJ_pkcs,1L,5L
326
327# define SN_dsaWithSHA "DSA-SHA"
328# define LN_dsaWithSHA "dsaWithSHA"
329# define NID_dsaWithSHA 66
330# define OBJ_dsaWithSHA OBJ_algorithm,13L
331
332# define SN_dsa_2 "DSA-old"
333# define LN_dsa_2 "dsaEncryption-old"
334# define NID_dsa_2 67
335# define OBJ_dsa_2 OBJ_algorithm,12L
336
337/* proposed by microsoft to RSA */
338# define SN_pbeWithSHA1AndRC2_CBC "PBE-SHA1-RC2-64"
339# define LN_pbeWithSHA1AndRC2_CBC "pbeWithSHA1AndRC2-CBC"
340# define NID_pbeWithSHA1AndRC2_CBC 68
341# define OBJ_pbeWithSHA1AndRC2_CBC OBJ_pkcs,5L,11L
342
343/*
344 * proposed by microsoft to RSA as pbeWithSHA1AndRC4: it is now defined
345 * explicitly in PKCS#5 v2.0 as id-PBKDF2 which is something completely
346 * different.
347 */
348# define LN_id_pbkdf2 "PBKDF2"
349# define NID_id_pbkdf2 69
350# define OBJ_id_pbkdf2 OBJ_pkcs,5L,12L
351
352# define SN_dsaWithSHA1_2 "DSA-SHA1-old"
353# define LN_dsaWithSHA1_2 "dsaWithSHA1-old"
354# define NID_dsaWithSHA1_2 70
355/* Got this one from 'sdn706r20.pdf' which is actually an NSA document :-) */
356# define OBJ_dsaWithSHA1_2 OBJ_algorithm,27L
357
358# define SN_netscape_cert_type "nsCertType"
359# define LN_netscape_cert_type "Netscape Cert Type"
360# define NID_netscape_cert_type 71
361# define OBJ_netscape_cert_type OBJ_netscape_cert_extension,1L
362
363# define SN_netscape_base_url "nsBaseUrl"
364# define LN_netscape_base_url "Netscape Base Url"
365# define NID_netscape_base_url 72
366# define OBJ_netscape_base_url OBJ_netscape_cert_extension,2L
367
368# define SN_netscape_revocation_url "nsRevocationUrl"
369# define LN_netscape_revocation_url "Netscape Revocation Url"
370# define NID_netscape_revocation_url 73
371# define OBJ_netscape_revocation_url OBJ_netscape_cert_extension,3L
372
373# define SN_netscape_ca_revocation_url "nsCaRevocationUrl"
374# define LN_netscape_ca_revocation_url "Netscape CA Revocation Url"
375# define NID_netscape_ca_revocation_url 74
376# define OBJ_netscape_ca_revocation_url OBJ_netscape_cert_extension,4L
377
378# define SN_netscape_renewal_url "nsRenewalUrl"
379# define LN_netscape_renewal_url "Netscape Renewal Url"
380# define NID_netscape_renewal_url 75
381# define OBJ_netscape_renewal_url OBJ_netscape_cert_extension,7L
382
383# define SN_netscape_ca_policy_url "nsCaPolicyUrl"
384# define LN_netscape_ca_policy_url "Netscape CA Policy Url"
385# define NID_netscape_ca_policy_url 76
386# define OBJ_netscape_ca_policy_url OBJ_netscape_cert_extension,8L
387
388# define SN_netscape_ssl_server_name "nsSslServerName"
389# define LN_netscape_ssl_server_name "Netscape SSL Server Name"
390# define NID_netscape_ssl_server_name 77
391# define OBJ_netscape_ssl_server_name OBJ_netscape_cert_extension,12L
392
393# define SN_netscape_comment "nsComment"
394# define LN_netscape_comment "Netscape Comment"
395# define NID_netscape_comment 78
396# define OBJ_netscape_comment OBJ_netscape_cert_extension,13L
397
398# define SN_netscape_cert_sequence "nsCertSequence"
399# define LN_netscape_cert_sequence "Netscape Certificate Sequence"
400# define NID_netscape_cert_sequence 79
401# define OBJ_netscape_cert_sequence OBJ_netscape_data_type,5L
402
403# define SN_desx_cbc "DESX-CBC"
404# define LN_desx_cbc "desx-cbc"
405# define NID_desx_cbc 80
406
407# define SN_id_ce "id-ce"
408# define NID_id_ce 81
409# define OBJ_id_ce 2L,5L,29L
410
411# define SN_subject_key_identifier "subjectKeyIdentifier"
412# define LN_subject_key_identifier "X509v3 Subject Key Identifier"
413# define NID_subject_key_identifier 82
414# define OBJ_subject_key_identifier OBJ_id_ce,14L
415
416# define SN_key_usage "keyUsage"
417# define LN_key_usage "X509v3 Key Usage"
418# define NID_key_usage 83
419# define OBJ_key_usage OBJ_id_ce,15L
420
421# define SN_private_key_usage_period "privateKeyUsagePeriod"
422# define LN_private_key_usage_period "X509v3 Private Key Usage Period"
423# define NID_private_key_usage_period 84
424# define OBJ_private_key_usage_period OBJ_id_ce,16L
425
426# define SN_subject_alt_name "subjectAltName"
427# define LN_subject_alt_name "X509v3 Subject Alternative Name"
428# define NID_subject_alt_name 85
429# define OBJ_subject_alt_name OBJ_id_ce,17L
430
431# define SN_issuer_alt_name "issuerAltName"
432# define LN_issuer_alt_name "X509v3 Issuer Alternative Name"
433# define NID_issuer_alt_name 86
434# define OBJ_issuer_alt_name OBJ_id_ce,18L
435
436# define SN_basic_constraints "basicConstraints"
437# define LN_basic_constraints "X509v3 Basic Constraints"
438# define NID_basic_constraints 87
439# define OBJ_basic_constraints OBJ_id_ce,19L
440
441# define SN_crl_number "crlNumber"
442# define LN_crl_number "X509v3 CRL Number"
443# define NID_crl_number 88
444# define OBJ_crl_number OBJ_id_ce,20L
445
446# define SN_certificate_policies "certificatePolicies"
447# define LN_certificate_policies "X509v3 Certificate Policies"
448# define NID_certificate_policies 89
449# define OBJ_certificate_policies OBJ_id_ce,32L
450
451# define SN_authority_key_identifier "authorityKeyIdentifier"
452# define LN_authority_key_identifier "X509v3 Authority Key Identifier"
453# define NID_authority_key_identifier 90
454# define OBJ_authority_key_identifier OBJ_id_ce,35L
455
456# define SN_bf_cbc "BF-CBC"
457# define LN_bf_cbc "bf-cbc"
458# define NID_bf_cbc 91
459# define OBJ_bf_cbc 1L,3L,6L,1L,4L,1L,3029L,1L,2L
460
461# define SN_bf_ecb "BF-ECB"
462# define LN_bf_ecb "bf-ecb"
463# define NID_bf_ecb 92
464
465# define SN_bf_cfb64 "BF-CFB"
466# define LN_bf_cfb64 "bf-cfb"
467# define NID_bf_cfb64 93
468
469# define SN_bf_ofb64 "BF-OFB"
470# define LN_bf_ofb64 "bf-ofb"
471# define NID_bf_ofb64 94
472
473# define SN_mdc2 "MDC2"
474# define LN_mdc2 "mdc2"
475# define NID_mdc2 95
476# define OBJ_mdc2 2L,5L,8L,3L,101L
477/* An alternative? 1L,3L,14L,3L,2L,19L */
478
479# define SN_mdc2WithRSA "RSA-MDC2"
480# define LN_mdc2WithRSA "mdc2withRSA"
481# define NID_mdc2WithRSA 96
482# define OBJ_mdc2WithRSA 2L,5L,8L,3L,100L
483
484# define SN_rc4_40 "RC4-40"
485# define LN_rc4_40 "rc4-40"
486# define NID_rc4_40 97
487
488# define SN_rc2_40_cbc "RC2-40-CBC"
489# define LN_rc2_40_cbc "rc2-40-cbc"
490# define NID_rc2_40_cbc 98
491
492# define SN_givenName "G"
493# define LN_givenName "givenName"
494# define NID_givenName 99
495# define OBJ_givenName OBJ_X509,42L
496
497# define SN_surname "S"
498# define LN_surname "surname"
499# define NID_surname 100
500# define OBJ_surname OBJ_X509,4L
501
502# define SN_initials "I"
503# define LN_initials "initials"
504# define NID_initials 101
505# define OBJ_initials OBJ_X509,43L
506
507# define SN_uniqueIdentifier "UID"
508# define LN_uniqueIdentifier "uniqueIdentifier"
509# define NID_uniqueIdentifier 102
510# define OBJ_uniqueIdentifier OBJ_X509,45L
511
512# define SN_crl_distribution_points "crlDistributionPoints"
513# define LN_crl_distribution_points "X509v3 CRL Distribution Points"
514# define NID_crl_distribution_points 103
515# define OBJ_crl_distribution_points OBJ_id_ce,31L
516
517# define SN_md5WithRSA "RSA-NP-MD5"
518# define LN_md5WithRSA "md5WithRSA"
519# define NID_md5WithRSA 104
520# define OBJ_md5WithRSA OBJ_algorithm,3L
521
522# define SN_serialNumber "SN"
523# define LN_serialNumber "serialNumber"
524# define NID_serialNumber 105
525# define OBJ_serialNumber OBJ_X509,5L
526
527# define SN_title "T"
528# define LN_title "title"
529# define NID_title 106
530# define OBJ_title OBJ_X509,12L
531
532# define SN_description "D"
533# define LN_description "description"
534# define NID_description 107
535# define OBJ_description OBJ_X509,13L
536
537/* CAST5 is CAST-128, I'm just sticking with the documentation */
538# define SN_cast5_cbc "CAST5-CBC"
539# define LN_cast5_cbc "cast5-cbc"
540# define NID_cast5_cbc 108
541# define OBJ_cast5_cbc 1L,2L,840L,113533L,7L,66L,10L
542
543# define SN_cast5_ecb "CAST5-ECB"
544# define LN_cast5_ecb "cast5-ecb"
545# define NID_cast5_ecb 109
546
547# define SN_cast5_cfb64 "CAST5-CFB"
548# define LN_cast5_cfb64 "cast5-cfb"
549# define NID_cast5_cfb64 110
550
551# define SN_cast5_ofb64 "CAST5-OFB"
552# define LN_cast5_ofb64 "cast5-ofb"
553# define NID_cast5_ofb64 111
554
555# define LN_pbeWithMD5AndCast5_CBC "pbeWithMD5AndCast5CBC"
556# define NID_pbeWithMD5AndCast5_CBC 112
557# define OBJ_pbeWithMD5AndCast5_CBC 1L,2L,840L,113533L,7L,66L,12L
558
559/*-
560 * This is one sun will soon be using :-(
561 * id-dsa-with-sha1 ID ::= {
562 * iso(1) member-body(2) us(840) x9-57 (10040) x9cm(4) 3 }
563 */
564# define SN_dsaWithSHA1 "DSA-SHA1"
565# define LN_dsaWithSHA1 "dsaWithSHA1"
566# define NID_dsaWithSHA1 113
567# define OBJ_dsaWithSHA1 1L,2L,840L,10040L,4L,3L
568
569# define NID_md5_sha1 114
570# define SN_md5_sha1 "MD5-SHA1"
571# define LN_md5_sha1 "md5-sha1"
572
573# define SN_sha1WithRSA "RSA-SHA1-2"
574# define LN_sha1WithRSA "sha1WithRSA"
575# define NID_sha1WithRSA 115
576# define OBJ_sha1WithRSA OBJ_algorithm,29L
577
578# define SN_dsa "DSA"
579# define LN_dsa "dsaEncryption"
580# define NID_dsa 116
581# define OBJ_dsa 1L,2L,840L,10040L,4L,1L
582
583# define SN_ripemd160 "RIPEMD160"
584# define LN_ripemd160 "ripemd160"
585# define NID_ripemd160 117
586# define OBJ_ripemd160 1L,3L,36L,3L,2L,1L
587
588/*
589 * The name should actually be rsaSignatureWithripemd160, but I'm going to
590 * continue using the convention I'm using with the other ciphers
591 */
592# define SN_ripemd160WithRSA "RSA-RIPEMD160"
593# define LN_ripemd160WithRSA "ripemd160WithRSA"
594# define NID_ripemd160WithRSA 119
595# define OBJ_ripemd160WithRSA 1L,3L,36L,3L,3L,1L,2L
596
597/*-
598 * Taken from rfc2040
599 * RC5_CBC_Parameters ::= SEQUENCE {
600 * version INTEGER (v1_0(16)),
601 * rounds INTEGER (8..127),
602 * blockSizeInBits INTEGER (64, 128),
603 * iv OCTET STRING OPTIONAL
604 * }
605 */
606# define SN_rc5_cbc "RC5-CBC"
607# define LN_rc5_cbc "rc5-cbc"
608# define NID_rc5_cbc 120
609# define OBJ_rc5_cbc OBJ_rsadsi,3L,8L
610
611# define SN_rc5_ecb "RC5-ECB"
612# define LN_rc5_ecb "rc5-ecb"
613# define NID_rc5_ecb 121
614
615# define SN_rc5_cfb64 "RC5-CFB"
616# define LN_rc5_cfb64 "rc5-cfb"
617# define NID_rc5_cfb64 122
618
619# define SN_rc5_ofb64 "RC5-OFB"
620# define LN_rc5_ofb64 "rc5-ofb"
621# define NID_rc5_ofb64 123
622
623# define SN_rle_compression "RLE"
624# define LN_rle_compression "run length compression"
625# define NID_rle_compression 124
626# define OBJ_rle_compression 1L,1L,1L,1L,666L,1L
627
628# define SN_zlib_compression "ZLIB"
629# define LN_zlib_compression "zlib compression"
630# define NID_zlib_compression 125
631# define OBJ_zlib_compression 1L,1L,1L,1L,666L,2L
632
633# define SN_ext_key_usage "extendedKeyUsage"
634# define LN_ext_key_usage "X509v3 Extended Key Usage"
635# define NID_ext_key_usage 126
636# define OBJ_ext_key_usage OBJ_id_ce,37
637
638# define SN_id_pkix "PKIX"
639# define NID_id_pkix 127
640# define OBJ_id_pkix 1L,3L,6L,1L,5L,5L,7L
641
642# define SN_id_kp "id-kp"
643# define NID_id_kp 128
644# define OBJ_id_kp OBJ_id_pkix,3L
645
646/* PKIX extended key usage OIDs */
647
648# define SN_server_auth "serverAuth"
649# define LN_server_auth "TLS Web Server Authentication"
650# define NID_server_auth 129
651# define OBJ_server_auth OBJ_id_kp,1L
652
653# define SN_client_auth "clientAuth"
654# define LN_client_auth "TLS Web Client Authentication"
655# define NID_client_auth 130
656# define OBJ_client_auth OBJ_id_kp,2L
657
658# define SN_code_sign "codeSigning"
659# define LN_code_sign "Code Signing"
660# define NID_code_sign 131
661# define OBJ_code_sign OBJ_id_kp,3L
662
663# define SN_email_protect "emailProtection"
664# define LN_email_protect "E-mail Protection"
665# define NID_email_protect 132
666# define OBJ_email_protect OBJ_id_kp,4L
667
668# define SN_time_stamp "timeStamping"
669# define LN_time_stamp "Time Stamping"
670# define NID_time_stamp 133
671# define OBJ_time_stamp OBJ_id_kp,8L
672
673/* Additional extended key usage OIDs: Microsoft */
674
675# define SN_ms_code_ind "msCodeInd"
676# define LN_ms_code_ind "Microsoft Individual Code Signing"
677# define NID_ms_code_ind 134
678# define OBJ_ms_code_ind 1L,3L,6L,1L,4L,1L,311L,2L,1L,21L
679
680# define SN_ms_code_com "msCodeCom"
681# define LN_ms_code_com "Microsoft Commercial Code Signing"
682# define NID_ms_code_com 135
683# define OBJ_ms_code_com 1L,3L,6L,1L,4L,1L,311L,2L,1L,22L
684
685# define SN_ms_ctl_sign "msCTLSign"
686# define LN_ms_ctl_sign "Microsoft Trust List Signing"
687# define NID_ms_ctl_sign 136
688# define OBJ_ms_ctl_sign 1L,3L,6L,1L,4L,1L,311L,10L,3L,1L
689
690# define SN_ms_sgc "msSGC"
691# define LN_ms_sgc "Microsoft Server Gated Crypto"
692# define NID_ms_sgc 137
693# define OBJ_ms_sgc 1L,3L,6L,1L,4L,1L,311L,10L,3L,3L
694
695# define SN_ms_efs "msEFS"
696# define LN_ms_efs "Microsoft Encrypted File System"
697# define NID_ms_efs 138
698# define OBJ_ms_efs 1L,3L,6L,1L,4L,1L,311L,10L,3L,4L
699
700/* Additional usage: Netscape */
701
702# define SN_ns_sgc "nsSGC"
703# define LN_ns_sgc "Netscape Server Gated Crypto"
704# define NID_ns_sgc 139
705# define OBJ_ns_sgc OBJ_netscape,4L,1L
706
707# define SN_delta_crl "deltaCRL"
708# define LN_delta_crl "X509v3 Delta CRL Indicator"
709# define NID_delta_crl 140
710# define OBJ_delta_crl OBJ_id_ce,27L
711
712# define SN_crl_reason "CRLReason"
713# define LN_crl_reason "CRL Reason Code"
714# define NID_crl_reason 141
715# define OBJ_crl_reason OBJ_id_ce,21L
716
717# define SN_invalidity_date "invalidityDate"
718# define LN_invalidity_date "Invalidity Date"
719# define NID_invalidity_date 142
720# define OBJ_invalidity_date OBJ_id_ce,24L
721
722# define SN_sxnet "SXNetID"
723# define LN_sxnet "Strong Extranet ID"
724# define NID_sxnet 143
725# define OBJ_sxnet 1L,3L,101L,1L,4L,1L
726
727/* PKCS12 and related OBJECT IDENTIFIERS */
728
729# define OBJ_pkcs12 OBJ_pkcs,12L
730# define OBJ_pkcs12_pbeids OBJ_pkcs12, 1
731
732# define SN_pbe_WithSHA1And128BitRC4 "PBE-SHA1-RC4-128"
733# define LN_pbe_WithSHA1And128BitRC4 "pbeWithSHA1And128BitRC4"
734# define NID_pbe_WithSHA1And128BitRC4 144
735# define OBJ_pbe_WithSHA1And128BitRC4 OBJ_pkcs12_pbeids, 1L
736
737# define SN_pbe_WithSHA1And40BitRC4 "PBE-SHA1-RC4-40"
738# define LN_pbe_WithSHA1And40BitRC4 "pbeWithSHA1And40BitRC4"
739# define NID_pbe_WithSHA1And40BitRC4 145
740# define OBJ_pbe_WithSHA1And40BitRC4 OBJ_pkcs12_pbeids, 2L
741
742# define SN_pbe_WithSHA1And3_Key_TripleDES_CBC "PBE-SHA1-3DES"
743# define LN_pbe_WithSHA1And3_Key_TripleDES_CBC "pbeWithSHA1And3-KeyTripleDES-CBC"
744# define NID_pbe_WithSHA1And3_Key_TripleDES_CBC 146
745# define OBJ_pbe_WithSHA1And3_Key_TripleDES_CBC OBJ_pkcs12_pbeids, 3L
746
747# define SN_pbe_WithSHA1And2_Key_TripleDES_CBC "PBE-SHA1-2DES"
748# define LN_pbe_WithSHA1And2_Key_TripleDES_CBC "pbeWithSHA1And2-KeyTripleDES-CBC"
749# define NID_pbe_WithSHA1And2_Key_TripleDES_CBC 147
750# define OBJ_pbe_WithSHA1And2_Key_TripleDES_CBC OBJ_pkcs12_pbeids, 4L
751
752# define SN_pbe_WithSHA1And128BitRC2_CBC "PBE-SHA1-RC2-128"
753# define LN_pbe_WithSHA1And128BitRC2_CBC "pbeWithSHA1And128BitRC2-CBC"
754# define NID_pbe_WithSHA1And128BitRC2_CBC 148
755# define OBJ_pbe_WithSHA1And128BitRC2_CBC OBJ_pkcs12_pbeids, 5L
756
757# define SN_pbe_WithSHA1And40BitRC2_CBC "PBE-SHA1-RC2-40"
758# define LN_pbe_WithSHA1And40BitRC2_CBC "pbeWithSHA1And40BitRC2-CBC"
759# define NID_pbe_WithSHA1And40BitRC2_CBC 149
760# define OBJ_pbe_WithSHA1And40BitRC2_CBC OBJ_pkcs12_pbeids, 6L
761
762# define OBJ_pkcs12_Version1 OBJ_pkcs12, 10L
763
764# define OBJ_pkcs12_BagIds OBJ_pkcs12_Version1, 1L
765
766# define LN_keyBag "keyBag"
767# define NID_keyBag 150
768# define OBJ_keyBag OBJ_pkcs12_BagIds, 1L
769
770# define LN_pkcs8ShroudedKeyBag "pkcs8ShroudedKeyBag"
771# define NID_pkcs8ShroudedKeyBag 151
772# define OBJ_pkcs8ShroudedKeyBag OBJ_pkcs12_BagIds, 2L
773
774# define LN_certBag "certBag"
775# define NID_certBag 152
776# define OBJ_certBag OBJ_pkcs12_BagIds, 3L
777
778# define LN_crlBag "crlBag"
779# define NID_crlBag 153
780# define OBJ_crlBag OBJ_pkcs12_BagIds, 4L
781
782# define LN_secretBag "secretBag"
783# define NID_secretBag 154
784# define OBJ_secretBag OBJ_pkcs12_BagIds, 5L
785
786# define LN_safeContentsBag "safeContentsBag"
787# define NID_safeContentsBag 155
788# define OBJ_safeContentsBag OBJ_pkcs12_BagIds, 6L
789
790# define LN_friendlyName "friendlyName"
791# define NID_friendlyName 156
792# define OBJ_friendlyName OBJ_pkcs9, 20L
793
794# define LN_localKeyID "localKeyID"
795# define NID_localKeyID 157
796# define OBJ_localKeyID OBJ_pkcs9, 21L
797
798# define OBJ_certTypes OBJ_pkcs9, 22L
799
800# define LN_x509Certificate "x509Certificate"
801# define NID_x509Certificate 158
802# define OBJ_x509Certificate OBJ_certTypes, 1L
803
804# define LN_sdsiCertificate "sdsiCertificate"
805# define NID_sdsiCertificate 159
806# define OBJ_sdsiCertificate OBJ_certTypes, 2L
807
808# define OBJ_crlTypes OBJ_pkcs9, 23L
809
810# define LN_x509Crl "x509Crl"
811# define NID_x509Crl 160
812# define OBJ_x509Crl OBJ_crlTypes, 1L
813
814/* PKCS#5 v2 OIDs */
815
816# define LN_pbes2 "PBES2"
817# define NID_pbes2 161
818# define OBJ_pbes2 OBJ_pkcs,5L,13L
819
820# define LN_pbmac1 "PBMAC1"
821# define NID_pbmac1 162
822# define OBJ_pbmac1 OBJ_pkcs,5L,14L
823
824# define LN_hmacWithSHA1 "hmacWithSHA1"
825# define NID_hmacWithSHA1 163
826# define OBJ_hmacWithSHA1 OBJ_rsadsi,2L,7L
827
828/* Policy Qualifier Ids */
829
830# define LN_id_qt_cps "Policy Qualifier CPS"
831# define SN_id_qt_cps "id-qt-cps"
832# define NID_id_qt_cps 164
833# define OBJ_id_qt_cps OBJ_id_pkix,2L,1L
834
835# define LN_id_qt_unotice "Policy Qualifier User Notice"
836# define SN_id_qt_unotice "id-qt-unotice"
837# define NID_id_qt_unotice 165
838# define OBJ_id_qt_unotice OBJ_id_pkix,2L,2L
839
840# define SN_rc2_64_cbc "RC2-64-CBC"
841# define LN_rc2_64_cbc "rc2-64-cbc"
842# define NID_rc2_64_cbc 166
843
844# define SN_SMIMECapabilities "SMIME-CAPS"
845# define LN_SMIMECapabilities "S/MIME Capabilities"
846# define NID_SMIMECapabilities 167
847# define OBJ_SMIMECapabilities OBJ_pkcs9,15L
848
849# define SN_pbeWithMD2AndRC2_CBC "PBE-MD2-RC2-64"
850# define LN_pbeWithMD2AndRC2_CBC "pbeWithMD2AndRC2-CBC"
851# define NID_pbeWithMD2AndRC2_CBC 168
852# define OBJ_pbeWithMD2AndRC2_CBC OBJ_pkcs,5L,4L
853
854# define SN_pbeWithMD5AndRC2_CBC "PBE-MD5-RC2-64"
855# define LN_pbeWithMD5AndRC2_CBC "pbeWithMD5AndRC2-CBC"
856# define NID_pbeWithMD5AndRC2_CBC 169
857# define OBJ_pbeWithMD5AndRC2_CBC OBJ_pkcs,5L,6L
858
859# define SN_pbeWithSHA1AndDES_CBC "PBE-SHA1-DES"
860# define LN_pbeWithSHA1AndDES_CBC "pbeWithSHA1AndDES-CBC"
861# define NID_pbeWithSHA1AndDES_CBC 170
862# define OBJ_pbeWithSHA1AndDES_CBC OBJ_pkcs,5L,10L
863
864/* Extension request OIDs */
865
866# define LN_ms_ext_req "Microsoft Extension Request"
867# define SN_ms_ext_req "msExtReq"
868# define NID_ms_ext_req 171
869# define OBJ_ms_ext_req 1L,3L,6L,1L,4L,1L,311L,2L,1L,14L
870
871# define LN_ext_req "Extension Request"
872# define SN_ext_req "extReq"
873# define NID_ext_req 172
874# define OBJ_ext_req OBJ_pkcs9,14L
875
876# define SN_name "name"
877# define LN_name "name"
878# define NID_name 173
879# define OBJ_name OBJ_X509,41L
880
881# define SN_dnQualifier "dnQualifier"
882# define LN_dnQualifier "dnQualifier"
883# define NID_dnQualifier 174
884# define OBJ_dnQualifier OBJ_X509,46L
885
886# define SN_id_pe "id-pe"
887# define NID_id_pe 175
888# define OBJ_id_pe OBJ_id_pkix,1L
889
890# define SN_id_ad "id-ad"
891# define NID_id_ad 176
892# define OBJ_id_ad OBJ_id_pkix,48L
893
894# define SN_info_access "authorityInfoAccess"
895# define LN_info_access "Authority Information Access"
896# define NID_info_access 177
897# define OBJ_info_access OBJ_id_pe,1L
898
899# define SN_ad_OCSP "OCSP"
900# define LN_ad_OCSP "OCSP"
901# define NID_ad_OCSP 178
902# define OBJ_ad_OCSP OBJ_id_ad,1L
903
904# define SN_ad_ca_issuers "caIssuers"
905# define LN_ad_ca_issuers "CA Issuers"
906# define NID_ad_ca_issuers 179
907# define OBJ_ad_ca_issuers OBJ_id_ad,2L
908
909# define SN_OCSP_sign "OCSPSigning"
910# define LN_OCSP_sign "OCSP Signing"
911# define NID_OCSP_sign 180
912# define OBJ_OCSP_sign OBJ_id_kp,9L
913# endif /* USE_OBJ_MAC */
914
915# include <openssl/bio.h>
916# include <openssl/asn1.h>
917
918# define OBJ_NAME_TYPE_UNDEF 0x00
919# define OBJ_NAME_TYPE_MD_METH 0x01
920# define OBJ_NAME_TYPE_CIPHER_METH 0x02
921# define OBJ_NAME_TYPE_PKEY_METH 0x03
922# define OBJ_NAME_TYPE_COMP_METH 0x04
923# define OBJ_NAME_TYPE_NUM 0x05
924
925# define OBJ_NAME_ALIAS 0x8000
926
927# define OBJ_BSEARCH_VALUE_ON_NOMATCH 0x01
928# define OBJ_BSEARCH_FIRST_VALUE_ON_MATCH 0x02
929
930
931#ifdef __cplusplus
932extern "C" {
933#endif
934
935typedef struct obj_name_st {
936 int type;
937 int alias;
938 const char *name;
939 const char *data;
940} OBJ_NAME;
941
942# define OBJ_create_and_add_object(a,b,c) OBJ_create(a,b,c)
943
944int OBJ_NAME_init(void);
945int OBJ_NAME_new_index(unsigned long (*hash_func) (const char *),
946 int (*cmp_func) (const char *, const char *),
947 void (*free_func) (const char *, int, const char *));
948const char *OBJ_NAME_get(const char *name, int type);
949int OBJ_NAME_add(const char *name, int type, const char *data);
950int OBJ_NAME_remove(const char *name, int type);
951void OBJ_NAME_cleanup(int type); /* -1 for everything */
952void OBJ_NAME_do_all(int type, void (*fn) (const OBJ_NAME *, void *arg),
953 void *arg);
954void OBJ_NAME_do_all_sorted(int type,
955 void (*fn) (const OBJ_NAME *, void *arg),
956 void *arg);
957
958ASN1_OBJECT *OBJ_dup(const ASN1_OBJECT *o);
959ASN1_OBJECT *OBJ_nid2obj(int n);
960const char *OBJ_nid2ln(int n);
961const char *OBJ_nid2sn(int n);
962int OBJ_obj2nid(const ASN1_OBJECT *o);
963ASN1_OBJECT *OBJ_txt2obj(const char *s, int no_name);
964int OBJ_obj2txt(char *buf, int buf_len, const ASN1_OBJECT *a, int no_name);
965int OBJ_txt2nid(const char *s);
966int OBJ_ln2nid(const char *s);
967int OBJ_sn2nid(const char *s);
968int OBJ_cmp(const ASN1_OBJECT *a, const ASN1_OBJECT *b);
969const void *OBJ_bsearch_(const void *key, const void *base, int num, int size,
970 int (*cmp) (const void *, const void *));
971const void *OBJ_bsearch_ex_(const void *key, const void *base, int num,
972 int size,
973 int (*cmp) (const void *, const void *),
974 int flags);
975
976# define _DECLARE_OBJ_BSEARCH_CMP_FN(scope, type1, type2, nm) \
977 static int nm##_cmp_BSEARCH_CMP_FN(const void *, const void *); \
978 static int nm##_cmp(type1 const *, type2 const *); \
979 scope type2 * OBJ_bsearch_##nm(type1 *key, type2 const *base, int num)
980
981# define DECLARE_OBJ_BSEARCH_CMP_FN(type1, type2, cmp) \
982 _DECLARE_OBJ_BSEARCH_CMP_FN(static, type1, type2, cmp)
983# define DECLARE_OBJ_BSEARCH_GLOBAL_CMP_FN(type1, type2, nm) \
984 type2 * OBJ_bsearch_##nm(type1 *key, type2 const *base, int num)
985
986/*-
987 * Unsolved problem: if a type is actually a pointer type, like
988 * nid_triple is, then its impossible to get a const where you need
989 * it. Consider:
990 *
991 * typedef int nid_triple[3];
992 * const void *a_;
993 * const nid_triple const *a = a_;
994 *
995 * The assignement discards a const because what you really want is:
996 *
997 * const int const * const *a = a_;
998 *
999 * But if you do that, you lose the fact that a is an array of 3 ints,
1000 * which breaks comparison functions.
1001 *
1002 * Thus we end up having to cast, sadly, or unpack the
1003 * declarations. Or, as I finally did in this case, delcare nid_triple
1004 * to be a struct, which it should have been in the first place.
1005 *
1006 * Ben, August 2008.
1007 *
1008 * Also, strictly speaking not all types need be const, but handling
1009 * the non-constness means a lot of complication, and in practice
1010 * comparison routines do always not touch their arguments.
1011 */
1012
1013# define IMPLEMENT_OBJ_BSEARCH_CMP_FN(type1, type2, nm) \
1014 static int nm##_cmp_BSEARCH_CMP_FN(const void *a_, const void *b_) \
1015 { \
1016 type1 const *a = a_; \
1017 type2 const *b = b_; \
1018 return nm##_cmp(a,b); \
1019 } \
1020 static type2 *OBJ_bsearch_##nm(type1 *key, type2 const *base, int num) \
1021 { \
1022 return (type2 *)OBJ_bsearch_(key, base, num, sizeof(type2), \
1023 nm##_cmp_BSEARCH_CMP_FN); \
1024 } \
1025 extern void dummy_prototype(void)
1026
1027# define IMPLEMENT_OBJ_BSEARCH_GLOBAL_CMP_FN(type1, type2, nm) \
1028 static int nm##_cmp_BSEARCH_CMP_FN(const void *a_, const void *b_) \
1029 { \
1030 type1 const *a = a_; \
1031 type2 const *b = b_; \
1032 return nm##_cmp(a,b); \
1033 } \
1034 type2 *OBJ_bsearch_##nm(type1 *key, type2 const *base, int num) \
1035 { \
1036 return (type2 *)OBJ_bsearch_(key, base, num, sizeof(type2), \
1037 nm##_cmp_BSEARCH_CMP_FN); \
1038 } \
1039 extern void dummy_prototype(void)
1040
1041# define OBJ_bsearch(type1,key,type2,base,num,cmp) \
1042 ((type2 *)OBJ_bsearch_(CHECKED_PTR_OF(type1,key),CHECKED_PTR_OF(type2,base), \
1043 num,sizeof(type2), \
1044 ((void)CHECKED_PTR_OF(type1,cmp##_type_1), \
1045 (void)CHECKED_PTR_OF(type2,cmp##_type_2), \
1046 cmp##_BSEARCH_CMP_FN)))
1047
1048# define OBJ_bsearch_ex(type1,key,type2,base,num,cmp,flags) \
1049 ((type2 *)OBJ_bsearch_ex_(CHECKED_PTR_OF(type1,key),CHECKED_PTR_OF(type2,base), \
1050 num,sizeof(type2), \
1051 ((void)CHECKED_PTR_OF(type1,cmp##_type_1), \
1052 (void)type_2=CHECKED_PTR_OF(type2,cmp##_type_2), \
1053 cmp##_BSEARCH_CMP_FN)),flags)
1054
1055int OBJ_new_nid(int num);
1056int OBJ_add_object(const ASN1_OBJECT *obj);
1057int OBJ_create(const char *oid, const char *sn, const char *ln);
1058#if OPENSSL_API_COMPAT < 0x10100000L
1059# define OBJ_cleanup() while(0) continue
1060#endif
1061int OBJ_create_objects(BIO *in);
1062
1063size_t OBJ_length(const ASN1_OBJECT *obj);
1064const unsigned char *OBJ_get0_data(const ASN1_OBJECT *obj);
1065
1066int OBJ_find_sigid_algs(int signid, int *pdig_nid, int *ppkey_nid);
1067int OBJ_find_sigid_by_algs(int *psignid, int dig_nid, int pkey_nid);
1068int OBJ_add_sigid(int signid, int dig_id, int pkey_id);
1069void OBJ_sigid_free(void);
1070
1071/* BEGIN ERROR CODES */
1072/*
1073 * The following lines are auto generated by the script mkerr.pl. Any changes
1074 * made after this point may be overwritten when the script is next run.
1075 */
1076
1077int ERR_load_OBJ_strings(void);
1078
1079/* Error codes for the OBJ functions. */
1080
1081/* Function codes. */
1082# define OBJ_F_OBJ_ADD_OBJECT 105
1083# define OBJ_F_OBJ_CREATE 100
1084# define OBJ_F_OBJ_DUP 101
1085# define OBJ_F_OBJ_NAME_NEW_INDEX 106
1086# define OBJ_F_OBJ_NID2LN 102
1087# define OBJ_F_OBJ_NID2OBJ 103
1088# define OBJ_F_OBJ_NID2SN 104
1089
1090/* Reason codes. */
1091# define OBJ_R_OID_EXISTS 102
1092# define OBJ_R_UNKNOWN_NID 101
1093
1094# ifdef __cplusplus
1095}
1096# endif
1097#endif
Note: See TracBrowser for help on using the repository browser.