@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.7 → 8.2.1-alpha.71
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/CHANGELOG.md +465 -0
- package/dist/src/curves/constant.d.ts +2 -0
- package/dist/src/curves/constant.d.ts.map +1 -0
- package/dist/src/curves/constant.js +6 -0
- package/dist/src/curves/{baseCurve.d.ts → ed25519.d.ts} +9 -7
- package/dist/src/curves/ed25519.d.ts.map +1 -0
- package/dist/src/curves/ed25519.js +72 -0
- package/dist/src/curves/ed25519Bip32HdTree.d.ts +10 -0
- package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +1 -0
- package/dist/src/curves/ed25519Bip32HdTree.js +85 -0
- package/dist/src/curves/index.d.ts +6 -1
- package/dist/src/curves/index.d.ts.map +1 -1
- package/dist/src/curves/index.js +12 -3
- package/dist/src/curves/secp256k1.d.ts +3 -1
- package/dist/src/curves/secp256k1.d.ts.map +1 -1
- package/dist/src/curves/secp256k1.js +25 -14
- package/dist/src/curves/secp256k1Bip32HdTree.d.ts +8 -0
- package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +1 -0
- package/dist/src/curves/secp256k1Bip32HdTree.js +54 -0
- package/dist/src/curves/types.d.ts +36 -0
- package/dist/src/curves/types.d.ts.map +1 -0
- package/dist/src/curves/types.js +3 -0
- package/dist/src/curves/util.d.ts +2 -0
- package/dist/src/curves/util.d.ts.map +1 -0
- package/dist/src/curves/util.js +11 -0
- package/dist/src/hashCommitment.d.ts +17 -0
- package/dist/src/hashCommitment.d.ts.map +1 -0
- package/dist/src/hashCommitment.js +45 -0
- package/dist/src/index.d.ts +6 -2
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +25 -4
- package/dist/src/safePrime.d.ts +3 -0
- package/dist/src/safePrime.d.ts.map +1 -0
- package/dist/src/safePrime.js +23 -0
- package/dist/src/schnorrProof.d.ts +22 -0
- package/dist/src/schnorrProof.d.ts.map +1 -0
- package/dist/src/schnorrProof.js +62 -0
- package/dist/src/shamir/index.d.ts +3 -0
- package/dist/src/shamir/index.d.ts.map +1 -0
- package/dist/src/{openssl → shamir}/index.js +8 -3
- package/dist/src/shamir/shamir.d.ts +38 -0
- package/dist/src/shamir/shamir.d.ts.map +1 -0
- package/dist/src/shamir/shamir.js +136 -0
- package/dist/src/shamir/types.d.ts +5 -0
- package/dist/src/shamir/types.d.ts.map +1 -0
- package/dist/src/shamir/types.js +3 -0
- package/dist/src/tss/ecdsa/index.d.ts +1 -0
- package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/index.js +8 -3
- package/dist/src/tss/ecdsa/paillierproof.js +6 -6
- package/dist/src/tss/ecdsa/rangeproof.d.ts +0 -1
- package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/rangeproof.js +102 -108
- package/dist/src/tss/ecdsa/types.d.ts +5 -0
- package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/tss/ecdsa/types.js +19 -19
- package/dist/src/tss/ecdsa/zkVProof.d.ts +25 -0
- package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
- package/dist/src/tss/ecdsa/zkVProof.js +71 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +43 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/commsLayer.js +216 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts +20 -0
- package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dkg.js +153 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts +30 -0
- package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/dsg.js +169 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts +4 -0
- package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/index.js +30 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts +74 -0
- package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
- package/dist/src/tss/ecdsa-dkls/types.js +70 -0
- package/dist/src/tss/index.d.ts +1 -0
- package/dist/src/tss/index.d.ts.map +1 -1
- package/dist/src/tss/index.js +7 -2
- package/dist/src/types.d.ts +14 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +3 -0
- package/dist/src/util.d.ts +8 -2
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +35 -13
- package/dist/tsconfig.tsbuildinfo +1 -3645
- package/package.json +11 -6
- package/dist/src/curves/baseCurve.d.ts.map +0 -1
- package/dist/src/curves/baseCurve.js +0 -6
- package/dist/src/openssl/index.d.ts +0 -2
- package/dist/src/openssl/index.d.ts.map +0 -1
- package/dist/src/openssl/openssl.d.ts +0 -9
- package/dist/src/openssl/openssl.d.ts.map +0 -1
- package/dist/src/openssl/openssl.js +0 -45
- package/dist/src/openssl/opensslbytes.d.ts +0 -4
- package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
- package/dist/src/openssl/opensslbytes.js +0 -20
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Dkg = void 0;
|
|
4
|
+
const dkls_wasm_ll_node_1 = require("@silencelaboratories/dkls-wasm-ll-node");
|
|
5
|
+
const types_1 = require("./types");
|
|
6
|
+
const cbor_1 = require("cbor");
|
|
7
|
+
class Dkg {
|
|
8
|
+
constructor(n, t, partyIdx) {
|
|
9
|
+
this.dkgState = types_1.DkgState.Uninitialized;
|
|
10
|
+
this.n = n;
|
|
11
|
+
this.t = t;
|
|
12
|
+
this.partyIdx = partyIdx;
|
|
13
|
+
this.chainCodeCommitment = undefined;
|
|
14
|
+
}
|
|
15
|
+
_restoreSession() {
|
|
16
|
+
if (!this.dkgSession) {
|
|
17
|
+
this.dkgSession = dkls_wasm_ll_node_1.KeygenSession.fromBytes(this.dkgSessionBytes);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
_deserializeState() {
|
|
21
|
+
if (!this.dkgSession) {
|
|
22
|
+
throw Error('Session not intialized');
|
|
23
|
+
}
|
|
24
|
+
const round = (0, cbor_1.decode)(this.dkgSession.toBytes()).round;
|
|
25
|
+
switch (round) {
|
|
26
|
+
case 'WaitMsg1':
|
|
27
|
+
this.dkgState = types_1.DkgState.Round1;
|
|
28
|
+
break;
|
|
29
|
+
case 'WaitMsg2':
|
|
30
|
+
this.dkgState = types_1.DkgState.Round2;
|
|
31
|
+
break;
|
|
32
|
+
case 'WaitMsg3':
|
|
33
|
+
this.dkgState = types_1.DkgState.Round3;
|
|
34
|
+
break;
|
|
35
|
+
case 'WaitMsg4':
|
|
36
|
+
this.dkgState = types_1.DkgState.Round4;
|
|
37
|
+
break;
|
|
38
|
+
case 'Ended':
|
|
39
|
+
this.dkgState = types_1.DkgState.Complete;
|
|
40
|
+
break;
|
|
41
|
+
default:
|
|
42
|
+
this.dkgState = types_1.DkgState.InvalidState;
|
|
43
|
+
throw `Invalid State: ${round}`;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
async initDkg() {
|
|
47
|
+
if (this.t > this.n || this.partyIdx >= this.n) {
|
|
48
|
+
throw 'Invalid parameters for DKG';
|
|
49
|
+
}
|
|
50
|
+
if (this.dkgState != types_1.DkgState.Uninitialized) {
|
|
51
|
+
throw 'DKG session already initialized';
|
|
52
|
+
}
|
|
53
|
+
if (typeof window !== 'undefined') {
|
|
54
|
+
const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');
|
|
55
|
+
await initDkls();
|
|
56
|
+
}
|
|
57
|
+
this.dkgSession = new dkls_wasm_ll_node_1.KeygenSession(this.n, this.t, this.partyIdx);
|
|
58
|
+
try {
|
|
59
|
+
const payload = this.dkgSession.createFirstMessage().payload;
|
|
60
|
+
this._deserializeState();
|
|
61
|
+
return {
|
|
62
|
+
payload: payload,
|
|
63
|
+
from: this.partyIdx,
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
catch (e) {
|
|
67
|
+
throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
getKeyShare() {
|
|
71
|
+
const keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());
|
|
72
|
+
this.dkgKeyShare.free();
|
|
73
|
+
return keyShareBuff;
|
|
74
|
+
}
|
|
75
|
+
handleIncomingMessages(messagesForIthRound) {
|
|
76
|
+
let nextRoundMessages = [];
|
|
77
|
+
let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
|
|
78
|
+
this._restoreSession();
|
|
79
|
+
if (!this.dkgSession) {
|
|
80
|
+
throw Error('Session not initialized');
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
if (this.dkgState == types_1.DkgState.Round3) {
|
|
84
|
+
const commitmentsUnsorted = messagesForIthRound.p2pMessages
|
|
85
|
+
.map((m) => {
|
|
86
|
+
return { from: m.from, commitment: m.commitment };
|
|
87
|
+
})
|
|
88
|
+
.concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);
|
|
89
|
+
const commitmentsSorted = commitmentsUnsorted
|
|
90
|
+
.sort((a, b) => {
|
|
91
|
+
return a.from - b.from;
|
|
92
|
+
})
|
|
93
|
+
.map((c) => c.commitment);
|
|
94
|
+
nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
95
|
+
.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
|
|
96
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), commitmentsSorted);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
100
|
+
.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
|
|
101
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), undefined);
|
|
102
|
+
}
|
|
103
|
+
if (this.dkgState == types_1.DkgState.Round4) {
|
|
104
|
+
this.dkgKeyShare = this.dkgSession.keyshare();
|
|
105
|
+
this.dkgState = types_1.DkgState.Complete;
|
|
106
|
+
return { broadcastMessages: [], p2pMessages: [] };
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
// Update ronud data.
|
|
110
|
+
this._deserializeState();
|
|
111
|
+
}
|
|
112
|
+
if (this.dkgState == types_1.DkgState.Round2) {
|
|
113
|
+
this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();
|
|
114
|
+
}
|
|
115
|
+
nextRoundDeserializedMessages = {
|
|
116
|
+
p2pMessages: nextRoundMessages
|
|
117
|
+
.filter((m) => m.to_id !== undefined)
|
|
118
|
+
.map((m) => {
|
|
119
|
+
const p2pReturn = {
|
|
120
|
+
payload: m.payload,
|
|
121
|
+
from: m.from_id,
|
|
122
|
+
to: m.to_id,
|
|
123
|
+
commitment: this.chainCodeCommitment,
|
|
124
|
+
};
|
|
125
|
+
return p2pReturn;
|
|
126
|
+
}),
|
|
127
|
+
broadcastMessages: nextRoundMessages
|
|
128
|
+
.filter((m) => m.to_id === undefined)
|
|
129
|
+
.map((m) => {
|
|
130
|
+
const broadcastReturn = {
|
|
131
|
+
payload: m.payload,
|
|
132
|
+
from: m.from_id,
|
|
133
|
+
};
|
|
134
|
+
return broadcastReturn;
|
|
135
|
+
}),
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
catch (e) {
|
|
139
|
+
throw `Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`;
|
|
140
|
+
}
|
|
141
|
+
finally {
|
|
142
|
+
nextRoundMessages.forEach((m) => m.free());
|
|
143
|
+
// Session is freed when keyshare is called.
|
|
144
|
+
if (this.dkgState !== types_1.DkgState.Complete) {
|
|
145
|
+
this.dkgSessionBytes = this.dkgSession.toBytes();
|
|
146
|
+
this.dkgSession = undefined;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return nextRoundDeserializedMessages;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
exports.Dkg = Dkg;
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dkg.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dkg.ts"],"names":[],"mappings":"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","sourcesContent":["import { KeygenSession, Keyshare, Message } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { DeserializedBroadcastMessage, DeserializedMessages, DkgState } from './types';\nimport { decode } from 'cbor';\n\nexport class Dkg {\n  protected dkgSession: KeygenSession | undefined;\n  protected dkgSessionBytes: Uint8Array;\n  protected dkgKeyShare: Keyshare;\n  protected n: number;\n  protected t: number;\n  protected chainCodeCommitment: Uint8Array | undefined;\n  protected partyIdx: number;\n  protected dkgState: DkgState = DkgState.Uninitialized;\n\n  constructor(n: number, t: number, partyIdx: number) {\n    this.n = n;\n    this.t = t;\n    this.partyIdx = partyIdx;\n    this.chainCodeCommitment = undefined;\n  }\n\n  private _restoreSession() {\n    if (!this.dkgSession) {\n      this.dkgSession = KeygenSession.fromBytes(this.dkgSessionBytes);\n    }\n  }\n\n  private _deserializeState() {\n    if (!this.dkgSession) {\n      throw Error('Session not intialized');\n    }\n    const round = decode(this.dkgSession.toBytes()).round;\n    switch (round) {\n      case 'WaitMsg1':\n        this.dkgState = DkgState.Round1;\n        break;\n      case 'WaitMsg2':\n        this.dkgState = DkgState.Round2;\n        break;\n      case 'WaitMsg3':\n        this.dkgState = DkgState.Round3;\n        break;\n      case 'WaitMsg4':\n        this.dkgState = DkgState.Round4;\n        break;\n      case 'Ended':\n        this.dkgState = DkgState.Complete;\n        break;\n      default:\n        this.dkgState = DkgState.InvalidState;\n        throw `Invalid State: ${round}`;\n    }\n  }\n\n  async initDkg(): Promise<DeserializedBroadcastMessage> {\n    if (this.t > this.n || this.partyIdx >= this.n) {\n      throw 'Invalid parameters for DKG';\n    }\n    if (this.dkgState != DkgState.Uninitialized) {\n      throw 'DKG session already initialized';\n    }\n    if (typeof window !== 'undefined') {\n      const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls();\n    }\n    this.dkgSession = new KeygenSession(this.n, this.t, this.partyIdx);\n    try {\n      const payload = this.dkgSession.createFirstMessage().payload;\n      this._deserializeState();\n      return {\n        payload: payload,\n        from: this.partyIdx,\n      };\n    } catch (e) {\n      throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;\n    }\n  }\n\n  getKeyShare(): Buffer {\n    const keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());\n    this.dkgKeyShare.free();\n    return keyShareBuff;\n  }\n\n  handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages {\n    let nextRoundMessages: Message[] = [];\n    let nextRoundDeserializedMessages: DeserializedMessages = { broadcastMessages: [], p2pMessages: [] };\n    this._restoreSession();\n    if (!this.dkgSession) {\n      throw Error('Session not initialized');\n    }\n    try {\n      if (this.dkgState == DkgState.Round3) {\n        const commitmentsUnsorted = messagesForIthRound.p2pMessages\n          .map((m) => {\n            return { from: m.from, commitment: m.commitment };\n          })\n          .concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);\n        const commitmentsSorted = commitmentsUnsorted\n          .sort((a, b) => {\n            return a.from - b.from;\n          })\n          .map((c) => c.commitment);\n        nextRoundMessages = this.dkgSession.handleMessages(\n          messagesForIthRound.broadcastMessages\n            .map((m) => new Message(m.payload, m.from, undefined))\n            .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))),\n          commitmentsSorted\n        );\n      } else {\n        nextRoundMessages = this.dkgSession.handleMessages(\n          messagesForIthRound.broadcastMessages\n            .map((m) => new Message(m.payload, m.from, undefined))\n            .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))),\n          undefined\n        );\n      }\n      if (this.dkgState == DkgState.Round4) {\n        this.dkgKeyShare = this.dkgSession.keyshare();\n        this.dkgState = DkgState.Complete;\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        // Update ronud data.\n        this._deserializeState();\n      }\n      if (this.dkgState == DkgState.Round2) {\n        this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();\n      }\n      nextRoundDeserializedMessages = {\n        p2pMessages: nextRoundMessages\n          .filter((m) => m.to_id !== undefined)\n          .map((m) => {\n            const p2pReturn = {\n              payload: m.payload,\n              from: m.from_id,\n              to: m.to_id!,\n              commitment: this.chainCodeCommitment,\n            };\n            return p2pReturn;\n          }),\n        broadcastMessages: nextRoundMessages\n          .filter((m) => m.to_id === undefined)\n          .map((m) => {\n            const broadcastReturn = {\n              payload: m.payload,\n              from: m.from_id,\n            };\n            return broadcastReturn;\n          }),\n      };\n    } catch (e) {\n      throw `Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`;\n    } finally {\n      nextRoundMessages.forEach((m) => m.free());\n      // Session is freed when keyshare is called.\n      if (this.dkgState !== DkgState.Complete) {\n        this.dkgSessionBytes = this.dkgSession.toBytes();\n        this.dkgSession = undefined;\n      }\n    }\n    return nextRoundDeserializedMessages;\n  }\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { SignSession, Keyshare } from '@silencelaboratories/dkls-wasm-ll-node';
|
|
3
|
+
import { DeserializedBroadcastMessage, DeserializedMessages, DklsSignature, DsgState } from './types';
|
|
4
|
+
export declare class Dsg {
|
|
5
|
+
protected dsgSession: SignSession | undefined;
|
|
6
|
+
protected dsgSessionBytes: Uint8Array;
|
|
7
|
+
private _signature;
|
|
8
|
+
protected keyShare: Keyshare;
|
|
9
|
+
protected messageHash: Buffer;
|
|
10
|
+
protected derivationPath: string;
|
|
11
|
+
protected partyIdx: number;
|
|
12
|
+
protected dsgState: DsgState;
|
|
13
|
+
constructor(keyShare: Buffer, partyIdx: number, derivationPath: string, messageHash: Buffer);
|
|
14
|
+
private _restoreSession;
|
|
15
|
+
private _deserializeState;
|
|
16
|
+
init(): Promise<DeserializedBroadcastMessage>;
|
|
17
|
+
get signature(): DklsSignature;
|
|
18
|
+
/**
|
|
19
|
+
* Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
|
|
20
|
+
*/
|
|
21
|
+
endSession(): void;
|
|
22
|
+
/**
|
|
23
|
+
* Proccesses incoming messages to this party in the DKLs DSG protocol and
|
|
24
|
+
* produces messages from this party to other parties for the next round.
|
|
25
|
+
* @param messagesForIthRound - messages to process the current round
|
|
26
|
+
* @returns {DeserializedMessages} - messages to send to other parties for the next round
|
|
27
|
+
*/
|
|
28
|
+
handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=dsg.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dsg.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dsg.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAW,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAE,4BAA4B,EAAE,oBAAoB,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGtG,qBAAa,GAAG;IACd,SAAS,CAAC,UAAU,EAAE,WAAW,GAAG,SAAS,CAAC;IAC9C,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC;IACtC,OAAO,CAAC,UAAU,CAA4B;IAC9C,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC7B,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAA0B;gBAE1C,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAU3F,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,iBAAiB;IAwBnB,IAAI,IAAI,OAAO,CAAC,4BAA4B,CAAC;IAqBnD,IAAI,SAAS,IAAI,aAAa,CAK7B;IAED;;OAEG;IACH,UAAU,IAAI,IAAI;IASlB;;;;;OAKG;IACH,sBAAsB,CAAC,mBAAmB,EAAE,oBAAoB,GAAG,oBAAoB;CA6ExF"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Dsg = void 0;
|
|
4
|
+
const dkls_wasm_ll_node_1 = require("@silencelaboratories/dkls-wasm-ll-node");
|
|
5
|
+
const types_1 = require("./types");
|
|
6
|
+
const cbor_1 = require("cbor");
|
|
7
|
+
class Dsg {
|
|
8
|
+
constructor(keyShare, partyIdx, derivationPath, messageHash) {
|
|
9
|
+
this.dsgState = types_1.DsgState.Uninitialized;
|
|
10
|
+
this.keyShare = dkls_wasm_ll_node_1.Keyshare.fromBytes(keyShare);
|
|
11
|
+
this.partyIdx = partyIdx;
|
|
12
|
+
if (this.keyShare.partyId !== partyIdx) {
|
|
13
|
+
throw Error(`Party index: ${partyIdx} does not match key share partyId: ${this.keyShare.partyId} `);
|
|
14
|
+
}
|
|
15
|
+
this.derivationPath = derivationPath;
|
|
16
|
+
this.messageHash = messageHash;
|
|
17
|
+
}
|
|
18
|
+
_restoreSession() {
|
|
19
|
+
if (!this.dsgSession) {
|
|
20
|
+
this.dsgSession = dkls_wasm_ll_node_1.SignSession.fromBytes(this.dsgSessionBytes);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
_deserializeState() {
|
|
24
|
+
if (!this.dsgSession) {
|
|
25
|
+
throw Error('Session not intialized');
|
|
26
|
+
}
|
|
27
|
+
const round = (0, cbor_1.decode)(this.dsgSession.toBytes()).round;
|
|
28
|
+
switch (round) {
|
|
29
|
+
case 'WaitMsg1':
|
|
30
|
+
this.dsgState = types_1.DsgState.Round1;
|
|
31
|
+
break;
|
|
32
|
+
case 'WaitMsg2':
|
|
33
|
+
this.dsgState = types_1.DsgState.Round2;
|
|
34
|
+
break;
|
|
35
|
+
case 'WaitMsg3':
|
|
36
|
+
this.dsgState = types_1.DsgState.Round3;
|
|
37
|
+
break;
|
|
38
|
+
case 'Ended':
|
|
39
|
+
this.dsgState = types_1.DsgState.Complete;
|
|
40
|
+
break;
|
|
41
|
+
default:
|
|
42
|
+
this.dsgState = types_1.DsgState.InvalidState;
|
|
43
|
+
throw `Invalid State: ${round}`;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
async init() {
|
|
47
|
+
if (this.dsgState !== types_1.DsgState.Uninitialized) {
|
|
48
|
+
throw 'DSG session already initialized';
|
|
49
|
+
}
|
|
50
|
+
if (typeof window !== 'undefined') {
|
|
51
|
+
const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');
|
|
52
|
+
await initDkls();
|
|
53
|
+
}
|
|
54
|
+
this.dsgSession = new dkls_wasm_ll_node_1.SignSession(this.keyShare, this.derivationPath);
|
|
55
|
+
try {
|
|
56
|
+
const payload = this.dsgSession.createFirstMessage().payload;
|
|
57
|
+
this._deserializeState();
|
|
58
|
+
return {
|
|
59
|
+
payload: payload,
|
|
60
|
+
from: this.partyIdx,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
get signature() {
|
|
68
|
+
if (!this._signature) {
|
|
69
|
+
throw Error('Can not request signature. Signature not produced yet.');
|
|
70
|
+
}
|
|
71
|
+
return this._signature;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
|
|
75
|
+
*/
|
|
76
|
+
endSession() {
|
|
77
|
+
if (this.signature) {
|
|
78
|
+
new Error('Session already ended because combined signature was produced.');
|
|
79
|
+
}
|
|
80
|
+
if (this.dsgSession) {
|
|
81
|
+
this.dsgSession.free();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Proccesses incoming messages to this party in the DKLs DSG protocol and
|
|
86
|
+
* produces messages from this party to other parties for the next round.
|
|
87
|
+
* @param messagesForIthRound - messages to process the current round
|
|
88
|
+
* @returns {DeserializedMessages} - messages to send to other parties for the next round
|
|
89
|
+
*/
|
|
90
|
+
handleIncomingMessages(messagesForIthRound) {
|
|
91
|
+
let nextRoundMessages = [];
|
|
92
|
+
let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
|
|
93
|
+
this._restoreSession();
|
|
94
|
+
if (!this.dsgSession) {
|
|
95
|
+
throw Error('Session not initialized');
|
|
96
|
+
}
|
|
97
|
+
try {
|
|
98
|
+
if (this.dsgState === types_1.DsgState.Round4) {
|
|
99
|
+
this.dsgState = types_1.DsgState.Complete;
|
|
100
|
+
const combineResult = this.dsgSession.combine(messagesForIthRound.broadcastMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined)));
|
|
101
|
+
this._signature = {
|
|
102
|
+
R: combineResult[0],
|
|
103
|
+
S: combineResult[1],
|
|
104
|
+
};
|
|
105
|
+
return { broadcastMessages: [], p2pMessages: [] };
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
nextRoundMessages = this.dsgSession.handleMessages(messagesForIthRound.broadcastMessages
|
|
109
|
+
.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
|
|
110
|
+
.concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))));
|
|
111
|
+
}
|
|
112
|
+
if (this.dsgState === types_1.DsgState.Round3) {
|
|
113
|
+
nextRoundMessages = [this.dsgSession.lastMessage(this.messageHash)];
|
|
114
|
+
this.dsgState = types_1.DsgState.Round4;
|
|
115
|
+
return {
|
|
116
|
+
broadcastMessages: [
|
|
117
|
+
{
|
|
118
|
+
payload: nextRoundMessages[0].payload,
|
|
119
|
+
from: nextRoundMessages[0].from_id,
|
|
120
|
+
},
|
|
121
|
+
],
|
|
122
|
+
p2pMessages: [],
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
// Update round data.
|
|
127
|
+
this._deserializeState();
|
|
128
|
+
}
|
|
129
|
+
nextRoundDeserializedMessages = {
|
|
130
|
+
p2pMessages: nextRoundMessages
|
|
131
|
+
.filter((m) => m.to_id !== undefined)
|
|
132
|
+
.map((m) => {
|
|
133
|
+
if (m.to_id === undefined) {
|
|
134
|
+
throw Error('Invalid P2P message, missing to_id.');
|
|
135
|
+
}
|
|
136
|
+
const p2pReturn = {
|
|
137
|
+
payload: m.payload,
|
|
138
|
+
from: m.from_id,
|
|
139
|
+
to: m.to_id,
|
|
140
|
+
};
|
|
141
|
+
return p2pReturn;
|
|
142
|
+
}),
|
|
143
|
+
broadcastMessages: nextRoundMessages
|
|
144
|
+
.filter((m) => m.to_id === undefined)
|
|
145
|
+
.map((m) => {
|
|
146
|
+
const broadcastReturn = {
|
|
147
|
+
payload: m.payload,
|
|
148
|
+
from: m.from_id,
|
|
149
|
+
};
|
|
150
|
+
return broadcastReturn;
|
|
151
|
+
}),
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
catch (e) {
|
|
155
|
+
throw `Error while creating messages from party ${this.partyIdx}, round ${this.dsgState}: ${e}`;
|
|
156
|
+
}
|
|
157
|
+
finally {
|
|
158
|
+
nextRoundMessages.forEach((m) => m.free());
|
|
159
|
+
// Session is freed when combine is called.
|
|
160
|
+
if (this.dsgState !== types_1.DsgState.Complete) {
|
|
161
|
+
this.dsgSessionBytes = this.dsgSession.toBytes();
|
|
162
|
+
this.dsgSession = undefined;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
return nextRoundDeserializedMessages;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
exports.Dsg = Dsg;
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dsg.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dsg.ts"],"names":[],"mappings":"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","sourcesContent":["import { SignSession, Keyshare, Message } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { DeserializedBroadcastMessage, DeserializedMessages, DklsSignature, DsgState } from './types';\nimport { decode } from 'cbor';\n\nexport class Dsg {\n  protected dsgSession: SignSession | undefined;\n  protected dsgSessionBytes: Uint8Array;\n  private _signature: DklsSignature | undefined;\n  protected keyShare: Keyshare;\n  protected messageHash: Buffer;\n  protected derivationPath: string;\n  protected partyIdx: number;\n  protected dsgState: DsgState = DsgState.Uninitialized;\n\n  constructor(keyShare: Buffer, partyIdx: number, derivationPath: string, messageHash: Buffer) {\n    this.keyShare = Keyshare.fromBytes(keyShare);\n    this.partyIdx = partyIdx;\n    if (this.keyShare.partyId !== partyIdx) {\n      throw Error(`Party index: ${partyIdx} does not match key share partyId: ${this.keyShare.partyId} `);\n    }\n    this.derivationPath = derivationPath;\n    this.messageHash = messageHash;\n  }\n\n  private _restoreSession() {\n    if (!this.dsgSession) {\n      this.dsgSession = SignSession.fromBytes(this.dsgSessionBytes);\n    }\n  }\n\n  private _deserializeState() {\n    if (!this.dsgSession) {\n      throw Error('Session not intialized');\n    }\n    const round = decode(this.dsgSession.toBytes()).round;\n    switch (round) {\n      case 'WaitMsg1':\n        this.dsgState = DsgState.Round1;\n        break;\n      case 'WaitMsg2':\n        this.dsgState = DsgState.Round2;\n        break;\n      case 'WaitMsg3':\n        this.dsgState = DsgState.Round3;\n        break;\n      case 'Ended':\n        this.dsgState = DsgState.Complete;\n        break;\n      default:\n        this.dsgState = DsgState.InvalidState;\n        throw `Invalid State: ${round}`;\n    }\n  }\n\n  async init(): Promise<DeserializedBroadcastMessage> {\n    if (this.dsgState !== DsgState.Uninitialized) {\n      throw 'DSG session already initialized';\n    }\n    if (typeof window !== 'undefined') {\n      const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls();\n    }\n    this.dsgSession = new SignSession(this.keyShare, this.derivationPath);\n    try {\n      const payload = this.dsgSession.createFirstMessage().payload;\n      this._deserializeState();\n      return {\n        payload: payload,\n        from: this.partyIdx,\n      };\n    } catch (e) {\n      throw `Error while creating the first message from party ${this.partyIdx}: ${e}`;\n    }\n  }\n\n  get signature(): DklsSignature {\n    if (!this._signature) {\n      throw Error('Can not request signature. Signature not produced yet.');\n    }\n    return this._signature;\n  }\n\n  /**\n   * Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.\n   */\n  endSession(): void {\n    if (this.signature) {\n      new Error('Session already ended because combined signature was produced.');\n    }\n    if (this.dsgSession) {\n      this.dsgSession.free();\n    }\n  }\n\n  /**\n   * Proccesses incoming messages to this party in the DKLs DSG protocol and\n   * produces messages from this party to other parties for the next round.\n   * @param messagesForIthRound - messages to process the current round\n   * @returns {DeserializedMessages} - messages to send to other parties for the next round\n   */\n  handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages {\n    let nextRoundMessages: Message[] = [];\n    let nextRoundDeserializedMessages: DeserializedMessages = { broadcastMessages: [], p2pMessages: [] };\n    this._restoreSession();\n    if (!this.dsgSession) {\n      throw Error('Session not initialized');\n    }\n    try {\n      if (this.dsgState === DsgState.Round4) {\n        this.dsgState = DsgState.Complete;\n        const combineResult = this.dsgSession.combine(\n          messagesForIthRound.broadcastMessages.map((m) => new Message(m.payload, m.from, undefined))\n        );\n        this._signature = {\n          R: combineResult[0],\n          S: combineResult[1],\n        };\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        nextRoundMessages = this.dsgSession.handleMessages(\n          messagesForIthRound.broadcastMessages\n            .map((m) => new Message(m.payload, m.from, undefined))\n            .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to)))\n        );\n      }\n      if (this.dsgState === DsgState.Round3) {\n        nextRoundMessages = [this.dsgSession.lastMessage(this.messageHash)];\n        this.dsgState = DsgState.Round4;\n        return {\n          broadcastMessages: [\n            {\n              payload: nextRoundMessages[0].payload,\n              from: nextRoundMessages[0].from_id,\n            },\n          ],\n          p2pMessages: [],\n        };\n      } else {\n        // Update round data.\n        this._deserializeState();\n      }\n      nextRoundDeserializedMessages = {\n        p2pMessages: nextRoundMessages\n          .filter((m) => m.to_id !== undefined)\n          .map((m) => {\n            if (m.to_id === undefined) {\n              throw Error('Invalid P2P message, missing to_id.');\n            }\n            const p2pReturn = {\n              payload: m.payload,\n              from: m.from_id,\n              to: m.to_id,\n            };\n            return p2pReturn;\n          }),\n        broadcastMessages: nextRoundMessages\n          .filter((m) => m.to_id === undefined)\n          .map((m) => {\n            const broadcastReturn = {\n              payload: m.payload,\n              from: m.from_id,\n            };\n            return broadcastReturn;\n          }),\n      };\n    } catch (e) {\n      throw `Error while creating messages from party ${this.partyIdx}, round ${this.dsgState}: ${e}`;\n    } finally {\n      nextRoundMessages.forEach((m) => m.free());\n      // Session is freed when combine is called.\n      if (this.dsgState !== DsgState.Complete) {\n        this.dsgSessionBytes = this.dsgSession.toBytes();\n        this.dsgSession = undefined;\n      }\n    }\n    return nextRoundDeserializedMessages;\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,OAAO,KAAK,OAAO,MAAM,OAAO,CAAC;AACjC,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.DklsTypes = exports.DklsDsg = exports.DklsDkg = void 0;
|
|
27
|
+
exports.DklsDkg = __importStar(require("./dkg"));
|
|
28
|
+
exports.DklsDsg = __importStar(require("./dsg"));
|
|
29
|
+
exports.DklsTypes = __importStar(require("./types"));
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhLWRrbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpREFBaUM7QUFDakMsaURBQWlDO0FBQ2pDLHFEQUFxQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGFzIERrbHNEa2cgZnJvbSAnLi9ka2cnO1xuZXhwb3J0ICogYXMgRGtsc0RzZyBmcm9tICcuL2RzZyc7XG5leHBvcnQgKiBhcyBEa2xzVHlwZXMgZnJvbSAnLi90eXBlcyc7XG4iXX0=
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
interface BroadcastMessage<T> {
|
|
2
|
+
payload: T;
|
|
3
|
+
from: number;
|
|
4
|
+
}
|
|
5
|
+
interface P2PMessage<T, G> {
|
|
6
|
+
payload: T;
|
|
7
|
+
from: number;
|
|
8
|
+
commitment?: G;
|
|
9
|
+
to: number;
|
|
10
|
+
}
|
|
11
|
+
export declare enum DkgState {
|
|
12
|
+
Uninitialized = 0,
|
|
13
|
+
Round1 = 1,
|
|
14
|
+
Round2 = 2,
|
|
15
|
+
Round3 = 3,
|
|
16
|
+
Round4 = 4,
|
|
17
|
+
Complete = 5,
|
|
18
|
+
InvalidState = 6
|
|
19
|
+
}
|
|
20
|
+
export declare enum DsgState {
|
|
21
|
+
Uninitialized = 0,
|
|
22
|
+
Round1 = 1,
|
|
23
|
+
Round2 = 2,
|
|
24
|
+
Round3 = 3,
|
|
25
|
+
Round4 = 4,
|
|
26
|
+
Complete = 5,
|
|
27
|
+
InvalidState = 6
|
|
28
|
+
}
|
|
29
|
+
export declare type AuthEncMessage = {
|
|
30
|
+
encryptedMessage: string;
|
|
31
|
+
signature: string;
|
|
32
|
+
};
|
|
33
|
+
export declare type AuthMessage = {
|
|
34
|
+
message: string;
|
|
35
|
+
signature: string;
|
|
36
|
+
};
|
|
37
|
+
export declare type PartyGpgKey = {
|
|
38
|
+
partyId: number;
|
|
39
|
+
gpgKey: string;
|
|
40
|
+
};
|
|
41
|
+
export declare type DklsSignature = {
|
|
42
|
+
R: Uint8Array;
|
|
43
|
+
S: Uint8Array;
|
|
44
|
+
};
|
|
45
|
+
export declare type SerializedBroadcastMessage = BroadcastMessage<string>;
|
|
46
|
+
export declare type DeserializedBroadcastMessage = BroadcastMessage<Uint8Array>;
|
|
47
|
+
export declare type SerializedP2PMessage = P2PMessage<string, string>;
|
|
48
|
+
export declare type DeserializedP2PMessage = P2PMessage<Uint8Array, Uint8Array>;
|
|
49
|
+
export declare type AuthEncP2PMessage = P2PMessage<AuthEncMessage, string>;
|
|
50
|
+
export declare type AuthBroadcastMessage = BroadcastMessage<AuthMessage>;
|
|
51
|
+
export declare type SerializedMessages = {
|
|
52
|
+
p2pMessages: SerializedP2PMessage[];
|
|
53
|
+
broadcastMessages: SerializedBroadcastMessage[];
|
|
54
|
+
};
|
|
55
|
+
export declare type AuthEncMessages = {
|
|
56
|
+
p2pMessages: AuthEncP2PMessage[];
|
|
57
|
+
broadcastMessages: AuthBroadcastMessage[];
|
|
58
|
+
};
|
|
59
|
+
export declare type DeserializedMessages = {
|
|
60
|
+
p2pMessages: DeserializedP2PMessage[];
|
|
61
|
+
broadcastMessages: DeserializedBroadcastMessage[];
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* Serializes messages payloads to base64 strings.
|
|
65
|
+
* @param messages
|
|
66
|
+
*/
|
|
67
|
+
export declare function serializeMessages(messages: DeserializedMessages): SerializedMessages;
|
|
68
|
+
/**
|
|
69
|
+
* Desrializes messages payloads to Uint8Array.
|
|
70
|
+
* @param messages
|
|
71
|
+
*/
|
|
72
|
+
export declare function deserializeMessages(messages: SerializedMessages): DeserializedMessages;
|
|
73
|
+
export {};
|
|
74
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/types.ts"],"names":[],"mappings":"AACA,UAAU,gBAAgB,CAAC,CAAC;IAC1B,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd;AAGD,UAAU,UAAU,CAAC,CAAC,EAAE,CAAC;IACvB,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,CAAC,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,oBAAY,QAAQ;IAClB,aAAa,IAAI;IACjB,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,QAAQ,IAAA;IACR,YAAY,IAAA;CACb;AAED,oBAAY,QAAQ;IAClB,aAAa,IAAI;IACjB,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,MAAM,IAAA;IACN,QAAQ,IAAA;IACR,YAAY,IAAA;CACb;AAED,oBAAY,cAAc,GAAG;IAC3B,gBAAgB,EAAE,MAAM,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AACF,oBAAY,WAAW,GAAG;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AACF,oBAAY,WAAW,GAAG;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AACF,oBAAY,aAAa,GAAG;IAC1B,CAAC,EAAE,UAAU,CAAC;IACd,CAAC,EAAE,UAAU,CAAC;CACf,CAAC;AACF,oBAAY,0BAA0B,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAClE,oBAAY,4BAA4B,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;AACxE,oBAAY,oBAAoB,GAAG,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AAC9D,oBAAY,sBAAsB,GAAG,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;AACxE,oBAAY,iBAAiB,GAAG,UAAU,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;AACnE,oBAAY,oBAAoB,GAAG,gBAAgB,CAAC,WAAW,CAAC,CAAC;AACjE,oBAAY,kBAAkB,GAAG;IAC/B,WAAW,EAAE,oBAAoB,EAAE,CAAC;IACpC,iBAAiB,EAAE,0BAA0B,EAAE,CAAC;CACjD,CAAC;AACF,oBAAY,eAAe,GAAG;IAC5B,WAAW,EAAE,iBAAiB,EAAE,CAAC;IACjC,iBAAiB,EAAE,oBAAoB,EAAE,CAAC;CAC3C,CAAC;AACF,oBAAY,oBAAoB,GAAG;IACjC,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtC,iBAAiB,EAAE,4BAA4B,EAAE,CAAC;CACnD,CAAC;AAEF;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,kBAAkB,CAiBpF;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,kBAAkB,GAAG,oBAAoB,CAiBtF"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.deserializeMessages = exports.serializeMessages = exports.DsgState = exports.DkgState = void 0;
|
|
4
|
+
var DkgState;
|
|
5
|
+
(function (DkgState) {
|
|
6
|
+
DkgState[DkgState["Uninitialized"] = 0] = "Uninitialized";
|
|
7
|
+
DkgState[DkgState["Round1"] = 1] = "Round1";
|
|
8
|
+
DkgState[DkgState["Round2"] = 2] = "Round2";
|
|
9
|
+
DkgState[DkgState["Round3"] = 3] = "Round3";
|
|
10
|
+
DkgState[DkgState["Round4"] = 4] = "Round4";
|
|
11
|
+
DkgState[DkgState["Complete"] = 5] = "Complete";
|
|
12
|
+
DkgState[DkgState["InvalidState"] = 6] = "InvalidState";
|
|
13
|
+
})(DkgState = exports.DkgState || (exports.DkgState = {}));
|
|
14
|
+
var DsgState;
|
|
15
|
+
(function (DsgState) {
|
|
16
|
+
DsgState[DsgState["Uninitialized"] = 0] = "Uninitialized";
|
|
17
|
+
DsgState[DsgState["Round1"] = 1] = "Round1";
|
|
18
|
+
DsgState[DsgState["Round2"] = 2] = "Round2";
|
|
19
|
+
DsgState[DsgState["Round3"] = 3] = "Round3";
|
|
20
|
+
DsgState[DsgState["Round4"] = 4] = "Round4";
|
|
21
|
+
DsgState[DsgState["Complete"] = 5] = "Complete";
|
|
22
|
+
DsgState[DsgState["InvalidState"] = 6] = "InvalidState";
|
|
23
|
+
})(DsgState = exports.DsgState || (exports.DsgState = {}));
|
|
24
|
+
/**
|
|
25
|
+
* Serializes messages payloads to base64 strings.
|
|
26
|
+
* @param messages
|
|
27
|
+
*/
|
|
28
|
+
function serializeMessages(messages) {
|
|
29
|
+
return {
|
|
30
|
+
p2pMessages: messages.p2pMessages.map((m) => {
|
|
31
|
+
return {
|
|
32
|
+
to: m.to,
|
|
33
|
+
from: m.from,
|
|
34
|
+
payload: Buffer.from(m.payload).toString('base64'),
|
|
35
|
+
commitment: m.commitment ? Buffer.from(m.commitment).toString('base64') : m.commitment,
|
|
36
|
+
};
|
|
37
|
+
}),
|
|
38
|
+
broadcastMessages: messages.broadcastMessages.map((m) => {
|
|
39
|
+
return {
|
|
40
|
+
from: m.from,
|
|
41
|
+
payload: Buffer.from(m.payload).toString('base64'),
|
|
42
|
+
};
|
|
43
|
+
}),
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
exports.serializeMessages = serializeMessages;
|
|
47
|
+
/**
|
|
48
|
+
* Desrializes messages payloads to Uint8Array.
|
|
49
|
+
* @param messages
|
|
50
|
+
*/
|
|
51
|
+
function deserializeMessages(messages) {
|
|
52
|
+
return {
|
|
53
|
+
p2pMessages: messages.p2pMessages.map((m) => {
|
|
54
|
+
return {
|
|
55
|
+
to: m.to,
|
|
56
|
+
from: m.from,
|
|
57
|
+
payload: new Uint8Array(Buffer.from(m.payload, 'base64')),
|
|
58
|
+
commitment: m.commitment ? new Uint8Array(Buffer.from(m.commitment, 'base64')) : undefined,
|
|
59
|
+
};
|
|
60
|
+
}),
|
|
61
|
+
broadcastMessages: messages.broadcastMessages.map((m) => {
|
|
62
|
+
return {
|
|
63
|
+
from: m.from,
|
|
64
|
+
payload: new Uint8Array(Buffer.from(m.payload, 'base64')),
|
|
65
|
+
};
|
|
66
|
+
}),
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
exports.deserializeMessages = deserializeMessages;
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhLWRrbHMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBY0EsSUFBWSxRQVFYO0FBUkQsV0FBWSxRQUFRO0lBQ2xCLHlEQUFpQixDQUFBO0lBQ2pCLDJDQUFNLENBQUE7SUFDTiwyQ0FBTSxDQUFBO0lBQ04sMkNBQU0sQ0FBQTtJQUNOLDJDQUFNLENBQUE7SUFDTiwrQ0FBUSxDQUFBO0lBQ1IsdURBQVksQ0FBQTtBQUNkLENBQUMsRUFSVyxRQUFRLEdBQVIsZ0JBQVEsS0FBUixnQkFBUSxRQVFuQjtBQUVELElBQVksUUFRWDtBQVJELFdBQVksUUFBUTtJQUNsQix5REFBaUIsQ0FBQTtJQUNqQiwyQ0FBTSxDQUFBO0lBQ04sMkNBQU0sQ0FBQTtJQUNOLDJDQUFNLENBQUE7SUFDTiwyQ0FBTSxDQUFBO0lBQ04sK0NBQVEsQ0FBQTtJQUNSLHVEQUFZLENBQUE7QUFDZCxDQUFDLEVBUlcsUUFBUSxHQUFSLGdCQUFRLEtBQVIsZ0JBQVEsUUFRbkI7QUFxQ0Q7OztHQUdHO0FBQ0gsU0FBZ0IsaUJBQWlCLENBQUMsUUFBOEI7SUFDOUQsT0FBTztRQUNMLFdBQVcsRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQzFDLE9BQU87Z0JBQ0wsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFO2dCQUNSLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSTtnQkFDWixPQUFPLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztnQkFDbEQsVUFBVSxFQUFFLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVU7YUFDdkYsQ0FBQztRQUNKLENBQUMsQ0FBQztRQUNGLGlCQUFpQixFQUFFLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN0RCxPQUFPO2dCQUNMLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSTtnQkFDWixPQUFPLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQzthQUNuRCxDQUFDO1FBQ0osQ0FBQyxDQUFDO0tBQ0gsQ0FBQztBQUNKLENBQUM7QUFqQkQsOENBaUJDO0FBRUQ7OztHQUdHO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQUMsUUFBNEI7SUFDOUQsT0FBTztRQUNMLFdBQVcsRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQzFDLE9BQU87Z0JBQ0wsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFO2dCQUNSLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSTtnQkFDWixPQUFPLEVBQUUsSUFBSSxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDO2dCQUN6RCxVQUFVLEVBQUUsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsSUFBSSxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVM7YUFDM0YsQ0FBQztRQUNKLENBQUMsQ0FBQztRQUNGLGlCQUFpQixFQUFFLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN0RCxPQUFPO2dCQUNMLElBQUksRUFBRSxDQUFDLENBQUMsSUFBSTtnQkFDWixPQUFPLEVBQUUsSUFBSSxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDO2FBQzFELENBQUM7UUFDSixDQUFDLENBQUM7S0FDSCxDQUFDO0FBQ0osQ0FBQztBQWpCRCxrREFpQkMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBCcm9hZGNhc3QgbWVzc2FnZSBtZWFudCB0byBiZSBzZW50IHRvIG11bHRpcGxlIHBhcnRpZXNcbmludGVyZmFjZSBCcm9hZGNhc3RNZXNzYWdlPFQ+IHtcbiAgcGF5bG9hZDogVDtcbiAgZnJvbTogbnVtYmVyO1xufVxuXG4vLyBQMlAgbWVzc2FnZSBtZWFudCB0byBiZSBzZW50IHRvIGEgc3BlY2lmaWMgcGFydHlcbmludGVyZmFjZSBQMlBNZXNzYWdlPFQsIEc+IHtcbiAgcGF5bG9hZDogVDtcbiAgZnJvbTogbnVtYmVyO1xuICBjb21taXRtZW50PzogRztcbiAgdG86IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gRGtnU3RhdGUge1xuICBVbmluaXRpYWxpemVkID0gMCxcbiAgUm91bmQxLFxuICBSb3VuZDIsXG4gIFJvdW5kMyxcbiAgUm91bmQ0LFxuICBDb21wbGV0ZSxcbiAgSW52YWxpZFN0YXRlLFxufVxuXG5leHBvcnQgZW51bSBEc2dTdGF0ZSB7XG4gIFVuaW5pdGlhbGl6ZWQgPSAwLFxuICBSb3VuZDEsXG4gIFJvdW5kMixcbiAgUm91bmQzLFxuICBSb3VuZDQsXG4gIENvbXBsZXRlLFxuICBJbnZhbGlkU3RhdGUsXG59XG5cbmV4cG9ydCB0eXBlIEF1dGhFbmNNZXNzYWdlID0ge1xuICBlbmNyeXB0ZWRNZXNzYWdlOiBzdHJpbmc7XG4gIHNpZ25hdHVyZTogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIEF1dGhNZXNzYWdlID0ge1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIHNpZ25hdHVyZTogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIFBhcnR5R3BnS2V5ID0ge1xuICBwYXJ0eUlkOiBudW1iZXI7XG4gIGdwZ0tleTogc3RyaW5nO1xufTtcbmV4cG9ydCB0eXBlIERrbHNTaWduYXR1cmUgPSB7XG4gIFI6IFVpbnQ4QXJyYXk7XG4gIFM6IFVpbnQ4QXJyYXk7XG59O1xuZXhwb3J0IHR5cGUgU2VyaWFsaXplZEJyb2FkY2FzdE1lc3NhZ2UgPSBCcm9hZGNhc3RNZXNzYWdlPHN0cmluZz47XG5leHBvcnQgdHlwZSBEZXNlcmlhbGl6ZWRCcm9hZGNhc3RNZXNzYWdlID0gQnJvYWRjYXN0TWVzc2FnZTxVaW50OEFycmF5PjtcbmV4cG9ydCB0eXBlIFNlcmlhbGl6ZWRQMlBNZXNzYWdlID0gUDJQTWVzc2FnZTxzdHJpbmcsIHN0cmluZz47XG5leHBvcnQgdHlwZSBEZXNlcmlhbGl6ZWRQMlBNZXNzYWdlID0gUDJQTWVzc2FnZTxVaW50OEFycmF5LCBVaW50OEFycmF5PjtcbmV4cG9ydCB0eXBlIEF1dGhFbmNQMlBNZXNzYWdlID0gUDJQTWVzc2FnZTxBdXRoRW5jTWVzc2FnZSwgc3RyaW5nPjtcbmV4cG9ydCB0eXBlIEF1dGhCcm9hZGNhc3RNZXNzYWdlID0gQnJvYWRjYXN0TWVzc2FnZTxBdXRoTWVzc2FnZT47XG5leHBvcnQgdHlwZSBTZXJpYWxpemVkTWVzc2FnZXMgPSB7XG4gIHAycE1lc3NhZ2VzOiBTZXJpYWxpemVkUDJQTWVzc2FnZVtdO1xuICBicm9hZGNhc3RNZXNzYWdlczogU2VyaWFsaXplZEJyb2FkY2FzdE1lc3NhZ2VbXTtcbn07XG5leHBvcnQgdHlwZSBBdXRoRW5jTWVzc2FnZXMgPSB7XG4gIHAycE1lc3NhZ2VzOiBBdXRoRW5jUDJQTWVzc2FnZVtdO1xuICBicm9hZGNhc3RNZXNzYWdlczogQXV0aEJyb2FkY2FzdE1lc3NhZ2VbXTtcbn07XG5leHBvcnQgdHlwZSBEZXNlcmlhbGl6ZWRNZXNzYWdlcyA9IHtcbiAgcDJwTWVzc2FnZXM6IERlc2VyaWFsaXplZFAyUE1lc3NhZ2VbXTtcbiAgYnJvYWRjYXN0TWVzc2FnZXM6IERlc2VyaWFsaXplZEJyb2FkY2FzdE1lc3NhZ2VbXTtcbn07XG5cbi8qKlxuICogU2VyaWFsaXplcyBtZXNzYWdlcyBwYXlsb2FkcyB0byBiYXNlNjQgc3RyaW5ncy5cbiAqIEBwYXJhbSBtZXNzYWdlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gc2VyaWFsaXplTWVzc2FnZXMobWVzc2FnZXM6IERlc2VyaWFsaXplZE1lc3NhZ2VzKTogU2VyaWFsaXplZE1lc3NhZ2VzIHtcbiAgcmV0dXJuIHtcbiAgICBwMnBNZXNzYWdlczogbWVzc2FnZXMucDJwTWVzc2FnZXMubWFwKChtKSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICB0bzogbS50byxcbiAgICAgICAgZnJvbTogbS5mcm9tLFxuICAgICAgICBwYXlsb2FkOiBCdWZmZXIuZnJvbShtLnBheWxvYWQpLnRvU3RyaW5nKCdiYXNlNjQnKSxcbiAgICAgICAgY29tbWl0bWVudDogbS5jb21taXRtZW50ID8gQnVmZmVyLmZyb20obS5jb21taXRtZW50KS50b1N0cmluZygnYmFzZTY0JykgOiBtLmNvbW1pdG1lbnQsXG4gICAgICB9O1xuICAgIH0pLFxuICAgIGJyb2FkY2FzdE1lc3NhZ2VzOiBtZXNzYWdlcy5icm9hZGNhc3RNZXNzYWdlcy5tYXAoKG0pID0+IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGZyb206IG0uZnJvbSxcbiAgICAgICAgcGF5bG9hZDogQnVmZmVyLmZyb20obS5wYXlsb2FkKS50b1N0cmluZygnYmFzZTY0JyksXG4gICAgICB9O1xuICAgIH0pLFxuICB9O1xufVxuXG4vKipcbiAqIERlc3JpYWxpemVzIG1lc3NhZ2VzIHBheWxvYWRzIHRvIFVpbnQ4QXJyYXkuXG4gKiBAcGFyYW0gbWVzc2FnZXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlc2VyaWFsaXplTWVzc2FnZXMobWVzc2FnZXM6IFNlcmlhbGl6ZWRNZXNzYWdlcyk6IERlc2VyaWFsaXplZE1lc3NhZ2VzIHtcbiAgcmV0dXJuIHtcbiAgICBwMnBNZXNzYWdlczogbWVzc2FnZXMucDJwTWVzc2FnZXMubWFwKChtKSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICB0bzogbS50byxcbiAgICAgICAgZnJvbTogbS5mcm9tLFxuICAgICAgICBwYXlsb2FkOiBuZXcgVWludDhBcnJheShCdWZmZXIuZnJvbShtLnBheWxvYWQsICdiYXNlNjQnKSksXG4gICAgICAgIGNvbW1pdG1lbnQ6IG0uY29tbWl0bWVudCA/IG5ldyBVaW50OEFycmF5KEJ1ZmZlci5mcm9tKG0uY29tbWl0bWVudCwgJ2Jhc2U2NCcpKSA6IHVuZGVmaW5lZCxcbiAgICAgIH07XG4gICAgfSksXG4gICAgYnJvYWRjYXN0TWVzc2FnZXM6IG1lc3NhZ2VzLmJyb2FkY2FzdE1lc3NhZ2VzLm1hcCgobSkgPT4ge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgZnJvbTogbS5mcm9tLFxuICAgICAgICBwYXlsb2FkOiBuZXcgVWludDhBcnJheShCdWZmZXIuZnJvbShtLnBheWxvYWQsICdiYXNlNjQnKSksXG4gICAgICB9O1xuICAgIH0pLFxuICB9O1xufVxuIl19
|
package/dist/src/tss/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC"}
|
package/dist/src/tss/index.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
11
15
|
};
|
|
12
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
17
|
__exportStar(require("./ecdsa"), exports);
|
|
14
|
-
|
|
18
|
+
__exportStar(require("./ecdsa-dkls"), exports);
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIsK0NBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lY2RzYSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZHNhLWRrbHMnO1xuIl19
|