@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.194 → 8.2.1-alpha.196

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 (50) hide show
  1. package/dist/src/curves/ed25519.d.ts +0 -2
  2. package/dist/src/curves/ed25519.d.ts.map +1 -1
  3. package/dist/src/curves/ed25519.js +1 -1
  4. package/dist/src/curves/ed25519Bip32HdTree.js +1 -1
  5. package/dist/src/curves/secp256k1.d.ts +0 -2
  6. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  7. package/dist/src/curves/secp256k1Bip32HdTree.js +1 -1
  8. package/dist/src/curves/types.d.ts +0 -2
  9. package/dist/src/curves/types.d.ts.map +1 -1
  10. package/dist/src/curves/util.js +2 -3
  11. package/dist/src/hashCommitment.d.ts +0 -2
  12. package/dist/src/hashCommitment.d.ts.map +1 -1
  13. package/dist/src/hashCommitment.js +3 -4
  14. package/dist/src/index.js +18 -8
  15. package/dist/src/openssl/openssl.js +1 -1
  16. package/dist/src/safePrime.js +3 -4
  17. package/dist/src/schnorrProof.d.ts +0 -2
  18. package/dist/src/schnorrProof.d.ts.map +1 -1
  19. package/dist/src/schnorrProof.js +3 -4
  20. package/dist/src/shamir/shamir.js +1 -1
  21. package/dist/src/tss/ecdsa/index.js +18 -8
  22. package/dist/src/tss/ecdsa/paillierproof.js +5 -5
  23. package/dist/src/tss/ecdsa/rangeproof.js +8 -9
  24. package/dist/src/tss/ecdsa/types.js +11 -12
  25. package/dist/src/tss/ecdsa/zkVProof.d.ts +0 -2
  26. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -1
  27. package/dist/src/tss/ecdsa/zkVProof.js +3 -4
  28. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +0 -2
  29. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -1
  30. package/dist/src/tss/ecdsa-dkls/commsLayer.js +24 -15
  31. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +0 -2
  32. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -1
  33. package/dist/src/tss/ecdsa-dkls/dkg.js +20 -11
  34. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +0 -2
  35. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -1
  36. package/dist/src/tss/ecdsa-dkls/dsg.js +20 -11
  37. package/dist/src/tss/ecdsa-dkls/index.js +18 -8
  38. package/dist/src/tss/ecdsa-dkls/types.d.ts +0 -2
  39. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -1
  40. package/dist/src/tss/ecdsa-dkls/types.js +29 -19
  41. package/dist/src/tss/ecdsa-dkls/util.d.ts +0 -3
  42. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -1
  43. package/dist/src/tss/ecdsa-dkls/util.js +23 -14
  44. package/dist/src/types.d.ts +0 -2
  45. package/dist/src/types.d.ts.map +1 -1
  46. package/dist/src/util.d.ts +0 -2
  47. package/dist/src/util.d.ts.map +1 -1
  48. package/dist/src/util.js +16 -17
  49. package/dist/tsconfig.tsbuildinfo +1 -1
  50. package/package.json +3 -3
@@ -15,18 +15,36 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
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
- };
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
+ })();
25
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
37
  };
28
38
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.getDecodedReducedKeyShare = exports.getCommonKeychain = exports.serializeBroadcastMessage = exports.serializeP2PMessage = exports.deserializeBroadcastMessage = exports.deserializeP2PMessage = exports.deserializeMessages = exports.serializeMessages = exports.ReducedKeyShareType = exports.DsgState = exports.DkgState = void 0;
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;
30
48
  const assert_1 = __importDefault(require("assert"));
31
49
  const cbor_x_1 = require("cbor-x");
32
50
  const t = __importStar(require("io-ts"));
@@ -40,7 +58,7 @@ var DkgState;
40
58
  DkgState[DkgState["Round4"] = 4] = "Round4";
41
59
  DkgState[DkgState["Complete"] = 5] = "Complete";
42
60
  DkgState[DkgState["InvalidState"] = 6] = "InvalidState";
43
- })(DkgState = exports.DkgState || (exports.DkgState = {}));
61
+ })(DkgState || (exports.DkgState = DkgState = {}));
44
62
  var DsgState;
