mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #17701 from fjmolinas/pr_libcose_riot_crypto
pkg/libcose: add RIOT as crypto backend
This commit is contained in:
commit
d7533fb855
@ -14,6 +14,10 @@ ifneq (,$(filter auto_init_saul,$(USEMODULE)))
|
||||
USEMODULE += saul_init_devs
|
||||
endif
|
||||
|
||||
ifneq (,$(filter auto_init_libcose_crypt,$(USEMODULE)))
|
||||
USEMODULE += libcose_crypt_init
|
||||
endif
|
||||
|
||||
ifneq (,$(filter xtimer,$(USEMODULE)))
|
||||
ifeq (,$(filter ztimer_xtimer_compat,$(USEMODULE)))
|
||||
USEMODULE += div
|
||||
|
@ -31,6 +31,21 @@ config MODULE_LIBCOSE_CRYPT_MONOCYPHER
|
||||
depends on TEST_KCONFIG
|
||||
depends on PACKAGE_MONOCYPHER
|
||||
|
||||
config MODULE_LIBCOSE_CRYPT_RIOT
|
||||
bool "COSE use RIOT backend"
|
||||
depends on TEST_KCONFIG
|
||||
select MODULE_CRYPTO
|
||||
|
||||
config MODULE_LIBCOSE_CRYPT_INIT
|
||||
bool "LibCose Crypt Initialization functions"
|
||||
default y
|
||||
|
||||
config MODULE_AUTO_INIT_LIBCOSE_CRYPT
|
||||
bool "Auto initialize LibCose Crypt"
|
||||
depends on MODULE_AUTO_INIT
|
||||
select MODULE_LIBCOSE_CRYPT_INIT
|
||||
default y
|
||||
|
||||
endif # PACKAGE_LIBCOSE
|
||||
|
||||
config MODULE_LIBCOSE_CRYPT
|
||||
|
@ -1,6 +1,6 @@
|
||||
PKG_NAME=libcose
|
||||
PKG_URL=https://github.com/bergzand/libcose
|
||||
PKG_VERSION=2929fdce7affbd5bb9db201370d95d8f7cf680f9
|
||||
PKG_VERSION=ea1fed87d6ca9b478f8bed323af97e6b192c0a6d
|
||||
PKG_LICENSE=LGPL
|
||||
|
||||
include $(RIOTBASE)/pkg/pkg.mk
|
||||
|
@ -13,3 +13,12 @@ endif
|
||||
ifneq (,$(filter libcose_crypt_tinycrypt,$(USEMODULE)))
|
||||
USEPKG += tinycrypt
|
||||
endif
|
||||
ifneq (,$(filter libcose_crypt_monocypher,$(USEMODULE)))
|
||||
USEPKG += monocypher
|
||||
endif
|
||||
ifneq (,$(filter libcose_crypt_riot,$(USEMODULE)))
|
||||
USEMODULE += crypto
|
||||
endif
|
||||
|
||||
DEFAULT_MODULE += libcose_crypt_init
|
||||
DEFAULT_MODULE += auto_init_libcose_crypt
|
||||
|
@ -1,4 +1,7 @@
|
||||
INCLUDES += -I$(PKGDIRBASE)/libcose/include
|
||||
INCLUDES += -I$(PKGDIRBASE)/libcose/include \
|
||||
-I$(RIOTBASE)/pkg/libcose/include \
|
||||
#
|
||||
|
||||
CFLAGS += -DUSE_CBOR_CONTEXT
|
||||
|
||||
ifneq (,$(filter libcose_crypt_hacl,$(USEMODULE)))
|
||||
@ -10,6 +13,20 @@ endif
|
||||
ifneq (,$(filter libcose_crypt_tinycrypt,$(USEMODULE)))
|
||||
CFLAGS += -DCRYPTO_TINYCRYPT
|
||||
endif
|
||||
ifneq (,$(filter libcose_crypt_monocypher,$(USEMODULE)))
|
||||
CFLAGS += -DCRYPTO_MONOCYPHER
|
||||
endif
|
||||
ifneq (,$(filter libcose_crypt_riot,$(USEMODULE)))
|
||||
CFLAGS += -DCRYPTO_RIOT
|
||||
DIRS += $(RIOTBASE)/pkg/libcose/contrib
|
||||
endif
|
||||
ifneq (,$(filter libcose_crypt_init,$(USEMODULE)))
|
||||
DIRS += $(RIOTBASE)/pkg/libcose/init
|
||||
endif
|
||||
|
||||
# Declare pseudomodules here to be selfcontained
|
||||
PSEUDOMODULES += libcose_crypt_%
|
||||
PSEUDOMODULES += libcose_crypt_c25519
|
||||
PSEUDOMODULES += libcose_crypt_hacl
|
||||
PSEUDOMODULES += libcose_crypt_tinycrypt
|
||||
PSEUDOMODULES += libcose_crypt_monocypher
|
||||
PSEUDOMODULES += auto_init_libcose_crypt
|
||||
|
@ -1,4 +1,6 @@
|
||||
MODULE := libcose_crypt
|
||||
SUBMODULES = 1
|
||||
|
||||
SRC += keygen_symm.c
|
||||
|
||||
include $(RIOTBASE)/Makefile.base
|
||||
|
3
pkg/libcose/contrib/Makefile
Normal file
3
pkg/libcose/contrib/Makefile
Normal file
@ -0,0 +1,3 @@
|
||||
MODULE = libcose_crypt_riot
|
||||
|
||||
include $(RIOTBASE)/Makefile.base
|
54
pkg/libcose/contrib/libcose_riot_crypto.c
Normal file
54
pkg/libcose/contrib/libcose_riot_crypto.c
Normal file
@ -0,0 +1,54 @@
|
||||
/*
|
||||
* Copyright (C) 2022 Inria
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup pkg_libcose
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief RIOT as a crypto backend for libcose implementation
|
||||
*
|
||||
* @author Francisco Molina <francois-xavier.molina@inria.fr>
|
||||
*
|
||||
* @}
|
||||
*/
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "crypto/chacha20poly1305.h"
|
||||
|
||||
#include "cose.h"
|
||||
#include "cose/crypto.h"
|
||||
#include "cose/crypto/selectors.h"
|
||||
|
||||
int cose_crypto_aead_encrypt_chachapoly(uint8_t *c, size_t *clen,
|
||||
const uint8_t *msg, size_t msglen,
|
||||
const uint8_t *aad, size_t aadlen,
|
||||
const uint8_t *npub, const uint8_t *k)
|
||||
{
|
||||
if (*clen < msglen + CHACHA20POLY1305_TAG_BYTES) {
|
||||
return COSE_ERR_INVALID_PARAM;
|
||||
}
|
||||
chacha20poly1305_encrypt(c, msg, msglen, aad, aadlen, k, npub);
|
||||
*clen = msglen + CHACHA20POLY1305_TAG_BYTES;
|
||||
return COSE_OK;
|
||||
}
|
||||
|
||||
int cose_crypto_aead_decrypt_chachapoly(uint8_t *msg, size_t *msglen,
|
||||
const uint8_t *c, size_t clen,
|
||||
const uint8_t *aad, size_t aadlen,
|
||||
const uint8_t *npub, const uint8_t *k)
|
||||
{
|
||||
if (chacha20poly1305_decrypt(c, clen, msg, msglen, aad, aadlen, k, npub) == 1) {
|
||||
return COSE_OK;
|
||||
}
|
||||
else {
|
||||
return COSE_ERR_CRYPTO;
|
||||
}
|
||||
}
|
56
pkg/libcose/include/cose/crypto/riot.h
Normal file
56
pkg/libcose/include/cose/crypto/riot.h
Normal file
@ -0,0 +1,56 @@
|
||||
/*
|
||||
* Copyright (C) 2022 Inria
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup pkg_libcose
|
||||
*
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief Crypto function api for glueing RIOT crypto libraries
|
||||
*
|
||||
* @author Francisco Molina <francois-xavier.molina@inria.fr>
|
||||
*/
|
||||
|
||||
#ifndef COSE_CRYPTO_RIOT_H
|
||||
#define COSE_CRYPTO_RIOT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#ifndef AUTO_INIT_PRIO_MOD_LIBCOSE
|
||||
/**
|
||||
* @brief libCOSE init priority
|
||||
*/
|
||||
#define AUTO_INIT_PRIO_MOD_LIBCOSE 1050
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @name list of provided algorithms
|
||||
*
|
||||
* @{
|
||||
*/
|
||||
#define HAVE_ALGO_CHACHA20POLY1305
|
||||
/** @} */
|
||||
|
||||
/**
|
||||
* @brief Initialize libCOSE RIOT crypto backend
|
||||
*
|
||||
* @note Automatically called if 'auto_init_libcose_crypt_riot' is included
|
||||
*
|
||||
*/
|
||||
void libcose_crypt_init(void);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* COSE_CRYPTO_RIOT_H */
|
||||
|
||||
/** @} */
|
3
pkg/libcose/init/Makefile
Normal file
3
pkg/libcose/init/Makefile
Normal file
@ -0,0 +1,3 @@
|
||||
MODULE = libcose_crypt_init
|
||||
|
||||
include $(RIOTBASE)/Makefile.base
|
48
pkg/libcose/init/init.c
Normal file
48
pkg/libcose/init/init.c
Normal file
@ -0,0 +1,48 @@
|
||||
/*
|
||||
* Copyright (C) 2022 Inria
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup pkg_libcose
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief RIOT as a crypto backend common functions
|
||||
*
|
||||
* @author Francisco Molina <francois-xavier.molina@inria.fr>
|
||||
*
|
||||
* @}
|
||||
*/
|
||||
|
||||
|
||||
#include <stdint.h>
|
||||
#include "random.h"
|
||||
#include "kernel_defines.h"
|
||||
#include "xfa.h"
|
||||
|
||||
#include "cose/crypto.h"
|
||||
|
||||
#if IS_USED(MODULE_AUTO_INIT)
|
||||
#include "auto_init_utils.h"
|
||||
#endif
|
||||
|
||||
static int _riot_random_bytes(void* arg, unsigned char * buf, size_t len)
|
||||
{
|
||||
(void)arg;
|
||||
random_bytes((uint8_t*) buf, len);
|
||||
return 1;
|
||||
}
|
||||
|
||||
void libcose_crypt_init(void)
|
||||
{
|
||||
cose_crypt_set_rng(_riot_random_bytes, NULL);
|
||||
}
|
||||
|
||||
#if IS_USED(MODULE_AUTO_INIT_LIBCOSE_CRYPT)
|
||||
/* initialize just after random module */
|
||||
AUTO_INIT(libcose_crypt_init, AUTO_INIT_PRIO_MOD_LIBCOSE);
|
||||
#endif
|
Binary file not shown.
Binary file not shown.
@ -47,15 +47,6 @@ static cose_sign_dec_t verify;
|
||||
static cose_signature_t signature1, signature2;
|
||||
static cose_key_t signer1, signer2;
|
||||
|
||||
#if defined(MODULE_LIBCOSE_CRYPT_HACL) || defined(MODULE_LIBCOSE_CRYPT_MONOCYPHER)
|
||||
static unsigned char symmkey[COSE_CRYPTO_AEAD_CHACHA20POLY1305_KEYBYTES];
|
||||
static uint8_t nonce[COSE_CRYPTO_AEAD_CHACHA20POLY1305_NONCEBYTES] = { 0 };
|
||||
static cose_key_t symm;
|
||||
static cose_encrypt_t test_encrypt;
|
||||
static cose_encrypt_dec_t test_decrypt;
|
||||
static cose_recp_dec_t test_derecp;
|
||||
#endif
|
||||
|
||||
/* COSE sign buffer */
|
||||
static uint8_t buf[2048];
|
||||
/* Signature Verification buffer */
|
||||
@ -185,45 +176,11 @@ static void test_libcose_02(void)
|
||||
sizeof(vbuf)));
|
||||
}
|
||||
|
||||
#if defined(MODULE_LIBCOSE_CRYPT_HACL) || defined(MODULE_LIBCOSE_CRYPT_MONOCYPHER)
|
||||
/* Untagged 1 encrypt test with chacha20poly1305*/
|
||||
static void test_libcose_03(void)
|
||||
{
|
||||
cose_key_init(&symm);
|
||||
cose_encrypt_init(&test_encrypt, 0);
|
||||
|
||||
cose_crypto_keygen(symmkey, sizeof(symmkey), COSE_ALGO_CHACHA20POLY1305);
|
||||
cose_key_set_kid(&symm, (uint8_t *)kid, sizeof(kid) - 1);
|
||||
cose_key_set_keys(&symm, 0, COSE_ALGO_CHACHA20POLY1305, NULL, NULL,
|
||||
symmkey);
|
||||
|
||||
cose_encrypt_add_recipient(&test_encrypt, &symm);
|
||||
cose_encrypt_set_payload(&test_encrypt, payload, sizeof(payload) - 1);
|
||||
cose_encrypt_set_algo(&test_encrypt, COSE_ALGO_DIRECT);
|
||||
|
||||
uint8_t *out = NULL;
|
||||
ssize_t len = cose_encrypt_encode(&test_encrypt, buf, sizeof(buf), nonce,
|
||||
&out);
|
||||
TEST_ASSERT(len > 0);
|
||||
TEST_ASSERT_EQUAL_INT(0, cose_encrypt_decode(&test_decrypt, out, len));
|
||||
size_t plaintext_len = 0;
|
||||
cose_encrypt_recp_iter(&test_decrypt, &test_derecp);
|
||||
TEST_ASSERT_EQUAL_INT(0,
|
||||
cose_encrypt_decrypt(&test_decrypt, &test_derecp,
|
||||
&symm, buf, sizeof(buf),
|
||||
vbuf, &plaintext_len));
|
||||
TEST_ASSERT_EQUAL_INT( sizeof(payload) - 1, plaintext_len);
|
||||
}
|
||||
#endif
|
||||
|
||||
Test *tests_libcose(void)
|
||||
{
|
||||
EMB_UNIT_TESTFIXTURES(fixtures) {
|
||||
new_TestFixture(test_libcose_01),
|
||||
new_TestFixture(test_libcose_02),
|
||||
#if defined(MODULE_LIBCOSE_CRYPT_HACL) || defined(MODULE_LIBCOSE_CRYPT_MONOCYPHER)
|
||||
new_TestFixture(test_libcose_03),
|
||||
#endif
|
||||
};
|
||||
|
||||
EMB_UNIT_TESTCALLER(libcose_tests, setUp, NULL, fixtures);
|
||||
|
14
tests/pkg_libcose_encrypt/Makefile
Normal file
14
tests/pkg_libcose_encrypt/Makefile
Normal file
@ -0,0 +1,14 @@
|
||||
include ../Makefile.tests_common
|
||||
|
||||
TEST_ON_CI_WHITELIST += native
|
||||
|
||||
USEPKG += libcose
|
||||
# crypto backend.
|
||||
USEMODULE += libcose_crypt_riot
|
||||
# USEMODULE += libcose_crypt_hacl
|
||||
# USEMODULE += libcose_crypt_monocypher
|
||||
# USEMODULE += libcose_crypt_tinycrypt
|
||||
USEMODULE += memarray
|
||||
USEMODULE += embunit
|
||||
|
||||
include $(RIOTBASE)/Makefile.include
|
25
tests/pkg_libcose_encrypt/Makefile.ci
Normal file
25
tests/pkg_libcose_encrypt/Makefile.ci
Normal file
@ -0,0 +1,25 @@
|
||||
BOARD_INSUFFICIENT_MEMORY := \
|
||||
arduino-duemilanove \
|
||||
arduino-leonardo \
|
||||
arduino-nano \
|
||||
arduino-uno \
|
||||
atmega328p \
|
||||
atmega328p-xplained-mini \
|
||||
bluepill-stm32f030c8 \
|
||||
i-nucleo-lrwan1 \
|
||||
msb-430 \
|
||||
msb-430h \
|
||||
nucleo-f030r8 \
|
||||
nucleo-f031k6 \
|
||||
nucleo-f042k6 \
|
||||
nucleo-l011k4 \
|
||||
nucleo-l031k6 \
|
||||
nucleo-l053r8 \
|
||||
samd10-xmini \
|
||||
slstk3400a \
|
||||
stk3200 \
|
||||
stm32f030f4-demo \
|
||||
stm32f0discovery \
|
||||
stm32g0316-disco \
|
||||
stm32l0538-disco \
|
||||
#
|
9
tests/pkg_libcose_encrypt/app.config.test
Normal file
9
tests/pkg_libcose_encrypt/app.config.test
Normal file
@ -0,0 +1,9 @@
|
||||
CONFIG_MODULE_EMBUNIT=y
|
||||
CONFIG_MODULE_LIBCOSE_CRYPT_RIOT=y
|
||||
CONFIG_MODULE_MEMARRAY=y
|
||||
# Should be autoselecting the MODULE_PRNG_HWRNG if possible
|
||||
# Since the makefile cannot we have to override until end of migration
|
||||
# Remove when TEST_KCONFIG is complete
|
||||
CONFIG_MODULE_PRNG_MUSL_LCG=y
|
||||
CONFIG_MODULE_RANDOM=y
|
||||
CONFIG_PACKAGE_LIBCOSE=y
|
99
tests/pkg_libcose_encrypt/main.c
Normal file
99
tests/pkg_libcose_encrypt/main.c
Normal file
@ -0,0 +1,99 @@
|
||||
/*
|
||||
* Copyright (C) 2018 Freie Universität Berlin
|
||||
* Copyright (C) 2018 Inria
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
/**
|
||||
* @ingroup tests
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief Tests for pkg libcose encryption
|
||||
*
|
||||
* @author Koen Zandberg <koen@bergzand.net>
|
||||
*/
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "cose.h"
|
||||
#include "cose/sign.h"
|
||||
#include "cose/crypto.h"
|
||||
#include "embUnit.h"
|
||||
#include "memarray.h"
|
||||
#include "random.h"
|
||||
|
||||
static uint8_t payload[] = "This is the content.";
|
||||
static uint8_t buf[2048];
|
||||
static uint8_t plaintext[2048];
|
||||
static uint8_t kid[] = "sec-256";
|
||||
|
||||
static void setUp(void)
|
||||
{
|
||||
/* Initialize */
|
||||
random_init(0);
|
||||
/* Clear buffer */
|
||||
memset(plaintext, 0, sizeof(plaintext));
|
||||
memset(buf, 0, sizeof(buf));
|
||||
}
|
||||
|
||||
static void _test_encrypt_generic(cose_algo_t algo)
|
||||
{
|
||||
uint8_t *out;
|
||||
uint8_t key_bytes[64];
|
||||
static const uint8_t nonce_bytes[32] = { 0 };
|
||||
cose_encrypt_t crypt;
|
||||
cose_key_t key;
|
||||
|
||||
cose_crypto_keygen(key_bytes, sizeof(key_bytes), algo);
|
||||
|
||||
cose_key_init(&key); /* Generate key */
|
||||
cose_key_set_kid(&key, kid, sizeof(kid) - 1);
|
||||
cose_key_set_keys(&key, 0, algo, NULL, NULL, key_bytes);
|
||||
|
||||
cose_encrypt_init(&crypt, COSE_FLAGS_ENCRYPT0);
|
||||
cose_encrypt_add_recipient(&crypt, &key);
|
||||
cose_encrypt_set_payload(&crypt, payload, sizeof(payload) - 1);
|
||||
cose_encrypt_set_algo(&crypt, COSE_ALGO_DIRECT);
|
||||
COSE_ssize_t len = cose_encrypt_encode(&crypt, buf, sizeof(buf), nonce_bytes, &out);
|
||||
cose_encrypt_dec_t decrypt;
|
||||
|
||||
TEST_ASSERT_EQUAL_INT(0, cose_encrypt_decode(&decrypt, out, len));
|
||||
size_t plaintext_len = 0;
|
||||
|
||||
TEST_ASSERT_EQUAL_INT(0,
|
||||
cose_encrypt_decrypt(&decrypt, NULL, &key, buf, sizeof(buf), plaintext,
|
||||
&plaintext_len));
|
||||
TEST_ASSERT_EQUAL_INT(sizeof(payload) - 1, plaintext_len);
|
||||
}
|
||||
|
||||
#ifdef HAVE_ALGO_CHACHA20POLY1305
|
||||
static void test_libcose_chacha20poly1305(void)
|
||||
{
|
||||
_test_encrypt_generic(COSE_ALGO_CHACHA20POLY1305);
|
||||
}
|
||||
#endif
|
||||
|
||||
Test *tests_libcose_encrypt(void)
|
||||
{
|
||||
EMB_UNIT_TESTFIXTURES(fixtures) {
|
||||
#ifdef HAVE_ALGO_CHACHA20POLY1305
|
||||
new_TestFixture(test_libcose_chacha20poly1305),
|
||||
#endif
|
||||
};
|
||||
|
||||
EMB_UNIT_TESTCALLER(libcose_encrypt_tests, setUp, NULL, fixtures);
|
||||
return (Test *)&libcose_encrypt_tests;
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
TESTS_START();
|
||||
TESTS_RUN(tests_libcose_encrypt());
|
||||
TESTS_END();
|
||||
return 0;
|
||||
}
|
22
tests/pkg_libcose_encrypt/tests/01-run.py
Executable file
22
tests/pkg_libcose_encrypt/tests/01-run.py
Executable file
@ -0,0 +1,22 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
# Copyright (C) 2017 Freie Universität Berlin
|
||||
#
|
||||
# This file is subject to the terms and conditions of the GNU Lesser
|
||||
# General Public License v2.1. See the file LICENSE in the top level
|
||||
# directory for more details.
|
||||
|
||||
import os
|
||||
import sys
|
||||
from testrunner import run_check_unittests
|
||||
from testrunner import TIMEOUT as DEFAULT_TIMEOUT
|
||||
|
||||
|
||||
BOARD = os.environ['BOARD']
|
||||
# on real hardware, this test application can take several minutes to
|
||||
# complete (>5min on nrf51dk)
|
||||
TIMEOUT = 400 if BOARD != 'native' else DEFAULT_TIMEOUT
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(run_check_unittests(timeout=TIMEOUT))
|
Loading…
Reference in New Issue
Block a user