2019-06-09 09:24:20 +02:00
|
|
|
go-libp2p-swarm
|
|
|
|
==================
|
|
|
|
|
|
|
|
[![](https://img.shields.io/badge/made%20by-Protocol%20Labs-blue.svg?style=flat-square)](https://protocol.ai)
|
2022-04-01 12:16:46 -04:00
|
|
|
[![Go Reference](https://pkg.go.dev/badge/github.com/libp2p/go-libp2p-swarm)](https://pkg.go.dev/github.com/libp2p/go-libp2p-swarm)
|
2019-06-09 09:24:20 +02:00
|
|
|
[![](https://img.shields.io/badge/project-libp2p-yellow.svg?style=flat-square)](https://libp2p.io/)
|
|
|
|
[![](https://img.shields.io/badge/freenode-%23libp2p-yellow.svg?style=flat-square)](http://webchat.freenode.net/?channels=%23libp2p)
|
2022-04-01 12:16:46 -04:00
|
|
|
[![Code Coverage](https://img.shields.io/codecov/c/github/libp2p/go-libp2p-swarm/master.svg?style=flat-square)](https://codecov.io/gh/libp2p/go-libp2p-swarm)
|
2019-06-09 09:24:20 +02:00
|
|
|
[![Discourse posts](https://img.shields.io/discourse/https/discuss.libp2p.io/posts.svg)](https://discuss.libp2p.io)
|
|
|
|
|
|
|
|
> The libp2p swarm manages groups of connections to peers, and handles incoming and outgoing streams.
|
|
|
|
|
|
|
|
The libp2p swarm is the 'low level' interface for working with a given libp2p
|
|
|
|
network. It gives you more fine grained control over various aspects of the
|
|
|
|
system. Most applications don't need this level of access, so the `Swarm` is
|
|
|
|
generally wrapped in a `Host` abstraction that provides a more friendly
|
2021-06-16 16:19:45 -04:00
|
|
|
interface. See [the host interface](https://godoc.org/github.com/libp2p/go-libp2p-core/host#Host)
|
2019-06-09 09:24:20 +02:00
|
|
|
for more info on that.
|
|
|
|
|
|
|
|
## Table of Contents
|
|
|
|
|
|
|
|
- [Install](#install)
|
|
|
|
- [Contribute](#contribute)
|
|
|
|
- [License](#license)
|
|
|
|
|
|
|
|
## Install
|
|
|
|
|
|
|
|
```sh
|
2022-04-01 12:16:46 -04:00
|
|
|
go get github.com/libp2p/go-libp2p-swarm
|
2019-06-09 09:24:20 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
### Creating a swarm
|
2022-04-01 12:16:46 -04:00
|
|
|
|
2019-06-09 09:24:20 +02:00
|
|
|
To construct a swarm, you'll be calling `NewSwarm`. That function looks like this:
|
|
|
|
```go
|
2022-04-01 12:16:46 -04:00
|
|
|
swarm, err := NewSwarm(peerID, peerstore)
|
2019-06-09 09:24:20 +02:00
|
|
|
```
|
|
|
|
|
2022-04-01 12:16:46 -04:00
|
|
|
The first parameter of the swarm constructor is an identity in the form of a peer.ID.
|
2019-06-09 09:24:20 +02:00
|
|
|
|
2022-04-01 12:16:46 -04:00
|
|
|
The second argument is a peerstore. This is essentially a database that the
|
|
|
|
swarm will use to store peer IDs, addresses, public keys, protocol preferences
|
|
|
|
and more.
|
2019-06-09 09:24:20 +02:00
|
|
|
|
|
|
|
### Streams
|
|
|
|
The swarm is designed around using multiplexed streams to communicate with
|
|
|
|
other peers. When working with a swarm, you will want to set a function to
|
|
|
|
handle incoming streams from your peers:
|
|
|
|
|
|
|
|
```go
|
2022-04-01 12:16:46 -04:00
|
|
|
swrm.SetStreamHandler(func(s network.Stream) {
|
2019-06-09 09:24:20 +02:00
|
|
|
defer s.Close()
|
|
|
|
fmt.Println("Got a stream from: ", s.SwarmConn().RemotePeer())
|
|
|
|
fmt.Fprintln(s, "Hello Friend!")
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
Tip: Always make sure to close streams when you're done with them.
|
|
|
|
|
|
|
|
|
|
|
|
## Contribute
|
|
|
|
|
|
|
|
PRs are welcome!
|
|
|
|
|
|
|
|
Small note: If editing the Readme, please conform to the [standard-readme](https://github.com/RichardLitt/standard-readme) specification.
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
MIT © Jeromy Johnson
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
The last gx published version of this module was: 3.0.35: QmQVoMEL1CxrVusTSUdYsiJXVBnvSqNUpBsGybkwSfksEF
|