Compare commits

...

30 Commits

Author SHA1 Message Date
ecc1e5be6d chore: release version v0.14.1 2020-09-03 18:49:02 +02:00
153bc8ea38 chore: update contributors 2020-09-03 18:49:01 +02:00
d40d588776 fix: ts constructor types (#130) 2020-08-26 11:46:38 +02:00
224b30cb65 fix: privKey possible undefined (#129) 2020-08-17 16:35:13 +02:00
6d571ae196 fix: typo in readme (#128) 2020-08-12 13:40:13 +02:00
ff4bd96467 chore: release version v0.14.0 2020-08-07 17:41:53 +02:00
427b46c86e chore: update contributors 2020-08-07 17:41:52 +02:00
d16ce9c2ac fix: replace node buffers with uint8arrays (#127)
* fix: replace node buffers with uint8arrays

Replaces all uses of node Buffers with Uint8Arrays

BREAKING CHANGES:

- Where node Buffers were returned, now Uint8Arrays are

* chore: remove gh dep
2020-08-07 17:36:22 +02:00
cd99cb2c7d chore: release version v0.13.13 2020-06-23 18:58:05 +02:00
c295329300 chore: update contributors 2020-06-23 18:58:04 +02:00
bb32b12395 chore: update deps (#126)
Allows for deduping multihashes module
2020-06-23 18:43:30 +02:00
6fd5ca2a12 chore(deps-dev): bump aegir from 21.10.2 to 22.0.0 (#124)
Bumps [aegir](https://github.com/ipfs/aegir) from 21.10.2 to 22.0.0.
- [Release notes](https://github.com/ipfs/aegir/releases)
- [Changelog](https://github.com/ipfs/aegir/blob/master/CHANGELOG.md)
- [Commits](https://github.com/ipfs/aegir/compare/v21.10.2...v22.0.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>

Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>
2020-05-28 18:10:20 +02:00
020b963711 chore: release version v0.13.12 2020-04-22 16:35:07 +02:00
e3da29a440 chore: update contributors 2020-04-22 16:35:07 +02:00
8cd9dfb137 feat(cli): add support for specifying type and size (#122) 2020-04-22 16:32:38 +02:00
3598a433dc chore: release version v0.13.11 2020-03-26 09:07:55 +01:00
5ec88281e2 chore: update contributors 2020-03-26 09:07:55 +01:00
a80c481146 chore(deps): bump cids from 0.7.5 to 0.8.0 (#121)
Bumps [cids](https://github.com/multiformats/js-cid) from 0.7.5 to 0.8.0.
- [Release notes](https://github.com/multiformats/js-cid/releases)
- [Changelog](https://github.com/multiformats/js-cid/blob/master/CHANGELOG.md)
- [Commits](https://github.com/multiformats/js-cid/compare/v0.7.5...v0.8.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>

Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>
2020-03-26 09:05:51 +01:00
efc96106a4 chore: release version v0.13.10 2020-03-18 17:38:41 +01:00
16e1c74e9a chore: update contributors 2020-03-18 17:38:40 +01:00
c305c36b26 fix: add buffer (#120)
related to this https://github.com/ipfs/js-ipfs/issues/2924
2020-03-18 17:33:29 +01:00
7e985b127f chore(deps-dev): bump @types/mocha from 5.2.7 to 7.0.2 (#119)
Bumps [@types/mocha](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/mocha) from 5.2.7 to 7.0.2.
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/mocha)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2020-03-04 14:23:01 +01:00
40d68cb512 chore(deps-dev): bump aegir from 20.6.1 to 21.2.0
Bumps [aegir](https://github.com/ipfs/aegir) from 20.6.1 to 21.2.0.
- [Release notes](https://github.com/ipfs/aegir/releases)
- [Changelog](https://github.com/ipfs/aegir/blob/master/CHANGELOG.md)
- [Commits](https://github.com/ipfs/aegir/compare/v20.6.1...v21.2.0)

Signed-off-by: dependabot-preview[bot] <support@dependabot.com>
2020-02-20 08:14:43 -05:00
1d86506c64 chore: release version v0.13.9 2020-02-19 12:06:43 -05:00
9dc7ce5f5e chore: update contributors 2020-02-19 12:06:42 -05:00
f775e3509b chore: update index.d.ts (#115)
Tell Typescript that `isPeerId(id)` returns true if, and only if, `id` is of type `PeerId`.

See https://www.typescriptlang.org/docs/handbook/advanced-types.html#using-type-predicates
2020-02-19 11:51:59 -05:00
00819ba4eb chore: update index.d.ts (#116)
This tells Typescript that `id` is immutable.
2020-02-19 09:17:30 -05:00
6870c8c4d7 chore: release version v0.13.8 2020-02-18 08:44:53 -05:00
71d3a100c9 chore: update contributors 2020-02-18 08:44:52 -05:00
f44645ef7e fix: remove use of assert module (#117)
The polyfill is big, we can simulate it by throwing an Error and it doesn't work under React Native.
2020-02-18 08:42:39 -05:00
8 changed files with 205 additions and 96 deletions

7
.aegir.js Normal file
View File

@ -0,0 +1,7 @@
'use strict'
module.exports = {
bundlesize: {
maxSize: '140kB'
}
}

View File

@ -1,3 +1,90 @@
<a name="0.14.1"></a>
## [0.14.1](https://github.com/libp2p/js-peer-id/compare/v0.13.13...v0.14.1) (2020-09-03)
### Bug Fixes
* privKey possible undefined ([#129](https://github.com/libp2p/js-peer-id/issues/129)) ([224b30c](https://github.com/libp2p/js-peer-id/commit/224b30c))
* replace node buffers with uint8arrays ([#127](https://github.com/libp2p/js-peer-id/issues/127)) ([d16ce9c](https://github.com/libp2p/js-peer-id/commit/d16ce9c))
* ts constructor types ([#130](https://github.com/libp2p/js-peer-id/issues/130)) ([d40d588](https://github.com/libp2p/js-peer-id/commit/d40d588))
* typo in readme ([#128](https://github.com/libp2p/js-peer-id/issues/128)) ([6d571ae](https://github.com/libp2p/js-peer-id/commit/6d571ae))
### BREAKING CHANGES
* - Where node Buffers were returned, now Uint8Arrays are
* chore: remove gh dep
<a name="0.14.0"></a>
# [0.14.0](https://github.com/libp2p/js-peer-id/compare/v0.13.13...v0.14.0) (2020-08-07)
### Bug Fixes
* replace node buffers with uint8arrays ([#127](https://github.com/libp2p/js-peer-id/issues/127)) ([d16ce9c](https://github.com/libp2p/js-peer-id/commit/d16ce9c))
### BREAKING CHANGES
* - Where node Buffers were returned, now Uint8Arrays are
* chore: remove gh dep
<a name="0.13.13"></a>
## [0.13.13](https://github.com/libp2p/js-peer-id/compare/v0.13.12...v0.13.13) (2020-06-23)
<a name="0.13.12"></a>
## [0.13.12](https://github.com/libp2p/js-peer-id/compare/v0.13.11...v0.13.12) (2020-04-22)
### Features
* **cli:** add support for specifying type and size ([#122](https://github.com/libp2p/js-peer-id/issues/122)) ([8cd9dfb](https://github.com/libp2p/js-peer-id/commit/8cd9dfb))
<a name="0.13.11"></a>
## [0.13.11](https://github.com/libp2p/js-peer-id/compare/v0.13.10...v0.13.11) (2020-03-26)
<a name="0.13.10"></a>
## [0.13.10](https://github.com/libp2p/js-peer-id/compare/v0.13.9...v0.13.10) (2020-03-18)
### Bug Fixes
* add buffer ([#120](https://github.com/libp2p/js-peer-id/issues/120)) ([c305c36](https://github.com/libp2p/js-peer-id/commit/c305c36))
<a name="0.13.9"></a>
## [0.13.9](https://github.com/libp2p/js-peer-id/compare/v0.13.8...v0.13.9) (2020-02-19)
<a name="0.13.8"></a>
## [0.13.8](https://github.com/libp2p/js-peer-id/compare/v0.13.6...v0.13.8) (2020-02-18)
### Bug Fixes
* remove use of assert module ([#117](https://github.com/libp2p/js-peer-id/issues/117)) ([f44645e](https://github.com/libp2p/js-peer-id/commit/f44645e))
### 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.7"></a> <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) ## [0.13.7](https://github.com/libp2p/js-peer-id/compare/v0.13.6...v0.13.7) (2020-01-27)

View File

@ -28,6 +28,7 @@
- [Node.js](#nodejs) - [Node.js](#nodejs)
- [Browser: Browserify, Webpack, other bundlers](#browser-browserify-webpack-other-bundlers) - [Browser: Browserify, Webpack, other bundlers](#browser-browserify-webpack-other-bundlers)
- [Browser: `<script>` Tag](#browser-script-tag) - [Browser: `<script>` Tag](#browser-script-tag)
- [CLI](#cli)
- [API](#api) - [API](#api)
- [Create](#create) - [Create](#create)
- [`new PeerId(id[, privKey, pubKey])`](#new-peeridid-privkey-pubkey) - [`new PeerId(id[, privKey, pubKey])`](#new-peeridid-privkey-pubkey)
@ -117,6 +118,14 @@ the global namespace.
<script src="https://unpkg.com/peer-id/dist/index.js"></script> <script src="https://unpkg.com/peer-id/dist/index.js"></script>
``` ```
# CLI
After installing `peer-id`, `npm install peer-id`, you can leverage the cli to generate keys exported as JSON. You can specify the type for the key and size, as detailed in [`create([opts])`](#createopts). The defaults are shown here.
```sh
> peer-id --type rsa --bits 2048
```
# API # API
```js ```js
@ -137,7 +146,8 @@ 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, keyType: 'rsa'}` - `opts.bits: number` - The size of the key. Default: `2048`
- `opts.keyType: string` - The key type, one of: `['rsa', 'ed25519', 'secp256k1']`. Default: `rsa`
Returns `Promise<PeerId>`. Returns `Promise<PeerId>`.
@ -147,7 +157,7 @@ Returns `Promise<PeerId>`.
Creates a Peer ID from hex string representing the key's multihash. Creates a Peer ID from hex string representing the key's multihash.
Returns `PeerId. Returns `PeerId`.
### `createFromBytes(buf)` ### `createFromBytes(buf)`

View File

@ -1,6 +1,6 @@
{ {
"name": "peer-id", "name": "peer-id",
"version": "0.13.7", "version": "0.14.1",
"description": "IPFS Peer Id implementation in Node.js", "description": "IPFS Peer Id implementation in Node.js",
"leadMaintainer": "Vasco Santos <santos.vasco10@gmail.com>", "leadMaintainer": "Vasco Santos <santos.vasco10@gmail.com>",
"main": "src/index.js", "main": "src/index.js",
@ -17,7 +17,7 @@
"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" "size": "aegir build -b"
}, },
"files": [ "files": [
"src", "src",
@ -38,49 +38,48 @@
"devDependencies": { "devDependencies": {
"@types/chai": "^4.2.7", "@types/chai": "^4.2.7",
"@types/dirty-chai": "^2.0.2", "@types/dirty-chai": "^2.0.2",
"@types/mocha": "^5.2.7", "@types/mocha": "^8.0.1",
"aegir": "^20.0.0", "aegir": "^25.0.0"
"bundlesize": "~0.18.0",
"chai": "^4.2.0",
"dirty-chai": "^2.0.1"
}, },
"dependencies": { "dependencies": {
"cids": "^0.7.3", "cids": "^1.0.0",
"class-is": "^1.1.0", "class-is": "^1.1.0",
"libp2p-crypto": "~0.17.2", "libp2p-crypto": "^0.18.0",
"multihashes": "~0.4.15", "minimist": "^1.2.5",
"protons": "^1.0.1" "multihashes": "^3.0.1",
"protons": "^2.0.0",
"uint8arrays": "^1.1.0"
}, },
"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": [
"David Dias <daviddias.p@gmail.com>",
"Vasco Santos <vasco.santos@moxy.studio>",
"nginnever <ginneversource@gmail.com>",
"dignifiedquire <dignifiedquire@gmail.com>",
"Jacob Heun <jacobheun@gmail.com>",
"Pedro Teixeira <i@pgte.me>",
"Stephen Whitmore <stephen.whitmore@gmail.com>",
"Hugo Dias <hugomrdias@gmail.com>",
"Maciej Krüger <mkg20001@gmail.com>",
"Alex Potsides <alex@achingbrain.net>",
"Nate Foss <npfoss@gmail.com>",
"Robert Kiel <robert.kiel@validitylabs.org>",
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>",
"Arve Knudsen <arve.knudsen@gmail.com>", "Arve Knudsen <arve.knudsen@gmail.com>",
"Carson Farmer <carson.farmer@gmail.com>", "Carson Farmer <carson.farmer@gmail.com>",
"Christian Paul <info@jaller.de>", "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>", "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>", "Marcin Rataj <lidel@lidel.org>",
"Michael Garvin <gar+gh@danger.computer>", "Michael Garvin <gar+gh@danger.computer>",
"Nate Foss <npfoss@gmail.com>",
"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>", "Richard Schneider <makaretu@gmail.com>",
"Stephen Whitmore <stephen.whitmore@gmail.com>",
"Topper Bowers <topper@quorumcontrol.com>", "Topper Bowers <topper@quorumcontrol.com>",
"Vasco Santos <vasco.santos@moxy.studio>", "Vojtech Simetka <vojtech@simetka.cz>",
"Vasco Santos <vasco.santos@ua.pt>",
"Yahya <ya7yaz@gmail.com>", "Yahya <ya7yaz@gmail.com>",
"greenkeeperio-bot <support@greenkeeper.io>", "Adam Uhlíř <adam@uhlir.dev>"
"nginnever <ginneversource@gmail.com>",
"npmcdn-to-unpkg-bot <npmcdn-to-unpkg-bot@users.noreply.github.com>",
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>"
] ]
} }

View File

@ -3,9 +3,13 @@
'use strict' 'use strict'
const PeerId = require('./index.js') const PeerId = require('./index.js')
const argv = require('minimist')(process.argv.slice(2))
async function main () { async function main () {
const id = await PeerId.create() const id = await PeerId.create({
keyType: argv.type,
bits: argv.bits
})
console.log(JSON.stringify(id.toJSON(), null, 2)) // eslint-disable-line no-console console.log(JSON.stringify(id.toJSON(), null, 2)) // eslint-disable-line no-console
} }

38
src/index.d.ts vendored
View File

@ -1,4 +1,4 @@
import crypto, { PrivateKey, PublicKey, KeyType } from "libp2p-crypto"; import { PrivateKey, PublicKey, KeyType } from "libp2p-crypto";
import CID from 'cids' import CID from 'cids'
declare namespace PeerId { declare namespace PeerId {
@ -31,14 +31,14 @@ declare namespace PeerId {
/** /**
* Private key. * Private key.
*/ */
privKey: string; privKey?: string;
}; };
/** /**
* Checks if a value is an instance of PeerId. * Checks if a value is an instance of PeerId.
* @param id The value to check. * @param id The value to check.
*/ */
function isPeerId(id: any): boolean function isPeerId(id: any): id is PeerId
/** /**
* Create a new PeerId. * Create a new PeerId.
@ -56,7 +56,7 @@ declare namespace PeerId {
* Create PeerId from raw bytes. * Create PeerId from raw bytes.
* @param buf The raw bytes. * @param buf The raw bytes.
*/ */
function createFromBytes(buf: Buffer): PeerId; function createFromBytes(buf: Uint8Array): PeerId;
/** /**
* Create PeerId from base58-encoded string. * Create PeerId from base58-encoded string.
@ -68,19 +68,19 @@ declare namespace PeerId {
* Create PeerId from CID. * Create PeerId from CID.
* @param cid The CID. * @param cid The CID.
*/ */
function createFromCID(cid: CID | Buffer | string | object): PeerId; function createFromCID(cid: CID | Uint8Array | string | object): PeerId;
/** /**
* Create PeerId from public key. * Create PeerId from public key.
* @param key Public key, as Buffer or base64-encoded string. * @param key Public key, as Uint8Array or base64-encoded string.
*/ */
function createFromPubKey(key: Buffer | string): Promise<PeerId>; function createFromPubKey(key: Uint8Array | string): Promise<PeerId>;
/** /**
* Create PeerId from private key. * Create PeerId from private key.
* @param key Private key, as Buffer or base64-encoded string. * @param key Private key, as Uint8Array or base64-encoded string.
*/ */
function createFromPrivKey(key: Buffer | string): Promise<PeerId>; function createFromPrivKey(key: Uint8Array | string): Promise<PeerId>;
/** /**
* Create PeerId from PeerId JSON formatted object. * Create PeerId from PeerId JSON formatted object.
@ -91,21 +91,21 @@ declare namespace PeerId {
/** /**
* Create PeerId from Protobuf bytes. * Create PeerId from Protobuf bytes.
* @param buf Protobuf bytes, as Buffer or hex-encoded string. * @param buf Protobuf bytes, as Uint8Array or hex-encoded string.
*/ */
function createFromProtobuf(buf: Buffer | string): Promise<PeerId>; function createFromProtobuf(buf: Uint8Array | string): Promise<PeerId>;
} }
/** /**
* PeerId is an object representation of a peer identifier. * PeerId is an object representation of a peer identifier.
*/ */
declare class PeerId { declare class PeerId {
constructor(id: Buffer | string, privKey?: PrivateKey, pubKey?: PublicKey); constructor(id: Uint8Array, privKey?: PrivateKey, pubKey?: PublicKey);
/** /**
* Raw id. * Raw id.
*/ */
id: Buffer; readonly id: Uint8Array;
/** /**
* Private key. * Private key.
@ -120,18 +120,18 @@ declare 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(): Buffer; marshalPubKey(): Uint8Array;
/** /**
* 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(): Buffer; marshalPrivKey(): Uint8Array;
/** /**
* Return the protobuf version of the peer-id. * Return the protobuf version of the peer-id.
* @param excludePriv Whether to exclude the private key information from the output. * @param excludePriv Whether to exclude the private key information from the output.
*/ */
marshal(excludePriv?: boolean): Buffer; marshal(excludePriv?: boolean): Uint8Array;
/** /**
* String representation. * String representation.
@ -153,7 +153,7 @@ declare class PeerId {
/** /**
* Return raw id bytes. * Return raw id bytes.
*/ */
toBytes(): Buffer; toBytes(): Uint8Array;
/** /**
* Encode to base58 string. * Encode to base58 string.
@ -170,14 +170,14 @@ declare class PeerId {
* Checks the equality of `this` peer against a given PeerId. * Checks the equality of `this` peer against a given PeerId.
* @param id The other PeerId. * @param id The other PeerId.
*/ */
equals(id: PeerId | Buffer): boolean; equals(id: PeerId | Uint8Array): boolean;
/** /**
* Checks the equality of `this` peer against a given PeerId. * Checks the equality of `this` peer against a given PeerId.
* @deprecated Use {.equals} * @deprecated Use {.equals}
* @param id The other PeerId. * @param id The other PeerId.
*/ */
isEqual(id: PeerId | Buffer): boolean; isEqual(id: PeerId | Uint8Array): boolean;
/** /**
* Check if this PeerId instance is valid (privKey -> pubKey -> Id) * Check if this PeerId instance is valid (privKey -> pubKey -> Id)

View File

@ -7,16 +7,20 @@
const mh = require('multihashes') const mh = require('multihashes')
const CID = require('cids') const CID = require('cids')
const cryptoKeys = require('libp2p-crypto/src/keys') const cryptoKeys = require('libp2p-crypto/src/keys')
const assert = require('assert')
const withIs = require('class-is') const withIs = require('class-is')
const { PeerIdProto } = require('./proto') const { PeerIdProto } = require('./proto')
const uint8ArrayEquals = require('uint8arrays/equals')
const uint8ArrayFromString = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string')
class PeerId { class PeerId {
constructor (id, privKey, pubKey) { constructor (id, privKey, pubKey) {
assert(Buffer.isBuffer(id), 'invalid id provided') if (!(id instanceof Uint8Array)) {
throw new Error('invalid id provided')
}
if (privKey && pubKey) { if (privKey && pubKey && !uint8ArrayEquals(privKey.public.bytes, pubKey.bytes)) {
assert(privKey.public.bytes.equals(pubKey.bytes), 'inconsistent arguments') throw new Error('inconsistent arguments')
} }
this._id = id this._id = id
@ -140,14 +144,14 @@ class PeerId {
/** /**
* Checks the equality of `this` peer against a given PeerId. * Checks the equality of `this` peer against a given PeerId.
* @param {Buffer|PeerId} id * @param {Uint8Array|PeerId} id
* @returns {boolean} * @returns {boolean}
*/ */
equals (id) { equals (id) {
if (Buffer.isBuffer(id)) { if (id instanceof Uint8Array) {
return this.id.equals(id) return uint8ArrayEquals(this.id, id)
} else if (id.id) { } else if (id.id) {
return this.id.equals(id.id) return uint8ArrayEquals(this.id, id.id)
} else { } else {
throw new Error('not valid Id') throw new Error('not valid Id')
} }
@ -156,7 +160,7 @@ class PeerId {
/** /**
* Checks the equality of `this` peer against a given PeerId. * Checks the equality of `this` peer against a given PeerId.
* @deprecated Use `.equals` * @deprecated Use `.equals`
* @param {Buffer|PeerId} id * @param {Uint8Array|PeerId} id
* @returns {boolean} * @returns {boolean}
*/ */
isEqual (id) { isEqual (id) {
@ -171,8 +175,8 @@ class PeerId {
return Boolean(this.privKey && return Boolean(this.privKey &&
this.privKey.public && this.privKey.public &&
this.privKey.public.bytes && this.privKey.public.bytes &&
Buffer.isBuffer(this.pubKey.bytes) && this.pubKey.bytes instanceof Uint8Array &&
this.privKey.public.bytes.equals(this.pubKey.bytes)) uint8ArrayEquals(this.privKey.public.bytes, this.pubKey.bytes))
} }
} }
@ -229,16 +233,16 @@ exports.createFromCID = (cid) => {
return new PeerIdWithIs(cid.multihash) return new PeerIdWithIs(cid.multihash)
} }
// Public Key input will be a buffer // Public Key input will be a Uint8Array
exports.createFromPubKey = async (key) => { exports.createFromPubKey = async (key) => {
let buf = key let buf = key
if (typeof buf === 'string') { if (typeof buf === 'string') {
buf = Buffer.from(key, 'base64') buf = uint8ArrayFromString(key, 'base64pad')
} }
if (!Buffer.isBuffer(buf)) { if (!(buf instanceof Uint8Array)) {
throw new Error('Supplied key is neither a base64 string nor a buffer') throw new Error('Supplied key is neither a base64 string nor a Uint8Array')
} }
const pubKey = await cryptoKeys.unmarshalPublicKey(buf) const pubKey = await cryptoKeys.unmarshalPublicKey(buf)
@ -247,24 +251,22 @@ exports.createFromPubKey = async (key) => {
// Private key input will be a string // Private key input will be a string
exports.createFromPrivKey = async (key) => { exports.createFromPrivKey = async (key) => {
let buf = key if (typeof key === 'string') {
key = uint8ArrayFromString(key, 'base64pad')
if (typeof buf === 'string') {
buf = Buffer.from(key, 'base64')
} }
if (!Buffer.isBuffer(buf)) { if (!(key instanceof Uint8Array)) {
throw new Error('Supplied key is neither a base64 string nor a buffer') throw new Error('Supplied key is neither a base64 string nor a Uint8Array')
} }
const privKey = await cryptoKeys.unmarshalPrivateKey(buf) const privKey = await cryptoKeys.unmarshalPrivateKey(key)
return computePeerId(privKey, privKey.public) return computePeerId(privKey, privKey.public)
} }
exports.createFromJSON = async (obj) => { exports.createFromJSON = async (obj) => {
const id = mh.fromB58String(obj.id) const id = mh.fromB58String(obj.id)
const rawPrivKey = obj.privKey && Buffer.from(obj.privKey, 'base64') const rawPrivKey = obj.privKey && uint8ArrayFromString(obj.privKey, 'base64pad')
const rawPubKey = obj.pubKey && Buffer.from(obj.pubKey, 'base64') const rawPubKey = obj.pubKey && uint8ArrayFromString(obj.pubKey, 'base64pad')
const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey) const pub = rawPubKey && await cryptoKeys.unmarshalPublicKey(rawPubKey)
if (!rawPrivKey) { if (!rawPrivKey) {
@ -280,11 +282,11 @@ exports.createFromJSON = async (obj) => {
pubDigest = await computeDigest(pub) pubDigest = await computeDigest(pub)
} }
if (pub && !privDigest.equals(pubDigest)) { if (pub && !uint8ArrayEquals(privDigest, pubDigest)) {
throw new Error('Public and private key do not match') throw new Error('Public and private key do not match')
} }
if (id && !privDigest.equals(id)) { if (id && !uint8ArrayEquals(privDigest, id)) {
throw new Error('Id and private key do not match') throw new Error('Id and private key do not match')
} }
@ -293,7 +295,7 @@ exports.createFromJSON = async (obj) => {
exports.createFromProtobuf = async (buf) => { exports.createFromProtobuf = async (buf) => {
if (typeof buf === 'string') { if (typeof buf === 'string') {
buf = Buffer.from(buf, 'hex') buf = uint8ArrayFromString(buf, 'base16')
} }
let { id, privKey, pubKey } = PeerIdProto.decode(buf) let { id, privKey, pubKey } = PeerIdProto.decode(buf)
@ -314,7 +316,7 @@ exports.createFromProtobuf = async (buf) => {
if (privKey) { if (privKey) {
if (pubKey) { if (pubKey) {
if (!privDigest.equals(pubDigest)) { if (!uint8ArrayEquals(privDigest, pubDigest)) {
throw new Error('Public and private key do not match') throw new Error('Public and private key do not match')
} }
} }
@ -342,6 +344,6 @@ exports.isPeerId = (peerId) => {
function toB64Opt (val) { function toB64Opt (val) {
if (val) { if (val) {
return val.toString('base64') return uint8ArrayToString(val, 'base64pad')
} }
} }

View File

@ -2,13 +2,12 @@
/* eslint-env mocha */ /* eslint-env mocha */
'use strict' 'use strict'
const chai = require('chai') const { expect } = require('aegir/utils/chai')
const dirtyChai = require('dirty-chai')
chai.use(dirtyChai)
const expect = chai.expect
const crypto = require('libp2p-crypto') const crypto = require('libp2p-crypto')
const mh = require('multihashes') const mh = require('multihashes')
const CID = require('cids') const CID = require('cids')
const uint8ArrayFromString = require('uint8arrays/from-string')
const uint8ArrayToString = require('uint8arrays/to-string')
const PeerId = require('../src') const PeerId = require('../src')
@ -55,14 +54,15 @@ describe('PeerId', () => {
const id = await PeerId.create(testOpts) const id = await PeerId.create(testOpts)
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)
expect(PeerId.isPeerId(Buffer.from('batatas'))).to.equal(false) expect(PeerId.isPeerId(uint8ArrayFromString('batatas'))).to.equal(false)
}) })
it('throws on changing the id', async () => { it('throws on changing the id', async () => {
const id = await PeerId.create(testOpts) const id = await PeerId.create(testOpts)
expect(id.toB58String().length).to.equal(46) expect(id.toB58String().length).to.equal(46)
expect(() => { expect(() => {
id.id = Buffer.from('hello') // @ts-ignore
id.id = uint8ArrayFromString('hello')
}).to.throw(/immutable/) }).to.throw(/immutable/)
}) })
@ -71,7 +71,7 @@ describe('PeerId', () => {
expect(testIdBytes).to.deep.equal(id.toBytes()) expect(testIdBytes).to.deep.equal(id.toBytes())
}) })
it('recreate from a Buffer', () => { it('recreate from a Uint8Array', () => {
const id = PeerId.createFromBytes(testIdBytes) const id = PeerId.createFromBytes(testIdBytes)
expect(testId.id).to.equal(id.toHexString()) expect(testId.id).to.equal(id.toHexString())
expect(testIdBytes).to.deep.equal(id.toBytes()) expect(testIdBytes).to.deep.equal(id.toBytes())
@ -112,8 +112,8 @@ describe('PeerId', () => {
expect(testIdBytes).to.deep.equal(id.toBytes()) expect(testIdBytes).to.deep.equal(id.toBytes())
}) })
it('recreate from CID Buffer', () => { it('recreate from CID Uint8Array', () => {
const id = PeerId.createFromCID(testIdCID.buffer) const id = PeerId.createFromCID(testIdCID.bytes)
expect(testIdCIDString).to.equal(id.toString()) expect(testIdCIDString).to.equal(id.toString())
expect(testIdBytes).to.deep.equal(id.toBytes()) expect(testIdBytes).to.deep.equal(id.toBytes())
}) })
@ -158,7 +158,7 @@ describe('PeerId', () => {
it('recreate from a Private Key', async () => { it('recreate from a Private Key', async () => {
const id = await PeerId.createFromPrivKey(testId.privKey) const id = await PeerId.createFromPrivKey(testId.privKey)
expect(testIdB58String).to.equal(id.toB58String()) expect(testIdB58String).to.equal(id.toB58String())
const encoded = Buffer.from(testId.privKey, 'base64') const encoded = uint8ArrayFromString(testId.privKey, 'base64pad')
const id2 = await PeerId.createFromPrivKey(encoded) const id2 = await PeerId.createFromPrivKey(encoded)
expect(testIdB58String).to.equal(id2.toB58String()) expect(testIdB58String).to.equal(id2.toB58String())
expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey()) expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey())
@ -167,11 +167,11 @@ describe('PeerId', () => {
it('recreate from Protobuf', async () => { it('recreate from Protobuf', async () => {
const id = await PeerId.createFromProtobuf(testId.marshaled) const id = await PeerId.createFromProtobuf(testId.marshaled)
expect(testIdB58String).to.equal(id.toB58String()) expect(testIdB58String).to.equal(id.toB58String())
const encoded = Buffer.from(testId.privKey, 'base64') const encoded = uint8ArrayFromString(testId.privKey, 'base64pad')
const id2 = await PeerId.createFromPrivKey(encoded) const id2 = await PeerId.createFromPrivKey(encoded)
expect(testIdB58String).to.equal(id2.toB58String()) expect(testIdB58String).to.equal(id2.toB58String())
expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey()) expect(id.marshalPubKey()).to.deep.equal(id2.marshalPubKey())
expect(id.marshal().toString('hex')).to.deep.equal(testId.marshaled) expect(uint8ArrayToString(id.marshal(), 'base16')).to.deep.equal(testId.marshaled)
}) })
it('can be created from a Secp256k1 public key', async () => { it('can be created from a Secp256k1 public key', async () => {
@ -216,7 +216,7 @@ describe('PeerId', () => {
it('toBytes', () => { it('toBytes', () => {
const id = PeerId.createFromHexString(testIdHex) const id = PeerId.createFromHexString(testIdHex)
expect(id.toBytes().toString('hex')).to.equal(testIdBytes.toString('hex')) expect(uint8ArrayToString(id.toBytes(), 'base16')).to.equal(uint8ArrayToString(testIdBytes, 'base16'))
}) })
it('isEqual', async () => { it('isEqual', async () => {
@ -286,22 +286,22 @@ describe('PeerId', () => {
it('set privKey (invalid)', async () => { it('set privKey (invalid)', async () => {
const peerId = await PeerId.create(testOpts) const peerId = await PeerId.create(testOpts)
// @ts-ignore // @ts-ignore
peerId.privKey = Buffer.from('bufff') peerId.privKey = uint8ArrayFromString('bufff')
expect(peerId.isValid()).to.equal(false) expect(peerId.isValid()).to.equal(false)
}) })
it('set pubKey (invalid)', async () => { it('set pubKey (invalid)', async () => {
const peerId = await PeerId.create(testOpts) const peerId = await PeerId.create(testOpts)
// @ts-ignore // @ts-ignore
peerId.pubKey = Buffer.from('bufff') peerId.pubKey = uint8ArrayFromString('bufff')
expect(peerId.isValid()).to.equal(false) expect(peerId.isValid()).to.equal(false)
}) })
describe('returns error via cb instead of crashing', () => { describe('returns error via cb instead of crashing', () => {
const garbage = [ const garbage = [
Buffer.from('00010203040506070809', 'hex'), uint8ArrayFromString('00010203040506070809', 'base16'),
{}, null, false, undefined, true, 1, 0, {}, null, false, undefined, true, 1, 0,
Buffer.from(''), 'aGVsbG93b3JsZA==', 'helloworld', '' uint8ArrayFromString(''), 'aGVsbG93b3JsZA==', 'helloworld', ''
] ]
const fncs = ['createFromPubKey', 'createFromPrivKey', 'createFromJSON', 'createFromProtobuf'] const fncs = ['createFromPubKey', 'createFromPrivKey', 'createFromJSON', 'createFromProtobuf']