summaryrefslogtreecommitdiff
path: root/src/certtool-args.h.bak
blob: bc8b2cf368f0ccb905a5944bef5e2315225eaf5e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
/*   -*- buffer-read-only: t -*- vi: set ro:
 *
 *  DO NOT EDIT THIS FILE   (certtool-args.h)
 *
 *  It has been AutoGen-ed
 *  From the definitions    certtool-args.def
 *  and the template file   options
 *
 * Generated from AutoOpts 41:1:16 templates.
 *
 *  AutoOpts is a copyrighted work.  This header file is not encumbered
 *  by AutoOpts licensing, but is provided under the licensing terms chosen
 *  by the certtool author or copyright holder.  AutoOpts is
 *  licensed under the terms of the LGPL.  The redistributable library
 *  (``libopts'') is licensed under the terms of either the LGPL or, at the
 *  users discretion, the BSD license.  See the AutoOpts and/or libopts sources
 *  for details.
 *
 * The certtool program is copyrighted and licensed
 * under the following terms:
 *
 *  Copyright (C) 2000-@YEAR@ Free Software Foundation, and others, all rights reserved.
 *  This is free software. It is licensed for use, modification and
 *  redistribution under the terms of the GNU General Public License,
 *  version 3 or later <http://gnu.org/licenses/gpl.html>
 *
 *  certtool is free software: you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License as published by the
 *  Free Software Foundation, either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  certtool is distributed in the hope that it will be useful, but
 *  WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 *  See the GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License along
 *  with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
/**
 *  This file contains the programmatic interface to the Automated
 *  Options generated for the certtool program.
 *  These macros are documented in the AutoGen info file in the
 *  "AutoOpts" chapter.  Please refer to that doc for usage help.
 */
#ifndef AUTOOPTS_CERTTOOL_ARGS_H_GUARD
#define AUTOOPTS_CERTTOOL_ARGS_H_GUARD 1
#include "config.h"
#include <autoopts/options.h>

/**
 *  Ensure that the library used for compiling this generated header is at
 *  least as new as the version current when the header template was released
 *  (not counting patch version increments).  Also ensure that the oldest
 *  tolerable version is at least as old as what was current when the header
 *  template was released.
 */
#define AO_TEMPLATE_VERSION 167937
#if (AO_TEMPLATE_VERSION < OPTIONS_MINIMUM_VERSION) \
 || (AO_TEMPLATE_VERSION > OPTIONS_STRUCT_VERSION)
# error option template version mismatches autoopts/options.h header
  Choke Me.
#endif

/**
 *  Enumeration of each option type for certtool
 */
