Update contrib.
1 /* crypto/x509/x509_err.c */
2 /* ====================================================================
3 * Copyright (c) 1999-2005 The OpenSSL Project. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in
14 * the documentation and/or other materials provided with the
17 * 3. All advertising materials mentioning features or use of this
18 * software must display the following acknowledgment:
19 * "This product includes software developed by the OpenSSL Project
20 * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
22 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
23 * endorse or promote products derived from this software without
24 * prior written permission. For written permission, please contact
25 * openssl-core@OpenSSL.org.
27 * 5. Products derived from this software may not be called "OpenSSL"
28 * nor may "OpenSSL" appear in their names without prior written
29 * permission of the OpenSSL Project.
31 * 6. Redistributions of any form whatsoever must retain the following
33 * "This product includes software developed by the OpenSSL Project
34 * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
36 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
37 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
38 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
39 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
40 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
42 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
43 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
44 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
45 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
46 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
47 * OF THE POSSIBILITY OF SUCH DAMAGE.
48 * ====================================================================
50 * This product includes cryptographic software written by Eric Young
51 * (eay@cryptsoft.com). This product includes software written by Tim
52 * Hudson (tjh@cryptsoft.com).
56 © Portions copyright (c) 2006 Nokia Corporation. All rights reserved.
59 /* NOTE: this file was auto generated by the mkerr.pl script: any changes
60 * made to it will be overwritten when the script next updates this file,
61 * only reason strings will be preserved.
65 #include <openssl/err.h>
66 #include <openssl/x509.h>
67 #if (defined(SYMBIAN) && (defined(__WINSCW__) || defined(__WINS__)))
68 #include "libcrypto_wsd_macros.h"
69 #include "libcrypto_wsd.h"
73 /* BEGIN ERROR CODES */
74 #ifndef OPENSSL_NO_ERR
76 #define ERR_FUNC(func) ERR_PACK(ERR_LIB_X509,func,0)
77 #define ERR_REASON(reason) ERR_PACK(ERR_LIB_X509,0,reason)
80 static ERR_STRING_DATA X509_str_functs[]=
82 {ERR_FUNC(X509_F_ADD_CERT_DIR), "ADD_CERT_DIR"},
83 {ERR_FUNC(X509_F_BY_FILE_CTRL), "BY_FILE_CTRL"},
84 {ERR_FUNC(X509_F_CHECK_POLICY), "CHECK_POLICY"},
85 {ERR_FUNC(X509_F_DIR_CTRL), "DIR_CTRL"},
86 {ERR_FUNC(X509_F_GET_CERT_BY_SUBJECT), "GET_CERT_BY_SUBJECT"},
87 {ERR_FUNC(X509_F_NETSCAPE_SPKI_B64_DECODE), "NETSCAPE_SPKI_b64_decode"},
88 {ERR_FUNC(X509_F_NETSCAPE_SPKI_B64_ENCODE), "NETSCAPE_SPKI_b64_encode"},
89 {ERR_FUNC(X509_F_X509AT_ADD1_ATTR), "X509at_add1_attr"},
90 {ERR_FUNC(X509_F_X509V3_ADD_EXT), "X509v3_add_ext"},
91 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_NID), "X509_ATTRIBUTE_create_by_NID"},
92 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_OBJ), "X509_ATTRIBUTE_create_by_OBJ"},
93 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_TXT), "X509_ATTRIBUTE_create_by_txt"},
94 {ERR_FUNC(X509_F_X509_ATTRIBUTE_GET0_DATA), "X509_ATTRIBUTE_get0_data"},
95 {ERR_FUNC(X509_F_X509_ATTRIBUTE_SET1_DATA), "X509_ATTRIBUTE_set1_data"},
96 {ERR_FUNC(X509_F_X509_CHECK_PRIVATE_KEY), "X509_check_private_key"},
97 {ERR_FUNC(X509_F_X509_CRL_PRINT_FP), "X509_CRL_print_fp"},
98 {ERR_FUNC(X509_F_X509_EXTENSION_CREATE_BY_NID), "X509_EXTENSION_create_by_NID"},
99 {ERR_FUNC(X509_F_X509_EXTENSION_CREATE_BY_OBJ), "X509_EXTENSION_create_by_OBJ"},
100 {ERR_FUNC(X509_F_X509_GET_PUBKEY_PARAMETERS), "X509_get_pubkey_parameters"},
101 {ERR_FUNC(X509_F_X509_LOAD_CERT_CRL_FILE), "X509_load_cert_crl_file"},
102 {ERR_FUNC(X509_F_X509_LOAD_CERT_FILE), "X509_load_cert_file"},
103 {ERR_FUNC(X509_F_X509_LOAD_CRL_FILE), "X509_load_crl_file"},
104 {ERR_FUNC(X509_F_X509_NAME_ADD_ENTRY), "X509_NAME_add_entry"},
105 {ERR_FUNC(X509_F_X509_NAME_ENTRY_CREATE_BY_NID), "X509_NAME_ENTRY_create_by_NID"},
106 {ERR_FUNC(X509_F_X509_NAME_ENTRY_CREATE_BY_TXT), "X509_NAME_ENTRY_create_by_txt"},
107 {ERR_FUNC(X509_F_X509_NAME_ENTRY_SET_OBJECT), "X509_NAME_ENTRY_set_object"},
108 {ERR_FUNC(X509_F_X509_NAME_ONELINE), "X509_NAME_oneline"},
109 {ERR_FUNC(X509_F_X509_NAME_PRINT), "X509_NAME_print"},
110 {ERR_FUNC(X509_F_X509_PRINT_EX_FP), "X509_print_ex_fp"},
111 {ERR_FUNC(X509_F_X509_PUBKEY_GET), "X509_PUBKEY_get"},
112 {ERR_FUNC(X509_F_X509_PUBKEY_SET), "X509_PUBKEY_set"},
113 {ERR_FUNC(X509_F_X509_REQ_CHECK_PRIVATE_KEY), "X509_REQ_check_private_key"},
114 {ERR_FUNC(X509_F_X509_REQ_PRINT_EX), "X509_REQ_print_ex"},
115 {ERR_FUNC(X509_F_X509_REQ_PRINT_FP), "X509_REQ_print_fp"},
116 {ERR_FUNC(X509_F_X509_REQ_TO_X509), "X509_REQ_to_X509"},
117 {ERR_FUNC(X509_F_X509_STORE_ADD_CERT), "X509_STORE_add_cert"},
118 {ERR_FUNC(X509_F_X509_STORE_ADD_CRL), "X509_STORE_add_crl"},
119 {ERR_FUNC(X509_F_X509_STORE_CTX_GET1_ISSUER), "X509_STORE_CTX_get1_issuer"},
120 {ERR_FUNC(X509_F_X509_STORE_CTX_INIT), "X509_STORE_CTX_init"},
121 {ERR_FUNC(X509_F_X509_STORE_CTX_NEW), "X509_STORE_CTX_new"},
122 {ERR_FUNC(X509_F_X509_STORE_CTX_PURPOSE_INHERIT), "X509_STORE_CTX_purpose_inherit"},
123 {ERR_FUNC(X509_F_X509_TO_X509_REQ), "X509_to_X509_REQ"},
124 {ERR_FUNC(X509_F_X509_TRUST_ADD), "X509_TRUST_add"},
125 {ERR_FUNC(X509_F_X509_TRUST_SET), "X509_TRUST_set"},
126 {ERR_FUNC(X509_F_X509_VERIFY_CERT), "X509_verify_cert"},
130 static ERR_STRING_DATA X509_str_reasons[]=
132 {ERR_REASON(X509_R_BAD_X509_FILETYPE) ,"bad x509 filetype"},
133 {ERR_REASON(X509_R_BASE64_DECODE_ERROR) ,"base64 decode error"},
134 {ERR_REASON(X509_R_CANT_CHECK_DH_KEY) ,"cant check dh key"},
135 {ERR_REASON(X509_R_CERT_ALREADY_IN_HASH_TABLE),"cert already in hash table"},
136 {ERR_REASON(X509_R_ERR_ASN1_LIB) ,"err asn1 lib"},
137 {ERR_REASON(X509_R_INVALID_DIRECTORY) ,"invalid directory"},
138 {ERR_REASON(X509_R_INVALID_FIELD_NAME) ,"invalid field name"},
139 {ERR_REASON(X509_R_INVALID_TRUST) ,"invalid trust"},
140 {ERR_REASON(X509_R_KEY_TYPE_MISMATCH) ,"key type mismatch"},
141 {ERR_REASON(X509_R_KEY_VALUES_MISMATCH) ,"key values mismatch"},
142 {ERR_REASON(X509_R_LOADING_CERT_DIR) ,"loading cert dir"},
143 {ERR_REASON(X509_R_LOADING_DEFAULTS) ,"loading defaults"},
144 {ERR_REASON(X509_R_NO_CERT_SET_FOR_US_TO_VERIFY),"no cert set for us to verify"},
145 {ERR_REASON(X509_R_SHOULD_RETRY) ,"should retry"},
146 {ERR_REASON(X509_R_UNABLE_TO_FIND_PARAMETERS_IN_CHAIN),"unable to find parameters in chain"},
147 {ERR_REASON(X509_R_UNABLE_TO_GET_CERTS_PUBLIC_KEY),"unable to get certs public key"},
148 {ERR_REASON(X509_R_UNKNOWN_KEY_TYPE) ,"unknown key type"},
149 {ERR_REASON(X509_R_UNKNOWN_NID) ,"unknown nid"},
150 {ERR_REASON(X509_R_UNKNOWN_PURPOSE_ID) ,"unknown purpose id"},
151 {ERR_REASON(X509_R_UNKNOWN_TRUST_ID) ,"unknown trust id"},
152 {ERR_REASON(X509_R_UNSUPPORTED_ALGORITHM),"unsupported algorithm"},
153 {ERR_REASON(X509_R_WRONG_LOOKUP_TYPE) ,"wrong lookup type"},
154 {ERR_REASON(X509_R_WRONG_TYPE) ,"wrong type"},
159 const ERR_STRING_DATA temp_X509_str_functs[]=
161 {ERR_FUNC(X509_F_ADD_CERT_DIR), "ADD_CERT_DIR"},
162 {ERR_FUNC(X509_F_BY_FILE_CTRL), "BY_FILE_CTRL"},
163 {ERR_FUNC(X509_F_CHECK_POLICY), "CHECK_POLICY"},
164 {ERR_FUNC(X509_F_DIR_CTRL), "DIR_CTRL"},
165 {ERR_FUNC(X509_F_GET_CERT_BY_SUBJECT), "GET_CERT_BY_SUBJECT"},
166 {ERR_FUNC(X509_F_NETSCAPE_SPKI_B64_DECODE), "NETSCAPE_SPKI_b64_decode"},
167 {ERR_FUNC(X509_F_NETSCAPE_SPKI_B64_ENCODE), "NETSCAPE_SPKI_b64_encode"},
168 {ERR_FUNC(X509_F_X509AT_ADD1_ATTR), "X509at_add1_attr"},
169 {ERR_FUNC(X509_F_X509V3_ADD_EXT), "X509v3_add_ext"},
170 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_NID), "X509_ATTRIBUTE_create_by_NID"},
171 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_OBJ), "X509_ATTRIBUTE_create_by_OBJ"},
172 {ERR_FUNC(X509_F_X509_ATTRIBUTE_CREATE_BY_TXT), "X509_ATTRIBUTE_create_by_txt"},
173 {ERR_FUNC(X509_F_X509_ATTRIBUTE_GET0_DATA), "X509_ATTRIBUTE_get0_data"},
174 {ERR_FUNC(X509_F_X509_ATTRIBUTE_SET1_DATA), "X509_ATTRIBUTE_set1_data"},
175 {ERR_FUNC(X509_F_X509_CHECK_PRIVATE_KEY), "X509_check_private_key"},
176 {ERR_FUNC(X509_F_X509_CRL_PRINT_FP), "X509_CRL_print_fp"},
177 {ERR_FUNC(X509_F_X509_EXTENSION_CREATE_BY_NID), "X509_EXTENSION_create_by_NID"},
178 {ERR_FUNC(X509_F_X509_EXTENSION_CREATE_BY_OBJ), "X509_EXTENSION_create_by_OBJ"},
179 {ERR_FUNC(X509_F_X509_GET_PUBKEY_PARAMETERS), "X509_get_pubkey_parameters"},
180 {ERR_FUNC(X509_F_X509_LOAD_CERT_CRL_FILE), "X509_load_cert_crl_file"},
181 {ERR_FUNC(X509_F_X509_LOAD_CERT_FILE), "X509_load_cert_file"},
182 {ERR_FUNC(X509_F_X509_LOAD_CRL_FILE), "X509_load_crl_file"},
183 {ERR_FUNC(X509_F_X509_NAME_ADD_ENTRY), "X509_NAME_add_entry"},
184 {ERR_FUNC(X509_F_X509_NAME_ENTRY_CREATE_BY_NID), "X509_NAME_ENTRY_create_by_NID"},
185 {ERR_FUNC(X509_F_X509_NAME_ENTRY_CREATE_BY_TXT), "X509_NAME_ENTRY_create_by_txt"},
186 {ERR_FUNC(X509_F_X509_NAME_ENTRY_SET_OBJECT), "X509_NAME_ENTRY_set_object"},
187 {ERR_FUNC(X509_F_X509_NAME_ONELINE), "X509_NAME_oneline"},
188 {ERR_FUNC(X509_F_X509_NAME_PRINT), "X509_NAME_print"},
189 {ERR_FUNC(X509_F_X509_PRINT_EX_FP), "X509_print_ex_fp"},
190 {ERR_FUNC(X509_F_X509_PUBKEY_GET), "X509_PUBKEY_get"},
191 {ERR_FUNC(X509_F_X509_PUBKEY_SET), "X509_PUBKEY_set"},
192 {ERR_FUNC(X509_F_X509_REQ_CHECK_PRIVATE_KEY), "X509_REQ_check_private_key"},
193 {ERR_FUNC(X509_F_X509_REQ_PRINT_EX), "X509_REQ_print_ex"},
194 {ERR_FUNC(X509_F_X509_REQ_PRINT_FP), "X509_REQ_print_fp"},
195 {ERR_FUNC(X509_F_X509_REQ_TO_X509), "X509_REQ_to_X509"},
196 {ERR_FUNC(X509_F_X509_STORE_ADD_CERT), "X509_STORE_add_cert"},
197 {ERR_FUNC(X509_F_X509_STORE_ADD_CRL), "X509_STORE_add_crl"},
198 {ERR_FUNC(X509_F_X509_STORE_CTX_GET1_ISSUER), "X509_STORE_CTX_get1_issuer"},
199 {ERR_FUNC(X509_F_X509_STORE_CTX_INIT), "X509_STORE_CTX_init"},
200 {ERR_FUNC(X509_F_X509_STORE_CTX_NEW), "X509_STORE_CTX_new"},
201 {ERR_FUNC(X509_F_X509_STORE_CTX_PURPOSE_INHERIT), "X509_STORE_CTX_purpose_inherit"},
202 {ERR_FUNC(X509_F_X509_TO_X509_REQ), "X509_to_X509_REQ"},
203 {ERR_FUNC(X509_F_X509_TRUST_ADD), "X509_TRUST_add"},
204 {ERR_FUNC(X509_F_X509_TRUST_SET), "X509_TRUST_set"},
205 {ERR_FUNC(X509_F_X509_VERIFY_CERT), "X509_verify_cert"},
209 const ERR_STRING_DATA temp_X509_str_reasons[]=
211 {ERR_REASON(X509_R_BAD_X509_FILETYPE) ,"bad x509 filetype"},
212 {ERR_REASON(X509_R_BASE64_DECODE_ERROR) ,"base64 decode error"},
213 {ERR_REASON(X509_R_CANT_CHECK_DH_KEY) ,"cant check dh key"},
214 {ERR_REASON(X509_R_CERT_ALREADY_IN_HASH_TABLE),"cert already in hash table"},
215 {ERR_REASON(X509_R_ERR_ASN1_LIB) ,"err asn1 lib"},
216 {ERR_REASON(X509_R_INVALID_DIRECTORY) ,"invalid directory"},
217 {ERR_REASON(X509_R_INVALID_FIELD_NAME) ,"invalid field name"},
218 {ERR_REASON(X509_R_INVALID_TRUST) ,"invalid trust"},
219 {ERR_REASON(X509_R_KEY_TYPE_MISMATCH) ,"key type mismatch"},
220 {ERR_REASON(X509_R_KEY_VALUES_MISMATCH) ,"key values mismatch"},
221 {ERR_REASON(X509_R_LOADING_CERT_DIR) ,"loading cert dir"},
222 {ERR_REASON(X509_R_LOADING_DEFAULTS) ,"loading defaults"},
223 {ERR_REASON(X509_R_NO_CERT_SET_FOR_US_TO_VERIFY),"no cert set for us to verify"},
224 {ERR_REASON(X509_R_SHOULD_RETRY) ,"should retry"},
225 {ERR_REASON(X509_R_UNABLE_TO_FIND_PARAMETERS_IN_CHAIN),"unable to find parameters in chain"},
226 {ERR_REASON(X509_R_UNABLE_TO_GET_CERTS_PUBLIC_KEY),"unable to get certs public key"},
227 {ERR_REASON(X509_R_UNKNOWN_KEY_TYPE) ,"unknown key type"},
228 {ERR_REASON(X509_R_UNKNOWN_NID) ,"unknown nid"},
229 {ERR_REASON(X509_R_UNKNOWN_PURPOSE_ID) ,"unknown purpose id"},
230 {ERR_REASON(X509_R_UNKNOWN_TRUST_ID) ,"unknown trust id"},
231 {ERR_REASON(X509_R_UNSUPPORTED_ALGORITHM),"unsupported algorithm"},
232 {ERR_REASON(X509_R_WRONG_LOOKUP_TYPE) ,"wrong lookup type"},
233 {ERR_REASON(X509_R_WRONG_TYPE) ,"wrong type"},
237 GET_STATIC_ARRAY_FROM_TLS(X509_str_functs,x509_err,ERR_STRING_DATA)
238 GET_STATIC_ARRAY_FROM_TLS(X509_str_reasons,x509_err,ERR_STRING_DATA)
239 #define X509_str_functs (GET_WSD_VAR_NAME(X509_str_functs,x509_err, s)())
240 #define X509_str_reasons (GET_WSD_VAR_NAME(X509_str_reasons,x509_err, s)())
246 EXPORT_C void ERR_load_X509_strings(void)
248 #ifndef OPENSSL_NO_ERR
250 if (ERR_func_error_string(X509_str_functs[0].error) == NULL)
252 ERR_load_strings(0,X509_str_functs);
253 ERR_load_strings(0,X509_str_reasons);