2020-03-16 15:43:08 +08:00
< h1 align = "center" >
2020-12-19 03:31:35 -05:00
< a href = "https://libp2p.io" > < img width = "250" src = "https://github.com/libp2p/libp2p/blob/master/logo/black-bg-2.png?raw=true" alt = "libp2p hex logo" / > < / a >
2020-03-16 15:43:08 +08:00
< / h1 >
2018-11-19 04:07:53 +02:00
2020-03-16 15:43:08 +08:00
< h3 align = "center" > The Nim implementation of the libp2p Networking Stack.< / h3 >
2020-02-06 16:07:50 +01:00
2020-03-16 15:43:08 +08:00
< p align = "center" >
2021-12-15 15:01:28 +01:00
< a href = "https://github.com/status-im/nim-libp2p/actions" > < img src = "https://github.com/status-im/nim-libp2p/actions/workflows/ci.yml/badge.svg" / > < / a >
< a href = "https://codecov.io/gh/status-im/nim-libp2p" > < img src = "https://codecov.io/gh/status-im/nim-libp2p/branch/master/graph/badge.svg?token=UR5JRQ249W" / > < / a >
2020-03-16 15:43:08 +08:00
< / p >
< p align = "center" >
< a href = "https://opensource.org/licenses/Apache-2.0" > < img src = "https://img.shields.io/badge/License-Apache%202.0-blue.svg" / > < / a >
< a href = "https://opensource.org/licenses/MIT" > < img src = "https://img.shields.io/badge/License-MIT-blue.svg" / > < / a >
2020-12-19 09:43:54 -05:00
< img src = "https://img.shields.io/badge/nim-%3E%3D1.2.0-orange.svg?style=flat-square" / >
2020-03-16 15:43:08 +08:00
< / p >
2018-11-19 04:07:53 +02:00
2019-08-14 10:56:56 +02:00
## Introduction
2021-06-28 11:37:00 +09:00
An implementation of [libp2p ](https://libp2p.io/ ) in Nim.
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
## Project Status
2021-12-15 15:01:28 +01:00
libp2p is used in production by a few projects at [Status ](https://github.com/status-im ), including [Nimbus ](https://github.com/status-im/nimbus-eth2 ).
2021-06-28 11:37:00 +09:00
2021-12-15 15:01:28 +01:00
While far from complete, currently available components are stable.
2019-09-30 09:46:57 -06:00
2020-08-05 01:27:59 +02:00
Check our [examples folder ](/examples ) to get started!
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
# Table of Contents
- [Background ](#background )
- [Install ](#install )
- [Prerequisite ](#prerequisite )
- [Usage ](#usage )
- [API ](#api )
- [Getting Started ](#getting-started )
- [Tutorials and Examples ](#tutorials-and-examples )
- [Using the Go Daemon ](#using-the-go-daemon )
- [Development ](#development )
- [Tests ](#tests )
- [Packages ](#packages )
- [Contribute ](#contribute )
2020-08-05 01:27:59 +02:00
- [Core Developers ](#core-developers )
2020-03-16 15:43:08 +08:00
- [License ](#license )
2019-09-30 09:58:20 -06:00
2020-08-05 01:27:59 +02:00
## Background
2020-03-16 15:43:08 +08:00
libp2p is a networking stack and library modularized out of [The IPFS Project ](https://github.com/ipfs/ipfs ), and bundled separately for other tools to use.
2019-09-30 09:46:57 -06:00
2020-08-05 01:27:59 +02:00
libp2p is the product of a long and arduous quest of understanding; a deep dive into the internet's network stack and the peer-to-peer protocols from the past. Building large scale peer-to-peer systems has been complex and difficult in the last 15 years and libp2p is a way to fix that. It is a "network stack", a suite of networking protocols that cleanly separates concerns and enables sophisticated applications to only use the protocols they absolutely need, without giving up interoperability and upgradeability.
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
libp2p grew out of IPFS, but it is built so that lots of people can use it, for lots of different projects.
2019-09-30 09:58:20 -06:00
2020-08-05 01:27:59 +02:00
- Learn more about libp2p at [**libp2p.io** ](https://libp2p.io ) and follow our evolving documentation efforts at [**docs.libp2p.io** ](https://docs.libp2p.io ).
- [Here ](https://github.com/libp2p/libp2p#description ) is an overview of libp2p and its implementations in other programming languages.
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
## Install
2019-09-30 09:58:20 -06:00
```
2020-03-16 15:43:08 +08:00
nimble install libp2p
```
2020-08-05 01:27:59 +02:00
### Prerequisite
2020-03-16 15:43:08 +08:00
- [Nim ](https://nim-lang.org/install.html )
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
## Usage
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
### API
2020-04-30 14:57:49 +08:00
The specification is available in the [docs/api ](docs/api ) folder.
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
### Getting Started
2020-08-05 01:27:59 +02:00
Please read the [GETTING_STARTED.md ](docs/GETTING_STARTED.md ) guide.
2019-09-30 09:58:20 -06:00
2020-08-05 01:27:59 +02:00
### Tutorials and Examples
2020-04-30 14:57:49 +08:00
Example code can be found in the [examples folder ](/examples ).
2020-08-05 01:27:59 +02:00
2020-04-30 14:57:49 +08:00
#### Direct Chat Tutorial
- [Part I ](https://our.status.im/nim-libp2p-tutorial-a-peer-to-peer-chat-example-1/ ): Set up the main function and use multi-thread for processing IO.
- [Part II ](https://our.status.im/nim-libp2p-tutorial-a-peer-to-peer-chat-example-2/ ): Dial remote peer and allow customized user input commands.
2020-08-05 01:27:59 +02:00
- [Part III ](https://our.status.im/nim-libp2p-tutorial-a-peer-to-peer-chat-example-3/ ): Configure and establish a libp2p node.
2020-04-30 14:57:49 +08:00
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
### Using the Go Daemon
2020-08-05 01:27:59 +02:00
Please find the installation and usage intructions in [daemonapi.md ](docs/api/libp2p/daemonapi.md ).
2019-09-30 09:58:20 -06:00
2020-03-16 15:43:08 +08:00
Examples can be found in the [examples/go-daemon folder ](https://github.com/status-im/nim-libp2p/tree/readme/examples/go-daemon );
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
## Development
**Clone and Install dependencies:**
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
```sh
git clone https://github.com/status-im/nim-libp2p
cd nim-libp2p
nimble install
```
#### Run unit tests
```sh
# run all the unit tests
nimble test
```
2021-12-10 10:11:52 +01:00
The code follows the [Status Nim Style Guide ](https://status-im.github.io/nim-style-guide/ ).
2019-09-30 09:46:57 -06:00
2020-08-05 01:27:59 +02:00
### Packages
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
List of packages currently in existence for nim-libp2p:
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Libp2p
- [libp2p ](https://github.com/status-im/nim-libp2p )
- [libp2p-daemon-client ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/daemon/daemonapi.nim )
- [interop-libp2p ](https://github.com/status-im/nim-libp2p/blob/master/tests/testinterop.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Transports
- [libp2p-tcp ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/transports/tcptransport.nim )
2021-12-15 15:01:28 +01:00
- [libp2p-ws ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/transports/wstransport.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Secure Channels
- [libp2p-secio ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/secure/secio.nim )
2021-12-15 15:01:28 +01:00
- [libp2p-noise ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/secure/noise.nim )
- [libp2p-plaintext ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/secure/plaintext.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Stream Multiplexers
- [libp2p-mplex ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/muxers/mplex/mplex.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Utilities
- [libp2p-crypto ](https://github.com/status-im/nim-libp2p/tree/master/libp2p/crypto )
- [libp2p-crypto-secp256k1 ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/crypto/secp.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Data Types
- [peer-id ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/peer.nim )
- [peer-info ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/peerinfo.nim )
2019-09-30 09:46:57 -06:00
2020-03-16 15:43:08 +08:00
#### Pubsub
- [libp2p-pubsub ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/pubsub/pubsub.nim )
- [libp2p-floodsub ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/pubsub/floodsub.nim )
- [libp2p-gossipsub ](https://github.com/status-im/nim-libp2p/blob/master/libp2p/protocols/pubsub/gossipsub.nim )
2019-09-30 09:46:57 -06:00
2020-08-05 01:27:59 +02:00
Packages that exist in the original libp2p specs and are under active development:
2020-03-16 15:43:08 +08:00
- libp2p-daemon
- libp2p-webrtc-direct
- libp2p-webrtc-star
- libp2p-spdy
- libp2p-bootstrap
- libp2p-kad-dht
- libp2p-mdns
- libp2p-webrtc-star
- libp2p-delegated-content-routing
- libp2p-delegated-peer-routing
- libp2p-nat-mgnr
- libp2p-utils
2019-09-30 09:46:57 -06:00
2020-08-05 01:27:59 +02:00
** Note that the current stack reflects the minimal requirements for the upcoming Eth2 implementation.
### Tips and tricks
2019-12-10 14:50:35 -06:00
2021-01-08 14:21:24 +09:00
#### enable expensive metrics:
2020-08-05 01:27:59 +02:00
```bash
nim c -d:libp2p_expensive_metrics some_file.nim
```
2019-09-30 09:46:57 -06:00
2021-01-08 14:21:24 +09:00
#### use identify metrics
```bash
nim c -d:libp2p_agents_metrics -d:KnownLibP2PAgents=nimbus,lighthouse,prysm,teku some_file.nim
```
### specify gossipsub specific topics to measure
```bash
nim c -d:KnownLibP2PTopics=topic1,topic2,topic3 some_file.nim
```
2020-03-16 15:43:08 +08:00
## Contribute
2021-12-10 10:11:52 +01:00
2020-03-16 15:43:08 +08:00
The libp2p implementation in Nim is a work in progress. We welcome contributors to help out! Specifically, you can:
2020-08-05 01:27:59 +02:00
- Go through the modules and **check out existing issues** . This would be especially useful for modules in active development. Some knowledge of IPFS/libp2p may be required, as well as the infrastructure behind it.
- **Perform code reviews**. Feel free to let us know if you found anything that can a) speed up the project development b) ensure better quality and c) reduce possible future bugs.
2020-03-16 15:43:08 +08:00
- **Add tests**. Help nim-libp2p to be more robust by adding more tests to the [tests folder ](https://github.com/status-im/nim-libp2p/tree/master/tests ).
2019-09-30 09:46:57 -06:00
2021-12-10 10:11:52 +01:00
The code follows the [Status Nim Style Guide ](https://status-im.github.io/nim-style-guide/ ).
2020-08-05 01:27:59 +02:00
### Core Developers
2021-12-15 15:01:28 +01:00
[@cheatfate ](https://github.com/cheatfate ), [Dmitriy Ryajov ](https://github.com/dryajov ), [Tanguy ](https://github.com/Menduist ), [Zahary Karadjov ](https://github.com/zah )
2019-09-30 09:46:57 -06:00
2018-11-19 04:04:47 +02:00
## License
Licensed and distributed under either of
* MIT license: [LICENSE-MIT ](LICENSE-MIT ) or http://opensource.org/licenses/MIT
2019-01-02 15:05:50 +01:00
or
* Apache License, Version 2.0, ([LICENSE-APACHEv2 ](LICENSE-APACHEv2 ) or http://www.apache.org/licenses/LICENSE-2.0)
2018-11-19 04:04:47 +02:00
2020-08-05 01:27:59 +02:00
at your option. These files may not be copied, modified, or distributed except according to those terms.