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-09-09 12:13:14 +02:00
[](https://coveralls.io/github/libp2p/js-libp2p-tcp?branch=master)
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)
2016-11-03 09:22:32 +01:00

2017-09-03 10:02:10 +01:00

2015-09-16 12:35:18 +01:00
2018-02-20 10:25:18 +00:00
[](https://github.com/libp2p/interface-transport)
[](https://github.com/libp2p/interface-connection)
2015-09-16 12:35:18 +01:00
2016-04-21 16:18:39 -07:00
2018-02-20 10:25:18 +00:00
> JavaScript implementation of the TCP module for libp2p. It exposes the [interface-transport](https://github.com/libp2p/interface-connection) for dial/listen. `libp2p-tcp` 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-08-05 14:22:18 +02:00
2016-09-06 09:16:32 -04:00
## Table of Contents
- [Install ](#install )
- [npm ](#npm )
- [Usage ](#usage )
- [API ](#api )
- [Contribute ](#contribute )
- [License ](#license )
## Install
### npm
```sh
2018-02-20 10:25:18 +00:00
> npm install libp2p-tcp
2016-09-06 09:16:32 -04:00
```
## Usage
2016-04-21 16:18:39 -07:00
```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
2018-04-05 11:55:25 -04:00
const mh = multiaddr('/ip4/127.0.0.1/tcp/9090')
2016-04-21 16:33:57 -07:00
2016-08-03 17:52:01 +02:00
const tcp = new TCP()
2016-04-21 16:33:57 -07:00
2018-04-05 11:55:25 -04:00
const listener = tcp.createListener((socket) => {
2016-08-05 14:22:18 +02:00
console.log('new connection opened')
pull(
pull.values(['hello']),
socket
)
2016-06-15 03:22:09 -04:00
})
2018-04-05 11:55:25 -04:00
listener.listen(mh, () => {
2016-08-05 14:22:18 +02:00
console.log('listening')
2016-04-21 16:33:57 -07:00
2016-08-05 14:22:18 +02:00
pull(
2018-04-05 11:55:25 -04:00
tcp.dial(mh),
pull.collect((err, values) => {
if (!err) {
console.log(`Value: ${values.toString()}` )
} else {
console.log(`Error: ${err}` )
}
// Close connection after reading
listener.close()
}),
2016-08-05 14:22:18 +02:00
)
2016-04-21 16:33:57 -07:00
})
2016-04-21 16:18:39 -07:00
```
2016-09-06 09:16:32 -04:00
Outputs:
2016-04-21 16:18:39 -07:00
2016-09-06 09:16:32 -04:00
```sh
2016-08-05 14:22:18 +02:00
listening
new connection opened
2018-04-05 11:55:25 -04:00
Value: hello
2016-04-21 16:18:39 -07:00
```
## API
2018-02-20 10:25:18 +00:00
### Transport
2016-11-03 09:22:32 +01:00
[](https://github.com/libp2p/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
2018-02-20 10:25:18 +00:00
### Connection
[](https://github.com/libp2p/interface-connection)
2016-09-06 09:16:32 -04:00
## Contribute
Contributions are welcome! The libp2p implementation in JavaScript is a work in progress. As such, there's a few things you can do right now to help out:
- [Check out the existing issues ](//github.com/libp2p/js-libp2p-tcp/issues ).
- **Perform code reviews**.
- **Add tests**. There can never be enough tests.
Please be aware that all interactions related to libp2p are subject to the IPFS [Code of Conduct ](https://github.com/ipfs/community/blob/master/code-of-conduct.md ).
Small note: If editing the README, please conform to the [standard-readme ](https://github.com/RichardLitt/standard-readme ) specification.
2016-04-21 16:18:39 -07:00
## License
2016-09-06 09:16:32 -04:00
[MIT ](LICENSE ) © 2015-2016 David Dias