45
63
  (function (DsgState) {
46
64
  DsgState[DsgState["Uninitialized"] = 0] = "Uninitialized";
@@ -50,7 +68,7 @@ var DsgState;
50
68
  DsgState[DsgState["Round4"] = 4] = "Round4";
51
69
  DsgState[DsgState["Complete"] = 5] = "Complete";
52
70
  DsgState[DsgState["InvalidState"] = 6] = "InvalidState";
53
- })(DsgState = exports.DsgState || (exports.DsgState = {}));
71
+ })(DsgState || (exports.DsgState = DsgState = {}));
54
72
  exports.ReducedKeyShareType = t.type({
55
73
  bigSList: t.array(t.array(t.number)),
56
74
  xList: t.array(t.array(t.number)),
@@ -68,7 +86,6 @@ function serializeMessages(messages) {
68
86
  broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),
69
87
  };
70
88
  }
71
- exports.serializeMessages = serializeMessages;
72
89
  /**
73
90
  * Deserialize messages payloads to Uint8Array.
74
91
  * @param messages
@@ -79,7 +96,6 @@ function deserializeMessages(messages) {
79
96
  broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),
80
97
  };
81
98
  }
82
- exports.deserializeMessages = deserializeMessages;
83
99
  /**
84
100
  * Deserializes a P2P message.
85
101
  * @param message
@@ -92,7 +108,6 @@ function deserializeP2PMessage(message) {
92
108
  commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'hex')) : undefined,
93
109
  };
94
110
  }
95
- exports.deserializeP2PMessage = deserializeP2PMessage;
96
111
  /**
97
112
  * Deserializes a Broadcast message.
98
113
  * @param message
@@ -104,7 +119,6 @@ function deserializeBroadcastMessage(message) {
104
119
  signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,
105
120
  };
106
121
  }
107
- exports.deserializeBroadcastMessage = deserializeBroadcastMessage;
108
122
  /**
109
123
  * Serializes a P2P message.
110
124
  * @param message
@@ -117,7 +131,6 @@ function serializeP2PMessage(message) {
117
131
  commitment: message.commitment ? Buffer.from(message.commitment).toString('hex') : undefined,
118
132
  };
119
133
  }
120
- exports.serializeP2PMessage = serializeP2PMessage;
121
134
  /**
122
135
  * Serializes a Broadcast message.
123
136
  * @param message
@@ -129,7 +142,6 @@ function serializeBroadcastMessage(message) {
129
142
  signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,
130
143
  };
131
144
  }
132
- exports.serializeBroadcastMessage = serializeBroadcastMessage;
133
145
  /**
134
146
  * Gets commonkeyChain from DKLS keyShare
135
147
  * @param {Buffer} keyShare - DKLS keyShare
@@ -143,7 +155,6 @@ function getCommonKeychain(keyShare) {
143
155
  const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');
144
156
  return publicKey + rootChainCode;
145
157
  }
146
- exports.getCommonKeychain = getCommonKeychain;
147
158
  function getDecodedReducedKeyShare(reducedKeyShare) {
148
159
  const decoded = exports.ReducedKeyShareType.decode((0, cbor_x_1.decode)(reducedKeyShare));
149
160
  if ((0, Either_1.isLeft)(decoded)) {
@@ -151,5 +162,4 @@ function getDecodedReducedKeyShare(reducedKeyShare) {
151
162
  }
152
163
  return decoded.right;
153
164
  }
154
- exports.getDecodedReducedKeyShare = getDecodedReducedKeyShare;
155
- //# 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"]}
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,6 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
- /// <reference types="node" />
4
1
  import { DeserializedDklsSignature, DeserializedMessages, RetrofitData } from './types';
5
2
  import { Hash } from 'crypto';
6
3
  import { Dsg } from './dsg';
@@ -1 +1 @@
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
+ {"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"}
@@ -15,18 +15,32 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
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
- };
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
+ })();
25
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
37
  };
28
38
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.generate2of2KeyShares = exports.generateDKGKeyShares = exports.executeTillRound = exports.verifyAndConvertDklsSignature = exports.combinePartialSignatures = void 0;
39
+ exports.combinePartialSignatures = combinePartialSignatures;
40
+ exports.verifyAndConvertDklsSignature = verifyAndConvertDklsSignature;
41
+ exports.executeTillRound = executeTillRound;
42
+ exports.generateDKGKeyShares = generateDKGKeyShares;
43
+ exports.generate2of2KeyShares = generate2of2KeyShares;
30
44
  const secp256k1_1 = require("@noble/curves/secp256k1");
31
45
  const curves_1 = require("../../curves");
32
46
  const util_1 = require("../../util");
@@ -59,7 +73,6 @@ function combinePartialSignatures(round4MessagePayloads, rHex) {
59
73
  S: new Uint8Array((0, util_1.bigIntToBufferBE)(normalizedSig.s, 32)),
60
74
  };
61
75
  }
62
- exports.combinePartialSignatures = combinePartialSignatures;
63
76
  /**
64
77
  * Verify a DKLs Signature and serialize it to recid:r:s:publickey format.
65
78
  * @param message - message that was signed.
@@ -98,7 +111,6 @@ function verifyAndConvertDklsSignature(message, dklsSignature, commonKeychain, d
98
111
  }
99
112
  return `${recId}${delimeter}${Buffer.from(dklsSignature.R).toString('hex')}${delimeter}${Buffer.from(dklsSignature.S).toString('hex')}${delimeter}${truePub}`;
100
113
  }
101
- exports.verifyAndConvertDklsSignature = verifyAndConvertDklsSignature;
102
114
  async function executeTillRound(round, party1Dsg, party2Dsg) {
103
115
  if (round < 1 || round > 5) {
104
116
  throw Error('Invalid round number');
@@ -147,7 +159,6 @@ async function executeTillRound(round, party1Dsg, party2Dsg) {
147
159
  (0, assert_1.default)(Buffer.from(party1Dsg.signature.S).toString('hex') === Buffer.from(party2Dsg.signature.S).toString('hex'));
148
160
  return party1Dsg.signature;
149
161
  }
150
- exports.executeTillRound = executeTillRound;
151
162
  async function generateDKGKeyShares(retrofitDataA, retrofitDataB, retrofitDataC, seedUser, seedBackup, seedBitgo) {
152
163
  const user = new dkg_1.Dkg(3, 2, 0, seedUser, retrofitDataA);
153
164
  const backup = new dkg_1.Dkg(3, 2, 1, seedBackup, retrofitDataB);
@@ -223,7 +234,6 @@ async function generateDKGKeyShares(retrofitDataA, retrofitDataB, retrofitDataC,
223
234
  });
224
235
  return [user, backup, bitgo];
225
236
  }
226
- exports.generateDKGKeyShares = generateDKGKeyShares;
227
237
  async function generate2of2KeyShares(retrofitDataA, retrofitDataB) {
228
238
  const partyA = new dkg_1.Dkg(2, 2, 0, undefined, retrofitDataA);
229
239
  const partyB = new dkg_1.Dkg(2, 2, 1, undefined, retrofitDataB);
@@ -263,5 +273,4 @@ async function generate2of2KeyShares(retrofitDataA, retrofitDataB) {
263
273
  });
264
274
  return [partyA, partyB];
265
275
  }
266
- exports.generate2of2KeyShares = generate2of2KeyShares;
267
- //# 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"]}
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,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  export interface HashCommitDecommit {
4
2
  commitment: Buffer;
5
3
  decommitment: HashDecommitment;
@@ -1 +1 @@
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"}
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"}
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
1
  import { PublicKey } from 'paillier-bigint';
4
2
  /**
5
3
  * Returns a bigint array from a hex string array
@@ -1 +1 @@
1
- {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAK5C;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAInE;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAIvF;AAED,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAU/C;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAOtE;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAQrE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAQrE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM,CAEvD;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAIvC;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS,CAEzD;AAED;;;;GAIG;AACH,wBAAsB,uBAAuB,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAOxE;AAED;;;;GAIG;AACH,wBAAsB,6BAA6B,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAU9E;AAED;;;;GAIG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAErE;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,UAAO,GAAG,MAAM,CAQvE"}
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAK5C;;;GAGG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAInE;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAIvF;AAED,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAU/C;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAOtE;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAQrE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAQrE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM,CAEvD;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAIvC;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS,CAEzD;AAED;;;;GAIG;AACH,wBAAsB,uBAAuB,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAOxE;AAED;;;;GAIG;AACH,wBAAsB,6BAA6B,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAU9E;AAED;;;;GAIG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAErE;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,UAAO,GAAG,MAAM,CAQvE"}
package/dist/src/util.js CHANGED
@@ -3,7 +3,21 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getDerivationPath = exports.randomBigInt = exports.randomPositiveCoPrimeLessThan = exports.randomPositiveCoPrimeTo = exports.getPaillierPublicKey = exports.clamp = exports.bigIntFromU8ABE = exports.bigIntFromBufferBE = exports.bigIntToBufferBE = exports.bigIntFromBufferLE = exports.bigIntToBufferLE = exports.bigIntToHex = exports.hexToBigInt = exports.convertBigIntArrToHexArr = exports.convertHexArrToBigIntArr = void 0;
6
+ exports.convertHexArrToBigIntArr = convertHexArrToBigIntArr;
7
+ exports.convertBigIntArrToHexArr = convertBigIntArrToHexArr;
8
+ exports.hexToBigInt = hexToBigInt;
9
+ exports.bigIntToHex = bigIntToHex;
10
+ exports.bigIntToBufferLE = bigIntToBufferLE;
11
+ exports.bigIntFromBufferLE = bigIntFromBufferLE;
12
+ exports.bigIntToBufferBE = bigIntToBufferBE;
13
+ exports.bigIntFromBufferBE = bigIntFromBufferBE;
14
+ exports.bigIntFromU8ABE = bigIntFromU8ABE;
15
+ exports.clamp = clamp;
16
+ exports.getPaillierPublicKey = getPaillierPublicKey;
17
+ exports.randomPositiveCoPrimeTo = randomPositiveCoPrimeTo;
18
+ exports.randomPositiveCoPrimeLessThan = randomPositiveCoPrimeLessThan;
19
+ exports.randomBigInt = randomBigInt;
20
+ exports.getDerivationPath = getDerivationPath;
7
21
  const paillier_bigint_1 = require("paillier-bigint");
8
22
  const bigint_crypto_utils_1 = require("bigint-crypto-utils");
9
23
  const bigint_mod_arith_1 = require("bigint-mod-arith");
@@ -17,7 +31,6 @@ function convertHexArrToBigIntArr(values) {
17
31
  return hexToBigInt(value);
18
32
  });
19
33
  }
20
- exports.convertHexArrToBigIntArr = convertHexArrToBigIntArr;
21
34
  /**
22
35
  * Returns a hex string array from a bigint array
23
36
  * @param values
@@ -28,7 +41,6 @@ function convertBigIntArrToHexArr(values, hexLength) {
28
41
  return bigIntToHex(value, hexLength);
29
42
  });
30
43
  }
31
- exports.convertBigIntArrToHexArr = convertBigIntArrToHexArr;
32
44
  function hexToBigInt(hex) {
33
45
  // Strangely bigint.toString(16) gives a hex string without 0x,
34
46
  // but it won't accept the same string without 0x to convert
@@ -40,7 +52,6 @@ function hexToBigInt(hex) {
40
52
  }
41
53
  return BigInt('0x' + hex);
42
54
  }
43
- exports.hexToBigInt = hexToBigInt;
44
55
  /**
45
56
  * Returns an hex string of the given bigint
46
57
  *
@@ -56,7 +67,6 @@ function bigIntToHex(bigint, hexLength) {
56
67
  }
57
68
  return hex;
58
69
  }
59
- exports.bigIntToHex = bigIntToHex;
60
70
  function bigIntToBufferLE(n, minBytes) {
61
71
  let v = n.toString(16);
62
72
  v = '0'.slice(0, v.length % 2) + v;
@@ -66,11 +76,9 @@ function bigIntToBufferLE(n, minBytes) {
66
76
  }
67
77
  return buf;
68
78
  }
69
- exports.bigIntToBufferLE = bigIntToBufferLE;
70
79
  function bigIntFromBufferLE(buf) {
71
80
  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));
72
81
  }
73
- exports.bigIntFromBufferLE = bigIntFromBufferLE;
74
82
  function bigIntToBufferBE(n, minBytes) {
75
83
  let v = n.toString(16);
76
84
  v = '0'.slice(0, v.length % 2) + v;
@@ -80,21 +88,17 @@ function bigIntToBufferBE(n, minBytes) {
80
88
  }
81
89
  return buf;
82
90
  }
83
- exports.bigIntToBufferBE = bigIntToBufferBE;
84
91
  function bigIntFromBufferBE(buf) {
85
92
  return BigInt('0x' + buf.toString('hex'));
86
93
  }
87
- exports.bigIntFromBufferBE = bigIntFromBufferBE;
88
94
  function bigIntFromU8ABE(buf) {
89
95
  return bigIntFromBufferBE(Buffer.from(buf));
90
96
  }
91
- exports.bigIntFromU8ABE = bigIntFromU8ABE;
92
97
  function clamp(u) {
93
98
  u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');
94
99
  u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');
95
100
  return u;
96
101
  }
97
- exports.clamp = clamp;
98
102
  /**
99
103
  * Function get paillier public key simple varient
100
104
  * @param {bigint} n
@@ -103,7 +107,6 @@ exports.clamp = clamp;
103
107
  function getPaillierPublicKey(n) {
104
108
  return new paillier_bigint_1.PublicKey(n, n + BigInt(1));
105
109
  }
106
- exports.getPaillierPublicKey = getPaillierPublicKey;
107
110
  /**
108
111
  * Generate a random positive integer co-prime to x
109
112
  * @param x
@@ -117,7 +120,6 @@ async function randomPositiveCoPrimeTo(x) {
117
120
  }
118
121
  }
119
122
  }
120
- exports.randomPositiveCoPrimeTo = randomPositiveCoPrimeTo;
121
123
  /**
122
124
  * Generate a random positive integer coprime less than x with the same bit depth.
123
125
  * @param x
@@ -134,7 +136,6 @@ async function randomPositiveCoPrimeLessThan(x) {
134
136
  }
135
137
  }
136
138
  }
137
- exports.randomPositiveCoPrimeLessThan = randomPositiveCoPrimeLessThan;
138
139
  /**
139
140
  * Generate a random number of a given bitlength
140
141
  * @param bitlength
@@ -143,7 +144,6 @@ exports.randomPositiveCoPrimeLessThan = randomPositiveCoPrimeLessThan;
143
144
  async function randomBigInt(bitlength) {
144
145
  return bigIntFromBufferBE(Buffer.from(await (0, bigint_crypto_utils_1.randBits)(bitlength, true)));
145
146
  }
146
- exports.randomBigInt = randomBigInt;
147
147
  /**
148
148
  * @param seed - used to construct derivation path deterministically
149
149
  * @param isMaster - if set, path starts with prefix `m/`
@@ -158,8 +158,7 @@ function getDerivationPath(seed, isMaster = true) {
158
158
  const prefix = isMaster ? 'm/' : '';
159
159
  return prefix + '999999/' + derivationPathParts.join('/');
160
160
  }
161
- exports.getDerivationPath = getDerivationPath;
162
161
  function sha256(input) {
163
162
  return crypto_1.default.createHash('sha256').update(input).digest();
164
163
  }
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBits } from 'bigint-crypto-utils';\nimport { gcd } from 'bigint-mod-arith';\nimport crypto from 'crypto';\n\n/**\n * Returns a bigint array from a hex string array\n * @param values\n */\nexport function convertHexArrToBigIntArr(values: string[]): bigint[] {\n  return values.map((value) => {\n    return hexToBigInt(value);\n  });\n}\n\n/**\n * Returns a hex string array from a bigint array\n * @param values\n * @param hexLength - length to pad each big int number too\n */\nexport function convertBigIntArrToHexArr(values: bigint[], hexLength?: number): string[] {\n  return values.map((value) => {\n    return bigIntToHex(value, hexLength);\n  });\n}\n\nexport function hexToBigInt(hex: string): bigint {\n  // Strangely bigint.toString(16) gives a hex string without 0x,\n  // but it won't accept the same string without 0x to convert\n  // to a bigint (BigInt(hex string)). So have to introduce this\n  // check to convert to add 0x in case if hex string\n  // doesn't have it.\n  if (hex.slice(0, 2) === '0x') {\n    return BigInt(hex);\n  }\n  return BigInt('0x' + hex);\n}\n\n/**\n * Returns an hex string of the given bigint\n *\n * @param {bigint} bigint - the bigint to be converted to hex\n * @param hexLength\n * @returns {string} - the hex value\n */\nexport function bigIntToHex(bigint: bigint, hexLength?: number): string {\n  let hex = bigint.toString(16);\n  hex = '0'.slice(0, hex.length % 2) + hex;\n  if (hexLength) {\n    hex = hex.padStart(hexLength, '0');\n  }\n  return hex;\n}\n\nexport function bigIntToBufferLE(n: bigint, minBytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex').reverse();\n  if (minBytes && buf.length < minBytes) {\n    return Buffer.concat([buf, Buffer.alloc(minBytes - buf.length)]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferLE(buf: Buffer): bigint {\n  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));\n}\n\nexport function bigIntToBufferBE(n: bigint, minBytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex');\n  if (minBytes && buf.length < minBytes) {\n    return Buffer.concat([Buffer.alloc(minBytes - buf.length), buf]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferBE(buf: Buffer): bigint {\n  return BigInt('0x' + buf.toString('hex'));\n}\n\nexport function bigIntFromU8ABE(buf: Uint8Array): bigint {\n  return bigIntFromBufferBE(Buffer.from(buf));\n}\n\nexport function clamp(u: bigint): bigint {\n  u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');\n  u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');\n  return u;\n}\n\n/**\n * Function get paillier public key simple varient\n * @param {bigint} n\n * @returns {bigint}\n */\nexport function getPaillierPublicKey(n: bigint): PublicKey {\n  return new PublicKey(n, n + BigInt(1));\n}\n\n/**\n * Generate a random positive integer co-prime to x\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeTo(x: bigint): Promise<bigint> {\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random positive integer coprime less than x with the same bit depth.\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeLessThan(x: bigint): Promise<bigint> {\n  if (x <= BigInt(2)) {\n    throw new Error('x must be larger than 2');\n  }\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && y < x && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random number of a given bitlength\n * @param bitlength\n * @returns {Promise<bigint>}\n */\nexport async function randomBigInt(bitlength: number): Promise<bigint> {\n  return bigIntFromBufferBE(Buffer.from(await randBits(bitlength, true)));\n}\n\n/**\n * @param seed - used to construct derivation path deterministically\n * @param isMaster - if set, path starts with prefix `m/`\n * @return path `(m/)/999999/a/b` where `a` and `b` are 7-byte pseudorandom numbers based on seed\n */\nexport function getDerivationPath(seed: string, isMaster = true): string {\n  const derivationPathInput = sha256(sha256(`${seed}`)).toString('hex');\n  const derivationPathParts = [\n    parseInt(derivationPathInput.slice(0, 7), 16),\n    parseInt(derivationPathInput.slice(7, 14), 16),\n  ];\n  const prefix = isMaster ? 'm/' : '';\n  return prefix + '999999/' + derivationPathParts.join('/');\n}\n\nfunction sha256(input: crypto.BinaryLike): Buffer {\n  return crypto.createHash('sha256').update(input).digest();\n}\n"]}
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { PublicKey } from 'paillier-bigint';\nimport { bitLength, randBits } from 'bigint-crypto-utils';\nimport { gcd } from 'bigint-mod-arith';\nimport crypto from 'crypto';\n\n/**\n * Returns a bigint array from a hex string array\n * @param values\n */\nexport function convertHexArrToBigIntArr(values: string[]): bigint[] {\n  return values.map((value) => {\n    return hexToBigInt(value);\n  });\n}\n\n/**\n * Returns a hex string array from a bigint array\n * @param values\n * @param hexLength - length to pad each big int number too\n */\nexport function convertBigIntArrToHexArr(values: bigint[], hexLength?: number): string[] {\n  return values.map((value) => {\n    return bigIntToHex(value, hexLength);\n  });\n}\n\nexport function hexToBigInt(hex: string): bigint {\n  // Strangely bigint.toString(16) gives a hex string without 0x,\n  // but it won't accept the same string without 0x to convert\n  // to a bigint (BigInt(hex string)). So have to introduce this\n  // check to convert to add 0x in case if hex string\n  // doesn't have it.\n  if (hex.slice(0, 2) === '0x') {\n    return BigInt(hex);\n  }\n  return BigInt('0x' + hex);\n}\n\n/**\n * Returns an hex string of the given bigint\n *\n * @param {bigint} bigint - the bigint to be converted to hex\n * @param hexLength\n * @returns {string} - the hex value\n */\nexport function bigIntToHex(bigint: bigint, hexLength?: number): string {\n  let hex = bigint.toString(16);\n  hex = '0'.slice(0, hex.length % 2) + hex;\n  if (hexLength) {\n    hex = hex.padStart(hexLength, '0');\n  }\n  return hex;\n}\n\nexport function bigIntToBufferLE(n: bigint, minBytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex').reverse();\n  if (minBytes && buf.length < minBytes) {\n    return Buffer.concat([buf, Buffer.alloc(minBytes - buf.length)]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferLE(buf: Buffer): bigint {\n  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));\n}\n\nexport function bigIntToBufferBE(n: bigint, minBytes?: number): Buffer {\n  let v = n.toString(16);\n  v = '0'.slice(0, v.length % 2) + v;\n  const buf = Buffer.from(v, 'hex');\n  if (minBytes && buf.length < minBytes) {\n    return Buffer.concat([Buffer.alloc(minBytes - buf.length), buf]);\n  }\n  return buf;\n}\n\nexport function bigIntFromBufferBE(buf: Buffer): bigint {\n  return BigInt('0x' + buf.toString('hex'));\n}\n\nexport function bigIntFromU8ABE(buf: Uint8Array): bigint {\n  return bigIntFromBufferBE(Buffer.from(buf));\n}\n\nexport function clamp(u: bigint): bigint {\n  u &= BigInt('0x7ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8');\n  u |= BigInt('0x4000000000000000000000000000000000000000000000000000000000000000');\n  return u;\n}\n\n/**\n * Function get paillier public key simple varient\n * @param {bigint} n\n * @returns {bigint}\n */\nexport function getPaillierPublicKey(n: bigint): PublicKey {\n  return new PublicKey(n, n + BigInt(1));\n}\n\n/**\n * Generate a random positive integer co-prime to x\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeTo(x: bigint): Promise<bigint> {\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random positive integer coprime less than x with the same bit depth.\n * @param x\n * @returns {Promise<bigint>}\n */\nexport async function randomPositiveCoPrimeLessThan(x: bigint): Promise<bigint> {\n  if (x <= BigInt(2)) {\n    throw new Error('x must be larger than 2');\n  }\n  while (true) {\n    const y = await randomBigInt(bitLength(x));\n    if (y > BigInt(0) && y < x && gcd(x, y) === BigInt(1)) {\n      return y;\n    }\n  }\n}\n\n/**\n * Generate a random number of a given bitlength\n * @param bitlength\n * @returns {Promise<bigint>}\n */\nexport async function randomBigInt(bitlength: number): Promise<bigint> {\n  return bigIntFromBufferBE(Buffer.from(await randBits(bitlength, true)));\n}\n\n/**\n * @param seed - used to construct derivation path deterministically\n * @param isMaster - if set, path starts with prefix `m/`\n * @return path `(m/)/999999/a/b` where `a` and `b` are 7-byte pseudorandom numbers based on seed\n */\nexport function getDerivationPath(seed: string, isMaster = true): string {\n  const derivationPathInput = sha256(sha256(`${seed}`)).toString('hex');\n  const derivationPathParts = [\n    parseInt(derivationPathInput.slice(0, 7), 16),\n    parseInt(derivationPathInput.slice(7, 14), 16),\n  ];\n  const prefix = isMaster ? 'm/' : '';\n  return prefix + '999999/' + derivationPathParts.join('/');\n}\n\nfunction sha256(input: crypto.BinaryLike): Buffer {\n  return crypto.createHash('sha256').update(input).digest();\n}\n"]}