Compare commits

...

13 Commits

Author SHA1 Message Date
Vasco Santos
e82b6e414b chore: release version v0.32.4 2021-08-20 09:25:15 +02:00
Vasco Santos
1d62ead8e5 chore: update contributors 2021-08-20 09:25:14 +02:00
Vasco Santos
3d25ff7fd0 chore: use new libp2p-noise 2021-08-20 09:13:21 +02:00
Vasco Santos
0f389a7828 chore: update uint8arrays 2021-08-20 09:13:21 +02:00
Vasco Santos
9f0582f372 chore: remove unused dev dep (#966) 2021-08-19 09:38:39 +02:00
Vasco Santos
266f2c3c86 chore: release version v0.32.3 2021-08-16 18:20:41 +02:00
Vasco Santos
7783edb059 chore: update contributors 2021-08-16 18:20:40 +02:00
Vasco Santos
ba2b4d4b28 fix: uint8arrays is a dep (#964) 2021-08-16 17:54:24 +02:00
Vasco Santos
06c3a6d407 chore: release version v0.32.2 2021-08-13 17:02:52 +02:00
Vasco Santos
833f789714 chore: update contributors 2021-08-13 17:02:51 +02:00
greenSnot
ef24fabf02 feat: custom protocol name (#962)
Co-authored-by: mzdws <8580712+mzdws@user.noreply.gitee.com>
2021-08-13 16:21:50 +02:00
Vasco Santos
3b33fb4b73 fix: browser example ci 2021-08-12 15:15:13 +02:00
Vasco Santos
a07fb7960b chore: update action setup node 2021-08-12 15:15:13 +02:00
96 changed files with 322 additions and 190 deletions

View File

@@ -7,7 +7,7 @@ const Peers = require('./test/fixtures/peers')
const PeerId = require('peer-id') const PeerId = require('peer-id')
const WebSockets = require('libp2p-websockets') const WebSockets = require('libp2p-websockets')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const pipe = require('it-pipe') const pipe = require('it-pipe')
let libp2p let libp2p

View File

@@ -12,8 +12,7 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- name: Use Node.js 14 - uses: actions/setup-node@v2
uses: actions/setup-node@v1
with: with:
node-version: 14 node-version: 14
- run: npm install - run: npm install
@@ -21,7 +20,7 @@ jobs:
- uses: gozala/typescript-error-reporter-action@v1.0.8 - uses: gozala/typescript-error-reporter-action@v1.0.8
- run: npx aegir build - run: npx aegir build
- run: npx aegir dep-check - run: npx aegir dep-check
- uses: ipfs/aegir/actions/bundle-size@master - uses: ipfs/aegir/actions/bundle-size@v32.1.0
name: size name: size
with: with:
github_token: ${{ secrets.GITHUB_TOKEN }} github_token: ${{ secrets.GITHUB_TOKEN }}
@@ -35,7 +34,7 @@ jobs:
fail-fast: true fail-fast: true
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- uses: actions/setup-node@v1 - uses: actions/setup-node@v2
with: with:
node-version: ${{ matrix.node }} node-version: ${{ matrix.node }}
- run: npm install - run: npm install

View File

@@ -1,3 +1,30 @@
## [0.32.4](https://github.com/libp2p/js-libp2p/compare/v0.32.3...v0.32.4) (2021-08-20)
## [0.32.3](https://github.com/libp2p/js-libp2p/compare/v0.32.2...v0.32.3) (2021-08-16)
### Bug Fixes
* uint8arrays is a dep ([#964](https://github.com/libp2p/js-libp2p/issues/964)) ([ba2b4d4](https://github.com/libp2p/js-libp2p/commit/ba2b4d4b28f1d9940b457de344aed44537f9eabd))
## [0.32.2](https://github.com/libp2p/js-libp2p/compare/v0.32.1...v0.32.2) (2021-08-13)
### Bug Fixes
* browser example ci ([3b33fb4](https://github.com/libp2p/js-libp2p/commit/3b33fb4b73ba8065e432fb59f758fe138fd23d9e))
### Features
* custom protocol name ([#962](https://github.com/libp2p/js-libp2p/issues/962)) ([ef24fab](https://github.com/libp2p/js-libp2p/commit/ef24fabf0269fd079888e92eedb458e23ef1c733))
## [0.32.1](https://github.com/libp2p/js-libp2p/compare/v0.32.0...v0.32.1) (2021-07-22) ## [0.32.1](https://github.com/libp2p/js-libp2p/compare/v0.32.0...v0.32.1) (2021-07-22)

View File

@@ -781,6 +781,26 @@ By default under nodejs libp2p will attempt to use [UPnP](https://en.wikipedia.o
[NAT-PMP](http://miniupnp.free.fr/nat-pmp.html) is a feature of some modern routers which performs a similar job to UPnP. NAT-PMP is disabled by default, if enabled libp2p will try to use NAT-PMP and will fall back to UPnP if it fails. [NAT-PMP](http://miniupnp.free.fr/nat-pmp.html) is a feature of some modern routers which performs a similar job to UPnP. NAT-PMP is disabled by default, if enabled libp2p will try to use NAT-PMP and will fall back to UPnP if it fails.
#### Configuring protocol name
Changing the protocol name prefix can isolate default public network (IPFS) for custom purposes.
```js
const node = await Libp2p.create({
config: {
protocolPrefix: 'ipfs' // default
}
})
/*
protocols: [
"/ipfs/id/1.0.0", // identify service protocol (if we have multiplexers)
"/ipfs/id/push/1.0.0", // identify service push protocol (if we have multiplexers)
"/ipfs/ping/1.0.0", // built-in ping protocol
]
*/
```
## Configuration examples ## Configuration examples
As libp2p is designed to be a modular networking library, its usage will vary based on individual project needs. We've included links to some existing project configurations for your reference, in case you wish to replicate their configuration: As libp2p is designed to be a modular networking library, its usage will vary based on individual project needs. We've included links to some existing project configurations for your reference, in case you wish to replicate their configuration:

View File

@@ -18,7 +18,7 @@ The relay node will need to have its relay subsystem enabled, as well as its HOP
```js ```js
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const node = await Libp2p.create({ const node = await Libp2p.create({
@@ -76,7 +76,7 @@ One of the typical use cases for Auto Relay is nodes behind a NAT or browser nod
```js ```js
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const relayAddr = process.argv[2] const relayAddr = process.argv[2]
@@ -147,7 +147,7 @@ Now that you have a relay node and a node bound to that relay, you can test conn
```js ```js
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const autoRelayNodeAddr = process.argv[2] const autoRelayNodeAddr = process.argv[2]

View File

@@ -2,7 +2,7 @@
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
async function main () { async function main () {

View File

@@ -2,7 +2,7 @@
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
async function main () { async function main () {

View File

@@ -2,7 +2,7 @@
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const Websockets = require('libp2p-websockets') const Websockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
async function main () { async function main () {

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
function startProcess (name, args = []) { function startProcess (name, args = []) {
return execa('node', [path.join(__dirname, name), ...args], { return execa('node', [path.join(__dirname, name), ...args], {

View File

@@ -3,7 +3,7 @@
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const WS = require('libp2p-websockets') const WS = require('libp2p-websockets')
const mplex = require('libp2p-mplex') const mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const defaultsDeep = require('@nodeutils/defaults-deep') const defaultsDeep = require('@nodeutils/defaults-deep')
const libp2p = require('../../..') const libp2p = require('../../..')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
function startProcess(name) { function startProcess(name) {
return execa('node', [path.join(__dirname, name)], { return execa('node', [path.join(__dirname, name)], {

View File

@@ -3,7 +3,7 @@
const Libp2p = require('../..') const Libp2p = require('../..')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -8,13 +8,13 @@ A byproduct of having these encrypted communications modules is that we can auth
# 1. Set up encrypted communications # 1. Set up encrypted communications
We will build this example on top of example for [Protocol and Stream Multiplexing](../protocol-and-stream-multiplexing). You will need the `libp2p-noise` module to complete it, go ahead and `npm install libp2p-noise`. We will build this example on top of example for [Protocol and Stream Multiplexing](../protocol-and-stream-multiplexing). You will need the `@chainsafe/libp2p-noise` module to complete it, go ahead and `npm install @chainsafe/libp2p-noise`.
To add them to your libp2p configuration, all you have to do is: To add them to your libp2p configuration, all you have to do is:
```JavaScript ```JavaScript
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const createNode = () => { const createNode = () => {
return Libp2p.create({ return Libp2p.create({

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const messageReceived = pDefer() const messageReceived = pDefer()

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Bootstrap = require('libp2p-bootstrap') const Bootstrap = require('libp2p-bootstrap')
const bootstrapers = require('./bootstrapers') const bootstrapers = require('./bootstrapers')

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MulticastDNS = require('libp2p-mdns') const MulticastDNS = require('libp2p-mdns')
const createNode = async () => { const createNode = async () => {

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Gossipsub = require('libp2p-gossipsub') const Gossipsub = require('libp2p-gossipsub')
const Bootstrap = require('libp2p-bootstrap') const Bootstrap = require('libp2p-bootstrap')
const PubsubPeerDiscovery = require('libp2p-pubsub-peer-discovery') const PubsubPeerDiscovery = require('libp2p-pubsub-peer-discovery')

View File

@@ -168,7 +168,7 @@ You can create your libp2p nodes as follows:
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Gossipsub = require('libp2p-gossipsub') const Gossipsub = require('libp2p-gossipsub')
const Bootstrap = require('libp2p-bootstrap') const Bootstrap = require('libp2p-bootstrap')
const PubsubPeerDiscovery = require('libp2p-pubsub-peer-discovery') const PubsubPeerDiscovery = require('libp2p-pubsub-peer-discovery')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const bootstrapers = require('./bootstrapers') const bootstrapers = require('./bootstrapers')
const discoveredCopy = 'Discovered:' const discoveredCopy = 'Discovered:'

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const discoveredCopy = 'Discovered:' const discoveredCopy = 'Discovered:'

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const discoveredCopy = 'discovered:' const discoveredCopy = 'discovered:'

View File

@@ -3,7 +3,7 @@
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const WS = require('libp2p-websockets') const WS = require('libp2p-websockets')
const mplex = require('libp2p-mplex') const mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const defaultsDeep = require('@nodeutils/defaults-deep') const defaultsDeep = require('@nodeutils/defaults-deep')
const libp2p = require('../../..') const libp2p = require('../../..')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
function startProcess(name) { function startProcess(name) {
return execa('node', [path.join(__dirname, name)], { return execa('node', [path.join(__dirname, name)], {

View File

@@ -16,7 +16,7 @@
<pre id="output"></pre> <pre id="output"></pre>
</main> </main>
<script src="./index.js"></script> <script type="module" src="./index.js"></script>
</body> </body>

View File

@@ -2,7 +2,7 @@ import 'babel-polyfill'
import Libp2p from 'libp2p' import Libp2p from 'libp2p'
import Websockets from 'libp2p-websockets' import Websockets from 'libp2p-websockets'
import WebRTCStar from 'libp2p-webrtc-star' import WebRTCStar from 'libp2p-webrtc-star'
import { NOISE } from 'libp2p-noise' import { NOISE } from '@chainsafe/libp2p-noise'
import Mplex from 'libp2p-mplex' import Mplex from 'libp2p-mplex'
import Bootstrap from 'libp2p-bootstrap' import Bootstrap from 'libp2p-bootstrap'

View File

@@ -2,7 +2,6 @@
"name": "libp2p-in-browser", "name": "libp2p-in-browser",
"version": "1.0.0", "version": "1.0.0",
"description": "A libp2p node running in the browser", "description": "A libp2p node running in the browser",
"main": "dist/index.html",
"browserslist": [ "browserslist": [
"last 2 Chrome versions" "last 2 Chrome versions"
], ],
@@ -19,7 +18,7 @@
"libp2p": "../../", "libp2p": "../../",
"libp2p-bootstrap": "^0.13.0", "libp2p-bootstrap": "^0.13.0",
"libp2p-mplex": "^0.10.4", "libp2p-mplex": "^0.10.4",
"libp2p-noise": "^4.0.0", "@chainsafe/libp2p-noise": "^4.1.0",
"libp2p-webrtc-star": "^0.23.0", "libp2p-webrtc-star": "^0.23.0",
"libp2p-websockets": "^0.16.1" "libp2p-websockets": "^0.16.1"
}, },

View File

@@ -10,10 +10,12 @@
"dependencies": { "dependencies": {
"execa": "^2.1.0", "execa": "^2.1.0",
"fs-extra": "^8.1.0", "fs-extra": "^8.1.0",
"libp2p": "../src",
"libp2p-pubsub-peer-discovery": "^4.0.0", "libp2p-pubsub-peer-discovery": "^4.0.0",
"libp2p-relay-server": "^0.2.0", "libp2p-relay-server": "^0.3.0",
"libp2p-gossipsub": "^0.9.1", "libp2p-gossipsub": "^0.11.0",
"p-defer": "^3.0.0", "p-defer": "^3.0.0",
"uint8arrays": "^3.0.0",
"which": "^2.0.1" "which": "^2.0.1"
}, },
"devDependencies": { "devDependencies": {

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const KadDHT = require('libp2p-kad-dht') const KadDHT = require('libp2p-kad-dht')
const delay = require('delay') const delay = require('delay')

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const { CID } = require('multiformats/cid') const { CID } = require('multiformats/cid')
const KadDHT = require('libp2p-kad-dht') const KadDHT = require('libp2p-kad-dht')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test() { async function test() {
process.stdout.write('1.js\n') process.stdout.write('1.js\n')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const providedCopy = 'is providing' const providedCopy = 'is providing'
const foundCopy = 'Found provider:' const foundCopy = 'Found provider:'

View File

@@ -3,7 +3,7 @@
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Protector = require('libp2p/src/pnet') const Protector = require('libp2p/src/pnet')
/** /**

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const messageReceived = pDefer() const messageReceived = pDefer()

View File

@@ -3,7 +3,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -3,7 +3,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test() { async function test() {
const messageDefer = pDefer() const messageDefer = pDefer()

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const messages = [ const messages = [
'protocol (a)', 'protocol (a)',

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const messages = [ const messages = [
'from 1 to 2', 'from 1 to 2',

View File

@@ -4,10 +4,10 @@
const Libp2p = require('../../') const Libp2p = require('../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Gossipsub = require('libp2p-gossipsub') const Gossipsub = require('libp2p-gossipsub')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const createNode = async () => { const createNode = async () => {
const node = await Libp2p.create({ const node = await Libp2p.create({

View File

@@ -4,10 +4,10 @@
const Libp2p = require('../../../') const Libp2p = require('../../../')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Gossipsub = require('libp2p-gossipsub') const Gossipsub = require('libp2p-gossipsub')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const createNode = async () => { const createNode = async () => {
const node = await Libp2p.create({ const node = await Libp2p.create({

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const stdout = [ const stdout = [
{ {

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const defer = pDefer() const defer = pDefer()

View File

@@ -3,7 +3,7 @@
const Libp2p = require('../..') const Libp2p = require('../..')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const createNode = async () => { const createNode = async () => {
const node = await Libp2p.create({ const node = await Libp2p.create({

View File

@@ -3,7 +3,7 @@
const Libp2p = require('../..') const Libp2p = require('../..')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../..') const Libp2p = require('../..')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const WebSockets = require('libp2p-websockets') const WebSockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const pipe = require('it-pipe') const pipe = require('it-pipe')

View File

@@ -4,7 +4,7 @@
const Libp2p = require('../..') const Libp2p = require('../..')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const WebSockets = require('libp2p-websockets') const WebSockets = require('libp2p-websockets')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const fs = require('fs'); const fs = require('fs');

View File

@@ -13,7 +13,7 @@ When using libp2p, you need properly configure it, that is, pick your set of mod
You will need 4 dependencies total, so go ahead and install all of them with: You will need 4 dependencies total, so go ahead and install all of them with:
```bash ```bash
> npm install libp2p libp2p-tcp libp2p-noise > npm install libp2p libp2p-tcp @chainsafe/libp2p-noise
``` ```
Then, in your favorite text editor create a file with the `.js` extension. I've called mine `1.js`. Then, in your favorite text editor create a file with the `.js` extension. I've called mine `1.js`.
@@ -25,7 +25,7 @@ First thing is to create our own libp2p node! Insert:
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const TCP = require('libp2p-tcp') const TCP = require('libp2p-tcp')
const { NOISE } = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const createNode = async () => { const createNode = async () => {
const node = await Libp2p.create({ const node = await Libp2p.create({

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const deferStarted = pDefer() const deferStarted = pDefer()

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const defer = pDefer() const defer = pDefer()

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const deferNode1 = pDefer() const deferNode1 = pDefer()

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
async function test () { async function test () {
const deferNode1 = pDefer() const deferNode1 = pDefer()

View File

@@ -2,7 +2,7 @@ import 'babel-polyfill'
const Libp2p = require('libp2p') const Libp2p = require('libp2p')
const WebRTCDirect = require('libp2p-webrtc-direct') const WebRTCDirect = require('libp2p-webrtc-direct')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const {NOISE} = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const Bootstrap = require('libp2p-bootstrap') const Bootstrap = require('libp2p-bootstrap')
document.addEventListener('DOMContentLoaded', async () => { document.addEventListener('DOMContentLoaded', async () => {

View File

@@ -2,7 +2,7 @@ const Libp2p = require('libp2p')
const Bootstrap = require('libp2p-bootstrap') const Bootstrap = require('libp2p-bootstrap')
const WebRTCDirect = require('libp2p-webrtc-direct') const WebRTCDirect = require('libp2p-webrtc-direct')
const Mplex = require('libp2p-mplex') const Mplex = require('libp2p-mplex')
const {NOISE} = require('libp2p-noise') const { NOISE } = require('@chainsafe/libp2p-noise')
const PeerId = require('peer-id') const PeerId = require('peer-id')
;(async () => { ;(async () => {

View File

@@ -23,7 +23,7 @@
"libp2p": "../../", "libp2p": "../../",
"libp2p-bootstrap": "^0.13.0", "libp2p-bootstrap": "^0.13.0",
"libp2p-mplex": "^0.10.4", "libp2p-mplex": "^0.10.4",
"libp2p-noise": "^4.0.0", "@chainsafe/libp2p-noise": "^4.1.0",
"libp2p-webrtc-direct": "^0.7.0", "libp2p-webrtc-direct": "^0.7.0",
"peer-id": "^0.15.0" "peer-id": "^0.15.0"
}, },

View File

@@ -3,7 +3,7 @@
const path = require('path') const path = require('path')
const execa = require('execa') const execa = require('execa')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const { chromium } = require('playwright'); const { chromium } = require('playwright');
function startNode (name, args = []) { function startNode (name, args = []) {

View File

@@ -1,6 +1,6 @@
{ {
"name": "libp2p", "name": "libp2p",
"version": "0.32.1", "version": "0.32.4",
"description": "JavaScript implementation of libp2p, a modular peer to peer network stack", "description": "JavaScript implementation of libp2p, a modular peer to peer network stack",
"leadMaintainer": "Jacob Heun <jacobheun@gmail.com>", "leadMaintainer": "Jacob Heun <jacobheun@gmail.com>",
"main": "src/index.js", "main": "src/index.js",
@@ -124,11 +124,13 @@
"set-delayed-interval": "^1.0.0", "set-delayed-interval": "^1.0.0",
"streaming-iterables": "^6.0.0", "streaming-iterables": "^6.0.0",
"timeout-abort-controller": "^1.1.1", "timeout-abort-controller": "^1.1.1",
"uint8arrays": "^3.0.0",
"varint": "^6.0.0", "varint": "^6.0.0",
"wherearewe": "^1.0.0", "wherearewe": "^1.0.0",
"xsalsa20": "^1.1.0" "xsalsa20": "^1.1.0"
}, },
"devDependencies": { "devDependencies": {
"@chainsafe/libp2p-noise": "^4.0.0",
"@nodeutils/defaults-deep": "^1.1.0", "@nodeutils/defaults-deep": "^1.1.0",
"@types/es6-promisify": "^6.0.0", "@types/es6-promisify": "^6.0.0",
"@types/node": "^16.0.1", "@types/node": "^16.0.1",
@@ -149,23 +151,20 @@
"libp2p-delegated-content-routing": "^0.11.0", "libp2p-delegated-content-routing": "^0.11.0",
"libp2p-delegated-peer-routing": "^0.10.0", "libp2p-delegated-peer-routing": "^0.10.0",
"libp2p-floodsub": "^0.27.0", "libp2p-floodsub": "^0.27.0",
"libp2p-gossipsub": "^0.10.0", "libp2p-gossipsub": "^0.11.0",
"libp2p-interfaces-compliance-tests": "^1.0.0", "libp2p-interfaces-compliance-tests": "^1.0.0",
"libp2p-kad-dht": "^0.23.0", "libp2p-kad-dht": "^0.23.0",
"libp2p-mdns": "^0.17.0", "libp2p-mdns": "^0.17.0",
"libp2p-mplex": "^0.10.1", "libp2p-mplex": "^0.10.1",
"libp2p-noise": "^4.0.0",
"libp2p-tcp": "^0.17.0", "libp2p-tcp": "^0.17.0",
"libp2p-webrtc-star": "^0.23.0", "libp2p-webrtc-star": "^0.23.0",
"libp2p-websockets": "^0.16.0", "libp2p-websockets": "^0.16.0",
"multihashes": "^4.0.2",
"nock": "^13.0.3", "nock": "^13.0.3",
"p-defer": "^3.0.0", "p-defer": "^3.0.0",
"p-times": "^3.0.0", "p-times": "^3.0.0",
"p-wait-for": "^3.2.0", "p-wait-for": "^3.2.0",
"rimraf": "^3.0.2", "rimraf": "^3.0.2",
"sinon": "^11.1.1", "sinon": "^11.1.1",
"uint8arrays": "^2.1.3",
"util": "^0.12.3" "util": "^0.12.3"
}, },
"contributors": [ "contributors": [
@@ -182,51 +181,19 @@
"Volker Mische <volker.mische@gmail.com>", "Volker Mische <volker.mische@gmail.com>",
"Chris Dostert <chrisdostert@users.noreply.github.com>", "Chris Dostert <chrisdostert@users.noreply.github.com>",
"dirkmc <dirkmdev@gmail.com>", "dirkmc <dirkmdev@gmail.com>",
"zeim839 <50573884+zeim839@users.noreply.github.com>",
"Richard Littauer <richard.littauer@gmail.com>", "Richard Littauer <richard.littauer@gmail.com>",
"zeim839 <50573884+zeim839@users.noreply.github.com>",
"Ryan Bell <ryan@piing.net>", "Ryan Bell <ryan@piing.net>",
"a1300 <matthias-knopp@gmx.net>", "a1300 <matthias-knopp@gmx.net>",
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>", "ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>",
"Samlior <samlior@foxmail.com>",
"Franck Royer <franck@royer.one>",
"Thomas Eizinger <thomas@eizinger.io>",
"Giovanni T. Parra <fiatjaf@gmail.com>",
"acolytec3 <17355484+acolytec3@users.noreply.github.com>",
"Elven <mon.samuel@qq.com>",
"Andrew Nesbitt <andrewnez@gmail.com>", "Andrew Nesbitt <andrewnez@gmail.com>",
"Didrik Nordström <didrik.nordstrom@gmail.com>", "Elven <mon.samuel@qq.com>",
"RasmusErik Voel Jensen <github@solsort.com>", "Franck Royer <franck@royer.one>",
"Robert Kiel <robert.kiel@hoprnet.org>", "Giovanni T. Parra <fiatjaf@gmail.com>",
"Aditya Bose <13054902+adbose@users.noreply.github.com>", "Samlior <samlior@foxmail.com>",
"Smite Chow <xiaopengyou@live.com>", "Thomas Eizinger <thomas@eizinger.io>",
"Soeren <nikorpoulsen@gmail.com>", "acolytec3 <17355484+acolytec3@users.noreply.github.com>",
"Sönke Hahn <soenkehahn@gmail.com>", "Didrik Nordström <didrik@betamos.se>",
"TJKoury <TJKoury@gmail.com>",
"Tiago Alves <alvesjtiago@gmail.com>",
"Yusef Napora <yusef@napora.org>",
"Zane Starr <zcstarr@gmail.com>",
"ebinks <elizabethjbinks@gmail.com>",
"isan_rivkin <isanrivkin@gmail.com>",
"mayerwin <mayerwin@users.noreply.github.com>",
"mcclure <andi.m.mcclure@gmail.com>",
"phillmac <phillmac@users.noreply.github.com>",
"robertkiel <robert.kiel@validitylabs.org>",
"shresthagrawal <34920931+shresthagrawal@users.noreply.github.com>",
"swedneck <40505480+swedneck@users.noreply.github.com>",
"Aleksei <vozhdb@gmail.com>",
"Bernd Strehl <bernd.strehl@gmail.com>",
"Chris Bratlien <chrisbratlien@gmail.com>",
"Cindy Wu <ciindy.wu@gmail.com>",
"Daijiro Wachi <daijiro.wachi@gmail.com>",
"Diogo Silva <fsdiogo@gmail.com>",
"Dmitriy Ryajov <dryajov@gmail.com>",
"Ethan Lam <elmemphis2000@gmail.com>",
"Fei Liu <liu.feiwood@gmail.com>",
"Felipe Martins <felipebrasil93@gmail.com>",
"Florian-Merle <florian.david.merle@gmail.com>",
"Francis Gulotta <wizard@roborooter.com>",
"Guy Sviry <32539816+guysv@users.noreply.github.com>",
"Henrique Dias <hacdias@gmail.com>",
"Irakli Gozalishvili <rfobic@gmail.com>", "Irakli Gozalishvili <rfobic@gmail.com>",
"Joel Gustafson <joelg@mit.edu>", "Joel Gustafson <joelg@mit.edu>",
"John Rees <johnrees@users.noreply.github.com>", "John Rees <johnrees@users.noreply.github.com>",
@@ -235,10 +202,43 @@
"Kevin Kwok <antimatter15@gmail.com>", "Kevin Kwok <antimatter15@gmail.com>",
"Kevin Lacker <lacker@gmail.com>", "Kevin Lacker <lacker@gmail.com>",
"Lars Gierth <lgierth@users.noreply.github.com>", "Lars Gierth <lgierth@users.noreply.github.com>",
"Ethan Lam <elmemphis2000@gmail.com>",
"Marcin Tojek <mtojek@users.noreply.github.com>", "Marcin Tojek <mtojek@users.noreply.github.com>",
"Michael Burns <5170+mburns@users.noreply.github.com>", "Michael Burns <5170+mburns@users.noreply.github.com>",
"Miguel Mota <miguelmota2@gmail.com>", "Miguel Mota <miguelmota2@gmail.com>",
"Nuno Nogueira <nunofmn@gmail.com>", "Nuno Nogueira <nunofmn@gmail.com>",
"Philipp Muens <raute1337@gmx.de>" "Dmitriy Ryajov <dryajov@gmail.com>",
"Philipp Muens <raute1337@gmx.de>",
"RasmusErik Voel Jensen <github@solsort.com>",
"Diogo Silva <fsdiogo@gmail.com>",
"Robert Kiel <robert.kiel@hoprnet.org>",
"phillmac <phillmac@users.noreply.github.com>",
"robertkiel <robert.kiel@validitylabs.org>",
"Smite Chow <xiaopengyou@live.com>",
"Soeren <nikorpoulsen@gmail.com>",
"Sönke Hahn <soenkehahn@gmail.com>",
"TJKoury <TJKoury@gmail.com>",
"shresthagrawal <34920931+shresthagrawal@users.noreply.github.com>",
"Tiago Alves <alvesjtiago@gmail.com>",
"Daijiro Wachi <daijiro.wachi@gmail.com>",
"Yusef Napora <yusef@napora.org>",
"Zane Starr <zcstarr@gmail.com>",
"swedneck <40505480+swedneck@users.noreply.github.com>",
"Aleksei <vozhdb@gmail.com>",
"Cindy Wu <ciindy.wu@gmail.com>",
"Aditya Bose <13054902+adbose@users.noreply.github.com>",
"Chris Bratlien <chrisbratlien@gmail.com>",
"ebinks <elizabethjbinks@gmail.com>",
"greenSnot <greenSnot@users.noreply.github.com>",
"Bernd Strehl <bernd.strehl@gmail.com>",
"Francis Gulotta <wizard@roborooter.com>",
"isan_rivkin <isanrivkin@gmail.com>",
"Florian-Merle <florian.david.merle@gmail.com>",
"mayerwin <mayerwin@users.noreply.github.com>",
"Guy Sviry <32539816+guysv@users.noreply.github.com>",
"Henrique Dias <hacdias@gmail.com>",
"mcclure <andi.m.mcclure@gmail.com>",
"Felipe Martins <felipebrasil93@gmail.com>",
"Fei Liu <liu.feiwood@gmail.com>"
] ]
} }

View File

@@ -5,8 +5,8 @@ const log = Object.assign(debug('libp2p:auto-relay'), {
error: debug('libp2p:auto-relay:err') error: debug('libp2p:auto-relay:err')
}) })
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const PeerId = require('peer-id') const PeerId = require('peer-id')

View File

@@ -57,6 +57,7 @@ const DefaultConfig = {
} }
}, },
config: { config: {
protocolPrefix: 'ipfs',
dht: { dht: {
enabled: false, enabled: false,
kBucketSize: 20, kBucketSize: 20,

View File

@@ -3,7 +3,13 @@
// @ts-ignore file not listed within the file list of projects // @ts-ignore file not listed within the file list of projects
const libp2pVersion = require('../../package.json').version const libp2pVersion = require('../../package.json').version
module.exports.PROTOCOL_VERSION = 'ipfs/0.1.0' module.exports.PROTOCOL_VERSION = 'ipfs/0.1.0' // deprecated
module.exports.AGENT_VERSION = `js-libp2p/${libp2pVersion}` module.exports.AGENT_VERSION = `js-libp2p/${libp2pVersion}`
module.exports.MULTICODEC_IDENTIFY = '/ipfs/id/1.0.0' module.exports.MULTICODEC_IDENTIFY = '/ipfs/id/1.0.0' // deprecated
module.exports.MULTICODEC_IDENTIFY_PUSH = '/ipfs/id/push/1.0.0' module.exports.MULTICODEC_IDENTIFY_PUSH = '/ipfs/id/push/1.0.0' // deprecated
module.exports.IDENTIFY_PROTOCOL_VERSION = '0.1.0'
module.exports.MULTICODEC_IDENTIFY_PROTOCOL_NAME = 'id'
module.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME = 'id/push'
module.exports.MULTICODEC_IDENTIFY_PROTOCOL_VERSION = '1.0.0'
module.exports.MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION = '1.0.0'

View File

@@ -8,7 +8,7 @@ const errCode = require('err-code')
const lp = require('it-length-prefixed') const lp = require('it-length-prefixed')
const { pipe } = require('it-pipe') const { pipe } = require('it-pipe')
const { collect, take, consume } = require('streaming-iterables') const { collect, take, consume } = require('streaming-iterables')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const PeerId = require('peer-id') const PeerId = require('peer-id')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
@@ -23,7 +23,11 @@ const PeerRecord = require('../record/peer-record')
const { const {
MULTICODEC_IDENTIFY, MULTICODEC_IDENTIFY,
MULTICODEC_IDENTIFY_PUSH, MULTICODEC_IDENTIFY_PUSH,
PROTOCOL_VERSION IDENTIFY_PROTOCOL_VERSION,
MULTICODEC_IDENTIFY_PROTOCOL_NAME,
MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME,
MULTICODEC_IDENTIFY_PROTOCOL_VERSION,
MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION
} = require('./consts') } = require('./consts')
const { codes } = require('../errors') const { codes } = require('../errors')
@@ -39,6 +43,16 @@ const { codes } = require('../errors')
*/ */
class IdentifyService { class IdentifyService {
/**
* @param {import('../')} libp2p
*/
static getProtocolStr (libp2p) {
return {
identifyProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PROTOCOL_VERSION}`,
identifyPushProtocolStr: `/${libp2p._config.protocolPrefix}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_NAME}/${MULTICODEC_IDENTIFY_PUSH_PROTOCOL_VERSION}`
}
}
/** /**
* @class * @class
* @param {Object} options * @param {Object} options
@@ -53,9 +67,13 @@ class IdentifyService {
this.handleMessage = this.handleMessage.bind(this) this.handleMessage = this.handleMessage.bind(this)
const protocolStr = IdentifyService.getProtocolStr(libp2p)
this.identifyProtocolStr = protocolStr.identifyProtocolStr
this.identifyPushProtocolStr = protocolStr.identifyPushProtocolStr
// Store self host metadata // Store self host metadata
this._host = { this._host = {
protocolVersion: PROTOCOL_VERSION, protocolVersion: `${libp2p._config.protocolPrefix}/${IDENTIFY_PROTOCOL_VERSION}`,
...libp2p._options.host ...libp2p._options.host
} }
@@ -94,7 +112,7 @@ class IdentifyService {
const pushes = connections.map(async connection => { const pushes = connections.map(async connection => {
try { try {
const { stream } = await connection.newStream(MULTICODEC_IDENTIFY_PUSH) const { stream } = await connection.newStream(this.identifyPushProtocolStr)
await pipe( await pipe(
[Message.Identify.encode({ [Message.Identify.encode({
@@ -129,7 +147,7 @@ class IdentifyService {
const connections = [] const connections = []
let connection let connection
for (const peer of this.peerStore.peers.values()) { for (const peer of this.peerStore.peers.values()) {
if (peer.protocols.includes(MULTICODEC_IDENTIFY_PUSH) && (connection = this.connectionManager.get(peer.id))) { if (peer.protocols.includes(this.identifyPushProtocolStr) && (connection = this.connectionManager.get(peer.id))) {
connections.push(connection) connections.push(connection)
} }
} }
@@ -147,7 +165,7 @@ class IdentifyService {
* @returns {Promise<void>} * @returns {Promise<void>}
*/ */
async identify (connection) { async identify (connection) {
const { stream } = await connection.newStream(MULTICODEC_IDENTIFY) const { stream } = await connection.newStream(this.identifyProtocolStr)
const [data] = await pipe( const [data] = await pipe(
[], [],
stream, stream,
@@ -224,9 +242,9 @@ class IdentifyService {
*/ */
handleMessage ({ connection, stream, protocol }) { handleMessage ({ connection, stream, protocol }) {
switch (protocol) { switch (protocol) {
case MULTICODEC_IDENTIFY: case this.identifyProtocolStr:
return this._handleIdentify({ connection, stream }) return this._handleIdentify({ connection, stream })
case MULTICODEC_IDENTIFY_PUSH: case this.identifyPushProtocolStr:
return this._handlePush({ connection, stream }) return this._handlePush({ connection, stream })
default: default:
log.error('cannot handle unknown protocol %s', protocol) log.error('cannot handle unknown protocol %s', protocol)

View File

@@ -31,7 +31,6 @@ const PersistentPeerStore = require('./peer-store/persistent')
const Registrar = require('./registrar') const Registrar = require('./registrar')
const ping = require('./ping') const ping = require('./ping')
const IdentifyService = require('./identify') const IdentifyService = require('./identify')
const IDENTIFY_PROTOCOLS = IdentifyService.multicodecs
const NatManager = require('./nat-manager') const NatManager = require('./nat-manager')
const { updateSelfPeerRecord } = require('./record/utils') const { updateSelfPeerRecord } = require('./record/utils')
@@ -289,7 +288,7 @@ class Libp2p extends EventEmitter {
// Add the identify service since we can multiplex // Add the identify service since we can multiplex
this.identifyService = new IdentifyService({ libp2p: this }) this.identifyService = new IdentifyService({ libp2p: this })
this.handle(Object.values(IDENTIFY_PROTOCOLS), this.identifyService.handleMessage) this.handle(Object.values(IdentifyService.getProtocolStr(this)), this.identifyService.handleMessage)
} }
// Attach private network protector // Attach private network protector

View File

@@ -8,8 +8,8 @@ require('node-forge/lib/pbe')
const forge = require('node-forge/lib/forge') const forge = require('node-forge/lib/forge')
const { certificateForKey, findAsync } = require('./util') const { certificateForKey, findAsync } = require('./util')
const errcode = require('err-code') const errcode = require('err-code')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const privates = new WeakMap() const privates = new WeakMap()

View File

@@ -10,8 +10,8 @@ const crypto = require('libp2p-crypto')
const { Key } = require('interface-datastore') const { Key } = require('interface-datastore')
const CMS = require('./cms') const CMS = require('./cms')
const errcode = require('err-code') const errcode = require('err-code')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
// @ts-ignore node-forge sha512 types not exported // @ts-ignore node-forge sha512 types not exported
require('node-forge/lib/sha512') require('node-forge/lib/sha512')

View File

@@ -5,7 +5,7 @@ const log = Object.assign(debug('libp2p:peer-store:proto-book'), {
error: debug('libp2p:peer-store:proto-book:err') error: debug('libp2p:peer-store:proto-book:err')
}) })
const errcode = require('err-code') const errcode = require('err-code')
const uint8ArrayEquals = require('uint8arrays/equals') const { equals: uint8ArrayEquals } = require('uint8arrays/equals')
const PeerId = require('peer-id') const PeerId = require('peer-id')

View File

@@ -1,6 +1,8 @@
'use strict' 'use strict'
module.exports = { module.exports = {
PROTOCOL: '/ipfs/ping/1.0.0', PROTOCOL: '/ipfs/ping/1.0.0', // deprecated
PING_LENGTH: 32 PING_LENGTH: 32,
PROTOCOL_VERSION: '1.0.0',
PROTOCOL_NAME: 'ping'
} }

View File

@@ -11,9 +11,9 @@ const { pipe } = require('it-pipe')
// @ts-ignore it-buffer has no types exported // @ts-ignore it-buffer has no types exported
const { toBuffer } = require('it-buffer') const { toBuffer } = require('it-buffer')
const { collect, take } = require('streaming-iterables') const { collect, take } = require('streaming-iterables')
const equals = require('uint8arrays/equals') const { equals } = require('uint8arrays/equals')
const { PROTOCOL, PING_LENGTH } = require('./constants') const { PROTOCOL_NAME, PING_LENGTH, PROTOCOL_VERSION } = require('./constants')
/** /**
* @typedef {import('../')} Libp2p * @typedef {import('../')} Libp2p
@@ -30,11 +30,12 @@ const { PROTOCOL, PING_LENGTH } = require('./constants')
* @returns {Promise<number>} * @returns {Promise<number>}
*/ */
async function ping (node, peer) { async function ping (node, peer) {
const protocol = `/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`
// @ts-ignore multiaddr might not have toB58String // @ts-ignore multiaddr might not have toB58String
log('dialing %s to %s', PROTOCOL, peer.toB58String ? peer.toB58String() : peer) log('dialing %s to %s', protocol, peer.toB58String ? peer.toB58String() : peer)
const connection = await node.dial(peer) const connection = await node.dial(peer)
const { stream } = await connection.newStream(PROTOCOL) const { stream } = await connection.newStream(protocol)
const start = Date.now() const start = Date.now()
const data = crypto.randomBytes(PING_LENGTH) const data = crypto.randomBytes(PING_LENGTH)
@@ -61,7 +62,7 @@ async function ping (node, peer) {
* @param {Libp2p} node * @param {Libp2p} node
*/ */
function mount (node) { function mount (node) {
node.handle(PROTOCOL, ({ stream }) => pipe(stream, stream)) node.handle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`, ({ stream }) => pipe(stream, stream))
} }
/** /**
@@ -70,7 +71,7 @@ function mount (node) {
* @param {Libp2p} node * @param {Libp2p} node
*/ */
function unmount (node) { function unmount (node) {
node.unhandle(PROTOCOL) node.unhandle(`/${node._config.protocolPrefix}/${PROTOCOL_NAME}/${PROTOCOL_VERSION}`)
} }
exports = module.exports = ping exports = module.exports = ping

View File

@@ -10,8 +10,8 @@ const Errors = require('./errors')
// @ts-ignore xsalsa20 has no types exported // @ts-ignore xsalsa20 has no types exported
const xsalsa20 = require('xsalsa20') const xsalsa20 = require('xsalsa20')
const KEY_LENGTH = require('./key-generator').KEY_LENGTH const KEY_LENGTH = require('./key-generator').KEY_LENGTH
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
/** /**
* Creates a stream iterable to encrypt messages in a private network * Creates a stream iterable to encrypt messages in a private network

View File

@@ -2,8 +2,8 @@
const crypto = require('libp2p-crypto') const crypto = require('libp2p-crypto')
const KEY_LENGTH = 32 const KEY_LENGTH = 32
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
/** /**
* Generates a PSK that can be used in a libp2p-pnet private network * Generates a PSK that can be used in a libp2p-pnet private network

View File

@@ -17,7 +17,7 @@ You can read further about the envelope in [libp2p/specs#217](https://github.com
```js ```js
// interface-record implementation example with the "libp2p-example" namespace // interface-record implementation example with the "libp2p-example" namespace
const Record = require('libp2p-interfaces/src/record') const Record = require('libp2p-interfaces/src/record')
const fromString = require('uint8arrays/from-string') const { fromString } = require('uint8arrays/from-string')
class ExampleRecord extends Record { class ExampleRecord extends Record {
constructor () { constructor () {

View File

@@ -1,13 +1,13 @@
'use strict' 'use strict'
const errCode = require('err-code') const errCode = require('err-code')
const uint8arraysConcat = require('uint8arrays/concat') const { concat: uint8arraysConcat } = require('uint8arrays/concat')
const uint8arraysFromString = require('uint8arrays/from-string') const { fromString: uint8arraysFromString } = require('uint8arrays/from-string')
// @ts-ignore libp2p-crypto does not support types // @ts-ignore libp2p-crypto does not support types
const cryptoKeys = require('libp2p-crypto/src/keys') const cryptoKeys = require('libp2p-crypto/src/keys')
const PeerId = require('peer-id') const PeerId = require('peer-id')
const varint = require('varint') const varint = require('varint')
const uint8arraysEquals = require('uint8arrays/equals') const { equals: uint8arraysEquals } = require('uint8arrays/equals')
const { codes } = require('../../errors') const { codes } = require('../../errors')
const { Envelope: Protobuf } = require('./envelope') const { Envelope: Protobuf } = require('./envelope')

View File

@@ -0,0 +1,47 @@
'use strict'
/* eslint-env mocha */
const { expect } = require('aegir/utils/chai')
const mergeOptions = require('merge-options')
const { create } = require('../../src')
const { baseOptions } = require('./utils')
describe('Protocol prefix is configurable', () => {
let libp2p
it('protocolPrefix is provided', async () => {
const testProtocol = 'test-protocol'
libp2p = await create(mergeOptions(baseOptions, {
config: {
protocolPrefix: testProtocol
}
}))
const protocols = libp2p.peerStore.protoBook.get(libp2p.peerId);
[
'/libp2p/circuit/relay/0.1.0',
`/${testProtocol}/id/1.0.0`,
`/${testProtocol}/id/push/1.0.0`,
`/${testProtocol}/ping/1.0.0`
].forEach((i, idx) => {
expect(protocols[idx]).equals(i)
})
await libp2p.stop()
})
it('protocolPrefix is not provided', async () => {
libp2p = await create(baseOptions)
const protocols = libp2p.peerStore.protoBook.get(libp2p.peerId);
[
'/libp2p/circuit/relay/0.1.0',
'/ipfs/id/1.0.0',
'/ipfs/id/push/1.0.0',
'/ipfs/ping/1.0.0'
].forEach((i, idx) => {
expect(protocols[idx]).equals(i)
})
await libp2p.stop()
})
})

View File

@@ -1,7 +1,7 @@
'use strict' 'use strict'
const Pubsub = require('libp2p-interfaces/src/pubsub') const Pubsub = require('libp2p-interfaces/src/pubsub')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const filters = require('libp2p-websockets/src/filters') const filters = require('libp2p-websockets/src/filters')

View File

@@ -6,7 +6,7 @@ const { expect } = require('aegir/utils/chai')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const mergeOptions = require('merge-options') const mergeOptions = require('merge-options')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const { create } = require('../../../src') const { create } = require('../../../src')
const { subsystemOptions, subsystemMulticodecs } = require('./utils') const { subsystemOptions, subsystemMulticodecs } = require('./utils')

View File

@@ -2,7 +2,7 @@
/* eslint-env mocha */ /* eslint-env mocha */
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const Libp2p = require('../../src') const Libp2p = require('../../src')
const { createPeerId } = require('../utils/creators/peer') const { createPeerId } = require('../utils/creators/peer')

View File

@@ -4,7 +4,7 @@
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const Libp2p = require('../../src') const Libp2p = require('../../src')
const { codes: ErrorCodes } = require('../../src/errors') const { codes: ErrorCodes } = require('../../src/errors')

View File

@@ -4,7 +4,7 @@
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const Transport = require('libp2p-tcp') const Transport = require('libp2p-tcp')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const { create } = require('../../src') const { create } = require('../../src')
const peerUtils = require('../utils/creators/peer') const peerUtils = require('../utils/creators/peer')

View File

@@ -5,7 +5,7 @@ const { expect } = require('aegir/utils/chai')
const sinon = require('sinon') const sinon = require('sinon')
const Transport = require('libp2p-tcp') const Transport = require('libp2p-tcp')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const PeerId = require('peer-id') const PeerId = require('peer-id')
const delay = require('delay') const delay = require('delay')
@@ -17,7 +17,7 @@ const pushable = require('it-pushable')
const AggregateError = require('aggregate-error') const AggregateError = require('aggregate-error')
const { Connection } = require('libp2p-interfaces/src/connection') const { Connection } = require('libp2p-interfaces/src/connection')
const { AbortError } = require('libp2p-interfaces/src/transport/errors') const { AbortError } = require('libp2p-interfaces/src/transport/errors')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const Libp2p = require('../../src') const Libp2p = require('../../src')
const Dialer = require('../../src/dialer') const Dialer = require('../../src/dialer')

View File

@@ -9,7 +9,7 @@ const delay = require('delay')
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const filters = require('libp2p-websockets/src/filters') const filters = require('libp2p-websockets/src/filters')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const AggregateError = require('aggregate-error') const AggregateError = require('aggregate-error')
const { AbortError } = require('libp2p-interfaces/src/transport/errors') const { AbortError } = require('libp2p-interfaces/src/transport/errors')

View File

@@ -9,7 +9,7 @@ const PeerId = require('peer-id')
const duplexPair = require('it-pair/duplex') const duplexPair = require('it-pair/duplex')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const pWaitFor = require('p-wait-for') const pWaitFor = require('p-wait-for')
const unit8ArrayToString = require('uint8arrays/to-string') const { toString: unit8ArrayToString } = require('uint8arrays/to-string')
const { codes: Errors } = require('../../src/errors') const { codes: Errors } = require('../../src/errors')
const IdentifyService = require('../../src/identify') const IdentifyService = require('../../src/identify')
@@ -60,7 +60,8 @@ describe('Identify', () => {
peerStore: localPeerStore, peerStore: localPeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
const remoteIdentify = new IdentifyService({ const remoteIdentify = new IdentifyService({
@@ -70,7 +71,8 @@ describe('Identify', () => {
peerStore: remotePeerStore, peerStore: remotePeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -119,7 +121,8 @@ describe('Identify', () => {
peerStore: localPeerStore, peerStore: localPeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: { agentVersion } } _options: { host: { agentVersion } },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -131,7 +134,8 @@ describe('Identify', () => {
peerStore: remotePeerStore, peerStore: remotePeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: { agentVersion } } _options: { host: { agentVersion } },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -180,7 +184,8 @@ describe('Identify', () => {
connectionManager: new EventEmitter(), connectionManager: new EventEmitter(),
peerStore: localPeerStore, peerStore: localPeerStore,
multiaddrs: [], multiaddrs: [],
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
const remoteIdentify = new IdentifyService({ const remoteIdentify = new IdentifyService({
@@ -189,7 +194,8 @@ describe('Identify', () => {
connectionManager: new EventEmitter(), connectionManager: new EventEmitter(),
peerStore: remotePeerStore, peerStore: remotePeerStore,
multiaddrs: [], multiaddrs: [],
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -231,7 +237,8 @@ describe('Identify', () => {
host: { host: {
agentVersion agentVersion
} }
} },
_config: { protocolPrefix: 'ipfs' }
}, },
protocols protocols
}) })
@@ -261,7 +268,8 @@ describe('Identify', () => {
peerStore: localPeerStore, peerStore: localPeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -275,7 +283,8 @@ describe('Identify', () => {
peerStore: remotePeerStore, peerStore: remotePeerStore,
multiaddrs: [], multiaddrs: [],
isStarted: () => true, isStarted: () => true,
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -333,7 +342,8 @@ describe('Identify', () => {
peerStore: localPeerStore, peerStore: localPeerStore,
multiaddrs: listenMaddrs, multiaddrs: listenMaddrs,
isStarted: () => true, isStarted: () => true,
_options: { host: {} } _options: { host: {} },
_config: { protocolPrefix: 'ipfs' }
} }
}) })
@@ -347,6 +357,7 @@ describe('Identify', () => {
peerStore: new PeerStore({ peerId: remotePeer }), peerStore: new PeerStore({ peerId: remotePeer }),
multiaddrs: [], multiaddrs: [],
_options: { host: {} }, _options: { host: {} },
_config: { protocolPrefix: 'ipfs' },
isStarted: () => true isStarted: () => true
} }
}) })

View File

@@ -3,8 +3,8 @@
'use strict' 'use strict'
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const { MemoryDatastore } = require('interface-datastore') const { MemoryDatastore } = require('interface-datastore')
const Keychain = require('../../src/keychain') const Keychain = require('../../src/keychain')

View File

@@ -4,8 +4,8 @@
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const fail = expect.fail const fail = expect.fail
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const peerUtils = require('../utils/creators/peer') const peerUtils = require('../utils/creators/peer')

View File

@@ -7,7 +7,7 @@ const { base58btc } = require('multiformats/bases/base58')
const crypto = require('libp2p-crypto') const crypto = require('libp2p-crypto')
const rsaUtils = require('libp2p-crypto/src/keys/rsa-utils') const rsaUtils = require('libp2p-crypto/src/keys/rsa-utils')
const rsaClass = require('libp2p-crypto/src/keys/rsa-class') const rsaClass = require('libp2p-crypto/src/keys/rsa-class')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const sample = { const sample = {
id: '122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a9', id: '122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a9',

View File

@@ -11,7 +11,7 @@ const crypto = require('libp2p-crypto')
const KadDht = require('libp2p-kad-dht') const KadDht = require('libp2p-kad-dht')
const MulticastDNS = require('libp2p-mdns') const MulticastDNS = require('libp2p-mdns')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const uint8ArrayToString = require('uint8arrays/to-string') const { toString: uint8ArrayToString } = require('uint8arrays/to-string')
const Libp2p = require('../../src') const Libp2p = require('../../src')
const baseOptions = require('../utils/base-options') const baseOptions = require('../utils/base-options')

View File

@@ -2,7 +2,7 @@
/* eslint-env mocha */ /* eslint-env mocha */
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const pDefer = require('p-defer') const pDefer = require('p-defer')
const PeerStore = require('../../src/peer-store') const PeerStore = require('../../src/peer-store')

View File

@@ -5,7 +5,7 @@ const { expect } = require('aegir/utils/chai')
const PeerStore = require('../../src/peer-store') const PeerStore = require('../../src/peer-store')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const peerUtils = require('../utils/creators/peer') const peerUtils = require('../utils/creators/peer')

View File

@@ -10,7 +10,7 @@ const PeerStore = require('../../src/peer-store/persistent')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const { MemoryDatastore } = require('interface-datastore') const { MemoryDatastore } = require('interface-datastore')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const peerUtils = require('../utils/creators/peer') const peerUtils = require('../utils/creators/peer')

View File

@@ -5,7 +5,7 @@ const { expect } = require('aegir/utils/chai')
const duplexPair = require('it-pair/duplex') const duplexPair = require('it-pair/duplex')
const pipe = require('it-pipe') const pipe = require('it-pipe')
const { collect } = require('streaming-iterables') const { collect } = require('streaming-iterables')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const Protector = require('../../src/pnet') const Protector = require('../../src/pnet')
const Errors = Protector.errors const Errors = Protector.errors

View File

@@ -2,8 +2,8 @@
/* eslint-env mocha */ /* eslint-env mocha */
const { expect } = require('aegir/utils/chai') const { expect } = require('aegir/utils/chai')
const uint8arrayFromString = require('uint8arrays/from-string') const { fromString: uint8arrayFromString } = require('uint8arrays/from-string')
const uint8arrayEquals = require('uint8arrays/equals') const { equals: uint8arrayEquals } = require('uint8arrays/equals')
const Envelope = require('../../src/record/envelope') const Envelope = require('../../src/record/envelope')
const { codes: ErrorCodes } = require('../../src/errors') const { codes: ErrorCodes } = require('../../src/errors')

View File

@@ -9,7 +9,7 @@ const { collect } = require('streaming-iterables')
const pipe = require('it-pipe') const pipe = require('it-pipe')
const AggregateError = require('aggregate-error') const AggregateError = require('aggregate-error')
const PeerId = require('peer-id') const PeerId = require('peer-id')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const { createPeerId } = require('../utils/creators/peer') const { createPeerId } = require('../utils/creators/peer')
const baseOptions = require('../utils/base-options') const baseOptions = require('../utils/base-options')

View File

@@ -7,7 +7,7 @@ const sinon = require('sinon')
const { Multiaddr } = require('multiaddr') const { Multiaddr } = require('multiaddr')
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const filters = require('libp2p-websockets/src/filters') const filters = require('libp2p-websockets/src/filters')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const AddressManager = require('../../src/address-manager') const AddressManager = require('../../src/address-manager')
const TransportManager = require('../../src/transport-manager') const TransportManager = require('../../src/transport-manager')
const mockUpgrader = require('../utils/mockUpgrader') const mockUpgrader = require('../utils/mockUpgrader')

View File

@@ -12,7 +12,7 @@
"libp2p-interfaces": "^1.0.1", "libp2p-interfaces": "^1.0.1",
"libp2p-kad-dht": "^0.23.1", "libp2p-kad-dht": "^0.23.1",
"libp2p-mplex": "^0.10.4", "libp2p-mplex": "^0.10.4",
"libp2p-noise": "^4.0.0", "@chainsafe/libp2p-noise": "^4.1.0",
"libp2p-record": "^0.10.4", "libp2p-record": "^0.10.4",
"libp2p-tcp": "^0.17.1", "libp2p-tcp": "^0.17.1",
"libp2p-websockets": "^0.16.1", "libp2p-websockets": "^0.16.1",

View File

@@ -3,7 +3,7 @@ import Libp2pRecord = require('libp2p-record')
import TCP = require('libp2p-tcp') import TCP = require('libp2p-tcp')
const WEBSOCKETS = require('libp2p-websockets') const WEBSOCKETS = require('libp2p-websockets')
const NOISE = require('libp2p-noise') const NOISE = require('@chainsafe/libp2p-noise')
const MPLEX = require('libp2p-mplex') const MPLEX = require('libp2p-mplex')
const Gossipsub = require('libp2p-gossipsub') const Gossipsub = require('libp2p-gossipsub')
const DHT = require('libp2p-kad-dht') const DHT = require('libp2p-kad-dht')

View File

@@ -10,9 +10,9 @@ const pipe = require('it-pipe')
const { collect } = require('streaming-iterables') const { collect } = require('streaming-iterables')
const pSettle = require('p-settle') const pSettle = require('p-settle')
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const Protector = require('../../src/pnet') const Protector = require('../../src/pnet')
const uint8ArrayFromString = require('uint8arrays/from-string') const { fromString: uint8ArrayFromString } = require('uint8arrays/from-string')
const swarmKeyBuffer = uint8ArrayFromString(require('../fixtures/swarm.key')) const swarmKeyBuffer = uint8ArrayFromString(require('../fixtures/swarm.key'))
const Libp2p = require('../../src') const Libp2p = require('../../src')

View File

@@ -3,7 +3,7 @@
const Transport = require('libp2p-websockets') const Transport = require('libp2p-websockets')
const filters = require('libp2p-websockets/src/filters') const filters = require('libp2p-websockets/src/filters')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
const transportKey = Transport.prototype[Symbol.toStringTag] const transportKey = Transport.prototype[Symbol.toStringTag]

View File

@@ -2,7 +2,7 @@
const Transport = require('libp2p-tcp') const Transport = require('libp2p-tcp')
const Muxer = require('libp2p-mplex') const Muxer = require('libp2p-mplex')
const { NOISE: Crypto } = require('libp2p-noise') const { NOISE: Crypto } = require('@chainsafe/libp2p-noise')
module.exports = { module.exports = {
modules: { modules: {