typedef enum {
    INDEX_OPT_DEBUG                    =  0,
    INDEX_OPT_VERBOSE                  =  1,
    INDEX_OPT_INFILE                   =  2,
    INDEX_OPT_OUTFILE                  =  3,
    INDEX_OPT_CERTIFICATE_INFO         =  5,
    INDEX_OPT_PUBKEY_INFO              =  6,
    INDEX_OPT_GENERATE_SELF_SIGNED     =  7,
    INDEX_OPT_GENERATE_CERTIFICATE     =  8,
    INDEX_OPT_GENERATE_PROXY           =  9,
    INDEX_OPT_UPDATE_CERTIFICATE       = 10,
    INDEX_OPT_FINGERPRINT              = 11,
    INDEX_OPT_KEY_ID                   = 12,
    INDEX_OPT_CERTIFICATE_PUBKEY       = 13,
    INDEX_OPT_V1                       = 14,
    INDEX_OPT_SIGN_PARAMS              = 15,
    INDEX_OPT_CRQ_INFO                 = 17,
    INDEX_OPT_GENERATE_REQUEST         = 18,
    INDEX_OPT_NO_CRQ_EXTENSIONS        = 19,
    INDEX_OPT_P12_INFO                 = 21,
    INDEX_OPT_P12_NAME                 = 22,
    INDEX_OPT_TO_P12                   = 23,
    INDEX_OPT_KEY_INFO                 = 25,
    INDEX_OPT_P8_INFO                  = 26,
    INDEX_OPT_GENERATE_PRIVKEY         = 27,
    INDEX_OPT_BITS                     = 28,
    INDEX_OPT_CURVE                    = 29,
    INDEX_OPT_SEC_PARAM                = 30,
    INDEX_OPT_TO_P8                    = 31,
    INDEX_OPT_PKCS8                    = 32,
    INDEX_OPT_PROVABLE                 = 33,
    INDEX_OPT_VERIFY_PROVABLE_PRIVKEY  = 34,
    INDEX_OPT_SEED                     = 35,
    INDEX_OPT_CRL_INFO                 = 37,
    INDEX_OPT_GENERATE_CRL             = 38,
    INDEX_OPT_VERIFY_CRL               = 39,
    INDEX_OPT_VERIFY_CHAIN             = 41,
    INDEX_OPT_VERIFY                   = 42,
    INDEX_OPT_VERIFY_HOSTNAME          = 43,
    INDEX_OPT_VERIFY_EMAIL             = 44,
    INDEX_OPT_VERIFY_PURPOSE           = 45,
    INDEX_OPT_VERIFY_ALLOW_BROKEN      = 46,
    INDEX_OPT_P7_GENERATE              = 48,
    INDEX_OPT_P7_SIGN                  = 49,
    INDEX_OPT_P7_DETACHED_SIGN         = 50,
    INDEX_OPT_P7_INCLUDE_CERT          = 51,
    INDEX_OPT_P7_TIME                  = 52,
    INDEX_OPT_P7_SHOW_DATA             = 53,
    INDEX_OPT_P7_INFO                  = 54,
    INDEX_OPT_P7_VERIFY                = 55,
    INDEX_OPT_SMIME_TO_P7              = 56,
    INDEX_OPT_GENERATE_DH_PARAMS       = 58,
    INDEX_OPT_GET_DH_PARAMS            = 59,
    INDEX_OPT_DH_INFO                  = 60,
    INDEX_OPT_LOAD_PRIVKEY             = 61,
    INDEX_OPT_LOAD_PUBKEY              = 62,
    INDEX_OPT_LOAD_REQUEST             = 63,
    INDEX_OPT_LOAD_CERTIFICATE         = 64,
    INDEX_OPT_LOAD_CA_PRIVKEY          = 65,
    INDEX_OPT_LOAD_CA_CERTIFICATE      = 66,
    INDEX_OPT_LOAD_CRL                 = 67,
    INDEX_OPT_LOAD_DATA                = 68,
    INDEX_OPT_PASSWORD                 = 69,
    INDEX_OPT_NULL_PASSWORD            = 70,
    INDEX_OPT_EMPTY_PASSWORD           = 71,
    INDEX_OPT_HEX_NUMBERS              = 72,
    INDEX_OPT_CPRINT                   = 73,
    INDEX_OPT_RSA                      = 74,
    INDEX_OPT_DSA                      = 75,
    INDEX_OPT_ECC                      = 76,
    INDEX_OPT_ECDSA                    = 77,
    INDEX_OPT_KEY_TYPE                 = 78,
    INDEX_OPT_HASH                     = 79,
    INDEX_OPT_SALT_SIZE                = 80,
    INDEX_OPT_INDER                    = 81,
    INDEX_OPT_INRAW                    = 82,
    INDEX_OPT_OUTDER                   = 83,
    INDEX_OPT_OUTRAW                   = 84,
    INDEX_OPT_DISABLE_QUICK_RANDOM     = 85,
    INDEX_OPT_TEMPLATE                 = 86,
    INDEX_OPT_STDOUT_INFO              = 87,
    INDEX_OPT_ASK_PASS                 = 88,
    INDEX_OPT_PKCS_CIPHER              = 89,
    INDEX_OPT_PROVIDER                 = 90,
    INDEX_OPT_VERSION                  = 91,
    INDEX_OPT_HELP                     = 92,
    INDEX_OPT_MORE_HELP                = 93
} teOptIndex;
/** count of all options for certtool */
#define OPTION_CT    94
/** certtool version */
#define CERTTOOL_VERSION       "@VERSION@"
/** Full certtool version text */
#define CERTTOOL_FULL_VERSION  "certtool @VERSION@"

