/* * errors.c: The textual representation of errors * * Copyright (C) 2001, 2002 Juha Yrjölä * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "config.h" #include #include "errors.h" #define DIM(v) (sizeof(v)/(sizeof((v)[0]))) const char *sc_strerror(int error) { const char *rdr_errors[] = { "Generic reader error", "No readers found", "UNUSED", "UNUSED", "Card not present", "Card removed", "Card reset", "Transmit failed", "Timed out while waiting for user input", "Input operation cancelled by user", "The two PINs did not match", "Message too long (keypad)", "Timeout while waiting for event from card reader", "Unresponsive card (correctly inserted?)", "Reader detached (hotplug device?)", "Reader reattached (hotplug device?)", "Reader in use by another application" }; const int rdr_base = -SC_ERROR_READER; const char *card_errors[] = { "Card command failed", "File not found", "Record not found", "Unsupported CLA byte in APDU", "Unsupported INS byte in APDU", "Incorrect parameters in APDU", "Wrong length", "Card memory failure", "Card does not support the requested operation", "Not allowed", "Card is invalid or cannot be handled", "Security status not satisfied", "Authentication method blocked", "Unknown data received from card", "PIN code or key incorrect", "File already exists", "Data object not found", "Not enough memory on card", "Part of returned data may be corrupted", "End of file/record reached before reading Le bytes" }; const int card_base = -SC_ERROR_CARD_CMD_FAILED; const char *arg_errors[] = { "Invalid arguments", "UNUSED", "UNUSED", "Buffer too small", "Invalid PIN length", "Invalid data", }; const int arg_base = -SC_ERROR_INVALID_ARGUMENTS; const char *int_errors[] = { "Internal error", "Invalid ASN.1 object", "Required ASN.1 object not found", "Premature end of ASN.1 stream", "Out of memory", "Object not valid", "Object not found", "Requested object not found", "Not supported", "Passphrase required", "UNUSED", "Decryption failed", "Wrong padding", "Unsupported card", "Unable to load external module", "EF offset too large", "Not implemented" }; const int int_base = -SC_ERROR_INTERNAL; const char *p15i_errors[] = { "Generic PKCS#15 initialization error", "Syntax error", "Inconsistent or incomplete PKCS#15 profile", "Key length/algorithm not supported by card", "No default (transport) key available", "Non unique object ID", "Unable to load key and certificate(s) from file", "UNUSED", "File template not found", "Invalid PIN reference", "File too small", }; const int p15i_base = -SC_ERROR_PKCS15INIT; const int sm_base = -SC_ERROR_SM; const char *sm_errors[] = { "Generic Secure Messaging error", "Data enciphering error", "Invalid secure messaging level", "No session keys", "Invalid session keys", "Secure Messaging not initialized", "Cannot authenticate card", "Random generation error", "Secure messaging keyset not found", "IFD data missing" }; const char *misc_errors[] = { "Unknown error", "PKCS#15 compatible smart card not found", }; const int misc_base = -SC_ERROR_UNKNOWN; const char *no_errors = "Success"; const char **errors = NULL; int count = 0, err_base = 0; if (!error) return no_errors; if (error < 0) error = -error; if (error >= misc_base) { errors = misc_errors; count = DIM(misc_errors); err_base = misc_base; } else if (error >= sm_base) { errors = sm_errors; count = DIM(sm_errors); err_base = sm_base; } else if (error >= p15i_base) { errors = p15i_errors; count = DIM(p15i_errors); err_base = p15i_base; } else if (error >= int_base) { errors = int_errors; count = DIM(int_errors); err_base = int_base; } else if (error >= arg_base) { errors = arg_errors; count = DIM(arg_errors); err_base = arg_base; } else if (error >= card_base) { errors = card_errors; count = DIM(card_errors); err_base = card_base; } else if (error >= rdr_base) { errors = rdr_errors; count = DIM(rdr_errors); err_base = rdr_base; } error -= err_base; if (error >= count || count == 0) return misc_errors[0]; return errors[error]; }