@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.19 → 8.2.1-alpha.191

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 (94) hide show
  1. package/CHANGELOG.md +578 -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} +8 -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 +2 -1
  15. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  16. package/dist/src/curves/secp256k1.js +22 -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 +37 -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 +1 -0
  27. package/dist/src/hashCommitment.d.ts.map +1 -1
  28. package/dist/src/hashCommitment.js +5 -5
  29. package/dist/src/index.d.ts +2 -1
  30. package/dist/src/index.d.ts.map +1 -1
  31. package/dist/src/index.js +8 -3
  32. package/dist/src/openssl/index.js +6 -2
  33. package/dist/src/openssl/openssl.d.ts +1 -2
  34. package/dist/src/openssl/openssl.d.ts.map +1 -1
  35. package/dist/src/openssl/openssl.js +4 -12
  36. package/dist/src/safePrime.d.ts +3 -0
  37. package/dist/src/safePrime.d.ts.map +1 -0
  38. package/dist/src/safePrime.js +20 -0
  39. package/dist/src/schnorrProof.d.ts +1 -0
  40. package/dist/src/schnorrProof.d.ts.map +1 -1
  41. package/dist/src/schnorrProof.js +15 -6
  42. package/dist/src/shamir/index.d.ts +3 -0
  43. package/dist/src/shamir/index.d.ts.map +1 -0
  44. package/dist/src/shamir/index.js +19 -0
  45. package/dist/src/shamir/shamir.d.ts +38 -0
  46. package/dist/src/shamir/shamir.d.ts.map +1 -0
  47. package/dist/src/shamir/shamir.js +136 -0
  48. package/dist/src/shamir/types.d.ts +5 -0
  49. package/dist/src/shamir/types.d.ts.map +1 -0
  50. package/dist/src/shamir/types.js +3 -0
  51. package/dist/src/tss/ecdsa/index.js +6 -2
  52. package/dist/src/tss/ecdsa/paillierproof.js +6 -6
  53. package/dist/src/tss/ecdsa/rangeproof.d.ts +1 -2
  54. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  55. package/dist/src/tss/ecdsa/rangeproof.js +105 -111
  56. package/dist/src/tss/ecdsa/types.d.ts +28 -17
  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 +1 -0
  60. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -1
  61. package/dist/src/tss/ecdsa/zkVProof.js +17 -7
  62. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +44 -0
  63. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  64. package/dist/src/tss/ecdsa-dkls/commsLayer.js +224 -0
  65. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +35 -0
  66. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  67. package/dist/src/tss/ecdsa-dkls/dkg.js +266 -0
  68. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +49 -0
  69. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  70. package/dist/src/tss/ecdsa-dkls/dsg.js +257 -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 +120 -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 +29 -0
  78. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  79. package/dist/src/tss/ecdsa-dkls/util.js +267 -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 +1 -0
  84. package/dist/src/types.d.ts.map +1 -1
  85. package/dist/src/util.d.ts +7 -0
  86. package/dist/src/util.d.ts.map +1 -1
  87. package/dist/src/util.js +29 -7
  88. package/dist/tsconfig.tsbuildinfo +1 -1
  89. package/package.json +27 -7
  90. package/dist/src/curves/baseCurve.d.ts.map +0 -1
  91. package/dist/src/curves/baseCurve.js +0 -6
  92. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  93. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  94. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -0,0 +1,224 @@
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.encryptAndAuthOutgoingMessages = exports.decryptAndVerifyIncomingMessages = exports.verifySignedData = exports.decryptAndVerifySignedData = exports.encryptAndDetachSignData = exports.detachSignData = void 0;
27
+ const pgp = __importStar(require("openpgp"));
28
+ /**
29
+ * Detach signs a binary and encodes it in base64
30
+ * @param data binary to encode in base64 and sign
31
+ * @param privateArmor private key to sign with
32
+ */
33
+ async function detachSignData(data, privateArmor) {
34
+ const message = await pgp.createMessage({ binary: data });
35
+ const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
36
+ const signature = await pgp.sign({
37
+ message,
38
+ signingKeys: privateKey,
39
+ format: 'armored',
40
+ detached: true,
41
+ config: {
42
+ rejectCurves: new Set(),
43
+ showVersion: false,
44
+ showComment: false,
45
+ },
46
+ });
47
+ return {
48
+ message: data.toString('base64'),
49
+ signature: signature,
50
+ };
51
+ }
52
+ exports.detachSignData = detachSignData;
53
+ /**
54
+ * Encrypts and detach signs a binary
55
+ * @param data binary to encrypt and sign
56
+ * @param publicArmor public key to encrypt with
57
+ * @param privateArmor private key to sign with
58
+ */
59
+ async function encryptAndDetachSignData(data, publicArmor, privateArmor) {
60
+ const message = await pgp.createMessage({ binary: data });
61
+ const publicKey = await pgp.readKey({ armoredKey: publicArmor });
62
+ const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
63
+ const encryptedMessage = await pgp.encrypt({
64
+ message,
65
+ encryptionKeys: publicKey,
66
+ format: 'armored',
67
+ config: {
68
+ rejectCurves: new Set(),
69
+ showVersion: false,
70
+ showComment: false,
71
+ },
72
+ });
73
+ const signature = await pgp.sign({
74
+ message,
75
+ signingKeys: privateKey,
76
+ format: 'armored',
77
+ detached: true,
78
+ config: {
79
+ rejectCurves: new Set(),
80
+ showVersion: false,
81
+ showComment: false,
82
+ },
83
+ });
84
+ return {
85
+ encryptedMessage: encryptedMessage,
86
+ signature: signature,
87
+ };
88
+ }
89
+ exports.encryptAndDetachSignData = encryptAndDetachSignData;
90
+ /**
91
+ * Decrypts and verifies signature on a binary
92
+ * @param encryptedAndSignedMessage message to decrypt and verify
93
+ * @param publicArmor public key to verify signature with
94
+ * @param privateArmor private key to decrypt with
95
+ */
96
+ async function decryptAndVerifySignedData(encryptedAndSignedMessage, publicArmor, privateArmor) {
97
+ const publicKey = await pgp.readKey({ armoredKey: publicArmor });
98
+ const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });
99
+ const decryptedMessage = await pgp.decrypt({
100
+ message: await pgp.readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),
101
+ decryptionKeys: [privateKey],
102
+ config: {
103
+ rejectCurves: new Set(),
104
+ showVersion: false,
105
+ showComment: false,
106
+ },
107
+ format: 'binary',
108
+ });
109
+ const verificationResult = await pgp.verify({
110
+ message: await pgp.createMessage({ binary: decryptedMessage.data }),
111
+ signature: await pgp.readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),
112
+ verificationKeys: publicKey,
113
+ date: null,
114
+ });
115
+ await verificationResult.signatures[0].verified;
116
+ return Buffer.from(decryptedMessage.data).toString('base64');
117
+ }
118
+ exports.decryptAndVerifySignedData = decryptAndVerifySignedData;
119
+ /**
120
+ * Verifies signature on a binary (message passed should be encoded in base64).
121
+ * @param signedMessage message to verify
122
+ * @param publicArmor public key to verify signature with
123
+ */
124
+ async function verifySignedData(signedMessage, publicArmor) {
125
+ const publicKey = await pgp.readKey({ armoredKey: publicArmor });
126
+ const verificationResult = await pgp.verify({
127
+ message: await pgp.createMessage({ binary: Buffer.from(signedMessage.message, 'base64') }),
128
+ signature: await pgp.readSignature({ armoredSignature: signedMessage.signature }),
129
+ verificationKeys: publicKey,
130
+ date: null,
131
+ });
132
+ try {
133
+ await verificationResult.signatures[0].verified;
134
+ return true;
135
+ }
136
+ catch (e) {
137
+ return false;
138
+ }
139
+ }
140
+ exports.verifySignedData = verifySignedData;
141
+ /**
142
+ * Decrypts and verifies p2p messages + verifies broadcast messages
143
+ * @param messages message to decrypt and verify
144
+ * @param pubVerificationGpgKeys public keys to verify signatures with
145
+ * @param prvDecryptionGpgKeys private keys to decrypt with
146
+ */
147
+ async function decryptAndVerifyIncomingMessages(messages, pubVerificationGpgKeys, prvDecryptionGpgKeys) {
148
+ return {
149
+ p2pMessages: await Promise.all(messages.p2pMessages.map(async (m) => {
150
+ const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);
151
+ const prvGpgKey = prvDecryptionGpgKeys.find((k) => k.partyId === m.to);
152
+ if (!pubGpgKey) {
153
+ throw Error(`No public key provided for sender with ID: ${m.from}`);
154
+ }
155
+ if (!prvGpgKey) {
156
+ throw Error(`No private key provided for recepient with ID: ${m.to}`);
157
+ }
158
+ return {
159
+ to: m.to,
160
+ from: m.from,
161
+ payload: await decryptAndVerifySignedData(m.payload, pubGpgKey.gpgKey, prvGpgKey.gpgKey),
162
+ commitment: m.commitment,
163
+ };
164
+ })),
165
+ broadcastMessages: await Promise.all(messages.broadcastMessages.map(async (m) => {
166
+ const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);
167
+ if (!pubGpgKey) {
168
+ throw Error(`No public key provided for sender with ID: ${m.from}`);
169
+ }
170
+ if (!(await verifySignedData(m.payload, pubGpgKey.gpgKey))) {
171
+ throw Error(`Failed to authenticate broadcast message from party: ${m.from}`);
172
+ }
173
+ return {
174
+ from: m.from,
175
+ payload: m.payload.message,
176
+ };
177
+ })),
178
+ };
179
+ }
180
+ exports.decryptAndVerifyIncomingMessages = decryptAndVerifyIncomingMessages;
181
+ /**
182
+ * Encrypts and signs p2p messages + signs broadcast messages
183
+ * @param messages messages to encrypt and sign
184
+ * @param pubEncryptionGpgKey public keys to encrypt data to
185
+ * @param prvAuthenticationGpgKey private keys to sign with
186
+ */
187
+ async function encryptAndAuthOutgoingMessages(messages, pubEncryptionGpgKeys, prvAuthenticationGpgKeys) {
188
+ return {
189
+ p2pMessages: await Promise.all(messages.p2pMessages.map(async (m) => {
190
+ const pubGpgKey = pubEncryptionGpgKeys.find((k) => k.partyId === m.to);
191
+ const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);
192
+ if (!pubGpgKey) {
193
+ throw Error(`No public key provided for recipient with ID: ${m.to}`);
194
+ }
195
+ if (!prvGpgKey) {
196
+ throw Error(`No private key provided for sender with ID: ${m.from}`);
197
+ }
198
+ return {
199
+ to: m.to,
200
+ from: m.from,
201
+ payload: await encryptAndDetachSignData(Buffer.from(m.payload, 'base64'), pubGpgKey.gpgKey, prvGpgKey.gpgKey),
202
+ commitment: m.commitment,
203
+ };
204
+ })),
205
+ broadcastMessages: await Promise.all(messages.broadcastMessages.map(async (m) => {
206
+ const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);
207
+ if (!prvGpgKey) {
208
+ throw Error(`No private key provided for sender with ID: ${m.from}`);
209
+ }
210
+ return {
211
+ from: m.from,
212
+ payload: await detachSignData(Buffer.from(m.payload, 'base64'), prvGpgKey.gpgKey),
213
+ signatureR: m.signatureR
214
+ ? {
215
+ message: m.signatureR,
216
+ signature: '',
217
+ }
218
+ : undefined,
219
+ };
220
+ })),
221
+ };
222
+ }
223
+ exports.encryptAndAuthOutgoingMessages = encryptAndAuthOutgoingMessages;
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commsLayer.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/commsLayer.ts"],"names":[],"mappings":"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","sourcesContent":["import { SerializedMessages, AuthEncMessage, AuthEncMessages, PartyGpgKey, AuthMessage } from './types';\nimport * as pgp from 'openpgp';\n\n/**\n * Detach signs a binary and encodes it in base64\n * @param data binary to encode in base64 and sign\n * @param privateArmor private key to sign with\n */\nexport async function detachSignData(data: Buffer, privateArmor: string): Promise<AuthMessage> {\n  const message = await pgp.createMessage({ binary: data });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const signature = await pgp.sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return {\n    message: data.toString('base64'),\n    signature: signature,\n  };\n}\n\n/**\n * Encrypts and detach signs a binary\n * @param data binary to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndDetachSignData(\n  data: Buffer,\n  publicArmor: string,\n  privateArmor: string\n): Promise<AuthEncMessage> {\n  const message = await pgp.createMessage({ binary: data });\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const encryptedMessage = await pgp.encrypt({\n    message,\n    encryptionKeys: publicKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  const signature = await pgp.sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return {\n    encryptedMessage: encryptedMessage,\n    signature: signature,\n  };\n}\n\n/**\n * Decrypts and verifies signature on a binary\n * @param encryptedAndSignedMessage message to decrypt and verify\n * @param publicArmor public key to verify signature with\n * @param privateArmor private key to decrypt with\n */\nexport async function decryptAndVerifySignedData(\n  encryptedAndSignedMessage: AuthEncMessage,\n  publicArmor: string,\n  privateArmor: string\n): Promise<string> {\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const privateKey = await pgp.readPrivateKey({ armoredKey: privateArmor });\n  const decryptedMessage = await pgp.decrypt({\n    message: await pgp.readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),\n    decryptionKeys: [privateKey],\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n    format: 'binary',\n  });\n  const verificationResult = await pgp.verify({\n    message: await pgp.createMessage({ binary: decryptedMessage.data }),\n    signature: await pgp.readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),\n    verificationKeys: publicKey,\n    date: null as unknown as undefined,\n  });\n  await verificationResult.signatures[0].verified;\n  return Buffer.from(decryptedMessage.data).toString('base64');\n}\n\n/**\n * Verifies signature on a binary (message passed should be encoded in base64).\n * @param signedMessage message to verify\n * @param publicArmor public key to verify signature with\n */\nexport async function verifySignedData(signedMessage: AuthMessage, publicArmor: string): Promise<boolean> {\n  const publicKey = await pgp.readKey({ armoredKey: publicArmor });\n  const verificationResult = await pgp.verify({\n    message: await pgp.createMessage({ binary: Buffer.from(signedMessage.message, 'base64') }),\n    signature: await pgp.readSignature({ armoredSignature: signedMessage.signature }),\n    verificationKeys: publicKey,\n    date: null as unknown as undefined,\n  });\n  try {\n    await verificationResult.signatures[0].verified;\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Decrypts and verifies p2p messages + verifies broadcast messages\n * @param messages message to decrypt and verify\n * @param pubVerificationGpgKeys public keys to verify signatures with\n * @param prvDecryptionGpgKeys private keys to decrypt with\n */\nexport async function decryptAndVerifyIncomingMessages(\n  messages: AuthEncMessages,\n  pubVerificationGpgKeys: PartyGpgKey[],\n  prvDecryptionGpgKeys: PartyGpgKey[]\n): Promise<SerializedMessages> {\n  return {\n    p2pMessages: await Promise.all(\n      messages.p2pMessages.map(async (m) => {\n        const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);\n        const prvGpgKey = prvDecryptionGpgKeys.find((k) => k.partyId === m.to);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for sender with ID: ${m.from}`);\n        }\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for recepient with ID: ${m.to}`);\n        }\n        return {\n          to: m.to,\n          from: m.from,\n          payload: await decryptAndVerifySignedData(m.payload, pubGpgKey.gpgKey, prvGpgKey.gpgKey),\n          commitment: m.commitment,\n        };\n      })\n    ),\n    broadcastMessages: await Promise.all(\n      messages.broadcastMessages.map(async (m) => {\n        const pubGpgKey = pubVerificationGpgKeys.find((k) => k.partyId === m.from);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for sender with ID: ${m.from}`);\n        }\n        if (!(await verifySignedData(m.payload, pubGpgKey.gpgKey))) {\n          throw Error(`Failed to authenticate broadcast message from party: ${m.from}`);\n        }\n        return {\n          from: m.from,\n          payload: m.payload.message,\n        };\n      })\n    ),\n  };\n}\n\n/**\n * Encrypts and signs p2p messages + signs broadcast messages\n * @param messages messages to encrypt and sign\n * @param pubEncryptionGpgKey public keys to encrypt data to\n * @param prvAuthenticationGpgKey private keys to sign with\n */\nexport async function encryptAndAuthOutgoingMessages(\n  messages: SerializedMessages,\n  pubEncryptionGpgKeys: PartyGpgKey[],\n  prvAuthenticationGpgKeys: PartyGpgKey[]\n): Promise<AuthEncMessages> {\n  return {\n    p2pMessages: await Promise.all(\n      messages.p2pMessages.map(async (m) => {\n        const pubGpgKey = pubEncryptionGpgKeys.find((k) => k.partyId === m.to);\n        const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);\n        if (!pubGpgKey) {\n          throw Error(`No public key provided for recipient with ID: ${m.to}`);\n        }\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for sender with ID: ${m.from}`);\n        }\n        return {\n          to: m.to,\n          from: m.from,\n          payload: await encryptAndDetachSignData(Buffer.from(m.payload, 'base64'), pubGpgKey.gpgKey, prvGpgKey.gpgKey),\n          commitment: m.commitment,\n        };\n      })\n    ),\n    broadcastMessages: await Promise.all(\n      messages.broadcastMessages.map(async (m) => {\n        const prvGpgKey = prvAuthenticationGpgKeys.find((k) => k.partyId === m.from);\n        if (!prvGpgKey) {\n          throw Error(`No private key provided for sender with ID: ${m.from}`);\n        }\n        return {\n          from: m.from,\n          payload: await detachSignData(Buffer.from(m.payload, 'base64'), prvGpgKey.gpgKey),\n          signatureR: m.signatureR\n            ? {\n                message: m.signatureR,\n                signature: '',\n              }\n            : undefined,\n        };\n      })\n    ),\n  };\n}\n"]}
@@ -0,0 +1,35 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import type { KeygenSession, Keyshare } from '@silencelaboratories/dkls-wasm-ll-node';
4
+ import { DeserializedBroadcastMessage, DeserializedMessages, DkgState, RetrofitData } from './types';
5
+ type NodeWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-node');
6
+ type WebWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-web');
7
+ type BundlerWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-bundler');
8
+ type DklsWasm = NodeWasmer | WebWasmer | BundlerWasmer;
9
+ export declare class Dkg {
10
+ protected dkgSession: KeygenSession | undefined;
11
+ protected dkgSessionBytes: Uint8Array;
12
+ protected dkgKeyShare: Keyshare;
13
+ protected keyShareBuff: Buffer;
14
+ protected n: number;
15
+ protected t: number;
16
+ protected seed: Buffer | undefined;
17
+ protected chainCodeCommitment: Uint8Array | undefined;
18
+ protected partyIdx: number;
19
+ protected dkgState: DkgState;
20
+ protected dklsKeyShareRetrofitObject: Keyshare | undefined;
21
+ protected retrofitData: RetrofitData | undefined;
22
+ protected dklsWasm: DklsWasm | null;
23
+ constructor(n: number, t: number, partyIdx: number, seed?: Buffer, retrofitData?: RetrofitData, dklsWasm?: BundlerWasmer);
24
+ private loadDklsWasm;
25
+ private getDklsWasm;
26
+ private _restoreSession;
27
+ private _createDKLsRetrofitKeyShare;
28
+ private _deserializeState;
29
+ initDkg(): Promise<DeserializedBroadcastMessage>;
30
+ getKeyShare(): Buffer;
31
+ getReducedKeyShare(): Buffer;
32
+ handleIncomingMessages(messagesForIthRound: DeserializedMessages): DeserializedMessages;
33
+ }
34
+ export {};
35
+ //# sourceMappingURL=dkg.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dkg.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/dkg.ts"],"names":[],"mappings":";;AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAW,MAAM,wCAAwC,CAAC;AAI/F,OAAO,EAAE,4BAA4B,EAAE,oBAAoB,EAAE,QAAQ,EAAmB,YAAY,EAAE,MAAM,SAAS,CAAC;AAEtH,KAAK,UAAU,GAAG,cAAc,wCAAwC,CAAC,CAAC;AAC1E,KAAK,SAAS,GAAG,cAAc,uCAAuC,CAAC,CAAC;AACxE,KAAK,aAAa,GAAG,cAAc,2CAA2C,CAAC,CAAC;AAEhF,KAAK,QAAQ,GAAG,UAAU,GAAG,SAAS,GAAG,aAAa,CAAC;AAEvD,qBAAa,GAAG;IACd,SAAS,CAAC,UAAU,EAAE,aAAa,GAAG,SAAS,CAAC;IAChD,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC;IACtC,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC;IAChC,SAAS,CAAC,YAAY,EAAE,MAAM,CAAC;IAC/B,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,SAAS,CAAC,mBAAmB,EAAE,UAAU,GAAG,SAAS,CAAC;IACtD,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAA0B;IACtD,SAAS,CAAC,0BAA0B,EAAE,QAAQ,GAAG,SAAS,CAAC;IAC3D,SAAS,CAAC,YAAY,EAAE,YAAY,GAAG,SAAS,CAAC;IACjD,SAAS,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;gBAGlC,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,QAAQ,EAAE,MAAM,EAChB,IAAI,CAAC,EAAE,MAAM,EACb,YAAY,CAAC,EAAE,YAAY,EAC3B,QAAQ,CAAC,EAAE,aAAa;YAWZ,YAAY;IAM1B,OAAO,CAAC,WAAW;IAQnB,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,2BAA2B;IAkCnC,OAAO,CAAC,iBAAiB;IA2BnB,OAAO,IAAI,OAAO,CAAC,4BAA4B,CAAC;IA8CtD,WAAW,IAAI,MAAM;IAOrB,kBAAkB,IAAI,MAAM;IAgB5B,sBAAsB,CAAC,mBAAmB,EAAE,oBAAoB,GAAG,oBAAoB;CAoFxF"}
@@ -0,0 +1,266 @@
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.Dkg = void 0;
27
+ const cbor_x_1 = require("cbor-x");
28
+ const curves_1 = require("../../curves");
29
+ const util_1 = require("../../util");
30
+ const types_1 = require("./types");
31
+ class Dkg {
32
+ constructor(n, t, partyIdx, seed, retrofitData, dklsWasm) {
33
+ this.dkgState = types_1.DkgState.Uninitialized;
34
+ this.n = n;
35
+ this.t = t;
36
+ this.partyIdx = partyIdx;
37
+ this.chainCodeCommitment = undefined;
38
+ this.retrofitData = retrofitData;
39
+ this.seed = seed;
40
+ this.dklsWasm = dklsWasm !== null && dklsWasm !== void 0 ? dklsWasm : null;
41
+ }
42
+ async loadDklsWasm() {
43
+ if (!this.dklsWasm) {
44
+ this.dklsWasm = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-node')));
45
+ }
46
+ }
47
+ getDklsWasm() {
48
+ if (!this.dklsWasm) {
49
+ throw Error('DKLS wasm not loaded');
50
+ }
51
+ return this.dklsWasm;
52
+ }
53
+ _restoreSession() {
54
+ if (!this.dkgSession) {
55
+ this.dkgSession = this.getDklsWasm().KeygenSession.fromBytes(this.dkgSessionBytes);
56
+ }
57
+ }
58
+ _createDKLsRetrofitKeyShare() {
59
+ if (this.retrofitData) {
60
+ if (!this.retrofitData.xShare.y || !this.retrofitData.xShare.chaincode || !this.retrofitData.xShare.x) {
61
+ throw Error('xShare must have a public key, private share value, and a chaincode.');
62
+ }
63
+ const xiList = [];
64
+ for (let i = 0; i < this.n; i++) {
65
+ xiList.push(Array.from((0, util_1.bigIntToBufferBE)(BigInt(i + 1), 32)));
66
+ }
67
+ const secp256k1 = new curves_1.Secp256k1Curve();
68
+ const dklsKeyShare = {
69
+ total_parties: this.n,
70
+ threshold: this.t,
71
+ rank_list: new Array(this.n).fill(0),
72
+ party_id: this.partyIdx,
73
+ public_key: Array.from(Buffer.from(this.retrofitData.xShare.y, 'hex')),
74
+ root_chain_code: Array.from(Buffer.from(this.retrofitData.xShare.chaincode, 'hex')),
75
+ final_session_id: Array(32).fill(0),
76
+ seed_ot_receivers: new Array(this.n - 1).fill(Array(32832).fill(0)),
77
+ seed_ot_senders: new Array(this.n - 1).fill(Array(32768).fill(0)),
78
+ sent_seed_list: [Array(32).fill(0)],
79
+ rec_seed_list: [Array(32).fill(0)],
80
+ s_i: Array.from(Buffer.from(this.retrofitData.xShare.x, 'hex')),
81
+ // big_s_list is now created internally during the protocol so isn't needed here, however a valid KeyShare object needs to have it.
82
+ // a dummy public key is used to fill big_s_list.
83
+ big_s_list: new Array(this.n).fill(Array.from((0, util_1.bigIntToBufferBE)(secp256k1.basePointMult(BigInt('0x' + this.retrofitData.xShare.x))))),
84
+ x_i_list: this.retrofitData.xiList ? this.retrofitData.xiList : xiList,
85
+ };
86
+ this.dklsKeyShareRetrofitObject = this.getDklsWasm().Keyshare.fromBytes((0, cbor_x_1.encode)(dklsKeyShare));
87
+ }
88
+ }
89
+ _deserializeState() {
90
+ if (!this.dkgSession) {
91
+ throw Error('Session not intialized');
92
+ }
93
+ const round = (0, cbor_x_1.decode)(this.dkgSession.toBytes()).round;
94
+ switch (round) {
95
+ case 'WaitMsg1':
96
+ this.dkgState = types_1.DkgState.Round1;
97
+ break;
98
+ case 'WaitMsg2':
99
+ this.dkgState = types_1.DkgState.Round2;
100
+ break;
101
+ case 'WaitMsg3':
102
+ this.dkgState = types_1.DkgState.Round3;
103
+ break;
104
+ case 'WaitMsg4':
105
+ this.dkgState = types_1.DkgState.Round4;
106
+ break;
107
+ case 'Ended':
108
+ this.dkgState = types_1.DkgState.Complete;
109
+ break;
110
+ default:
111
+ this.dkgState = types_1.DkgState.InvalidState;
112
+ throw Error(`Invalid State: ${round}`);
113
+ }
114
+ }
115
+ async initDkg() {
116
+ var _a;
117
+ if (!this.dklsWasm) {
118
+ await this.loadDklsWasm();
119
+ }
120
+ if (this.t > this.n || this.partyIdx >= this.n) {
121
+ throw Error('Invalid parameters for DKG');
122
+ }
123
+ if (this.dkgState != types_1.DkgState.Uninitialized) {
124
+ throw Error('DKG session already initialized');
125
+ }
126
+ if (typeof window !== 'undefined' &&
127
+ /* checks for electron processes */
128
+ !window.process &&
129
+ !((_a = window.process) === null || _a === void 0 ? void 0 : _a['type'])) {
130
+ /* This is only needed for browsers/web because it uses fetch to resolve the wasm asset for the web */
131
+ const initDkls = await Promise.resolve().then(() => __importStar(require('@silencelaboratories/dkls-wasm-ll-web')));
132
+ await initDkls.default();
133
+ }
134
+ this._createDKLsRetrofitKeyShare();
135
+ if (this.seed && this.seed.length !== 32) {
136
+ throw Error(`Seed should be 32 bytes, got ${this.seed.length}.`);
137
+ }
138
+ const { KeygenSession } = this.getDklsWasm();
139
+ if (this.dklsKeyShareRetrofitObject) {
140
+ this.dkgSession = this.seed
141
+ ? KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject, new Uint8Array(this.seed))
142
+ : KeygenSession.initKeyRotation(this.dklsKeyShareRetrofitObject);
143
+ }
144
+ else {
145
+ this.dkgSession = this.seed
146
+ ? new KeygenSession(this.n, this.t, this.partyIdx, new Uint8Array(this.seed))
147
+ : new KeygenSession(this.n, this.t, this.partyIdx);
148
+ }
149
+ try {
150
+ const payload = this.dkgSession.createFirstMessage().payload;
151
+ this._deserializeState();
152
+ return {
153
+ payload: payload,
154
+ from: this.partyIdx,
155
+ };
156
+ }
157
+ catch (e) {
158
+ throw Error(`Error while creating the first message from party ${this.partyIdx}: ${e}`);
159
+ }
160
+ }
161
+ getKeyShare() {
162
+ if (!this.keyShareBuff) {
163
+ throw Error('Can not get key share, DKG is not complete yet.');
164
+ }
165
+ return this.keyShareBuff;
166
+ }
167
+ getReducedKeyShare() {
168
+ if (!this.keyShareBuff) {
169
+ throw Error('Can not get key share, DKG is not complete yet.');
170
+ }
171
+ const decodedKeyshare = (0, cbor_x_1.decode)(this.keyShareBuff);
172
+ const reducedKeyShare = {
173
+ bigSList: decodedKeyshare.big_s_list,
174
+ xList: decodedKeyshare.x_i_list,
175
+ rootChainCode: decodedKeyshare.root_chain_code,
176
+ prv: decodedKeyshare.s_i,
177
+ pub: decodedKeyshare.public_key,
178
+ };
179
+ const encodedKeyShare = (0, cbor_x_1.encode)(reducedKeyShare);
180
+ return encodedKeyShare;
181
+ }
182
+ handleIncomingMessages(messagesForIthRound) {
183
+ let nextRoundMessages = [];
184
+ let nextRoundDeserializedMessages = { broadcastMessages: [], p2pMessages: [] };
185
+ this._restoreSession();
186
+ if (!this.dkgSession) {
187
+ throw Error('Session not initialized');
188
+ }
189
+ const { Message } = this.getDklsWasm();
190
+ try {
191
+ if (this.dkgState === types_1.DkgState.Round3) {
192
+ const commitmentsUnsorted = messagesForIthRound.p2pMessages
193
+ .map((m) => {
194
+ return { from: m.from, commitment: m.commitment };
195
+ })
196
+ .concat([{ from: this.partyIdx, commitment: this.chainCodeCommitment }]);
197
+ const commitmentsSorted = commitmentsUnsorted
198
+ .sort((a, b) => {
199
+ return a.from - b.from;
200
+ })
201
+ .map((c) => c.commitment);
202
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
203
+ .map((m) => new Message(m.payload, m.from, undefined))
204
+ .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))), commitmentsSorted);
205
+ }
206
+ else {
207
+ nextRoundMessages = this.dkgSession.handleMessages(messagesForIthRound.broadcastMessages
208
+ .map((m) => new Message(m.payload, m.from, undefined))
209
+ .concat(messagesForIthRound.p2pMessages.map((m) => new Message(m.payload, m.from, m.to))), undefined);
210
+ }
211
+ if (this.dkgState === types_1.DkgState.Round4) {
212
+ this.dkgKeyShare = this.dkgSession.keyshare();
213
+ this.keyShareBuff = Buffer.from(this.dkgKeyShare.toBytes());
214
+ this.dkgKeyShare.free();
215
+ if (this.dklsKeyShareRetrofitObject) {
216
+ this.dklsKeyShareRetrofitObject.free();
217
+ }
218
+ this.dkgState = types_1.DkgState.Complete;
219
+ return { broadcastMessages: [], p2pMessages: [] };
220
+ }
221
+ else {
222
+ // Update round data.
223
+ this._deserializeState();
224
+ }
225
+ if (this.dkgState === types_1.DkgState.Round2) {
226
+ this.chainCodeCommitment = this.dkgSession.calculateChainCodeCommitment();
227
+ }
228
+ nextRoundDeserializedMessages = {
229
+ p2pMessages: nextRoundMessages
230
+ .filter((m) => m.to_id !== undefined)
231
+ .map((m) => {
232
+ const p2pReturn = {
233
+ payload: m.payload,
234
+ from: m.from_id,
235
+ to: m.to_id,
236
+ commitment: this.chainCodeCommitment,
237
+ };
238
+ return p2pReturn;
239
+ }),
240
+ broadcastMessages: nextRoundMessages
241
+ .filter((m) => m.to_id === undefined)
242
+ .map((m) => {
243
+ const broadcastReturn = {
244
+ payload: m.payload,
245
+ from: m.from_id,
246
+ };
247
+ return broadcastReturn;
248
+ }),
249
+ };
250
+ }
251
+ catch (e) {
252
+ throw Error(`Error while creating messages from party ${this.partyIdx}, round ${this.dkgState}: ${e}`);
253
+ }
254
+ finally {
255
+ nextRoundMessages.forEach((m) => m.free());
256
+ // Session is freed when keyshare is called.
257
+ if (this.dkgState !== types_1.DkgState.Complete) {
258
+ this.dkgSessionBytes = this.dkgSession.toBytes();
259
+ this.dkgSession = undefined;
260
+ }
261
+ }
262
+ return nextRoundDeserializedMessages;
263
+ }
264
+ }
265
+ exports.Dkg = Dkg;
266
+ //# 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 type { KeygenSession, Keyshare, Message } from '@silencelaboratories/dkls-wasm-ll-node';\nimport { decode, encode } from 'cbor-x';\nimport { Secp256k1Curve } from '../../curves';\nimport { bigIntToBufferBE } from '../../util';\nimport { DeserializedBroadcastMessage, DeserializedMessages, DkgState, ReducedKeyShare, RetrofitData } from './types';\n\ntype NodeWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-node');\ntype WebWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-web');\ntype BundlerWasmer = typeof import('@silencelaboratories/dkls-wasm-ll-bundler');\n\ntype DklsWasm = NodeWasmer | WebWasmer | BundlerWasmer;\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  protected dklsWasm: DklsWasm | null;\n\n  constructor(\n    n: number,\n    t: number,\n    partyIdx: number,\n    seed?: Buffer,\n    retrofitData?: RetrofitData,\n    dklsWasm?: BundlerWasmer\n  ) {\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    this.dklsWasm = dklsWasm ?? null;\n  }\n\n  private async loadDklsWasm(): Promise<void> {\n    if (!this.dklsWasm) {\n      this.dklsWasm = await import('@silencelaboratories/dkls-wasm-ll-node');\n    }\n  }\n\n  private getDklsWasm() {\n    if (!this.dklsWasm) {\n      throw Error('DKLS wasm not loaded');\n    }\n\n    return this.dklsWasm;\n  }\n\n  private _restoreSession() {\n    if (!this.dkgSession) {\n      this.dkgSession = this.getDklsWasm().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 = this.getDklsWasm().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.dklsWasm) {\n      await this.loadDklsWasm();\n    }\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 (\n      typeof window !== 'undefined' &&\n      /* checks for electron processes */\n      !window.process &&\n      !window.process?.['type']\n    ) {\n      /* This is only needed for browsers/web because it uses fetch to resolve the wasm asset for the web */\n      const initDkls = await import('@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    const { KeygenSession } = this.getDklsWasm();\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    const { Message } = this.getDklsWasm();\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"]}