/**
 *  Interface defines for all options.  Replace "n" with the UPPER_CASED
 *  option name (as in the teOptIndex enumeration above).
 *  e.g. HAVE_OPT(DEBUG)
 */
#define         DESC(n) (certtoolOptions.pOptDesc[INDEX_OPT_## n])
/** 'true' if an option has been specified in any way */
#define     HAVE_OPT(n) (! UNUSED_OPT(& DESC(n)))
/** The string argument to an option. The argument type must be \"string\". */
#define      OPT_ARG(n) (DESC(n).optArg.argString)
/** Mask the option state revealing how an option was specified.
 *  It will be one and only one of \a OPTST_SET, \a OPTST_PRESET,
 * \a OPTST_DEFINED, \a OPTST_RESET or zero.
 */
#define    STATE_OPT(n) (DESC(n).fOptState & OPTST_SET_MASK)
/** Count of option's occurrances *on the command line*. */
#define    COUNT_OPT(n) (DESC(n).optOccCt)
/** mask of \a OPTST_SET and \a OPTST_DEFINED. */
#define    ISSEL_OPT(n) (SELECTED_OPT(&DESC(n)))
/** 'true' if \a HAVE_OPT would yield 'false'. */
#define ISUNUSED_OPT(n) (UNUSED_OPT(& DESC(n)))
/** 'true' if OPTST_DISABLED bit not set. */
#define  ENABLED_OPT(n) (! DISABLED_OPT(& DESC(n)))
/** number of stacked option arguments.
 *  Valid only for stacked option arguments. */
#define  STACKCT_OPT(n) (((tArgList*)(DESC(n).optCookie))->useCt)
/** stacked argument vector.
 *  Valid only for stacked option arguments. */
#define STACKLST_OPT(n) (((tArgList*)(DESC(n).optCookie))->apzArgs)
/** Reset an option. */
#define    CLEAR_OPT(n) STMTS( \
                DESC(n).fOptState &= OPTST_PERSISTENT_MASK;   \
                if ((DESC(n).fOptState & OPTST_INITENABLED) == 0) \
                    DESC(n).fOptState |= OPTST_DISABLED; \
                DESC(n).optCookie = NULL )
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/**
 *  Enumeration of certtool exit codes
 */
typedef enum {
    CERTTOOL_EXIT_SUCCESS         = 0,
    CERTTOOL_EXIT_FAILURE         = 1,
    CERTTOOL_EXIT_USAGE_ERROR     = 64,
    CERTTOOL_EXIT_LIBOPTS_FAILURE = 70
}   certtool_exit_code_t;
/**
 *  Interface defines for specific options.
 * @{
 */
#define VALUE_OPT_DEBUG          'd'

