Operating system Website nacl.cr.yp.to | ||
Original author(s) Initial release 2008; 9 years ago (2008) |
NaCl (pronounced "salt") is an abbreviation for "Networking and Cryptography library", a public domain "...high-speed software library for network communication, encryption, decryption, signatures, etc".
Contents
- Public key cryptography
- Secret key cryptography
- Low level functions
- Key features
- Implementations
- Alternative implementation
- References
NaCl was created by the mathematician and programmer Daniel J. Bernstein who is best known for the creation of qmail and Curve25519. The core team also includes Tanja Lange and Peter Schwabe. The main goal while creating NaCl, according to the paper, was to "avoid various types of cryptographic disasters suffered by previous cryptographic libraries".
Public-key cryptography
Secret-key cryptography
Low-level functions
Key features
Implementations
Reference implementation is written in C, often with several inline assembler. C++ and Python are handled as wrappers.
NaCl has a variety of programming language bindings such as PHP, and forms the basis for Libsodium, a cross-platform cryptography library created in 2013 which is API compatible with NaCl.