1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/pkg/libcose/doc.txt
2021-06-10 12:36:16 +02:00

50 lines
1.7 KiB
Plaintext

/**
* @defgroup pkg_libcose libcose for RIOT
* @ingroup pkg
* @brief Constrained node COSE library
* @see https://github.com/bergzand/libcose
*
* Usage
* -----
*
* Add as a package in the Makefile of your application:
*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.mk}
* USEPKG += libcose
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
* The main consumers of libcose are other libraries or system components, for
* example @ref sys_suit "SUIT".
*
* The use of the library itself [is described in the libcose
* documentation](https://bergzand.github.io/libcose/), and some example code
* can be found in
* [`tests/pkg_libcose/`](https://github.com/RIOT-OS/RIOT/tree/master/tests/pkg_libcose).
*
* Backends
* --------
*
* The libcose library does not implement cryptographic algorithms itself, but
* fans that out to other libraries (which are pulled into the dependency tree
* as packages) and exposes a consistent interface for the
* operations they provide.
*
* Backends are selected by any of those pseudomodules:
*
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.mk}
* USEMODULE += libcose_crypt_hacl
* USEMODULE += libcose_crypt_monocypher
* USEMODULE += libcose_crypt_c25519
* USEMODULE += libcose_crypt_tinycrypt
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
*
* The selection of pseudomodules determines the available algorithms:
*
* * @ref pkg_hacl "HACL" and @ref pkg_monocypher "Monocypher" both provide ChaCha20-Poly1305 and Ed25519.
* * @ref pkg_c25519 "C25519" only provides the Ed25519 algorithm.
* * @ref pkg_tinycrypt "TINYCRYPT" provides AES-CCM-16-64-128, AES-CCM-16-128-128
* ECDSA and ES256 as well as EC NIST P-256 curve support.
*
* Some backend may conflict, others might be complementary.
*/