#define OPT_VALUE_DEBUG          (DESC(DEBUG).optArg.argInt)
#define VALUE_OPT_VERBOSE        'V'
#define VALUE_OPT_INFILE         0x1001
#define VALUE_OPT_OUTFILE        0x1002
#define VALUE_OPT_CERTIFICATE_INFO 'i'
#define VALUE_OPT_PUBKEY_INFO    0x1003
#define VALUE_OPT_GENERATE_SELF_SIGNED 's'
#define VALUE_OPT_GENERATE_CERTIFICATE 'c'
#define VALUE_OPT_GENERATE_PROXY 0x1004
#define VALUE_OPT_UPDATE_CERTIFICATE 'u'
#define VALUE_OPT_FINGERPRINT    0x1005
#define VALUE_OPT_KEY_ID         0x1006
#define VALUE_OPT_CERTIFICATE_PUBKEY 0x1007
#define VALUE_OPT_V1             0x1008
#define VALUE_OPT_SIGN_PARAMS    0x1009
#define VALUE_OPT_CRQ_INFO       0x100A
#define VALUE_OPT_GENERATE_REQUEST 'q'
#define VALUE_OPT_NO_CRQ_EXTENSIONS 0x100B
#define VALUE_OPT_P12_INFO       0x100C
#define VALUE_OPT_P12_NAME       0x100D
#define VALUE_OPT_TO_P12         0x100E
#define VALUE_OPT_KEY_INFO       'k'
#define VALUE_OPT_P8_INFO        0x100F
#define VALUE_OPT_GENERATE_PRIVKEY 'p'
#define VALUE_OPT_BITS           0x1010

#define OPT_VALUE_BITS           (DESC(BITS).optArg.argInt)
#define VALUE_OPT_CURVE          0x1011
#define VALUE_OPT_SEC_PARAM      0x1012
#define VALUE_OPT_TO_P8          0x1013
#define VALUE_OPT_PKCS8          '8'
#define VALUE_OPT_PROVABLE       0x1014
#define VALUE_OPT_VERIFY_PROVABLE_PRIVKEY 0x1015
#define VALUE_OPT_SEED           0x1016
#define VALUE_OPT_CRL_INFO       'l'
#define VALUE_OPT_GENERATE_CRL   0x1017
#define VALUE_OPT_VERIFY_CRL     0x1018
#define VALUE_OPT_VERIFY_CHAIN   'e'
#define VALUE_OPT_VERIFY         0x1019
#define VALUE_OPT_VERIFY_HOSTNAME 0x101A
#define VALUE_OPT_VERIFY_EMAIL   0x101B
#define VALUE_OPT_VERIFY_PURPOSE 0x101C
#define VALUE_OPT_VERIFY_ALLOW_BROKEN 0x101D
#define VALUE_OPT_P7_GENERATE    0x101E
#define VALUE_OPT_P7_SIGN        0x101F
#define VALUE_OPT_P7_DETACHED_SIGN 0x1020
#define VALUE_OPT_P7_INCLUDE_CERT 0x1021
#define VALUE_OPT_P7_TIME        0x1022
#define VALUE_OPT_P7_SHOW_DATA   0x1023
#define VALUE_OPT_P7_INFO        0x1024
#define VALUE_OPT_P7_VERIFY      0x1025
#define VALUE_OPT_SMIME_TO_P7    0x1026
#define VALUE_OPT_GENERATE_DH_PARAMS 0x1027
#define VALUE_OPT_GET_DH_PARAMS  0x1028
#define VALUE_OPT_DH_INFO        0x1029
#define VALUE_OPT_LOAD_PRIVKEY   0x102A
#define VALUE_OPT_LOAD_PUBKEY    0x102B
#define VALUE_OPT_LOAD_REQUEST   0x102C
#define VALUE_OPT_LOAD_CERTIFICATE 0x102D
#define VALUE_OPT_LOAD_CA_PRIVKEY 0x102E
#define VALUE_OPT_LOAD_CA_CERTIFICATE 0x102F
#define VALUE_OPT_LOAD_CRL       0x1030
#define VALUE_OPT_LOAD_DATA      0x1031
#define VALUE_OPT_PASSWORD       0x1032
#define VALUE_OPT_NULL_PASSWORD  0x1033
#define VALUE_OPT_EMPTY_PASSWORD 0x1034
#define VALUE_OPT_HEX_NUMBERS    0x1035
#define VALUE_OPT_CPRINT         0x1036
#define VALUE_OPT_RSA            0x1037
#define VALUE_OPT_DSA            0x1038
#define VALUE_OPT_ECC            0x1039
#define VALUE_OPT_ECDSA          0x103A
#define VALUE_OPT_KEY_TYPE       0x103B
#define VALUE_OPT_HASH           0x103C
#define VALUE_OPT_SALT_SIZE      0x103D

