JavaScript implementation of the WebSockets module that libp2p uses and that implements the interface-transport spec
A libp2p transport based on WebSockets.
import { createLibp2p } from 'libp2p'
import { webSockets } from '@libp2p/websockets'
import { multiaddr } from '@multiformats/multiaddr'
const node = await createLibp2p({
transports: [
webSockets()
]
//... other config
})
await node.start()
const ma = multiaddr('/ip4/127.0.0.1/tcp/9090/ws')
await node.dial(ma)
When run in a browser by default this module will only connect to secure web socket addresses.
To change this you should pass a filter to the factory function.
You can create your own address filters for this transports, or rely in the filters provided.
The available filters are:
filters.all
ws
or wss
.filters.dnsWss
wss
.filters.dnsWsOrWss
ws
or wss
.import { createLibp2p } from 'libp2p'
import { webSockets } from '@libp2p/websockets'
import * as filters from '@libp2p/websockets/filters'
const node = await createLibp2p({
transports: [
webSockets({
// connect to all sockets, even insecure ones
filter: filters.all
})
]
})
$ npm i @libp2p/websockets
<script>
tagLoading this module through a script tag will make it's exports available as Libp2pWebsockets
in the global namespace.
<script src="https://unpkg.com/@libp2p/websockets/dist/index.min.js"></script>
Licensed under either of
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.