mirror of
https://github.com/fluencelabs/js-peer-id
synced 2025-07-04 08:51:55 +00:00
Compare commits
50 Commits
Author | SHA1 | Date | |
---|---|---|---|
9922f85693 | |||
843d35e1da | |||
ceeff130fa | |||
8f4027b136 | |||
90835484fe | |||
8bcd9a880e | |||
0bce8f7a87 | |||
8f15adbce5 | |||
fd072213b7 | |||
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 |
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,3 +1,4 @@
|
|||||||
|
docs
|
||||||
**/node_modules/
|
**/node_modules/
|
||||||
**/*.log
|
**/*.log
|
||||||
test/repo-tests*
|
test/repo-tests*
|
||||||
@ -41,4 +42,4 @@ test/test-data/go-ipfs-repo/LOG.old
|
|||||||
|
|
||||||
# while testing npm5
|
# while testing npm5
|
||||||
package-lock.json
|
package-lock.json
|
||||||
yarn.lock
|
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,31 +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: 6
|
- os: windows
|
||||||
env: CXX=g++-4.8
|
cache: false
|
||||||
- node_js: 8
|
|
||||||
env: CXX=g++-4.8
|
|
||||||
# - node_js: stable
|
|
||||||
# env: CXX=g++-4.8
|
|
||||||
|
|
||||||
script:
|
- stage: check
|
||||||
- npm run lint
|
script:
|
||||||
- npm run test
|
- npx aegir dep-check
|
||||||
- npm run coverage -- --upload
|
- npm run lint
|
||||||
|
|
||||||
before_script:
|
- stage: test
|
||||||
- export DISPLAY=:99.0
|
name: chrome
|
||||||
- sh -e /etc/init.d/xvfb start
|
addons:
|
||||||
|
chrome: stable
|
||||||
|
script:
|
||||||
|
- npx aegir test -t browser
|
||||||
|
- npx aegir test -t webworker
|
||||||
|
|
||||||
after_success:
|
- stage: test
|
||||||
- npm run coverage-publish
|
name: firefox
|
||||||
|
addons:
|
||||||
|
firefox: latest
|
||||||
|
script:
|
||||||
|
- npx aegir test -t browser -- --browsers FirefoxHeadless
|
||||||
|
- npx aegir test -t webworker -- --browsers FirefoxHeadless
|
||||||
|
|
||||||
addons:
|
notifications:
|
||||||
firefox: 'latest'
|
email: false
|
||||||
apt:
|
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
packages:
|
|
||||||
- g++-4.8
|
|
||||||
|
100
CHANGELOG.md
100
CHANGELOG.md
@ -1,3 +1,103 @@
|
|||||||
|
<a name="0.12.5"></a>
|
||||||
|
## [0.12.5](https://github.com/libp2p/js-peer-id/compare/v0.12.4...v0.12.5) (2019-09-25)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* inline public key handling for the 0.12.x line ([#102](https://github.com/libp2p/js-peer-id/issues/102)) ([ceeff13](https://github.com/libp2p/js-peer-id/commit/ceeff13))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.12.4"></a>
|
||||||
|
## [0.12.4](https://github.com/libp2p/js-peer-id/compare/v0.12.3...v0.12.4) (2019-07-23)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<a name="0.12.3"></a>
|
||||||
|
## [0.12.3](https://github.com/libp2p/js-peer-id/compare/v0.12.2...v0.12.3) (2019-07-11)
|
||||||
|
|
||||||
|
|
||||||
|
### Features
|
||||||
|
|
||||||
|
* **peerid:** support creating from secp256k1; harmonize algo with Go ([fd07221](https://github.com/libp2p/js-peer-id/commit/fd07221))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<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>
|
<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)
|
## [0.10.2](https://github.com/libp2p/js-peer-id/compare/v0.10.1...v0.10.2) (2017-10-12)
|
||||||
|
|
||||||
|
32
README.md
32
README.md
@ -1,16 +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)
|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
> [IPFS](https://github.com/ipfs/ipfs) Peer ID implementation in JavaScript.
|
> [IPFS](https://github.com/ipfs/ipfs) Peer ID implementation in JavaScript.
|
||||||
|
|
||||||
|
## Lead Maintainer
|
||||||
|
|
||||||
|
[Pedro Teixeira](https://github.com/pgte)
|
||||||
|
|
||||||
|
## Table of Contents
|
||||||
|
|
||||||
- [Description](#description)
|
- [Description](#description)
|
||||||
- [Example](#example)
|
- [Example](#example)
|
||||||
- [Installation](#installation)
|
- [Installation](#installation)
|
||||||
@ -51,7 +57,7 @@ The public key is a base64 encoded string of a protobuf containing an RSA DER bu
|
|||||||
```JavaScript
|
```JavaScript
|
||||||
const PeerId = require('peer-id')
|
const PeerId = require('peer-id')
|
||||||
|
|
||||||
PeerId.create({ bits: 1024 }, (err, id) => {
|
PeerId.create({ bits: 1024, keyType: 'rsa' }, (err, id) => {
|
||||||
if (err) { throw err }
|
if (err) { throw err }
|
||||||
console.log(JSON.stringify(id.toJSON(), null, 2))
|
console.log(JSON.stringify(id.toJSON(), null, 2))
|
||||||
})
|
})
|
||||||
@ -122,7 +128,7 @@ The key format is detailed in [libp2p-crypto](https://github.com/libp2p/js-libp2
|
|||||||
|
|
||||||
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`
|
- `callback: Function`
|
||||||
|
|
||||||
Calls back `callback` with `err, id`.
|
Calls back `callback` with `err, id`.
|
||||||
@ -138,6 +144,7 @@ Creates a Peer ID from hex string representing the key's multihash.
|
|||||||
Creates a Peer ID from a buffer representing the key's multihash.
|
Creates a Peer ID from a buffer representing the key's multihash.
|
||||||
|
|
||||||
### `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.
|
||||||
|
|
||||||
### `createFromPubKey(pubKey)`
|
### `createFromPubKey(pubKey)`
|
||||||
@ -155,8 +162,8 @@ Creates a Peer ID from a buffer containing a private key.
|
|||||||
### `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`
|
||||||
|
|
||||||
## Export
|
## Export
|
||||||
|
|
||||||
@ -192,10 +199,11 @@ 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'
|
||||||
|
|
||||||
|
|
||||||
### `toPrint()`
|
### `toPrint()`
|
||||||
|
|
||||||
Alias for `.toJSON()`.
|
Returns the Peer ID as a printable string without the `Qm` prefix.
|
||||||
|
|
||||||
|
Example: `<peer.ID xxxxxx>`
|
||||||
|
|
||||||
### `isEqual(id)`
|
### `isEqual(id)`
|
||||||
|
|
||||||
|
14
circle.yml
14
circle.yml
@ -1,14 +0,0 @@
|
|||||||
machine:
|
|
||||||
node:
|
|
||||||
version: stable
|
|
||||||
|
|
||||||
dependencies:
|
|
||||||
pre:
|
|
||||||
- google-chrome --version
|
|
||||||
- curl -L -o google-chrome.deb https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
|
|
||||||
- sudo dpkg -i google-chrome.deb || true
|
|
||||||
- sudo apt-get update
|
|
||||||
- sudo apt-get install -f
|
|
||||||
- sudo apt-get install --only-upgrade lsb-base
|
|
||||||
- sudo dpkg -i google-chrome.deb
|
|
||||||
- google-chrome --version
|
|
48
package.json
48
package.json
@ -1,7 +1,8 @@
|
|||||||
{
|
{
|
||||||
"name": "peer-id",
|
"name": "peer-id",
|
||||||
"version": "0.10.2",
|
"version": "0.12.5",
|
||||||
"description": "IPFS Peer Id implementation in Node.js",
|
"description": "IPFS Peer Id implementation in Node.js",
|
||||||
|
"leadMaintainer": "Pedro Teixeira <i@pgte.me>",
|
||||||
"main": "src/index.js",
|
"main": "src/index.js",
|
||||||
"bin": "src/bin.js",
|
"bin": "src/bin.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
@ -13,51 +14,62 @@
|
|||||||
"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",
|
||||||
|
"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": ">=6.0.0",
|
"node": ">=10.0.0",
|
||||||
"npm": ">=3.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": "^12.0.8",
|
"aegir": "^20.0.0",
|
||||||
"chai": "^4.1.2",
|
"bundlesize": "~0.17.1",
|
||||||
"dirty-chai": "^2.0.1",
|
"chai": "^4.2.0",
|
||||||
"pre-commit": "^1.2.2"
|
"dirty-chai": "^2.0.1"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"async": "^2.5.0",
|
"libp2p-crypto": "~0.16.1",
|
||||||
"libp2p-crypto": "~0.10.3",
|
"async": "^2.6.3",
|
||||||
"lodash": "^4.17.4",
|
"class-is": "^1.1.0",
|
||||||
"multihashes": "~0.4.9"
|
"multihashes": "~0.4.15"
|
||||||
},
|
},
|
||||||
"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>",
|
||||||
|
"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>",
|
"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@toppingdesign.com>",
|
||||||
|
"Vasco Santos <vasco.santos@ua.pt>",
|
||||||
|
"Vasco Santos <vasco.santos@moxy.studio>",
|
||||||
"Yahya <ya7yaz@gmail.com>",
|
"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>"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -9,5 +9,6 @@ PeerId.create((err, id) => {
|
|||||||
throw err
|
throw err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// eslint-disable-next-line
|
||||||
console.log(JSON.stringify(id.toJSON(), null, 2))
|
console.log(JSON.stringify(id.toJSON(), null, 2))
|
||||||
})
|
})
|
||||||
|
213
src/index.js
213
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 waterfall = require('async/waterfall')
|
||||||
|
const withIs = require('class-is')
|
||||||
|
|
||||||
class PeerId {
|
class PeerId {
|
||||||
constructor (id, privKey, pubKey) {
|
constructor (id, privKey, pubKey) {
|
||||||
@ -47,6 +48,13 @@ class PeerId {
|
|||||||
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
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
set pubKey (pubKey) {
|
set pubKey (pubKey) {
|
||||||
@ -56,20 +64,30 @@ class PeerId {
|
|||||||
// Return the protobuf version of the public key, matching go ipfs formatting
|
// Return the protobuf version of the public key, matching go ipfs formatting
|
||||||
marshalPubKey () {
|
marshalPubKey () {
|
||||||
if (this.pubKey) {
|
if (this.pubKey) {
|
||||||
return crypto.keys.marshalPublicKey(this.pubKey)
|
return cryptoKeys.marshalPublicKey(this.pubKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the protobuf version of the private key, matching go ipfs formatting
|
// Return the protobuf version of the private key, matching go ipfs formatting
|
||||||
marshalPrivKey () {
|
marshalPrivKey () {
|
||||||
if (this.privKey) {
|
if (this.privKey) {
|
||||||
return crypto.keys.marshalPrivateKey(this.privKey)
|
return cryptoKeys.marshalPrivateKey(this.privKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// pretty print
|
|
||||||
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
|
||||||
@ -122,7 +140,30 @@ class PeerId {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exports = module.exports = PeerId
|
const PeerIdWithIs = withIs(PeerId, { className: 'PeerId', symbolName: '@libp2p/js-peer-id/PeerId' })
|
||||||
|
|
||||||
|
exports = module.exports = PeerIdWithIs
|
||||||
|
|
||||||
|
const computeDigest = (pubKey, cb) => {
|
||||||
|
if (pubKey.bytes.length <= 42) {
|
||||||
|
const digest = mh.encode(pubKey.bytes, 'identity')
|
||||||
|
cb(null, digest)
|
||||||
|
} else {
|
||||||
|
pubKey.hash((err, digest) => {
|
||||||
|
cb(err, digest)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const computePeerId = (privKey, pubKey, cb) => {
|
||||||
|
computeDigest(pubKey, (err, digest) => {
|
||||||
|
if (err != null) {
|
||||||
|
cb(err)
|
||||||
|
} else {
|
||||||
|
cb(null, new PeerIdWithIs(digest, privKey, pubKey))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// generation
|
// generation
|
||||||
exports.create = function (opts, callback) {
|
exports.create = function (opts, callback) {
|
||||||
@ -132,31 +173,27 @@ exports.create = function (opts, callback) {
|
|||||||
}
|
}
|
||||||
opts = opts || {}
|
opts = opts || {}
|
||||||
opts.bits = opts.bits || 2048
|
opts.bits = opts.bits || 2048
|
||||||
|
opts.keyType = opts.keyType || 'RSA'
|
||||||
|
|
||||||
waterfall([
|
cryptoKeys.generateKeyPair(opts.keyType, opts.bits, (err, privKey) => {
|
||||||
(cb) => crypto.keys.generateKeyPair('RSA', opts.bits, cb),
|
if (err != null) {
|
||||||
(privKey, cb) => privKey.public.hash((err, digest) => {
|
callback(err)
|
||||||
cb(err, digest, privKey)
|
} else {
|
||||||
})
|
computePeerId(privKey, privKey.public, callback)
|
||||||
], (err, digest, privKey) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, new PeerId(digest, privKey))
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromHexString = function (str) {
|
exports.createFromHexString = function (str) {
|
||||||
return new PeerId(mh.fromHexString(str))
|
return new PeerIdWithIs(mh.fromHexString(str))
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromBytes = function (buf) {
|
exports.createFromBytes = function (buf) {
|
||||||
return new PeerId(buf)
|
return new PeerIdWithIs(buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.createFromB58String = function (str) {
|
exports.createFromB58String = function (str) {
|
||||||
return new PeerId(mh.fromB58String(str))
|
return new PeerIdWithIs(mh.fromB58String(str))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public Key input will be a buffer
|
// Public Key input will be a buffer
|
||||||
@ -165,44 +202,48 @@ exports.createFromPubKey = function (key, callback) {
|
|||||||
throw new Error('callback is required')
|
throw new Error('callback is required')
|
||||||
}
|
}
|
||||||
|
|
||||||
let buf = key
|
let pubKey
|
||||||
if (typeof buf === 'string') {
|
|
||||||
buf = Buffer.from(key, 'base64')
|
|
||||||
}
|
|
||||||
|
|
||||||
const pubKey = crypto.keys.unmarshalPublicKey(buf)
|
try {
|
||||||
|
let buf = key
|
||||||
pubKey.hash((err, digest) => {
|
if (typeof buf === 'string') {
|
||||||
if (err) {
|
buf = Buffer.from(key, 'base64')
|
||||||
return callback(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, new PeerId(digest, null, pubKey))
|
if (!Buffer.isBuffer(buf)) throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
})
|
|
||||||
|
pubKey = cryptoKeys.unmarshalPublicKey(buf)
|
||||||
|
} catch (err) {
|
||||||
|
return callback(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
computePeerId(null, pubKey, callback)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Private key input will be a string
|
// Private key input will be a string
|
||||||
exports.createFromPrivKey = function (key, callback) {
|
exports.createFromPrivKey = function (key, callback) {
|
||||||
let buf = key
|
|
||||||
if (typeof buf === 'string') {
|
|
||||||
buf = Buffer.from(key, 'base64')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof callback !== 'function') {
|
if (typeof callback !== 'function') {
|
||||||
throw new Error('callback is required')
|
throw new Error('callback is required')
|
||||||
}
|
}
|
||||||
|
|
||||||
waterfall([
|
let buf = key
|
||||||
(cb) => crypto.keys.unmarshalPrivateKey(buf, cb),
|
|
||||||
(privKey, cb) => privKey.public.hash((err, digest) => {
|
try {
|
||||||
cb(err, digest, privKey)
|
if (typeof buf === 'string') {
|
||||||
})
|
buf = Buffer.from(key, 'base64')
|
||||||
], (err, digest, privKey) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, new PeerId(digest, privKey, privKey.public))
|
if (!Buffer.isBuffer(buf)) throw new Error('Supplied key is neither a base64 string nor a buffer')
|
||||||
|
} catch (err) {
|
||||||
|
return callback(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cryptoKeys.unmarshalPrivateKey(buf, (err, privKey) => {
|
||||||
|
if (err != null) {
|
||||||
|
callback(err)
|
||||||
|
} else {
|
||||||
|
computePeerId(privKey, privKey.public, callback)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -211,44 +252,56 @@ exports.createFromJSON = function (obj, callback) {
|
|||||||
throw new Error('callback is required')
|
throw new Error('callback is required')
|
||||||
}
|
}
|
||||||
|
|
||||||
const id = mh.fromB58String(obj.id)
|
let id
|
||||||
const rawPrivKey = obj.privKey && Buffer.from(obj.privKey, 'base64')
|
let rawPrivKey
|
||||||
const rawPubKey = obj.pubKey && Buffer.from(obj.pubKey, 'base64')
|
let rawPubKey
|
||||||
const pub = rawPubKey && crypto.keys.unmarshalPublicKey(rawPubKey)
|
let pub
|
||||||
|
|
||||||
if (rawPrivKey) {
|
try {
|
||||||
waterfall([
|
id = mh.fromB58String(obj.id)
|
||||||
(cb) => crypto.keys.unmarshalPrivateKey(rawPrivKey, cb),
|
rawPrivKey = obj.privKey && Buffer.from(obj.privKey, 'base64')
|
||||||
(priv, cb) => priv.public.hash((err, digest) => {
|
rawPubKey = obj.pubKey && Buffer.from(obj.pubKey, 'base64')
|
||||||
cb(err, digest, priv)
|
pub = rawPubKey && cryptoKeys.unmarshalPublicKey(rawPubKey)
|
||||||
}),
|
} catch (err) {
|
||||||
(privDigest, priv, cb) => {
|
return callback(err)
|
||||||
if (pub) {
|
|
||||||
pub.hash((err, pubDigest) => {
|
|
||||||
cb(err, privDigest, priv, pubDigest)
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
cb(null, privDigest, priv)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
], (err, privDigest, priv, pubDigest) => {
|
|
||||||
if (err) {
|
|
||||||
return callback(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pub && !privDigest.equals(pubDigest)) {
|
|
||||||
return callback(new Error('Public and private key do not match'))
|
|
||||||
}
|
|
||||||
|
|
||||||
if (id && !privDigest.equals(id)) {
|
|
||||||
return callback(new Error('Id and private key do not match'))
|
|
||||||
}
|
|
||||||
|
|
||||||
callback(null, new PeerId(id, priv, pub))
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
callback(null, new PeerId(id, null, pub))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!rawPrivKey) {
|
||||||
|
callback(null, new PeerIdWithIs(id, null, pub))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
waterfall([
|
||||||
|
(cb) => cryptoKeys.unmarshalPrivateKey(rawPrivKey, cb),
|
||||||
|
(priv, cb) => {
|
||||||
|
computeDigest(priv.public, (err, digest) => {
|
||||||
|
cb(err, digest, priv)
|
||||||
|
})
|
||||||
|
},
|
||||||
|
(privDigest, priv, cb) => {
|
||||||
|
if (pub) {
|
||||||
|
computeDigest(pub, (err, pubDigest) => {
|
||||||
|
cb(err, privDigest, priv, pubDigest)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
cb(null, privDigest, priv)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
], (err, privDigest, priv, pubDigest) => {
|
||||||
|
if (err) {
|
||||||
|
return callback(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pub && !privDigest.equals(pubDigest)) {
|
||||||
|
return callback(new Error('Public and private key do not match'))
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id && !privDigest.equals(id)) {
|
||||||
|
return callback(new Error('Id and private key do not match'))
|
||||||
|
}
|
||||||
|
|
||||||
|
callback(null, new PeerIdWithIs(id, priv, pub))
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.isPeerId = function (peerId) {
|
exports.isPeerId = function (peerId) {
|
||||||
|
@ -9,9 +9,12 @@ const expect = chai.expect
|
|||||||
const crypto = require('libp2p-crypto')
|
const crypto = require('libp2p-crypto')
|
||||||
const mh = require('multihashes')
|
const mh = require('multihashes')
|
||||||
const parallel = require('async/parallel')
|
const parallel = require('async/parallel')
|
||||||
|
const waterfall = require('async/waterfall')
|
||||||
|
|
||||||
const PeerId = require('../src')
|
const PeerId = require('../src')
|
||||||
|
|
||||||
|
const util = require('util')
|
||||||
|
|
||||||
const testId = require('./fixtures/sample-id')
|
const testId = require('./fixtures/sample-id')
|
||||||
const testIdHex = testId.id
|
const testIdHex = testId.id
|
||||||
const testIdBytes = mh.fromHexString(testId.id)
|
const testIdBytes = mh.fromHexString(testId.id)
|
||||||
@ -19,21 +22,46 @@ const testIdB58String = mh.toB58String(testIdBytes)
|
|||||||
|
|
||||||
const goId = require('./fixtures/go-private-key')
|
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', () => {
|
describe('PeerId', () => {
|
||||||
it('create an id without \'new\'', () => {
|
it('create an id without \'new\'', () => {
|
||||||
expect(PeerId).to.throw(Error)
|
expect(PeerId).to.throw(Error)
|
||||||
})
|
})
|
||||||
|
|
||||||
it('create a new id', (done) => {
|
it('create a new id', (done) => {
|
||||||
PeerId.create((err, id) => {
|
PeerId.create(testOpts, (err, id) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(id.toB58String().length).to.equal(46)
|
expect(id.toB58String().length).to.equal(46)
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('can be created for a Secp256k1 key', (done) => {
|
||||||
|
PeerId.create({ keyType: 'secp256k1', bits: 256 }, (err, id) => {
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('can get the public key from a Secp256k1 key', (done) => {
|
||||||
|
PeerId.create({ keyType: 'secp256k1', bits: 256 }, (err, original) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
|
||||||
|
const newId = PeerId.createFromB58String(original.toB58String())
|
||||||
|
expect(original.pubKey.bytes).to.eql(newId.pubKey.bytes)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
it('isPeerId', (done) => {
|
it('isPeerId', (done) => {
|
||||||
PeerId.create((err, id) => {
|
PeerId.create(testOpts, (err, id) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(PeerId.isPeerId(id)).to.equal(true)
|
expect(PeerId.isPeerId(id)).to.equal(true)
|
||||||
expect(PeerId.isPeerId('aaa')).to.equal(false)
|
expect(PeerId.isPeerId('aaa')).to.equal(false)
|
||||||
@ -42,8 +70,9 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('throws on changing the id', (done) => {
|
it('throws on changing the id', function (done) {
|
||||||
PeerId.create((err, id) => {
|
this.timeout(10000)
|
||||||
|
PeerId.create(testOpts, (err, id) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(id.toB58String().length).to.equal(46)
|
expect(id.toB58String().length).to.equal(46)
|
||||||
expect(() => {
|
expect(() => {
|
||||||
@ -76,6 +105,22 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('can be created from a Secp256k1 public key', (done) => {
|
||||||
|
waterfall([
|
||||||
|
(cb) => {
|
||||||
|
crypto.keys.generateKeyPair('secp256k1', 256, cb)
|
||||||
|
},
|
||||||
|
(privKey, cb) => {
|
||||||
|
PeerId.createFromPubKey(privKey.public.bytes, cb)
|
||||||
|
}
|
||||||
|
], (err, id) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
it('Recreate from a Private Key', (done) => {
|
it('Recreate from a Private Key', (done) => {
|
||||||
PeerId.createFromPrivKey(testId.privKey, (err, id) => {
|
PeerId.createFromPrivKey(testId.privKey, (err, id) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
@ -91,8 +136,24 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('can be created from a Secp256k1 private key', (done) => {
|
||||||
|
waterfall([
|
||||||
|
(cb) => {
|
||||||
|
crypto.keys.generateKeyPair('secp256k1', 256, cb)
|
||||||
|
},
|
||||||
|
(privKey, cb) => {
|
||||||
|
PeerId.createFromPrivKey(privKey.bytes, cb)
|
||||||
|
}
|
||||||
|
], (err, id) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
const expB58 = mh.toB58String(mh.encode(id.pubKey.bytes, 'identity'))
|
||||||
|
expect(id.toB58String()).to.equal(expB58)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
it('Compare generated ID with one created from PubKey', (done) => {
|
it('Compare generated ID with one created from PubKey', (done) => {
|
||||||
PeerId.create((err, id1) => {
|
PeerId.create(testOpts, (err, id1) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
|
|
||||||
PeerId.createFromPubKey(id1.marshalPubKey(), (err, id2) => {
|
PeerId.createFromPubKey(id1.marshalPubKey(), (err, id2) => {
|
||||||
@ -103,12 +164,20 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('Non-default # of bits', function (done) {
|
it('Works with default options', function (done) {
|
||||||
// rsa is slow atm
|
this.timeout(10000)
|
||||||
this.timeout(100000)
|
PeerId.create((err, id) => {
|
||||||
PeerId.create({ bits: 1024 }, (err, shortId) => {
|
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
PeerId.create({ bits: 4096 }, (err, longId) => {
|
expect(id.toB58String().length).to.equal(46)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('Non-default # of bits', function (done) {
|
||||||
|
this.timeout(1000 * 60)
|
||||||
|
PeerId.create(testOpts, (err, shortId) => {
|
||||||
|
expect(err).to.not.exist()
|
||||||
|
PeerId.create({ bits: 1024 }, (err, longId) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(shortId.privKey.bytes.length).is.below(longId.privKey.bytes.length)
|
expect(shortId.privKey.bytes.length).is.below(longId.privKey.bytes.length)
|
||||||
done()
|
done()
|
||||||
@ -117,11 +186,12 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('Pretty printing', (done) => {
|
it('Pretty printing', (done) => {
|
||||||
PeerId.create((err, id1) => {
|
PeerId.create(testOpts, (err, id1) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
PeerId.createFromPrivKey(id1.toPrint().privKey, (err, id2) => {
|
PeerId.createFromPrivKey(id1.toJSON().privKey, (err, id2) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(id1.toPrint()).to.be.eql(id2.toPrint())
|
expect(id1.toPrint()).to.be.eql(id2.toPrint())
|
||||||
|
expect(id1.toPrint()).to.equal('<peer.ID ' + id1.toB58String().substr(2, 6) + '>')
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
@ -134,8 +204,8 @@ describe('PeerId', () => {
|
|||||||
|
|
||||||
it('isEqual', (done) => {
|
it('isEqual', (done) => {
|
||||||
parallel([
|
parallel([
|
||||||
(cb) => PeerId.create(cb),
|
(cb) => PeerId.create(testOpts, cb),
|
||||||
(cb) => PeerId.create(cb)
|
(cb) => PeerId.create(testOpts, cb)
|
||||||
], (err, ids) => {
|
], (err, ids) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
expect(ids[0].isEqual(ids[0])).to.equal(true)
|
expect(ids[0].isEqual(ids[0])).to.equal(true)
|
||||||
@ -148,7 +218,7 @@ describe('PeerId', () => {
|
|||||||
|
|
||||||
describe('fromJSON', () => {
|
describe('fromJSON', () => {
|
||||||
it('full node', (done) => {
|
it('full node', (done) => {
|
||||||
PeerId.create({ bits: 1024 }, (err, id) => {
|
PeerId.create(testOpts, (err, id) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
|
|
||||||
PeerId.createFromJSON(id.toJSON(), (err, other) => {
|
PeerId.createFromJSON(id.toJSON(), (err, other) => {
|
||||||
@ -193,7 +263,7 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('set privKey (valid)', (done) => {
|
it('set privKey (valid)', (done) => {
|
||||||
PeerId.create((err, peerId) => {
|
PeerId.create(testOpts, (err, peerId) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
peerId.privKey = peerId._privKey
|
peerId.privKey = peerId._privKey
|
||||||
peerId.isValid(done)
|
peerId.isValid(done)
|
||||||
@ -201,7 +271,7 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('set pubKey (valid)', (done) => {
|
it('set pubKey (valid)', (done) => {
|
||||||
PeerId.create((err, peerId) => {
|
PeerId.create(testOpts, (err, peerId) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
peerId.pubKey = peerId._pubKey
|
peerId.pubKey = peerId._pubKey
|
||||||
peerId.isValid(done)
|
peerId.isValid(done)
|
||||||
@ -209,7 +279,7 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('set privKey (invalid)', (done) => {
|
it('set privKey (invalid)', (done) => {
|
||||||
PeerId.create((err, peerId) => {
|
PeerId.create(testOpts, (err, peerId) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
peerId.privKey = Buffer.from('bufff')
|
peerId.privKey = Buffer.from('bufff')
|
||||||
peerId.isValid((err) => {
|
peerId.isValid((err) => {
|
||||||
@ -220,7 +290,7 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('set pubKey (invalid)', (done) => {
|
it('set pubKey (invalid)', (done) => {
|
||||||
PeerId.create((err, peerId) => {
|
PeerId.create(testOpts, (err, peerId) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
peerId.pubKey = Buffer.from('buffff')
|
peerId.pubKey = Buffer.from('buffff')
|
||||||
peerId.isValid((err) => {
|
peerId.isValid((err) => {
|
||||||
@ -230,6 +300,24 @@ describe('PeerId', () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
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']
|
||||||
|
|
||||||
|
garbage.forEach(garbage => {
|
||||||
|
fncs.forEach(fnc => {
|
||||||
|
it(fnc + '(' + util.inspect(garbage) + ')', cb => {
|
||||||
|
PeerId[fnc](garbage, (err, res) => {
|
||||||
|
expect(err).to.exist()
|
||||||
|
expect(res).to.not.exist()
|
||||||
|
cb()
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
describe('throws on inconsistent data', () => {
|
describe('throws on inconsistent data', () => {
|
||||||
let k1
|
let k1
|
||||||
let k2
|
let k2
|
||||||
@ -237,9 +325,9 @@ describe('PeerId', () => {
|
|||||||
|
|
||||||
before((done) => {
|
before((done) => {
|
||||||
parallel([
|
parallel([
|
||||||
(cb) => crypto.keys.generateKeyPair('RSA', 1024, cb),
|
(cb) => crypto.keys.generateKeyPair('RSA', 512, cb),
|
||||||
(cb) => crypto.keys.generateKeyPair('RSA', 1024, cb),
|
(cb) => crypto.keys.generateKeyPair('RSA', 512, cb),
|
||||||
(cb) => crypto.keys.generateKeyPair('RSA', 1024, cb)
|
(cb) => crypto.keys.generateKeyPair('RSA', 512, cb)
|
||||||
], (err, keys) => {
|
], (err, keys) => {
|
||||||
expect(err).to.not.exist()
|
expect(err).to.not.exist()
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user