mirror of
https://github.com/fluencelabs/js-peer-id
synced 2025-07-04 11:11:51 +00:00
Compare commits
103 Commits
Author | SHA1 | Date | |
---|---|---|---|
ed211a943b | |||
8ea480a3b0 | |||
f39fb24321 | |||
911aa634d3 | |||
94aa3483b3 | |||
1f1f86f576 | |||
76864184da | |||
f50b2ac016 | |||
6754752b05 | |||
17440a3f9a | |||
989b413a96 | |||
52ed9c58a5 | |||
c3463c7421 | |||
bbabd7451e | |||
1624b0f70a | |||
ce8a6ff77e | |||
41ce1d4671 | |||
231e553a22 | |||
cd2099305e | |||
8e030b24d4 | |||
9f69e1ba74 | |||
cbc8c5e2ba | |||
77000dbd8b | |||
eb062759c6 | |||
39e17c0c0b | |||
e03a4098df | |||
d7e633a90b | |||
2e5e666140 | |||
b388257b69 | |||
6ecd9a8cb0 | |||
6513a02e1e | |||
bd1dc9bda0 | |||
31cbb5d94c | |||
35556c3a37 | |||
e8ab1b9281 | |||
a786018528 | |||
417fd330b9 | |||
d74bdebcc8 | |||
ffed046595 | |||
1727a135aa | |||
466b3a030d | |||
464c92a53b | |||
8a608def32 | |||
19deeff432 | |||
b18c0082ff | |||
2b050bcaa1 | |||
b19edf2ab2 | |||
35b384ed15 | |||
655ceec29b | |||
8b9a134276 | |||
a637297112 | |||
e666b7284f | |||
156911e162 | |||
f91f2b6506 | |||
8f6935499e | |||
80da1a54b2 | |||
300266ad51 | |||
3abdcdabbb | |||
7d3cb8e87c | |||
a57c0c6f14 | |||
d7088d6650 | |||
c945d6ad48 | |||
0eee1a2a69 | |||
63428faae9 | |||
a38e3859d2 | |||
551fd710be | |||
442df13a11 | |||
156088db99 | |||
9c0c648001 | |||
a2934aa371 | |||
ac98b7582a | |||
0dc3c14f2b | |||
af6575d06c | |||
ccf0b7875c | |||
733b40bb47 | |||
ac27907241 | |||
e206c46549 | |||
41d3e5be5b | |||
bc213dd818 | |||
3f4f670691 | |||
d2894bfa32 | |||
c3e3b70d09 | |||
f08866047d | |||
a3fe1a2f03 | |||
0acc572fd3 | |||
8c49610dff | |||
e1ffe9bba5 | |||
e59010b439 | |||
60b1c09665 | |||
b28b8ef693 | |||
961b218a53 | |||
0642070fdd | |||
3da91b92fa | |||
ad9a43b7c8 | |||
c67bf150f2 | |||
a2afb2aeea | |||
6624c27d8d | |||
26ac06d21c | |||
f0d72b7bfe | |||
78d96d0b14 | |||
bebb0a7eae | |||
5d6a962b6c | |||
531c9f1086 |
20
.gitignore
vendored
20
.gitignore
vendored
@ -1,7 +1,15 @@
|
|||||||
|
docs
|
||||||
|
**/node_modules/
|
||||||
|
**/*.log
|
||||||
|
test/repo-tests*
|
||||||
|
**/bundle.js
|
||||||
|
|
||||||
# Logs
|
# Logs
|
||||||
logs
|
logs
|
||||||
*.log
|
*.log
|
||||||
|
|
||||||
|
coverage
|
||||||
|
|
||||||
# Runtime data
|
# Runtime data
|
||||||
pids
|
pids
|
||||||
*.pid
|
*.pid
|
||||||
@ -19,11 +27,19 @@ coverage
|
|||||||
# node-waf configuration
|
# node-waf configuration
|
||||||
.lock-wscript
|
.lock-wscript
|
||||||
|
|
||||||
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
build
|
||||||
build/Release
|
|
||||||
|
|
||||||
# Dependency directory
|
# Dependency directory
|
||||||
# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git
|
# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git
|
||||||
node_modules
|
node_modules
|
||||||
|
|
||||||
|
docs
|
||||||
|
lib
|
||||||
dist
|
dist
|
||||||
|
test/test-data/go-ipfs-repo/LOCK
|
||||||
|
test/test-data/go-ipfs-repo/LOG
|
||||||
|
test/test-data/go-ipfs-repo/LOG.old
|
||||||
|
|
||||||
|
# while testing npm5
|
||||||
|
package-lock.json
|
||||||
|
yarn.lock
|
||||||
|
28
.npmignore
28
.npmignore
@ -1,28 +0,0 @@
|
|||||||
# Logs
|
|
||||||
logs
|
|
||||||
*.log
|
|
||||||
|
|
||||||
# Runtime data
|
|
||||||
pids
|
|
||||||
*.pid
|
|
||||||
*.seed
|
|
||||||
|
|
||||||
# Directory for instrumented libs generated by jscoverage/JSCover
|
|
||||||
lib-cov
|
|
||||||
|
|
||||||
# Coverage directory used by tools like istanbul
|
|
||||||
coverage
|
|
||||||
|
|
||||||
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
|
||||||
.grunt
|
|
||||||
|
|
||||||
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
|
||||||
build/Release
|
|
||||||
|
|
||||||
# Optional npm cache directory
|
|
||||||
.npm
|
|
||||||
|
|
||||||
# Optional REPL history
|
|
||||||
.node_repl_history
|
|
||||||
|
|
||||||
test
|
|
62
.travis.yml
62
.travis.yml
@ -1,37 +1,45 @@
|
|||||||
sudo: false
|
|
||||||
language: node_js
|
language: node_js
|
||||||
|
cache: npm
|
||||||
|
stages:
|
||||||
|
- check
|
||||||
|
- test
|
||||||
|
- cov
|
||||||
|
|
||||||
matrix:
|
node_js:
|
||||||
|
- '10'
|
||||||
|
|
||||||
|
os:
|
||||||
|
- linux
|
||||||
|
- osx
|
||||||
|
|
||||||
|
script: npx nyc -s npm run test:node -- --bail
|
||||||
|
after_success: npx nyc report --reporter=text-lcov > coverage.lcov && npx codecov
|
||||||
|
|
||||||
|
jobs:
|
||||||
include:
|
include:
|
||||||
- node_js: 4
|
- os: windows
|
||||||
env: CXX=g++-4.8
|
cache: false
|
||||||
- node_js: 6
|
|
||||||
env:
|
|
||||||
- SAUCE=true
|
|
||||||
- CXX=g++-4.8
|
|
||||||
- node_js: stable
|
|
||||||
env: CXX=g++-4.8
|
|
||||||
|
|
||||||
# Make sure we have new NPM.
|
|
||||||
before_install:
|
|
||||||
- npm install -g npm
|
|
||||||
|
|
||||||
|
- stage: check
|
||||||
script:
|
script:
|
||||||
|
- npx aegir dep-check
|
||||||
- npm run lint
|
- npm run lint
|
||||||
- npm test
|
|
||||||
- npm run coverage
|
|
||||||
|
|
||||||
before_script:
|
- stage: test
|
||||||
- export DISPLAY=:99.0
|
name: chrome
|
||||||
- sh -e /etc/init.d/xvfb start
|
addons:
|
||||||
|
chrome: stable
|
||||||
after_success:
|
script:
|
||||||
- npm run coverage-publish
|
- npx aegir test -t browser
|
||||||
|
- npx aegir test -t webworker
|
||||||
|
|
||||||
|
- stage: test
|
||||||
|
name: firefox
|
||||||
addons:
|
addons:
|
||||||
firefox: latest
|
firefox: latest
|
||||||
apt:
|
script:
|
||||||
sources:
|
- npx aegir test -t browser -- --browsers FirefoxHeadless
|
||||||
- ubuntu-toolchain-r-test
|
- npx aegir test -t webworker -- --browsers FirefoxHeadless
|
||||||
packages:
|
|
||||||
- g++-4.8
|
notifications:
|
||||||
|
email: false
|
||||||
|
326
CHANGELOG.md
Normal file
326
CHANGELOG.md
Normal file
@ -0,0 +1,326 @@
|
|||||||
|
<a name="0.13.3"></a>
|
||||||
|
## [0.13.3](https://github.com/libp2p/js-peer-id/compare/v0.13.2...v0.13.3) (2019-09-25)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* allow nested PeerIds to support pubKey function when using identity encoding ([#101](https://github.com/libp2p/js-peer-id/issues/101)) ([f39fb24](https://github.com/libp2p/js-peer-id/commit/f39fb24))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.2"></a>
|
||||||
|
## [0.13.2](https://github.com/libp2p/js-peer-id/compare/v0.13.1...v0.13.2) (2019-07-12)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* add compact protobuf format ([#76](https://github.com/libp2p/js-peer-id/issues/76)) ([7686418](https://github.com/libp2p/js-peer-id/commit/7686418))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.1"></a>
|
||||||
|
## [0.13.1](https://github.com/libp2p/js-peer-id/compare/v0.13.0...v0.13.1) (2019-07-11)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* **peerid:** support creating from secp256k1; harmonize algo with Go ([#95](https://github.com/libp2p/js-peer-id/issues/95)) ([17440a3](https://github.com/libp2p/js-peer-id/commit/17440a3))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.0"></a>
|
||||||
|
# [0.13.0](https://github.com/libp2p/js-peer-id/compare/v0.12.2...v0.13.0) (2019-07-11)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* async await ([#87](https://github.com/libp2p/js-peer-id/issues/87)) ([c3463c7](https://github.com/libp2p/js-peer-id/commit/c3463c7))
|
||||||
|
|
||||||
|
|
||||||
|
### BREAKING CHANGES
|
||||||
|
|
||||||
|
* API refactored to use async/await
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.12.2"></a>
|
||||||
|
## [0.12.2](https://github.com/libp2p/js-peer-id/compare/v0.12.1...v0.12.2) (2019-01-09)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* clean repo and bundle size reduction ([cd20993](https://github.com/libp2p/js-peer-id/commit/cd20993))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.12.1"></a>
|
||||||
|
## [0.12.1](https://github.com/libp2p/js-peer-id/compare/v0.12.0...v0.12.1) (2019-01-03)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.12.0"></a>
|
||||||
|
# [0.12.0](https://github.com/libp2p/js-peer-id/compare/v0.11.0...v0.12.0) (2018-10-18)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* add peerIdWithIs to the API functions using the instance ([2e5e666](https://github.com/libp2p/js-peer-id/commit/2e5e666))
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* add class-is module ([6513a02](https://github.com/libp2p/js-peer-id/commit/6513a02))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.11.0"></a>
|
||||||
|
# [0.11.0](https://github.com/libp2p/js-peer-id/compare/v0.10.7...v0.11.0) (2018-07-02)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* change toPrint output to match go implementation ([e8ab1b9](https://github.com/libp2p/js-peer-id/commit/e8ab1b9))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.7"></a>
|
||||||
|
## [0.10.7](https://github.com/libp2p/js-peer-id/compare/v0.10.6...v0.10.7) (2018-04-05)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.6"></a>
|
||||||
|
## [0.10.6](https://github.com/libp2p/js-peer-id/compare/v0.10.5...v0.10.6) (2018-02-12)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.5"></a>
|
||||||
|
## [0.10.5](https://github.com/libp2p/js-peer-id/compare/v0.10.4...v0.10.5) (2018-01-28)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.4"></a>
|
||||||
|
## [0.10.4](https://github.com/libp2p/js-peer-id/compare/v0.10.3...v0.10.4) (2017-12-20)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* update dependencies ([#73](https://github.com/libp2p/js-peer-id/issues/73)) ([8b9a134](https://github.com/libp2p/js-peer-id/commit/8b9a134))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.3"></a>
|
||||||
|
## [0.10.3](https://github.com/libp2p/js-peer-id/compare/v0.10.2...v0.10.3) (2017-12-01)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* catch error when unmarshaling instead of crashing ([#72](https://github.com/libp2p/js-peer-id/issues/72)) ([156911e](https://github.com/libp2p/js-peer-id/commit/156911e))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.2"></a>
|
||||||
|
## [0.10.2](https://github.com/libp2p/js-peer-id/compare/v0.10.1...v0.10.2) (2017-10-12)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* Always add public key to constructor if possible, Fix for undefined pubKey in remote peers ([#68](https://github.com/libp2p/js-peer-id/issues/68)) ([3abdcda](https://github.com/libp2p/js-peer-id/commit/3abdcda))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.1"></a>
|
||||||
|
## [0.10.1](https://github.com/libp2p/js-peer-id/compare/v0.10.0...v0.10.1) (2017-09-07)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* **deps:** update aegir and libp2p-crypto ([#67](https://github.com/libp2p/js-peer-id/issues/67)) ([d7088d6](https://github.com/libp2p/js-peer-id/commit/d7088d6))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.10.0"></a>
|
||||||
|
# [0.10.0](https://github.com/libp2p/js-peer-id/compare/v0.9.0...v0.10.0) (2017-09-03)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* p2p addrs situation ([#66](https://github.com/libp2p/js-peer-id/issues/66)) ([63428fa](https://github.com/libp2p/js-peer-id/commit/63428fa))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.9.0"></a>
|
||||||
|
# [0.9.0](https://github.com/libp2p/js-peer-id/compare/v0.8.8...v0.9.0) (2017-07-22)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* use next libp2p-crypto ([#64](https://github.com/libp2p/js-peer-id/issues/64)) ([442df13](https://github.com/libp2p/js-peer-id/commit/442df13))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.8"></a>
|
||||||
|
## [0.8.8](https://github.com/libp2p/js-peer-id/compare/v0.8.7...v0.8.8) (2017-07-21)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.7"></a>
|
||||||
|
## [0.8.7](https://github.com/libp2p/js-peer-id/compare/v0.8.6...v0.8.7) (2017-04-03)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* set privKey pubKey ([ac27907](https://github.com/libp2p/js-peer-id/commit/ac27907))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.6"></a>
|
||||||
|
## [0.8.6](https://github.com/libp2p/js-peer-id/compare/v0.8.5...v0.8.6) (2017-03-30)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* isEqual ([3f4f670](https://github.com/libp2p/js-peer-id/commit/3f4f670))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.5"></a>
|
||||||
|
## [0.8.5](https://github.com/libp2p/js-peer-id/compare/v0.8.4...v0.8.5) (2017-03-27)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* avoid using constructor.name ([a3fe1a2](https://github.com/libp2p/js-peer-id/commit/a3fe1a2))
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* isPeerId ([0acc572](https://github.com/libp2p/js-peer-id/commit/0acc572))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.4"></a>
|
||||||
|
## [0.8.4](https://github.com/libp2p/js-peer-id/compare/v0.8.2...v0.8.4) (2017-03-16)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.2"></a>
|
||||||
|
## [0.8.2](https://github.com/libp2p/js-peer-id/compare/v0.8.1...v0.8.2) (2017-02-09)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.1"></a>
|
||||||
|
## [0.8.1](https://github.com/libp2p/js-peer-id/compare/v0.8.0...v0.8.1) (2016-12-18)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* cache b58 id ([bebb0a7](https://github.com/libp2p/js-peer-id/commit/bebb0a7))
|
||||||
|
* create b58 string on creation and throw on id mutation ([78d96d0](https://github.com/libp2p/js-peer-id/commit/78d96d0))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.8.0"></a>
|
||||||
|
# [0.8.0](https://github.com/libp2p/js-peer-id/compare/v0.7.0...v0.8.0) (2016-11-03)
|
||||||
|
|
||||||
|
|
||||||
|
* Async Crypto Endeavour (#33) ([31701e2](https://github.com/libp2p/js-peer-id/commit/31701e2))
|
||||||
|
|
||||||
|
|
||||||
|
### BREAKING CHANGES
|
||||||
|
|
||||||
|
* This changes the interface of .create, .createFromPrivKey,
|
||||||
|
.createFromPubKey, .createFromJSON
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.7.0"></a>
|
||||||
|
# [0.7.0](https://github.com/libp2p/js-peer-id/compare/v0.6.7...v0.7.0) (2016-05-26)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* code review and docs and go interop ([58f1933](https://github.com/libp2p/js-peer-id/commit/58f1933))
|
||||||
|
* use new version of libp2p-crypto ([ab55046](https://github.com/libp2p/js-peer-id/commit/ab55046))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.6.7"></a>
|
||||||
|
## [0.6.7](https://github.com/libp2p/js-peer-id/compare/v0.6.6...v0.6.7) (2016-05-23)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.6.6"></a>
|
||||||
|
## [0.6.6](https://github.com/libp2p/js-peer-id/compare/v0.6.5...v0.6.6) (2016-04-12)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.6.5"></a>
|
||||||
|
## [0.6.5](https://github.com/libp2p/js-peer-id/compare/v0.6.1...v0.6.5) (2016-04-12)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.6.1"></a>
|
||||||
|
## [0.6.1](https://github.com/libp2p/js-peer-id/compare/v0.6.0...v0.6.1) (2016-03-15)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.6.0"></a>
|
||||||
|
# [0.6.0](https://github.com/libp2p/js-peer-id/compare/v0.5.3...v0.6.0) (2016-03-10)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.5.3"></a>
|
||||||
|
## [0.5.3](https://github.com/libp2p/js-peer-id/compare/v0.5.1...v0.5.3) (2016-03-05)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.5.1"></a>
|
||||||
|
## [0.5.1](https://github.com/libp2p/js-peer-id/compare/v0.5.0...v0.5.1) (2016-03-03)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.5.0"></a>
|
||||||
|
# [0.5.0](https://github.com/libp2p/js-peer-id/compare/v0.4.0...v0.5.0) (2016-02-14)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.4.0"></a>
|
||||||
|
# [0.4.0](https://github.com/libp2p/js-peer-id/compare/v0.3.4...v0.4.0) (2015-11-05)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.3.4"></a>
|
||||||
|
## [0.3.4](https://github.com/libp2p/js-peer-id/compare/v0.3.3...v0.3.4) (2015-10-28)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.3.3"></a>
|
||||||
|
## [0.3.3](https://github.com/libp2p/js-peer-id/compare/v0.3.2...v0.3.3) (2015-09-15)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.3.2"></a>
|
||||||
|
## [0.3.2](https://github.com/libp2p/js-peer-id/compare/v0.3.1...v0.3.2) (2015-09-14)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.3.1"></a>
|
||||||
|
## [0.3.1](https://github.com/libp2p/js-peer-id/compare/v0.3.0...v0.3.1) (2015-08-25)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.3.0"></a>
|
||||||
|
# [0.3.0](https://github.com/libp2p/js-peer-id/compare/v0.2.0...v0.3.0) (2015-07-19)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.2.0"></a>
|
||||||
|
# [0.2.0](https://github.com/libp2p/js-peer-id/compare/v0.1.0...v0.2.0) (2015-07-17)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.1.0"></a>
|
||||||
|
# 0.1.0 (2015-07-08)
|
||||||
|
|
||||||
|
|
||||||
|
|
83
README.md
83
README.md
@ -1,18 +1,22 @@
|
|||||||
# peer-id
|
# peer-id
|
||||||
|
|
||||||
[](http://ipn.io)
|
[](http://protocol.ai)
|
||||||
[](http://webchat.freenode.net/?channels=%23ipfs)
|
[](http://libp2p.io/)
|
||||||
[](https://travis-ci.org/libp2p/js-peer-id)
|
[](http://webchat.freenode.net/?channels=%23libp2p)
|
||||||
[](https://coveralls.io/github/libp2p/js-peer-id?branch=master)
|
[](https://discuss.libp2p.io)
|
||||||
|
[](https://codecov.io/gh/libp2p/js-peer-id)
|
||||||
|
[](https://travis-ci.com/libp2p/js-peer-id)
|
||||||
[](https://david-dm.org/libp2p/js-peer-id)
|
[](https://david-dm.org/libp2p/js-peer-id)
|
||||||
[](https://github.com/feross/standard)
|
[](https://github.com/feross/standard)
|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
[](https://saucelabs.com/u/ipfs-js-peer-id)
|
|
||||||
|
|
||||||
> [IPFS](https://github.com/ipfs/ipfs) Peer ID implementation in JavaScript.
|
> [IPFS](https://github.com/ipfs/ipfs) Peer ID implementation in JavaScript.
|
||||||
|
|
||||||
|
## Lead Maintainer
|
||||||
|
|
||||||
|
[Vasco Santos](https://github.com/vasco-santos)
|
||||||
|
|
||||||
|
## Table of Contents
|
||||||
|
|
||||||
- [Description](#description)
|
- [Description](#description)
|
||||||
- [Example](#example)
|
- [Example](#example)
|
||||||
- [Installation](#installation)
|
- [Installation](#installation)
|
||||||
@ -24,7 +28,7 @@
|
|||||||
- [API](#api)
|
- [API](#api)
|
||||||
- [Create](#create)
|
- [Create](#create)
|
||||||
- [`new PeerId(id[, privKey, pubKey])`](#new-peeridid-privkey-pubkey)
|
- [`new PeerId(id[, privKey, pubKey])`](#new-peeridid-privkey-pubkey)
|
||||||
- [`create([opts], callback)`](#createopts-callback)
|
- [`create([opts])`](#createopts)
|
||||||
- [Import](#import)
|
- [Import](#import)
|
||||||
- [`createFromHexString(str)`](#createfromhexstringstr)
|
- [`createFromHexString(str)`](#createfromhexstringstr)
|
||||||
- [`createFromBytes(buf)`](#createfrombytesbuf)
|
- [`createFromBytes(buf)`](#createfrombytesbuf)
|
||||||
@ -44,25 +48,20 @@
|
|||||||
|
|
||||||
Generate, import, and export PeerIDs, for use with [IPFS](https://github.com/ipfs/ipfs).
|
Generate, import, and export PeerIDs, for use with [IPFS](https://github.com/ipfs/ipfs).
|
||||||
|
|
||||||
*A Peer ID is the SHA-256 [multihash](https://github.com/multiformats/multihash) of a
|
A Peer ID is the SHA-256 [multihash](https://github.com/multiformats/multihash) of a public key.
|
||||||
public key.*
|
|
||||||
|
|
||||||
*The public key is a base64 encoded string of a protobuf containing an RSA DER
|
The public key is a base64 encoded string of a protobuf containing an RSA DER buffer. This uses a node buffer to pass the base64 encoded public key protobuf to the multihash for ID generation.
|
||||||
buffer. This uses a node buffer to pass the base64 encoded public key protobuf
|
|
||||||
to the multihash for ID generation.*
|
|
||||||
|
|
||||||
# Example
|
# Example
|
||||||
|
|
||||||
```js
|
```JavaScript
|
||||||
var PeerId = require('peer-id')
|
const PeerId = require('peer-id')
|
||||||
var bs58 = require('bs58')
|
|
||||||
|
|
||||||
PeerId.create({ bits: 1024 }, (err, id) => {
|
const id = await PeerId.create({ bits: 1024, keyType: 'rsa' })
|
||||||
console.log(JSON.stringify(id.toJSON(), null, 2)
|
console.log(JSON.stringify(id.toJSON(), null, 2))
|
||||||
})
|
|
||||||
```
|
```
|
||||||
|
|
||||||
```
|
```bash
|
||||||
{
|
{
|
||||||
"id": "Qma9T5YraSnpRDZqRR4krcSJabThc8nwZuJV3LercPHufi",
|
"id": "Qma9T5YraSnpRDZqRR4krcSJabThc8nwZuJV3LercPHufi",
|
||||||
"privKey": "CAAS4AQwggJcAgEAAoGBAMBgbIqyOL26oV3nGPBYrdpbv..",
|
"privKey": "CAAS4AQwggJcAgEAAoGBAMBgbIqyOL26oV3nGPBYrdpbv..",
|
||||||
@ -83,7 +82,7 @@ PeerId.create({ bits: 1024 }, (err, id) => {
|
|||||||
## Node.js
|
## Node.js
|
||||||
|
|
||||||
```js
|
```js
|
||||||
var PeerId = require('peer-id')
|
const PeerId = require('peer-id')
|
||||||
```
|
```
|
||||||
|
|
||||||
## Browser: Browserify, Webpack, other bundlers
|
## Browser: Browserify, Webpack, other bundlers
|
||||||
@ -94,7 +93,7 @@ it and use with your favourite bundler without having to adjust asset management
|
|||||||
process.
|
process.
|
||||||
|
|
||||||
```js
|
```js
|
||||||
var PeerId = require('peer-id')
|
const PeerId = require('peer-id')
|
||||||
```
|
```
|
||||||
|
|
||||||
## Browser: `<script>` Tag
|
## Browser: `<script>` Tag
|
||||||
@ -124,14 +123,13 @@ const PeerId = require('peer-id')
|
|||||||
|
|
||||||
The key format is detailed in [libp2p-crypto](https://github.com/libp2p/js-libp2p-crypto).
|
The key format is detailed in [libp2p-crypto](https://github.com/libp2p/js-libp2p-crypto).
|
||||||
|
|
||||||
### `create([opts], callback)`
|
### `create([opts])`
|
||||||
|
|
||||||
Generates a new Peer ID, complete with public/private keypair.
|
Generates a new Peer ID, complete with public/private keypair.
|
||||||
|
|
||||||
- `opts: Object`: Default: `{bits: 2048}`
|
- `opts: Object`: Default: `{bits: 2048, keyType: 'rsa'}`
|
||||||
- `callback: Function`
|
|
||||||
|
|
||||||
Calls back `callback` with `err, id`.
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
## Import
|
## Import
|
||||||
|
|
||||||
@ -139,30 +137,47 @@ Calls back `callback` with `err, id`.
|
|||||||
|
|
||||||
Creates a Peer ID from hex string representing the key's multihash.
|
Creates a Peer ID from hex string representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId.
|
||||||
|
|
||||||
### `createFromBytes(buf)`
|
### `createFromBytes(buf)`
|
||||||
|
|
||||||
Creates a Peer ID from a buffer representing the key's multihash.
|
Creates a Peer ID from a buffer representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId`.
|
||||||
|
|
||||||
### `createFromB58String(str)`
|
### `createFromB58String(str)`
|
||||||
|
|
||||||
Creates a Peer ID from a Base58 string representing the key's multihash.
|
Creates a Peer ID from a Base58 string representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId`.
|
||||||
|
|
||||||
### `createFromPubKey(pubKey)`
|
### `createFromPubKey(pubKey)`
|
||||||
|
|
||||||
- `publicKey: Buffer`
|
- `publicKey: Buffer`
|
||||||
|
|
||||||
Creates a Peer ID from a buffer containing a public key.
|
Creates a Peer ID from a buffer containing a public key.
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
### `createFromPrivKey(privKey)`
|
### `createFromPrivKey(privKey)`
|
||||||
|
|
||||||
- `privKey: Buffer`
|
- `privKey: Buffer`
|
||||||
|
|
||||||
Creates a Peer ID from a buffer containing a private key.
|
Creates a Peer ID from a buffer containing a private key.
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
### `createFromJSON(obj)`
|
### `createFromJSON(obj)`
|
||||||
|
|
||||||
- `obj.id: String` - The multihash encoded in `base58`
|
- `obj.id: String` - The multihash encoded in `base58`
|
||||||
- `obj.pubKey: String` - The public key in protobuf format, encoded in 'base64'
|
- `obj.pubKey: String` - The public key in protobuf format, encoded in `base64`
|
||||||
- `obj.privKey: String` - The private key in protobuf format, encoded in 'base 64'
|
- `obj.privKey: String` - The private key in protobuf format, encoded in `base64`
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
|
### `createFromProtobuf(buf)`
|
||||||
|
|
||||||
|
`buf` is a protocol-buffers encoded PeerId (see `marshal()`)
|
||||||
|
|
||||||
## Export
|
## Export
|
||||||
|
|
||||||
@ -198,11 +213,19 @@ Returns an `obj` of the form
|
|||||||
- `obj.pubKey: String` - The public key in protobuf format, encoded in 'base64'
|
- `obj.pubKey: String` - The public key in protobuf format, encoded in 'base64'
|
||||||
- `obj.privKey: String` - The private key in protobuf format, encoded in 'base 64'
|
- `obj.privKey: String` - The private key in protobuf format, encoded in 'base 64'
|
||||||
|
|
||||||
|
### `marshal(excludePrivatKey)`
|
||||||
|
|
||||||
|
Returns a protocol-buffers encoded version of the id, public key and, if `excludePrivateKey` is not set, the private key.
|
||||||
|
|
||||||
### `toPrint()`
|
### `toPrint()`
|
||||||
|
|
||||||
Alias for `.toJSON()`.
|
Returns the Peer ID as a printable string without the `Qm` prefix.
|
||||||
|
|
||||||
|
Example: `<peer.ID xxxxxx>`
|
||||||
|
|
||||||
|
### `isEqual(id)`
|
||||||
|
|
||||||
|
- `id` can be a PeerId or a Buffer containing the id
|
||||||
|
|
||||||
# License
|
# License
|
||||||
|
|
||||||
|
12
circle.yml
12
circle.yml
@ -1,12 +0,0 @@
|
|||||||
machine:
|
|
||||||
node:
|
|
||||||
version: stable
|
|
||||||
|
|
||||||
dependencies:
|
|
||||||
pre:
|
|
||||||
- google-chrome --version
|
|
||||||
- wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | sudo apt-key add -
|
|
||||||
- sudo sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google.list'
|
|
||||||
- sudo apt-get update
|
|
||||||
- sudo apt-get --only-upgrade install google-chrome-stable
|
|
||||||
- google-chrome --version
|
|
65
package.json
65
package.json
@ -1,59 +1,76 @@
|
|||||||
{
|
{
|
||||||
"name": "peer-id",
|
"name": "peer-id",
|
||||||
"version": "0.8.0",
|
"version": "0.13.3",
|
||||||
"description": "IPFS Peer Id implementation in Node.js",
|
"description": "IPFS Peer Id implementation in Node.js",
|
||||||
|
"leadMaintainer": "Vasco Santos <santos.vasco10@gmail.com>",
|
||||||
"main": "src/index.js",
|
"main": "src/index.js",
|
||||||
"bin": "src/bin.js",
|
"bin": "src/bin.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "aegir-lint",
|
"lint": "aegir lint",
|
||||||
"build": "aegir-build",
|
"build": "aegir build",
|
||||||
"test": "aegir-test",
|
"test": "aegir test",
|
||||||
"test:node": "aegir-test node",
|
"test:node": "aegir test -t node",
|
||||||
"test:browser": "aegir-test browser",
|
"test:browser": "aegir test -t browser -t webworker",
|
||||||
"release": "aegir-release",
|
"release": "aegir release",
|
||||||
"release-minor": "aegir-release --type minor",
|
"release-minor": "aegir release --type minor",
|
||||||
"release-major": "aegir-release --type major",
|
"release-major": "aegir release --type major",
|
||||||
"coverage": "aegir-coverage",
|
"coverage": "aegir coverage",
|
||||||
"coverage-publish": "aegir-coverage publish"
|
"size": "bundlesize -f dist/index.min.js -s 140kB"
|
||||||
},
|
},
|
||||||
|
"files": [
|
||||||
|
"src",
|
||||||
|
"dist"
|
||||||
|
],
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"IPFS"
|
"IPFS"
|
||||||
],
|
],
|
||||||
"author": "David Dias <daviddias@ipfs.io>",
|
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"pre-commit": [
|
|
||||||
"lint",
|
|
||||||
"test"
|
|
||||||
],
|
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=4.0.0"
|
"node": ">=10.0.0",
|
||||||
|
"npm": ">=6.0.0"
|
||||||
},
|
},
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/libp2p/js-peer-id/issues"
|
"url": "https://github.com/libp2p/js-peer-id/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/libp2p/js-peer-id",
|
"homepage": "https://github.com/libp2p/js-peer-id",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"aegir": "^9.1.2",
|
"aegir": "^20.0.0",
|
||||||
"chai": "^3.5.0",
|
"bundlesize": "~0.18.0",
|
||||||
"pre-commit": "^1.1.3"
|
"chai": "^4.2.0",
|
||||||
|
"dirty-chai": "^2.0.1"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"async": "^2.0.1",
|
"class-is": "^1.1.0",
|
||||||
"libp2p-crypto": "^0.7.0",
|
"libp2p-crypto": "~0.17.0",
|
||||||
"multihashes": "^0.3.0"
|
"multihashes": "~0.4.15",
|
||||||
|
"protons": "^1.0.1"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/libp2p/js-peer-id.git"
|
"url": "https://github.com/libp2p/js-peer-id.git"
|
||||||
},
|
},
|
||||||
"contributors": [
|
"contributors": [
|
||||||
|
"Arve Knudsen <arve.knudsen@gmail.com>",
|
||||||
"David Dias <daviddias.p@gmail.com>",
|
"David Dias <daviddias.p@gmail.com>",
|
||||||
"David Dias <mail@daviddias.me>",
|
"David Dias <mail@daviddias.me>",
|
||||||
"Friedel Ziegelmayer <dignifiedquire@gmail.com>",
|
"Friedel Ziegelmayer <dignifiedquire@gmail.com>",
|
||||||
|
"Henrique Dias <hacdias@gmail.com>",
|
||||||
|
"Hugo Dias <hugomrdias@gmail.com>",
|
||||||
|
"Jacob Heun <jacobheun@gmail.com>",
|
||||||
|
"Maciej Krüger <mkg20001@gmail.com>",
|
||||||
|
"Michael Garvin <gar+gh@danger.computer>",
|
||||||
|
"Pedro Teixeira <i@pgte.me>",
|
||||||
|
"Prashanth Chandra <coolshanth94@gmail.com>",
|
||||||
"Richard Littauer <richard.littauer@gmail.com>",
|
"Richard Littauer <richard.littauer@gmail.com>",
|
||||||
|
"Richard Schneider <makaretu@gmail.com>",
|
||||||
"Stephen Whitmore <stephen.whitmore@gmail.com>",
|
"Stephen Whitmore <stephen.whitmore@gmail.com>",
|
||||||
|
"Topper Bowers <topper@quorumcontrol.com>",
|
||||||
|
"Vasco Santos <vasco.santos@moxy.studio>",
|
||||||
|
"Vasco Santos <vasco.santos@ua.pt>",
|
||||||
|
"Yahya <ya7yaz@gmail.com>",
|
||||||
"greenkeeperio-bot <support@greenkeeper.io>",
|
"greenkeeperio-bot <support@greenkeeper.io>",
|
||||||
"nginnever <ginneversource@gmail.com>",
|
"nginnever <ginneversource@gmail.com>",
|
||||||
"npmcdn-to-unpkg-bot <npmcdn-to-unpkg-bot@users.noreply.github.com>"
|
"npmcdn-to-unpkg-bot <npmcdn-to-unpkg-bot@users.noreply.github.com>",
|
||||||
|
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>"
|
||||||
]
|
]
|
||||||
}
|
}
|
@ -4,10 +4,9 @@
|
|||||||
|
|
||||||
const PeerId = require('./index.js')
|
const PeerId = require('./index.js')
|
||||||
|
|
||||||
PeerId.create((err, id) => {
|
async function main () {
|
||||||
if (err) {
|
const id = await PeerId.create()
|
||||||
throw err
|
console.log(JSON.stringify(id.toJSON(), null, 2)) // eslint-disable-line no-console
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log(JSON.stringify(id.toJSON(), null, 2))
|
main()
|
||||||
})
|
|
||||||
|
286
src/index.js
286
src/index.js
@ -5,9 +5,10 @@
|
|||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
const mh = require('multihashes')
|
const mh = require('multihashes')
|
||||||
const crypto = require('libp2p-crypto')
|
const cryptoKeys = require('libp2p-crypto/src/keys')
|
||||||
const assert = require('assert')
|
const assert = require('assert')
|
||||||
const waterfall = require('async/waterfall')
|
const withIs = require('class-is')
|
||||||
|
const { PeerIdProto } = require('./proto')
|
||||||
|
|
||||||
class PeerId {
|
class PeerId {
|
||||||
constructor (id, privKey, pubKey) {
|
constructor (id, privKey, pubKey) {
|
||||||
@ -17,51 +18,92 @@ class PeerId {
|
|||||||
assert(privKey.public.bytes.equals(pubKey.bytes), 'inconsistent arguments')
|
assert(privKey.public.bytes.equals(pubKey.bytes), 'inconsistent arguments')
|
||||||
}
|
}
|
||||||
|
|
||||||
this.id = id
|
this._id = id
|
||||||
|
this._idB58String = mh.toB58String(this.id)
|
||||||
this._privKey = privKey
|
this._privKey = privKey
|
||||||
this._pubKey = pubKey
|
this._pubKey = pubKey
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get id () {
|
||||||
|
return this._id
|
||||||
|
}
|
||||||
|
|
||||||
|
set id (val) {
|
||||||
|
throw new Error('Id is immutable')
|
||||||
|
}
|
||||||
|
|
||||||
get privKey () {
|
get privKey () {
|
||||||
return this._privKey
|
return this._privKey
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set privKey (privKey) {
|
||||||
|
this._privKey = privKey
|
||||||
|
}
|
||||||
|
|
||||||
get pubKey () {
|
get pubKey () {
|
||||||
if (this._pubKey) {
|
if (this._pubKey) {
|
||||||
return this._pubKey
|
return this._pubKey
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.privKey) {
|
if (this._privKey) {
|
||||||
return this.privKey.public
|
return this._privKey.public
|
||||||
|
}
|
||||||
|
|
||||||
|
const decoded = mh.decode(this.id)
|
||||||
|
|
||||||
|
if (decoded.name === 'identity') {
|
||||||
|
this._pubKey = cryptoKeys.unmarshalPublicKey(decoded.digest)
|
||||||
|
return this._pubKey
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the protobuf version of the public key,
|
set pubKey (pubKey) {
|
||||||
// matching go ipfs formatting
|
this._pubKey = pubKey
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the protobuf version of the public key, matching go ipfs formatting
|
||||||
marshalPubKey () {
|
marshalPubKey () {
|
||||||
if (this.pubKey) {
|
if (this.pubKey) {
|
||||||
return crypto.marshalPublicKey(this.pubKey)
|
return cryptoKeys.marshalPublicKey(this.pubKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the protobuf version of the private key,
|
// Return the protobuf version of the private key, matching go ipfs formatting
|
||||||
// matching go ipfs formatting
|
|
||||||
marshalPrivKey () {
|
marshalPrivKey () {
|
||||||
if (this.privKey) {
|
if (this.privKey) {
|
||||||
return crypto.marshalPrivateKey(this.privKey)
|
return cryptoKeys.marshalPrivateKey(this.privKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// pretty print
|
// Return the protobuf version of the peer-id
|
||||||
|
marshal (excludePriv) {
|
||||||
|
return PeerIdProto.encode({
|
||||||
|
id: this.toBytes(),
|
||||||
|
pubKey: this.marshalPubKey(),
|
||||||
|
privKey: excludePriv ? null : this.marshalPrivKey()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
toPrint () {
|
toPrint () {
|
||||||
return this.toJSON()
|
let pid = this.toB58String()
|
||||||
|
// All sha256 nodes start with Qm
|
||||||
|
// We can skip the Qm to make the peer.ID more useful
|
||||||
|
if (pid.startsWith('Qm')) {
|
||||||
|
pid = pid.slice(2)
|
||||||
|
}
|
||||||
|
let maxRunes = 6
|
||||||
|
if (pid.length < maxRunes) {
|
||||||
|
maxRunes = pid.length
|
||||||
|
}
|
||||||
|
|
||||||
|
return '<peer.ID ' + pid.substr(0, maxRunes) + '>'
|
||||||
}
|
}
|
||||||
|
|
||||||
// return the jsonified version of the key, matching the formatting
|
// return the jsonified version of the key, matching the formatting
|
||||||
// of go-ipfs for its config file
|
// of go-ipfs for its config file
|
||||||
toJSON () {
|
toJSON () {
|
||||||
return {
|
return {
|
||||||
id: mh.toB58String(this.id),
|
id: this.toB58String(),
|
||||||
privKey: toB64Opt(this.marshalPrivKey()),
|
privKey: toB64Opt(this.marshalPrivKey()),
|
||||||
pubKey: toB64Opt(this.marshalPubKey())
|
pubKey: toB64Opt(this.marshalPubKey())
|
||||||
}
|
}
|
||||||
@ -77,137 +119,183 @@ class PeerId {
|
|||||||
}
|
}
|
||||||
|
|
||||||
toB58String () {
|
toB58String () {
|
||||||
return mh.toB58String(this.id)
|
return this._idB58String
|
||||||
|
}
|
||||||
|
|
||||||
|
isEqual (id) {
|
||||||
|
if (Buffer.isBuffer(id)) {
|
||||||
|
return this.id.equals(id)
|
||||||
|
} else if (id.id) {
|
||||||
|
return this.id.equals(id.id)
|
||||||
|
} else {
|
||||||
|
throw new Error('not valid Id')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exports = module.exports = PeerId
|
/*
|
||||||
exports.Buffer = Buffer
|
* Check if this PeerId instance is valid (privKey -> pubKey -> Id)
|
||||||
|
*/
|
||||||
|
isValid () {
|
||||||
|
// TODO: needs better checking
|
||||||
|
return Boolean(this.privKey &&
|
||||||
|
this.privKey.public &&
|
||||||
|
this.privKey.public.bytes &&
|
||||||
|
Buffer.isBuffer(this.pubKey.bytes) &&
|
||||||
|
this.privKey.public.bytes.equals(this.pubKey.bytes))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const PeerIdWithIs = withIs(PeerId, {
|
||||||
|
className: 'PeerId',
|
||||||
|
symbolName: '@libp2p/js-peer-id/PeerId'
|
||||||
|
})
|
||||||
|
|
||||||
|
exports = module.exports = PeerIdWithIs
|
||||||
|
|
||||||
|
const computeDigest = (pubKey) => {
|
||||||
|
if (pubKey.bytes.length <= 42) {
|
||||||
|
return mh.encode(pubKey.bytes, 'identity')
|
||||||
|
} else {
|
||||||
|
return pubKey.hash()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const computePeerId = async (privKey, pubKey) => {
|
||||||
|
const digest = await computeDigest(pubKey)
|
||||||
|
return new PeerIdWithIs(digest, privKey, pubKey)
|
||||||
|
}
|
||||||
|
|
||||||
// generation
|
// generation
|
||||||
exports.create = function (opts, callback) {
|
exports.create = async (opts) => {
|
||||||
if (typeof opts === 'function') {
|
|
||||||
callback = opts
|
|
||||||
opts = {}
|
|
||||||
}
|
|
||||||
opts = opts || {}
|
opts = opts || {}
|
||||||
opts.bits = opts.bits || 2048
|
opts.bits = opts.bits || 2048
|
||||||
|
opts.keyType = opts.keyType || 'RSA'
|
||||||
|
|
||||||
waterfall([
|
const key = await cryptoKeys.generateKeyPair(opts.keyType, opts.bits)
|
||||||
(cb) => crypto.generateKeyPair('RSA', opts.bits, cb),
|
return computePeerId(key, key.public)
|
||||||
(privKey, cb) => privKey.public.hash((err, digest) => {
|
|
||||||
cb(err, digest, privKey)
|
|
||||||
})
|
|
||||||
], (err, digest, privKey) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, new PeerId(digest, privKey))
|
exports.createFromHexString = (str) => {
|
||||||
})
|
return new PeerIdWithIs(mh.fromHexString(str))
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromHexString = function (str) {
|
exports.createFromBytes = (buf) => {
|
||||||
return new PeerId(mh.fromHexString(str))
|
return new PeerIdWithIs(buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromBytes = function (buf) {
|
exports.createFromB58String = (str) => {
|
||||||
return new PeerId(buf)
|
return new PeerIdWithIs(mh.fromB58String(str))
|
||||||
}
|
|
||||||
|
|
||||||
exports.createFromB58String = function (str) {
|
|
||||||
return new PeerId(mh.fromB58String(str))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public Key input will be a buffer
|
// Public Key input will be a buffer
|
||||||
exports.createFromPubKey = function (key, callback) {
|
exports.createFromPubKey = async (key) => {
|
||||||
let buf = key
|
let buf = key
|
||||||
|
|
||||||
if (typeof buf === 'string') {
|
if (typeof buf === 'string') {
|
||||||
buf = new Buffer(key, 'base64')
|
buf = Buffer.from(key, 'base64')
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof callback !== 'function') {
|
if (!Buffer.isBuffer(buf)) {
|
||||||
throw new Error('callback is required')
|
throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
}
|
}
|
||||||
|
|
||||||
const pubKey = crypto.unmarshalPublicKey(buf)
|
const pubKey = await cryptoKeys.unmarshalPublicKey(buf)
|
||||||
pubKey.hash((err, digest) => {
|
return computePeerId(null, pubKey)
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
callback(null, new PeerId(digest, null, pubKey))
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Private key input will be a string
|
// Private key input will be a string
|
||||||
exports.createFromPrivKey = function (key, callback) {
|
exports.createFromPrivKey = async (key) => {
|
||||||
let buf = key
|
let buf = key
|
||||||
|
|
||||||
if (typeof buf === 'string') {
|
if (typeof buf === 'string') {
|
||||||
buf = new Buffer(key, 'base64')
|
buf = Buffer.from(key, 'base64')
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof callback !== 'function') {
|
if (!Buffer.isBuffer(buf)) {
|
||||||
throw new Error('callback is required')
|
throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
}
|
}
|
||||||
|
|
||||||
waterfall([
|
const privKey = await cryptoKeys.unmarshalPrivateKey(buf)
|
||||||
(cb) => crypto.unmarshalPrivateKey(buf, cb),
|
return computePeerId(privKey, privKey.public)
|
||||||
(privKey, cb) => privKey.public.hash((err, digest) => {
|
|
||||||
cb(err, digest, privKey)
|
|
||||||
})
|
|
||||||
], (err, digest, privKey) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
callback(null, new PeerId(digest, privKey))
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
exports.createFromJSON = function (obj, callback) {
|
|
||||||
if (typeof callback !== 'function') {
|
|
||||||
throw new Error('callback is required')
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
exports.createFromJSON = async (obj) => {
|
||||||
const id = mh.fromB58String(obj.id)
|
const id = mh.fromB58String(obj.id)
|
||||||
const rawPrivKey = obj.privKey && new Buffer(obj.privKey, 'base64')
|
const rawPrivKey = obj.privKey && Buffer.from(obj.privKey, 'base64')
|
||||||
const rawPubKey = obj.pubKey && new Buffer(obj.pubKey, 'base64')
|
const rawPubKey = obj.pubKey && Buffer.from(obj.pubKey, 'base64')
|
||||||
const pub = rawPubKey && crypto.unmarshalPublicKey(rawPubKey)
|
const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey)
|
||||||
|
|
||||||
|
if (!rawPrivKey) {
|
||||||
|
return new PeerIdWithIs(id, null, pub)
|
||||||
|
}
|
||||||
|
|
||||||
|
const privKey = await cryptoKeys.unmarshalPrivateKey(rawPrivKey)
|
||||||
|
const privDigest = await computeDigest(privKey.public)
|
||||||
|
|
||||||
|
let pubDigest
|
||||||
|
|
||||||
if (rawPrivKey) {
|
|
||||||
waterfall([
|
|
||||||
(cb) => crypto.unmarshalPrivateKey(rawPrivKey, cb),
|
|
||||||
(priv, cb) => priv.public.hash((err, digest) => {
|
|
||||||
cb(err, digest, priv)
|
|
||||||
}),
|
|
||||||
(privDigest, priv, cb) => {
|
|
||||||
if (pub) {
|
if (pub) {
|
||||||
pub.hash((err, pubDigest) => {
|
pubDigest = await computeDigest(pub)
|
||||||
cb(err, privDigest, priv, pubDigest)
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
cb(null, privDigest, priv)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
], (err, privDigest, priv, pubDigest) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pub && !privDigest.equals(pubDigest)) {
|
if (pub && !privDigest.equals(pubDigest)) {
|
||||||
return callback(new Error('Public and private key do not match'))
|
throw new Error('Public and private key do not match')
|
||||||
}
|
}
|
||||||
|
|
||||||
if (id && !privDigest.equals(id)) {
|
if (id && !privDigest.equals(id)) {
|
||||||
return callback(new Error('Id and private key do not match'))
|
throw new Error('Id and private key do not match')
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, new PeerId(id, priv, pub))
|
return new PeerIdWithIs(id, privKey, pub)
|
||||||
})
|
|
||||||
} else {
|
|
||||||
callback(null, new PeerId(id, null, pub))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
exports.createFromProtobuf = async (buf) => {
|
||||||
|
if (typeof buf === 'string') {
|
||||||
|
buf = Buffer.from(buf, 'hex')
|
||||||
|
}
|
||||||
|
|
||||||
|
let { id, privKey, pubKey } = PeerIdProto.decode(buf)
|
||||||
|
|
||||||
|
privKey = privKey ? await cryptoKeys.unmarshalPrivateKey(privKey) : false
|
||||||
|
pubKey = pubKey ? await cryptoKeys.unmarshalPublicKey(pubKey) : false
|
||||||
|
|
||||||
|
let pubDigest
|
||||||
|
let privDigest
|
||||||
|
|
||||||
|
if (privKey) {
|
||||||
|
privDigest = await computeDigest(privKey.public)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pubKey) {
|
||||||
|
pubDigest = await computeDigest(pubKey)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (privKey) {
|
||||||
|
if (pubKey) {
|
||||||
|
if (!privDigest.equals(pubDigest)) {
|
||||||
|
throw new Error('Public and private key do not match')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new PeerIdWithIs(privDigest, privKey, privKey.public)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: val id and pubDigest
|
||||||
|
|
||||||
|
if (pubKey) {
|
||||||
|
return new PeerIdWithIs(pubDigest, null, pubKey)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id) {
|
||||||
|
return new PeerIdWithIs(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Error('Protobuf did not contain any usable key material')
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.isPeerId = (peerId) => {
|
||||||
|
return Boolean(typeof peerId === 'object' &&
|
||||||
|
peerId._id &&
|
||||||
|
peerId._idB58String)
|
||||||
}
|
}
|
||||||
|
|
||||||
function toB64Opt (val) {
|
function toB64Opt (val) {
|
||||||
|
12
src/proto.js
Normal file
12
src/proto.js
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
'use strict'
|
||||||
|
|
||||||
|
const protons = require('protons')
|
||||||
|
module.exports = protons(`
|
||||||
|
|
||||||
|
message PeerIdProto {
|
||||||
|
required bytes id = 1;
|
||||||
|
bytes pubKey = 2;
|
||||||
|
bytes privKey = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
`)
|
3
test/fixtures/sample-id.js
vendored
3
test/fixtures/sample-id.js
vendored
@ -3,5 +3,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
id: '122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a9',
|
id: '122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a9',
|
||||||
privKey: 'CAASpgkwggSiAgEAAoIBAQC2SKo/HMFZeBml1AF3XijzrxrfQXdJzjePBZAbdxqKR1Mc6juRHXij6HXYPjlAk01BhF1S3Ll4Lwi0cAHhggf457sMg55UWyeGKeUv0ucgvCpBwlR5cQ020i0MgzjPWOLWq1rtvSbNcAi2ZEVn6+Q2EcHo3wUvWRtLeKz+DZSZfw2PEDC+DGPJPl7f8g7zl56YymmmzH9liZLNrzg/qidokUv5u1pdGrcpLuPNeTODk0cqKB+OUbuKj9GShYECCEjaybJDl9276oalL9ghBtSeEv20kugatTvYy590wFlJkkvyl+nPxIH0EEYMKK9XRWlu9XYnoSfboiwcv8M3SlsjAgMBAAECggEAZtju/bcKvKFPz0mkHiaJcpycy9STKphorpCT83srBVQi59CdFU6Mj+aL/xt0kCPMVigJw8P3/YCEJ9J+rS8BsoWE+xWUEsJvtXoT7vzPHaAtM3ci1HZd302Mz1+GgS8Epdx+7F5p80XAFLDUnELzOzKftvWGZmWfSeDnslwVONkL/1VAzwKy7Ce6hk4SxRE7l2NE2OklSHOzCGU1f78ZzVYKSnS5Ag9YrGjOAmTOXDbKNKN/qIorAQ1bovzGoCwx3iGIatQKFOxyVCyO1PsJYT7JO+kZbhBWRRE+L7l+ppPER9bdLFxs1t5CrKc078h+wuUr05S1P1JjXk68pk3+kQKBgQDeK8AR11373Mzib6uzpjGzgNRMzdYNuExWjxyxAzz53NAR7zrPHvXvfIqjDScLJ4NcRO2TddhXAfZoOPVH5k4PJHKLBPKuXZpWlookCAyENY7+Pd55S8r+a+MusrMagYNljb5WbVTgN8cgdpim9lbbIFlpN6SZaVjLQL3J8TWH6wKBgQDSChzItkqWX11CNstJ9zJyUE20I7LrpyBJNgG1gtvz3ZMUQCn3PxxHtQzN9n1P0mSSYs+jBKPuoSyYLt1wwe10/lpgL4rkKWU3/m1Myt0tveJ9WcqHh6tzcAbb/fXpUFT/o4SWDimWkPkuCb+8j//2yiXk0a/T2f36zKMuZvujqQKBgC6B7BAQDG2H2B/ijofp12ejJU36nL98gAZyqOfpLJ+FeMz4TlBDQ+phIMhnHXA5UkdDapQ+zA3SrFk+6yGk9Vw4Hf46B+82SvOrSbmnMa+PYqKYIvUzR4gg34rL/7AhwnbEyD5hXq4dHwMNsIDq+l2elPjwm/U9V0gdAl2+r50HAoGALtsKqMvhv8HucAMBPrLikhXP/8um8mMKFMrzfqZ+otxfHzlhI0L08Bo3jQrb0Z7ByNY6M8epOmbCKADsbWcVre/AAY0ZkuSZK/CaOXNX/AhMKmKJh8qAOPRY02LIJRBCpfS4czEdnfUhYV/TYiFNnKRj57PPYZdTzUsxa/yVTmECgYBr7slQEjb5Onn5mZnGDh+72BxLNdgwBkhO0OCdpdISqk0F0Pxby22DFOKXZEpiyI9XYP1C8wPiJsShGm2yEwBPWXnrrZNWczaVuCbXHrZkWQogBDG3HGXNdU4MAWCyiYlyinIBpPpoAJZSzpGLmWbMWh28+RJS6AQX6KHrK1o2uw==',
|
privKey: 'CAASpgkwggSiAgEAAoIBAQC2SKo/HMFZeBml1AF3XijzrxrfQXdJzjePBZAbdxqKR1Mc6juRHXij6HXYPjlAk01BhF1S3Ll4Lwi0cAHhggf457sMg55UWyeGKeUv0ucgvCpBwlR5cQ020i0MgzjPWOLWq1rtvSbNcAi2ZEVn6+Q2EcHo3wUvWRtLeKz+DZSZfw2PEDC+DGPJPl7f8g7zl56YymmmzH9liZLNrzg/qidokUv5u1pdGrcpLuPNeTODk0cqKB+OUbuKj9GShYECCEjaybJDl9276oalL9ghBtSeEv20kugatTvYy590wFlJkkvyl+nPxIH0EEYMKK9XRWlu9XYnoSfboiwcv8M3SlsjAgMBAAECggEAZtju/bcKvKFPz0mkHiaJcpycy9STKphorpCT83srBVQi59CdFU6Mj+aL/xt0kCPMVigJw8P3/YCEJ9J+rS8BsoWE+xWUEsJvtXoT7vzPHaAtM3ci1HZd302Mz1+GgS8Epdx+7F5p80XAFLDUnELzOzKftvWGZmWfSeDnslwVONkL/1VAzwKy7Ce6hk4SxRE7l2NE2OklSHOzCGU1f78ZzVYKSnS5Ag9YrGjOAmTOXDbKNKN/qIorAQ1bovzGoCwx3iGIatQKFOxyVCyO1PsJYT7JO+kZbhBWRRE+L7l+ppPER9bdLFxs1t5CrKc078h+wuUr05S1P1JjXk68pk3+kQKBgQDeK8AR11373Mzib6uzpjGzgNRMzdYNuExWjxyxAzz53NAR7zrPHvXvfIqjDScLJ4NcRO2TddhXAfZoOPVH5k4PJHKLBPKuXZpWlookCAyENY7+Pd55S8r+a+MusrMagYNljb5WbVTgN8cgdpim9lbbIFlpN6SZaVjLQL3J8TWH6wKBgQDSChzItkqWX11CNstJ9zJyUE20I7LrpyBJNgG1gtvz3ZMUQCn3PxxHtQzN9n1P0mSSYs+jBKPuoSyYLt1wwe10/lpgL4rkKWU3/m1Myt0tveJ9WcqHh6tzcAbb/fXpUFT/o4SWDimWkPkuCb+8j//2yiXk0a/T2f36zKMuZvujqQKBgC6B7BAQDG2H2B/ijofp12ejJU36nL98gAZyqOfpLJ+FeMz4TlBDQ+phIMhnHXA5UkdDapQ+zA3SrFk+6yGk9Vw4Hf46B+82SvOrSbmnMa+PYqKYIvUzR4gg34rL/7AhwnbEyD5hXq4dHwMNsIDq+l2elPjwm/U9V0gdAl2+r50HAoGALtsKqMvhv8HucAMBPrLikhXP/8um8mMKFMrzfqZ+otxfHzlhI0L08Bo3jQrb0Z7ByNY6M8epOmbCKADsbWcVre/AAY0ZkuSZK/CaOXNX/AhMKmKJh8qAOPRY02LIJRBCpfS4czEdnfUhYV/TYiFNnKRj57PPYZdTzUsxa/yVTmECgYBr7slQEjb5Onn5mZnGDh+72BxLNdgwBkhO0OCdpdISqk0F0Pxby22DFOKXZEpiyI9XYP1C8wPiJsShGm2yEwBPWXnrrZNWczaVuCbXHrZkWQogBDG3HGXNdU4MAWCyiYlyinIBpPpoAJZSzpGLmWbMWh28+RJS6AQX6KHrK1o2uw==',
|
||||||
pubKey: 'CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC2SKo/HMFZeBml1AF3XijzrxrfQXdJzjePBZAbdxqKR1Mc6juRHXij6HXYPjlAk01BhF1S3Ll4Lwi0cAHhggf457sMg55UWyeGKeUv0ucgvCpBwlR5cQ020i0MgzjPWOLWq1rtvSbNcAi2ZEVn6+Q2EcHo3wUvWRtLeKz+DZSZfw2PEDC+DGPJPl7f8g7zl56YymmmzH9liZLNrzg/qidokUv5u1pdGrcpLuPNeTODk0cqKB+OUbuKj9GShYECCEjaybJDl9276oalL9ghBtSeEv20kugatTvYy590wFlJkkvyl+nPxIH0EEYMKK9XRWlu9XYnoSfboiwcv8M3SlsjAgMBAAE='
|
pubKey: 'CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC2SKo/HMFZeBml1AF3XijzrxrfQXdJzjePBZAbdxqKR1Mc6juRHXij6HXYPjlAk01BhF1S3Ll4Lwi0cAHhggf457sMg55UWyeGKeUv0ucgvCpBwlR5cQ020i0MgzjPWOLWq1rtvSbNcAi2ZEVn6+Q2EcHo3wUvWRtLeKz+DZSZfw2PEDC+DGPJPl7f8g7zl56YymmmzH9liZLNrzg/qidokUv5u1pdGrcpLuPNeTODk0cqKB+OUbuKj9GShYECCEjaybJDl9276oalL9ghBtSeEv20kugatTvYy590wFlJkkvyl+nPxIH0EEYMKK9XRWlu9XYnoSfboiwcv8M3SlsjAgMBAAE=',
|
||||||
|
marshaled: '0a22122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a912ab02080012a60230820122300d06092a864886f70d01010105000382010f003082010a0282010100b648aa3f1cc1597819a5d401775e28f3af1adf417749ce378f05901b771a8a47531cea3b911d78a3e875d83e3940934d41845d52dcb9782f08b47001e18207f8e7bb0c839e545b278629e52fd2e720bc2a41c25479710d36d22d0c8338cf58e2d6ab5aedbd26cd7008b6644567ebe43611c1e8df052f591b4b78acfe0d94997f0d8f1030be0c63c93e5edff20ef3979e98ca69a6cc7f658992cdaf383faa2768914bf9bb5a5d1ab7292ee3cd79338393472a281f8e51bb8a8fd1928581020848dac9b24397ddbbea86a52fd82106d49e12fdb492e81ab53bd8cb9f74c05949924bf297e9cfc481f410460c28af5745696ef57627a127dba22c1cbfc3374a5b2302030100011aab09080012a609308204a20201000282010100b648aa3f1cc1597819a5d401775e28f3af1adf417749ce378f05901b771a8a47531cea3b911d78a3e875d83e3940934d41845d52dcb9782f08b47001e18207f8e7bb0c839e545b278629e52fd2e720bc2a41c25479710d36d22d0c8338cf58e2d6ab5aedbd26cd7008b6644567ebe43611c1e8df052f591b4b78acfe0d94997f0d8f1030be0c63c93e5edff20ef3979e98ca69a6cc7f658992cdaf383faa2768914bf9bb5a5d1ab7292ee3cd79338393472a281f8e51bb8a8fd1928581020848dac9b24397ddbbea86a52fd82106d49e12fdb492e81ab53bd8cb9f74c05949924bf297e9cfc481f410460c28af5745696ef57627a127dba22c1cbfc3374a5b2302030100010282010066d8eefdb70abca14fcf49a41e2689729c9ccbd4932a9868ae9093f37b2b055422e7d09d154e8c8fe68bff1b749023cc562809c3c3f7fd808427d27ead2f01b28584fb159412c26fb57a13eefccf1da02d337722d4765ddf4d8ccf5f86812f04a5dc7eec5e69f345c014b0d49c42f33b329fb6f58666659f49e0e7b25c1538d90bff5540cf02b2ec27ba864e12c5113b976344d8e9254873b30865357fbf19cd560a4a74b9020f58ac68ce0264ce5c36ca34a37fa88a2b010d5ba2fcc6a02c31de21886ad40a14ec72542c8ed4fb09613ec93be9196e105645113e2fb97ea693c447d6dd2c5c6cd6de42aca734efc87ec2e52bd394b53f52635e4ebca64dfe9102818100de2bc011d75dfbdccce26fabb3a631b380d44ccdd60db84c568f1cb1033cf9dcd011ef3acf1ef5ef7c8aa30d270b27835c44ed9375d85701f66838f547e64e0f24728b04f2ae5d9a56968a24080c84358efe3dde794bcafe6be32eb2b31a8183658dbe566d54e037c7207698a6f656db20596937a4996958cb40bdc9f13587eb02818100d20a1cc8b64a965f5d4236cb49f73272504db423b2eba720493601b582dbf3dd93144029f73f1c47b50ccdf67d4fd2649262cfa304a3eea12c982edd70c1ed74fe5a602f8ae4296537fe6d4ccadd2dbde27d59ca8787ab737006dbfdf5e95054ffa384960e299690f92e09bfbc8ffff6ca25e4d1afd3d9fdfacca32e66fba3a90281802e81ec10100c6d87d81fe28e87e9d767a3254dfa9cbf7c800672a8e7e92c9f8578ccf84e504343ea6120c8671d70395247436a943ecc0dd2ac593eeb21a4f55c381dfe3a07ef364af3ab49b9a731af8f62a29822f533478820df8acbffb021c276c4c83e615eae1d1f030db080eafa5d9e94f8f09bf53d57481d025dbeaf9d070281802edb0aa8cbe1bfc1ee7003013eb2e29215cfffcba6f2630a14caf37ea67ea2dc5f1f39612342f4f01a378d0adbd19ec1c8d63a33c7a93a66c22800ec6d6715adefc0018d1992e4992bf09a397357fc084c2a628987ca8038f458d362c8251042a5f4b873311d9df521615fd362214d9ca463e7b3cf619753cd4b316bfc954e610281806beec9501236f93a79f99999c60e1fbbd81c4b35d83006484ed0e09da5d212aa4d05d0fc5bcb6d8314e297644a62c88f5760fd42f303e226c4a11a6db213004f5979ebad9356733695b826d71eb664590a200431b71c65cd754e0c0160b28989728a7201a4fa68009652ce918b9966cc5a1dbcf91252e80417e8a1eb2b5a36bb'
|
||||||
}
|
}
|
||||||
|
@ -1,225 +0,0 @@
|
|||||||
/* eslint max-nested-callbacks: ["error", 8] */
|
|
||||||
/* eslint-env mocha */
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
const expect = require('chai').expect
|
|
||||||
const crypto = require('libp2p-crypto')
|
|
||||||
const mh = require('multihashes')
|
|
||||||
const parallel = require('async/parallel')
|
|
||||||
|
|
||||||
const PeerId = require('../src')
|
|
||||||
|
|
||||||
const testId = require('./fixtures/sample-id')
|
|
||||||
const testIdHex = testId.id
|
|
||||||
const testIdBytes = mh.fromHexString(testId.id)
|
|
||||||
const testIdB58String = mh.toB58String(testIdBytes)
|
|
||||||
|
|
||||||
const goId = require('./fixtures/go-private-key')
|
|
||||||
|
|
||||||
describe('PeerId', () => {
|
|
||||||
it('create an id without \'new\'', () => {
|
|
||||||
expect(PeerId).to.throw(Error)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('create a new id', (done) => {
|
|
||||||
PeerId.create((err, id) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(id.toB58String().length).to.equal(46)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('recreate an Id from Hex string', () => {
|
|
||||||
const id = PeerId.createFromHexString(testIdHex)
|
|
||||||
expect(testIdBytes).to.deep.equal(id.id)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate an Id from a Buffer', () => {
|
|
||||||
const id = PeerId.createFromBytes(testIdBytes)
|
|
||||||
expect(testId.id).to.equal(id.toHexString())
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate a B58 String', () => {
|
|
||||||
const id = PeerId.createFromB58String(testIdB58String)
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate from a Public Key', (done) => {
|
|
||||||
PeerId.createFromPubKey(testId.pubKey, (err, id) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate from a Private Key', (done) => {
|
|
||||||
PeerId.createFromPrivKey(testId.privKey, (err, id) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
|
|
||||||
const encoded = new Buffer(testId.privKey, 'base64')
|
|
||||||
PeerId.createFromPrivKey(encoded, (err, id2) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(testIdB58String).to.equal(id2.toB58String())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Compare generated ID with one created from PubKey', (done) => {
|
|
||||||
PeerId.create((err, id1) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
|
|
||||||
PeerId.createFromPubKey(id1.marshalPubKey(), (err, id2) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(id1.id).to.be.eql(id2.id)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Non-default # of bits', (done) => {
|
|
||||||
PeerId.create({ bits: 1024 }, (err, shortId) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
PeerId.create({ bits: 4096 }, (err, longId) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(shortId.privKey.bytes.length).is.below(longId.privKey.bytes.length)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Pretty printing', (done) => {
|
|
||||||
PeerId.create((err, id1) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
PeerId.createFromPrivKey(id1.toPrint().privKey, (err, id2) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(id1.toPrint()).to.be.eql(id2.toPrint())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('toBytes', () => {
|
|
||||||
const id = PeerId.createFromHexString(testIdHex)
|
|
||||||
expect(id.toBytes().toString('hex')).to.equal(testIdBytes.toString('hex'))
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('fromJSON', () => {
|
|
||||||
it('full node', (done) => {
|
|
||||||
PeerId.create({bits: 1024}, (err, id) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
|
|
||||||
PeerId.createFromJSON(id.toJSON(), (err, other) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(
|
|
||||||
id.toB58String()
|
|
||||||
).to.equal(
|
|
||||||
other.toB58String()
|
|
||||||
)
|
|
||||||
expect(
|
|
||||||
id.privKey.bytes
|
|
||||||
).to.deep.equal(
|
|
||||||
other.privKey.bytes
|
|
||||||
)
|
|
||||||
expect(
|
|
||||||
id.pubKey.bytes
|
|
||||||
).to.deep.equal(
|
|
||||||
other.pubKey.bytes
|
|
||||||
)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('only id', (done) => {
|
|
||||||
crypto.generateKeyPair('RSA', 1024, (err, key) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
key.public.hash((err, digest) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
|
|
||||||
const id = PeerId.createFromBytes(digest)
|
|
||||||
expect(id.privKey).to.not.exist
|
|
||||||
expect(id.pubKey).to.not.exist
|
|
||||||
|
|
||||||
PeerId.createFromJSON(id.toJSON(), (err, other) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(
|
|
||||||
id.toB58String()
|
|
||||||
).to.equal(
|
|
||||||
other.toB58String()
|
|
||||||
)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('go interop', (done) => {
|
|
||||||
PeerId.createFromJSON(goId, (err, id) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
id.privKey.public.hash((err, digest) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(
|
|
||||||
mh.toB58String(digest)
|
|
||||||
).to.be.eql(
|
|
||||||
goId.id
|
|
||||||
)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('throws on inconsistent data', () => {
|
|
||||||
let k1, k2, k3
|
|
||||||
before((done) => {
|
|
||||||
parallel([
|
|
||||||
(cb) => crypto.generateKeyPair('RSA', 1024, cb),
|
|
||||||
(cb) => crypto.generateKeyPair('RSA', 1024, cb),
|
|
||||||
(cb) => crypto.generateKeyPair('RSA', 1024, cb)
|
|
||||||
], (err, keys) => {
|
|
||||||
if (err) {
|
|
||||||
return done(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
k1 = keys[0]
|
|
||||||
k2 = keys[1]
|
|
||||||
k3 = keys[2]
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('missmatch private - public key', (done) => {
|
|
||||||
k1.public.hash((err, digest) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(
|
|
||||||
() => new PeerId(digest, k1, k2.public)
|
|
||||||
).to.throw(
|
|
||||||
/inconsistent arguments/
|
|
||||||
)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('missmatch id - private - public key', (done) => {
|
|
||||||
k1.public.hash((err, digest) => {
|
|
||||||
expect(err).to.not.exist
|
|
||||||
expect(
|
|
||||||
() => new PeerId(digest, k1, k3.public)
|
|
||||||
).to.throw(
|
|
||||||
/inconsistent arguments/
|
|
||||||
)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
it('invalid id', () => {
|
|
||||||
expect(
|
|
||||||
() => new PeerId('hello world')
|
|
||||||
).to.throw(
|
|
||||||
/invalid id/
|
|
||||||
)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
269
test/peer-id.spec.js
Normal file
269
test/peer-id.spec.js
Normal file
@ -0,0 +1,269 @@
|
|||||||
|
/* eslint max-nested-callbacks: ["error", 8] */
|
||||||
|
/* eslint-env mocha */
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const chai = require('chai')
|
||||||
|
const dirtyChai = require('dirty-chai')
|
||||||
|
chai.use(dirtyChai)
|
||||||
|
const expect = chai.expect
|
||||||
|
const crypto = require('libp2p-crypto')
|
||||||
|
const mh = require('multihashes')
|
||||||
|
|
||||||
|
const PeerId = require('../src')
|
||||||
|
|
||||||
|
const util = require('util')
|
||||||
|
|
||||||
|
const testId = require('./fixtures/sample-id')
|
||||||
|
const testIdHex = testId.id
|
||||||
|
const testIdBytes = mh.fromHexString(testId.id)
|
||||||
|
const testIdB58String = mh.toB58String(testIdBytes)
|
||||||
|
|
||||||
|
const goId = require('./fixtures/go-private-key')
|
||||||
|
|
||||||
|
// Test options for making PeerId.create faster
|
||||||
|
// INSECURE, only use when testing
|
||||||
|
const testOpts = {
|
||||||
|
bits: 512
|
||||||
|
}
|
||||||
|
|
||||||
|
describe('PeerId', () => {
|
||||||
|
it('create an id without \'new\'', () => {
|
||||||
|
expect(PeerId).to.throw(Error)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('create a new id', async () => {
|
||||||
|
const id = await PeerId.create(testOpts)
|
||||||
|
expect(id.toB58String().length).to.equal(46)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can be created for a Secp256k1 key', async () => {
|
||||||
|
const id = await PeerId.create({ keyType: 'secp256k1', bits: 256 })
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can get the public key from a Secp256k1 key', async () => {
|
||||||
|
const original = await PeerId.create({ keyType: 'secp256k1', bits: 256 })
|
||||||
|
const newId = PeerId.createFromB58String(original.toB58String())
|
||||||
|
expect(original.pubKey.bytes).to.eql(newId.pubKey.bytes)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('isPeerId', async () => {
|
||||||
|
const id = await PeerId.create(testOpts)
|
||||||
|
expect(PeerId.isPeerId(id)).to.equal(true)
|
||||||
|
expect(PeerId.isPeerId('aaa')).to.equal(false)
|
||||||
|
expect(PeerId.isPeerId(Buffer.from('batatas'))).to.equal(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws on changing the id', async () => {
|
||||||
|
const id = await PeerId.create(testOpts)
|
||||||
|
expect(id.toB58String().length).to.equal(46)
|
||||||
|
expect(() => {
|
||||||
|
id.id = Buffer.from('hello')
|
||||||
|
}).to.throw(/immutable/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate an Id from Hex string', () => {
|
||||||
|
const id = PeerId.createFromHexString(testIdHex)
|
||||||
|
expect(testIdBytes).to.deep.equal(id.id)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Recreate an Id from a Buffer', () => {
|
||||||
|
const id = PeerId.createFromBytes(testIdBytes)
|
||||||
|
expect(testId.id).to.equal(id.toHexString())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Recreate a B58 String', () => {
|
||||||
|
const id = PeerId.createFromB58String(testIdB58String)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Recreate from a Public Key', async () => {
|
||||||
|
const id = await PeerId.createFromPubKey(testId.pubKey)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Recreate from a Private Key', async () => {
|
||||||
|
const id = await PeerId.createFromPrivKey(testId.privKey)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
const encoded = Buffer.from(testId.privKey, 'base64')
|
||||||
|
const id2 = await PeerId.createFromPrivKey(encoded)
|
||||||
|
expect(testIdB58String).to.equal(id2.toB58String())
|
||||||
|
expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Recreate from Protobuf', async () => {
|
||||||
|
const id = await PeerId.createFromProtobuf(testId.marshaled)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
const encoded = Buffer.from(testId.privKey, 'base64')
|
||||||
|
const id2 = await PeerId.createFromPrivKey(encoded)
|
||||||
|
expect(testIdB58String).to.equal(id2.toB58String())
|
||||||
|
expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey())
|
||||||
|
expect(id.marshal().toString('hex')).to.deep.equal(testId.marshaled)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can be created from a Secp256k1 public key', async () => {
|
||||||
|
const privKey = await crypto.keys.generateKeyPair('secp256k1', 256)
|
||||||
|
const id = await PeerId.createFromPubKey(privKey.public.bytes)
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can be created from a Secp256k1 private key', async () => {
|
||||||
|
const privKey = await crypto.keys.generateKeyPair('secp256k1', 256)
|
||||||
|
const id = await PeerId.createFromPrivKey(privKey.bytes)
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Compare generated ID with one created from PubKey', async () => {
|
||||||
|
const id1 = await PeerId.create(testOpts)
|
||||||
|
const id2 = await PeerId.createFromPubKey(id1.marshalPubKey())
|
||||||
|
expect(id1.id).to.be.eql(id2.id)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Works with default options', async function () {
|
||||||
|
this.timeout(10000)
|
||||||
|
const id = await PeerId.create()
|
||||||
|
expect(id.toB58String().length).to.equal(46)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Non-default # of bits', async function () {
|
||||||
|
this.timeout(1000 * 60)
|
||||||
|
const shortId = await PeerId.create(testOpts)
|
||||||
|
const longId = await PeerId.create({ bits: 1024 })
|
||||||
|
expect(shortId.privKey.bytes.length).is.below(longId.privKey.bytes.length)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Pretty printing', async () => {
|
||||||
|
const id1 = await PeerId.create(testOpts)
|
||||||
|
const id2 = await PeerId.createFromPrivKey((id1.toJSON()).privKey)
|
||||||
|
expect(id1.toPrint()).to.be.eql(id2.toPrint())
|
||||||
|
expect(id1.toPrint()).to.equal('<peer.ID ' + id1.toB58String().substr(2, 6) + '>')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('toBytes', () => {
|
||||||
|
const id = PeerId.createFromHexString(testIdHex)
|
||||||
|
expect(id.toBytes().toString('hex')).to.equal(testIdBytes.toString('hex'))
|
||||||
|
})
|
||||||
|
|
||||||
|
it('isEqual', async () => {
|
||||||
|
const ids = await Promise.all([
|
||||||
|
PeerId.create(testOpts),
|
||||||
|
PeerId.create(testOpts)
|
||||||
|
])
|
||||||
|
|
||||||
|
expect(ids[0].isEqual(ids[0])).to.equal(true)
|
||||||
|
expect(ids[0].isEqual(ids[1])).to.equal(false)
|
||||||
|
expect(ids[0].isEqual(ids[0].id)).to.equal(true)
|
||||||
|
expect(ids[0].isEqual(ids[1].id)).to.equal(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('fromJSON', () => {
|
||||||
|
it('full node', async () => {
|
||||||
|
const id = await PeerId.create(testOpts)
|
||||||
|
const other = await PeerId.createFromJSON(id.toJSON())
|
||||||
|
expect(id.toB58String()).to.equal(other.toB58String())
|
||||||
|
expect(id.privKey.bytes).to.eql(other.privKey.bytes)
|
||||||
|
expect(id.pubKey.bytes).to.eql(other.pubKey.bytes)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('only id', async () => {
|
||||||
|
const key = await crypto.keys.generateKeyPair('RSA', 1024)
|
||||||
|
const digest = await key.public.hash()
|
||||||
|
const id = PeerId.createFromBytes(digest)
|
||||||
|
expect(id.privKey).to.not.exist()
|
||||||
|
expect(id.pubKey).to.not.exist()
|
||||||
|
const other = await PeerId.createFromJSON(id.toJSON())
|
||||||
|
expect(id.toB58String()).to.equal(other.toB58String())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('go interop', async () => {
|
||||||
|
const id = await PeerId.createFromJSON(goId)
|
||||||
|
const digest = await id.privKey.public.hash()
|
||||||
|
expect(mh.toB58String(digest)).to.eql(goId.id)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set privKey (valid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
peerId.privKey = peerId._privKey
|
||||||
|
expect(peerId.isValid()).to.equal(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set pubKey (valid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
peerId.pubKey = peerId._pubKey
|
||||||
|
expect(peerId.isValid()).to.equal(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set privKey (invalid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
peerId.privKey = Buffer.from('bufff')
|
||||||
|
expect(peerId.isValid()).to.equal(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set pubKey (invalid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
peerId.pubKey = Buffer.from('bufff')
|
||||||
|
expect(peerId.isValid()).to.equal(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('returns error via cb instead of crashing', () => {
|
||||||
|
const garbage = [
|
||||||
|
Buffer.from('00010203040506070809', 'hex'),
|
||||||
|
{}, null, false, undefined, true, 1, 0,
|
||||||
|
Buffer.from(''), 'aGVsbG93b3JsZA==', 'helloworld', ''
|
||||||
|
]
|
||||||
|
|
||||||
|
const fncs = ['createFromPubKey', 'createFromPrivKey', 'createFromJSON', 'createFromProtobuf']
|
||||||
|
|
||||||
|
for (const gb of garbage) {
|
||||||
|
for (const fn of fncs) {
|
||||||
|
it(`${fn} (${util.inspect(gb)})`, async () => {
|
||||||
|
try {
|
||||||
|
await PeerId[fn](gb)
|
||||||
|
} catch (err) {
|
||||||
|
expect(err).to.exist()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('throws on inconsistent data', () => {
|
||||||
|
let k1
|
||||||
|
let k2
|
||||||
|
let k3
|
||||||
|
|
||||||
|
before(async () => {
|
||||||
|
const keys = await Promise.all([
|
||||||
|
crypto.keys.generateKeyPair('RSA', 512),
|
||||||
|
crypto.keys.generateKeyPair('RSA', 512),
|
||||||
|
crypto.keys.generateKeyPair('RSA', 512)
|
||||||
|
])
|
||||||
|
|
||||||
|
k1 = keys[0]
|
||||||
|
k2 = keys[1]
|
||||||
|
k3 = keys[2]
|
||||||
|
})
|
||||||
|
|
||||||
|
it('missmatch private - public key', async () => {
|
||||||
|
const digest = await k1.public.hash()
|
||||||
|
expect(() => {
|
||||||
|
new PeerId(digest, k1, k2.public) // eslint-disable-line no-new
|
||||||
|
}).to.throw(/inconsistent arguments/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('missmatch id - private - public key', async () => {
|
||||||
|
const digest = await k1.public.hash()
|
||||||
|
expect(() => {
|
||||||
|
new PeerId(digest, k1, k3.public) // eslint-disable-line no-new
|
||||||
|
}).to.throw(/inconsistent arguments/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('invalid id', () => {
|
||||||
|
expect(() => new PeerId('hello world')).to.throw(/invalid id/)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
Reference in New Issue
Block a user