mirror of
https://github.com/status-im/status-go.git
synced 2025-02-22 03:38:27 +00:00
104 lines
4.6 KiB
Markdown
104 lines
4.6 KiB
Markdown
|
# go-libp2p-noise
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/4412e/4412ebe6c431872a78a9e4acedc1c62b95be7917" alt=""](https://ethberlinzwei.com)
|
||
|
[data:image/s3,"s3://crabby-images/1ff9b/1ff9b36c5bc0ae0aaa2b6e054045fc1b1d375c46" alt=""](https://libp2p.io/)
|
||
|
[data:image/s3,"s3://crabby-images/02c72/02c725665e50a3a468f94297aba53d06eced5b90" alt=""](http://webchat.freenode.net/?channels=%23libp2p)
|
||
|
[data:image/s3,"s3://crabby-images/c086f/c086fee1320483521ff59458eacc2121966cb88b" alt="Discourse posts"](https://discuss.libp2p.io)
|
||
|
[data:image/s3,"s3://crabby-images/3a07e/3a07edd2706245afc998d65e7d825bfcb1a3363c" alt="GoDoc"](https://godoc.org/github.com/libp2p/go-libp2p-noise)
|
||
|
[data:image/s3,"s3://crabby-images/3fc13/3fc13347ca1f3aaa60aeeccc46b1af0b0122e1bd" alt="Build Status"](https://travis-ci.com/libp2p/go-libp2p-noise)
|
||
|
|
||
|
> go-libp2p's noise encrypted transport
|
||
|
|
||
|
`go-libp2p-noise` is a component of the [libp2p project](https://libp2p.io), a
|
||
|
modular networking stack for developing peer-to-peer applications. It provides a
|
||
|
secure transport channel for [`go-libp2p`][go-libp2p] based on the
|
||
|
[Noise Protocol Framework](https://noiseprotocol.org). Following an initial
|
||
|
plaintext handshake, all data exchanged between peers using `go-libp2p-noise` is
|
||
|
encrypted and protected from eavesdropping.
|
||
|
|
||
|
libp2p supports multiple [transport protocols][docs-transport], many of which
|
||
|
lack native channel security. `go-libp2p-noise` is designed to work with
|
||
|
go-libp2p's ["transport upgrader"][transport-upgrader], which applies security
|
||
|
modules (like `go-libp2p-noise`) to an insecure channel. `go-libp2p-noise`
|
||
|
implements the [`SecureTransport` interface][godoc-securetransport], which
|
||
|
allows the upgrader to secure any underlying connection.
|
||
|
|
||
|
More detail on the handshake protocol and wire format used is available in the
|
||
|
[noise-libp2p specification][noise-libp2p-spec]. Details about security protocol
|
||
|
negotiation in libp2p can be found in the [connection establishment spec][conn-spec].
|
||
|
|
||
|
## Status
|
||
|
|
||
|
This implementation is currently considered "feature complete," but it has not yet
|
||
|
been widely tested in a production environment.
|
||
|
|
||
|
## Install
|
||
|
|
||
|
As `go-libp2p-noise` is still in development, it is not included as a default dependency of `go-libp2p`.
|
||
|
|
||
|
`go-libp2p-noise` is a standard Go module which can be installed with:
|
||
|
|
||
|
```sh
|
||
|
go get github.com/libp2p/go-libp2p-noise
|
||
|
```
|
||
|
|
||
|
This repo is [gomod](https://github.com/golang/go/wiki/Modules) compatible, and users of
|
||
|
go 1.12 and later with modules enabled will automatically pull the latest tagged release
|
||
|
by referencing this package. Upgrades to future releases can be managed using `go get`,
|
||
|
or by editing your `go.mod` file as [described by the gomod documentation](https://github.com/golang/go/wiki/Modules#how-to-upgrade-and-downgrade-dependencies).
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
`go-libp2p-noise` is not currently enabled by default when constructing a new libp2p
|
||
|
[Host][godoc-host], so you will need to explicitly enable it in order to use it.
|
||
|
|
||
|
To do so, you can pass `noise.New` as an argument to a `libp2p.Security` `Option` when
|
||
|
constructing a libp2p `Host` with `libp2p.New`:
|
||
|
|
||
|
```go
|
||
|
import (
|
||
|
libp2p "github.com/libp2p/go-libp2p"
|
||
|
noise "github.com/libp2p/go-libp2p-noise"
|
||
|
)
|
||
|
|
||
|
// wherever you create your libp2p instance:
|
||
|
host := libp2p.New(
|
||
|
libp2p.Security(noise.ID, noise.New)
|
||
|
)
|
||
|
```
|
||
|
|
||
|
Note that the above snippet will _replace_ the default security protocols. To add Noise
|
||
|
as an additional protocol, chain it to the default options instead:
|
||
|
|
||
|
```go
|
||
|
libp2p.ChainOptions(libp2p.DefaultSecurity, libp2p.Security(noise.ID, noise.New))
|
||
|
```
|
||
|
|
||
|
## Contribute
|
||
|
|
||
|
Feel free to join in. All welcome. Open an [issue](https://github.com/libp2p/go-libp2p-noise/issues)!
|
||
|
|
||
|
This repository falls under the libp2p [Code of Conduct](https://github.com/libp2p/community/blob/master/code-of-conduct.md).
|
||
|
|
||
|
### Want to hack on libp2p?
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/7323c/7323cae2da2362e60a617015a9263428ca2b302c" alt=""](https://github.com/libp2p/community/blob/master/CONTRIBUTE.md)
|
||
|
|
||
|
## License
|
||
|
|
||
|
MIT
|
||
|
|
||
|
---
|
||
|
|
||
|
[go-libp2p]: https://github.com/libp2p/go-libp2p
|
||
|
[noise-libp2p-spec]: https://github.com/libp2p/specs/blob/master/noise/README.md
|
||
|
[conn-spec]: https://github.com/libp2p/specs/blob/master/connections/README.md
|
||
|
[docs-transport]: https://docs.libp2p.io/concepts/transport
|
||
|
[transport-upgrader]: https://github.com/libp2p/go-libp2p-transport-upgrader
|
||
|
[godoc-host]: https://godoc.org/github.com/libp2p/go-libp2p-core/host#Host
|
||
|
[godoc-option]: https://godoc.org/github.com/libp2p/go-libp2p#Option
|
||
|
[godoc-go-libp2p-pkg-vars]: https://godoc.org/github.com/libp2p/go-libp2p#pkg-variables
|
||
|
[godoc-security-option]: https://godoc.org/github.com/libp2p/go-libp2p#Security
|
||
|
[godoc-securetransport]: https://godoc.org/github.com/libp2p/go-libp2p-core/sec#SecureTransport
|
||
|
|