sodalite
An implimentation of tweetnacl in pure rust. Originally generated by directly manually translating tweetnacl.c
into rust. Tested by verifying outputs match those of tweetnacl.
Todo
- fix failure of
crypto_sign
- start testing against sodiumoxide as well
- provide additional APIs:
- rather than take bare mutable references, use wrapper types around the refs to capture the underlying type (ie: prevent mixing keys between primitives)
- add a buffer and/or "set-only" abstraction to prevent unsafety wrt uninitialized values (also should allow some internal optimization).
- sodiumoxide style API that returns values rather than taking mutable refs
- Use namespacing to seperate different APIs and backend impls
- Provide type aliases for existing fixed arrays
- Split out
index_N
and index_mut_N
functions into a seperate crate
- Provide some of the API impovements from libsodium that are missing nacl (disjoint signatures, not requiring special extra space in buffers)
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you shall be licensed as AGPLv3 (or later) or
Apache 2.0 or LGPL v2.1 (or later) or MIT, without any additional terms or
conditions.