@bitgo-beta/sdk-lib-mpc 8.2.0-beta.39 → 8.2.0-beta.391

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.
Files changed (92) hide show
  1. package/CHANGELOG.md +525 -0
  2. package/dist/src/curves/constant.d.ts +2 -0
  3. package/dist/src/curves/constant.d.ts.map +1 -0
  4. package/dist/src/curves/constant.js +6 -0
  5. package/dist/src/curves/{baseCurve.d.ts → ed25519.d.ts} +9 -7
  6. package/dist/src/curves/ed25519.d.ts.map +1 -0
  7. package/dist/src/curves/ed25519.js +72 -0
  8. package/dist/src/curves/ed25519Bip32HdTree.d.ts +10 -0
  9. package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +1 -0
  10. package/dist/src/curves/ed25519Bip32HdTree.js +85 -0
  11. package/dist/src/curves/index.d.ts +6 -1
  12. package/dist/src/curves/index.d.ts.map +1 -1
  13. package/dist/src/curves/index.js +12 -3
  14. package/dist/src/curves/secp256k1.d.ts +3 -1
  15. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  16. package/dist/src/curves/secp256k1.js +29 -38
  17. package/dist/src/curves/secp256k1Bip32HdTree.d.ts +8 -0
  18. package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +1 -0
  19. package/dist/src/curves/secp256k1Bip32HdTree.js +54 -0
  20. package/dist/src/curves/types.d.ts +36 -0
  21. package/dist/src/curves/types.d.ts.map +1 -0
  22. package/dist/src/curves/types.js +3 -0
  23. package/dist/src/curves/util.d.ts +2 -0
  24. package/dist/src/curves/util.d.ts.map +1 -0
  25. package/dist/src/curves/util.js +11 -0
  26. package/dist/src/hashCommitment.d.ts +17 -0
  27. package/dist/src/hashCommitment.d.ts.map +1 -0
  28. package/dist/src/hashCommitment.js +45 -0
  29. package/dist/src/index.d.ts +6 -2
  30. package/dist/src/index.d.ts.map +1 -1
  31. package/dist/src/index.js +25 -4
  32. package/dist/src/openssl/index.js +6 -2
  33. package/dist/src/openssl/openssl.js +3 -3
  34. package/dist/src/safePrime.d.ts +3 -0
  35. package/dist/src/safePrime.d.ts.map +1 -0
  36. package/dist/src/safePrime.js +20 -0
  37. package/dist/src/schnorrProof.d.ts +22 -0
  38. package/dist/src/schnorrProof.d.ts.map +1 -0
  39. package/dist/src/schnorrProof.js +62 -0
  40. package/dist/src/shamir/index.d.ts +3 -0
  41. package/dist/src/shamir/index.d.ts.map +1 -0
  42. package/dist/src/shamir/index.js +19 -0
  43. package/dist/src/shamir/shamir.d.ts +38 -0
  44. package/dist/src/shamir/shamir.d.ts.map +1 -0
  45. package/dist/src/shamir/shamir.js +136 -0
  46. package/dist/src/shamir/types.d.ts +5 -0
  47. package/dist/src/shamir/types.d.ts.map +1 -0
  48. package/dist/src/shamir/types.js +3 -0
  49. package/dist/src/tss/ecdsa/index.d.ts +1 -0
  50. package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
  51. package/dist/src/tss/ecdsa/index.js +8 -3
  52. package/dist/src/tss/ecdsa/paillierproof.js +6 -6
  53. package/dist/src/tss/ecdsa/rangeproof.d.ts +0 -1
  54. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  55. package/dist/src/tss/ecdsa/rangeproof.js +102 -108
  56. package/dist/src/tss/ecdsa/types.d.ts +16 -0
  57. package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
  58. package/dist/src/tss/ecdsa/types.js +19 -20
  59. package/dist/src/tss/ecdsa/zkVProof.d.ts +25 -0
  60. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
  61. package/dist/src/tss/ecdsa/zkVProof.js +71 -0
  62. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +43 -0
  63. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  64. package/dist/src/tss/ecdsa-dkls/commsLayer.js +222 -0
  65. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +26 -0
  66. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  67. package/dist/src/tss/ecdsa-dkls/dkg.js +222 -0
  68. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +30 -0
  69. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  70. package/dist/src/tss/ecdsa-dkls/dsg.js +174 -0
  71. package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
  72. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
  73. package/dist/src/tss/ecdsa-dkls/index.js +32 -0
  74. package/dist/src/tss/ecdsa-dkls/types.d.ts +119 -0
  75. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
  76. package/dist/src/tss/ecdsa-dkls/types.js +155 -0
  77. package/dist/src/tss/ecdsa-dkls/util.d.ts +28 -0
  78. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  79. package/dist/src/tss/ecdsa-dkls/util.js +261 -0
  80. package/dist/src/tss/index.d.ts +1 -0
  81. package/dist/src/tss/index.d.ts.map +1 -1
  82. package/dist/src/tss/index.js +7 -2
  83. package/dist/src/types.d.ts +14 -0
  84. package/dist/src/types.d.ts.map +1 -0
  85. package/dist/src/types.js +3 -0
  86. package/dist/src/util.d.ts +8 -2
  87. package/dist/src/util.d.ts.map +1 -1
  88. package/dist/src/util.js +35 -13
  89. package/dist/tsconfig.tsbuildinfo +1 -3645
  90. package/package.json +17 -7
  91. package/dist/src/curves/baseCurve.d.ts.map +0 -1
  92. package/dist/src/curves/baseCurve.js +0 -6
