cms_err.c revision 296465
1/* crypto/cms/cms_err.c */
2/* ====================================================================
3 * Copyright (c) 1999-2008 The OpenSSL Project.  All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright
10 *    notice, this list of conditions and the following disclaimer.
11 *
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
15 *    distribution.
16 *
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/)"
21 *
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.
26 *
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.
30 *
31 * 6. Redistributions of any form whatsoever must retain the following
32 *    acknowledgment:
33 *    "This product includes software developed by the OpenSSL Project
34 *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
35 *
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 * ====================================================================
49 *
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).
53 *
54 */
55
56/*
57 * NOTE: this file was auto generated by the mkerr.pl script: any changes
58 * made to it will be overwritten when the script next updates this file,
59 * only reason strings will be preserved.
60 */
61
62#include <stdio.h>
63#include <openssl/err.h>
64#include <openssl/cms.h>
65
66/* BEGIN ERROR CODES */
67#ifndef OPENSSL_NO_ERR
68
69# define ERR_FUNC(func) ERR_PACK(ERR_LIB_CMS,func,0)
70# define ERR_REASON(reason) ERR_PACK(ERR_LIB_CMS,0,reason)
71
72static ERR_STRING_DATA CMS_str_functs[] = {
73    {ERR_FUNC(CMS_F_CHECK_CONTENT), "CHECK_CONTENT"},
74    {ERR_FUNC(CMS_F_CMS_ADD0_CERT), "CMS_add0_cert"},
75    {ERR_FUNC(CMS_F_CMS_ADD0_RECIPIENT_KEY), "CMS_add0_recipient_key"},
76    {ERR_FUNC(CMS_F_CMS_ADD1_RECEIPTREQUEST), "CMS_add1_ReceiptRequest"},
77    {ERR_FUNC(CMS_F_CMS_ADD1_RECIPIENT_CERT), "CMS_add1_recipient_cert"},
78    {ERR_FUNC(CMS_F_CMS_ADD1_SIGNER), "CMS_add1_signer"},
79    {ERR_FUNC(CMS_F_CMS_ADD1_SIGNINGTIME), "CMS_ADD1_SIGNINGTIME"},
80    {ERR_FUNC(CMS_F_CMS_COMPRESS), "CMS_compress"},
81    {ERR_FUNC(CMS_F_CMS_COMPRESSEDDATA_CREATE), "cms_CompressedData_create"},
82    {ERR_FUNC(CMS_F_CMS_COMPRESSEDDATA_INIT_BIO),
83     "cms_CompressedData_init_bio"},
84    {ERR_FUNC(CMS_F_CMS_COPY_CONTENT), "CMS_COPY_CONTENT"},
85    {ERR_FUNC(CMS_F_CMS_COPY_MESSAGEDIGEST), "CMS_COPY_MESSAGEDIGEST"},
86    {ERR_FUNC(CMS_F_CMS_DATA), "CMS_data"},
87    {ERR_FUNC(CMS_F_CMS_DATAFINAL), "CMS_dataFinal"},
88    {ERR_FUNC(CMS_F_CMS_DATAINIT), "CMS_dataInit"},
89    {ERR_FUNC(CMS_F_CMS_DECRYPT), "CMS_decrypt"},
90    {ERR_FUNC(CMS_F_CMS_DECRYPT_SET1_KEY), "CMS_decrypt_set1_key"},
91    {ERR_FUNC(CMS_F_CMS_DECRYPT_SET1_PKEY), "CMS_decrypt_set1_pkey"},
92    {ERR_FUNC(CMS_F_CMS_DIGESTALGORITHM_FIND_CTX),
93     "cms_DigestAlgorithm_find_ctx"},
94    {ERR_FUNC(CMS_F_CMS_DIGESTALGORITHM_INIT_BIO),
95     "cms_DigestAlgorithm_init_bio"},
96    {ERR_FUNC(CMS_F_CMS_DIGESTEDDATA_DO_FINAL), "cms_DigestedData_do_final"},
97    {ERR_FUNC(CMS_F_CMS_DIGEST_VERIFY), "CMS_digest_verify"},
98    {ERR_FUNC(CMS_F_CMS_ENCODE_RECEIPT), "cms_encode_Receipt"},
99    {ERR_FUNC(CMS_F_CMS_ENCRYPT), "CMS_encrypt"},
100    {ERR_FUNC(CMS_F_CMS_ENCRYPTEDCONTENT_INIT_BIO),
101     "cms_EncryptedContent_init_bio"},
102    {ERR_FUNC(CMS_F_CMS_ENCRYPTEDDATA_DECRYPT), "CMS_EncryptedData_decrypt"},
103    {ERR_FUNC(CMS_F_CMS_ENCRYPTEDDATA_ENCRYPT), "CMS_EncryptedData_encrypt"},
104    {ERR_FUNC(CMS_F_CMS_ENCRYPTEDDATA_SET1_KEY),
105     "CMS_EncryptedData_set1_key"},
106    {ERR_FUNC(CMS_F_CMS_ENVELOPEDDATA_CREATE), "CMS_EnvelopedData_create"},
107    {ERR_FUNC(CMS_F_CMS_ENVELOPEDDATA_INIT_BIO),
108     "cms_EnvelopedData_init_bio"},
109    {ERR_FUNC(CMS_F_CMS_ENVELOPED_DATA_INIT), "CMS_ENVELOPED_DATA_INIT"},
110    {ERR_FUNC(CMS_F_CMS_FINAL), "CMS_final"},
111    {ERR_FUNC(CMS_F_CMS_GET0_CERTIFICATE_CHOICES),
112     "CMS_GET0_CERTIFICATE_CHOICES"},
113    {ERR_FUNC(CMS_F_CMS_GET0_CONTENT), "CMS_get0_content"},
114    {ERR_FUNC(CMS_F_CMS_GET0_ECONTENT_TYPE), "CMS_GET0_ECONTENT_TYPE"},
115    {ERR_FUNC(CMS_F_CMS_GET0_ENVELOPED), "CMS_GET0_ENVELOPED"},
116    {ERR_FUNC(CMS_F_CMS_GET0_REVOCATION_CHOICES),
117     "CMS_GET0_REVOCATION_CHOICES"},
118    {ERR_FUNC(CMS_F_CMS_GET0_SIGNED), "CMS_GET0_SIGNED"},
119    {ERR_FUNC(CMS_F_CMS_MSGSIGDIGEST_ADD1), "cms_msgSigDigest_add1"},
120    {ERR_FUNC(CMS_F_CMS_RECEIPTREQUEST_CREATE0),
121     "CMS_ReceiptRequest_create0"},
122    {ERR_FUNC(CMS_F_CMS_RECEIPT_VERIFY), "cms_Receipt_verify"},
123    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_DECRYPT), "CMS_RecipientInfo_decrypt"},
124    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KEKRI_DECRYPT),
125     "CMS_RECIPIENTINFO_KEKRI_DECRYPT"},
126    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KEKRI_ENCRYPT),
127     "CMS_RECIPIENTINFO_KEKRI_ENCRYPT"},
128    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KEKRI_GET0_ID),
129     "CMS_RecipientInfo_kekri_get0_id"},
130    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KEKRI_ID_CMP),
131     "CMS_RecipientInfo_kekri_id_cmp"},
132    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KTRI_CERT_CMP),
133     "CMS_RecipientInfo_ktri_cert_cmp"},
134    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KTRI_DECRYPT),
135     "CMS_RECIPIENTINFO_KTRI_DECRYPT"},
136    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KTRI_ENCRYPT),
137     "CMS_RECIPIENTINFO_KTRI_ENCRYPT"},
138    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KTRI_GET0_ALGS),
139     "CMS_RecipientInfo_ktri_get0_algs"},
140    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_KTRI_GET0_SIGNER_ID),
141     "CMS_RecipientInfo_ktri_get0_signer_id"},
142    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_SET0_KEY),
143     "CMS_RecipientInfo_set0_key"},
144    {ERR_FUNC(CMS_F_CMS_RECIPIENTINFO_SET0_PKEY),
145     "CMS_RecipientInfo_set0_pkey"},
146    {ERR_FUNC(CMS_F_CMS_SET1_SIGNERIDENTIFIER), "cms_set1_SignerIdentifier"},
147    {ERR_FUNC(CMS_F_CMS_SET_DETACHED), "CMS_set_detached"},
148    {ERR_FUNC(CMS_F_CMS_SIGN), "CMS_sign"},
149    {ERR_FUNC(CMS_F_CMS_SIGNED_DATA_INIT), "CMS_SIGNED_DATA_INIT"},
150    {ERR_FUNC(CMS_F_CMS_SIGNERINFO_CONTENT_SIGN),
151     "CMS_SIGNERINFO_CONTENT_SIGN"},
152    {ERR_FUNC(CMS_F_CMS_SIGNERINFO_SIGN), "CMS_SignerInfo_sign"},
153    {ERR_FUNC(CMS_F_CMS_SIGNERINFO_VERIFY), "CMS_SignerInfo_verify"},
154    {ERR_FUNC(CMS_F_CMS_SIGNERINFO_VERIFY_CERT),
155     "CMS_SIGNERINFO_VERIFY_CERT"},
156    {ERR_FUNC(CMS_F_CMS_SIGNERINFO_VERIFY_CONTENT),
157     "CMS_SignerInfo_verify_content"},
158    {ERR_FUNC(CMS_F_CMS_SIGN_RECEIPT), "CMS_sign_receipt"},
159    {ERR_FUNC(CMS_F_CMS_STREAM), "CMS_STREAM"},
160    {ERR_FUNC(CMS_F_CMS_UNCOMPRESS), "CMS_uncompress"},
161    {ERR_FUNC(CMS_F_CMS_VERIFY), "CMS_verify"},
162    {0, NULL}
163};
164
165static ERR_STRING_DATA CMS_str_reasons[] = {
166    {ERR_REASON(CMS_R_ADD_SIGNER_ERROR), "add signer error"},
167    {ERR_REASON(CMS_R_CERTIFICATE_ALREADY_PRESENT),
168     "certificate already present"},
169    {ERR_REASON(CMS_R_CERTIFICATE_HAS_NO_KEYID), "certificate has no keyid"},
170    {ERR_REASON(CMS_R_CERTIFICATE_VERIFY_ERROR), "certificate verify error"},
171    {ERR_REASON(CMS_R_CIPHER_INITIALISATION_ERROR),
172     "cipher initialisation error"},
173    {ERR_REASON(CMS_R_CIPHER_PARAMETER_INITIALISATION_ERROR),
174     "cipher parameter initialisation error"},
175    {ERR_REASON(CMS_R_CMS_DATAFINAL_ERROR), "cms datafinal error"},
176    {ERR_REASON(CMS_R_CMS_LIB), "cms lib"},
177    {ERR_REASON(CMS_R_CONTENTIDENTIFIER_MISMATCH),
178     "contentidentifier mismatch"},
179    {ERR_REASON(CMS_R_CONTENT_NOT_FOUND), "content not found"},
180    {ERR_REASON(CMS_R_CONTENT_TYPE_MISMATCH), "content type mismatch"},
181    {ERR_REASON(CMS_R_CONTENT_TYPE_NOT_COMPRESSED_DATA),
182     "content type not compressed data"},
183    {ERR_REASON(CMS_R_CONTENT_TYPE_NOT_ENVELOPED_DATA),
184     "content type not enveloped data"},
185    {ERR_REASON(CMS_R_CONTENT_TYPE_NOT_SIGNED_DATA),
186     "content type not signed data"},
187    {ERR_REASON(CMS_R_CONTENT_VERIFY_ERROR), "content verify error"},
188    {ERR_REASON(CMS_R_CTRL_ERROR), "ctrl error"},
189    {ERR_REASON(CMS_R_CTRL_FAILURE), "ctrl failure"},
190    {ERR_REASON(CMS_R_DECRYPT_ERROR), "decrypt error"},
191    {ERR_REASON(CMS_R_DIGEST_ERROR), "digest error"},
192    {ERR_REASON(CMS_R_ERROR_GETTING_PUBLIC_KEY), "error getting public key"},
193    {ERR_REASON(CMS_R_ERROR_READING_MESSAGEDIGEST_ATTRIBUTE),
194     "error reading messagedigest attribute"},
195    {ERR_REASON(CMS_R_ERROR_SETTING_KEY), "error setting key"},
196    {ERR_REASON(CMS_R_ERROR_SETTING_RECIPIENTINFO),
197     "error setting recipientinfo"},
198    {ERR_REASON(CMS_R_INVALID_ENCRYPTED_KEY_LENGTH),
199     "invalid encrypted key length"},
200    {ERR_REASON(CMS_R_INVALID_KEY_LENGTH), "invalid key length"},
201    {ERR_REASON(CMS_R_MD_BIO_INIT_ERROR), "md bio init error"},
202    {ERR_REASON(CMS_R_MESSAGEDIGEST_ATTRIBUTE_WRONG_LENGTH),
203     "messagedigest attribute wrong length"},
204    {ERR_REASON(CMS_R_MESSAGEDIGEST_WRONG_LENGTH),
205     "messagedigest wrong length"},
206    {ERR_REASON(CMS_R_MSGSIGDIGEST_ERROR), "msgsigdigest error"},
207    {ERR_REASON(CMS_R_MSGSIGDIGEST_VERIFICATION_FAILURE),
208     "msgsigdigest verification failure"},
209    {ERR_REASON(CMS_R_MSGSIGDIGEST_WRONG_LENGTH),
210     "msgsigdigest wrong length"},
211    {ERR_REASON(CMS_R_NEED_ONE_SIGNER), "need one signer"},
212    {ERR_REASON(CMS_R_NOT_A_SIGNED_RECEIPT), "not a signed receipt"},
213    {ERR_REASON(CMS_R_NOT_ENCRYPTED_DATA), "not encrypted data"},
214    {ERR_REASON(CMS_R_NOT_KEK), "not kek"},
215    {ERR_REASON(CMS_R_NOT_KEY_TRANSPORT), "not key transport"},
216    {ERR_REASON(CMS_R_NOT_SUPPORTED_FOR_THIS_KEY_TYPE),
217     "not supported for this key type"},
218    {ERR_REASON(CMS_R_NO_CIPHER), "no cipher"},
219    {ERR_REASON(CMS_R_NO_CONTENT), "no content"},
220    {ERR_REASON(CMS_R_NO_CONTENT_TYPE), "no content type"},
221    {ERR_REASON(CMS_R_NO_DEFAULT_DIGEST), "no default digest"},
222    {ERR_REASON(CMS_R_NO_DIGEST_SET), "no digest set"},
223    {ERR_REASON(CMS_R_NO_KEY), "no key"},
224    {ERR_REASON(CMS_R_NO_KEY_OR_CERT), "no key or cert"},
225    {ERR_REASON(CMS_R_NO_MATCHING_DIGEST), "no matching digest"},
226    {ERR_REASON(CMS_R_NO_MATCHING_RECIPIENT), "no matching recipient"},
227    {ERR_REASON(CMS_R_NO_MATCHING_SIGNATURE), "no matching signature"},
228    {ERR_REASON(CMS_R_NO_MSGSIGDIGEST), "no msgsigdigest"},
229    {ERR_REASON(CMS_R_NO_PRIVATE_KEY), "no private key"},
230    {ERR_REASON(CMS_R_NO_PUBLIC_KEY), "no public key"},
231    {ERR_REASON(CMS_R_NO_RECEIPT_REQUEST), "no receipt request"},
232    {ERR_REASON(CMS_R_NO_SIGNERS), "no signers"},
233    {ERR_REASON(CMS_R_PRIVATE_KEY_DOES_NOT_MATCH_CERTIFICATE),
234     "private key does not match certificate"},
235    {ERR_REASON(CMS_R_RECEIPT_DECODE_ERROR), "receipt decode error"},
236    {ERR_REASON(CMS_R_RECIPIENT_ERROR), "recipient error"},
237    {ERR_REASON(CMS_R_SIGNER_CERTIFICATE_NOT_FOUND),
238     "signer certificate not found"},
239    {ERR_REASON(CMS_R_SIGNFINAL_ERROR), "signfinal error"},
240    {ERR_REASON(CMS_R_SMIME_TEXT_ERROR), "smime text error"},
241    {ERR_REASON(CMS_R_STORE_INIT_ERROR), "store init error"},
242    {ERR_REASON(CMS_R_TYPE_NOT_COMPRESSED_DATA), "type not compressed data"},
243    {ERR_REASON(CMS_R_TYPE_NOT_DATA), "type not data"},
244    {ERR_REASON(CMS_R_TYPE_NOT_DIGESTED_DATA), "type not digested data"},
245    {ERR_REASON(CMS_R_TYPE_NOT_ENCRYPTED_DATA), "type not encrypted data"},
246    {ERR_REASON(CMS_R_TYPE_NOT_ENVELOPED_DATA), "type not enveloped data"},
247    {ERR_REASON(CMS_R_UNABLE_TO_FINALIZE_CONTEXT),
248     "unable to finalize context"},
249    {ERR_REASON(CMS_R_UNKNOWN_CIPHER), "unknown cipher"},
250    {ERR_REASON(CMS_R_UNKNOWN_DIGEST_ALGORIHM), "unknown digest algorihm"},
251    {ERR_REASON(CMS_R_UNKNOWN_ID), "unknown id"},
252    {ERR_REASON(CMS_R_UNSUPPORTED_COMPRESSION_ALGORITHM),
253     "unsupported compression algorithm"},
254    {ERR_REASON(CMS_R_UNSUPPORTED_CONTENT_TYPE), "unsupported content type"},
255    {ERR_REASON(CMS_R_UNSUPPORTED_KEK_ALGORITHM),
256     "unsupported kek algorithm"},
257    {ERR_REASON(CMS_R_UNSUPPORTED_RECIPIENT_TYPE),
258     "unsupported recipient type"},
259    {ERR_REASON(CMS_R_UNSUPPORTED_RECPIENTINFO_TYPE),
260     "unsupported recpientinfo type"},
261    {ERR_REASON(CMS_R_UNSUPPORTED_TYPE), "unsupported type"},
262    {ERR_REASON(CMS_R_UNWRAP_ERROR), "unwrap error"},
263    {ERR_REASON(CMS_R_VERIFICATION_FAILURE), "verification failure"},
264    {ERR_REASON(CMS_R_WRAP_ERROR), "wrap error"},
265    {0, NULL}
266};
267
268#endif
269
270void ERR_load_CMS_strings(void)
271{
272#ifndef OPENSSL_NO_ERR
273
274    if (ERR_func_error_string(CMS_str_functs[0].error) == NULL) {
275        ERR_load_strings(0, CMS_str_functs);
276        ERR_load_strings(0, CMS_str_reasons);
277    }
278#endif
279}
280