|
Packit |
6b81fa |
/* libp11, a simple layer on to of PKCS#11 API
|
|
Packit |
6b81fa |
* Copyright (C) 2005 Olaf Kirch <okir@lst.de>
|
|
Packit |
6b81fa |
*
|
|
Packit |
6b81fa |
* This library is free software; you can redistribute it and/or
|
|
Packit |
6b81fa |
* modify it under the terms of the GNU Lesser General Public
|
|
Packit |
6b81fa |
* License as published by the Free Software Foundation; either
|
|
Packit |
6b81fa |
* version 2.1 of the License, or (at your option) any later version.
|
|
Packit |
6b81fa |
*
|
|
Packit |
6b81fa |
* This library is distributed in the hope that it will be useful,
|
|
Packit |
6b81fa |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
6b81fa |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit |
6b81fa |
* Lesser General Public License for more details.
|
|
Packit |
6b81fa |
*
|
|
Packit |
6b81fa |
* You should have received a copy of the GNU Lesser General Public
|
|
Packit |
6b81fa |
* License along with this library; if not, write to the Free Software
|
|
Packit |
6b81fa |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
Packit |
6b81fa |
*/
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
#include "libp11.h"
|
|
Packit |
6b81fa |
#include "libp11-int.h"
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
#define CKR_LIB_NAME "PKCS#11 module"
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
/* BEGIN ERROR CODES */
|
|
Packit |
6b81fa |
#ifndef NO_ERR
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
# define ERR_FUNC(func) ERR_PACK(0,func,0)
|
|
Packit |
6b81fa |
# define ERR_REASON(reason) ERR_PACK(0,0,reason)
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
static ERR_STRING_DATA CKR_str_functs[] = {
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_CHANGE_PIN), "pkcs11_change_pin"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_CHECK_TOKEN), "pkcs11_check_token"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_CTX_LOAD), "pkcs11_CTX_load"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_ECDH_DERIVE), "pkcs11_ecdh_derive"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_ECDSA_SIGN), "pkcs11_ecdsa_sign"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_ENUMERATE_SLOTS), "pkcs11_enumerate_slots"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_FIND_CERTS), "pkcs11_find_certs"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_FIND_KEYS), "pkcs11_find_keys"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_GENERATE_RANDOM), "pkcs11_generate_random"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_GETATTR_ALLOC), "pkcs11_getattr_alloc"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_GETATTR_BN), "pkcs11_getattr_bn"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_GETATTR_INT), "pkcs11_getattr_int"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_INIT_PIN), "pkcs11_init_pin"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_INIT_SLOT), "pkcs11_init_slot"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_INIT_TOKEN), "pkcs11_init_token"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_IS_LOGGED_IN), "pkcs11_is_logged_in"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_LOGIN), "pkcs11_login"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_LOGOUT), "pkcs11_logout"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_NEXT_CERT), "pkcs11_next_cert"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_NEXT_KEY), "pkcs11_next_key"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_OPEN_SESSION), "pkcs11_open_session"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_PRIVATE_DECRYPT), "pkcs11_private_decrypt"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_PRIVATE_ENCRYPT), "pkcs11_private_encrypt"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_RELOAD_KEY), "pkcs11_reload_key"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_REOPEN_SESSION), "pkcs11_reopen_session"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_SEED_RANDOM), "pkcs11_seed_random"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_STORE_CERTIFICATE), "pkcs11_store_certificate"},
|
|
Packit |
6b81fa |
{ERR_FUNC(CKR_F_PKCS11_STORE_KEY), "pkcs11_store_key"},
|
|
Packit |
6b81fa |
{0, NULL}
|
|
Packit |
6b81fa |
};
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
static ERR_STRING_DATA CKR_str_reasons[] = {
|
|
Packit |
6b81fa |
{CKR_CANCEL, "Cancel"},
|
|
Packit |
6b81fa |
{CKR_HOST_MEMORY, "Host memory error"},
|
|
Packit |
6b81fa |
{CKR_SLOT_ID_INVALID, "Invalid slot ID"},
|
|
Packit |
6b81fa |
{CKR_GENERAL_ERROR, "General Error"},
|
|
Packit |
6b81fa |
{CKR_FUNCTION_FAILED, "Function failed"},
|
|
Packit |
6b81fa |
{CKR_ARGUMENTS_BAD, "Invalid arguments"},
|
|
Packit |
6b81fa |
{CKR_NO_EVENT, "No event"},
|
|
Packit |
6b81fa |
{CKR_NEED_TO_CREATE_THREADS, "Need to create threads"},
|
|
Packit |
6b81fa |
{CKR_CANT_LOCK, "Cannott lock"},
|
|
Packit |
6b81fa |
{CKR_ATTRIBUTE_READ_ONLY, "Attribute read only"},
|
|
Packit |
6b81fa |
{CKR_ATTRIBUTE_SENSITIVE, "Attribute sensitive"},
|
|
Packit |
6b81fa |
{CKR_ATTRIBUTE_TYPE_INVALID, "Attribute type invalid"},
|
|
Packit |
6b81fa |
{CKR_ATTRIBUTE_VALUE_INVALID, "Attribute value invalid"},
|
|
Packit |
6b81fa |
{CKR_DATA_INVALID, "Data invalid"},
|
|
Packit |
6b81fa |
{CKR_DATA_LEN_RANGE, "Data len range"},
|
|
Packit |
6b81fa |
{CKR_DEVICE_ERROR, "Device error"},
|
|
Packit |
6b81fa |
{CKR_DEVICE_MEMORY, "Device memory"},
|
|
Packit |
6b81fa |
{CKR_DEVICE_REMOVED, "Device removed"},
|
|
Packit |
6b81fa |
{CKR_ENCRYPTED_DATA_INVALID, "Encrypted data invalid"},
|
|
Packit |
6b81fa |
{CKR_ENCRYPTED_DATA_LEN_RANGE, "Encrypted data len range"},
|
|
Packit |
6b81fa |
{CKR_FUNCTION_CANCELED, "Function canceled"},
|
|
Packit |
6b81fa |
{CKR_FUNCTION_NOT_PARALLEL, "Function not parallel"},
|
|
Packit |
6b81fa |
{CKR_FUNCTION_NOT_SUPPORTED, "Function not supported"},
|
|
Packit |
6b81fa |
{CKR_KEY_HANDLE_INVALID, "Key handle invalid"},
|
|
Packit |
6b81fa |
{CKR_KEY_SIZE_RANGE, "Key size range"},
|
|
Packit |
6b81fa |
{CKR_KEY_TYPE_INCONSISTENT, "Key type inconsistent"},
|
|
Packit |
6b81fa |
{CKR_KEY_NOT_NEEDED, "Key not needed"},
|
|
Packit |
6b81fa |
{CKR_KEY_CHANGED, "Key changed"},
|
|
Packit |
6b81fa |
{CKR_KEY_NEEDED, "Key needed"},
|
|
Packit |
6b81fa |
{CKR_KEY_INDIGESTIBLE, "Key indigestible"},
|
|
Packit |
6b81fa |
{CKR_KEY_FUNCTION_NOT_PERMITTED, "Key function not permitted"},
|
|
Packit |
6b81fa |
{CKR_KEY_NOT_WRAPPABLE, "Key not wrappable"},
|
|
Packit |
6b81fa |
{CKR_KEY_UNEXTRACTABLE, "Key unextractable"},
|
|
Packit |
6b81fa |
{CKR_MECHANISM_INVALID, "Mechanism invalid"},
|
|
Packit |
6b81fa |
{CKR_MECHANISM_PARAM_INVALID, "Mechanism param invalid"},
|
|
Packit |
6b81fa |
{CKR_OBJECT_HANDLE_INVALID, "Object handle invalid"},
|
|
Packit |
6b81fa |
{CKR_OPERATION_ACTIVE, "Operation active"},
|
|
Packit |
6b81fa |
{CKR_OPERATION_NOT_INITIALIZED, "Operation not initialized"},
|
|
Packit |
6b81fa |
{CKR_PIN_INCORRECT, "PIN incorrect"},
|
|
Packit |
6b81fa |
{CKR_PIN_INVALID, "PIN invalid"},
|
|
Packit |
6b81fa |
{CKR_PIN_LEN_RANGE, "Invalid PIN length"},
|
|
Packit |
6b81fa |
{CKR_PIN_EXPIRED, "PIN expired"},
|
|
Packit |
6b81fa |
{CKR_PIN_LOCKED, "PIN locked"},
|
|
Packit |
6b81fa |
{CKR_SESSION_CLOSED, "Session closed"},
|
|
Packit |
6b81fa |
{CKR_SESSION_COUNT, "Session count"},
|
|
Packit |
6b81fa |
{CKR_SESSION_HANDLE_INVALID, "Session handle invalid"},
|
|
Packit |
6b81fa |
{CKR_SESSION_PARALLEL_NOT_SUPPORTED, "Session parallel not supported"},
|
|
Packit |
6b81fa |
{CKR_SESSION_READ_ONLY, "Session read only"},
|
|
Packit |
6b81fa |
{CKR_SESSION_EXISTS, "Session exists"},
|
|
Packit |
6b81fa |
{CKR_SESSION_READ_ONLY_EXISTS, "Read-only session exists"},
|
|
Packit |
6b81fa |
{CKR_SESSION_READ_WRITE_SO_EXISTS, "Read/write SO session exists"},
|
|
Packit |
6b81fa |
{CKR_SIGNATURE_INVALID, "Signature invalid"},
|
|
Packit |
6b81fa |
{CKR_SIGNATURE_LEN_RANGE, "Signature len range"},
|
|
Packit |
6b81fa |
{CKR_TEMPLATE_INCOMPLETE, "Incomplete template"},
|
|
Packit |
6b81fa |
{CKR_TEMPLATE_INCONSISTENT, "Inconsistent template"},
|
|
Packit |
6b81fa |
{CKR_TOKEN_NOT_PRESENT, "No PKCS#11 token present"},
|
|
Packit |
6b81fa |
{CKR_TOKEN_NOT_RECOGNIZED, "PKCS#11 token not recognized"},
|
|
Packit |
6b81fa |
{CKR_TOKEN_WRITE_PROTECTED, "Token write protected"},
|
|
Packit |
6b81fa |
{CKR_UNWRAPPING_KEY_HANDLE_INVALID, "Unwrapping key handle invalid"},
|
|
Packit |
6b81fa |
{CKR_UNWRAPPING_KEY_SIZE_RANGE, "Unwrapping key size range"},
|
|
Packit |
6b81fa |
{CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT, "Unwrapping key type inconsistent"},
|
|
Packit |
6b81fa |
{CKR_USER_ALREADY_LOGGED_IN, "User already logged in"},
|
|
Packit |
6b81fa |
{CKR_USER_NOT_LOGGED_IN, "User not logged in"},
|
|
Packit |
6b81fa |
{CKR_USER_PIN_NOT_INITIALIZED, "User pin not initialized"},
|
|
Packit |
6b81fa |
{CKR_USER_TYPE_INVALID, "User type invalid"},
|
|
Packit |
6b81fa |
{CKR_USER_ANOTHER_ALREADY_LOGGED_IN, "User another is already logged in"},
|
|
Packit |
6b81fa |
{CKR_USER_TOO_MANY_TYPES, "User too many types"},
|
|
Packit |
6b81fa |
{CKR_WRAPPED_KEY_INVALID, "Wrapped key invalid"},
|
|
Packit |
6b81fa |
{CKR_WRAPPED_KEY_LEN_RANGE, "Wrapped key len range"},
|
|
Packit |
6b81fa |
{CKR_WRAPPING_KEY_HANDLE_INVALID, "Wrapping key handle invalid"},
|
|
Packit |
6b81fa |
{CKR_WRAPPING_KEY_SIZE_RANGE, "Wrapping key size range"},
|
|
Packit |
6b81fa |
{CKR_WRAPPING_KEY_TYPE_INCONSISTENT, "Wrapping key type inconsistent"},
|
|
Packit |
6b81fa |
{CKR_RANDOM_SEED_NOT_SUPPORTED, "Random seed not supported"},
|
|
Packit |
6b81fa |
{CKR_RANDOM_NO_RNG, "Random no rng"},
|
|
Packit |
6b81fa |
{CKR_DOMAIN_PARAMS_INVALID, "Domain params invalid"},
|
|
Packit |
6b81fa |
{CKR_BUFFER_TOO_SMALL, "Buffer too small"},
|
|
Packit |
6b81fa |
{CKR_SAVED_STATE_INVALID, "Saved state invalid"},
|
|
Packit |
6b81fa |
{CKR_INFORMATION_SENSITIVE, "Information sensitive"},
|
|
Packit |
6b81fa |
{CKR_STATE_UNSAVEABLE, "State unsaveable"},
|
|
Packit |
6b81fa |
{CKR_CRYPTOKI_NOT_INITIALIZED, "Cryptoki not initialized"},
|
|
Packit |
6b81fa |
{CKR_CRYPTOKI_ALREADY_INITIALIZED, "Cryptoki already initialized"},
|
|
Packit |
6b81fa |
{CKR_MUTEX_BAD, "Mutex bad"},
|
|
Packit |
6b81fa |
{CKR_MUTEX_NOT_LOCKED, "Mutex not locked"},
|
|
Packit |
6b81fa |
{CKR_VENDOR_DEFINED, "Vendor defined"},
|
|
Packit |
6b81fa |
{0, NULL}
|
|
Packit |
6b81fa |
};
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
#ifdef CKR_LIB_NAME
|
|
Packit |
6b81fa |
static ERR_STRING_DATA CKR_lib_name[] = {
|
|
Packit |
6b81fa |
{0, CKR_LIB_NAME},
|
|
Packit |
6b81fa |
{0, NULL}
|
|
Packit |
6b81fa |
};
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
static int CKR_lib_error_code = 0;
|
|
Packit |
6b81fa |
static int CKR_error_init = 1;
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
int ERR_load_CKR_strings(void)
|
|
Packit |
6b81fa |
{
|
|
Packit |
6b81fa |
if (CKR_lib_error_code == 0)
|
|
Packit |
6b81fa |
CKR_lib_error_code = ERR_get_next_error_library();
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
if (CKR_error_init) {
|
|
Packit |
6b81fa |
CKR_error_init = 0;
|
|
Packit |
6b81fa |
#ifndef OPENSSL_NO_ERR
|
|
Packit |
6b81fa |
ERR_load_strings(CKR_lib_error_code, CKR_str_functs);
|
|
Packit |
6b81fa |
ERR_load_strings(CKR_lib_error_code, CKR_str_reasons);
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
#ifdef CKR_LIB_NAME
|
|
Packit |
6b81fa |
CKR_lib_name->error = ERR_PACK(CKR_lib_error_code, 0, 0);
|
|
Packit |
6b81fa |
ERR_load_strings(0, CKR_lib_name);
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
return 1;
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
void ERR_unload_CKR_strings(void)
|
|
Packit |
6b81fa |
{
|
|
Packit |
6b81fa |
if (CKR_error_init == 0) {
|
|
Packit |
6b81fa |
#ifndef OPENSSL_NO_ERR
|
|
Packit |
6b81fa |
ERR_unload_strings(CKR_lib_error_code, CKR_str_functs);
|
|
Packit |
6b81fa |
ERR_unload_strings(CKR_lib_error_code, CKR_str_reasons);
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
#ifdef CKR_LIB_NAME
|
|
Packit |
6b81fa |
ERR_unload_strings(0, CKR_lib_name);
|
|
Packit |
6b81fa |
#endif
|
|
Packit |
6b81fa |
CKR_error_init = 1;
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
void ERR_CKR_error(int function, int reason, char *file, int line)
|
|
Packit |
6b81fa |
{
|
|
Packit |
6b81fa |
if (CKR_lib_error_code == 0)
|
|
Packit |
6b81fa |
CKR_lib_error_code = ERR_get_next_error_library();
|
|
Packit |
6b81fa |
ERR_PUT_error(CKR_lib_error_code, function, reason, file, line);
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
int ERR_get_CKR_code(void)
|
|
Packit |
6b81fa |
{
|
|
Packit |
6b81fa |
if (CKR_lib_error_code == 0)
|
|
Packit |
6b81fa |
CKR_lib_error_code = ERR_get_next_error_library();
|
|
Packit |
6b81fa |
return CKR_lib_error_code;
|
|
Packit |
6b81fa |
}
|
|
Packit |
6b81fa |
|
|
Packit |
6b81fa |
/* vim: set noexpandtab: */
|