/* -*- 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 42:1:17 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-2020 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 * * 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 . */ /** * 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 #include #include /** * 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 172033 #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 #if GCC_VERSION > 40400 #define NOT_REACHED __builtin_unreachable(); #else #define NOT_REACHED #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_TO_RSA = 27, INDEX_OPT_GENERATE_PRIVKEY = 28, INDEX_OPT_KEY_TYPE = 29, INDEX_OPT_BITS = 30, INDEX_OPT_CURVE = 31, INDEX_OPT_SEC_PARAM = 32, INDEX_OPT_TO_P8 = 33, INDEX_OPT_PKCS8 = 34, INDEX_OPT_PROVABLE = 35, INDEX_OPT_VERIFY_PROVABLE_PRIVKEY = 36, INDEX_OPT_SEED = 37, INDEX_OPT_CRL_INFO = 39, INDEX_OPT_GENERATE_CRL = 40, INDEX_OPT_VERIFY_CRL = 41, INDEX_OPT_VERIFY_CHAIN = 43, INDEX_OPT_VERIFY = 44, INDEX_OPT_VERIFY_HOSTNAME = 45, INDEX_OPT_VERIFY_EMAIL = 46, INDEX_OPT_VERIFY_PURPOSE = 47, INDEX_OPT_VERIFY_ALLOW_BROKEN = 48, INDEX_OPT_VERIFY_PROFILE = 49, INDEX_OPT_P7_GENERATE = 51, INDEX_OPT_P7_SIGN = 52, INDEX_OPT_P7_DETACHED_SIGN = 53, INDEX_OPT_P7_INCLUDE_CERT = 54, INDEX_OPT_P7_TIME = 55, INDEX_OPT_P7_SHOW_DATA = 56, INDEX_OPT_P7_INFO = 57, INDEX_OPT_P7_VERIFY = 58, INDEX_OPT_SMIME_TO_P7 = 59, INDEX_OPT_GENERATE_DH_PARAMS = 61, INDEX_OPT_GET_DH_PARAMS = 62, INDEX_OPT_DH_INFO = 63, INDEX_OPT_LOAD_PRIVKEY = 64, INDEX_OPT_LOAD_PUBKEY = 65, INDEX_OPT_LOAD_REQUEST = 66, INDEX_OPT_LOAD_CERTIFICATE = 67, INDEX_OPT_LOAD_CA_PRIVKEY = 68, INDEX_OPT_LOAD_CA_CERTIFICATE = 69, INDEX_OPT_LOAD_CRL = 70, INDEX_OPT_LOAD_DATA = 71, INDEX_OPT_PASSWORD = 72, INDEX_OPT_NULL_PASSWORD = 73, INDEX_OPT_EMPTY_PASSWORD = 74, INDEX_OPT_HEX_NUMBERS = 75, INDEX_OPT_CPRINT = 76, INDEX_OPT_RSA = 77, INDEX_OPT_DSA = 78, INDEX_OPT_ECC = 79, INDEX_OPT_ECDSA = 80, INDEX_OPT_HASH = 81, INDEX_OPT_SALT_SIZE = 82, INDEX_OPT_INDER = 83, INDEX_OPT_INRAW = 84, INDEX_OPT_OUTDER = 85, INDEX_OPT_OUTRAW = 86, INDEX_OPT_DISABLE_QUICK_RANDOM = 87, INDEX_OPT_TEMPLATE = 88, INDEX_OPT_STDOUT_INFO = 89, INDEX_OPT_ASK_PASS = 90, INDEX_OPT_PKCS_CIPHER = 91, INDEX_OPT_PROVIDER = 92, INDEX_OPT_TEXT = 93, INDEX_OPT_VERSION = 94, INDEX_OPT_HELP = 95, INDEX_OPT_MORE_HELP = 96 } teOptIndex; /** count of all options for certtool */ #define OPTION_CT 97 /** certtool version */ #define CERTTOOL_VERSION "3.6.14" /** Full certtool version text */ #define CERTTOOL_FULL_VERSION "certtool 3.6.14" /** * 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_TO_RSA 0x1010 #define VALUE_OPT_GENERATE_PRIVKEY 'p' #define VALUE_OPT_KEY_TYPE 0x1011 #define VALUE_OPT_BITS 0x1012 #define OPT_VALUE_BITS (DESC(BITS).optArg.argInt) #define VALUE_OPT_CURVE 0x1013 #define VALUE_OPT_SEC_PARAM 0x1014 #define VALUE_OPT_TO_P8 0x1015 #define VALUE_OPT_PKCS8 '8' #define VALUE_OPT_PROVABLE 0x1016 #define VALUE_OPT_VERIFY_PROVABLE_PRIVKEY 0x1017 #define VALUE_OPT_SEED 0x1018 #define VALUE_OPT_CRL_INFO 'l' #define VALUE_OPT_GENERATE_CRL 0x1019 #define VALUE_OPT_VERIFY_CRL 0x101A #define VALUE_OPT_VERIFY_CHAIN 'e' #define VALUE_OPT_VERIFY 0x101B #define VALUE_OPT_VERIFY_HOSTNAME 0x101C #define VALUE_OPT_VERIFY_EMAIL 0x101D #define VALUE_OPT_VERIFY_PURPOSE 0x101E #define VALUE_OPT_VERIFY_ALLOW_BROKEN 0x101F #define VALUE_OPT_VERIFY_PROFILE 0x1020 #define VALUE_OPT_P7_GENERATE 0x1021 #define VALUE_OPT_P7_SIGN 0x1022 #define VALUE_OPT_P7_DETACHED_SIGN 0x1023 #define VALUE_OPT_P7_INCLUDE_CERT 0x1024 #define VALUE_OPT_P7_TIME 0x1025 #define VALUE_OPT_P7_SHOW_DATA 0x1026 #define VALUE_OPT_P7_INFO 0x1027 #define VALUE_OPT_P7_VERIFY 0x1028 #define VALUE_OPT_SMIME_TO_P7 0x1029 #define VALUE_OPT_GENERATE_DH_PARAMS 0x102A #define VALUE_OPT_GET_DH_PARAMS 0x102B #define VALUE_OPT_DH_INFO 0x102C #define VALUE_OPT_LOAD_PRIVKEY 0x102D #define VALUE_OPT_LOAD_PUBKEY 0x102E #define VALUE_OPT_LOAD_REQUEST 0x102F #define VALUE_OPT_LOAD_CERTIFICATE 0x1030 #define VALUE_OPT_LOAD_CA_PRIVKEY 0x1031 #define VALUE_OPT_LOAD_CA_CERTIFICATE 0x1032 #define VALUE_OPT_LOAD_CRL 0x1033 #define VALUE_OPT_LOAD_DATA 0x1034 #define VALUE_OPT_PASSWORD 0x1035 #define VALUE_OPT_NULL_PASSWORD 0x1036 #define VALUE_OPT_EMPTY_PASSWORD 0x1037 #define VALUE_OPT_HEX_NUMBERS 0x1038 #define VALUE_OPT_CPRINT 0x1039 #define VALUE_OPT_RSA 0x103A #define VALUE_OPT_DSA 0x103B #define VALUE_OPT_ECC 0x103C #define VALUE_OPT_ECDSA 0x103D #define VALUE_OPT_HASH 0x103E #define VALUE_OPT_SALT_SIZE 0x103F #define OPT_VALUE_SALT_SIZE (DESC(SALT_SIZE).optArg.argInt) #define VALUE_OPT_INDER 0x1040 #define VALUE_OPT_INRAW 0x1041 #define VALUE_OPT_OUTDER 0x1042 #define VALUE_OPT_OUTRAW 0x1043 #define VALUE_OPT_DISABLE_QUICK_RANDOM 0x1044 #define VALUE_OPT_TEMPLATE 0x1045 #define VALUE_OPT_STDOUT_INFO 0x1046 #define VALUE_OPT_ASK_PASS 0x1047 #define VALUE_OPT_PKCS_CIPHER 0x1048 #define VALUE_OPT_PROVIDER 0x1049 #define VALUE_OPT_TEXT 0x104A /** 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 /* * * * * * * * Declare the certtool option descriptor. */ extern tOptions certtoolOptions; #if defined(ENABLE_NLS) # ifndef _ # include # ifndef HAVE_GETTEXT extern char * gettext(char const *); # else # include # 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 */