You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The Hydrogen library is a small, easy-to-use, hard-to-misuse cryptographic library for constrained environments.
Features:
Consistent high-level API, inspired by libsodium. Instead of low-level primitives, it exposes simple functions to solve common problems that cryptography can solve.
Under the hood, it uses modern cryptographic primitives (BLAKE2X, SipHash, XChaCha20, X25519) and follows the current best practices.
Small and easy to audit. Implemented as one tiny file for every set of operation, and adding a single .c file to your project is all it takes to use libhydrogen in your project.
The whole code is released under a single, very liberal license (ISC).
Zero dynamic memory allocations and low stack requirements. This makes it usable in constrained environments such as microcontrollers.
Portable: written in standard C99. Supports Linux, *BSD, MacOS, Windows, and the Arduino IDE out of the box.
Can generate cryptographically-secure random numbers, even on Arduino boards.
Attempts to mitigate the implications of accidental misuse, even on systems with an unreliable PRG and/or no clock.
Non-goals:
Having multiple primitives serving the same purpose, even to provide compatibility with other libraries.
Networking -- but a simple key exchange API based on the Noise protocol is available.
Replacing libsodium. Libhydrogen focuses on being small and is for environments where libsodium cannot be used.