mirror of
https://github.com/fluencelabs/js-peer-id
synced 2025-07-04 20:31:54 +00:00
Compare commits
179 Commits
Author | SHA1 | Date | |
---|---|---|---|
a68855a5d2 | |||
d8c307a44f | |||
a5070aea6e | |||
fc9698476f | |||
ffe04c12a0 | |||
65e0b746a5 | |||
74cdb24544 | |||
b5335cd4ee | |||
519052693d | |||
bbf0416f08 | |||
4fbf859efc | |||
52bd949b43 | |||
544ca7d74b | |||
11d4ec10bd | |||
4d5bb2cfff | |||
a2ac32ac0f | |||
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 | |||
06f93cd961 | |||
1452f233c8 | |||
77900c7b45 | |||
564489b0ea | |||
65c2ac8dca | |||
31701e236d | |||
e08907ff94 | |||
f6a42fef76 | |||
ba8aa3ff34 | |||
ae81e95927 | |||
d24500a042 | |||
5fec44833e | |||
2432c56ad5 | |||
f0e380af58 | |||
24cd31b2d1 | |||
5f9136b3ca | |||
4fe3e12b3c | |||
49d454da7d | |||
7336b6ad80 | |||
461d2ea287 | |||
7c100f845a | |||
c3f50a2dfd | |||
907ed1571d | |||
2aad1dce7b | |||
58f1933980 | |||
ab5504686a | |||
4beb1f8888 | |||
7635cfcfda | |||
afbd96edda | |||
c1e18ee420 | |||
b358530dfb | |||
4afbedb525 | |||
e9b107fc55 | |||
855a97956d | |||
dee54d3dcc | |||
167b726dad | |||
3b9f8af2e7 | |||
771b994d7e | |||
524fc37877 | |||
3c55473a45 | |||
8771627ce4 | |||
bbf6bae073 | |||
e45a9f4083 | |||
13f98c8913 | |||
f374ab4411 | |||
2f4cdd3725 | |||
d2f90ff447 | |||
f2a75f1188 | |||
dab90bd3b6 | |||
e9fdc0a27e | |||
f0a17a9bd9 | |||
57ab8406c0 | |||
f16c08e7fd | |||
be5d4f9b41 | |||
35a3ccca3d | |||
989c3fb7a5 | |||
bbe67df1c8 | |||
8849d90d6a | |||
2552871bcc | |||
ab76788771 |
22
.gitignore
vendored
22
.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,9 +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
|
||||||
|
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
|
||||||
|
52
.travis.yml
52
.travis.yml
@ -1,21 +1,45 @@
|
|||||||
language: node_js
|
language: node_js
|
||||||
|
cache: npm
|
||||||
|
stages:
|
||||||
|
- check
|
||||||
|
- test
|
||||||
|
- cov
|
||||||
|
|
||||||
node_js:
|
node_js:
|
||||||
- "4.0"
|
- '10'
|
||||||
|
|
||||||
branches:
|
os:
|
||||||
only:
|
- linux
|
||||||
- master
|
- osx
|
||||||
|
|
||||||
before_install:
|
script: npx nyc -s npm run test:node -- --bail
|
||||||
- npm i -g npm
|
after_success: npx nyc report --reporter=text-lcov > coverage.lcov && npx codecov
|
||||||
# Workaround for a permissions issue with Travis virtual machine images
|
|
||||||
|
|
||||||
addons:
|
jobs:
|
||||||
firefox: 'latest'
|
include:
|
||||||
|
- os: windows
|
||||||
|
cache: false
|
||||||
|
|
||||||
before_script:
|
- stage: check
|
||||||
- export DISPLAY=:99.0
|
script:
|
||||||
- sh -e /etc/init.d/xvfb start
|
- npx aegir dep-check
|
||||||
|
- npm run lint
|
||||||
|
|
||||||
script:
|
- stage: test
|
||||||
- npm test
|
name: chrome
|
||||||
|
addons:
|
||||||
|
chrome: stable
|
||||||
|
script:
|
||||||
|
- npx aegir test -t browser
|
||||||
|
- npx aegir test -t webworker
|
||||||
|
|
||||||
|
- stage: test
|
||||||
|
name: firefox
|
||||||
|
addons:
|
||||||
|
firefox: latest
|
||||||
|
script:
|
||||||
|
- npx aegir test -t browser -- --browsers FirefoxHeadless
|
||||||
|
- npx aegir test -t webworker -- --browsers FirefoxHeadless
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
email: false
|
||||||
|
371
CHANGELOG.md
Normal file
371
CHANGELOG.md
Normal file
@ -0,0 +1,371 @@
|
|||||||
|
<a name="0.13.7"></a>
|
||||||
|
## [0.13.7](https://github.com/libp2p/js-peer-id/compare/v0.13.6...v0.13.7) (2020-01-27)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* adds typescript types + type tests ([#110](https://github.com/libp2p/js-peer-id/issues/110)) ([a5070ae](https://github.com/libp2p/js-peer-id/commit/a5070ae))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.6"></a>
|
||||||
|
## [0.13.6](https://github.com/libp2p/js-peer-id/compare/v0.13.5...v0.13.6) (2019-12-18)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* catch errors thrown by multihash decode ([#109](https://github.com/libp2p/js-peer-id/issues/109)) ([65e0b74](https://github.com/libp2p/js-peer-id/commit/65e0b74))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.5"></a>
|
||||||
|
## [0.13.5](https://github.com/libp2p/js-peer-id/compare/v0.13.4...v0.13.5) (2019-11-12)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* deprecate isEqual in favor of equals ([#107](https://github.com/libp2p/js-peer-id/issues/107)) ([bbf0416](https://github.com/libp2p/js-peer-id/commit/bbf0416))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.13.4"></a>
|
||||||
|
## [0.13.4](https://github.com/libp2p/js-peer-id/compare/v0.13.3...v0.13.4) (2019-11-04)
|
||||||
|
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* bang in bin.js ([#106](https://github.com/libp2p/js-peer-id/issues/106)) ([11d4ec1](https://github.com/libp2p/js-peer-id/commit/11d4ec1))
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* support Peer ID represented as CID ([#105](https://github.com/libp2p/js-peer-id/issues/105)) ([544ca7d](https://github.com/libp2p/js-peer-id/commit/544ca7d))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<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)
|
||||||
|
|
||||||
|
|
||||||
|
|
319
README.md
319
README.md
@ -1,97 +1,280 @@
|
|||||||
peer-id JavaScript implementation
|
# peer-id
|
||||||
=================================
|
|
||||||
|
|
||||||
[](http://ipn.io)
|
[](http://protocol.ai)
|
||||||
[](http://webchat.freenode.net/?channels=%23ipfs)
|
[](http://libp2p.io/)
|
||||||
[](https://travis-ci.org/diasdavid/js-peer-id)
|
[](http://webchat.freenode.net/?channels=%23libp2p)
|
||||||

|
[](https://discuss.libp2p.io)
|
||||||
[](https://david-dm.org/diasdavid/js-peer-id)
|
[](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://github.com/feross/standard)
|
[](https://github.com/feross/standard)
|
||||||
> 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
|
||||||
|
|
||||||
|
- [peer-id](#peer-id)
|
||||||
|
- [Lead Maintainer](#lead-maintainer)
|
||||||
|
- [Table of Contents](#table-of-contents)
|
||||||
|
- [Description](#description)
|
||||||
|
- [Example](#example)
|
||||||
|
- [Installation](#installation)
|
||||||
|
- [npm](#npm)
|
||||||
|
- [Setup](#setup)
|
||||||
|
- [Node.js](#nodejs)
|
||||||
|
- [Browser: Browserify, Webpack, other bundlers](#browser-browserify-webpack-other-bundlers)
|
||||||
|
- [Browser: `<script>` Tag](#browser-script-tag)
|
||||||
|
- [API](#api)
|
||||||
|
- [Create](#create)
|
||||||
|
- [`new PeerId(id[, privKey, pubKey])`](#new-peeridid-privkey-pubkey)
|
||||||
|
- [`create([opts])`](#createopts)
|
||||||
|
- [Import](#import)
|
||||||
|
- [`createFromHexString(str)`](#createfromhexstringstr)
|
||||||
|
- [`createFromBytes(buf)`](#createfrombytesbuf)
|
||||||
|
- [`createFromCID(cid)`](#createfromcidcid)
|
||||||
|
- [`createFromB58String(str)`](#createfromb58stringstr)
|
||||||
|
- [`createFromPubKey(pubKey)`](#createfrompubkeypubkey)
|
||||||
|
- [`createFromPrivKey(privKey)`](#createfromprivkeyprivkey)
|
||||||
|
- [`createFromJSON(obj)`](#createfromjsonobj)
|
||||||
|
- [`createFromProtobuf(buf)`](#createfromprotobufbuf)
|
||||||
|
- [Export](#export)
|
||||||
|
- [`toHexString()`](#tohexstring)
|
||||||
|
- [`toBytes()`](#tobytes)
|
||||||
|
- [`toString()`](#tostring)
|
||||||
|
- [`toB58String()`](#tob58string)
|
||||||
|
- [`toJSON()`](#tojson)
|
||||||
|
- [`marshal(excludePrivateKey)`](#marshalexcludeprivatekey)
|
||||||
|
- [`marshalPubKey()`](#marshalpubkey)
|
||||||
|
- [`toPrint()`](#toprint)
|
||||||
|
- [`equals(id)`](#equalsid)
|
||||||
|
- [`isEqual(id)`](#isequalid)
|
||||||
|
- [License](#license)
|
||||||
|
|
||||||
# Description
|
# Description
|
||||||
|
|
||||||
An IPFS Peer Id is based on a sha256 hash of the peer public key, using [multihash](https://github.com/jbenet/multihash)
|
Generate, import, and export PeerIDs, for use with [IPFS](https://github.com/ipfs/ipfs).
|
||||||
|
|
||||||
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.
|
A Peer ID is the SHA-256 [multihash](https://github.com/multiformats/multihash) of a public key.
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
# Usage
|
# Example
|
||||||
|
|
||||||
### In Node.js through npm
|
```JavaScript
|
||||||
|
const PeerId = require('peer-id')
|
||||||
|
|
||||||
```bash
|
const id = await PeerId.create({ bits: 1024, keyType: 'rsa' })
|
||||||
> npm install --save peer-id
|
console.log(JSON.stringify(id.toJSON(), null, 2))
|
||||||
```
|
```
|
||||||
|
|
||||||
```javascript
|
```bash
|
||||||
|
{
|
||||||
|
"id": "Qma9T5YraSnpRDZqRR4krcSJabThc8nwZuJV3LercPHufi",
|
||||||
|
"privKey": "CAAS4AQwggJcAgEAAoGBAMBgbIqyOL26oV3nGPBYrdpbv..",
|
||||||
|
"pubKey": "CAASogEwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAMBgbIqyOL26oV3nGPBYrdpbvzCY..."
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
# Installation
|
||||||
|
|
||||||
|
## npm
|
||||||
|
|
||||||
|
```sh
|
||||||
|
> npm i peer-id
|
||||||
|
```
|
||||||
|
|
||||||
|
# Setup
|
||||||
|
|
||||||
|
## Node.js
|
||||||
|
|
||||||
|
```js
|
||||||
const PeerId = require('peer-id')
|
const PeerId = require('peer-id')
|
||||||
```
|
```
|
||||||
|
|
||||||
### In the Browser through Webpack
|
## Browser: Browserify, Webpack, other bundlers
|
||||||
|
|
||||||
Follow our [webpack config](/webpack.config.js) example.
|
The code published to npm that gets loaded on require is in fact a ES5
|
||||||
|
transpiled version with the right shims added. This means that you can require
|
||||||
|
it and use with your favourite bundler without having to adjust asset management
|
||||||
|
process.
|
||||||
|
|
||||||
### In the Browser through browserify
|
```js
|
||||||
|
const PeerId = require('peer-id')
|
||||||
> **WIP** Doesn't work out yet
|
|
||||||
|
|
||||||
### In the Browser through `<script>` tag
|
|
||||||
|
|
||||||
Make the [peer-id.js](/dist/peer-id.js) available through your server and load it using a normal `<script>` tag, this will export the `PeerId` object, such that:
|
|
||||||
|
|
||||||
```JavaScript
|
|
||||||
const Id = PeerId
|
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Gotchas
|
## Browser: `<script>` Tag
|
||||||
|
|
||||||
You will need to use Node.js `Buffer` API compatible, if you are running inside the browser, you can access it by `PeerId.Buffer` or you can install Feross's [Buffer](https://github.com/feross/buffer).
|
Loading this module through a script tag will make the `PeerId` obj available in
|
||||||
|
the global namespace.
|
||||||
|
|
||||||
### Creating a new Id
|
```html
|
||||||
|
<script src="https://unpkg.com/peer-id/dist/index.min.js"></script>
|
||||||
```
|
<!-- OR -->
|
||||||
const PeerId = require('ipfs-peer')
|
<script src="https://unpkg.com/peer-id/dist/index.js"></script>
|
||||||
|
|
||||||
// Create a new Id
|
|
||||||
const id = PeerId.create()
|
|
||||||
|
|
||||||
// Recreate an Id from Hex string
|
|
||||||
const id = PeerId.createFromHexString(str)
|
|
||||||
|
|
||||||
// Recreate an Id from a Buffer
|
|
||||||
const id = PeerId.createFromBytes(buf)
|
|
||||||
|
|
||||||
// Recreate an B58 String
|
|
||||||
const id = PeerId.createFromB58String(str)
|
|
||||||
|
|
||||||
// Recreate from a Public Key
|
|
||||||
const id = PeerId.createFromPubKey(pubKey)
|
|
||||||
|
|
||||||
// Recreate from a Private Key
|
|
||||||
const id = PeerId.createFromPrivKey(privKey)
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Exporting an Id
|
# API
|
||||||
|
|
||||||
```
|
```js
|
||||||
// Print friendly format
|
const PeerId = require('peer-id')
|
||||||
id.toPrint() // returns an object with id, privKey and pubKey in hex format
|
|
||||||
|
|
||||||
// Export to an hex string
|
|
||||||
id.toHexString()
|
|
||||||
|
|
||||||
// Export to Buffer
|
|
||||||
id.toBytes() (same as id.id)
|
|
||||||
|
|
||||||
// Export to a B58 string
|
|
||||||
id.toB58String()
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Id format
|
## Create
|
||||||
|
|
||||||
|
### `new PeerId(id[, privKey, pubKey])`
|
||||||
|
|
||||||
|
- `id: Buffer` - The multihash of the public key as `Buffer`
|
||||||
|
- `privKey: RsaPrivateKey` - The private key
|
||||||
|
- `pubKey: RsaPublicKey` - The public key
|
||||||
|
|
||||||
|
The key format is detailed in [libp2p-crypto](https://github.com/libp2p/js-libp2p-crypto).
|
||||||
|
|
||||||
|
### `create([opts])`
|
||||||
|
|
||||||
|
Generates a new Peer ID, complete with public/private keypair.
|
||||||
|
|
||||||
|
- `opts: Object`: Default: `{bits: 2048, keyType: 'rsa'}`
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
|
## Import
|
||||||
|
|
||||||
|
### `createFromHexString(str)`
|
||||||
|
|
||||||
|
Creates a Peer ID from hex string representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId.
|
||||||
|
|
||||||
|
### `createFromBytes(buf)`
|
||||||
|
|
||||||
|
Creates a Peer ID from a buffer representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId`.
|
||||||
|
|
||||||
|
### `createFromCID(cid)`
|
||||||
|
|
||||||
|
- `cid: CID|String|Buffer` - The multihash encoded as [CID](https://github.com/ipld/js-cid) (object, `String` or `Buffer`)
|
||||||
|
|
||||||
|
Creates a Peer ID from a CID representation of the key's multihash ([RFC 0001](https://github.com/libp2p/specs/blob/master/RFC/0001-text-peerid-cid.md)).
|
||||||
|
|
||||||
|
Returns `PeerId`.
|
||||||
|
|
||||||
|
### `createFromB58String(str)`
|
||||||
|
|
||||||
|
Creates a Peer ID from a Base58 string representing the key's multihash.
|
||||||
|
|
||||||
|
Returns `PeerId`.
|
||||||
|
|
||||||
|
### `createFromPubKey(pubKey)`
|
||||||
|
|
||||||
|
- `publicKey: Buffer`
|
||||||
|
|
||||||
|
Creates a Peer ID from a buffer containing a public key.
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
|
### `createFromPrivKey(privKey)`
|
||||||
|
|
||||||
|
- `privKey: Buffer`
|
||||||
|
|
||||||
|
Creates a Peer ID from a buffer containing a private key.
|
||||||
|
|
||||||
|
Returns `Promise<PeerId>`.
|
||||||
|
|
||||||
|
### `createFromJSON(obj)`
|
||||||
|
|
||||||
|
- `obj.id: String` - The multihash encoded in `base58`
|
||||||
|
- `obj.pubKey: String` - The public key in protobuf format, encoded in `base64`
|
||||||
|
- `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
|
||||||
|
|
||||||
|
### `toHexString()`
|
||||||
|
|
||||||
|
Returns the Peer ID's `id` as a hex string.
|
||||||
|
|
||||||
```
|
```
|
||||||
id.pubKey // Buffer containing the Public Key
|
1220d6243998f2fc56343ad7ed0342ab7886a4eb18d736f1b67d44b37fcc81e0f39f
|
||||||
id.privKey // Buffer containing the Private Key
|
|
||||||
id.id // Buffer containing the multihash
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### `toBytes()`
|
||||||
|
|
||||||
|
Returns the Peer ID's `id` as a buffer.
|
||||||
|
|
||||||
|
```
|
||||||
|
<Buffer 12 20 d6 24 39 98 f2 fc 56 34 3a d7 ed 03 42 ab 78 86 a4 eb 18 d7 36 f1 b6 7d 44 b3 7f cc 81 e0 f3 9f>
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
### `toString()`
|
||||||
|
|
||||||
|
Returns the Peer ID's `id` as a self-describing CIDv1 in Base32 ([RFC 0001](https://github.com/libp2p/specs/blob/master/RFC/0001-text-peerid-cid.md))
|
||||||
|
|
||||||
|
```
|
||||||
|
bafzbeigweq4zr4x4ky2dvv7nanbkw6egutvrrvzw6g3h2rftp7gidyhtt4
|
||||||
|
```
|
||||||
|
|
||||||
|
### `toB58String()`
|
||||||
|
|
||||||
|
Returns the Peer ID's `id` as a base58 string (multihash/CIDv0).
|
||||||
|
|
||||||
|
```
|
||||||
|
QmckZzdVd72h9QUFuJJpQqhsZqGLwjhh81qSvZ9BhB2FQi
|
||||||
|
```
|
||||||
|
|
||||||
|
### `toJSON()`
|
||||||
|
|
||||||
|
Returns an `obj` of the form
|
||||||
|
|
||||||
|
- `obj.id: String` - The multihash encoded in `base58`
|
||||||
|
- `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'
|
||||||
|
|
||||||
|
### `marshal(excludePrivateKey)`
|
||||||
|
|
||||||
|
Returns a protocol-buffers encoded version of the id, public key and, if `excludePrivateKey` is not set, the private key.
|
||||||
|
|
||||||
|
### `marshalPubKey()`
|
||||||
|
|
||||||
|
Returns a protobuf of just the public key, compatible with `libp2p-crypto` (unlike `marshal` above).
|
||||||
|
|
||||||
|
For example:
|
||||||
|
```js
|
||||||
|
const crypto = require('libp2p-crypto')
|
||||||
|
|
||||||
|
PeerId.create({ bits: 256, keyType: 'ed25519' }).then( pid => {
|
||||||
|
let pk = crypto.keys.unmarshalPublicKey(pid.marshalPubKey())
|
||||||
|
// your code here
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### `toPrint()`
|
||||||
|
|
||||||
|
Returns the Peer ID as a printable string without the `Qm` prefix.
|
||||||
|
|
||||||
|
Example: `<peer.ID xxxxxx>`
|
||||||
|
|
||||||
|
### `equals(id)`
|
||||||
|
|
||||||
|
Returns `true` if the given PeerId is equal to the current instance.
|
||||||
|
|
||||||
|
- `id` can be a PeerId or a Buffer containing the id
|
||||||
|
|
||||||
|
### `isEqual(id)`
|
||||||
|
**Deprecation Notice**: Use [`equals`](#equalsid), `isEqual` will be removed in 0.14.0.
|
||||||
|
|
||||||
|
- `id` can be a PeerId or a Buffer containing the id
|
||||||
|
|
||||||
|
# License
|
||||||
|
|
||||||
|
MIT
|
||||||
|
29552
deps/forge.bundle.js
vendored
29552
deps/forge.bundle.js
vendored
File diff suppressed because it is too large
Load Diff
75722
dist/peer-id.js
vendored
75722
dist/peer-id.js
vendored
File diff suppressed because one or more lines are too long
@ -1,61 +0,0 @@
|
|||||||
module.exports = (config) => {
|
|
||||||
const path = require('path')
|
|
||||||
const node_modules_dir = path.join(__dirname, 'node_modules')
|
|
||||||
const deps = [
|
|
||||||
'deps/forge.bundle.js'
|
|
||||||
]
|
|
||||||
config.set({
|
|
||||||
basePath: '',
|
|
||||||
frameworks: ['mocha'],
|
|
||||||
|
|
||||||
files: [
|
|
||||||
'tests/test.js'
|
|
||||||
],
|
|
||||||
|
|
||||||
preprocessors: {
|
|
||||||
'tests/*': ['webpack']
|
|
||||||
},
|
|
||||||
|
|
||||||
webpack: {
|
|
||||||
output: {
|
|
||||||
path: path.join(__dirname, 'dist'),
|
|
||||||
filename: 'bundle.js'
|
|
||||||
},
|
|
||||||
resolve: {
|
|
||||||
extensions: ['', '.js', '.json'],
|
|
||||||
alias: { 'node-forge': path.resolve(__dirname, 'deps/forge.bundle.js') }
|
|
||||||
},
|
|
||||||
externals: {
|
|
||||||
fs: '{}'
|
|
||||||
},
|
|
||||||
node: {
|
|
||||||
Buffer: true
|
|
||||||
},
|
|
||||||
module: {
|
|
||||||
loaders: [
|
|
||||||
{ test: /\.json$/, loader: 'json' }
|
|
||||||
],
|
|
||||||
noParse: []
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
webpackMiddleware: {
|
|
||||||
noInfo: true,
|
|
||||||
stats: {
|
|
||||||
colors: true
|
|
||||||
}
|
|
||||||
},
|
|
||||||
reporters: ['spec'],
|
|
||||||
port: 9876,
|
|
||||||
colors: true,
|
|
||||||
logLevel: config.LOG_INFO,
|
|
||||||
autoWatch: false,
|
|
||||||
browsers: process.env.TRAVIS ? ['Firefox'] : ['Chrome'],
|
|
||||||
singleRun: true
|
|
||||||
})
|
|
||||||
|
|
||||||
deps.forEach((dep) => {
|
|
||||||
const depPath = path.resolve(node_modules_dir, dep)
|
|
||||||
config.webpack.module.noParse.push(depPath)
|
|
||||||
})
|
|
||||||
}
|
|
108
package.json
108
package.json
@ -1,64 +1,86 @@
|
|||||||
{
|
{
|
||||||
"name": "peer-id",
|
"name": "peer-id",
|
||||||
"version": "0.6.1",
|
"version": "0.13.7",
|
||||||
"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",
|
||||||
|
"types": "src/index.d.ts",
|
||||||
|
"bin": "src/bin.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "standard",
|
"lint": "aegir lint",
|
||||||
"test": "npm run test:node && npm run test:browser",
|
"build": "aegir build",
|
||||||
"test:node": "mocha tests/test.js",
|
"test": "aegir test",
|
||||||
"test:browser": "karma start karma.conf.js",
|
"test:node": "aegir test -t node",
|
||||||
"coverage": "istanbul cover --print both -- _mocha tests/test.js",
|
"test:browser": "aegir test -t browser -t webworker",
|
||||||
"dist": "webpack"
|
"test:types": "npx tsc",
|
||||||
},
|
"release": "aegir release",
|
||||||
"standard": {
|
"release-minor": "aegir release --type minor",
|
||||||
"ignore": [
|
"release-major": "aegir release --type major",
|
||||||
"dist",
|
"coverage": "aegir coverage",
|
||||||
"deps"
|
"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.3.0"
|
"node": ">=10.0.0",
|
||||||
|
"npm": ">=6.0.0"
|
||||||
},
|
},
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/diasdavid/js-peer-id/issues"
|
"url": "https://github.com/libp2p/js-peer-id/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/diasdavid/js-peer-id",
|
"homepage": "https://github.com/libp2p/js-peer-id",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"browserify": "^13.0.0",
|
"@types/chai": "^4.2.7",
|
||||||
"buffer-loader": "0.0.1",
|
"@types/dirty-chai": "^2.0.2",
|
||||||
"chai": "^3.5.0",
|
"@types/mocha": "^5.2.7",
|
||||||
"istanbul": "^0.4.2",
|
"aegir": "^20.0.0",
|
||||||
"json-loader": "^0.5.4",
|
"bundlesize": "~0.18.0",
|
||||||
"karma": "^0.13.19",
|
"chai": "^4.2.0",
|
||||||
"karma-chrome-launcher": "^0.2.2",
|
"dirty-chai": "^2.0.1"
|
||||||
"karma-cli": "^0.1.2",
|
|
||||||
"karma-firefox-launcher": "^0.1.7",
|
|
||||||
"karma-mocha": "^0.2.1",
|
|
||||||
"karma-spec-reporter": "0.0.24",
|
|
||||||
"karma-webpack": "^1.7.0",
|
|
||||||
"mocha": "^2.4.5",
|
|
||||||
"pre-commit": "^1.1.1",
|
|
||||||
"standard": "^6.0.7",
|
|
||||||
"webpack": "^1.12.14"
|
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"bs58": "^3.0.0",
|
"cids": "^0.7.3",
|
||||||
"multihashing": "^0.2.0",
|
"class-is": "^1.1.0",
|
||||||
"node-forge": "^0.6.38",
|
"libp2p-crypto": "~0.17.2",
|
||||||
"protocol-buffers": "^3.1.4"
|
"multihashes": "~0.4.15",
|
||||||
|
"protons": "^1.0.1"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/diasdavid/js-peer-id.git"
|
"url": "https://github.com/libp2p/js-peer-id.git"
|
||||||
}
|
},
|
||||||
|
"contributors": [
|
||||||
|
"Arve Knudsen <arve.knudsen@gmail.com>",
|
||||||
|
"Carson Farmer <carson.farmer@gmail.com>",
|
||||||
|
"Christian Paul <info@jaller.de>",
|
||||||
|
"David Dias <daviddias.p@gmail.com>",
|
||||||
|
"David Dias <mail@daviddias.me>",
|
||||||
|
"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>",
|
||||||
|
"Marcin Rataj <lidel@lidel.org>",
|
||||||
|
"Michael Garvin <gar+gh@danger.computer>",
|
||||||
|
"Nate Foss <npfoss@gmail.com>",
|
||||||
|
"Pedro Teixeira <i@pgte.me>",
|
||||||
|
"Prashanth Chandra <coolshanth94@gmail.com>",
|
||||||
|
"Richard Littauer <richard.littauer@gmail.com>",
|
||||||
|
"Richard Schneider <makaretu@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>",
|
||||||
|
"nginnever <ginneversource@gmail.com>",
|
||||||
|
"npmcdn-to-unpkg-bot <npmcdn-to-unpkg-bot@users.noreply.github.com>",
|
||||||
|
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
12
src/bin.js
Executable file
12
src/bin.js
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const PeerId = require('./index.js')
|
||||||
|
|
||||||
|
async function main () {
|
||||||
|
const id = await PeerId.create()
|
||||||
|
console.log(JSON.stringify(id.toJSON(), null, 2)) // eslint-disable-line no-console
|
||||||
|
}
|
||||||
|
|
||||||
|
main()
|
188
src/index.d.ts
vendored
Normal file
188
src/index.d.ts
vendored
Normal file
@ -0,0 +1,188 @@
|
|||||||
|
import crypto, { PrivateKey, PublicKey, KeyType } from "libp2p-crypto";
|
||||||
|
import CID from 'cids'
|
||||||
|
|
||||||
|
declare namespace PeerId {
|
||||||
|
/**
|
||||||
|
* Options for PeerId creation.
|
||||||
|
*/
|
||||||
|
type CreateOptions = {
|
||||||
|
/**
|
||||||
|
* The number of bits to use.
|
||||||
|
*/
|
||||||
|
bits?: number;
|
||||||
|
/**
|
||||||
|
* The type of key to use.
|
||||||
|
*/
|
||||||
|
keyType?: KeyType;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PeerId JSON format.
|
||||||
|
*/
|
||||||
|
type JSONPeerId = {
|
||||||
|
/**
|
||||||
|
* String representation of PeerId.
|
||||||
|
*/
|
||||||
|
id: string;
|
||||||
|
/**
|
||||||
|
* Public key.
|
||||||
|
*/
|
||||||
|
pubKey?: string;
|
||||||
|
/**
|
||||||
|
* Private key.
|
||||||
|
*/
|
||||||
|
privKey: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if a value is an instance of PeerId.
|
||||||
|
* @param id The value to check.
|
||||||
|
*/
|
||||||
|
function isPeerId(id: any): boolean
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new PeerId.
|
||||||
|
* @param opts Options.
|
||||||
|
*/
|
||||||
|
function create(opts?: PeerId.CreateOptions): Promise<PeerId>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from hex string.
|
||||||
|
* @param str The input hex string.
|
||||||
|
*/
|
||||||
|
function createFromHexString(str: string): PeerId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from raw bytes.
|
||||||
|
* @param buf The raw bytes.
|
||||||
|
*/
|
||||||
|
function createFromBytes(buf: Buffer): PeerId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from base58-encoded string.
|
||||||
|
* @param str The base58-encoded string.
|
||||||
|
*/
|
||||||
|
function createFromB58String(str: string): PeerId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from CID.
|
||||||
|
* @param cid The CID.
|
||||||
|
*/
|
||||||
|
function createFromCID(cid: CID | Buffer | string | object): PeerId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from public key.
|
||||||
|
* @param key Public key, as Buffer or base64-encoded string.
|
||||||
|
*/
|
||||||
|
function createFromPubKey(key: Buffer | string): Promise<PeerId>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from private key.
|
||||||
|
* @param key Private key, as Buffer or base64-encoded string.
|
||||||
|
*/
|
||||||
|
function createFromPrivKey(key: Buffer | string): Promise<PeerId>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from PeerId JSON formatted object.
|
||||||
|
* @see {@link PeerId#toJSON}
|
||||||
|
* @param json PeerId in JSON format.
|
||||||
|
*/
|
||||||
|
function createFromJSON(json: JSONPeerId): Promise<PeerId>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create PeerId from Protobuf bytes.
|
||||||
|
* @param buf Protobuf bytes, as Buffer or hex-encoded string.
|
||||||
|
*/
|
||||||
|
function createFromProtobuf(buf: Buffer | string): Promise<PeerId>;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PeerId is an object representation of a peer identifier.
|
||||||
|
*/
|
||||||
|
declare class PeerId {
|
||||||
|
constructor(id: Buffer | string, privKey?: PrivateKey, pubKey?: PublicKey);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Raw id.
|
||||||
|
*/
|
||||||
|
id: Buffer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Private key.
|
||||||
|
*/
|
||||||
|
privKey: PrivateKey;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Public key.
|
||||||
|
*/
|
||||||
|
pubKey: PublicKey;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the protobuf version of the public key, matching go ipfs formatting.
|
||||||
|
*/
|
||||||
|
marshalPubKey(): Buffer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the protobuf version of the private key, matching go ipfs formatting.
|
||||||
|
*/
|
||||||
|
marshalPrivKey(): Buffer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the protobuf version of the peer-id.
|
||||||
|
* @param excludePriv Whether to exclude the private key information from the output.
|
||||||
|
*/
|
||||||
|
marshal(excludePriv?: boolean): Buffer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* String representation.
|
||||||
|
*/
|
||||||
|
toPrint(): string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the jsonified version of the key.
|
||||||
|
* Matches the formatting of go-ipfs for its config file.
|
||||||
|
* @see {@link PeerId.createFromJSON}
|
||||||
|
*/
|
||||||
|
toJSON(): PeerId.JSONPeerId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encode to hex.
|
||||||
|
*/
|
||||||
|
toHexString(): string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return raw id bytes.
|
||||||
|
*/
|
||||||
|
toBytes(): Buffer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encode to base58 string.
|
||||||
|
*/
|
||||||
|
toB58String(): string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return self-describing string representation.
|
||||||
|
* Uses default format from RFC 0001: https://github.com/libp2p/specs/pull/209
|
||||||
|
*/
|
||||||
|
toString(): string;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the equality of `this` peer against a given PeerId.
|
||||||
|
* @param id The other PeerId.
|
||||||
|
*/
|
||||||
|
equals(id: PeerId | Buffer): boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the equality of `this` peer against a given PeerId.
|
||||||
|
* @deprecated Use {.equals}
|
||||||
|
* @param id The other PeerId.
|
||||||
|
*/
|
||||||
|
isEqual(id: PeerId | Buffer): boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if this PeerId instance is valid (privKey -> pubKey -> Id)
|
||||||
|
*/
|
||||||
|
isValid(): boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
export = PeerId;
|
429
src/index.js
429
src/index.js
@ -2,175 +2,346 @@
|
|||||||
* Id is an object representation of a peer Id. a peer Id is a multihash
|
* Id is an object representation of a peer Id. a peer Id is a multihash
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const fs = require('fs')
|
'use strict'
|
||||||
const multihashing = require('multihashing')
|
|
||||||
const base58 = require('bs58')
|
|
||||||
const forge = require('node-forge')
|
|
||||||
const protobuf = require('protocol-buffers')
|
|
||||||
const path = require('path')
|
|
||||||
|
|
||||||
const isNode = !global.window
|
const mh = require('multihashes')
|
||||||
|
const CID = require('cids')
|
||||||
|
const cryptoKeys = require('libp2p-crypto/src/keys')
|
||||||
|
const assert = require('assert')
|
||||||
|
const withIs = require('class-is')
|
||||||
|
const { PeerIdProto } = require('./proto')
|
||||||
|
|
||||||
// protobuf read from file
|
class PeerId {
|
||||||
const messages = isNode ? protobuf(fs.readFileSync(path.resolve(__dirname, 'pb/crypto.proto'))) : protobuf(require('buffer!./pb/crypto.proto'))
|
constructor (id, privKey, pubKey) {
|
||||||
|
assert(Buffer.isBuffer(id), 'invalid id provided')
|
||||||
|
|
||||||
exports = module.exports = Id
|
if (privKey && pubKey) {
|
||||||
|
assert(privKey.public.bytes.equals(pubKey.bytes), 'inconsistent arguments')
|
||||||
|
}
|
||||||
|
|
||||||
exports.Buffer = Buffer
|
this._id = id
|
||||||
|
this._idB58String = mh.toB58String(this.id)
|
||||||
function Id (id, privKey, pubKey) {
|
this._privKey = privKey
|
||||||
const self = this
|
this._pubKey = pubKey
|
||||||
|
|
||||||
if (!(self instanceof Id)) {
|
|
||||||
throw new Error('Id must be called with new')
|
|
||||||
}
|
}
|
||||||
|
|
||||||
self.privKey = privKey
|
get id () {
|
||||||
self.pubKey = pubKey
|
return this._id
|
||||||
self.id = id // multihash - sha256 - buffer
|
}
|
||||||
|
|
||||||
// pretty print
|
set id (val) {
|
||||||
self.toPrint = function () {
|
throw new Error('Id is immutable')
|
||||||
|
}
|
||||||
|
|
||||||
|
get privKey () {
|
||||||
|
return this._privKey
|
||||||
|
}
|
||||||
|
|
||||||
|
set privKey (privKey) {
|
||||||
|
this._privKey = privKey
|
||||||
|
}
|
||||||
|
|
||||||
|
get pubKey () {
|
||||||
|
if (this._pubKey) {
|
||||||
|
return this._pubKey
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this._privKey) {
|
||||||
|
return this._privKey.public
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const decoded = mh.decode(this.id)
|
||||||
|
|
||||||
|
if (decoded.name === 'identity') {
|
||||||
|
this._pubKey = cryptoKeys.unmarshalPublicKey(decoded.digest)
|
||||||
|
}
|
||||||
|
} catch (_) {
|
||||||
|
// Ignore, there is no valid public key
|
||||||
|
}
|
||||||
|
|
||||||
|
return this._pubKey
|
||||||
|
}
|
||||||
|
|
||||||
|
set pubKey (pubKey) {
|
||||||
|
this._pubKey = pubKey
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the protobuf version of the public key, matching go ipfs formatting
|
||||||
|
marshalPubKey () {
|
||||||
|
if (this.pubKey) {
|
||||||
|
return cryptoKeys.marshalPublicKey(this.pubKey)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the protobuf version of the private key, matching go ipfs formatting
|
||||||
|
marshalPrivKey () {
|
||||||
|
if (this.privKey) {
|
||||||
|
return cryptoKeys.marshalPrivateKey(this.privKey)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 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 () {
|
||||||
|
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
|
||||||
|
// of go-ipfs for its config file
|
||||||
|
toJSON () {
|
||||||
return {
|
return {
|
||||||
id: self.toB58String(),
|
id: this.toB58String(),
|
||||||
privKey: privKey.toString('hex'),
|
privKey: toB64Opt(this.marshalPrivKey()),
|
||||||
pubKey: pubKey.toString('hex')
|
pubKey: toB64Opt(this.marshalPubKey())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// encode/decode functions
|
// encode/decode functions
|
||||||
self.toHexString = function () {
|
toHexString () {
|
||||||
return self.id.toString('hex')
|
return mh.toHexString(this.id)
|
||||||
}
|
}
|
||||||
|
|
||||||
self.toBytes = function () {
|
toBytes () {
|
||||||
return self.id
|
return this.id
|
||||||
}
|
}
|
||||||
|
|
||||||
self.toB58String = function () {
|
toB58String () {
|
||||||
return base58.encode(self.id)
|
return this._idB58String
|
||||||
|
}
|
||||||
|
|
||||||
|
// return self-describing String representation
|
||||||
|
// in default format from RFC 0001: https://github.com/libp2p/specs/pull/209
|
||||||
|
toString () {
|
||||||
|
if (!this._idCIDString) {
|
||||||
|
const cid = new CID(1, 'libp2p-key', this.id, 'base32')
|
||||||
|
this._idCIDString = cid.toBaseEncodedString('base32')
|
||||||
|
}
|
||||||
|
return this._idCIDString
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the equality of `this` peer against a given PeerId.
|
||||||
|
* @param {Buffer|PeerId} id
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
equals (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')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the equality of `this` peer against a given PeerId.
|
||||||
|
* @deprecated Use `.equals`
|
||||||
|
* @param {Buffer|PeerId} id
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
isEqual (id) {
|
||||||
|
return this.equals(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// unwrap the private key protobuf
|
const PeerIdWithIs = withIs(PeerId, {
|
||||||
function unmarshal (key) {
|
className: 'PeerId',
|
||||||
return messages.PrivateKey.decode(key)
|
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()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// create a public key protobuf to be base64 string stored in config
|
const computePeerId = async (privKey, pubKey) => {
|
||||||
function marshal (data, type) {
|
const digest = await computeDigest(pubKey)
|
||||||
var epb
|
return new PeerIdWithIs(digest, privKey, pubKey)
|
||||||
if (type === 'Public') {
|
|
||||||
epb = messages.PublicKey.encode({
|
|
||||||
Type: 0,
|
|
||||||
Data: data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if (type === 'Private') {
|
|
||||||
epb = messages.PrivateKey.encode({
|
|
||||||
Type: 0,
|
|
||||||
Data: data
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
return epb
|
|
||||||
}
|
|
||||||
|
|
||||||
// this returns a base64 encoded protobuf of the public key
|
|
||||||
function formatKey (key, type) {
|
|
||||||
// create der buffer of public key asn.1 object
|
|
||||||
const der = forge.asn1.toDer(key)
|
|
||||||
|
|
||||||
// create forge buffer of der public key buffer
|
|
||||||
const fDerBuf = forge.util.createBuffer(der.data, 'binary')
|
|
||||||
|
|
||||||
// convert forge buffer to node buffer public key
|
|
||||||
const nDerBuf = new Buffer(fDerBuf.getBytes(), 'binary')
|
|
||||||
|
|
||||||
// protobuf the new DER bytes to the PublicKey Data: field
|
|
||||||
const marshalKey = marshal(nDerBuf, type)
|
|
||||||
|
|
||||||
// encode the protobuf public key to base64 string
|
|
||||||
const b64 = marshalKey.toString('base64')
|
|
||||||
return b64
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// generation
|
// generation
|
||||||
exports.create = function (opts) {
|
exports.create = async (opts) => {
|
||||||
opts = opts || {}
|
opts = opts || {}
|
||||||
opts.bits = opts.bits || 2048
|
opts.bits = opts.bits || 2048
|
||||||
|
opts.keyType = opts.keyType || 'RSA'
|
||||||
|
|
||||||
// generate keys
|
const key = await cryptoKeys.generateKeyPair(opts.keyType, opts.bits)
|
||||||
const pair = forge.rsa.generateKeyPair({
|
return computePeerId(key, key.public)
|
||||||
bits: opts.bits,
|
|
||||||
e: 0x10001
|
|
||||||
})
|
|
||||||
|
|
||||||
// return the RSA public/private key to asn1 object
|
|
||||||
const asnPub = forge.pki.publicKeyToAsn1(pair.publicKey)
|
|
||||||
const asnPriv = forge.pki.privateKeyToAsn1(pair.privateKey)
|
|
||||||
|
|
||||||
// format the keys to protobuf base64 encoded string
|
|
||||||
const protoPublic64 = formatKey(asnPub, 'Public')
|
|
||||||
const protoPrivate64 = formatKey(asnPriv, 'Private')
|
|
||||||
|
|
||||||
// store the keys as a buffer
|
|
||||||
const bufProtoPub64 = new Buffer(protoPublic64, 'base64')
|
|
||||||
const bufProtoPriv64 = new Buffer(protoPrivate64, 'base64')
|
|
||||||
|
|
||||||
const mhId = multihashing(new Buffer(protoPublic64, 'base64'), 'sha2-256')
|
|
||||||
|
|
||||||
return new Id(mhId, bufProtoPriv64, bufProtoPub64)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromHexString = function (str) {
|
exports.createFromHexString = (str) => {
|
||||||
return new Id(new Buffer(str, 'hex'))
|
return new PeerIdWithIs(mh.fromHexString(str))
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromBytes = function (buf) {
|
exports.createFromBytes = (buf) => {
|
||||||
return new Id(buf)
|
return new PeerIdWithIs(buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromB58String = function (str) {
|
exports.createFromB58String = (str) => {
|
||||||
return new Id(new Buffer(base58.decode(str)))
|
return exports.createFromCID(str) // B58String is CIDv0
|
||||||
|
}
|
||||||
|
|
||||||
|
const validMulticodec = (cid) => {
|
||||||
|
// supported: 'libp2p-key' (CIDv1) and 'dag-pb' (CIDv0 converted to CIDv1)
|
||||||
|
return cid.codec === 'libp2p-key' || cid.codec === 'dag-pb'
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.createFromCID = (cid) => {
|
||||||
|
cid = CID.isCID(cid) ? cid : new CID(cid)
|
||||||
|
if (!validMulticodec(cid)) throw new Error('Supplied PeerID CID has invalid multicodec: ' + cid.codec)
|
||||||
|
return new PeerIdWithIs(cid.multihash)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public Key input will be a buffer
|
// Public Key input will be a buffer
|
||||||
exports.createFromPubKey = function (pubKey) {
|
exports.createFromPubKey = async (key) => {
|
||||||
const buf = new Buffer(pubKey, 'base64')
|
let buf = key
|
||||||
const mhId = multihashing(buf, 'sha2-256')
|
|
||||||
return new Id(mhId, null, pubKey)
|
if (typeof buf === 'string') {
|
||||||
|
buf = Buffer.from(key, 'base64')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!Buffer.isBuffer(buf)) {
|
||||||
|
throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
|
}
|
||||||
|
|
||||||
|
const pubKey = await cryptoKeys.unmarshalPublicKey(buf)
|
||||||
|
return computePeerId(null, pubKey)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Private key input will be a string
|
// Private key input will be a string
|
||||||
exports.createFromPrivKey = function (privKey) {
|
exports.createFromPrivKey = async (key) => {
|
||||||
// create a buffer from the base64 encoded string
|
let buf = key
|
||||||
const buf = new Buffer(privKey, 'base64')
|
|
||||||
|
|
||||||
// get the private key data from the protobuf
|
if (typeof buf === 'string') {
|
||||||
const mpk = unmarshal(buf)
|
buf = Buffer.from(key, 'base64')
|
||||||
|
}
|
||||||
|
|
||||||
// create a forge buffer
|
if (!Buffer.isBuffer(buf)) {
|
||||||
const fbuf = forge.util.createBuffer(mpk.Data.toString('binary'))
|
throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
|
}
|
||||||
|
|
||||||
// create an asn1 object from the private key bytes saved in the protobuf Data: field
|
const privKey = await cryptoKeys.unmarshalPrivateKey(buf)
|
||||||
const asnPriv = forge.asn1.fromDer(fbuf)
|
return computePeerId(privKey, privKey.public)
|
||||||
|
}
|
||||||
// get the RSA privatekey data from the asn1 object
|
|
||||||
const privateKey = forge.pki.privateKeyFromAsn1(asnPriv)
|
exports.createFromJSON = async (obj) => {
|
||||||
|
const id = mh.fromB58String(obj.id)
|
||||||
// set the RSA public key to the modulus and exponent of the private key
|
const rawPrivKey = obj.privKey && Buffer.from(obj.privKey, 'base64')
|
||||||
const publicKey = forge.pki.rsa.setPublicKey(privateKey.n, privateKey.e)
|
const rawPubKey = obj.pubKey && Buffer.from(obj.pubKey, 'base64')
|
||||||
|
const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey)
|
||||||
// return the RSA public key to asn1 object
|
|
||||||
const asnPub = forge.pki.publicKeyToAsn1(publicKey)
|
if (!rawPrivKey) {
|
||||||
|
return new PeerIdWithIs(id, null, pub)
|
||||||
// format the public key
|
}
|
||||||
const protoPublic64 = formatKey(asnPub, 'Public')
|
|
||||||
|
const privKey = await cryptoKeys.unmarshalPrivateKey(rawPrivKey)
|
||||||
// buffer the public key for consistency before storing
|
const privDigest = await computeDigest(privKey.public)
|
||||||
const bufProtoPub64 = new Buffer(protoPublic64, 'base64')
|
|
||||||
const mhId = multihashing(new Buffer(protoPublic64, 'base64'), 'sha2-256')
|
let pubDigest
|
||||||
return new Id(mhId, privKey, bufProtoPub64)
|
|
||||||
|
if (pub) {
|
||||||
|
pubDigest = await computeDigest(pub)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pub && !privDigest.equals(pubDigest)) {
|
||||||
|
throw new Error('Public and private key do not match')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id && !privDigest.equals(id)) {
|
||||||
|
throw new Error('Id and private key do not match')
|
||||||
|
}
|
||||||
|
|
||||||
|
return new PeerIdWithIs(id, privKey, 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) {
|
||||||
|
if (val) {
|
||||||
|
return val.toString('base64')
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
enum KeyType {
|
|
||||||
RSA = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
message PublicKey {
|
|
||||||
required KeyType Type = 1;
|
|
||||||
required bytes Data = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
message PrivateKey {
|
|
||||||
required KeyType Type = 1;
|
|
||||||
required bytes Data = 2;
|
|
||||||
}
|
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
`)
|
6
test/fixtures/go-private-key.js
vendored
Normal file
6
test/fixtures/go-private-key.js
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
'use strict'
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
id: 'QmRLoXS3E73psYaUsma1VSbboTa2J8Z9kso1tpiGLk9WQ4',
|
||||||
|
privKey: 'CAASpwkwggSjAgEAAoIBAQDWBEbO8kc6a5kEks09CKPQargY3p0DCmCczoCT52/RYFqxvH9dI+s+u4ZAvF9aLWOBvFomL7jHZODPxKDrbiNCmyEbViNgZYK+PNbwh0V3ZGbB27X3q8yZtLvYA8dhcNkz/2SHBarSoC4QLA5MXUuSWtVaYMY3MzMnzBF57Jc9Ase7NvHOIUI90M7aN5izP7hxPXpZ+shiN+TyjM8mFxYONG7ZSsY3IxUhtrU5MRzFX+tp1o/gb/aa51mHf7AL3N02j5ABiYbCK97Rbwr03hsBcwgMxoDPJmP3WZ+D5yyPcOIIF1Vd7+4/f7FQJnIw3xr9/jvaFbPyDCVbBOhr9oyxAgMBAAECggEALlrgx2Q8v0+c5hux7p1XdgYXd/OHyKfPw0cLHH4NfylCm6q7X34vLvhJHO5wLMUV/3y/ffPqLu4Pr5DkVfoWExAsvJIMuY1jIzdkStbR2glaJHUlVc7VUxmNcj1nSxi5QwT3TjORC2v8bi5Mroeqnbmk6p15cW1akC0oP+NZ4rG48+WFHRqsBaBusdSOVfA+IiZUqSd1ILysJ1w7aVN3EC7jLjDG43i+P/2BcEHy8TVClGOknJL341bHe3UPdEpmeu6k6aHGlDI4blUMXahCIUh0IdZuj+Vi/TxQME9+3bKIOjQb8RCNm3U3j/uz5gs9SyTjBuYIib9Scj/jDbLh0QKBgQDfLr3go3Q/AR0jb12QjGALJz1lc9ZRX2RQJkqqmYkZwOlHHyl+YJgqOZiO80fUkN0sJ29CmKecXU4gXuHir913Fdceei1ScBSsvZpWtBLhEZXKrRJYq8U0atKUFQADDMGutyB/uGCNeNwR6VcJezHPICvHxQfmWlWHA5VIOEtRPQKBgQD1fID76SkIpF/EaJMnN2alXWWnzKhUBUPGpQtbpwgSfaCBiZ4vr3NQwKBntOOB5QwHmifNZMoqaFQLzC4B/uyTNUcQMQQ6arYav7WQXqXTmW6poTsjUSuSOPx1swsHlYX09SmUwWDfd94XF9UOU0KUfA2/c85ixzNlV5ejkFA4hQKBgEvP3uQN4hD82d8Nl2TgqkdfnvV1cdnWY4buWvK0kOPUqelk5n1tZoMBaZc1gLLuOpMjGiIvJNByyXUpheWxA7POEXLi4b5dIEjFZ0YIiVk21gEw5UiFoMl7d+ihcY2Xqbslrb507SdhZLAY6V3pITRQo06K2XIgQWlJiE4uATepAoGBALZ2vEiBnYZW5vfN4tKbUyhGq3B1pggNgbr8odyV4mIcDlk6OOGov0WeZ5ut0AyUesSLyFnaOIoc0ZuTP/8rxBwG1bMrO8FP39sx83pDX25P9PkQZixyALjGsp+pXOFeOhtAvo9azO5M4j638Bydtjc3neBX62dwOLtyx7tDYN0hAoGAVLmr3w7XMVHTfEuCSzKHyRrOaN2PAuSX31QAji1PwlwVKMylVrb8rRvBOpTicA/wXPX9Q5O/yjegqhqLT/LXAm9ziFzy5b9/9SzXPukKebXXbvc0FOmcsrcxtijlPyUzf9fKM1ShiwqqsgM9eNyZ9GWUJw2GFATCWW7pl7rtnWk='
|
||||||
|
}
|
8
test/fixtures/sample-id.js
vendored
Normal file
8
test/fixtures/sample-id.js
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
'use strict'
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
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==',
|
||||||
|
pubKey: 'CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC2SKo/HMFZeBml1AF3XijzrxrfQXdJzjePBZAbdxqKR1Mc6juRHXij6HXYPjlAk01BhF1S3Ll4Lwi0cAHhggf457sMg55UWyeGKeUv0ucgvCpBwlR5cQ020i0MgzjPWOLWq1rtvSbNcAi2ZEVn6+Q2EcHo3wUvWRtLeKz+DZSZfw2PEDC+DGPJPl7f8g7zl56YymmmzH9liZLNrzg/qidokUv5u1pdGrcpLuPNeTODk0cqKB+OUbuKj9GShYECCEjaybJDl9276oalL9ghBtSeEv20kugatTvYy590wFlJkkvyl+nPxIH0EEYMKK9XRWlu9XYnoSfboiwcv8M3SlsjAgMBAAE=',
|
||||||
|
marshaled: '0a22122019318b6e5e0cf93a2314bf01269a2cc23cd3dcd452d742cdb9379d8646f6e4a912ab02080012a60230820122300d06092a864886f70d01010105000382010f003082010a0282010100b648aa3f1cc1597819a5d401775e28f3af1adf417749ce378f05901b771a8a47531cea3b911d78a3e875d83e3940934d41845d52dcb9782f08b47001e18207f8e7bb0c839e545b278629e52fd2e720bc2a41c25479710d36d22d0c8338cf58e2d6ab5aedbd26cd7008b6644567ebe43611c1e8df052f591b4b78acfe0d94997f0d8f1030be0c63c93e5edff20ef3979e98ca69a6cc7f658992cdaf383faa2768914bf9bb5a5d1ab7292ee3cd79338393472a281f8e51bb8a8fd1928581020848dac9b24397ddbbea86a52fd82106d49e12fdb492e81ab53bd8cb9f74c05949924bf297e9cfc481f410460c28af5745696ef57627a127dba22c1cbfc3374a5b2302030100011aab09080012a609308204a20201000282010100b648aa3f1cc1597819a5d401775e28f3af1adf417749ce378f05901b771a8a47531cea3b911d78a3e875d83e3940934d41845d52dcb9782f08b47001e18207f8e7bb0c839e545b278629e52fd2e720bc2a41c25479710d36d22d0c8338cf58e2d6ab5aedbd26cd7008b6644567ebe43611c1e8df052f591b4b78acfe0d94997f0d8f1030be0c63c93e5edff20ef3979e98ca69a6cc7f658992cdaf383faa2768914bf9bb5a5d1ab7292ee3cd79338393472a281f8e51bb8a8fd1928581020848dac9b24397ddbbea86a52fd82106d49e12fdb492e81ab53bd8cb9f74c05949924bf297e9cfc481f410460c28af5745696ef57627a127dba22c1cbfc3374a5b2302030100010282010066d8eefdb70abca14fcf49a41e2689729c9ccbd4932a9868ae9093f37b2b055422e7d09d154e8c8fe68bff1b749023cc562809c3c3f7fd808427d27ead2f01b28584fb159412c26fb57a13eefccf1da02d337722d4765ddf4d8ccf5f86812f04a5dc7eec5e69f345c014b0d49c42f33b329fb6f58666659f49e0e7b25c1538d90bff5540cf02b2ec27ba864e12c5113b976344d8e9254873b30865357fbf19cd560a4a74b9020f58ac68ce0264ce5c36ca34a37fa88a2b010d5ba2fcc6a02c31de21886ad40a14ec72542c8ed4fb09613ec93be9196e105645113e2fb97ea693c447d6dd2c5c6cd6de42aca734efc87ec2e52bd394b53f52635e4ebca64dfe9102818100de2bc011d75dfbdccce26fabb3a631b380d44ccdd60db84c568f1cb1033cf9dcd011ef3acf1ef5ef7c8aa30d270b27835c44ed9375d85701f66838f547e64e0f24728b04f2ae5d9a56968a24080c84358efe3dde794bcafe6be32eb2b31a8183658dbe566d54e037c7207698a6f656db20596937a4996958cb40bdc9f13587eb02818100d20a1cc8b64a965f5d4236cb49f73272504db423b2eba720493601b582dbf3dd93144029f73f1c47b50ccdf67d4fd2649262cfa304a3eea12c982edd70c1ed74fe5a602f8ae4296537fe6d4ccadd2dbde27d59ca8787ab737006dbfdf5e95054ffa384960e299690f92e09bfbc8ffff6ca25e4d1afd3d9fdfacca32e66fba3a90281802e81ec10100c6d87d81fe28e87e9d767a3254dfa9cbf7c800672a8e7e92c9f8578ccf84e504343ea6120c8671d70395247436a943ecc0dd2ac593eeb21a4f55c381dfe3a07ef364af3ab49b9a731af8f62a29822f533478820df8acbffb021c276c4c83e615eae1d1f030db080eafa5d9e94f8f09bf53d57481d025dbeaf9d070281802edb0aa8cbe1bfc1ee7003013eb2e29215cfffcba6f2630a14caf37ea67ea2dc5f1f39612342f4f01a378d0adbd19ec1c8d63a33c7a93a66c22800ec6d6715adefc0018d1992e4992bf09a397357fc084c2a628987ca8038f458d362c8251042a5f4b873311d9df521615fd362214d9ca463e7b3cf619753cd4b316bfc954e610281806beec9501236f93a79f99999c60e1fbbd81c4b35d83006484ed0e09da5d212aa4d05d0fc5bcb6d8314e297644a62c88f5760fd42f303e226c4a11a6db213004f5979ebad9356733695b826d71eb664590a200431b71c65cd754e0c0160b28989728a7201a4fa68009652ce918b9966cc5a1dbcf91252e80417e8a1eb2b5a36bb'
|
||||||
|
}
|
357
test/peer-id.spec.js
Normal file
357
test/peer-id.spec.js
Normal file
@ -0,0 +1,357 @@
|
|||||||
|
/* 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 CID = require('cids')
|
||||||
|
|
||||||
|
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 testIdCID = new CID(1, 'libp2p-key', testIdBytes)
|
||||||
|
const testIdCIDString = testIdCID.toBaseEncodedString('base32')
|
||||||
|
|
||||||
|
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 from Hex string', () => {
|
||||||
|
const id = PeerId.createFromHexString(testIdHex)
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from a Buffer', () => {
|
||||||
|
const id = PeerId.createFromBytes(testIdBytes)
|
||||||
|
expect(testId.id).to.equal(id.toHexString())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from a B58 String', () => {
|
||||||
|
const id = PeerId.createFromB58String(testIdB58String)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from CID object', () => {
|
||||||
|
const id = PeerId.createFromCID(testIdCID)
|
||||||
|
expect(testIdCIDString).to.equal(id.toString())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from Base58 String (CIDv0))', () => {
|
||||||
|
const id = PeerId.createFromCID(testIdB58String)
|
||||||
|
expect(testIdCIDString).to.equal(id.toString())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from CIDv1 Base32 (libp2p-key multicodec)', () => {
|
||||||
|
const cid = new CID(1, 'libp2p-key', testIdBytes)
|
||||||
|
const cidString = cid.toBaseEncodedString('base32')
|
||||||
|
const id = PeerId.createFromCID(cidString)
|
||||||
|
expect(cidString).to.equal(id.toString())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from CIDv1 Base32 (dag-pb multicodec)', () => {
|
||||||
|
const cid = new CID(1, 'dag-pb', testIdBytes)
|
||||||
|
const cidString = cid.toBaseEncodedString('base32')
|
||||||
|
const id = PeerId.createFromCID(cidString)
|
||||||
|
// toString should return CID with multicodec set to libp2p-key
|
||||||
|
expect(new CID(id.toString()).codec).to.equal('libp2p-key')
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from CID Buffer', () => {
|
||||||
|
const id = PeerId.createFromCID(testIdCID.buffer)
|
||||||
|
expect(testIdCIDString).to.equal(id.toString())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws on invalid CID multicodec', () => {
|
||||||
|
// only libp2p and dag-pb are supported
|
||||||
|
const invalidCID = new CID(1, 'raw', testIdBytes).toBaseEncodedString('base32')
|
||||||
|
expect(() => {
|
||||||
|
PeerId.createFromCID(invalidCID)
|
||||||
|
}).to.throw(/Supplied PeerID CID has invalid multicodec: raw/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws on invalid CID value', () => {
|
||||||
|
// using function code that does not represent valid hash function
|
||||||
|
// https://github.com/multiformats/js-multihash/blob/b85999d5768bf06f1b0f16b926ef2cb6d9c14265/src/constants.js#L345
|
||||||
|
const invalidCID = 'QmaozNR7DZHQK1ZcU9p7QdrshMvXqWK6gpu5rmrkPdT3L'
|
||||||
|
expect(() => {
|
||||||
|
PeerId.createFromCID(invalidCID)
|
||||||
|
}).to.throw(/multihash unknown function code: 0x50/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws on invalid CID object', () => {
|
||||||
|
const invalidCID = {}
|
||||||
|
expect(() => {
|
||||||
|
PeerId.createFromCID(invalidCID)
|
||||||
|
}).to.throw(/Invalid version, must be a number equal to 1 or 0/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws on invalid CID object', () => {
|
||||||
|
const invalidCID = {}
|
||||||
|
expect(() => {
|
||||||
|
PeerId.createFromCID(invalidCID)
|
||||||
|
}).to.throw(/Invalid version, must be a number equal to 1 or 0/)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('recreate from a Public Key', async () => {
|
||||||
|
const id = await PeerId.createFromPubKey(testId.pubKey)
|
||||||
|
expect(testIdB58String).to.equal(id.toB58String())
|
||||||
|
expect(testIdBytes).to.deep.equal(id.toBytes())
|
||||||
|
})
|
||||||
|
|
||||||
|
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)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('equals', async () => {
|
||||||
|
const ids = await Promise.all([
|
||||||
|
PeerId.create(testOpts),
|
||||||
|
PeerId.create(testOpts)
|
||||||
|
])
|
||||||
|
|
||||||
|
expect(ids[0].equals(ids[0])).to.equal(true)
|
||||||
|
expect(ids[0].equals(ids[1])).to.equal(false)
|
||||||
|
expect(ids[0].equals(ids[0].id)).to.equal(true)
|
||||||
|
expect(ids[0].equals(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)
|
||||||
|
// @ts-ignore
|
||||||
|
peerId.privKey = peerId._privKey
|
||||||
|
expect(peerId.isValid()).to.equal(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set pubKey (valid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
// @ts-ignore
|
||||||
|
peerId.pubKey = peerId._pubKey
|
||||||
|
expect(peerId.isValid()).to.equal(true)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set privKey (invalid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
// @ts-ignore
|
||||||
|
peerId.privKey = Buffer.from('bufff')
|
||||||
|
expect(peerId.isValid()).to.equal(false)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('set pubKey (invalid)', async () => {
|
||||||
|
const peerId = await PeerId.create(testOpts)
|
||||||
|
// @ts-ignore
|
||||||
|
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/)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
@ -1,73 +0,0 @@
|
|||||||
/* globals describe, it */
|
|
||||||
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
const expect = require('chai').expect
|
|
||||||
const PeerId = require('../src')
|
|
||||||
|
|
||||||
const testId = {
|
|
||||||
id: '1220151ab1658d8294ab34b71d5582cfe20d06414212f440a69366f1bc31deb5c72d',
|
|
||||||
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='
|
|
||||||
}
|
|
||||||
|
|
||||||
const testIdHex = '1220151ab1658d8294ab34b71d5582cfe20d06414212f440a69366f1bc31deb5c72d'
|
|
||||||
|
|
||||||
const testIdBytes = new Buffer('1220151ab1658d8294ab34b71d5582cfe20d06414212f440a69366f1bc31deb5c72d', 'hex')
|
|
||||||
|
|
||||||
const testIdB58String = 'QmQ2zigjQikYnyYUSXZydNXrDRhBut2mubwJBaLXobMt3A'
|
|
||||||
|
|
||||||
describe('id', function (done) {
|
|
||||||
this.timeout(30000)
|
|
||||||
|
|
||||||
it('create a new id', (done) => {
|
|
||||||
const id = PeerId.create()
|
|
||||||
expect(id.toB58String().length).to.equal(46)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('recreate an Id from Hex string', (done) => {
|
|
||||||
const id = PeerId.createFromHexString(testIdHex)
|
|
||||||
expect(testIdBytes).to.deep.equal(id.id)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate an Id from a Buffer', (done) => {
|
|
||||||
const id = PeerId.createFromBytes(testIdBytes)
|
|
||||||
expect(testId.id).to.equal(id.toHexString())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate a B58 String', (done) => {
|
|
||||||
const id = PeerId.createFromB58String(testIdB58String)
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate from a Public Key', (done) => {
|
|
||||||
const id = PeerId.createFromPubKey(testId.pubKey)
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Recreate from a Private Key', (done) => {
|
|
||||||
const id = PeerId.createFromPrivKey(testId.privKey)
|
|
||||||
expect(testIdB58String).to.equal(id.toB58String())
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Compare generated ID with one created from PubKey', (done) => {
|
|
||||||
const id1 = PeerId.create()
|
|
||||||
const id2 = PeerId.createFromPubKey(id1.pubKey)
|
|
||||||
expect(id2.id).to.deep.equal(id1.id)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
|
|
||||||
it('Non-default # of bits', (done) => {
|
|
||||||
const shortId = PeerId.create({ bits: 128 })
|
|
||||||
const longId = PeerId.create({ bits: 256 })
|
|
||||||
expect(shortId.privKey.length).is.below(longId.privKey.length)
|
|
||||||
done()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
37
tsconfig.json
Normal file
37
tsconfig.json
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"module": "commonjs",
|
||||||
|
"lib": [
|
||||||
|
"es6"
|
||||||
|
],
|
||||||
|
"target": "ES5",
|
||||||
|
"noImplicitAny": false,
|
||||||
|
"noImplicitThis": true,
|
||||||
|
"strictFunctionTypes": true,
|
||||||
|
"strictNullChecks": true,
|
||||||
|
"esModuleInterop": true,
|
||||||
|
"resolveJsonModule": true,
|
||||||
|
"allowJs": true,
|
||||||
|
"checkJs": true,
|
||||||
|
"baseUrl": ".",
|
||||||
|
"paths": {
|
||||||
|
"peer-id": [
|
||||||
|
"./src",
|
||||||
|
"../src",
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"types": [
|
||||||
|
"node",
|
||||||
|
"mocha",
|
||||||
|
"chai"
|
||||||
|
],
|
||||||
|
"noEmit": true,
|
||||||
|
"forceConsistentCasingInFileNames": true
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"./src/index.d.ts",
|
||||||
|
],
|
||||||
|
"include": [
|
||||||
|
"./test/**/*.spec.js"
|
||||||
|
]
|
||||||
|
}
|
@ -1,29 +0,0 @@
|
|||||||
var path = require('path')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
name: 'peerid',
|
|
||||||
context: __dirname,
|
|
||||||
entry: './src/index.js',
|
|
||||||
output: {
|
|
||||||
path: path.join(__dirname, 'dist'),
|
|
||||||
filename: 'peer-id.js',
|
|
||||||
libraryTarget: 'var',
|
|
||||||
library: 'PeerId'
|
|
||||||
},
|
|
||||||
resolve: {
|
|
||||||
extensions: ['', '.js', '.json'],
|
|
||||||
alias: { 'node-forge': path.resolve(__dirname, 'deps/forge.bundle.js') }
|
|
||||||
},
|
|
||||||
externals: {
|
|
||||||
fs: '{}'
|
|
||||||
},
|
|
||||||
node: {
|
|
||||||
Buffer: true
|
|
||||||
},
|
|
||||||
module: {
|
|
||||||
loaders: [
|
|
||||||
{ test: /\.json$/, loader: 'json' }
|
|
||||||
],
|
|
||||||
noParse: []
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user