Skip to content

Commit

Permalink
add readme to noise-sv2 crate
Browse files Browse the repository at this point in the history
  • Loading branch information
Shourya742 committed Oct 7, 2024
1 parent 6387925 commit 1f3f265
Showing 1 changed file with 36 additions and 0 deletions.
36 changes: 36 additions & 0 deletions protocols/v2/noise-sv2/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@

<div align="center">
<h1>Noise-SV2</h1>
<p>
A noise protocol implemenation for Stratum V2
</p>
<p>
<a href="https://github.com/stratum-mining/stratum/blob/main/LICENSE.md"><img alt="CC0 1.0 Universal Licensed" src="https://img.shields.io/badge/license-CC0--1.0-blue.svg"/></a>
<a href="https://app.codecov.io/gh/stratum-mining/stratum/tree/main/protocols%2Fv2%2Fnoise-sv2">
<img src="https://codecov.io/gh/stratum-mining/stratum/branch/main/graph/badge.svg" alt="codecov">
</a>
<a href="https://blog.rust-lang.org/2023/12/28/Rust-1.75.0.html"><img alt="Rustc Version 1.75.0+" src="https://img.shields.io/badge/rustc-1.75.0%2B-lightgrey.svg"/></a>
<a href="https://crates.io/crates/noise_sv2"><img alt="crate.io" src="https://img.shields.io/crates/v/noise_sv2.svg"/></a>
<a href="https://docs.rs/noise_sv2"><img alt="docs" src="https://docs.rs/noise_sv2/badge.svg"/></a>
</p>
</div>


This crate provides an implementation of the [Noise protocol](https://github.com/stratum-mining/sv2-spec/blob/main/04-Protocol-Security.md#4-protocol-security) as outlined in the Stratum V2 specification. The `noise_sv2` crate ensures secure communication channels between downstream and upstream components of the Stratum V2 mining protocol by performing encryption, decryption, and authentication via Noise handshakes and cipher operations.

## Key Features
* **Secure Communication**: Provides robust encryption and authentication for messages exchanged between different roles (downstream and upstream) in a mining pool architecture.
* **Cipher Support**: Includes support for both AES-GCM and ChaCha20-Poly1305, two well-known and widely used encryption algorithms.
* **Handshake Roles**: Implements the [`Initiator`] and [`Responder`] roles required by the Noise handshake, allowing both sides of a connection to establish secure communication.
* **Cryptographic Helpers**: Comes with utility types to facilitate the management of cryptographic state and encryption operations, simplifying usage for developers.

## Usage Overview
`noise_sv2` is primarily intended to secure communication in the Stratum V2 protocol. It handles the necessary Noise handshakes, encrypts outgoing messages, and decrypts incoming responses, ensuring privacy and integrity across the communication link between clients (downstream) and servers (upstream).

### Adding to Your Project

To include this crate in your project, add the following to your `Cargo.toml`:

```toml
[dependencies]
noise_sv2 = "1.1.0"

0 comments on commit 1f3f265

Please sign in to comment.