@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.356 → 8.2.1-alpha.358

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 (98) hide show
  1. package/dist/tsconfig.tsbuildinfo +1 -1
  2. package/package.json +3 -3
  3. package/dist/src/curves/constant.d.ts +0 -2
  4. package/dist/src/curves/constant.d.ts.map +0 -1
  5. package/dist/src/curves/constant.js +0 -6
  6. package/dist/src/curves/ed25519.d.ts +0 -20
  7. package/dist/src/curves/ed25519.d.ts.map +0 -1
  8. package/dist/src/curves/ed25519.js +0 -72
  9. package/dist/src/curves/ed25519Bip32HdTree.d.ts +0 -10
  10. package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +0 -1
  11. package/dist/src/curves/ed25519Bip32HdTree.js +0 -85
  12. package/dist/src/curves/index.d.ts +0 -8
  13. package/dist/src/curves/index.d.ts.map +0 -1
  14. package/dist/src/curves/index.js +0 -24
  15. package/dist/src/curves/secp256k1.d.ts +0 -18
  16. package/dist/src/curves/secp256k1.d.ts.map +0 -1
  17. package/dist/src/curves/secp256k1.js +0 -61
  18. package/dist/src/curves/secp256k1Bip32HdTree.d.ts +0 -8
  19. package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +0 -1
  20. package/dist/src/curves/secp256k1Bip32HdTree.js +0 -54
  21. package/dist/src/curves/types.d.ts +0 -35
  22. package/dist/src/curves/types.d.ts.map +0 -1
  23. package/dist/src/curves/types.js +0 -3
  24. package/dist/src/curves/util.d.ts +0 -4
  25. package/dist/src/curves/util.d.ts.map +0 -1
  26. package/dist/src/curves/util.js +0 -42
  27. package/dist/src/hashCommitment.d.ts +0 -16
  28. package/dist/src/hashCommitment.d.ts.map +0 -1
  29. package/dist/src/hashCommitment.js +0 -44
  30. package/dist/src/index.d.ts +0 -9
  31. package/dist/src/index.d.ts.map +0 -1
  32. package/dist/src/index.js +0 -48
  33. package/dist/src/openssl/index.d.ts +0 -2
  34. package/dist/src/openssl/index.d.ts.map +0 -1
  35. package/dist/src/openssl/index.js +0 -18
  36. package/dist/src/openssl/openssl.d.ts +0 -8
  37. package/dist/src/openssl/openssl.d.ts.map +0 -1
  38. package/dist/src/openssl/openssl.js +0 -37
  39. package/dist/src/safePrime.d.ts +0 -3
  40. package/dist/src/safePrime.d.ts.map +0 -1
  41. package/dist/src/safePrime.js +0 -19
  42. package/dist/src/schnorrProof.d.ts +0 -21
  43. package/dist/src/schnorrProof.d.ts.map +0 -1
  44. package/dist/src/schnorrProof.js +0 -61
  45. package/dist/src/shamir/index.d.ts +0 -3
  46. package/dist/src/shamir/index.d.ts.map +0 -1
  47. package/dist/src/shamir/index.js +0 -19
  48. package/dist/src/shamir/shamir.d.ts +0 -38
  49. package/dist/src/shamir/shamir.d.ts.map +0 -1
  50. package/dist/src/shamir/shamir.js +0 -136
  51. package/dist/src/shamir/types.d.ts +0 -5
  52. package/dist/src/shamir/types.d.ts.map +0 -1
  53. package/dist/src/shamir/types.js +0 -3
  54. package/dist/src/tss/ecdsa/index.d.ts +0 -6
  55. package/dist/src/tss/ecdsa/index.d.ts.map +0 -1
  56. package/dist/src/tss/ecdsa/index.js +0 -42
  57. package/dist/src/tss/ecdsa/paillierproof.d.ts +0 -24
  58. package/dist/src/tss/ecdsa/paillierproof.d.ts.map +0 -1
  59. package/dist/src/tss/ecdsa/paillierproof.js +0 -86
  60. package/dist/src/tss/ecdsa/primes.d.ts +0 -2
  61. package/dist/src/tss/ecdsa/primes.d.ts.map +0 -1
  62. package/dist/src/tss/ecdsa/primes.js +0 -1846
  63. package/dist/src/tss/ecdsa/rangeproof.d.ts +0 -79
  64. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +0 -1
  65. package/dist/src/tss/ecdsa/rangeproof.js +0 -394
  66. package/dist/src/tss/ecdsa/types.d.ts +0 -142
  67. package/dist/src/tss/ecdsa/types.d.ts.map +0 -1
  68. package/dist/src/tss/ecdsa/types.js +0 -130
  69. package/dist/src/tss/ecdsa/zkVProof.d.ts +0 -24
  70. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +0 -1
  71. package/dist/src/tss/ecdsa/zkVProof.js +0 -70
  72. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +0 -42
  73. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +0 -1
  74. package/dist/src/tss/ecdsa-dkls/commsLayer.js +0 -235
  75. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +0 -57
  76. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +0 -1
  77. package/dist/src/tss/ecdsa-dkls/dkg.js +0 -321
  78. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +0 -47
  79. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +0 -1
  80. package/dist/src/tss/ecdsa-dkls/dsg.js +0 -266
  81. package/dist/src/tss/ecdsa-dkls/index.d.ts +0 -6
  82. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +0 -1
  83. package/dist/src/tss/ecdsa-dkls/index.js +0 -42
  84. package/dist/src/tss/ecdsa-dkls/types.d.ts +0 -118
  85. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +0 -1
  86. package/dist/src/tss/ecdsa-dkls/types.js +0 -165
  87. package/dist/src/tss/ecdsa-dkls/util.d.ts +0 -26
  88. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +0 -1
  89. package/dist/src/tss/ecdsa-dkls/util.js +0 -276
  90. package/dist/src/tss/index.d.ts +0 -3
  91. package/dist/src/tss/index.d.ts.map +0 -1
  92. package/dist/src/tss/index.js +0 -19
  93. package/dist/src/types.d.ts +0 -13
  94. package/dist/src/types.d.ts.map +0 -1
  95. package/dist/src/types.js +0 -3
  96. package/dist/src/util.d.ts +0 -58
  97. package/dist/src/util.d.ts.map +0 -1
  98. package/dist/src/util.js +0 -164
