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
|
|
|
[](http://ipn.io)
|
|
|
|
[](http://webchat.freenode.net/?channels=%23ipfs)
|
2016-06-15 03:22:09 -04:00
|
|
|
[](https://travis-ci.org/libp2p/js-libp2p-tcp)
|
2016-03-14 16:57:54 +00:00
|
|
|

|
2016-06-15 03:22:09 -04:00
|
|
|
[](https://david-dm.org/libp2p/js-libp2p-tcp)
|
2016-03-14 16:57:54 +00:00
|
|
|
[](https://github.com/feross/standard)
|
2015-09-16 12:35:18 +01:00
|
|
|
|
2016-06-15 03:22:09 -04:00
|
|
|

|
|
|
|

|
2015-09-16 17:43:45 +01:00
|
|
|
|
2016-04-21 16:18:39 -07:00
|
|
|
> Node.js implementation of the TCP module that libp2p uses, which implements
|
2016-06-15 03:22:09 -04:00
|
|
|
> the [interface-connection](https://github.com/libp2p/interface-connection)
|
2016-04-21 16:18:39 -07:00
|
|
|
> interface for dial/listen.
|
2015-09-16 12:35:18 +01:00
|
|
|
|
2016-04-21 16:18:39 -07:00
|
|
|
## Description
|
|
|
|
|
2016-04-22 14:14:07 -07:00
|
|
|
`libp2p-tcp` in Node.js is a very thin shim that adds support for dialing to a
|
2016-04-21 16:18:39 -07:00
|
|
|
`multiaddr`. This small shim will enable libp2p to use other different
|
|
|
|
transports.
|
|
|
|
|
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
|
2016-06-15 03:22:09 -04:00
|
|
|
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-06-15 03:22:09 -04:00
|
|
|
})
|
|
|
|
|
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
|
|
|
|
```
|
|
|
|
|
|
|
|
## API
|
|
|
|
|
2016-06-15 03:22:09 -04:00
|
|
|
[](https://github.com/diasdavid/interface-transport)
|
2016-04-21 16:18:39 -07:00
|
|
|
|
2016-06-15 03:22:09 -04:00
|
|
|
`libp2p-tcp` accepts TCP addresses both IPFS and non IPFS encapsulated addresses, i.e:
|
2016-04-21 16:18:39 -07:00
|
|
|
|
2016-06-15 03:22:09 -04: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
|
|
|
|
2016-06-15 03:22:09 -04:00
|
|
|
Both for dialing and listening.
|
2016-04-21 16:18:39 -07:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
MIT
|