76 lines
2.6 KiB
Markdown
Raw Normal View History

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
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