js-libp2p-tcp/README.md

108 lines
3.7 KiB
Markdown
Raw Normal View History

2016-08-05 14:22:18 +02:00
# js-libp2p-tcp
2015-09-16 12:35:18 +01:00
2016-03-14 16:57:54 +00:00
[![](https://img.shields.io/badge/made%20by-Protocol%20Labs-blue.svg?style=flat-square)](http://ipn.io)
[![](https://img.shields.io/badge/freenode-%23ipfs-blue.svg?style=flat-square)](http://webchat.freenode.net/?channels=%23ipfs)
[![Build Status](https://travis-ci.org/libp2p/js-libp2p-tcp.svg?style=flat-square)](https://travis-ci.org/libp2p/js-libp2p-tcp)
2016-03-14 16:57:54 +00:00
![](https://img.shields.io/badge/coverage-%3F-yellow.svg?style=flat-square)
[![Dependency Status](https://david-dm.org/libp2p/js-libp2p-tcp.svg?style=flat-square)](https://david-dm.org/libp2p/js-libp2p-tcp)
2016-03-14 16:57:54 +00:00
[![js-standard-style](https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat-square)](https://github.com/feross/standard)
2015-09-16 12:35:18 +01:00
![](https://raw.githubusercontent.com/libp2p/interface-connection/master/img/badge.png)
![](https://raw.githubusercontent.com/libp2p/interface-transport/master/img/badge.png)
2015-09-16 17:43:45 +01:00
> Node.js implementation of the TCP module that libp2p uses, which implements the [interface-connection](https://github.com/libp2p/interface-connection) interface for dial/listen.
2015-09-16 12:35:18 +01:00
2016-04-21 16:18:39 -07:00
## Description
`libp2p-tcp` in Node.js is a very thin shim that adds support for dialing to a `multiaddr`. This small shim will enable libp2p to use other different transports.
2016-04-21 16:18:39 -07:00
2016-08-05 14:22:18 +02:00
**Note:** This module uses [pull-streams](https://pull-stream.github.io) for all stream based interfaces.
2016-04-21 16:18:39 -07:00
## Example
```js
const TCP = require('libp2p-tcp')
2016-04-21 16:33:57 -07:00
const multiaddr = require('multiaddr')
2016-08-05 14:22:18 +02:00
const pull = require('pull-stream')
2016-04-21 16:33:57 -07:00
const mh1 = multiaddr('/ip4/127.0.0.1/tcp/9090')
const mh2 = multiaddr('/ip6/::/tcp/9092')
2016-08-03 17:52:01 +02:00
const tcp = new TCP()
2016-04-21 16:33:57 -07:00
2016-08-05 14:22:18 +02:00
const listener = tcp.createListener(mh1, (socket) => {
console.log('new connection opened')
pull(
pull.values(['hello']),
socket
)
})
2016-08-05 14:22:18 +02:00
listener.listen(() => {
console.log('listening')
2016-04-21 16:33:57 -07:00
2016-08-05 14:22:18 +02:00
pull(
tcp.dial(mh1),
pull.log,
pull.onEnd(() => {
tcp.close()
})
)
2016-04-21 16:33:57 -07:00
})
2016-04-21 16:18:39 -07:00
```
outputs
```
2016-08-05 14:22:18 +02:00
listening
new connection opened
hello
2016-04-21 16:18:39 -07:00
```
## Installation
### npm
```sh
> npm i libp2p-tcp
```
## This module uses `pull-streams`
We expose a streaming interface based on `pull-streams`, rather then on the Node.js core streams implementation (aka Node.js streams). `pull-streams` offers us a better mechanism for error handling and flow control guarantees. If you would like to know more about what took us to make this migration, see the discussion at this [issue](https://github.com/ipfs/js-ipfs/issues/362).
You can learn more about pull-streams at:
- [The history of Node.js streams, nodebp April 2014](https://www.youtube.com/watch?v=g5ewQEuXjsQ)
- [The history of streams, 2016](http://dominictarr.com/post/145135293917/history-of-streams)
- [pull-streams, the simple streaming primitive](http://dominictarr.com/post/149248845122/pull-streams-pull-streams-are-a-very-simple)
- [pull-streams documentation](https://pull-stream.github.io/)
### Converting `pull-streams` to Node.js Streams
If you are a Node.js streams user, you can convert a pull-stream to Node.js Stream using the module `pull-stream-to-stream`, giving you an instance of a Node.js stream that is linked to the pull-stream. Example:
```
const pullToStream = require('pull-stream-to-stream')
const nodeStreamInstance = pullToStream(pullStreamInstance)
// nodeStreamInstance is an instance of a Node.js Stream
```
To learn more about his utility, visit https://pull-stream.github.io/#pull-stream-to-stream
2016-04-21 16:18:39 -07:00
## API
[![](https://raw.githubusercontent.com/diasdavid/interface-transport/master/img/badge.png)](https://github.com/diasdavid/interface-transport)
2016-04-21 16:18:39 -07:00
`libp2p-tcp` accepts TCP addresses both IPFS and non IPFS encapsulated addresses, i.e:
2016-04-21 16:18:39 -07:00
`/ip4/127.0.0.1/tcp/4001`
`/ip4/127.0.0.1/tcp/4001/ipfs/QmHash`
2016-04-21 16:18:39 -07:00
Both for dialing and listening.
2016-04-21 16:18:39 -07:00
## License
MIT