OpenPACE
objects.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2013 Frank Morgner
3 *
4 * This file is part of OpenPACE.
5 *
6 * OpenPACE is free software: you can redistribute it and/or modify it under
7 * the terms of the GNU General Public License as published by the Free
8 * Software Foundation, either version 3 of the License, or (at your option)
9 * any later version.
10 *
11 * OpenPACE is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
13 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
14 * details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * OpenPACE. If not, see <http://www.gnu.org/licenses/>.
18 *
19 * Additional permission under GNU GPL version 3 section 7
20 *
21 * If you modify this Program, or any covered work, by linking or combining it
22 * with OpenSSL (or a modified version of that library), containing
23 * parts covered by the terms of OpenSSL's license, the licensors of
24 * this Program grant you additional permission to convey the resulting work.
25 * Corresponding Source for a non-source form of such a combination shall include
26 * the source code for the parts of OpenSSL used as well as that of the
27 * covered work.
28 *
29 * If you modify this Program, or any covered work, by linking or combining it
30 * with OpenSC (or a modified version of that library), containing
31 * parts covered by the terms of OpenSC's license, the licensors of
32 * this Program grant you additional permission to convey the resulting work.
33 * Corresponding Source for a non-source form of such a combination shall include
34 * the source code for the parts of OpenSC used as well as that of the
35 * covered work.
36 */
37
45#ifndef OBJ_H_
46#define OBJ_H_
47
48#ifdef __cplusplus
49extern "C" {
50#endif
51
52#include <openssl/objects.h>
53#include <openssl/obj_mac.h>
54
63ASN1_OBJECT *EAC_OBJ_nid2obj(int n);
64const char *EAC_OBJ_nid2ln(int n);
65const char *EAC_OBJ_nid2sn(int n);
66int EAC_OBJ_obj2nid(const ASN1_OBJECT *o);
67ASN1_OBJECT *EAC_OBJ_txt2obj(const char *s, int no_name);
68int EAC_OBJ_txt2nid(const char *s);
69int EAC_OBJ_ln2nid(const char *s);
70int EAC_OBJ_sn2nid(const char *s);
71
72#ifdef NID_id_PACE_ECDH_GM_AES_CBC_CMAC_128
73#define HAVE_PATCHED_OPENSSL 1
74
75#else
76
77/* The following definitions are made to be compatible with OpenSSL */
78
79#define OBJ_bsi_de 0L,4L,0L,127L,0L,7L
80
81#define SN_standardizedDomainParameters "standardizedDomainParameters"
82extern int NID_standardizedDomainParameters;
83#define OBJ_standardizedDomainParameters OBJ_bsi_de,1L,2L
84
85#define OBJ_id_PK OBJ_bsi_de,2L,2L,1L
86
87#define SN_id_PK_DH "id-PK-DH"
88extern int NID_id_PK_DH;
89#define OBJ_id_PK_DH OBJ_id_PK,1L
90
91#define SN_id_PK_ECDH "id-PK-ECDH"
92extern int NID_id_PK_ECDH;
93#define OBJ_id_PK_ECDH OBJ_id_PK,2L
94
95#define SN_id_TA "id-TA"
96extern int NID_id_TA;
97#define OBJ_id_TA OBJ_bsi_de,2L,2L,2L
98
99#define SN_id_TA_RSA "id-TA-RSA"
100extern int NID_id_TA_RSA;
101#define OBJ_id_TA_RSA OBJ_id_TA,1L
102
103#define SN_id_TA_RSA_v1_5_SHA_1 "id-TA-RSA-v1-5-SHA-1"
104extern int NID_id_TA_RSA_v1_5_SHA_1;
105#define OBJ_id_TA_RSA_v1_5_SHA_1 OBJ_id_TA_RSA,1L
106
107#define SN_id_TA_RSA_v1_5_SHA_256 "id-TA-RSA-v1-5-SHA-256"
108extern int NID_id_TA_RSA_v1_5_SHA_256;
109#define OBJ_id_TA_RSA_v1_5_SHA_256 OBJ_id_TA_RSA,2L
110
111#define SN_id_TA_RSA_PSS_SHA_1 "id-TA-RSA-PSS-SHA-1"
112extern int NID_id_TA_RSA_PSS_SHA_1;
113#define OBJ_id_TA_RSA_PSS_SHA_1 OBJ_id_TA_RSA,3L
114
115#define SN_id_TA_RSA_PSS_SHA_256 "id-TA-RSA-PSS-SHA-256"
116extern int NID_id_TA_RSA_PSS_SHA_256;
117#define OBJ_id_TA_RSA_PSS_SHA_256 OBJ_id_TA_RSA,4L
118
119#define SN_id_TA_RSA_v1_5_SHA_512 "id-TA-RSA-v1-5-SHA-512"
120extern int NID_id_TA_RSA_v1_5_SHA_512;
121#define OBJ_id_TA_RSA_v1_5_SHA_512 OBJ_id_TA_RSA,5L
122
123#define SN_id_TA_RSA_PSS_SHA_512 "id-TA-RSA-PSS-SHA-512"
124extern int NID_id_TA_RSA_PSS_SHA_512;
125#define OBJ_id_TA_RSA_PSS_SHA_512 OBJ_id_TA_RSA,6L
126
127#define SN_id_TA_ECDSA "id-TA-ECDSA"
128extern int NID_id_TA_ECDSA;
129#define OBJ_id_TA_ECDSA OBJ_id_TA,2L
130
131#define SN_id_TA_ECDSA_SHA_1 "id-TA-ECDSA-SHA-1"
132extern int NID_id_TA_ECDSA_SHA_1;
133#define OBJ_id_TA_ECDSA_SHA_1 OBJ_id_TA_ECDSA,1L
134
135#define SN_id_TA_ECDSA_SHA_224 "id-TA-ECDSA-SHA-224"
136extern int NID_id_TA_ECDSA_SHA_224;
137#define OBJ_id_TA_ECDSA_SHA_224 OBJ_id_TA_ECDSA,2L
138
139#define SN_id_TA_ECDSA_SHA_256 "id-TA-ECDSA-SHA-256"
140extern int NID_id_TA_ECDSA_SHA_256;
141#define OBJ_id_TA_ECDSA_SHA_256 OBJ_id_TA_ECDSA,3L
142
143#define SN_id_TA_ECDSA_SHA_384 "id-TA-ECDSA-SHA-384"
144extern int NID_id_TA_ECDSA_SHA_384;
145#define OBJ_id_TA_ECDSA_SHA_384 OBJ_id_TA_ECDSA,4L
146
147#define SN_id_TA_ECDSA_SHA_512 "id-TA-ECDSA-SHA-512"
148extern int NID_id_TA_ECDSA_SHA_512;
149#define OBJ_id_TA_ECDSA_SHA_512 OBJ_id_TA_ECDSA,5L
150
151#define OBJ_id_CA OBJ_bsi_de,2L,2L,3L
152
153#define SN_id_CA_DH "id-CA-DH"
154extern int NID_id_CA_DH;
155#define OBJ_id_CA_DH OBJ_id_CA,1L
156
157#define SN_id_CA_DH_3DES_CBC_CBC "id-CA-DH-3DES-CBC-CBC"
158extern int NID_id_CA_DH_3DES_CBC_CBC;
159#define OBJ_id_CA_DH_3DES_CBC_CBC OBJ_id_CA_DH,1L
160
161#define SN_id_CA_DH_AES_CBC_CMAC_128 "id-CA-DH-AES-CBC-CMAC-128"
162extern int NID_id_CA_DH_AES_CBC_CMAC_128;
163#define OBJ_id_CA_DH_AES_CBC_CMAC_128 OBJ_id_CA_DH,2L
164
165#define SN_id_CA_DH_AES_CBC_CMAC_192 "id-CA-DH-AES-CBC-CMAC-192"
166extern int NID_id_CA_DH_AES_CBC_CMAC_192;
167#define OBJ_id_CA_DH_AES_CBC_CMAC_192 OBJ_id_CA_DH,3L
168
169#define SN_id_CA_DH_AES_CBC_CMAC_256 "id-CA-DH-AES-CBC-CMAC-256"
170extern int NID_id_CA_DH_AES_CBC_CMAC_256;
171#define OBJ_id_CA_DH_AES_CBC_CMAC_256 OBJ_id_CA_DH,4L
172
173#define SN_id_CA_ECDH "id-CA-ECDH"
174extern int NID_id_CA_ECDH;
175#define OBJ_id_CA_ECDH OBJ_id_CA,2L
176
177#define SN_id_CA_ECDH_3DES_CBC_CBC "id-CA-ECDH-3DES-CBC-CBC"
178extern int NID_id_CA_ECDH_3DES_CBC_CBC;
179#define OBJ_id_CA_ECDH_3DES_CBC_CBC OBJ_id_CA_ECDH,1L
180
181#define SN_id_CA_ECDH_AES_CBC_CMAC_128 "id-CA-ECDH-AES-CBC-CMAC-128"
182extern int NID_id_CA_ECDH_AES_CBC_CMAC_128;
183#define OBJ_id_CA_ECDH_AES_CBC_CMAC_128 OBJ_id_CA_ECDH,2L
184
185#define SN_id_CA_ECDH_AES_CBC_CMAC_192 "id-CA-ECDH-AES-CBC-CMAC-192"
186extern int NID_id_CA_ECDH_AES_CBC_CMAC_192;
187#define OBJ_id_CA_ECDH_AES_CBC_CMAC_192 OBJ_id_CA_ECDH,3L
188
189#define SN_id_CA_ECDH_AES_CBC_CMAC_256 "id-CA-ECDH-AES-CBC-CMAC-256"
190extern int NID_id_CA_ECDH_AES_CBC_CMAC_256;
191#define OBJ_id_CA_ECDH_AES_CBC_CMAC_256 OBJ_id_CA_ECDH,4L
192
193#define OBJ_id_PACE OBJ_bsi_de,2L,2L,4L
194
195#define SN_id_PACE_DH_GM "id-PACE-DH-GM"
196extern int NID_id_PACE_DH_GM;
197#define OBJ_id_PACE_DH_GM OBJ_id_PACE,1L
198
199#define SN_id_PACE_DH_GM_3DES_CBC_CBC "id-PACE-DH-GM-3DES-CBC-CBC"
200extern int NID_id_PACE_DH_GM_3DES_CBC_CBC;
201#define OBJ_id_PACE_DH_GM_3DES_CBC_CBC OBJ_id_PACE_DH_GM,1L
202
203#define SN_id_PACE_DH_GM_AES_CBC_CMAC_128 "id-PACE-DH-GM-AES-CBC-CMAC-128"
204extern int NID_id_PACE_DH_GM_AES_CBC_CMAC_128;
205#define OBJ_id_PACE_DH_GM_AES_CBC_CMAC_128 OBJ_id_PACE_DH_GM,2L
206
207#define SN_id_PACE_DH_GM_AES_CBC_CMAC_192 "id-PACE-DH-GM-AES-CBC-CMAC-192"
208extern int NID_id_PACE_DH_GM_AES_CBC_CMAC_192;
209#define OBJ_id_PACE_DH_GM_AES_CBC_CMAC_192 OBJ_id_PACE_DH_GM,3L
210
211#define SN_id_PACE_DH_GM_AES_CBC_CMAC_256 "id-PACE-DH-GM-AES-CBC-CMAC-256"
212extern int NID_id_PACE_DH_GM_AES_CBC_CMAC_256;
213#define OBJ_id_PACE_DH_GM_AES_CBC_CMAC_256 OBJ_id_PACE_DH_GM,4L
214
215#define SN_id_PACE_ECDH_GM "id-PACE-ECDH-GM"
216extern int NID_id_PACE_ECDH_GM;
217#define OBJ_id_PACE_ECDH_GM OBJ_id_PACE,2L
218
219#define SN_id_PACE_ECDH_GM_3DES_CBC_CBC "id-PACE-ECDH-GM-3DES-CBC-CBC"
220extern int NID_id_PACE_ECDH_GM_3DES_CBC_CBC;
221#define OBJ_id_PACE_ECDH_GM_3DES_CBC_CBC OBJ_id_PACE_ECDH_GM,1L
222
223#define SN_id_PACE_ECDH_GM_AES_CBC_CMAC_128 "id-PACE-ECDH-GM-AES-CBC-CMAC-128"
224extern int NID_id_PACE_ECDH_GM_AES_CBC_CMAC_128;
225#define OBJ_id_PACE_ECDH_GM_AES_CBC_CMAC_128 OBJ_id_PACE_ECDH_GM,2L
226
227#define SN_id_PACE_ECDH_GM_AES_CBC_CMAC_192 "id-PACE-ECDH-GM-AES-CBC-CMAC-192"
228extern int NID_id_PACE_ECDH_GM_AES_CBC_CMAC_192;
229#define OBJ_id_PACE_ECDH_GM_AES_CBC_CMAC_192 OBJ_id_PACE_ECDH_GM,3L
230
231#define SN_id_PACE_ECDH_GM_AES_CBC_CMAC_256 "id-PACE-ECDH-GM-AES-CBC-CMAC-256"
232extern int NID_id_PACE_ECDH_GM_AES_CBC_CMAC_256;
233#define OBJ_id_PACE_ECDH_GM_AES_CBC_CMAC_256 OBJ_id_PACE_ECDH_GM,4L
234
235#define SN_id_PACE_DH_IM "id-PACE-DH-IM"
236extern int NID_id_PACE_DH_IM;
237#define OBJ_id_PACE_DH_IM OBJ_id_PACE,3L
238
239#define SN_id_PACE_DH_IM_3DES_CBC_CBC "id-PACE-DH-IM-3DES-CBC-CBC"
240extern int NID_id_PACE_DH_IM_3DES_CBC_CBC;
241#define OBJ_id_PACE_DH_IM_3DES_CBC_CBC OBJ_id_PACE_DH_IM,1L
242
243#define SN_id_PACE_DH_IM_AES_CBC_CMAC_128 "id-PACE-DH-IM-AES-CBC-CMAC-128"
244extern int NID_id_PACE_DH_IM_AES_CBC_CMAC_128;
245#define OBJ_id_PACE_DH_IM_AES_CBC_CMAC_128 OBJ_id_PACE_DH_IM,2L
246
247#define SN_id_PACE_DH_IM_AES_CBC_CMAC_192 "id-PACE-DH-IM-AES-CBC-CMAC-192"
248extern int NID_id_PACE_DH_IM_AES_CBC_CMAC_192;
249#define OBJ_id_PACE_DH_IM_AES_CBC_CMAC_192 OBJ_id_PACE_DH_IM,3L
250
251#define SN_id_PACE_DH_IM_AES_CBC_CMAC_256 "id-PACE-DH-IM-AES-CBC-CMAC-256"
252extern int NID_id_PACE_DH_IM_AES_CBC_CMAC_256;
253#define OBJ_id_PACE_DH_IM_AES_CBC_CMAC_256 OBJ_id_PACE_DH_IM,4L
254
255#define SN_id_PACE_ECDH_IM "id-PACE-ECDH-IM"
256extern int NID_id_PACE_ECDH_IM;
257#define OBJ_id_PACE_ECDH_IM OBJ_id_PACE,4L
258
259#define SN_id_PACE_ECDH_IM_3DES_CBC_CBC "id-PACE-ECDH-IM-3DES-CBC-CBC"
260extern int NID_id_PACE_ECDH_IM_3DES_CBC_CBC;
261#define OBJ_id_PACE_ECDH_IM_3DES_CBC_CBC OBJ_id_PACE_ECDH_IM,1L
262
263#define SN_id_PACE_ECDH_IM_AES_CBC_CMAC_128 "id-PACE-ECDH-IM-AES-CBC-CMAC-128"
264extern int NID_id_PACE_ECDH_IM_AES_CBC_CMAC_128;
265#define OBJ_id_PACE_ECDH_IM_AES_CBC_CMAC_128 OBJ_id_PACE_ECDH_IM,2L
266
267#define SN_id_PACE_ECDH_IM_AES_CBC_CMAC_192 "id-PACE-ECDH-IM-AES-CBC-CMAC-192"
268extern int NID_id_PACE_ECDH_IM_AES_CBC_CMAC_192;
269#define OBJ_id_PACE_ECDH_IM_AES_CBC_CMAC_192 OBJ_id_PACE_ECDH_IM,3L
270
271#define SN_id_PACE_ECDH_IM_AES_CBC_CMAC_256 "id-PACE-ECDH-IM-AES-CBC-CMAC-256"
272extern int NID_id_PACE_ECDH_IM_AES_CBC_CMAC_256;
273#define OBJ_id_PACE_ECDH_IM_AES_CBC_CMAC_256 OBJ_id_PACE_ECDH_IM,4L
274
275#define OBJ_id_RI OBJ_bsi_de,2L,2L,5L
276
277#define SN_id_RI_DH "id-RI-DH"
278extern int NID_id_RI_DH;
279#define OBJ_id_RI_DH OBJ_id_RI,1L
280
281#define SN_id_RI_DH_SHA_1 "id-RI-DH-SHA-1"
282extern int NID_id_RI_DH_SHA_1;
283#define OBJ_id_RI_DH_SHA_1 OBJ_id_RI_DH,1L
284
285#define SN_id_RI_DH_SHA_224 "id-RI-DH-SHA-224"
286extern int NID_id_RI_DH_SHA_224;
287#define OBJ_id_RI_DH_SHA_224 OBJ_id_RI_DH,2L
288
289#define SN_id_RI_DH_SHA_256 "id-RI-DH-SHA-256"
290extern int NID_id_RI_DH_SHA_256;
291#define OBJ_id_RI_DH_SHA_256 OBJ_id_RI_DH,3L
292
293#define SN_id_RI_DH_SHA_384 "id-RI-DH-SHA-384"
294extern int NID_id_RI_DH_SHA_384;
295#define OBJ_id_RI_DH_SHA_384 OBJ_id_RI_DH,4L
296
297#define SN_id_RI_DH_SHA_512 "id-RI-DH-SHA-512"
298extern int NID_id_RI_DH_SHA_512;
299#define OBJ_id_RI_DH_SHA_512 OBJ_id_RI_DH,5L
300
301#define SN_id_RI_ECDH "id-RI-ECDH"
302extern int NID_id_RI_ECDH;
303#define OBJ_id_RI_ECDH OBJ_id_RI,2L
304
305#define SN_id_RI_ECDH_SHA_1 "id-RI-ECDH-SHA-1"
306extern int NID_id_RI_ECDH_SHA_1;
307#define OBJ_id_RI_ECDH_SHA_1 OBJ_id_RI_ECDH,1L
308
309#define SN_id_RI_ECDH_SHA_224 "id-RI-ECDH-SHA-224"
310extern int NID_id_RI_ECDH_SHA_224;
311#define OBJ_id_RI_ECDH_SHA_224 OBJ_id_RI_ECDH,2L
312
313#define SN_id_RI_ECDH_SHA_256 "id-RI-ECDH-SHA-256"
314extern int NID_id_RI_ECDH_SHA_256;
315#define OBJ_id_RI_ECDH_SHA_256 OBJ_id_RI_ECDH,3L
316
317#define SN_id_RI_ECDH_SHA_384 "id-RI-ECDH-SHA-384"
318extern int NID_id_RI_ECDH_SHA_384;
319#define OBJ_id_RI_ECDH_SHA_384 OBJ_id_RI_ECDH,4L
320
321#define SN_id_RI_ECDH_SHA_512 "id-RI-ECDH-SHA-512"
322extern int NID_id_RI_ECDH_SHA_512;
323#define OBJ_id_RI_ECDH_SHA_512 OBJ_id_RI_ECDH,5L
324
325#define SN_id_CI "id-CI"
326extern int NID_id_CI;
327#define OBJ_id_CI OBJ_bsi_de,2L,2L,6L
328
329#define SN_id_eIDSecurity "id-eIDSecurity"
330extern int NID_id_eIDSecurity;
331#define OBJ_id_eIDSecurity OBJ_bsi_de,2L,2L,7L
332
333#define SN_id_PT "id-PT"
334extern int NID_id_PT;
335#define OBJ_id_PT OBJ_bsi_de,2L,2L,8L
336
337#define OBJ_id_ecc OBJ_bsi_de,1L,1L
338
339#define OBJ_ecka_dh OBJ_id_ecc,5L,2L
340
341#define SN_ecka_dh_SessionKDF "ecka-dh-SessionKDF"
342extern int NID_ecka_dh_SessionKDF;
343#define OBJ_ecka_dh_SessionKDF OBJ_ecka_dh,2L
344
345#define SN_ecka_dh_SessionKDF_DES3 "ecka-dh-SessionKDF-DES3"
346extern int NID_ecka_dh_SessionKDF_DES3;
347#define OBJ_ecka_dh_SessionKDF_DES3 OBJ_ecka_dh,2L,1L
348
349#define SN_ecka_dh_SessionKDF_AES128 "ecka-dh-SessionKDF-AES128"
350extern int NID_ecka_dh_SessionKDF_AES128;
351#define OBJ_ecka_dh_SessionKDF_AES128 OBJ_ecka_dh,2L,2L
352
353#define SN_ecka_dh_SessionKDF_AES192 "ecka-dh-SessionKDF-AES192"
354extern int NID_ecka_dh_SessionKDF_AES192;
355#define OBJ_ecka_dh_SessionKDF_AES192 OBJ_ecka_dh,2L,3L
356
357#define SN_ecka_dh_SessionKDF_AES256 "ecka-dh-SessionKDF-AES256"
358extern int NID_ecka_dh_SessionKDF_AES256;
359#define OBJ_ecka_dh_SessionKDF_AES256 OBJ_ecka_dh,2L,4L
360
361#define OBJ_id_roles OBJ_bsi_de,3L,1L,2L
362
363#define SN_id_IS "id-IS"
364extern int NID_id_IS;
365#define OBJ_id_IS OBJ_id_roles,1L
366
367#define SN_id_AT "id-AT"
368extern int NID_id_AT;
369#define OBJ_id_AT OBJ_id_roles,2L
370
371#define SN_id_ST "id-ST"
372extern int NID_id_ST;
373#define OBJ_id_ST OBJ_id_roles,3L
374
375#define OBJ_id_extensions OBJ_bsi_de,3L,1L,3L
376
377#define SN_id_description "id-description"
378extern int NID_id_description;
379#define OBJ_id_description OBJ_id_extensions,1L
380
381#define SN_id_plainFormat "id-plainFormat"
382extern int NID_id_plainFormat;
383#define OBJ_id_plainFormat OBJ_id_description,1L
384
385#define SN_id_htmlFormat "id-htmlFormat"
386extern int NID_id_htmlFormat;
387#define OBJ_id_htmlFormat OBJ_id_description,2L
388
389#define SN_id_pdfFormat "id-pdfFormat"
390extern int NID_id_pdfFormat;
391#define OBJ_id_pdfFormat OBJ_id_description,3L
392
393#define SN_id_sector "id-sector"
394extern int NID_id_sector;
395#define OBJ_id_sector OBJ_id_extensions,2L
396
397#define OBJ_id_eID OBJ_bsi_de,3L,2L
398
399#define SN_id_SecurityObject "id-SecurityObject"
400extern int NID_id_SecurityObject;
401#define OBJ_id_SecurityObject OBJ_id_eID,1L
402
403#define OBJ_id_AuxiliaryData OBJ_bsi_de,3L,1L,4L
404
405#define SN_id_DateOfBirth "id-DateOfBirth"
406extern int NID_id_DateOfBirth;
407#define OBJ_id_DateOfBirth OBJ_id_AuxiliaryData,1L
408
409#define SN_id_DateOfExpiry "id-DateOfExpiry"
410extern int NID_id_DateOfExpiry;
411#define OBJ_id_DateOfExpiry OBJ_id_AuxiliaryData,2L
412
413#define SN_id_CommunityID "id-CommunityID"
414extern int NID_id_CommunityID;
415#define OBJ_id_CommunityID OBJ_id_AuxiliaryData,3L
416
417#endif
418
419#ifdef __cplusplus
420}
421#endif
422#endif
ASN1_OBJECT * EAC_OBJ_nid2obj(int n)