#coap #oscore #back-end #embedded-devices #no-alloc #networking

no-std liboscore-cryptobackend

An implementation of libOSCORE's cryptographic primitives backend based on Rust implementations

5 releases

0.2.2 Dec 6, 2024
0.2.1 Nov 25, 2024
0.2.0 Nov 11, 2024
0.1.0 Apr 17, 2024

#2146 in Embedded development

Download history 18/week @ 2024-09-21 8/week @ 2024-09-28 1/week @ 2024-10-05 7/week @ 2024-10-12 1/week @ 2024-10-19 3/week @ 2024-10-26 5/week @ 2024-11-02 122/week @ 2024-11-09 18/week @ 2024-11-16 209/week @ 2024-11-23 274/week @ 2024-11-30 577/week @ 2024-12-07 170/week @ 2024-12-14 18/week @ 2024-12-21 3/week @ 2024-12-28 229/week @ 2025-01-04

435 downloads per month
Used in liboscore

BSD-3-Clause

23KB
440 lines

libOSCORE: An OSCORE implementation (not only) for embedded systems

The libOSCORE library is a portable (and freestanding) implementation of OSCORE (RFC8613) usable for embedded devices.

OSCORE is a method of protecting (ie. encrypting and verifying) exchanges of CoAP messages (network traffic between typical IoT devices) against eavesdropping or manipulation in an end-to-end fashion without sacrificing the compactness of the messages and protocol implementations. The article OSCORE: A look at the new IoT security protocol provides a newcomer friendly summary.

This implementation aims to be usable on various platforms, especially embedded ones; it achieves this by describing its requirements towards the used platform's CoAP implementation with a small generic API that can then be implemented by different CoAP libraries, for example RIOT-OS's gcoap. By the choice of programming language (C), the avoidance of dynamic memory allocation as well as the extensive use of in-place operations, it is suitable for the smallest class of devices that are capable of IP traffic and of performing cryptographic operations at all.

State of the project

The library is feature complete and an implemenation of the OSCORE plug test server is usable on RIOT-OS, even though it does not pass all the tests yet.

Use and documentation

The libOSCORE library can be used in different ways depending on the support of the underlying CoAP library.

The integration levels guide gives an overview of the possibilities, and also serves as a starting point into the rest of the documentation.

For a quick start, some examples and demos cover the common use cases:

Please note that the examples currently use what is described as "intermediate integration" (see integration levels) in their code. For high-level applications, it is recommended to use full integration, but that level is not even provided for the RIOT platform yet.

Library integrations

Libraries with planned integration:

  • RIOT-OS - light integration available; full integration tracked at 11761
  • MoCkoAP – an internal minimal CoAP library used as a mock-up in tests
  • libcose – providing the required crypto primitives
  • Rust integration
    • liboscore-cryptobackend – providing a (configurable) variety of crypto primitives
    • liboscore-msgbackend – implementing libOSCORE's message accessors on the [coap-message] traits
    • liboscore-backends-standalone – build infrastructure for using the Rust cryptobackend from a C application
    • liboscore – high level Rust abstractions

Potential future candidates: (No implementation is being planned right now, but they are being looked into for portability)

License

Copyright 2019 Christian Amsüss and Ericsson AB

Licensed under the terms of the 3-clause BSD license as described in the LICENSE file.


lib.rs:

Backend for liboscore's crypto API that fans out to AEAD algorithms base on the aead Rust crate.

This takes a mixture of trait- and enum-based approaches; algorithms are handled as trait objects (or constructors derived from them), but the oscore_crypto_aead_encryptstate_t would eventually be an enum in order to be Sized and thus stack-allocatable.

Dependencies

~1.2–1.6MB
~27K SLoC