@@ -1,165 +0,0 @@
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 () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.ReducedKeyShareType = exports.DsgState = exports.DkgState = void 0;
40
- exports.serializeMessages = serializeMessages;
41
- exports.deserializeMessages = deserializeMessages;
42
- exports.deserializeP2PMessage = deserializeP2PMessage;
43
- exports.deserializeBroadcastMessage = deserializeBroadcastMessage;
44
- exports.serializeP2PMessage = serializeP2PMessage;
45
- exports.serializeBroadcastMessage = serializeBroadcastMessage;
46
- exports.getCommonKeychain = getCommonKeychain;
47
- exports.getDecodedReducedKeyShare = getDecodedReducedKeyShare;
48
- const assert_1 = __importDefault(require("assert"));
49
- const cbor_x_1 = require("cbor-x");
50
- const t = __importStar(require("io-ts"));
51
- const Either_1 = require("fp-ts/Either");
52
- var DkgState;
53
- (function (DkgState) {
54
- DkgState[DkgState["Uninitialized"] = 0] = "Uninitialized";
55
- DkgState[DkgState["Round1"] = 1] = "Round1";
56
- DkgState[DkgState["Round2"] = 2] = "Round2";
57
- DkgState[DkgState["Round3"] = 3] = "Round3";
58
- DkgState[DkgState["Round4"] = 4] = "Round4";
59
- DkgState[DkgState["Complete"] = 5] = "Complete";
60
- DkgState[DkgState["InvalidState"] = 6] = "InvalidState";
61
- })(DkgState || (exports.DkgState = DkgState = {}));
62
- var DsgState;
63
- (function (DsgState) {
64
- DsgState[DsgState["Uninitialized"] = 0] = "Uninitialized";
65
- DsgState[DsgState["Round1"] = 1] = "Round1";
66
- DsgState[DsgState["Round2"] = 2] = "Round2";
67
- DsgState[DsgState["Round3"] = 3] = "Round3";
68
- DsgState[DsgState["Round4"] = 4] = "Round4";
69
- DsgState[DsgState["Complete"] = 5] = "Complete";
70
- DsgState[DsgState["InvalidState"] = 6] = "InvalidState";
71
- })(DsgState || (exports.DsgState = DsgState = {}));
72
- exports.ReducedKeyShareType = t.type({
73
- bigSList: t.array(t.array(t.number)),
74
- xList: t.array(t.array(t.number)),
75
- rootChainCode: t.array(t.number),
76
- prv: t.array(t.number),
77
- pub: t.array(t.number),
78
- });
79
- /**
80
- * Serializes messages payloads to base64 strings.
81
- * @param messages
82
- */
83
- function serializeMessages(messages) {
84
- return {
85
- p2pMessages: messages.p2pMessages.map(serializeP2PMessage),
86
- broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),
87
- };
88
- }
89
- /**
90
- * Deserialize messages payloads to Uint8Array.
91
- * @param messages
92
- */
93
- function deserializeMessages(messages) {
94
- return {
95
- p2pMessages: messages.p2pMessages.map(deserializeP2PMessage),
96
- broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),
97
- };
98
- }
99
- /**
100
- * Deserializes a P2P message.
101
- * @param message
102
- */
103
- function deserializeP2PMessage(message) {
104
- return {
105
- to: message.to,
106
- from: message.from,
107
- payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
108
- commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'hex')) : undefined,
109
- };
110
- }
111
- /**
112
- * Deserializes a Broadcast message.
113
- * @param message
114
- */
115
- function deserializeBroadcastMessage(message) {
116
- return {
117
- from: message.from,
118
- payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
119
- signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,
120
- };
121
- }
122
- /**
123
- * Serializes a P2P message.
124
- * @param message
125
- */
126
- function serializeP2PMessage(message) {
127
- return {
128
- to: message.to,
129
- from: message.from,
130
- payload: Buffer.from(message.payload).toString('base64'),
131
- commitment: message.commitment ? Buffer.from(message.commitment).toString('hex') : undefined,
132
- };
133
- }
134
- /**
135
- * Serializes a Broadcast message.
136
- * @param message
137
- */
138
- function serializeBroadcastMessage(message) {
139
- return {
140
- from: message.from,
141
- payload: Buffer.from(message.payload).toString('base64'),
142
- signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,
143
- };
144
- }
145
- /**
146
- * Gets commonkeyChain from DKLS keyShare
147
- * @param {Buffer} keyShare - DKLS keyShare
148
- * @returns {string} commonKeychain in hex format
149
- */
150
- function getCommonKeychain(keyShare) {
151
- const parsedKeyShare = (0, cbor_x_1.decode)(keyShare);
152
- (0, assert_1.default)(parsedKeyShare.public_key, 'public_key not found in keyShare');
153
- (0, assert_1.default)(parsedKeyShare.root_chain_code, 'root_chain_code not found in public_key');
154
- const publicKey = Buffer.from(parsedKeyShare.public_key).toString('hex');
155
- const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');
156
- return publicKey + rootChainCode;
157
- }
158
- function getDecodedReducedKeyShare(reducedKeyShare) {
159
- const decoded = exports.ReducedKeyShareType.decode((0, cbor_x_1.decode)(reducedKeyShare));
160
- if ((0, Either_1.isLeft)(decoded)) {
161
- throw new Error(`Unable to parse reducedKeyShare: ${decoded.left}`);
162
- }
163
- return decoded.right;
164
- }
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/types.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { decode } from 'cbor-x';\nimport * as t from 'io-ts';\nimport { XShare } from '../ecdsa/types';\nimport { isLeft } from 'fp-ts/Either';\n\n// Broadcast message meant to be sent to multiple parties\ninterface BroadcastMessage<T> {\n  payload: T;\n  from: number;\n  signatureR?: T;\n}\n\n// P2P message meant to be sent to a specific party\ninterface P2PMessage<T, G> {\n  payload: T;\n  from: number;\n  commitment?: G;\n  to: number;\n}\n\nexport enum DkgState {\n  Uninitialized = 0,\n  Round1,\n  Round2,\n  Round3,\n  Round4,\n  Complete,\n  InvalidState,\n}\n\nexport enum DsgState {\n  Uninitialized,\n  Round1,\n  Round2,\n  Round3,\n  Round4,\n  Complete,\n  InvalidState,\n}\n\nexport type AuthEncMessage = {\n  encryptedMessage: string;\n  signature: string;\n};\nexport type AuthMessage = {\n  message: string;\n  signature: string;\n};\nexport type PartyGpgKey = {\n  partyId: number;\n  gpgKey: string;\n};\nexport type DklsSignature<T> = {\n  R: T;\n  S: T;\n};\nexport type RetrofitData = {\n  xShare: Partial<XShare>;\n  xiList?: number[][];\n};\n\nexport const ReducedKeyShareType = t.type({\n  bigSList: t.array(t.array(t.number)),\n  xList: t.array(t.array(t.number)),\n  rootChainCode: t.array(t.number),\n  prv: t.array(t.number),\n  pub: t.array(t.number),\n});\n\nexport type ReducedKeyShare = t.TypeOf<typeof ReducedKeyShareType>;\n\nexport type SerializedBroadcastMessage = BroadcastMessage<string>;\nexport type DeserializedBroadcastMessage = BroadcastMessage<Uint8Array>;\nexport type SerializedP2PMessage = P2PMessage<string, string>;\nexport type DeserializedP2PMessage = P2PMessage<Uint8Array, Uint8Array>;\nexport type SerializedDklsSignature = DklsSignature<string>;\nexport type DeserializedDklsSignature = DklsSignature<Uint8Array>;\nexport type AuthEncP2PMessage = P2PMessage<AuthEncMessage, string>;\nexport type AuthBroadcastMessage = BroadcastMessage<AuthMessage>;\nexport type SerializedMessages = {\n  p2pMessages: SerializedP2PMessage[];\n  broadcastMessages: SerializedBroadcastMessage[];\n};\nexport type AuthEncMessages = {\n  p2pMessages: AuthEncP2PMessage[];\n  broadcastMessages: AuthBroadcastMessage[];\n};\nexport type DeserializedMessages = {\n  p2pMessages: DeserializedP2PMessage[];\n  broadcastMessages: DeserializedBroadcastMessage[];\n};\n\n/**\n * Serializes messages payloads to base64 strings.\n * @param messages\n */\nexport function serializeMessages(messages: DeserializedMessages): SerializedMessages {\n  return {\n    p2pMessages: messages.p2pMessages.map(serializeP2PMessage),\n    broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),\n  };\n}\n\n/**\n * Deserialize messages payloads to Uint8Array.\n * @param messages\n */\nexport function deserializeMessages(messages: SerializedMessages): DeserializedMessages {\n  return {\n    p2pMessages: messages.p2pMessages.map(deserializeP2PMessage),\n    broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),\n  };\n}\n\n/**\n * Deserializes a P2P message.\n * @param message\n */\nexport function deserializeP2PMessage(message: SerializedP2PMessage): DeserializedP2PMessage {\n  return {\n    to: message.to,\n    from: message.from,\n    payload: new Uint8Array(Buffer.from(message.payload, 'base64')),\n    commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'hex')) : undefined,\n  };\n}\n\n/**\n * Deserializes a Broadcast message.\n * @param message\n */\nexport function deserializeBroadcastMessage(message: SerializedBroadcastMessage): DeserializedBroadcastMessage {\n  return {\n    from: message.from,\n    payload: new Uint8Array(Buffer.from(message.payload, 'base64')),\n    signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,\n  };\n}\n\n/**\n * Serializes a P2P message.\n * @param message\n */\nexport function serializeP2PMessage(message: DeserializedP2PMessage): SerializedP2PMessage {\n  return {\n    to: message.to,\n    from: message.from,\n    payload: Buffer.from(message.payload).toString('base64'),\n    commitment: message.commitment ? Buffer.from(message.commitment).toString('hex') : undefined,\n  };\n}\n\n/**\n * Serializes a Broadcast message.\n * @param message\n */\nexport function serializeBroadcastMessage(message: DeserializedBroadcastMessage): SerializedBroadcastMessage {\n  return {\n    from: message.from,\n    payload: Buffer.from(message.payload).toString('base64'),\n    signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,\n  };\n}\n\n/**\n * Gets commonkeyChain from DKLS keyShare\n * @param {Buffer} keyShare - DKLS keyShare\n * @returns {string} commonKeychain in hex format\n */\nexport function getCommonKeychain(keyShare: Buffer): string {\n  const parsedKeyShare = decode(keyShare);\n  assert(parsedKeyShare.public_key, 'public_key not found in keyShare');\n  assert(parsedKeyShare.root_chain_code, 'root_chain_code not found in public_key');\n  const publicKey = Buffer.from(parsedKeyShare.public_key).toString('hex');\n  const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');\n  return publicKey + rootChainCode;\n}\n\nexport function getDecodedReducedKeyShare(reducedKeyShare: Buffer | Uint8Array): ReducedKeyShare {\n  const decoded = ReducedKeyShareType.decode(decode(reducedKeyShare));\n  if (isLeft(decoded)) {\n    throw new Error(`Unable to parse reducedKeyShare: ${decoded.left}`);\n  }\n  return decoded.right;\n}\n"]}
@@ -1,26 +0,0 @@
1
- import { DeserializedDklsSignature, DeserializedMessages, RetrofitData } from './types';
2
- import { Hash } from 'crypto';
3
- import { Dsg } from './dsg';
4
- import { Dkg } from './dkg';
5
- /**
6
- * Combines partial signatures from parties participating in DSG.
7
- * @param round4MessagePayloads - round 4 message payloads from participating parties
8
- * @param rHex - hex representation of the r value in the signature
9
- * @returns {DeserializedMessages} - messages to send to other parties for the next round
10
- */
11
- export declare function combinePartialSignatures(round4MessagePayloads: Uint8Array[], rHex: string): DeserializedDklsSignature;
12
- /**
13
- * Verify a DKLs Signature and serialize it to recid:r:s:publickey format.
14
- * @param message - message that was signed.
15
- * @param dklsSignature - R and S values of the ECDSA signature.
16
- * @param commonKeychain - public key appended to chaincode in hex.
17
- * @param derivationPath - optional derivation path to derive on the commonkeychain before verification.
18
- * @param hash - optional hash function to apply on message before verifying. Default is sha256.
19
- * @param shouldHash - flag to determine whether message should be hashed before verifying.
20
- * @returns {string} - serialized signature in `recid:r:s:publickey` format
21
- */
22
- export declare function verifyAndConvertDklsSignature(message: Buffer, dklsSignature: DeserializedDklsSignature, commonKeychain: string, derivationPath?: string, hash?: Hash, shouldHash?: boolean): string;
23
- export declare function executeTillRound(round: number, party1Dsg: Dsg, party2Dsg: Dsg): Promise<DeserializedMessages[] | DeserializedDklsSignature>;
24
- export declare function generateDKGKeyShares(retrofitDataA?: RetrofitData, retrofitDataB?: RetrofitData, retrofitDataC?: RetrofitData, seedUser?: Buffer, seedBackup?: Buffer, seedBitgo?: Buffer): Promise<[Dkg, Dkg, Dkg]>;
25
- export declare function generate2of2KeyShares(retrofitDataA?: RetrofitData, retrofitDataB?: RetrofitData): Promise<[Dkg, Dkg]>;
26
- //# sourceMappingURL=util.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/util.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,yBAAyB,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAGxF,OAAO,EAAc,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAK5B;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,qBAAqB,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,yBAAyB,CAgBrH;AAED;;;;;;;;;GASG;AACH,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,yBAAyB,EACxC,cAAc,EAAE,MAAM,EACtB,cAAc,CAAC,EAAE,MAAM,EACvB,IAAI,CAAC,EAAE,IAAI,EACX,UAAU,UAAO,GAChB,MAAM,CA6BR;AAED,wBAAsB,gBAAgB,CACpC,KAAK,EAAE,MAAM,EACb,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,GAAG,GACb,OAAO,CAAC,oBAAoB,EAAE,GAAG,yBAAyB,CAAC,CAgD7D;AAED,wBAAsB,oBAAoB,CACxC,aAAa,CAAC,EAAE,YAAY,EAC5B,aAAa,CAAC,EAAE,YAAY,EAC5B,aAAa,CAAC,EAAE,YAAY,EAC5B,QAAQ,CAAC,EAAE,MAAM,EACjB,UAAU,CAAC,EAAE,MAAM,EACnB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CA6E1B;AAED,wBAAsB,qBAAqB,CACzC,aAAa,CAAC,EAAE,YAAY,EAC5B,aAAa,CAAC,EAAE,YAAY,GAC3B,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAsCrB"}
@@ -1,276 +0,0 @@
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 () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.combinePartialSignatures = combinePartialSignatures;
40
- exports.verifyAndConvertDklsSignature = verifyAndConvertDklsSignature;
41
- exports.executeTillRound = executeTillRound;
42
- exports.generateDKGKeyShares = generateDKGKeyShares;
43
- exports.generate2of2KeyShares = generate2of2KeyShares;
44
- const secp256k1_1 = require("@noble/curves/secp256k1");
45
- const curves_1 = require("../../curves");
46
- const util_1 = require("../../util");
47
- const cbor_x_1 = require("cbor-x");
48
- const secp256k1 = __importStar(require("secp256k1"));
49
- const crypto_1 = require("crypto");
50
- const dkg_1 = require("./dkg");
51
- const assert_1 = __importDefault(require("assert"));
52
- const delimeter = ':';
53
- /**
54
- * Combines partial signatures from parties participating in DSG.
55
- * @param round4MessagePayloads - round 4 message payloads from participating parties
56
- * @param rHex - hex representation of the r value in the signature
57
- * @returns {DeserializedMessages} - messages to send to other parties for the next round
58
- */
59
- function combinePartialSignatures(round4MessagePayloads, rHex) {
60
- const r = (0, util_1.bigIntFromBufferBE)(Buffer.from(rHex, 'hex').subarray(1));
61
- const s0Arr = round4MessagePayloads.map((p) => (0, cbor_x_1.decode)(p).s_0);
62
- const s1Arr = round4MessagePayloads.map((p) => (0, cbor_x_1.decode)(p).s_1);
63
- const s0BigInts = s0Arr.map((s0) => (0, util_1.bigIntFromBufferBE)(Buffer.from(s0)));
64
- const s1BigInts = s1Arr.map((s1) => (0, util_1.bigIntFromBufferBE)(Buffer.from(s1)));
65
- const secp256k1Curve = new curves_1.Secp256k1Curve();
66
- const s0Sum = s0BigInts.slice(1).reduce((sumSoFar, s0) => secp256k1Curve.scalarAdd(sumSoFar, s0), s0BigInts[0]);
67
- const s1Sum = s1BigInts.slice(1).reduce((sumSoFar, s1) => secp256k1Curve.scalarAdd(sumSoFar, s1), s1BigInts[0]);
68
- const s = secp256k1Curve.scalarMult(s0Sum, secp256k1Curve.scalarInvert(s1Sum));
69
- const sig = new secp256k1_1.secp256k1.Signature(r, s);
70
- const normalizedSig = sig.normalizeS();
71
- return {
72
- R: new Uint8Array((0, util_1.bigIntToBufferBE)(normalizedSig.r, 32)),
73
- S: new Uint8Array((0, util_1.bigIntToBufferBE)(normalizedSig.s, 32)),
74
- };
75
- }
76
- /**
77
- * Verify a DKLs Signature and serialize it to recid:r:s:publickey format.
78
- * @param message - message that was signed.
79
- * @param dklsSignature - R and S values of the ECDSA signature.
80
- * @param commonKeychain - public key appended to chaincode in hex.
81
- * @param derivationPath - optional derivation path to derive on the commonkeychain before verification.
82
- * @param hash - optional hash function to apply on message before verifying. Default is sha256.
83
- * @param shouldHash - flag to determine whether message should be hashed before verifying.
84
- * @returns {string} - serialized signature in `recid:r:s:publickey` format
85
- */
86
- function verifyAndConvertDklsSignature(message, dklsSignature, commonKeychain, derivationPath, hash, shouldHash = true) {
87
- let truePub = '';
88
- if (derivationPath && derivationPath !== 'm') {
89
- const hdTree = new curves_1.Secp256k1Bip32HdTree();
90
- const derivedPub = hdTree.publicDerive({
91
- pk: (0, util_1.bigIntFromBufferBE)(Buffer.from(commonKeychain.slice(0, 66), 'hex')),
92
- chaincode: (0, util_1.bigIntFromBufferBE)(Buffer.from(commonKeychain.slice(66), 'hex')),
93
- }, derivationPath);
94
- truePub = (0, util_1.bigIntToBufferBE)(derivedPub.pk).toString('hex');
95
- }
96
- else {
97
- truePub = commonKeychain.slice(0, 66);
98
- }
99
- const messageToVerify = shouldHash ? (hash || (0, crypto_1.createHash)('sha256')).update(message).digest() : message;
100
- const pub0 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 0, messageToVerify, true);
101
- const pub1 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 1, messageToVerify, true);
102
- let recId;
103
- if (truePub === Buffer.from(pub0).toString('hex')) {
104
- recId = 0;
105
- }
106
- else if (truePub === Buffer.from(pub1).toString('hex')) {
107
- recId = 1;
108
- }
109
- else {
110
- throw Error('Invalid Signature');
111
- }
112
- return `${recId}${delimeter}${Buffer.from(dklsSignature.R).toString('hex')}${delimeter}${Buffer.from(dklsSignature.S).toString('hex')}${delimeter}${truePub}`;
113
- }
114
- async function executeTillRound(round, party1Dsg, party2Dsg) {
115
- if (round < 1 || round > 5) {
116
- throw Error('Invalid round number');
117
- }
118
- const party1Round1Message = await party1Dsg.init();
119
- const party2Round1Message = await party2Dsg.init();
120
- const party2Round2Messages = party2Dsg.handleIncomingMessages({
121
- p2pMessages: [],
122
- broadcastMessages: [party1Round1Message],
123
- });
124
- const party1Round2Messages = party1Dsg.handleIncomingMessages({
125
- p2pMessages: [],
126
- broadcastMessages: [party2Round1Message],
127
- });
128
- if (round === 2)
129
- return [party1Round2Messages, party2Round2Messages];
130
- const party1Round3Messages = party1Dsg.handleIncomingMessages({
131
- p2pMessages: party2Round2Messages.p2pMessages,
132
- broadcastMessages: [],
133
- });
134
- const party2Round3Messages = party2Dsg.handleIncomingMessages({
135
- p2pMessages: party1Round2Messages.p2pMessages,
136
- broadcastMessages: [],
137
- });
138
- if (round === 3)
139
- return [party1Round3Messages, party2Round3Messages];
140
- const party2Round4Messages = party2Dsg.handleIncomingMessages({
141
- p2pMessages: party1Round3Messages.p2pMessages,
142
- broadcastMessages: [],
143
- });
144
- const party1Round4Messages = party1Dsg.handleIncomingMessages({
145
- p2pMessages: party2Round3Messages.p2pMessages,
146
- broadcastMessages: [],
147
- });
148
- if (round === 4)
149
- return [party1Round4Messages, party2Round4Messages];
150
- party1Dsg.handleIncomingMessages({
151
- p2pMessages: [],
152
- broadcastMessages: party2Round4Messages.broadcastMessages,
153
- });
154
- party2Dsg.handleIncomingMessages({
155
- p2pMessages: [],
156
- broadcastMessages: party1Round4Messages.broadcastMessages,
157
- });
158
- (0, assert_1.default)(Buffer.from(party1Dsg.signature.R).toString('hex') === Buffer.from(party2Dsg.signature.R).toString('hex'));
159
- (0, assert_1.default)(Buffer.from(party1Dsg.signature.S).toString('hex') === Buffer.from(party2Dsg.signature.S).toString('hex'));
160
- return party1Dsg.signature;
161
- }
162
- async function generateDKGKeyShares(retrofitDataA, retrofitDataB, retrofitDataC, seedUser, seedBackup, seedBitgo) {
163
- const user = new dkg_1.Dkg(3, 2, 0, seedUser, retrofitDataA);
164
- const backup = new dkg_1.Dkg(3, 2, 1, seedBackup, retrofitDataB);
165
- const bitgo = new dkg_1.Dkg(3, 2, 2, seedBitgo, retrofitDataC);
166
- // #region round 1
167
- const userRound1Message = await user.initDkg();
168
- const backupRound1Message = await backup.initDkg();
169
- const bitgoRound1Message = await bitgo.initDkg();
170
- const bitgoRound2Messages = bitgo.handleIncomingMessages({
171
- p2pMessages: [],
172
- broadcastMessages: [userRound1Message, backupRound1Message],
173
- });
174
- // #endregion
175
- // #region round 2
176
- const userRound2Messages = user.handleIncomingMessages({
177
- p2pMessages: [],
178
- broadcastMessages: [bitgoRound1Message, backupRound1Message],
179
- });
180
- const backupRound2Messages = backup.handleIncomingMessages({
181
- p2pMessages: [],
182
- broadcastMessages: [userRound1Message, bitgoRound1Message],
183
- });
184
- const bitgoRound3Messages = bitgo.handleIncomingMessages({
185
- p2pMessages: backupRound2Messages.p2pMessages
186
- .filter((m) => m.to === 2)
187
- .concat(userRound2Messages.p2pMessages.filter((m) => m.to === 2)),
188
- broadcastMessages: [],
189
- });
190
- // #endregion
191
- // #region round 3
192
- const userRound3Messages = user.handleIncomingMessages({
193
- p2pMessages: backupRound2Messages.p2pMessages
194
- .filter((m) => m.to === 0)
195
- .concat(bitgoRound2Messages.p2pMessages.filter((m) => m.to === 0)),
196
- broadcastMessages: [],
197
- });
198
- const backupRound3Messages = backup.handleIncomingMessages({
199
- p2pMessages: bitgoRound2Messages.p2pMessages
200
- .filter((m) => m.to === 1)
201
- .concat(userRound2Messages.p2pMessages.filter((m) => m.to === 1)),
202
- broadcastMessages: [],
203
- });
204
- const userRound4Messages = user.handleIncomingMessages({
205
- p2pMessages: backupRound3Messages.p2pMessages
206
- .filter((m) => m.to === 0)
207
- .concat(bitgoRound3Messages.p2pMessages.filter((m) => m.to === 0)),
208
- broadcastMessages: [],
209
- });
210
- const backupRound4Messages = backup.handleIncomingMessages({
211
- p2pMessages: bitgoRound3Messages.p2pMessages
212
- .filter((m) => m.to === 1)
213
- .concat(userRound3Messages.p2pMessages.filter((m) => m.to === 1)),
214
- broadcastMessages: [],
215
- });
216
- const bitgoRound4Messages = bitgo.handleIncomingMessages({
217
- p2pMessages: backupRound3Messages.p2pMessages
218
- .filter((m) => m.to === 2)
219
- .concat(userRound3Messages.p2pMessages.filter((m) => m.to === 2)),
220
- broadcastMessages: [],
221
- });
222
- // #endregion
223
- user.handleIncomingMessages({
224
- p2pMessages: [],
225
- broadcastMessages: bitgoRound4Messages.broadcastMessages.concat(backupRound4Messages.broadcastMessages),
226
- });
227
- bitgo.handleIncomingMessages({
228
- p2pMessages: [],
229
- broadcastMessages: backupRound4Messages.broadcastMessages.concat(userRound4Messages.broadcastMessages),
230
- });
231
- backup.handleIncomingMessages({
232
- p2pMessages: [],
233
- broadcastMessages: bitgoRound4Messages.broadcastMessages.concat(userRound4Messages.broadcastMessages),
234
- });
235
- return [user, backup, bitgo];
236
- }
237
- async function generate2of2KeyShares(retrofitDataA, retrofitDataB) {
238
- const partyA = new dkg_1.Dkg(2, 2, 0, undefined, retrofitDataA);
239
- const partyB = new dkg_1.Dkg(2, 2, 1, undefined, retrofitDataB);
240
- const partyARound1Message = await partyA.initDkg();
241
- const partyBRound1Message = await partyB.initDkg();
242
- const partyARound2Messages = partyA.handleIncomingMessages({
243
- p2pMessages: [],
244
- broadcastMessages: [partyBRound1Message],
245
- });
246
- const partyBRound2Messages = partyB.handleIncomingMessages({
247
- p2pMessages: [],
248
- broadcastMessages: [partyARound1Message],
249
- });
250
- const partyARound3Messages = partyA.handleIncomingMessages({
251
- p2pMessages: partyBRound2Messages.p2pMessages.filter((m) => m.to === 0),
252
- broadcastMessages: [],
253
- });
254
- const partyBRound3Messages = partyB.handleIncomingMessages({
255
- p2pMessages: partyARound2Messages.p2pMessages.filter((m) => m.to === 1),
256
- broadcastMessages: [],
257
- });
258
- const partyARound4Messages = partyA.handleIncomingMessages({
259
- p2pMessages: partyBRound3Messages.p2pMessages.filter((m) => m.to === 0),
260
- broadcastMessages: [],
261
- });
262
- const partyBRound4Messages = partyB.handleIncomingMessages({
263
- p2pMessages: partyARound3Messages.p2pMessages.filter((m) => m.to === 1),
264
- broadcastMessages: [],
265
- });
266
- partyA.handleIncomingMessages({
267
- p2pMessages: [],
268
- broadcastMessages: partyBRound4Messages.broadcastMessages,
269
- });
270
- partyB.handleIncomingMessages({
271
- p2pMessages: [],
272
- broadcastMessages: partyARound4Messages.broadcastMessages,
273
- });
274
- return [partyA, partyB];
275
- }
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { secp256k1 as secp } from '@noble/curves/secp256k1';\nimport { HDTree, Secp256k1Bip32HdTree, Secp256k1Curve } from '../../curves';\nimport { bigIntFromBufferBE, bigIntToBufferBE } from '../../util';\nimport { DeserializedDklsSignature, DeserializedMessages, RetrofitData } from './types';\nimport { decode } from 'cbor-x';\nimport * as secp256k1 from 'secp256k1';\nimport { createHash, Hash } from 'crypto';\nimport { Dsg } from './dsg';\nimport { Dkg } from './dkg';\nimport assert from 'assert';\n\nconst delimeter = ':';\n\n/**\n * Combines partial signatures from parties participating in DSG.\n * @param round4MessagePayloads - round 4 message payloads from participating parties\n * @param rHex - hex representation of the r value in the signature\n * @returns {DeserializedMessages} - messages to send to other parties for the next round\n */\nexport function combinePartialSignatures(round4MessagePayloads: Uint8Array[], rHex: string): DeserializedDklsSignature {\n  const r = bigIntFromBufferBE(Buffer.from(rHex, 'hex').subarray(1));\n  const s0Arr = round4MessagePayloads.map((p) => decode(p).s_0);\n  const s1Arr = round4MessagePayloads.map((p) => decode(p).s_1);\n  const s0BigInts = s0Arr.map((s0) => bigIntFromBufferBE(Buffer.from(s0)));\n  const s1BigInts = s1Arr.map((s1) => bigIntFromBufferBE(Buffer.from(s1)));\n  const secp256k1Curve = new Secp256k1Curve();\n  const s0Sum = s0BigInts.slice(1).reduce((sumSoFar, s0) => secp256k1Curve.scalarAdd(sumSoFar, s0), s0BigInts[0]);\n  const s1Sum = s1BigInts.slice(1).reduce((sumSoFar, s1) => secp256k1Curve.scalarAdd(sumSoFar, s1), s1BigInts[0]);\n  const s = secp256k1Curve.scalarMult(s0Sum, secp256k1Curve.scalarInvert(s1Sum));\n  const sig = new secp.Signature(r, s);\n  const normalizedSig = sig.normalizeS();\n  return {\n    R: new Uint8Array(bigIntToBufferBE(normalizedSig.r, 32)),\n    S: new Uint8Array(bigIntToBufferBE(normalizedSig.s, 32)),\n  };\n}\n\n/**\n * Verify a DKLs Signature and serialize it to recid:r:s:publickey format.\n * @param message - message that was signed.\n * @param dklsSignature - R and S values of the ECDSA signature.\n * @param commonKeychain - public key appended to chaincode in hex.\n * @param derivationPath - optional derivation path to derive on the commonkeychain before verification.\n * @param hash - optional hash function to apply on message before verifying. Default is sha256.\n * @param shouldHash - flag to determine whether message should be hashed before verifying.\n * @returns {string} - serialized signature in `recid:r:s:publickey` format\n */\nexport function verifyAndConvertDklsSignature(\n  message: Buffer,\n  dklsSignature: DeserializedDklsSignature,\n  commonKeychain: string,\n  derivationPath?: string,\n  hash?: Hash,\n  shouldHash = true\n): string {\n  let truePub = '';\n  if (derivationPath && derivationPath !== 'm') {\n    const hdTree: HDTree = new Secp256k1Bip32HdTree();\n    const derivedPub = hdTree.publicDerive(\n      {\n        pk: bigIntFromBufferBE(Buffer.from(commonKeychain.slice(0, 66), 'hex')),\n        chaincode: bigIntFromBufferBE(Buffer.from(commonKeychain.slice(66), 'hex')),\n      },\n      derivationPath\n    );\n    truePub = bigIntToBufferBE(derivedPub.pk).toString('hex');\n  } else {\n    truePub = commonKeychain.slice(0, 66);\n  }\n  const messageToVerify = shouldHash ? (hash || createHash('sha256')).update(message).digest() : message;\n  const pub0 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 0, messageToVerify, true);\n  const pub1 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 1, messageToVerify, true);\n  let recId: number;\n  if (truePub === Buffer.from(pub0).toString('hex')) {\n    recId = 0;\n  } else if (truePub === Buffer.from(pub1).toString('hex')) {\n    recId = 1;\n  } else {\n    throw Error('Invalid Signature');\n  }\n  return `${recId}${delimeter}${Buffer.from(dklsSignature.R).toString('hex')}${delimeter}${Buffer.from(\n    dklsSignature.S\n  ).toString('hex')}${delimeter}${truePub}`;\n}\n\nexport async function executeTillRound(\n  round: number,\n  party1Dsg: Dsg,\n  party2Dsg: Dsg\n): Promise<DeserializedMessages[] | DeserializedDklsSignature> {\n  if (round < 1 || round > 5) {\n    throw Error('Invalid round number');\n  }\n  const party1Round1Message = await party1Dsg.init();\n  const party2Round1Message = await party2Dsg.init();\n\n  const party2Round2Messages = party2Dsg.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [party1Round1Message],\n  });\n  const party1Round2Messages = party1Dsg.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [party2Round1Message],\n  });\n  if (round === 2) return [party1Round2Messages, party2Round2Messages];\n\n  const party1Round3Messages = party1Dsg.handleIncomingMessages({\n    p2pMessages: party2Round2Messages.p2pMessages,\n    broadcastMessages: [],\n  });\n  const party2Round3Messages = party2Dsg.handleIncomingMessages({\n    p2pMessages: party1Round2Messages.p2pMessages,\n    broadcastMessages: [],\n  });\n  if (round === 3) return [party1Round3Messages, party2Round3Messages];\n\n  const party2Round4Messages = party2Dsg.handleIncomingMessages({\n    p2pMessages: party1Round3Messages.p2pMessages,\n    broadcastMessages: [],\n  });\n  const party1Round4Messages = party1Dsg.handleIncomingMessages({\n    p2pMessages: party2Round3Messages.p2pMessages,\n    broadcastMessages: [],\n  });\n  if (round === 4) return [party1Round4Messages, party2Round4Messages];\n\n  party1Dsg.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: party2Round4Messages.broadcastMessages,\n  });\n  party2Dsg.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: party1Round4Messages.broadcastMessages,\n  });\n  assert(Buffer.from(party1Dsg.signature.R).toString('hex') === Buffer.from(party2Dsg.signature.R).toString('hex'));\n  assert(Buffer.from(party1Dsg.signature.S).toString('hex') === Buffer.from(party2Dsg.signature.S).toString('hex'));\n  return party1Dsg.signature;\n}\n\nexport async function generateDKGKeyShares(\n  retrofitDataA?: RetrofitData,\n  retrofitDataB?: RetrofitData,\n  retrofitDataC?: RetrofitData,\n  seedUser?: Buffer,\n  seedBackup?: Buffer,\n  seedBitgo?: Buffer\n): Promise<[Dkg, Dkg, Dkg]> {\n  const user = new Dkg(3, 2, 0, seedUser, retrofitDataA);\n  const backup = new Dkg(3, 2, 1, seedBackup, retrofitDataB);\n  const bitgo = new Dkg(3, 2, 2, seedBitgo, retrofitDataC);\n  // #region round 1\n  const userRound1Message = await user.initDkg();\n  const backupRound1Message = await backup.initDkg();\n  const bitgoRound1Message = await bitgo.initDkg();\n  const bitgoRound2Messages = bitgo.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [userRound1Message, backupRound1Message],\n  });\n  // #endregion\n\n  // #region round 2\n  const userRound2Messages = user.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [bitgoRound1Message, backupRound1Message],\n  });\n  const backupRound2Messages = backup.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [userRound1Message, bitgoRound1Message],\n  });\n  const bitgoRound3Messages = bitgo.handleIncomingMessages({\n    p2pMessages: backupRound2Messages.p2pMessages\n      .filter((m) => m.to === 2)\n      .concat(userRound2Messages.p2pMessages.filter((m) => m.to === 2)),\n    broadcastMessages: [],\n  });\n  // #endregion\n\n  // #region round 3\n  const userRound3Messages = user.handleIncomingMessages({\n    p2pMessages: backupRound2Messages.p2pMessages\n      .filter((m) => m.to === 0)\n      .concat(bitgoRound2Messages.p2pMessages.filter((m) => m.to === 0)),\n    broadcastMessages: [],\n  });\n  const backupRound3Messages = backup.handleIncomingMessages({\n    p2pMessages: bitgoRound2Messages.p2pMessages\n      .filter((m) => m.to === 1)\n      .concat(userRound2Messages.p2pMessages.filter((m) => m.to === 1)),\n    broadcastMessages: [],\n  });\n  const userRound4Messages = user.handleIncomingMessages({\n    p2pMessages: backupRound3Messages.p2pMessages\n      .filter((m) => m.to === 0)\n      .concat(bitgoRound3Messages.p2pMessages.filter((m) => m.to === 0)),\n    broadcastMessages: [],\n  });\n  const backupRound4Messages = backup.handleIncomingMessages({\n    p2pMessages: bitgoRound3Messages.p2pMessages\n      .filter((m) => m.to === 1)\n      .concat(userRound3Messages.p2pMessages.filter((m) => m.to === 1)),\n    broadcastMessages: [],\n  });\n  const bitgoRound4Messages = bitgo.handleIncomingMessages({\n    p2pMessages: backupRound3Messages.p2pMessages\n      .filter((m) => m.to === 2)\n      .concat(userRound3Messages.p2pMessages.filter((m) => m.to === 2)),\n    broadcastMessages: [],\n  });\n  // #endregion\n\n  user.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: bitgoRound4Messages.broadcastMessages.concat(backupRound4Messages.broadcastMessages),\n  });\n  bitgo.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: backupRound4Messages.broadcastMessages.concat(userRound4Messages.broadcastMessages),\n  });\n  backup.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: bitgoRound4Messages.broadcastMessages.concat(userRound4Messages.broadcastMessages),\n  });\n  return [user, backup, bitgo];\n}\n\nexport async function generate2of2KeyShares(\n  retrofitDataA?: RetrofitData,\n  retrofitDataB?: RetrofitData\n): Promise<[Dkg, Dkg]> {\n  const partyA = new Dkg(2, 2, 0, undefined, retrofitDataA);\n  const partyB = new Dkg(2, 2, 1, undefined, retrofitDataB);\n  const partyARound1Message = await partyA.initDkg();\n  const partyBRound1Message = await partyB.initDkg();\n  const partyARound2Messages = partyA.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [partyBRound1Message],\n  });\n  const partyBRound2Messages = partyB.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: [partyARound1Message],\n  });\n  const partyARound3Messages = partyA.handleIncomingMessages({\n    p2pMessages: partyBRound2Messages.p2pMessages.filter((m) => m.to === 0),\n    broadcastMessages: [],\n  });\n  const partyBRound3Messages = partyB.handleIncomingMessages({\n    p2pMessages: partyARound2Messages.p2pMessages.filter((m) => m.to === 1),\n    broadcastMessages: [],\n  });\n  const partyARound4Messages = partyA.handleIncomingMessages({\n    p2pMessages: partyBRound3Messages.p2pMessages.filter((m) => m.to === 0),\n    broadcastMessages: [],\n  });\n  const partyBRound4Messages = partyB.handleIncomingMessages({\n    p2pMessages: partyARound3Messages.p2pMessages.filter((m) => m.to === 1),\n    broadcastMessages: [],\n  });\n  partyA.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: partyBRound4Messages.broadcastMessages,\n  });\n  partyB.handleIncomingMessages({\n    p2pMessages: [],\n    broadcastMessages: partyARound4Messages.broadcastMessages,\n  });\n  return [partyA, partyB];\n}\n"]}
@@ -1,3 +0,0 @@
1
- export * from './ecdsa';
2
- export * from './ecdsa-dkls';
3
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC"}
@@ -1,19 +0,0 @@
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./ecdsa"), exports);
18
- __exportStar(require("./ecdsa-dkls"), exports);
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIsK0NBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lY2RzYSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZHNhLWRrbHMnO1xuIl19
@@ -1,13 +0,0 @@
1
- export interface HashCommitDecommit {
2
- commitment: Buffer;
3
- decommitment: HashDecommitment;
4
- }
5
- export interface HashDecommitment {
6
- secret: Buffer;
7
- blindingFactor: Buffer;
8
- }
9
- export interface SchnorrProof {
10
- vPoint: bigint;
11
- r: bigint;
12
- }
13
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,kBAAkB;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,gBAAgB,CAAC;CAChC;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,CAAC,EAAE,MAAM,CAAC;CACX"}
package/dist/src/types.js DELETED
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSGFzaENvbW1pdERlY29tbWl0IHtcbiAgY29tbWl0bWVudDogQnVmZmVyO1xuICBkZWNvbW1pdG1lbnQ6IEhhc2hEZWNvbW1pdG1lbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzaERlY29tbWl0bWVudCB7XG4gIHNlY3JldDogQnVmZmVyO1xuICBibGluZGluZ0ZhY3RvcjogQnVmZmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaG5vcnJQcm9vZiB7XG4gIHZQb2ludDogYmlnaW50O1xuICByOiBiaWdpbnQ7XG59XG4iXX0=