@@ -0,0 +1,222 @@
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_x_1 = require("cbor-x");
7
+ const util_1 = require("../../util");
8
+ const curves_1 = require("../../curves");
9
+ class Dkg {
10
+ constructor(n, t, partyIdx, seed, retrofitData) {
11
+ this.dkgState = types_1.DkgState.Uninitialized;
12
+ this.n = n;
13
+ this.t = t;
14
+ this.partyIdx = partyIdx;
15
+ this.chainCodeCommitment = undefined;
16
+ this.retrofitData = retrofitData;
17
+ this.seed = seed;
18
+ }
19
+ _restoreSession() {
20
+ if (!this.dkgSession) {
21
+ this.dkgSession = dkls_wasm_ll_node_1.KeygenSession.fromBytes(this.dkgSessionBytes);
22
+ }
23
+ }
24
+ _createDKLsRetrofitKeyShare() {
25
+ if (this.retrofitData) {
26
+ if (!this.retrofitData.xShare.y || !this.retrofitData.xShare.chaincode || !this.retrofitData.xShare.x) {
27
+ throw Error('xShare must have a public key, private share value, and a chaincode.');
28
+ }
29
+ const xiList = [];
30
+ for (let i = 0; i < this.n; i++) {
31
+ xiList.push(Array.from((0, util_1.bigIntToBufferBE)(BigInt(i + 1), 32)));
32
+ }
33
+ const secp256k1 = new curves_1.Secp256k1Curve();
34
+ const dklsKeyShare = {
35
+ total_parties: this.n,
36
+ threshold: this.t,
37
+ rank_list: new Array(this.n).fill(0),
38
+ party_id: this.partyIdx,
39
+ public_key: Array.from(Buffer.from(this.retrofitData.xShare.y, 'hex')),
40
+ root_chain_code: Array.from(Buffer.from(this.retrofitData.xShare.chaincode, 'hex')),
41
+ final_session_id: Array(32).fill(0),
42
+ seed_ot_receivers: new Array(this.n - 1).fill(Array(32832).fill(0)),
43
+ seed_ot_senders: new Array(this.n - 1).fill(Array(32768).fill(0)),
44
+ sent_seed_list: [Array(32).fill(0)],
45
+ rec_seed_list: [Array(32).fill(0)],
46
+ s_i: Array.from(Buffer.from(this.retrofitData.xShare.x, 'hex')),
47
+ // big_s_list is now created internally during the protocol so isn't needed here, however a valid KeyShare object needs to have it.
48
+ // a dummy public key is used to fill big_s_list.
49
+ big_s_list: new Array(this.n).fill(Array.from((0, util_1.bigIntToBufferBE)(secp256k1.basePointMult(BigInt('0x' + this.retrofitData.xShare.x))))),
50
+ x_i_list: this.retrofitData.xiList ? this.retrofitData.xiList : xiList,
51
+ };
52
+ this.dklsKeyShareRetrofitObject = dkls_wasm_ll_node_1.Keyshare.fromBytes((0, cbor_x_1.encode)(dklsKeyShare));
53
+ }
54
+ }
55
+ _deserializeState() {
56
+ if (!this.dkgSession) {
57
+ throw Error('Session not intialized');
58
+ }
59
+ const round = (0, cbor_x_1.decode)(this.dkgSession.toBytes()).round;
60
+ switch (round) {
61
+ case 'WaitMsg1':
62
+ this.dkgState = types_1.DkgState.Round1;
63
+ break;
64
+ case 'WaitMsg2':
65
+ this.dkgState = types_1.DkgState.Round2;
66
+ break;
67
+ case 'WaitMsg3':
68
+ this.dkgState = types_1.DkgState.Round3;
69
+ break;
70
+ case 'WaitMsg4':
71
+ this.dkgState = types_1.DkgState.Round4;
72
+ break;
73
+ case 'Ended':
74
+ this.dkgState = types_1.DkgState.Complete;
75
+ break;
76
+ default:
77
+ this.dkgState = types_1.DkgState.InvalidState;
78
+ throw Error(`Invalid State: ${round}`);
79
+ }
80
+ }
81
+ async initDkg() {
82
+ if (this.t > this.n || this.partyIdx >= this.n) {
83
+ throw Error('Invalid parameters for DKG');
84
+ }
85
+ if (this.dkgState != types_1.DkgState.Uninitialized) {
86
+ throw Error('DKG session already initialized');
87
+ }
88
+ if (typeof window !== 'undefined') {
89
+ const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');
90
+ await initDkls.default();
91
+ }
92
+ this._createDKLsRetrofitKeyShare();
93
+ if (this.seed && this.seed.length !== 32) {
94
+ throw Error(`Seed should be 32 bytes, got ${this.seed.length}.`);
95
+ }
96
+ if (this.dklsKeyShareRetrofitObject) {
97
+ this.dkgSession = this.seed
98
+ ? dkls_wasm_ll_node_1.KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject, new Uint8Array(this.seed))
99
+ : dkls_wasm_ll_node_1.KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject);
100
+ }
101
+ else {
102
+ this.dkgSession = this.seed
103
+ ? new dkls_wasm_ll_node_1.KeygenSession(this.n, this.t, this.partyIdx, new Uint8Array(this.seed))
104
+ : new dkls_wasm_ll_node_1.KeygenSession(this.n, this.t, this.partyIdx);
105
+ }
106
+ try {
107
+ const payload = this.dkgSession.createFirstMessage().payload;
108
+ this._deserializeState();
109
+ return {
110
+ payload: payload,
111
+ from: this.partyIdx,
112
+ };
113
+ }
114
+ catch (e) {
115
+ throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);
116
+ }
117
+ }
118
+ getKeyShare() {
119
+ if (!this.keyShareBuff) {
120
+ throw Error('Can not get key share, DKG is not complete yet.');
121
+ }
122
+ return this.keyShareBuff;
123
+ }
124
+ getReducedKeyShare() {
125
+ if (!this.keyShareBuff) {
126
+ throw Error('Can not get key share, DKG is not complete yet.');
127
+ }
128
+ const decodedKeyshare = (0, cbor_x_1.decode)(this.keyShareBuff);
129
+ const reducedKeyShare = {
130
+ bigSList: decodedKeyshare.big_s_list,
131
+ xList: decodedKeyshare.x_i_list,
132
+ rootChainCode: decodedKeyshare.root_chain_code,
133
+ prv: decodedKeyshare.s_i,
134
+ pub: decodedKeyshare.public_key,
135
+ };
136
+ const encodedKeyShare = (0, cbor_x_1.encode)(reducedKeyShare);
137
+ return encodedKeyShare;
138
+ }
139
+ handleIncomingMessages(messagesForIthRound) {
140
+ let nextRoundMessages = [];
141
+ let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
142
+ this._restoreSession();
143
+ if (!this.dkgSession) {
144
+ throw Error('Session not initialized');
145
+ }
146
+ try {
147
+ if (this.dkgState === types_1.DkgState.Round3) {
148
+ const commitmentsUnsorted = messagesForIthRound.p2pMessages
149
+ .map((m) => {
150
+ return { from: m.from, commitment: m.commitment };
151
+ })
152
+ .concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);
153
+ const commitmentsSorted = commitmentsUnsorted
154
+ .sort((a, b) => {
155
+ return a.from - b.from;
156
+ })
157
+ .map((c) => c.commitment);
158
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
159
+ .map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
160
+ .concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), commitmentsSorted);
161
+ }
162
+ else {
163
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
164
+ .map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
165
+ .concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))), undefined);
166
+ }
167
+ if (this.dkgState === types_1.DkgState.Round4) {
168
+ this.dkgKeyShare = this.dkgSession.keyshare();
169
+ this.keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());
170
+ this.dkgKeyShare.free();
171
+ if (this.dklsKeyShareRetrofitObject) {
172
+ this.dklsKeyShareRetrofitObject.free();
173
+ }
174
+ this.dkgState = types_1.DkgState.Complete;
175
+ return { broadcastMessages: [], p2pMessages: [] };
176
+ }
177
+ else {
178
+ // Update round data.
179
+ this._deserializeState();
180
+ }
181
+ if (this.dkgState === types_1.DkgState.Round2) {
182
+ this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();
183
+ }
184
+ nextRoundDeserializedMessages = {
185
+ p2pMessages: nextRoundMessages
186
+ .filter((m) => m.to_id !== undefined)
187
+ .map((m) => {
188
+ const p2pReturn = {
189
+ payload: m.payload,
190
+ from: m.from_id,
191
+ to: m.to_id,
192
+ commitment: this.chainCodeCommitment,
193
+ };
194
+ return p2pReturn;
195
+ }),
196
+ broadcastMessages: nextRoundMessages
197
+ .filter((m) => m.to_id === undefined)
198
+ .map((m) => {
199
+ const broadcastReturn = {
200
+ payload: m.payload,
201
+ from: m.from_id,
202
+ };
203
+ return broadcastReturn;
204
+ }),
205
+ };
206
+ }
207
+ catch (e) {
208
+ throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`);
209
+ }
210
+ finally {
211
+ nextRoundMessages.forEach((m) => m.free());
212
+ // Session is freed when keyshare is called.
213
+ if (this.dkgState !== types_1.DkgState.Complete) {
214
+ this.dkgSessionBytes = this.dkgSession.toBytes();
215
+ this.dkgSession = undefined;
216
+ }
217
+ }
218
+ return nextRoundDeserializedMessages;
219
+ }
220
+ }
221
+ exports.Dkg = Dkg;
222
+ //# 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, ReducedKeyShare, RetrofitData } from './types';\nimport { decode, encode } from 'cbor-x';\nimport { bigIntToBufferBE } from '../../util';\nimport { Secp256k1Curve } from '../../curves';\n\nexport class Dkg {\n  protected dkgSession: KeygenSession | undefined;\n  protected dkgSessionBytes: Uint8Array;\n  protected dkgKeyShare: Keyshare;\n  protected keyShareBuff: Buffer;\n  protected n: number;\n  protected t: number;\n  protected seed: Buffer | undefined;\n  protected chainCodeCommitment: Uint8Array | undefined;\n  protected partyIdx: number;\n  protected dkgState: DkgState = DkgState.Uninitialized;\n  protected dklsKeyShareRetrofitObject: Keyshare | undefined;\n  protected retrofitData: RetrofitData | undefined;\n\n  constructor(n: number, t: number, partyIdx: number, seed?: Buffer, retrofitData?: RetrofitData) {\n    this.n = n;\n    this.t = t;\n    this.partyIdx = partyIdx;\n    this.chainCodeCommitment = undefined;\n    this.retrofitData = retrofitData;\n    this.seed = seed;\n  }\n\n  private _restoreSession() {\n    if (!this.dkgSession) {\n      this.dkgSession = KeygenSession.fromBytes(this.dkgSessionBytes);\n    }\n  }\n\n  private _createDKLsRetrofitKeyShare() {\n    if (this.retrofitData) {\n      if (!this.retrofitData.xShare.y || !this.retrofitData.xShare.chaincode || !this.retrofitData.xShare.x) {\n        throw Error('xShare must have a public key, private share value, and a chaincode.');\n      }\n      const xiList: Array<Array<number>> = [];\n      for (let i = 0; i < this.n; i++) {\n        xiList.push(Array.from(bigIntToBufferBE(BigInt(i + 1), 32)));\n      }\n      const secp256k1 = new Secp256k1Curve();\n      const dklsKeyShare = {\n        total_parties: this.n,\n        threshold: this.t,\n        rank_list: new Array(this.n).fill(0),\n        party_id: this.partyIdx,\n        public_key: Array.from(Buffer.from(this.retrofitData.xShare.y, 'hex')),\n        root_chain_code: Array.from(Buffer.from(this.retrofitData.xShare.chaincode, 'hex')),\n        final_session_id: Array(32).fill(0),\n        seed_ot_receivers: new Array(this.n - 1).fill(Array(32832).fill(0)),\n        seed_ot_senders: new Array(this.n - 1).fill(Array(32768).fill(0)),\n        sent_seed_list: [Array(32).fill(0)],\n        rec_seed_list: [Array(32).fill(0)],\n        s_i: Array.from(Buffer.from(this.retrofitData.xShare.x, 'hex')),\n        // big_s_list is now created internally during the protocol so isn't needed here, however a valid KeyShare object needs to have it.\n        // a dummy public key is used to fill big_s_list.\n        big_s_list: new Array(this.n).fill(\n          Array.from(bigIntToBufferBE(secp256k1.basePointMult(BigInt('0x' + this.retrofitData.xShare.x))))\n        ),\n        x_i_list: this.retrofitData.xiList ? this.retrofitData.xiList : xiList,\n      };\n      this.dklsKeyShareRetrofitObject = Keyshare.fromBytes(encode(dklsKeyShare));\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 Error(`Invalid State: ${round}`);\n    }\n  }\n\n  async initDkg(): Promise<DeserializedBroadcastMessage> {\n    if (this.t > this.n || this.partyIdx >= this.n) {\n      throw Error('Invalid parameters for DKG');\n    }\n    if (this.dkgState != DkgState.Uninitialized) {\n      throw Error('DKG session already initialized');\n    }\n    if (typeof window !== 'undefined') {\n      const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls.default();\n    }\n    this._createDKLsRetrofitKeyShare();\n    if (this.seed && this.seed.length !== 32) {\n      throw Error(`Seed should be 32 bytes, got ${this.seed.length}.`);\n    }\n    if (this.dklsKeyShareRetrofitObject) {\n      this.dkgSession = this.seed\n        ? KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject, new Uint8Array(this.seed))\n        : KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject);\n    } else {\n      this.dkgSession = this.seed\n        ? new KeygenSession(this.n, this.t, this.partyIdx, new Uint8Array(this.seed))\n        : new KeygenSession(this.n, this.t, this.partyIdx);\n    }\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(`Error while creating the first message from party ${this.partyIdx}: ${e}`);\n    }\n  }\n\n  getKeyShare(): Buffer {\n    if (!this.keyShareBuff) {\n      throw Error('Can not get key share, DKG is not complete yet.');\n    }\n    return this.keyShareBuff;\n  }\n\n  getReducedKeyShare(): Buffer {\n    if (!this.keyShareBuff) {\n      throw Error('Can not get key share, DKG is not complete yet.');\n    }\n    const decodedKeyshare = decode(this.keyShareBuff);\n    const reducedKeyShare: ReducedKeyShare = {\n      bigSList: decodedKeyshare.big_s_list,\n      xList: decodedKeyshare.x_i_list,\n      rootChainCode: decodedKeyshare.root_chain_code,\n      prv: decodedKeyshare.s_i,\n      pub: decodedKeyshare.public_key,\n    };\n    const encodedKeyShare = encode(reducedKeyShare);\n    return encodedKeyShare;\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.keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());\n        this.dkgKeyShare.free();\n        if (this.dklsKeyShareRetrofitObject) {\n          this.dklsKeyShareRetrofitObject.free();\n        }\n        this.dkgState = DkgState.Complete;\n        return { broadcastMessages: [], p2pMessages: [] };\n      } else {\n        // Update round 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(`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 } from '@silencelaboratories/dkls-wasm-ll-node';
3
+ import { DeserializedBroadcastMessage, DeserializedDklsSignature, DeserializedMessages, DsgState } from './types';
4
+ export declare class Dsg {
5
+ protected dsgSession: SignSession | undefined;
6
+ protected dsgSessionBytes: Uint8Array;
7
+ private _signature;
8
+ protected keyShareBytes: Buffer;
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(): DeserializedDklsSignature;
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,EAAqB,MAAM,wCAAwC,CAAC;AACxF,OAAO,EAAE,4BAA4B,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGlH,qBAAa,GAAG;IACd,SAAS,CAAC,UAAU,EAAE,WAAW,GAAG,SAAS,CAAC;IAC9C,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC;IACtC,OAAO,CAAC,UAAU,CAAwC;IAC1D,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;IAChC,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;IAO3F,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,iBAAiB;IAwBnB,IAAI,IAAI,OAAO,CAAC,4BAA4B,CAAC;IAyBnD,IAAI,SAAS,IAAI,yBAAyB,CAKzC;IAED;;OAEG;IACH,UAAU,IAAI,IAAI;IASlB;;;;;OAKG;IACH,sBAAsB,CAAC,mBAAmB,EAAE,oBAAoB,GAAG,oBAAoB;CAmFxF"}
@@ -0,0 +1,174 @@
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_x_1 = require("cbor-x");
7
+ class Dsg {
8
+ constructor(keyShare, partyIdx, derivationPath, messageHash) {
9
+ this.dsgState = types_1.DsgState.Uninitialized;
10
+ this.partyIdx = partyIdx;
11
+ this.keyShareBytes = keyShare;
12
+ this.derivationPath = derivationPath;
13
+ this.messageHash = messageHash;
14
+ }
15
+ _restoreSession() {
16
+ if (!this.dsgSession) {
17
+ this.dsgSession = dkls_wasm_ll_node_1.SignSession.fromBytes(this.dsgSessionBytes);
18
+ }
19
+ }
20
+ _deserializeState() {
21
+ if (!this.dsgSession) {
22
+ throw Error('Session not intialized');
23
+ }
24
+ const round = (0, cbor_x_1.decode)(this.dsgSession.toBytes()).round;
25
+ switch (round) {
26
+ case 'WaitMsg1':
27
+ this.dsgState = types_1.DsgState.Round1;
28
+ break;
29
+ case 'WaitMsg2':
30
+ this.dsgState = types_1.DsgState.Round2;
31
+ break;
32
+ case 'WaitMsg3':
33
+ this.dsgState = types_1.DsgState.Round3;
34
+ break;
35
+ case 'Ended':
36
+ this.dsgState = types_1.DsgState.Complete;
37
+ break;
38
+ default:
39
+ this.dsgState = types_1.DsgState.InvalidState;
40
+ throw Error(`Invalid State: ${round}`);
41
+ }
42
+ }
43
+ async init() {
44
+ if (this.dsgState !== types_1.DsgState.Uninitialized) {
45
+ throw Error('DSG session already initialized');
46
+ }
47
+ if (typeof window !== 'undefined') {
48
+ const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');
49
+ await initDkls.default();
50
+ }
51
+ const keyShare = dkls_wasm_ll_node_1.Keyshare.fromBytes(this.keyShareBytes);
52
+ if (keyShare.partyId !== this.partyIdx) {
53
+ throw Error(`Party index: ${this.partyIdx} does not match key share partyId: ${keyShare.partyId} `);
54
+ }
55
+ this.dsgSession = new dkls_wasm_ll_node_1.SignSession(keyShare, this.derivationPath);
56
+ try {
57
+ const payload = this.dsgSession.createFirstMessage().payload;
58
+ this._deserializeState();
59
+ return {
60
+ payload: payload,
61
+ from: this.partyIdx,
62
+ };
63
+ }
64
+ catch (e) {
65
+ throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);
66
+ }
67
+ }
68
+ get signature() {
69
+ if (!this._signature) {
70
+ throw Error('Can not request signature. Signature not produced yet.');
71
+ }
72
+ return this._signature;
73
+ }
74
+ /**
75
+ * Ends the DSG session by freeing any heap allocations from wasm. Note that the session is freed if a signature is produced.
76
+ */
77
+ endSession() {
78
+ if (this.signature) {
79
+ new Error('Session already ended because combined signature was produced.');
80
+ }
81
+ if (this.dsgSession) {
82
+ this.dsgSession.free();
83
+ }
84
+ }
85
+ /**
86
+ * Proccesses incoming messages to this party in the DKLs DSG protocol and
87
+ * produces messages from this party to other parties for the next round.
88
+ * @param messagesForIthRound - messages to process the current round
89
+ * @returns {DeserializedMessages} - messages to send to other parties for the next round
90
+ */
91
+ handleIncomingMessages(messagesForIthRound) {
92
+ let nextRoundMessages = [];
93
+ let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
94
+ this._restoreSession();
95
+ if (!this.dsgSession) {
96
+ throw Error('Session not initialized');
97
+ }
98
+ try {
99
+ if (this.dsgState === types_1.DsgState.Round4) {
100
+ this.dsgState = types_1.DsgState.Complete;
101
+ const combineResult = this.dsgSession.combine(messagesForIthRound.broadcastMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined)));
102
+ this._signature = {
103
+ R: combineResult[0],
104
+ S: combineResult[1],
105
+ };
106
+ return { broadcastMessages: [], p2pMessages: [] };
107
+ }
108
+ else {
109
+ nextRoundMessages = this.dsgSession.handleMessages(messagesForIthRound.broadcastMessages
110
+ .map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, undefined))
111
+ .concat(messagesForIthRound.p2pMessages.map((m) => new dkls_wasm_ll_node_1.Message(m.payload, m.from, m.to))));
112
+ }
113
+ if (this.dsgState === types_1.DsgState.Round3) {
114
+ nextRoundMessages = [this.dsgSession.lastMessage(this.messageHash)];
115
+ this.dsgState = types_1.DsgState.Round4;
116
+ return {
117
+ broadcastMessages: [
118
+ {
119
+ payload: nextRoundMessages[0].payload,
120
+ from: nextRoundMessages[0].from_id,
121
+ signatureR: (0, cbor_x_1.decode)(this.dsgSession.toBytes()).round.WaitMsg4.r,
122
+ },
123
+ ],
124
+ p2pMessages: [],
125
+ };
126
+ }
127
+ else {
128
+ // Update round data.
129
+ this._deserializeState();
130
+ }
131
+ nextRoundDeserializedMessages = {
132
+ p2pMessages: nextRoundMessages
133
+ .filter((m) => m.to_id !== undefined)
134
+ .map((m) => {
135
+ if (m.to_id === undefined) {
136
+ throw Error('Invalid P2P message, missing to_id.');
137
+ }
138
+ const p2pReturn = {
139
+ payload: m.payload,
140
+ from: m.from_id,
141
+ to: m.to_id,
142
+ };
143
+ return p2pReturn;
144
+ }),
145
+ broadcastMessages: nextRoundMessages
146
+ .filter((m) => m.to_id === undefined)
147
+ .map((m) => {
148
+ const broadcastReturn = {
149
+ payload: m.payload,
150
+ from: m.from_id,
151
+ };
152
+ return broadcastReturn;
153
+ }),
154
+ };
155
+ }
156
+ catch (e) {
157
+ if (e.message.startsWith('Abort the protocol and ban')) {
158
+ throw Error('Signing aborted. Please stop all transaction signing from this wallet and contact support@bitgo.com.');
159
+ }
160
+ throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dsgState}: ${e}`);
161
+ }
162
+ finally {
163
+ nextRoundMessages.forEach((m) => m.free());
164
+ // Session is freed when combine is called.
165
+ if (this.dsgState !== types_1.DsgState.Complete) {
166
+ this.dsgSessionBytes = this.dsgSession.toBytes();
167
+ this.dsgSession = undefined;
168
+ }
169
+ }
170
+ return nextRoundDeserializedMessages;
171
+ }
172
+ }
173
+ exports.Dsg = Dsg;
174
+ //# 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, DeserializedDklsSignature, DeserializedMessages, DsgState } from './types';\nimport { decode } from 'cbor-x';\n\nexport class Dsg {\n  protected dsgSession: SignSession | undefined;\n  protected dsgSessionBytes: Uint8Array;\n  private _signature: DeserializedDklsSignature | undefined;\n  protected keyShareBytes: Buffer;\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.partyIdx = partyIdx;\n    this.keyShareBytes = keyShare;\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 Error(`Invalid State: ${round}`);\n    }\n  }\n\n  async init(): Promise<DeserializedBroadcastMessage> {\n    if (this.dsgState !== DsgState.Uninitialized) {\n      throw Error('DSG session already initialized');\n    }\n    if (typeof window !== 'undefined') {\n      const initDkls = require('@silencelaboratories/dkls-wasm-ll-web');\n      await initDkls.default();\n    }\n    const keyShare = Keyshare.fromBytes(this.keyShareBytes);\n    if (keyShare.partyId !== this.partyIdx) {\n      throw Error(`Party index: ${this.partyIdx} does not match key share partyId: ${keyShare.partyId} `);\n    }\n    this.dsgSession = new SignSession(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(`Error while creating the first message from party ${this.partyIdx}: ${e}`);\n    }\n  }\n\n  get signature(): DeserializedDklsSignature {\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              signatureR: decode(this.dsgSession.toBytes()).round.WaitMsg4.r,\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      if (e.message.startsWith('Abort the protocol and ban')) {\n        throw Error(\n          'Signing aborted. Please stop all transaction signing from this wallet and contact support@bitgo.com.'\n        );\n      }\n      throw Error(`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,6 @@
1
+ export * as DklsDkg from './dkg';
2
+ export * as DklsDsg from './dsg';
3
+ export * as DklsTypes from './types';
4
+ export * as DklsComms from './commsLayer';
5
+ export * as DklsUtils from './util';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -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;AACrC,OAAO,KAAK,SAAS,MAAM,cAAc,CAAC;AAC1C,OAAO,KAAK,SAAS,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,32 @@
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.DklsUtils = exports.DklsComms = 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
+ exports.DklsComms = __importStar(require("./commsLayer"));
31
+ exports.DklsUtils = __importStar(require("./util"));
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHNzL2VjZHNhLWRrbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxpREFBaUM7QUFDakMsaURBQWlDO0FBQ2pDLHFEQUFxQztBQUNyQywwREFBMEM7QUFDMUMsb0RBQW9DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogYXMgRGtsc0RrZyBmcm9tICcuL2RrZyc7XG5leHBvcnQgKiBhcyBEa2xzRHNnIGZyb20gJy4vZHNnJztcbmV4cG9ydCAqIGFzIERrbHNUeXBlcyBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGFzIERrbHNDb21tcyBmcm9tICcuL2NvbW1zTGF5ZXInO1xuZXhwb3J0ICogYXMgRGtsc1V0aWxzIGZyb20gJy4vdXRpbCc7XG4iXX0=