mirror of
https://github.com/guanzhi/GmSSL.git
synced 2026-06-18 19:03:40 +08:00
SKF Wrapper
This commit is contained in:
@@ -1,146 +1,151 @@
|
||||
#include "skf/skf.h"
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
static ERR_STRING_DATA SKF_str_functs[] = {
|
||||
{ERR_FUNC(SKF_F_SKF_INIT_KEY), "SKF_INIT_KEY"},
|
||||
{ERR_FUNC(SKF_F_SKF_CIPHER), "SKF_CIPHER"},
|
||||
{ERR_FUNC(SKF_F_SKF_INIT), "SKF_INIT"},
|
||||
{ERR_FUNC(SKF_F_SKF_CTRL), "SKF_CTRL"},
|
||||
{ERR_FUNC(SKF_F_SKF_FINISH), "SKF_FINISH"},
|
||||
{0, NULL}
|
||||
};
|
||||
|
||||
static ERR_STRING_DATA SKF_str_reasons[] = {
|
||||
{ERR_REASON(SKF_F_OK), ok"},
|
||||
{0, NULL}
|
||||
};
|
||||
|
||||
|
||||
int skf_err2openssl(int err)
|
||||
{
|
||||
switch (err) {
|
||||
case SAR_OK:
|
||||
return SKF_R_SAR_OK;
|
||||
case SAR_FAIL:
|
||||
return SKF_R_SAR_FAIL;
|
||||
case SAR_UNKNOWNERR:
|
||||
case SAR_NOTSUPPORTYETERR:
|
||||
case SAR_FILEERR:
|
||||
case SAR_INVALIDHANDLEERR:
|
||||
case SAR_INVALIDPARAMERR:
|
||||
case SAR_READFILEERR:
|
||||
case SAR_WRITEFILEERR:
|
||||
case SAR_NAMELENERR:
|
||||
case SAR_KEYUSAGEERR:
|
||||
case SAR_MODULUSLENERR:
|
||||
case SAR_NOTINITIALIZEERR:
|
||||
case SAR_OBJERR:
|
||||
case SAR_MEMORYERR:
|
||||
case SAR_TIMEOUTERR:
|
||||
case SAR_INDATALENERR
|
||||
case SAR_INDATAERR
|
||||
case SAR_GENRANDERR
|
||||
case SAR_HASHOBJERR
|
||||
case SAR_HASHERR
|
||||
case SAR_GENRSAKEYERR
|
||||
case SAR_RSAMODULUSLENERR
|
||||
case SAR_CSPIMPRTPUBKEYERR
|
||||
case SAR_RSAENCERR
|
||||
case SAR_RSADECERR
|
||||
case SAR_HASHNOTEQUALERR
|
||||
case SAR_KEYNOTFOUNTERR
|
||||
case SAR_CERTNOTFOUNTERR
|
||||
case SAR_NOTEXPORTERR
|
||||
case SAR_DECRYPTPADERR
|
||||
case SAR_MACLENERR
|
||||
case SAR_BUFFER_TOO_SMALL
|
||||
case SAR_KEYINFOTYPEERR
|
||||
case SAR_NOT_EVENTERR
|
||||
case SAR_DEVICE_REMOVED
|
||||
case SAR_PIN_INCORRECT
|
||||
case SAR_PIN_LOCKED
|
||||
case SAR_PIN_INVALID
|
||||
case SAR_PIN_LEN_RANGE
|
||||
case SAR_USER_ALREADY_LOGGED_IN
|
||||
case SAR_USER_PIN_NOT_INITIALIZED
|
||||
case SAR_USER_TYPE_INVALID
|
||||
case SAR_APPLICATION_NAME_INVALID
|
||||
case SAR_APPLICATION_EXISTS
|
||||
case SAR_USER_NOT_LOGGED_IN
|
||||
case SAR_APPLICATION_NOT_EXISTS
|
||||
case SAR_FILE_ALREADY_EXIST
|
||||
case SAR_NO_ROOM
|
||||
case SAR_FILE_NOT_EXIST
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
typedef struct {
|
||||
int err_no;
|
||||
char *err_str;
|
||||
} skf_errstr[] = {
|
||||
{ SAR_OK, "Success" },
|
||||
{ SAR_FAIL, "Failure" },
|
||||
{ SAR_UNKNOWNERR, "Unknown error" },
|
||||
{ SAR_NOTSUPPORTYETERR, "Not supported" },
|
||||
{ SAR_FILEERR, "File error" },
|
||||
{ SAR_INVALIDHANDLEERR, "Invalid handler" },
|
||||
{ SAR_INVALIDPARAMERR, "Invalid parameter" },
|
||||
{ SAR_READFILEERR, "Read file error" },
|
||||
{ SAR_WRITEFILEERR "Write file error" },
|
||||
{ SAR_NAMELENERR, "Name length error" },
|
||||
{ SAR_KEYUSAGEERR, "Key usage error" },
|
||||
{ SAR_MODULUSLENERR, "Modulus length error" },
|
||||
{ SAR_NOTINITIALIZEERR, "Not initialized" },
|
||||
{ SAR_OBJERR, "Object error" },
|
||||
{ SAR_MEMORYERR, "Memory error" },
|
||||
{ SAR_TIMEOUTERR, "Time out" },
|
||||
{ SAR_INDATALENERR, "Input data length error" },
|
||||
{ SAR_INDATAERR, "Input data error" },
|
||||
{ SAR_GENRANDERR, "Generate randomness error" },
|
||||
{ SAR_HASHOBJERR, "Hash object error" },
|
||||
{ SAR_HASHERR, "Hash error" },
|
||||
{ SAR_GENRSAKEYERR, "Genenerate RSA key error" },
|
||||
{ SAR_RSAMODULUSLENERR, "RSA modulus length error" },
|
||||
{ SAR_CSPIMPRTPUBKEYERR, "CSP import public key error" },
|
||||
{ SAR_RSAENCERR, "RSA encryption error" },
|
||||
{ SAR_RSADECERR, "RSA decryption error" },
|
||||
{ SAR_HASHNOTEQUALERR, "Hash not equal" },
|
||||
{ SAR_KEYNOTFOUNTERR, "Key not found" },
|
||||
{ SAR_CERTNOTFOUNTERR, "Certificate not found" },
|
||||
{ SAR_NOTEXPORTERR, "Not exported" },
|
||||
{ SAR_DECRYPTPADERR, "Decrypt pad error" },
|
||||
{ SAR_MACLENERR, "MAC length error" },
|
||||
{ SAR_BUFFER_TOO_SMALL, "Buffer too small" },
|
||||
{ SAR_KEYINFOTYPEERR, "Key info type error" },
|
||||
{ SAR_NOT_EVENTERR, "No event error" },
|
||||
{ SAR_DEVICE_REMOVED "Device removed" },
|
||||
{ SAR_PIN_INCORRECT, "PIN incorrect" },
|
||||
{ SAR_PIN_LOCKED, "PIN locked" },
|
||||
{ SAR_PIN_INVALID, "PIN invalid" },
|
||||
{ SAR_PIN_LEN_RANGE, "PIN length error" },
|
||||
{ SAR_USER_ALREADY_LOGGED_IN, "User already logged in" },
|
||||
{ SAR_USER_PIN_NOT_INITIALIZED, "User PIN not initialized" },
|
||||
{ SAR_USER_TYPE_INVALID, "User type invalid" },
|
||||
{ SAR_APPLICATION_NAME_INVALID, "Application name invalid" },
|
||||
{ SAR_APPLICATION_EXISTS, "Application already exist" },
|
||||
{ SAR_USER_NOT_LOGGED_IN, "User not logged in" },
|
||||
{ SAR_APPLICATION_NOT_EXISTS, "Application not exist" },
|
||||
{ SAR_FILE_ALREADY_EXIST, "File already exist" },
|
||||
{ SAR_NO_ROOM, "No file space" },
|
||||
{ SAR_FILE_NOT_EXIST, "File not exist" }
|
||||
};
|
||||
|
||||
|
||||
LPSTR DEVAPI SKF_GetErrorString(ULONG ulError)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
/* e_skf_err.c */
|
||||
/* ====================================================================
|
||||
* Copyright (c) 1999-2016 The OpenSSL Project. All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* 3. All advertising materials mentioning features or use of this
|
||||
* software must display the following acknowledgment:
|
||||
* "This product includes software developed by the OpenSSL Project
|
||||
* for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
|
||||
*
|
||||
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
|
||||
* endorse or promote products derived from this software without
|
||||
* prior written permission. For written permission, please contact
|
||||
* openssl-core@OpenSSL.org.
|
||||
*
|
||||
* 5. Products derived from this software may not be called "OpenSSL"
|
||||
* nor may "OpenSSL" appear in their names without prior written
|
||||
* permission of the OpenSSL Project.
|
||||
*
|
||||
* 6. Redistributions of any form whatsoever must retain the following
|
||||
* acknowledgment:
|
||||
* "This product includes software developed by the OpenSSL Project
|
||||
* for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
|
||||
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
|
||||
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||||
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
|
||||
* OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
* ====================================================================
|
||||
*
|
||||
* This product includes cryptographic software written by Eric Young
|
||||
* (eay@cryptsoft.com). This product includes software written by Tim
|
||||
* Hudson (tjh@cryptsoft.com).
|
||||
*
|
||||
*/
|
||||
|
||||
/*
|
||||
* NOTE: this file was auto generated by the mkerr.pl script: any changes
|
||||
* made to it will be overwritten when the script next updates this file,
|
||||
* only reason strings will be preserved.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <openssl/err.h>
|
||||
#include "e_skf_err.h"
|
||||
|
||||
/* BEGIN ERROR CODES */
|
||||
#ifndef OPENSSL_NO_ERR
|
||||
|
||||
# define ERR_FUNC(func) ERR_PACK(0,func,0)
|
||||
# define ERR_REASON(reason) ERR_PACK(0,0,reason)
|
||||
|
||||
static ERR_STRING_DATA ESKF_str_functs[] = {
|
||||
{ERR_FUNC(ESKF_F_OPEN_APP), "OPEN_APP"},
|
||||
{ERR_FUNC(ESKF_F_OPEN_CONTAINER), "OPEN_CONTAINER"},
|
||||
{ERR_FUNC(ESKF_F_OPEN_DEV), "OPEN_DEV"},
|
||||
{ERR_FUNC(ESKF_F_SET_AUTHKEY), "SET_AUTHKEY"},
|
||||
{ERR_FUNC(ESKF_F_SET_USERPIN), "SET_USERPIN"},
|
||||
{ERR_FUNC(ESKF_F_SKF_CIPHER), "SKF_CIPHER"},
|
||||
{ERR_FUNC(ESKF_F_SKF_CIPHERS), "SKF_CIPHERS"},
|
||||
{ERR_FUNC(ESKF_F_SKF_DIGESTS), "SKF_DIGESTS"},
|
||||
{ERR_FUNC(ESKF_F_SKF_ENGINE_CTRL), "SKF_ENGINE_CTRL"},
|
||||
{ERR_FUNC(ESKF_F_SKF_FINISH), "SKF_FINISH"},
|
||||
{ERR_FUNC(ESKF_F_SKF_INIT), "SKF_INIT"},
|
||||
{ERR_FUNC(ESKF_F_SKF_INIT_KEY), "SKF_INIT_KEY"},
|
||||
{ERR_FUNC(ESKF_F_SKF_LOAD_PUBKEY), "SKF_LOAD_PUBKEY"},
|
||||
{ERR_FUNC(ESKF_F_SKF_RAND_BYTES), "SKF_RAND_BYTES"},
|
||||
{ERR_FUNC(ESKF_F_SKF_RSA_SIGN), "SKF_RSA_SIGN"},
|
||||
{ERR_FUNC(ESKF_F_SKF_SM2_DO_SIGN), "SKF_SM2_DO_SIGN"},
|
||||
{ERR_FUNC(ESKF_F_SKF_SM3_FINAL), "SKF_SM3_FINAL"},
|
||||
{ERR_FUNC(ESKF_F_SKF_SM3_INIT), "SKF_SM3_INIT"},
|
||||
{ERR_FUNC(ESKF_F_SKF_SM3_UPDATE), "SKF_SM3_UPDATE"},
|
||||
{0, NULL}
|
||||
};
|
||||
|
||||
static ERR_STRING_DATA ESKF_str_reasons[] = {
|
||||
{ERR_REASON(ESKF_R_NOT_IMPLEMENTED), "not implemented"},
|
||||
{0, NULL}
|
||||
};
|
||||
|
||||
#endif
|
||||
|
||||
#ifdef ESKF_LIB_NAME
|
||||
static ERR_STRING_DATA ESKF_lib_name[] = {
|
||||
{0, ESKF_LIB_NAME},
|
||||
{0, NULL}
|
||||
};
|
||||
#endif
|
||||
|
||||
static int ESKF_lib_error_code = 0;
|
||||
static int ESKF_error_init = 1;
|
||||
|
||||
static void ERR_load_ESKF_strings(void)
|
||||
{
|
||||
if (ESKF_lib_error_code == 0)
|
||||
ESKF_lib_error_code = ERR_get_next_error_library();
|
||||
|
||||
if (ESKF_error_init) {
|
||||
ESKF_error_init = 0;
|
||||
#ifndef OPENSSL_NO_ERR
|
||||
ERR_load_strings(ESKF_lib_error_code, ESKF_str_functs);
|
||||
ERR_load_strings(ESKF_lib_error_code, ESKF_str_reasons);
|
||||
#endif
|
||||
|
||||
#ifdef ESKF_LIB_NAME
|
||||
ESKF_lib_name->error = ERR_PACK(ESKF_lib_error_code, 0, 0);
|
||||
ERR_load_strings(0, ESKF_lib_name);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
static void ERR_unload_ESKF_strings(void)
|
||||
{
|
||||
if (ESKF_error_init == 0) {
|
||||
#ifndef OPENSSL_NO_ERR
|
||||
ERR_unload_strings(ESKF_lib_error_code, ESKF_str_functs);
|
||||
ERR_unload_strings(ESKF_lib_error_code, ESKF_str_reasons);
|
||||
#endif
|
||||
|
||||
#ifdef ESKF_LIB_NAME
|
||||
ERR_unload_strings(0, ESKF_lib_name);
|
||||
#endif
|
||||
ESKF_error_init = 1;
|
||||
}
|
||||
}
|
||||
|
||||
static void ERR_ESKF_error(int function, int reason, char *file, int line)
|
||||
{
|
||||
if (ESKF_lib_error_code == 0)
|
||||
ESKF_lib_error_code = ERR_get_next_error_library();
|
||||
ERR_PUT_error(ESKF_lib_error_code, function, reason, file, line);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user