7 unstable releases (3 breaking)
0.4.0 | Feb 24, 2025 |
---|---|
0.3.2 | Mar 6, 2025 |
0.3.1 | Feb 20, 2025 |
0.2.0 | May 20, 2024 |
0.1.0 | Feb 22, 2023 |
#170 in Cryptography
5,323 downloads per month
Used in 3 crates
(2 directly)
160KB
3.5K
SLoC
Sphinx
A Sphinx packet implementation in Rust.
Prerequisites
- rust (stable) : https://www.rust-lang.org/
- docker (for code coverage reports): https://www.docker.com/
Testing
cargo test
will run the unit and integration tests.
Versioning
Whilst this crate hasn't been strictly following the semver versioning conventions, the following changes have been made:
v0.1.0
initial release
v0.1.1
updates crypto dependencies, including dalek libraries
v0.2.0
fixes uses of undefined scalar multiplications and transitions to using pure x25519 instead
v0.3.0
allows using the library with either the v0.2.0 or v0.1.1 crypto (for backwards compatibility reasons). it also changes the public API to expose version information which has further been reinterpreted to no longer map to the semver version of this library
v0.3.1
added additional public methods on the Version
v0.4.0
removed processing and creation of packets with undefined operations
Benchmarks
To run benchmarks, use:
cargo bench
Rust benchmarks run the operation multiple times to give a consistent output and report back in the number of
nanoseconds (billionths of a second) per iteration. 1000000000 / result
gives you the number of operations per second.
For later reference, on Dave's i7 Dell XPS-13 (2018) laptop (our test reference machine :)) output is as follows.
test tests::bench_new ... bench: 386.348 us/iter
test tests::bench_process ... bench: 157.322 us/iter
1000000 / 386.348
= ~2588 packet creations per second1000000 / 157.322
= ~6356 packet unwrappings per second
Dependencies
~4–5.5MB
~109K SLoC