summaryrefslogtreecommitdiffstats
path: root/common/maperror.c
blob: ab03669ae30497a0382f11b40e5c304c141d9ebb (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
/* maperror.c - Error mapping
 *	Copyright (C) 2001, 2002 Free Software Foundation, Inc.
 *
 * This file is part of GnuPG.
 *
 * GnuPG 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 2 of the License, or
 * (at your option) any later version.
 *
 * GnuPG 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, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
 */

#include <config.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <unistd.h>

#include <ksba.h>

#include "util.h"
#include "errors.h"
#include "../assuan/assuan.h"

/* Note: we might want to wrap this in a macro to get our hands on
   the line and file where the error occured */
int
map_ksba_err (int err)
{
  switch (err)
    {
    case -1:
    case 0: 
      break;

    case KSBA_Out_Of_Core: err = GNUPG_Out_Of_Core; break;
    case KSBA_Invalid_Value: err = GNUPG_Invalid_Value; break;
    case KSBA_Not_Implemented: err = GNUPG_Not_Implemented; break;
    case KSBA_Conflict: err = GNUPG_Conflict; break;
    case KSBA_Read_Error: err = GNUPG_Read_Error; break;
    case KSBA_Write_Error: err = GNUPG_Write_Error; break;
    case KSBA_No_Data: err = GNUPG_No_Data; break;
    case KSBA_Bug: err = GNUPG_Bug; break;
    case KSBA_Unsupported_Algorithm: err = GNUPG_Unsupported_Algorithm; break;
    case KSBA_Invalid_Index: err = GNUPG_Invalid_Index; break;
    case KSBA_Invalid_Sexp: err = GNUPG_Invalid_Sexp; break;
    case KSBA_Unknown_Sexp: err = GNUPG_Unknown_Sexp; break;
      
    default:
      err = seterr (General_Error);
      break;
    }
  return err;
}


int 
map_gcry_err (int err)
{
  switch (err)
    {
    case GCRYERR_EOF:
    case -1:
      err = -1;
      break;

    case 0:
      break;

    case GCRYERR_WRONG_PK_ALGO:
    case GCRYERR_INV_PK_ALGO:
    case GCRYERR_INV_MD_ALGO:
    case GCRYERR_INV_CIPHER_ALGO:
      err = GNUPG_Unsupported_Algorithm;
      break;
    case GCRYERR_INV_KEYLEN:
    case GCRYERR_WEAK_KEY:
    case GCRYERR_BAD_PUBLIC_KEY: err = GNUPG_Bad_Public_Key; break;
    case GCRYERR_BAD_SECRET_KEY: err = GNUPG_Bad_Secret_Key; break;
    case GCRYERR_BAD_SIGNATURE:  err = GNUPG_Bad_Signature; break;

    case GCRYERR_BAD_MPI:
      err = GNUPG_Bad_Data;
      break;
      
    case GCRYERR_INV_ARG:
    case GCRYERR_INV_OP:
    case GCRYERR_INTERNAL:
    case GCRYERR_INV_CIPHER_MODE:
      err = GNUPG_Invalid_Value;
      break;

    case GCRYERR_SELFTEST: 
      err = GNUPG_Bug;
      break;

    case GCRYERR_SEXP_INV_LEN_SPEC    :
    case GCRYERR_SEXP_STRING_TOO_LONG :
    case GCRYERR_SEXP_UNMATCHED_PAREN :
    case GCRYERR_SEXP_NOT_CANONICAL   :
    case GCRYERR_SEXP_BAD_CHARACTER   :
    case GCRYERR_SEXP_BAD_QUOTATION   :
    case GCRYERR_SEXP_ZERO_PREFIX     :
    case GCRYERR_SEXP_NESTED_DH       :
    case GCRYERR_SEXP_UNMATCHED_DH    :
    case GCRYERR_SEXP_UNEXPECTED_PUNC :
    case GCRYERR_SEXP_BAD_HEX_CHAR    :
    case GCRYERR_SEXP_ODD_HEX_NUMBERS :
    case GCRYERR_SEXP_BAD_OCT_CHAR    :
      err = GNUPG_Invalid_Sexp;
      break;

    case GCRYERR_NO_MEM: err = GNUPG_Out_Of_Core; break;

    case GCRYERR_NOT_IMPL:  err = GNUPG_Not_Implemented; break;
    case GCRYERR_CONFLICT:  err = GNUPG_Conflict; break;
      
    case GCRYERR_INV_OBJ:   /* an object is not valid */
    case GCRYERR_TOO_SHORT: /* provided buffer too short */
    case GCRYERR_TOO_LARGE: /* object is too large */
    case GCRYERR_NO_OBJ:    /* Missing item in an object */
    default:
      err = seterr (General_Error);
      break;
    }
  return err;
}

int 
map_kbx_err (int err)
{
  switch (err)
    {
    case -1:
    case 0:
      break;
      
    default:
      err = seterr (General_Error);
      break;
    }
  return err;
}


int 
map_assuan_err (int err)
{
  switch (err)
    {
    case -1:
    case 0:
      break;

    case ASSUAN_Canceled:        err = GNUPG_Canceled; break;
    case ASSUAN_Invalid_Index:   err = GNUPG_Invalid_Index; break;

    case ASSUAN_Not_Implemented: err = GNUPG_Not_Implemented; break;
    case ASSUAN_Server_Fault:    err = GNUPG_Assuan_Server_Fault; break;
    case ASSUAN_No_Public_Key:   err = GNUPG_No_Public_Key; break;
    case ASSUAN_No_Secret_Key:   err = GNUPG_No_Secret_Key; break;

    case ASSUAN_Cert_Revoked:    err = GNUPG_Certificate_Revoked; break;
    case ASSUAN_No_CRL_For_Cert: err = GNUPG_No_CRL_Known; break;       
    case ASSUAN_CRL_Too_Old:     err = GNUPG_CRL_Too_Old; break;        

    case ASSUAN_Not_Trusted:     err = GNUPG_Not_Trusted; break;

    case ASSUAN_Card_Error:      err = GNUPG_Card_Error; break;
    case ASSUAN_Invalid_Card:    err = GNUPG_Invalid_Card; break;
    case ASSUAN_No_PKCS15_App:   err = GNUPG_No_PKCS15_App; break;
    case ASSUAN_Card_Not_Present: err= GNUPG_Card_Not_Present; break;
    case ASSUAN_Not_Confirmed:   err = GNUPG_Not_Confirmed; break;
    case ASSUAN_Invalid_Id:      err = GNUPG_Invalid_Id; break;

    default:
      err = err < 100? GNUPG_Assuan_Server_Fault : GNUPG_Assuan_Error;
      break;
    }
  return err;
}

/* Map GNUPG_xxx error codes to Assuan status codes */
int
map_to_assuan_status (int rc)
{
  switch (rc)
    {
    case -1:
      rc = ASSUAN_No_Data_Available;
      break;
    case 0: break;
    case GNUPG_Bad_CA_Certificate: 
    case GNUPG_Bad_Certificate:  
    case GNUPG_Wrong_Key_Usage:
    case GNUPG_Certificate_Revoked:
    case GNUPG_No_CRL_Known:
    case GNUPG_CRL_Too_Old:
    case GNUPG_No_Policy_Match:
    case GNUPG_Certificate_Expired:
      rc = ASSUAN_Bad_Certificate; 
      break;
    case GNUPG_Bad_Certificate_Chain: rc = ASSUAN_Bad_Certificate_Chain; break;
    case GNUPG_Missing_Certificate: rc = ASSUAN_Missing_Certificate; break;
    case GNUPG_No_Data:           rc = ASSUAN_No_Data_Available; break;
    case GNUPG_Bad_Signature:     rc = ASSUAN_Bad_Signature; break;
    case GNUPG_Not_Implemented:   rc = ASSUAN_Not_Implemented; break;
    case GNUPG_No_Agent:          rc = ASSUAN_No_Agent; break;
    case GNUPG_Agent_Error:       rc = ASSUAN_Agent_Error; break;
    case GNUPG_No_Public_Key:     rc = ASSUAN_No_Public_Key; break;
    case GNUPG_No_Secret_Key:     rc = ASSUAN_No_Secret_Key; break;
    case GNUPG_Invalid_Data:      rc = ASSUAN_Invalid_Data; break;
    case GNUPG_Invalid_Name:      rc = ASSUAN_Invalid_Name; break;
    case GNUPG_Not_Trusted:       rc = ASSUAN_Not_Trusted; break;
    case GNUPG_Canceled:          rc = ASSUAN_Canceled; break;
    case GNUPG_Invalid_Index:     rc = ASSUAN_Invalid_Index; break;

    case GNUPG_Card_Error:      
    case GNUPG_Card_Reset:      
      rc = ASSUAN_Card_Error; 
      break;
    case GNUPG_Card_Removed:  
    case GNUPG_Card_Not_Present:
      rc = ASSUAN_Card_Not_Present;
      break;
    case GNUPG_Invalid_Card:      rc = ASSUAN_Invalid_Card; break;
    case GNUPG_No_PKCS15_App:     rc = ASSUAN_No_PKCS15_App; break;
    case GNUPG_Not_Confirmed:     rc = ASSUAN_Not_Confirmed; break;
    case GNUPG_Invalid_Id:        rc = ASSUAN_Invalid_Id; break; 

    case GNUPG_Bad_PIN:
    case GNUPG_Bad_Passphrase:
      rc = ASSUAN_No_Secret_Key;
      break;

    case GNUPG_Read_Error: 
    case GNUPG_Write_Error:
    case GNUPG_IO_Error: 
      rc = ASSUAN_Server_IO_Error;
      break;
    case GNUPG_Out_Of_Core:    
    case GNUPG_Resource_Limit: 
      rc = ASSUAN_Server_Resource_Problem;
      break;
    case GNUPG_Bug: 
    case GNUPG_Internal_Error:   
      rc = ASSUAN_Server_Bug;
      break;
    default: 
      rc = ASSUAN_Server_Fault;
      break;
    }
  return rc;
}