TLS/SSL crypto for libp2p
This repo contains an experimental TLS/SSL transport for libp2p. Currently there is no browser support (planned - see Roadmap)
npm install libp2p-tls
const tls = require('libp2p-tls')
The current tls
tag, usable in multistream
.
id: PeerId
- The id of the node.key: RSAPrivateKey
- The private key of the node.insecure: PullStream
- The insecure connection.callback: Function
- Called if an error happens during the initialization.
Returns the insecure
connection provided, wrapped with TLS. This is a pull-stream.
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 why we did this, see the discussion at this issue.
You can learn more about pull-streams at:
- The history of Node.js streams, nodebp April 2014
- The history of streams, 2016
- pull-streams, the simple streaming primitive
- pull-streams documentation
If you are a Node.js streams user, you can convert a pull-stream to a 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. For 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 this utility, visit https://pull-stream.github.io/#pull-stream-to-stream.
- Add backwards-compatible tls1.3 support
- Add a parameter to let the clients choose between ECC and RSA crypto?
- Add browser support
Feel free to join in. All welcome. Open an issue!