From 95be68c0505152774f1705b8f99433b5bc274015 Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 10:43:57 +0200 Subject: [PATCH 1/8] feat: add eckey_t --- include/cose/cose.h | 20 ++++++++++++++++++-- src/Sign1.c | 46 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 64 insertions(+), 2 deletions(-) diff --git a/include/cose/cose.h b/include/cose/cose.h index d767c850..a99ab789 100644 --- a/include/cose/cose.h +++ b/include/cose/cose.h @@ -1,7 +1,11 @@ +#pragma once + #include #include "cose/cose_configure.h" -#pragma once +#if USE_MBED_TLS +#include "mbedtls/ecp.h" +#endif // USE_MBED_TLS #ifdef __cplusplus extern "C" { @@ -202,6 +206,16 @@ typedef enum { COSE_Curve_Ed448 = 7, } COSE_Curves; + +#if USE_MBED_TLS +typedef struct mbedtls_ecp_keypair eckey_t; +#else + typedef struct eckey_t { + struct ec_key_st *key; + int group; + } eckey_t; +#endif // USE_MBED_TLS + /* * messages dealing with the Enveloped message type */ @@ -343,7 +357,7 @@ bool COSE_Signer_SetExternal(HCOSE_SIGNER hcose, const byte * pbExternalData, si #define COSE_Sign0_map_get_int COSE_Sign1_map_get_int #define COSE_Sign0_map_put_int COSE_Sign1_map_put_int - + HCOSE_SIGN1 COSE_Sign1_Init(COSE_INIT_FLAGS flags, CBOR_CONTEXT_COMMA cose_errback * perr); bool COSE_Sign1_Free(HCOSE_SIGN1 cose); @@ -352,6 +366,8 @@ bool COSE_Sign1_SetExternal(HCOSE_SIGN1 hcose, const byte * pbExternalData, size bool COSE_Sign1_Sign(HCOSE_SIGN1 h, const cn_cbor * pkey, cose_errback * perr); bool COSE_Sign1_validate(HCOSE_SIGN1 hSign, const cn_cbor * pkey, cose_errback * perr); +bool COSE_Sign1_Sign_eckey(HCOSE_SIGN1 h, const eckey_t * pbKey, cose_errback * perr); +bool COSE_Sign1_validate_eckey(HCOSE_SIGN1 hSign, const eckey_t * pbKey, cose_errback * perr); cn_cbor * COSE_Sign1_map_get_int(HCOSE_SIGN1 h, int key, int flags, cose_errback * perror); bool COSE_Sign1_map_put_int(HCOSE_SIGN1 cose, int key, cn_cbor * value, int flags, cose_errback * errp); diff --git a/src/Sign1.c b/src/Sign1.c index 93364b81..804af46b 100644 --- a/src/Sign1.c +++ b/src/Sign1.c @@ -201,6 +201,31 @@ bool COSE_Sign1_Sign(HCOSE_SIGN1 h, const cn_cbor * pKey, cose_errback * perr) return true; } +bool COSE_Sign1_Sign_eckey(HCOSE_SIGN1 h, const eckey_t * eckey, cose_errback * perr) +{ +#ifdef USE_CBOR_CONTEXT + // cn_cbor_context * context = NULL; +#endif + COSE_Sign1Message * pMessage = (COSE_Sign1Message *)h; + const cn_cbor * pcborProtected; + + if (!IsValidSign1Handle(h)) { + CHECK_CONDITION(false, COSE_ERR_INVALID_HANDLE); + errorReturn: + return false; + } +#ifdef USE_CBOR_CONTEXT + // context = &pMessage->m_message.m_allocContext; +#endif + + pcborProtected = _COSE_encode_protected(&pMessage->m_message, perr); + if (pcborProtected == NULL) goto errorReturn; + + if (!_COSE_Signer0_sign(pMessage, eckey, perr)) goto errorReturn; + + return true; +} + bool COSE_Sign1_validate(HCOSE_SIGN1 hSign, const cn_cbor * pKey, cose_errback * perr) { bool f; @@ -226,6 +251,27 @@ bool COSE_Sign1_validate(HCOSE_SIGN1 hSign, const cn_cbor * pKey, cose_errback * return false; } +bool COSE_Sign1_validate_eckey(HCOSE_SIGN1 hSign, const eckey_t * eckey, cose_errback * perr) +{ + COSE_Sign1Message * pSign; + const cn_cbor * cnContent; + const cn_cbor * cnProtected; + + CHECK_CONDITION(IsValidSign1Handle(hSign), COSE_ERR_INVALID_HANDLE); + + pSign = (COSE_Sign1Message *)hSign; + + cnContent = _COSE_arrayget_int(&pSign->m_message, INDEX_BODY); + CHECK_CONDITION(cnContent != NULL && cnContent->type == CN_CBOR_BYTES, COSE_ERR_INVALID_PARAMETER); + + cnProtected = _COSE_arrayget_int(&pSign->m_message, INDEX_PROTECTED); + CHECK_CONDITION(cnProtected != NULL && cnProtected->type == CN_CBOR_BYTES, COSE_ERR_INVALID_PARAMETER); + + return _COSE_Signer0_validate(pSign, eckey, perr); + +errorReturn: + return false; +} cn_cbor * COSE_Sign1_map_get_int(HCOSE_SIGN1 h, int key, int flags, cose_errback * perror) { From ed2be92db755e57f711cb496a20d69a96279377d Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 12:37:43 +0200 Subject: [PATCH 2/8] chore: create configure.h at configuration time --- CMakeLists.txt | 5 +-- include/cose/cose.h | 8 ++-- .../{cose_configure.h => cose_configure.h.in} | 43 +++++++++++-------- src/CMakeLists.txt | 16 ++++++- src/bcrypt.c | 7 +-- src/mbedtls.c | 8 ++-- src/openssl.c | 7 +-- test/test.c | 4 +- 8 files changed, 58 insertions(+), 40 deletions(-) rename include/cose/{cose_configure.h => cose_configure.h.in} (79%) diff --git a/CMakeLists.txt b/CMakeLists.txt index 54f94db7..33146249 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -154,7 +154,6 @@ if(COSE_C_RUN_CLANG_TIDY) endif() endif(COSE_C_RUN_CLANG_TIDY) - ############################################################################### # DEPENDENCIES ############################################################################### @@ -198,8 +197,7 @@ else() endif() if(COSE_C_USE_MBEDTLS) - add_definitions(-DUSE_MBED_TLS) - + set(COSE_C_USE_OPENSSL OFF) if(COSE_C_USE_FIND_PACKAGE) find_package(MbedTLS) else() @@ -231,6 +229,7 @@ if(COSE_C_USE_MBEDTLS) else() find_package(OpenSSL REQUIRED) + set(COSE_C_USE_OPENSSL ON) endif() ############################################################################### diff --git a/include/cose/cose.h b/include/cose/cose.h index a99ab789..561476db 100644 --- a/include/cose/cose.h +++ b/include/cose/cose.h @@ -3,9 +3,9 @@ #include #include "cose/cose_configure.h" -#if USE_MBED_TLS +#if defined(COSE_C_USE_MBEDTLS) #include "mbedtls/ecp.h" -#endif // USE_MBED_TLS +#endif // COSE_C_USE_MBEDTLS #ifdef __cplusplus extern "C" { @@ -207,14 +207,14 @@ typedef enum { } COSE_Curves; -#if USE_MBED_TLS +#if defined(COSE_C_USE_MBEDTLS) typedef struct mbedtls_ecp_keypair eckey_t; #else typedef struct eckey_t { struct ec_key_st *key; int group; } eckey_t; -#endif // USE_MBED_TLS +#endif // COSE_C_USE_MBEDTLS /* * messages dealing with the Enveloped message type diff --git a/include/cose/cose_configure.h b/include/cose/cose_configure.h.in similarity index 79% rename from include/cose/cose_configure.h rename to include/cose/cose_configure.h.in index dfabc96c..9a9b41b4 100644 --- a/include/cose/cose_configure.h +++ b/include/cose/cose_configure.h.in @@ -1,20 +1,25 @@ // -// Determine which cryptographic library we are going to be using +// cose_configure.h. Generated from cose_configure.h.in by CMake +// Determine which cryptographic library we are going to be using // #pragma once -#if defined(USE_MBED_TLS) -#if defined(USE_OPEN_SSL) || defined(USE_BCRYPT) +#cmakedefine COSE_C_USE_MBEDTLS +#cmakedefine COSE_C_USE_OPENSSL + + +#if defined(COSE_C_USE_MBEDTLS) +#if defined(COSE_C_USE_OPENSSL) || defined(COSE_C_USE_BCRYPT) #error Only Define One Crypto Package #endif -#elif defined(USE_BCRYPT) -#if defined(USE_OPENSSL) +#elif defined(COSE_C_USE_BCRYPT) +#if defined(COSE_C_USE_OPENSSL) #error Only Define One Crypto Package #endif -#elif !defined(USE_OPEN_SSL) +#elif !defined(COSE_C_USE_OPENSSL) #include -#define USE_OPEN_SSL +#define COSE_C_USE_OPENSSL #endif // @@ -60,20 +65,20 @@ // Define which AES CBC-MAC algorithms are to be used // -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) #define USE_AES_CBC_MAC_128_64 #define USE_AES_CBC_MAC_128_128 #define USE_AES_CBC_MAC_256_64 #define USE_AES_CBC_MAC_256_128 -#endif // !defined(USE_MBED_TLS) +#endif // !defined(COSE_C_USE_MBEDTLS) // // Define which ECDH algorithms are to be used // -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) #define USE_ECDH_ES_HKDF_256 #define USE_ECDH_ES_HKDF_512 #define USE_ECDH_SS_HKDF_256 @@ -82,9 +87,9 @@ #define USE_ECDH 1 #define USE_HKDF_SHA2 1 #endif -#endif // !defined(USE_MBED_TLS) +#endif // !defined(COSE_C_USE_MBEDTLS) -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) #define USE_ECDH_ES_A128KW #define USE_ECDH_ES_A192KW #define USE_ECDH_ES_A256KW @@ -95,23 +100,23 @@ #define USE_ECDH 1 #define USE_HKDF_AES 1 #endif -#endif // !defined(USE_MBED_TLS) +#endif // !defined(COSE_C_USE_MBEDTLS) // // Define which Key Wrap functions are to be used // -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) #define USE_AES_KW_128 #define USE_AES_KW_192 #define USE_AES_KW_256 -#endif // !defined(USE_MBED_TLS) +#endif // !defined(COSE_C_USE_MBEDTLS) // // Define which of the DIRECT + KDF algorithms are to be used // -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) #define USE_Direct_HKDF_HMAC_SHA_256 #define USE_Direct_HKDF_HMAC_SHA_512 #define USE_Direct_HKDF_AES_128 @@ -122,7 +127,7 @@ #if defined(USE_Direct_HKDF_AES_128) || defined(USE_Direct_KDF_AES_256) #define USE_HKDF_AES 1 #endif -#endif // !defined(USE_MBED_TLS) +#endif // !defined(COSE_C_USE_MBEDTLS) // @@ -132,7 +137,7 @@ #define USE_ECDSA_SHA_256 #define USE_ECDSA_SHA_384 #define USE_ECDSA_SHA_512 -#if !defined(USE_MBED_TLS) +#if !defined(COSE_C_USE_MBEDTLS) // MBEDTLS currently supports ECDH for X25519 but not EdDSA #if OPENSSL_VERSION_NUMBER > 0x10100000L // Requires OPEN SSL 1.1.1 to build @@ -141,7 +146,7 @@ #pragma message("OPENSSL VERSION IS ") #pragma message(OPENSSL_VERISON_NUMBER) #endif -#endif // !defined (USE_MBED_TLS) +#endif // !defined (COSE_C_USE_MBEDTLS) //#define USE_COUNTER_SIGNATURES diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 46a3f042..766ddb84 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,5 +1,10 @@ add_library(${PROJECT_NAME}) +# some structs look differently depending on the crypto lib used +# therefore we create the config header file at configure time. +configure_file(${CMAKE_CURRENT_LIST_DIR}/../include/cose/cose_configure.h.in + ${CMAKE_BINARY_DIR}/include/cose/cose_configure.h) + if(COSE_C_USE_MBEDTLS) set(cose_crypto mbedtls.c) else() @@ -8,7 +13,7 @@ endif() set(cose_sources ${PROJECT_SOURCE_DIR}/include/cose/cose.h - ${PROJECT_SOURCE_DIR}/include/cose/cose_configure.h + ${CMAKE_BINARY_DIR}/include/cose/cose_configure.h crypto.h cose_int.h crypto.h @@ -28,7 +33,8 @@ target_sources(${PROJECT_NAME} PRIVATE ${cose_sources}) target_include_directories( ${PROJECT_NAME} - PUBLIC $ $ + PUBLIC $ $ + $ PRIVATE ../src) target_link_libraries(${PROJECT_NAME} PRIVATE cn-cbor::cn-cbor) @@ -99,3 +105,9 @@ install( COMPONENT dev FILES_MATCHING PATTERN "*.h") +install( + DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include/cose + DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} + COMPONENT dev + FILES_MATCHING + PATTERN "*.h") diff --git a/src/bcrypt.c b/src/bcrypt.c index d38bff04..8115862d 100644 --- a/src/bcrypt.c +++ b/src/bcrypt.c @@ -1,9 +1,10 @@ #include "cose/cose.h" -#include "cose/cose_configure.h" + +#if COSE_C_USE_BCRYPT + #include "cose_int.h" #include "crypto.h" -#if USE_BCRYPT #include @@ -61,4 +62,4 @@ bool AES_CCM_Encrypt(COSE_Encrypt * pcose, int TSize, int LSize, int KSize, byte return true; } -#endif // USE_BCRYPT \ No newline at end of file +#endif // COSE_C_USE_BCRYPT \ No newline at end of file diff --git a/src/mbedtls.c b/src/mbedtls.c index 912cd7de..8e4786c2 100644 --- a/src/mbedtls.c +++ b/src/mbedtls.c @@ -1,5 +1,7 @@ #include "cose/cose.h" -#include "cose/cose_configure.h" + +#ifdef COSE_C_USE_MBEDTLS + #include "cose_int.h" #include "crypto.h" @@ -9,8 +11,6 @@ #endif #include -#ifdef USE_MBED_TLS - #include "mbedtls/ccm.h" #include "mbedtls/md.h" #include "mbedtls/ctr_drbg.h" @@ -1340,4 +1340,4 @@ bool ECDH_ComputeSecret(COSE * pRecipient, cn_cbor ** ppKeyPrivate, const cn_cbo return fRet; } #endif // USE_ECDH -#endif // USE_MBED_TLS +#endif // COSE_C_USE_MBEDTLS diff --git a/src/openssl.c b/src/openssl.c index 229ba29b..f867e1a6 100644 --- a/src/openssl.c +++ b/src/openssl.c @@ -1,4 +1,7 @@ #include "cose/cose.h" + +#ifdef COSE_C_USE_OPENSSL + #include "cose/cose_configure.h" #include "cose_int.h" #include "crypto.h" @@ -7,8 +10,6 @@ #include #include -#ifdef USE_OPEN_SSL - #include #include #include @@ -1365,4 +1366,4 @@ bool ECDH_ComputeSecret(COSE * pRecipient, cn_cbor ** ppKeyPrivate, const cn_cbo return fRet; } -#endif // USE_OPEN_SSL +#endif // COSE_C_USE_OPENSSL diff --git a/test/test.c b/test/test.c index bc110f16..70dcd638 100644 --- a/test/test.c +++ b/test/test.c @@ -21,7 +21,7 @@ #include "test.h" -#ifdef USE_MBED_TLS +#ifdef COSE_C_USE_MBEDTLS #include "mbedtls/entropy.h" #endif @@ -1042,7 +1042,7 @@ int main(int argc, char ** argv) } } -#ifdef USE_MBED_TLS +#ifdef COSE_C_USE_MBEDTLS mbedtls_entropy_context entropy; mbedtls_entropy_init(&entropy); #endif From 1eab41d7c0548bd16f5bb5788a2ae47524e5d60a Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 12:39:31 +0200 Subject: [PATCH 3/8] fix: typos --- src/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 766ddb84..95cb25a7 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -33,7 +33,7 @@ target_sources(${PROJECT_NAME} PRIVATE ${cose_sources}) target_include_directories( ${PROJECT_NAME} - PUBLIC $ $ + PUBLIC $ $ $ PRIVATE ../src) target_link_libraries(${PROJECT_NAME} PRIVATE cn-cbor::cn-cbor) From 893d9cf3fb17d012dda17bc37def336229d48c36 Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 12:52:18 +0200 Subject: [PATCH 4/8] fix: typos --- include/cose/cose_configure.h.in | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/cose/cose_configure.h.in b/include/cose/cose_configure.h.in index 9a9b41b4..85650f0b 100644 --- a/include/cose/cose_configure.h.in +++ b/include/cose/cose_configure.h.in @@ -144,7 +144,7 @@ #define USE_EDDSA #else #pragma message("OPENSSL VERSION IS ") -#pragma message(OPENSSL_VERISON_NUMBER) +#pragma message(OPENSSL_VERSION_NUMBER) #endif #endif // !defined (COSE_C_USE_MBEDTLS) From abeff7ad8644ece717814dee843ad041f042c653 Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 13:16:09 +0200 Subject: [PATCH 5/8] fix: pragma message --- include/cose/cose_configure.h.in | 33 +++++++++++++++++--------------- src/MacMessage.c | 2 +- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/include/cose/cose_configure.h.in b/include/cose/cose_configure.h.in index 85650f0b..76d92a1c 100644 --- a/include/cose/cose_configure.h.in +++ b/include/cose/cose_configure.h.in @@ -7,19 +7,33 @@ #cmakedefine COSE_C_USE_MBEDTLS #cmakedefine COSE_C_USE_OPENSSL +#cmakedefine COSE_C_USE_BCRYPT - +// make sure we only use one crypto lib #if defined(COSE_C_USE_MBEDTLS) #if defined(COSE_C_USE_OPENSSL) || defined(COSE_C_USE_BCRYPT) #error Only Define One Crypto Package #endif -#elif defined(COSE_C_USE_BCRYPT) +#endif + +#if defined(COSE_C_USE_BCRYPT) #if defined(COSE_C_USE_OPENSSL) #error Only Define One Crypto Package #endif -#elif !defined(COSE_C_USE_OPENSSL) +#endif + +#if defined(COSE_C_USE_OPENSSL) #include -#define COSE_C_USE_OPENSSL +// MBEDTLS currently supports ECDH for X25519 but not EdDSA +#if OPENSSL_VERSION_NUMBER > 0x10100000L +// Requires OPEN SSL 1.1.1 to build +#define USE_EDDSA +#else +#define STRINGIFY(x) #x +#define TOSTRING(x) STRINGIFY(x) +#pragma message("OPENSSL VERSION IS " OPENSSL_VERSION_TEXT) +#pragma message ("Version number: " TOSTRING(OPENSSL_VERSION_NUMBER)) +#endif #endif // @@ -137,17 +151,6 @@ #define USE_ECDSA_SHA_256 #define USE_ECDSA_SHA_384 #define USE_ECDSA_SHA_512 -#if !defined(COSE_C_USE_MBEDTLS) -// MBEDTLS currently supports ECDH for X25519 but not EdDSA -#if OPENSSL_VERSION_NUMBER > 0x10100000L -// Requires OPEN SSL 1.1.1 to build -#define USE_EDDSA -#else -#pragma message("OPENSSL VERSION IS ") -#pragma message(OPENSSL_VERSION_NUMBER) -#endif -#endif // !defined (COSE_C_USE_MBEDTLS) - //#define USE_COUNTER_SIGNATURES diff --git a/src/MacMessage.c b/src/MacMessage.c index 6c4eb347..43696816 100644 --- a/src/MacMessage.c +++ b/src/MacMessage.c @@ -17,7 +17,7 @@ #if INCLUDE_MAC -COSE * MacRoot = NULL; +static COSE * MacRoot = NULL; /*! \private * @brief Test if a HCOSE_MAC handle is valid From e0d24e9a59e76e5856cb0d8ff1f92b8610e0f3cb Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 13:21:14 +0200 Subject: [PATCH 6/8] build: fix install fuer config header --- src/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 95cb25a7..9a438524 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -106,7 +106,7 @@ install( FILES_MATCHING PATTERN "*.h") install( - DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include/cose + DIRECTORY ${CMAKE_BINARY_DIR}/include/cose DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} COMPONENT dev FILES_MATCHING From 3b579de2a2d648d410c70b414274993ce4b90c84 Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 16:24:40 +0200 Subject: [PATCH 7/8] style: add new line --- src/bcrypt.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/bcrypt.c b/src/bcrypt.c index 8115862d..4dfcace7 100644 --- a/src/bcrypt.c +++ b/src/bcrypt.c @@ -62,4 +62,4 @@ bool AES_CCM_Encrypt(COSE_Encrypt * pcose, int TSize, int LSize, int KSize, byte return true; } -#endif // COSE_C_USE_BCRYPT \ No newline at end of file +#endif // COSE_C_USE_BCRYPT From 48f04dbe049de5f12802ffd9beb4df3f46fdbcc1 Mon Sep 17 00:00:00 2001 From: Carlos Gomes Martinho Date: Wed, 22 Apr 2020 16:32:04 +0200 Subject: [PATCH 8/8] refactor: rename functions from sign0 to sign1 --- src/Sign1.c | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/src/Sign1.c b/src/Sign1.c index 804af46b..f4b8cbb2 100644 --- a/src/Sign1.c +++ b/src/Sign1.c @@ -1,4 +1,4 @@ -/** \file Sign.c +/** \file Sign1.c * Contains implementation of the functions related to HCOSE_SIGN handle objects. */ @@ -11,8 +11,8 @@ #if INCLUDE_SIGN1 -bool _COSE_Signer0_sign(COSE_Sign1Message * pSigner, const cn_cbor * pKey, cose_errback * perr); -bool _COSE_Signer0_validate(COSE_Sign1Message * pSign, const cn_cbor * pKey, cose_errback * perr); +bool _COSE_Signer1_sign(COSE_Sign1Message * pSigner, const cn_cbor * pKey, cose_errback * perr); +bool _COSE_Signer1_validate(COSE_Sign1Message * pSign, const cn_cbor * pKey, cose_errback * perr); void _COSE_Sign1_Release(COSE_Sign1Message * p); COSE * Sign1Root = NULL; @@ -196,7 +196,7 @@ bool COSE_Sign1_Sign(HCOSE_SIGN1 h, const cn_cbor * pKey, cose_errback * perr) pcborProtected = _COSE_encode_protected(&pMessage->m_message, perr); if (pcborProtected == NULL) goto errorReturn; - if (!_COSE_Signer0_sign(pMessage, pKey, perr)) goto errorReturn; + if (!_COSE_Signer1_sign(pMessage, pKey, perr)) goto errorReturn; return true; } @@ -221,7 +221,7 @@ bool COSE_Sign1_Sign_eckey(HCOSE_SIGN1 h, const eckey_t * eckey, cose_errback * pcborProtected = _COSE_encode_protected(&pMessage->m_message, perr); if (pcborProtected == NULL) goto errorReturn; - if (!_COSE_Signer0_sign(pMessage, eckey, perr)) goto errorReturn; + if (!_COSE_Signer1_sign(pMessage, eckey, perr)) goto errorReturn; return true; } @@ -243,7 +243,7 @@ bool COSE_Sign1_validate(HCOSE_SIGN1 hSign, const cn_cbor * pKey, cose_errback * cnProtected = _COSE_arrayget_int(&pSign->m_message, INDEX_PROTECTED); CHECK_CONDITION(cnProtected != NULL && cnProtected->type == CN_CBOR_BYTES, COSE_ERR_INVALID_PARAMETER); - f = _COSE_Signer0_validate(pSign, pKey, perr); + f = _COSE_Signer1_validate(pSign, pKey, perr); return f; @@ -267,7 +267,7 @@ bool COSE_Sign1_validate_eckey(HCOSE_SIGN1 hSign, const eckey_t * eckey, cose_er cnProtected = _COSE_arrayget_int(&pSign->m_message, INDEX_PROTECTED); CHECK_CONDITION(cnProtected != NULL && cnProtected->type == CN_CBOR_BYTES, COSE_ERR_INVALID_PARAMETER); - return _COSE_Signer0_validate(pSign, eckey, perr); + return _COSE_Signer1_validate(pSign, eckey, perr); errorReturn: return false; @@ -357,7 +357,7 @@ static bool CreateSign1AAD(COSE_Sign1Message * pMessage, byte ** ppbToSign, size return false; } -bool _COSE_Signer0_sign(COSE_Sign1Message * pSigner, const cn_cbor * pKey, cose_errback * perr) +bool _COSE_Signer1_sign(COSE_Sign1Message * pSigner, const cn_cbor * pKey, cose_errback * perr) { #ifdef USE_CBOR_CONTEXT cn_cbor_context * context = &pSigner->m_message.m_allocContext; @@ -432,7 +432,7 @@ bool _COSE_Signer0_sign(COSE_Sign1Message * pSigner, const cn_cbor * pKey, cose_ return f; } -bool _COSE_Signer0_validate(COSE_Sign1Message * pSign, const cn_cbor * pKey, cose_errback * perr) +bool _COSE_Signer1_validate(COSE_Sign1Message * pSign, const cn_cbor * pKey, cose_errback * perr) { byte * pbToSign = NULL; int alg;