#define OPT_VALUE_SALT_SIZE      (DESC(SALT_SIZE).optArg.argInt)
#define VALUE_OPT_INDER          0x103E
#define VALUE_OPT_INRAW          0x103F
#define VALUE_OPT_OUTDER         0x1040
#define VALUE_OPT_OUTRAW         0x1041
#define VALUE_OPT_DISABLE_QUICK_RANDOM 0x1042
#define VALUE_OPT_TEMPLATE       0x1043
#define VALUE_OPT_STDOUT_INFO    0x1044
#define VALUE_OPT_ASK_PASS       0x1045
#define VALUE_OPT_PKCS_CIPHER    0x1046
#define VALUE_OPT_PROVIDER       0x1047
/** option flag (value) for help-value option */
#define VALUE_OPT_HELP          'h'
/** option flag (value) for more-help-value option */
#define VALUE_OPT_MORE_HELP     '!'
/** option flag (value) for version-value option */
#define VALUE_OPT_VERSION       'v'
/*
 *  Interface defines not associated with particular options
 */
#define ERRSKIP_OPTERR  STMTS(certtoolOptions.fOptSet &= ~OPTPROC_ERRSTOP)
#define ERRSTOP_OPTERR  STMTS(certtoolOptions.fOptSet |= OPTPROC_ERRSTOP)
#define RESTART_OPT(n)  STMTS( \
                certtoolOptions.curOptIdx = (n); \
                certtoolOptions.pzCurOpt  = NULL )
#define START_OPT       RESTART_OPT(1)
#define USAGE(c)        (*certtoolOptions.pUsageProc)(&certtoolOptions, c)

#ifdef  __cplusplus
extern "C" {
#endif
/*
 *  global exported definitions
 */
#include <gettext.h>


/* * * * * *
 *
 *  Declare the certtool option descriptor.
 */
extern tOptions certtoolOptions;

#if defined(ENABLE_NLS)
# ifndef _
#   include <stdio.h>
#   ifndef HAVE_GETTEXT
      extern char * gettext(char const *);
#   else
#     include <libintl.h>
#   endif

# ifndef ATTRIBUTE_FORMAT_ARG
#   define ATTRIBUTE_FORMAT_ARG(_a)
# endif

static inline char* aoGetsText(char const* pz) ATTRIBUTE_FORMAT_ARG(1);
static inline char* aoGetsText(char const* pz) {
    if (pz == NULL) return NULL;
    return (char*)gettext(pz);
}
#   define _(s)  aoGetsText(s)
# endif /* _() */

# define OPT_NO_XLAT_CFG_NAMES  STMTS(certtoolOptions.fOptSet |= \
                                    OPTPROC_NXLAT_OPT_CFG;)
# define OPT_NO_XLAT_OPT_NAMES  STMTS(certtoolOptions.fOptSet |= \
                                    OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG;)

# define OPT_XLAT_CFG_NAMES     STMTS(certtoolOptions.fOptSet &= \
                                  ~(OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG);)
# define OPT_XLAT_OPT_NAMES     STMTS(certtoolOptions.fOptSet &= \
                                  ~OPTPROC_NXLAT_OPT;)

#else   /* ENABLE_NLS */
# define OPT_NO_XLAT_CFG_NAMES
# define OPT_NO_XLAT_OPT_NAMES

# define OPT_XLAT_CFG_NAMES
# define OPT_XLAT_OPT_NAMES

# ifndef _
#   define _(_s)  _s
# endif
#endif  /* ENABLE_NLS */

#ifdef  __cplusplus
}
#endif
#endif /* AUTOOPTS_CERTTOOL_ARGS_H_GUARD */

/* certtool-args.h ends here */