https://github.com/mcginty/snow
A Rust implementation of the Noise Protocol Framework
https://github.com/mcginty/snow
crypto cryptography noise noise-protocol noise-protocol-framework rust security
Last synced: 15 days ago
JSON representation
A Rust implementation of the Noise Protocol Framework
- Host: GitHub
- URL: https://github.com/mcginty/snow
- Owner: mcginty
- License: apache-2.0
- Created: 2016-10-16T12:09:30.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2025-03-04T17:28:24.000Z (about 2 months ago)
- Last Synced: 2025-04-01T23:09:29.050Z (22 days ago)
- Topics: crypto, cryptography, noise, noise-protocol, noise-protocol-framework, rust, security
- Language: Rust
- Homepage:
- Size: 2.9 MB
- Stars: 930
- Watchers: 25
- Forks: 120
- Open Issues: 34
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
- Security: SECURITY.md
Awesome Lists containing this project
README
# Snow
[](https://crates.io/crates/snow)
[](https://docs.rs/snow)
[](https://github.com/mcginty/snow/actions)
[](https://deps.rs/repo/github/mcginty/snow)
An implementation of Trevor Perrin's [Noise Protocol](https://noiseprotocol.org/) that
is designed to be Hard To Fuck Up™.🔥 **Warning** 🔥 This library has not received any formal audit.
## What's it look like?
See `examples/simple.rs` for a more complete TCP client/server example.
```rust
let mut noise = snow::Builder::new("Noise_NN_25519_ChaChaPoly_BLAKE2s".parse()?)
.build_initiator()?;let mut buf = [0u8; 65535];
// write first handshake message
noise.write_message(&[], &mut buf)?;// receive response message
let incoming = receive_message_from_the_mysterious_ether();
noise.read_message(&incoming, &mut buf)?;// complete handshake, and transition the state machine into transport mode
let mut noise = noise.into_transport_mode()?;
```See the full documentation at [https://docs.rs/snow](https://docs.rs/snow).
## Implemented
Snow is currently tracking against [Noise spec revision 34](https://noiseprotocol.org/noise_rev34.html).
However, a not all features have been implemented yet (pull requests welcome):
- [ ] [The `fallback` modifier](https://noiseprotocol.org/noise_rev34.html#the-fallback-modifier)
## Crypto
Cryptographic providers are swappable through `Builder::with_resolver()`, but by default
it chooses select, artisanal pure-Rust implementations (see `Cargo.toml` for a quick
overview).### Other Providers
#### ring
[ring](https://github.com/briansmith/ring) is a crypto library based off of BoringSSL
and is significantly faster than most of the pure-Rust implementations.If you enable the `ring-resolver` feature, Snow will include a `resolvers::ring` module
as well as a `RingAcceleratedResolver` available to be used with
`Builder::with_resolver()`.If you enable the `ring-accelerated` feature, Snow will default to choosing `ring`'s
crypto implementations when available.### Resolver primitives supported
| | default | ring |
| -------------------------------------: | :----------------: | :----------------: |
| CSPRNG | :heavy_check_mark: | :heavy_check_mark: |
| 25519 | :heavy_check_mark: | :heavy_check_mark: |
| 448 | | |
| P-256:checkered_flag: | :heavy_check_mark: | |
| AESGCM | :heavy_check_mark: | :heavy_check_mark: |
| ChaChaPoly | :heavy_check_mark: | :heavy_check_mark: |
| XChaChaPoly:checkered_flag: | :heavy_check_mark: | |
| SHA256 | :heavy_check_mark: | :heavy_check_mark: |
| SHA512 | :heavy_check_mark: | :heavy_check_mark: |
| BLAKE2s | :heavy_check_mark: | |
| BLAKE2b | :heavy_check_mark: | |> [!Note]
> :checkered_flag: P-256 and XChaChaPoly are not in the official specification of Noise, and thus need to be enabled
via the feature flags `use-p256` and `use-xchacha20poly1305`, respectively.## `no_std` support and feature selection
Snow can be used in `no_std` environments if `alloc` is provided.
By default, Snow uses the standard library, default crypto resolver and a selected collection
of crypto primitives. To use Snow in `no_std` environments or make other kinds of customized
setups, use Snow with `default-features = false`. This way you will individually select
the components you wish to use. `default-resolver` is the only built-in resolver that
currently supports `no_std`.To use a custom setup with `default-resolver`, enable your desired selection of cryptographic primitives:
| | Primitive | Feature flag |
| ----------: | :------------------------------------- | :--------------------- |
| **DHs** | Curve25519 | `use-curve25519` |
| | P-256:checkered_flag: | `use-p256` |
| **Ciphers** | AES-GCM | `use-aes-gcm` |
| | ChaChaPoly | `use-chacha20poly1305` |
| | XChaChaPoly:checkered_flag: | `use-xchacha20poly1305`|
| **Hashes** | SHA-256 | `use-sha2` |
| | SHA-512 | `use-sha2` |
| | BLAKE2s | `use-blake2` |
| | BLAKE2b | `use-blake2` |> [!Note]
> :checkered_flag: XChaChaPoly and P-256 are not in the official specification of Noise, but they are supported
by Snow.### Example configurations
**Curve25519 + AES-GCM + SHA-2** with standard library features.
```toml
default-features = false
features = [
"use-curve25519",
"use-aes-gcm",
"use-sha2",
"std",
]
```**Curve25519 + ChaChaPoly + BLAKE2** without standard library.
```toml
default-features = false
features = [
"use-curve25519",
"use-chacha20poly1305",
"use-blake2",
]
```### `getrandom` support
Most crypto implementations supported by `default-resolver` will require
[`getrandom`](getrandom).If your target platform is not directly supported
you might have to provide a custom implementation in your crate root.
Check out their [documentation](getrandom-custom) for details.[getrandom]: https://crates.io/crates/getrandom
[getrandom-custom]: https://docs.rs/getrandom/0.2.15/getrandom/macro.register_custom_getrandom.html## License
`snow` is offered with a dual choice-of-license between:
- [Apache License, Version 2.0](https://www.apache.org/licenses/LICENSE-2.0)
- [MIT license](https://opensource.org/license/mit/)where you may choose either of these licenses to follow for this work.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.