@waku/enr 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundle/crypto-5b69130e.js +2914 -0
- package/bundle/crypto.js +1 -0
- package/bundle/index.js +30072 -0
- package/dist/constants.d.ts +4 -0
- package/dist/constants.js +8 -0
- package/dist/constants.js.map +1 -0
- package/dist/crypto.d.ts +22 -0
- package/dist/crypto.js +47 -0
- package/dist/crypto.js.map +1 -0
- package/dist/enr.d.ts +90 -0
- package/dist/enr.js +432 -0
- package/dist/enr.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/keypair/index.d.ts +8 -0
- package/dist/keypair/index.js +53 -0
- package/dist/keypair/index.js.map +1 -0
- package/dist/keypair/secp256k1.d.ts +13 -0
- package/dist/keypair/secp256k1.js +57 -0
- package/dist/keypair/secp256k1.js.map +1 -0
- package/dist/keypair/types.d.ts +13 -0
- package/dist/keypair/types.js +7 -0
- package/dist/keypair/types.js.map +1 -0
- package/dist/multiaddr_from_fields.d.ts +2 -0
- package/dist/multiaddr_from_fields.js +8 -0
- package/dist/multiaddr_from_fields.js.map +1 -0
- package/dist/multiaddrs_codec.d.ts +3 -0
- package/dist/multiaddrs_codec.js +32 -0
- package/dist/multiaddrs_codec.js.map +1 -0
- package/dist/types.d.ts +8 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/dist/v4.d.ts +3 -0
- package/dist/v4.js +14 -0
- package/dist/v4.js.map +1 -0
- package/dist/waku2_codec.d.ts +8 -0
- package/dist/waku2_codec.js +36 -0
- package/dist/waku2_codec.js.map +1 -0
- package/package.json +191 -0
- package/src/constants.ts +10 -0
- package/src/crypto.ts +61 -0
- package/src/enr.ts +524 -0
- package/src/index.ts +6 -0
- package/src/keypair/index.ts +76 -0
- package/src/keypair/secp256k1.ts +69 -0
- package/src/keypair/types.ts +14 -0
- package/src/multiaddr_from_fields.ts +18 -0
- package/src/multiaddrs_codec.ts +50 -0
- package/src/types.ts +11 -0
- package/src/v4.ts +21 -0
- package/src/waku2_codec.ts +39 -0
@@ -0,0 +1,8 @@
|
|
1
|
+
// Maximum encoded size of an ENR
|
2
|
+
export const MAX_RECORD_SIZE = 300;
|
3
|
+
export const ERR_INVALID_ID = "Invalid record id";
|
4
|
+
export const ERR_NO_SIGNATURE = "No valid signature found";
|
5
|
+
// The maximum length of byte size of a multiaddr to encode in the `multiaddr` field
|
6
|
+
// The size is a big endian 16-bit unsigned integer
|
7
|
+
export const MULTIADDR_LENGTH_SIZE = 2;
|
8
|
+
//# sourceMappingURL=constants.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,CAAC;AAEnC,MAAM,CAAC,MAAM,cAAc,GAAG,mBAAmB,CAAC;AAElD,MAAM,CAAC,MAAM,gBAAgB,GAAG,0BAA0B,CAAC;AAE3D,oFAAoF;AACpF,mDAAmD;AACnD,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAC"}
|
package/dist/crypto.d.ts
ADDED
@@ -0,0 +1,22 @@
|
|
1
|
+
import * as secp from "@noble/secp256k1";
|
2
|
+
export declare const randomBytes: (bytesLength?: number | undefined) => Uint8Array;
|
3
|
+
/**
|
4
|
+
* Return the public key for the given private key, to be used for asymmetric
|
5
|
+
* encryption.
|
6
|
+
*/
|
7
|
+
export declare const getPublicKey: typeof secp.getPublicKey;
|
8
|
+
/**
|
9
|
+
* ECDSA Sign a message with the given private key.
|
10
|
+
*
|
11
|
+
* @param message The message to sign, usually a hash.
|
12
|
+
* @param privateKey The ECDSA private key to use to sign the message.
|
13
|
+
*
|
14
|
+
* @returns The signature and the recovery id concatenated.
|
15
|
+
*/
|
16
|
+
export declare function sign(message: Uint8Array, privateKey: Uint8Array): Promise<Uint8Array>;
|
17
|
+
export declare function keccak256(input: Uint8Array): Uint8Array;
|
18
|
+
export declare function compressPublicKey(publicKey: Uint8Array): Uint8Array;
|
19
|
+
/**
|
20
|
+
* Verify an ECDSA signature.
|
21
|
+
*/
|
22
|
+
export declare function verifySignature(signature: Uint8Array, message: Uint8Array | string, publicKey: Uint8Array): boolean;
|
package/dist/crypto.js
ADDED
@@ -0,0 +1,47 @@
|
|
1
|
+
import * as secp from "@noble/secp256k1";
|
2
|
+
import { concat } from "@waku/byte-utils";
|
3
|
+
import sha3 from "js-sha3";
|
4
|
+
export const randomBytes = secp.utils.randomBytes;
|
5
|
+
/**
|
6
|
+
* Return the public key for the given private key, to be used for asymmetric
|
7
|
+
* encryption.
|
8
|
+
*/
|
9
|
+
export const getPublicKey = secp.getPublicKey;
|
10
|
+
/**
|
11
|
+
* ECDSA Sign a message with the given private key.
|
12
|
+
*
|
13
|
+
* @param message The message to sign, usually a hash.
|
14
|
+
* @param privateKey The ECDSA private key to use to sign the message.
|
15
|
+
*
|
16
|
+
* @returns The signature and the recovery id concatenated.
|
17
|
+
*/
|
18
|
+
export async function sign(message, privateKey) {
|
19
|
+
const [signature, recoveryId] = await secp.sign(message, privateKey, {
|
20
|
+
recovered: true,
|
21
|
+
der: false,
|
22
|
+
});
|
23
|
+
return concat([signature, new Uint8Array([recoveryId])], signature.length + 1);
|
24
|
+
}
|
25
|
+
export function keccak256(input) {
|
26
|
+
return new Uint8Array(sha3.keccak256.arrayBuffer(input));
|
27
|
+
}
|
28
|
+
export function compressPublicKey(publicKey) {
|
29
|
+
if (publicKey.length === 64) {
|
30
|
+
publicKey = concat([new Uint8Array([4]), publicKey], 65);
|
31
|
+
}
|
32
|
+
const point = secp.Point.fromHex(publicKey);
|
33
|
+
return point.toRawBytes(true);
|
34
|
+
}
|
35
|
+
/**
|
36
|
+
* Verify an ECDSA signature.
|
37
|
+
*/
|
38
|
+
export function verifySignature(signature, message, publicKey) {
|
39
|
+
try {
|
40
|
+
const _signature = secp.Signature.fromCompact(signature.slice(0, 64));
|
41
|
+
return secp.verify(_signature, message, publicKey);
|
42
|
+
}
|
43
|
+
catch {
|
44
|
+
return false;
|
45
|
+
}
|
46
|
+
}
|
47
|
+
//# sourceMappingURL=crypto.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../src/crypto.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,IAAI,MAAM,SAAS,CAAC;AAE3B,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;AAElD;;;GAGG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;AAE9C;;;;;;;GAOG;AACH,MAAM,CAAC,KAAK,UAAU,IAAI,CACxB,OAAmB,EACnB,UAAsB;IAEtB,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE;QACnE,SAAS,EAAE,IAAI;QACf,GAAG,EAAE,KAAK;KACX,CAAC,CAAC;IACH,OAAO,MAAM,CACX,CAAC,SAAS,EAAE,IAAI,UAAU,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EACzC,SAAS,CAAC,MAAM,GAAG,CAAC,CACrB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,KAAiB;IACzC,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,SAAqB;IACrD,IAAI,SAAS,CAAC,MAAM,KAAK,EAAE,EAAE;QAC3B,SAAS,GAAG,MAAM,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC;KAC1D;IACD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC5C,OAAO,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAC7B,SAAqB,EACrB,OAA4B,EAC5B,SAAqB;IAErB,IAAI;QACF,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACtE,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;KACpD;IAAC,MAAM;QACN,OAAO,KAAK,CAAC;KACd;AACH,CAAC"}
|
package/dist/enr.d.ts
ADDED
@@ -0,0 +1,90 @@
|
|
1
|
+
import type { PeerId } from "@libp2p/interface-peer-id";
|
2
|
+
import { Multiaddr } from "@multiformats/multiaddr";
|
3
|
+
import { IKeypair, KeypairType } from "./keypair";
|
4
|
+
import { ENRKey, ENRValue, NodeId, SequenceNumber } from "./types";
|
5
|
+
import { Waku2 } from "./waku2_codec";
|
6
|
+
export declare class ENR extends Map<ENRKey, ENRValue> {
|
7
|
+
static readonly RECORD_PREFIX = "enr:";
|
8
|
+
seq: SequenceNumber;
|
9
|
+
signature: Uint8Array | null;
|
10
|
+
peerId?: PeerId;
|
11
|
+
private constructor();
|
12
|
+
static create(kvs?: Record<ENRKey, ENRValue>, seq?: SequenceNumber, signature?: Uint8Array | null): Promise<ENR>;
|
13
|
+
static createV4(publicKey: Uint8Array, kvs?: Record<ENRKey, ENRValue>): Promise<ENR>;
|
14
|
+
static createFromPeerId(peerId: PeerId, kvs?: Record<ENRKey, ENRValue>): Promise<ENR>;
|
15
|
+
static decodeFromValues(decoded: Uint8Array[]): Promise<ENR>;
|
16
|
+
static decode(encoded: Uint8Array): Promise<ENR>;
|
17
|
+
static decodeTxt(encoded: string): Promise<ENR>;
|
18
|
+
set(k: ENRKey, v: ENRValue): this;
|
19
|
+
get id(): string;
|
20
|
+
get keypairType(): KeypairType;
|
21
|
+
get publicKey(): Uint8Array | undefined;
|
22
|
+
get keypair(): IKeypair | undefined;
|
23
|
+
get nodeId(): NodeId | undefined;
|
24
|
+
get ip(): string | undefined;
|
25
|
+
set ip(ip: string | undefined);
|
26
|
+
get tcp(): number | undefined;
|
27
|
+
set tcp(port: number | undefined);
|
28
|
+
get udp(): number | undefined;
|
29
|
+
set udp(port: number | undefined);
|
30
|
+
get ip6(): string | undefined;
|
31
|
+
set ip6(ip: string | undefined);
|
32
|
+
get tcp6(): number | undefined;
|
33
|
+
set tcp6(port: number | undefined);
|
34
|
+
get udp6(): number | undefined;
|
35
|
+
set udp6(port: number | undefined);
|
36
|
+
/**
|
37
|
+
* Get the `multiaddrs` field from ENR.
|
38
|
+
*
|
39
|
+
* This field is used to store multiaddresses that cannot be stored with the current ENR pre-defined keys.
|
40
|
+
* These can be a multiaddresses that include encapsulation (e.g. wss) or do not use `ip4` nor `ip6` for the host
|
41
|
+
* address (e.g. `dns4`, `dnsaddr`, etc)..
|
42
|
+
*
|
43
|
+
* If the peer information only contains information that can be represented with the ENR pre-defined keys
|
44
|
+
* (ip, tcp, etc) then the usage of { @link getLocationMultiaddr } should be preferred.
|
45
|
+
*
|
46
|
+
* The multiaddresses stored in this field are expected to be location multiaddresses, ie, peer id less.
|
47
|
+
*/
|
48
|
+
get multiaddrs(): Multiaddr[] | undefined;
|
49
|
+
/**
|
50
|
+
* Set the `multiaddrs` field on the ENR.
|
51
|
+
*
|
52
|
+
* This field is used to store multiaddresses that cannot be stored with the current ENR pre-defined keys.
|
53
|
+
* These can be a multiaddresses that include encapsulation (e.g. wss) or do not use `ip4` nor `ip6` for the host
|
54
|
+
* address (e.g. `dns4`, `dnsaddr`, etc)..
|
55
|
+
*
|
56
|
+
* If the peer information only contains information that can be represented with the ENR pre-defined keys
|
57
|
+
* (ip, tcp, etc) then the usage of { @link setLocationMultiaddr } should be preferred.
|
58
|
+
* The multiaddresses stored in this field must be location multiaddresses,
|
59
|
+
* ie, without a peer id.
|
60
|
+
*/
|
61
|
+
set multiaddrs(multiaddrs: Multiaddr[] | undefined);
|
62
|
+
getLocationMultiaddr(protocol: "udp" | "udp4" | "udp6" | "tcp" | "tcp4" | "tcp6"): Multiaddr | undefined;
|
63
|
+
setLocationMultiaddr(multiaddr: Multiaddr): void;
|
64
|
+
/**
|
65
|
+
* Returns the full multiaddr from the ENR fields matching the provided
|
66
|
+
* `protocol` parameter.
|
67
|
+
* To return full multiaddrs from the `multiaddrs` ENR field,
|
68
|
+
* use { @link ENR.getFullMultiaddrs }.
|
69
|
+
*
|
70
|
+
* @param protocol
|
71
|
+
*/
|
72
|
+
getFullMultiaddr(protocol: "udp" | "udp4" | "udp6" | "tcp" | "tcp4" | "tcp6"): Multiaddr | undefined;
|
73
|
+
/**
|
74
|
+
* Returns the full multiaddrs from the `multiaddrs` ENR field.
|
75
|
+
*/
|
76
|
+
getFullMultiaddrs(): Multiaddr[];
|
77
|
+
/**
|
78
|
+
* Get the `waku2` field from ENR.
|
79
|
+
*/
|
80
|
+
get waku2(): Waku2 | undefined;
|
81
|
+
/**
|
82
|
+
* Set the `waku2` field on the ENR.
|
83
|
+
*/
|
84
|
+
set waku2(waku2: Waku2 | undefined);
|
85
|
+
verify(data: Uint8Array, signature: Uint8Array): boolean;
|
86
|
+
sign(data: Uint8Array, privateKey: Uint8Array): Promise<Uint8Array>;
|
87
|
+
encodeToValues(privateKey?: Uint8Array): Promise<(ENRKey | ENRValue | number[])[]>;
|
88
|
+
encode(privateKey?: Uint8Array): Promise<Uint8Array>;
|
89
|
+
encodeTxt(privateKey?: Uint8Array): Promise<string>;
|
90
|
+
}
|
package/dist/enr.js
ADDED
@@ -0,0 +1,432 @@
|
|
1
|
+
import * as RLP from "@ethersproject/rlp";
|
2
|
+
import { convertToBytes, convertToString, } from "@multiformats/multiaddr/convert";
|
3
|
+
import { bytesToHex, bytesToUtf8, hexToBytes, utf8ToBytes, } from "@waku/byte-utils";
|
4
|
+
import debug from "debug";
|
5
|
+
import { fromString } from "uint8arrays/from-string";
|
6
|
+
import { toString } from "uint8arrays/to-string";
|
7
|
+
import { ERR_INVALID_ID, ERR_NO_SIGNATURE, MAX_RECORD_SIZE, } from "./constants.js";
|
8
|
+
import { compressPublicKey, keccak256, verifySignature } from "./crypto.js";
|
9
|
+
import { createKeypair, createKeypairFromPeerId, createPeerIdFromKeypair, KeypairType, } from "./keypair";
|
10
|
+
import { multiaddrFromFields } from "./multiaddr_from_fields";
|
11
|
+
import { decodeMultiaddrs, encodeMultiaddrs } from "./multiaddrs_codec";
|
12
|
+
import * as v4 from "./v4";
|
13
|
+
import { decodeWaku2, encodeWaku2 } from "./waku2_codec";
|
14
|
+
const log = debug("waku:enr");
|
15
|
+
export class ENR extends Map {
|
16
|
+
constructor(kvs = {}, seq = BigInt(1), signature = null) {
|
17
|
+
super(Object.entries(kvs));
|
18
|
+
this.seq = seq;
|
19
|
+
this.signature = signature;
|
20
|
+
}
|
21
|
+
static async create(kvs = {}, seq = BigInt(1), signature = null) {
|
22
|
+
const enr = new ENR(kvs, seq, signature);
|
23
|
+
try {
|
24
|
+
const publicKey = enr.publicKey;
|
25
|
+
if (publicKey) {
|
26
|
+
const keypair = createKeypair(enr.keypairType, undefined, publicKey);
|
27
|
+
enr.peerId = await createPeerIdFromKeypair(keypair);
|
28
|
+
}
|
29
|
+
}
|
30
|
+
catch (e) {
|
31
|
+
log("Could not calculate peer id for ENR", e);
|
32
|
+
}
|
33
|
+
return enr;
|
34
|
+
}
|
35
|
+
static createV4(publicKey, kvs = {}) {
|
36
|
+
// EIP-778 specifies that the key must be in compressed format, 33 bytes
|
37
|
+
if (publicKey.length !== 33) {
|
38
|
+
publicKey = compressPublicKey(publicKey);
|
39
|
+
}
|
40
|
+
return ENR.create({
|
41
|
+
...kvs,
|
42
|
+
id: utf8ToBytes("v4"),
|
43
|
+
secp256k1: publicKey,
|
44
|
+
});
|
45
|
+
}
|
46
|
+
static async createFromPeerId(peerId, kvs = {}) {
|
47
|
+
const keypair = await createKeypairFromPeerId(peerId);
|
48
|
+
switch (keypair.type) {
|
49
|
+
case KeypairType.secp256k1:
|
50
|
+
return ENR.createV4(keypair.publicKey, kvs);
|
51
|
+
default:
|
52
|
+
throw new Error();
|
53
|
+
}
|
54
|
+
}
|
55
|
+
static async decodeFromValues(decoded) {
|
56
|
+
if (!Array.isArray(decoded)) {
|
57
|
+
throw new Error("Decoded ENR must be an array");
|
58
|
+
}
|
59
|
+
if (decoded.length % 2 !== 0) {
|
60
|
+
throw new Error("Decoded ENR must have an even number of elements");
|
61
|
+
}
|
62
|
+
const [signature, seq, ...kvs] = decoded;
|
63
|
+
if (!signature || Array.isArray(signature)) {
|
64
|
+
throw new Error("Decoded ENR invalid signature: must be a byte array");
|
65
|
+
}
|
66
|
+
if (!seq || Array.isArray(seq)) {
|
67
|
+
throw new Error("Decoded ENR invalid sequence number: must be a byte array");
|
68
|
+
}
|
69
|
+
const obj = {};
|
70
|
+
for (let i = 0; i < kvs.length; i += 2) {
|
71
|
+
try {
|
72
|
+
obj[bytesToUtf8(kvs[i])] = kvs[i + 1];
|
73
|
+
}
|
74
|
+
catch (e) {
|
75
|
+
log("Failed to decode ENR key to UTF-8, skipping it", kvs[i], e);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
// If seq is an empty array, translate as value 0
|
79
|
+
const hexSeq = "0x" + (seq.length ? bytesToHex(seq) : "00");
|
80
|
+
const enr = await ENR.create(obj, BigInt(hexSeq), signature);
|
81
|
+
const rlpEncodedBytes = hexToBytes(RLP.encode([seq, ...kvs]));
|
82
|
+
if (!enr.verify(rlpEncodedBytes, signature)) {
|
83
|
+
throw new Error("Unable to verify ENR signature");
|
84
|
+
}
|
85
|
+
return enr;
|
86
|
+
}
|
87
|
+
static decode(encoded) {
|
88
|
+
const decoded = RLP.decode(encoded).map(hexToBytes);
|
89
|
+
return ENR.decodeFromValues(decoded);
|
90
|
+
}
|
91
|
+
static decodeTxt(encoded) {
|
92
|
+
if (!encoded.startsWith(this.RECORD_PREFIX)) {
|
93
|
+
throw new Error(`"string encoded ENR must start with '${this.RECORD_PREFIX}'`);
|
94
|
+
}
|
95
|
+
return ENR.decode(fromString(encoded.slice(4), "base64url"));
|
96
|
+
}
|
97
|
+
set(k, v) {
|
98
|
+
this.signature = null;
|
99
|
+
this.seq++;
|
100
|
+
return super.set(k, v);
|
101
|
+
}
|
102
|
+
get id() {
|
103
|
+
const id = this.get("id");
|
104
|
+
if (!id)
|
105
|
+
throw new Error("id not found.");
|
106
|
+
return bytesToUtf8(id);
|
107
|
+
}
|
108
|
+
get keypairType() {
|
109
|
+
switch (this.id) {
|
110
|
+
case "v4":
|
111
|
+
return KeypairType.secp256k1;
|
112
|
+
default:
|
113
|
+
throw new Error(ERR_INVALID_ID);
|
114
|
+
}
|
115
|
+
}
|
116
|
+
get publicKey() {
|
117
|
+
switch (this.id) {
|
118
|
+
case "v4":
|
119
|
+
return this.get("secp256k1");
|
120
|
+
default:
|
121
|
+
throw new Error(ERR_INVALID_ID);
|
122
|
+
}
|
123
|
+
}
|
124
|
+
get keypair() {
|
125
|
+
if (this.publicKey) {
|
126
|
+
const publicKey = this.publicKey;
|
127
|
+
return createKeypair(this.keypairType, undefined, publicKey);
|
128
|
+
}
|
129
|
+
return;
|
130
|
+
}
|
131
|
+
get nodeId() {
|
132
|
+
switch (this.id) {
|
133
|
+
case "v4":
|
134
|
+
return this.publicKey ? v4.nodeId(this.publicKey) : undefined;
|
135
|
+
default:
|
136
|
+
throw new Error(ERR_INVALID_ID);
|
137
|
+
}
|
138
|
+
}
|
139
|
+
get ip() {
|
140
|
+
const raw = this.get("ip");
|
141
|
+
if (raw) {
|
142
|
+
return convertToString("ip4", raw);
|
143
|
+
}
|
144
|
+
else {
|
145
|
+
return undefined;
|
146
|
+
}
|
147
|
+
}
|
148
|
+
set ip(ip) {
|
149
|
+
if (ip) {
|
150
|
+
this.set("ip", convertToBytes("ip4", ip));
|
151
|
+
}
|
152
|
+
else {
|
153
|
+
this.delete("ip");
|
154
|
+
}
|
155
|
+
}
|
156
|
+
get tcp() {
|
157
|
+
const raw = this.get("tcp");
|
158
|
+
if (raw) {
|
159
|
+
return Number(convertToString("tcp", raw));
|
160
|
+
}
|
161
|
+
else {
|
162
|
+
return undefined;
|
163
|
+
}
|
164
|
+
}
|
165
|
+
set tcp(port) {
|
166
|
+
if (port === undefined) {
|
167
|
+
this.delete("tcp");
|
168
|
+
}
|
169
|
+
else {
|
170
|
+
this.set("tcp", convertToBytes("tcp", port.toString(10)));
|
171
|
+
}
|
172
|
+
}
|
173
|
+
get udp() {
|
174
|
+
const raw = this.get("udp");
|
175
|
+
if (raw) {
|
176
|
+
return Number(convertToString("udp", raw));
|
177
|
+
}
|
178
|
+
else {
|
179
|
+
return undefined;
|
180
|
+
}
|
181
|
+
}
|
182
|
+
set udp(port) {
|
183
|
+
if (port === undefined) {
|
184
|
+
this.delete("udp");
|
185
|
+
}
|
186
|
+
else {
|
187
|
+
this.set("udp", convertToBytes("udp", port.toString(10)));
|
188
|
+
}
|
189
|
+
}
|
190
|
+
get ip6() {
|
191
|
+
const raw = this.get("ip6");
|
192
|
+
if (raw) {
|
193
|
+
return convertToString("ip6", raw);
|
194
|
+
}
|
195
|
+
else {
|
196
|
+
return undefined;
|
197
|
+
}
|
198
|
+
}
|
199
|
+
set ip6(ip) {
|
200
|
+
if (ip) {
|
201
|
+
this.set("ip6", convertToBytes("ip6", ip));
|
202
|
+
}
|
203
|
+
else {
|
204
|
+
this.delete("ip6");
|
205
|
+
}
|
206
|
+
}
|
207
|
+
get tcp6() {
|
208
|
+
const raw = this.get("tcp6");
|
209
|
+
if (raw) {
|
210
|
+
return Number(convertToString("tcp", raw));
|
211
|
+
}
|
212
|
+
else {
|
213
|
+
return undefined;
|
214
|
+
}
|
215
|
+
}
|
216
|
+
set tcp6(port) {
|
217
|
+
if (port === undefined) {
|
218
|
+
this.delete("tcp6");
|
219
|
+
}
|
220
|
+
else {
|
221
|
+
this.set("tcp6", convertToBytes("tcp", port.toString(10)));
|
222
|
+
}
|
223
|
+
}
|
224
|
+
get udp6() {
|
225
|
+
const raw = this.get("udp6");
|
226
|
+
if (raw) {
|
227
|
+
return Number(convertToString("udp", raw));
|
228
|
+
}
|
229
|
+
else {
|
230
|
+
return undefined;
|
231
|
+
}
|
232
|
+
}
|
233
|
+
set udp6(port) {
|
234
|
+
if (port === undefined) {
|
235
|
+
this.delete("udp6");
|
236
|
+
}
|
237
|
+
else {
|
238
|
+
this.set("udp6", convertToBytes("udp", port.toString(10)));
|
239
|
+
}
|
240
|
+
}
|
241
|
+
/**
|
242
|
+
* Get the `multiaddrs` field from ENR.
|
243
|
+
*
|
244
|
+
* This field is used to store multiaddresses that cannot be stored with the current ENR pre-defined keys.
|
245
|
+
* These can be a multiaddresses that include encapsulation (e.g. wss) or do not use `ip4` nor `ip6` for the host
|
246
|
+
* address (e.g. `dns4`, `dnsaddr`, etc)..
|
247
|
+
*
|
248
|
+
* If the peer information only contains information that can be represented with the ENR pre-defined keys
|
249
|
+
* (ip, tcp, etc) then the usage of { @link getLocationMultiaddr } should be preferred.
|
250
|
+
*
|
251
|
+
* The multiaddresses stored in this field are expected to be location multiaddresses, ie, peer id less.
|
252
|
+
*/
|
253
|
+
get multiaddrs() {
|
254
|
+
const raw = this.get("multiaddrs");
|
255
|
+
if (raw)
|
256
|
+
return decodeMultiaddrs(raw);
|
257
|
+
return;
|
258
|
+
}
|
259
|
+
/**
|
260
|
+
* Set the `multiaddrs` field on the ENR.
|
261
|
+
*
|
262
|
+
* This field is used to store multiaddresses that cannot be stored with the current ENR pre-defined keys.
|
263
|
+
* These can be a multiaddresses that include encapsulation (e.g. wss) or do not use `ip4` nor `ip6` for the host
|
264
|
+
* address (e.g. `dns4`, `dnsaddr`, etc)..
|
265
|
+
*
|
266
|
+
* If the peer information only contains information that can be represented with the ENR pre-defined keys
|
267
|
+
* (ip, tcp, etc) then the usage of { @link setLocationMultiaddr } should be preferred.
|
268
|
+
* The multiaddresses stored in this field must be location multiaddresses,
|
269
|
+
* ie, without a peer id.
|
270
|
+
*/
|
271
|
+
set multiaddrs(multiaddrs) {
|
272
|
+
if (multiaddrs === undefined) {
|
273
|
+
this.delete("multiaddrs");
|
274
|
+
}
|
275
|
+
else {
|
276
|
+
const multiaddrsBuf = encodeMultiaddrs(multiaddrs);
|
277
|
+
this.set("multiaddrs", multiaddrsBuf);
|
278
|
+
}
|
279
|
+
}
|
280
|
+
getLocationMultiaddr(protocol) {
|
281
|
+
if (protocol === "udp") {
|
282
|
+
return (this.getLocationMultiaddr("udp4") || this.getLocationMultiaddr("udp6"));
|
283
|
+
}
|
284
|
+
if (protocol === "tcp") {
|
285
|
+
return (this.getLocationMultiaddr("tcp4") || this.getLocationMultiaddr("tcp6"));
|
286
|
+
}
|
287
|
+
const isIpv6 = protocol.endsWith("6");
|
288
|
+
const ipVal = this.get(isIpv6 ? "ip6" : "ip");
|
289
|
+
if (!ipVal) {
|
290
|
+
return;
|
291
|
+
}
|
292
|
+
const isUdp = protocol.startsWith("udp");
|
293
|
+
const isTcp = protocol.startsWith("tcp");
|
294
|
+
let protoName, protoVal;
|
295
|
+
if (isUdp) {
|
296
|
+
protoName = "udp";
|
297
|
+
protoVal = isIpv6 ? this.get("udp6") : this.get("udp");
|
298
|
+
}
|
299
|
+
else if (isTcp) {
|
300
|
+
protoName = "tcp";
|
301
|
+
protoVal = isIpv6 ? this.get("tcp6") : this.get("tcp");
|
302
|
+
}
|
303
|
+
else {
|
304
|
+
return;
|
305
|
+
}
|
306
|
+
if (!protoVal) {
|
307
|
+
return;
|
308
|
+
}
|
309
|
+
return multiaddrFromFields(isIpv6 ? "ip6" : "ip4", protoName, ipVal, protoVal);
|
310
|
+
}
|
311
|
+
setLocationMultiaddr(multiaddr) {
|
312
|
+
const protoNames = multiaddr.protoNames();
|
313
|
+
if (protoNames.length !== 2 &&
|
314
|
+
protoNames[1] !== "udp" &&
|
315
|
+
protoNames[1] !== "tcp") {
|
316
|
+
throw new Error("Invalid multiaddr");
|
317
|
+
}
|
318
|
+
const tuples = multiaddr.tuples();
|
319
|
+
if (!tuples[0][1] || !tuples[1][1]) {
|
320
|
+
throw new Error("Invalid multiaddr");
|
321
|
+
}
|
322
|
+
// IPv4
|
323
|
+
if (tuples[0][0] === 4) {
|
324
|
+
this.set("ip", tuples[0][1]);
|
325
|
+
this.set(protoNames[1], tuples[1][1]);
|
326
|
+
}
|
327
|
+
else {
|
328
|
+
this.set("ip6", tuples[0][1]);
|
329
|
+
this.set(protoNames[1] + "6", tuples[1][1]);
|
330
|
+
}
|
331
|
+
}
|
332
|
+
/**
|
333
|
+
* Returns the full multiaddr from the ENR fields matching the provided
|
334
|
+
* `protocol` parameter.
|
335
|
+
* To return full multiaddrs from the `multiaddrs` ENR field,
|
336
|
+
* use { @link ENR.getFullMultiaddrs }.
|
337
|
+
*
|
338
|
+
* @param protocol
|
339
|
+
*/
|
340
|
+
getFullMultiaddr(protocol) {
|
341
|
+
if (this.peerId) {
|
342
|
+
const locationMultiaddr = this.getLocationMultiaddr(protocol);
|
343
|
+
if (locationMultiaddr) {
|
344
|
+
return locationMultiaddr.encapsulate(`/p2p/${this.peerId.toString()}`);
|
345
|
+
}
|
346
|
+
}
|
347
|
+
return;
|
348
|
+
}
|
349
|
+
/**
|
350
|
+
* Returns the full multiaddrs from the `multiaddrs` ENR field.
|
351
|
+
*/
|
352
|
+
getFullMultiaddrs() {
|
353
|
+
if (this.peerId && this.multiaddrs) {
|
354
|
+
const peerId = this.peerId;
|
355
|
+
return this.multiaddrs.map((ma) => {
|
356
|
+
return ma.encapsulate(`/p2p/${peerId.toString()}`);
|
357
|
+
});
|
358
|
+
}
|
359
|
+
return [];
|
360
|
+
}
|
361
|
+
/**
|
362
|
+
* Get the `waku2` field from ENR.
|
363
|
+
*/
|
364
|
+
get waku2() {
|
365
|
+
const raw = this.get("waku2");
|
366
|
+
if (raw)
|
367
|
+
return decodeWaku2(raw[0]);
|
368
|
+
return;
|
369
|
+
}
|
370
|
+
/**
|
371
|
+
* Set the `waku2` field on the ENR.
|
372
|
+
*/
|
373
|
+
set waku2(waku2) {
|
374
|
+
if (waku2 === undefined) {
|
375
|
+
this.delete("waku2");
|
376
|
+
}
|
377
|
+
else {
|
378
|
+
const byte = encodeWaku2(waku2);
|
379
|
+
this.set("waku2", new Uint8Array([byte]));
|
380
|
+
}
|
381
|
+
}
|
382
|
+
verify(data, signature) {
|
383
|
+
if (!this.get("id") || this.id !== "v4") {
|
384
|
+
throw new Error(ERR_INVALID_ID);
|
385
|
+
}
|
386
|
+
if (!this.publicKey) {
|
387
|
+
throw new Error("Failed to verify ENR: No public key");
|
388
|
+
}
|
389
|
+
return verifySignature(signature, keccak256(data), this.publicKey);
|
390
|
+
}
|
391
|
+
async sign(data, privateKey) {
|
392
|
+
switch (this.id) {
|
393
|
+
case "v4":
|
394
|
+
this.signature = await v4.sign(privateKey, data);
|
395
|
+
break;
|
396
|
+
default:
|
397
|
+
throw new Error(ERR_INVALID_ID);
|
398
|
+
}
|
399
|
+
return this.signature;
|
400
|
+
}
|
401
|
+
async encodeToValues(privateKey) {
|
402
|
+
// sort keys and flatten into [k, v, k, v, ...]
|
403
|
+
const content = Array.from(this.keys())
|
404
|
+
.sort((a, b) => a.localeCompare(b))
|
405
|
+
.map((k) => [k, this.get(k)])
|
406
|
+
.map(([k, v]) => [utf8ToBytes(k), v])
|
407
|
+
.flat();
|
408
|
+
content.unshift(new Uint8Array([Number(this.seq)]));
|
409
|
+
if (privateKey) {
|
410
|
+
content.unshift(await this.sign(hexToBytes(RLP.encode(content)), privateKey));
|
411
|
+
}
|
412
|
+
else {
|
413
|
+
if (!this.signature) {
|
414
|
+
throw new Error(ERR_NO_SIGNATURE);
|
415
|
+
}
|
416
|
+
content.unshift(this.signature);
|
417
|
+
}
|
418
|
+
return content;
|
419
|
+
}
|
420
|
+
async encode(privateKey) {
|
421
|
+
const encoded = hexToBytes(RLP.encode(await this.encodeToValues(privateKey)));
|
422
|
+
if (encoded.length >= MAX_RECORD_SIZE) {
|
423
|
+
throw new Error("ENR must be less than 300 bytes");
|
424
|
+
}
|
425
|
+
return encoded;
|
426
|
+
}
|
427
|
+
async encodeTxt(privateKey) {
|
428
|
+
return (ENR.RECORD_PREFIX + toString(await this.encode(privateKey), "base64url"));
|
429
|
+
}
|
430
|
+
}
|
431
|
+
ENR.RECORD_PREFIX = "enr:";
|
432
|
+
//# sourceMappingURL=enr.js.map
|
package/dist/enr.js.map
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"enr.js","sourceRoot":"","sources":["../src/enr.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,aAAa,CAAC"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import type { PeerId } from "@libp2p/interface-peer-id";
|
2
|
+
import { IKeypair, KeypairType } from "./types.js";
|
3
|
+
export declare const ERR_TYPE_NOT_IMPLEMENTED = "Keypair type not implemented";
|
4
|
+
export * from "./types.js";
|
5
|
+
export * from "./secp256k1.js";
|
6
|
+
export declare function createKeypair(type: KeypairType, privateKey?: Uint8Array, publicKey?: Uint8Array): IKeypair;
|
7
|
+
export declare function createPeerIdFromKeypair(keypair: IKeypair): Promise<PeerId>;
|
8
|
+
export declare function createKeypairFromPeerId(peerId: PeerId): Promise<IKeypair>;
|