@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.8 → 8.2.1-alpha.80

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/CHANGELOG.md +466 -0
  2. package/dist/src/curves/constant.d.ts +2 -0
  3. package/dist/src/curves/constant.d.ts.map +1 -0
  4. package/dist/src/curves/constant.js +6 -0
  5. package/dist/src/curves/{baseCurve.d.ts → ed25519.d.ts} +9 -7
  6. package/dist/src/curves/ed25519.d.ts.map +1 -0
  7. package/dist/src/curves/ed25519.js +72 -0
  8. package/dist/src/curves/ed25519Bip32HdTree.d.ts +10 -0
  9. package/dist/src/curves/ed25519Bip32HdTree.d.ts.map +1 -0
  10. package/dist/src/curves/ed25519Bip32HdTree.js +85 -0
  11. package/dist/src/curves/index.d.ts +6 -1
  12. package/dist/src/curves/index.d.ts.map +1 -1
  13. package/dist/src/curves/index.js +12 -3
  14. package/dist/src/curves/secp256k1.d.ts +3 -1
  15. package/dist/src/curves/secp256k1.d.ts.map +1 -1
  16. package/dist/src/curves/secp256k1.js +25 -14
  17. package/dist/src/curves/secp256k1Bip32HdTree.d.ts +8 -0
  18. package/dist/src/curves/secp256k1Bip32HdTree.d.ts.map +1 -0
  19. package/dist/src/curves/secp256k1Bip32HdTree.js +54 -0
  20. package/dist/src/curves/types.d.ts +36 -0
  21. package/dist/src/curves/types.d.ts.map +1 -0
  22. package/dist/src/curves/types.js +3 -0
  23. package/dist/src/curves/util.d.ts +2 -0
  24. package/dist/src/curves/util.d.ts.map +1 -0
  25. package/dist/src/curves/util.js +11 -0
  26. package/dist/src/hashCommitment.d.ts +17 -0
  27. package/dist/src/hashCommitment.d.ts.map +1 -0
  28. package/dist/src/hashCommitment.js +45 -0
  29. package/dist/src/index.d.ts +6 -2
  30. package/dist/src/index.d.ts.map +1 -1
  31. package/dist/src/index.js +25 -4
  32. package/dist/src/safePrime.d.ts +3 -0
  33. package/dist/src/safePrime.d.ts.map +1 -0
  34. package/dist/src/safePrime.js +23 -0
  35. package/dist/src/schnorrProof.d.ts +22 -0
  36. package/dist/src/schnorrProof.d.ts.map +1 -0
  37. package/dist/src/schnorrProof.js +62 -0
  38. package/dist/src/shamir/index.d.ts +3 -0
  39. package/dist/src/shamir/index.d.ts.map +1 -0
  40. package/dist/src/{openssl → shamir}/index.js +8 -3
  41. package/dist/src/shamir/shamir.d.ts +38 -0
  42. package/dist/src/shamir/shamir.d.ts.map +1 -0
  43. package/dist/src/shamir/shamir.js +136 -0
  44. package/dist/src/shamir/types.d.ts +5 -0
  45. package/dist/src/shamir/types.d.ts.map +1 -0
  46. package/dist/src/shamir/types.js +3 -0
  47. package/dist/src/tss/ecdsa/index.d.ts +1 -0
  48. package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
  49. package/dist/src/tss/ecdsa/index.js +8 -3
  50. package/dist/src/tss/ecdsa/paillierproof.js +6 -6
  51. package/dist/src/tss/ecdsa/rangeproof.d.ts +0 -1
  52. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  53. package/dist/src/tss/ecdsa/rangeproof.js +102 -108
  54. package/dist/src/tss/ecdsa/types.d.ts +5 -0
  55. package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
  56. package/dist/src/tss/ecdsa/types.js +19 -19
  57. package/dist/src/tss/ecdsa/zkVProof.d.ts +25 -0
  58. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
  59. package/dist/src/tss/ecdsa/zkVProof.js +71 -0
  60. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +43 -0
  61. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  62. package/dist/src/tss/ecdsa-dkls/commsLayer.js +216 -0
  63. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +20 -0
  64. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  65. package/dist/src/tss/ecdsa-dkls/dkg.js +153 -0
  66. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +30 -0
  67. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  68. package/dist/src/tss/ecdsa-dkls/dsg.js +170 -0
  69. package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
  70. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
  71. package/dist/src/tss/ecdsa-dkls/index.js +32 -0
  72. package/dist/src/tss/ecdsa-dkls/types.d.ts +104 -0
  73. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
  74. package/dist/src/tss/ecdsa-dkls/types.js +115 -0
  75. package/dist/src/tss/ecdsa-dkls/util.d.ts +22 -0
  76. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  77. package/dist/src/tss/ecdsa-dkls/util.js +85 -0
  78. package/dist/src/tss/index.d.ts +1 -0
  79. package/dist/src/tss/index.d.ts.map +1 -1
  80. package/dist/src/tss/index.js +7 -2
  81. package/dist/src/types.d.ts +14 -0
  82. package/dist/src/types.d.ts.map +1 -0
  83. package/dist/src/types.js +3 -0
  84. package/dist/src/util.d.ts +8 -2
  85. package/dist/src/util.d.ts.map +1 -1
  86. package/dist/src/util.js +35 -13
  87. package/dist/tsconfig.tsbuildinfo +1 -3645
  88. package/package.json +13 -7
  89. package/dist/src/curves/baseCurve.d.ts.map +0 -1
  90. package/dist/src/curves/baseCurve.js +0 -6
  91. package/dist/src/openssl/index.d.ts +0 -2
  92. package/dist/src/openssl/index.d.ts.map +0 -1
  93. package/dist/src/openssl/openssl.d.ts +0 -9
  94. package/dist/src/openssl/openssl.d.ts.map +0 -1
  95. package/dist/src/openssl/openssl.js +0 -45
  96. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  97. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  98. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getCommonKeychain = exports.serializeBroadcastMessage = exports.serializeP2PMessage = exports.deserializeBroadcastMessage = exports.deserializeP2PMessage = exports.deserializeMessages = exports.serializeMessages = exports.DsgState = exports.DkgState = void 0;
7
+ const assert_1 = __importDefault(require("assert"));
8
+ const cbor_1 = require("cbor");
9
+ var DkgState;
10
+ (function (DkgState) {
11
+ DkgState[DkgState["Uninitialized"] = 0] = "Uninitialized";
12
+ DkgState[DkgState["Round1"] = 1] = "Round1";
13
+ DkgState[DkgState["Round2"] = 2] = "Round2";
14
+ DkgState[DkgState["Round3"] = 3] = "Round3";
15
+ DkgState[DkgState["Round4"] = 4] = "Round4";
16
+ DkgState[DkgState["Complete"] = 5] = "Complete";
17
+ DkgState[DkgState["InvalidState"] = 6] = "InvalidState";
18
+ })(DkgState = exports.DkgState || (exports.DkgState = {}));
19
+ var DsgState;
20
+ (function (DsgState) {
21
+ DsgState[DsgState["Uninitialized"] = 0] = "Uninitialized";
22
+ DsgState[DsgState["Round1"] = 1] = "Round1";
23
+ DsgState[DsgState["Round2"] = 2] = "Round2";
24
+ DsgState[DsgState["Round3"] = 3] = "Round3";
25
+ DsgState[DsgState["Round4"] = 4] = "Round4";
26
+ DsgState[DsgState["Complete"] = 5] = "Complete";
27
+ DsgState[DsgState["InvalidState"] = 6] = "InvalidState";
28
+ })(DsgState = exports.DsgState || (exports.DsgState = {}));
29
+ /**
30
+ * Serializes messages payloads to base64 strings.
31
+ * @param messages
32
+ */
33
+ function serializeMessages(messages) {
34
+ return {
35
+ p2pMessages: messages.p2pMessages.map(serializeP2PMessage),
36
+ broadcastMessages: messages.broadcastMessages.map(serializeBroadcastMessage),
37
+ };
38
+ }
39
+ exports.serializeMessages = serializeMessages;
40
+ /**
41
+ * Deserialize messages payloads to Uint8Array.
42
+ * @param messages
43
+ */
44
+ function deserializeMessages(messages) {
45
+ return {
46
+ p2pMessages: messages.p2pMessages.map(deserializeP2PMessage),
47
+ broadcastMessages: messages.broadcastMessages.map(deserializeBroadcastMessage),
48
+ };
49
+ }
50
+ exports.deserializeMessages = deserializeMessages;
51
+ /**
52
+ * Deserializes a P2P message.
53
+ * @param message
54
+ */
55
+ function deserializeP2PMessage(message) {
56
+ return {
57
+ to: message.to,
58
+ from: message.from,
59
+ payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
60
+ commitment: message.commitment ? new Uint8Array(Buffer.from(message.commitment, 'base64')) : undefined,
61
+ };
62
+ }
63
+ exports.deserializeP2PMessage = deserializeP2PMessage;
64
+ /**
65
+ * Deserializes a Broadcast message.
66
+ * @param message
67
+ */
68
+ function deserializeBroadcastMessage(message) {
69
+ return {
70
+ from: message.from,
71
+ payload: new Uint8Array(Buffer.from(message.payload, 'base64')),
72
+ signatureR: message.signatureR ? new Uint8Array(Buffer.from(message.signatureR, 'base64')) : undefined,
73
+ };
74
+ }
75
+ exports.deserializeBroadcastMessage = deserializeBroadcastMessage;
76
+ /**
77
+ * Serializes a P2P message.
78
+ * @param message
79
+ */
80
+ function serializeP2PMessage(message) {
81
+ return {
82
+ to: message.to,
83
+ from: message.from,
84
+ payload: Buffer.from(message.payload).toString('base64'),
85
+ commitment: message.commitment ? Buffer.from(message.commitment).toString('base64') : undefined,
86
+ };
87
+ }
88
+ exports.serializeP2PMessage = serializeP2PMessage;
89
+ /**
90
+ * Serializes a Broadcast message.
91
+ * @param message
92
+ */
93
+ function serializeBroadcastMessage(message) {
94
+ return {
95
+ from: message.from,
96
+ payload: Buffer.from(message.payload).toString('base64'),
97
+ signatureR: message.signatureR ? Buffer.from(message.signatureR).toString('base64') : undefined,
98
+ };
99
+ }
100
+ exports.serializeBroadcastMessage = serializeBroadcastMessage;
101
+ /**
102
+ * Gets commonkeyChain from DKLS keyShare
103
+ * @param {Buffer} keyShare - DKLS keyShare
104
+ * @returns {string} commonKeychain
105
+ */
106
+ function getCommonKeychain(keyShare) {
107
+ const parsedKeyShare = (0, cbor_1.decode)(keyShare);
108
+ (0, assert_1.default)(parsedKeyShare.public_key, 'public_key not found in keyShare');
109
+ (0, assert_1.default)(parsedKeyShare.root_chain_code, 'root_chain_code not found in public_key');
110
+ const publicKey = Buffer.from(parsedKeyShare.public_key).toString('hex');
111
+ const rootChainCode = Buffer.from(parsedKeyShare.root_chain_code).toString('hex');
112
+ return publicKey + rootChainCode;
113
+ }
114
+ exports.getCommonKeychain = getCommonKeychain;
115
+ //# 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';\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 = 0,\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 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, 'base64')) : 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('base64') : 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\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"]}
@@ -0,0 +1,22 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { DeserializedDklsSignature } from './types';
4
+ import { Hash } from 'crypto';
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 hash - optional hash function to apply on message before verifying. Default is sha256.
18
+ * @param shouldHash - flag to determine whether message should be hashed before verifying.
19
+ * @returns {string} - serialized signature in `recid:r:s:publickey` format
20
+ */
21
+ export declare function verifyAndConvertDklsSignature(message: Buffer, dklsSignature: DeserializedDklsSignature, commonKeychain: string, hash?: Hash, shouldHash?: boolean): string;
22
+ //# sourceMappingURL=util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/tss/ecdsa-dkls/util.ts"],"names":[],"mappings":";;AAGA,OAAO,EAAE,yBAAyB,EAAE,MAAM,SAAS,CAAC;AAGpD,OAAO,EAAE,IAAI,EAAc,MAAM,QAAQ,CAAC;AAI1C;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,qBAAqB,EAAE,UAAU,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,yBAAyB,CAgBrH;AAED;;;;;;;;GAQG;AACH,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,yBAAyB,EACxC,cAAc,EAAE,MAAM,EACtB,IAAI,CAAC,EAAE,IAAI,EACX,UAAU,UAAO,GAChB,MAAM,CAgBR"}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.verifyAndConvertDklsSignature = exports.combinePartialSignatures = void 0;
27
+ const secp256k1_1 = require("@noble/secp256k1");
28
+ const curves_1 = require("../../curves");
29
+ const util_1 = require("../../util");
30
+ const cbor_1 = require("cbor");
31
+ const secp256k1 = __importStar(require("secp256k1"));
32
+ const crypto_1 = require("crypto");
33
+ const delimeter = ':';
34
+ /**
35
+ * Combines partial signatures from parties participating in DSG.
36
+ * @param round4MessagePayloads - round 4 message payloads from participating parties
37
+ * @param rHex - hex representation of the r value in the signature
38
+ * @returns {DeserializedMessages} - messages to send to other parties for the next round
39
+ */
40
+ function combinePartialSignatures(round4MessagePayloads, rHex) {
41
+ const r = (0, util_1.bigIntFromBufferBE)(Buffer.from(rHex, 'hex').subarray(1));
42
+ const s0Arr = round4MessagePayloads.map((p) => (0, cbor_1.decode)(p).s_0);
43
+ const s1Arr = round4MessagePayloads.map((p) => (0, cbor_1.decode)(p).s_1);
44
+ const s0BigInts = s0Arr.map((s0) => (0, util_1.bigIntFromBufferBE)(Buffer.from(s0)));
45
+ const s1BigInts = s1Arr.map((s1) => (0, util_1.bigIntFromBufferBE)(Buffer.from(s1)));
46
+ const secp256k1Curve = new curves_1.Secp256k1Curve();
47
+ const s0Sum = s0BigInts.slice(1).reduce((sumSoFar, s0) => secp256k1Curve.scalarAdd(sumSoFar, s0), s0BigInts[0]);
48
+ const s1Sum = s1BigInts.slice(1).reduce((sumSoFar, s1) => secp256k1Curve.scalarAdd(sumSoFar, s1), s1BigInts[0]);
49
+ const s = secp256k1Curve.scalarMult(s0Sum, secp256k1Curve.scalarInvert(s1Sum));
50
+ const sig = new secp256k1_1.Signature(r, s);
51
+ const normalizedSig = sig.normalizeS();
52
+ return {
53
+ R: new Uint8Array((0, util_1.bigIntToBufferBE)(normalizedSig.r)),
54
+ S: new Uint8Array((0, util_1.bigIntToBufferBE)(normalizedSig.s)),
55
+ };
56
+ }
57
+ exports.combinePartialSignatures = combinePartialSignatures;
58
+ /**
59
+ * Verify a DKLs Signature and serialize it to recid:r:s:publickey format.
60
+ * @param message - message that was signed.
61
+ * @param dklsSignature - R and S values of the ECDSA signature.
62
+ * @param commonKeychain - public key appended to chaincode in hex.
63
+ * @param hash - optional hash function to apply on message before verifying. Default is sha256.
64
+ * @param shouldHash - flag to determine whether message should be hashed before verifying.
65
+ * @returns {string} - serialized signature in `recid:r:s:publickey` format
66
+ */
67
+ function verifyAndConvertDklsSignature(message, dklsSignature, commonKeychain, hash, shouldHash = true) {
68
+ const messageToVerify = shouldHash ? (hash || (0, crypto_1.createHash)('sha256')).update(message).digest() : message;
69
+ const pub0 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 0, messageToVerify, true);
70
+ const pub1 = secp256k1.ecdsaRecover(Buffer.concat([dklsSignature.R, dklsSignature.S]), 1, messageToVerify, true);
71
+ const truePub = commonKeychain.slice(0, 66);
72
+ let recId;
73
+ if (truePub === Buffer.from(pub0).toString('hex')) {
74
+ recId = 0;
75
+ }
76
+ else if (truePub === Buffer.from(pub1).toString('hex')) {
77
+ recId = 1;
78
+ }
79
+ else {
80
+ throw Error('Invalid Signature');
81
+ }
82
+ return `${recId}${delimeter}${Buffer.from(dklsSignature.R).toString('hex')}${delimeter}${Buffer.from(dklsSignature.S).toString('hex')}${delimeter}${truePub}`;
83
+ }
84
+ exports.verifyAndConvertDklsSignature = verifyAndConvertDklsSignature;
85
+ //# 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 { Signature } from '@noble/secp256k1';\nimport { Secp256k1Curve } from '../../curves';\nimport { bigIntFromBufferBE, bigIntToBufferBE } from '../../util';\nimport { DeserializedDklsSignature } from './types';\nimport { decode } from 'cbor';\nimport * as secp256k1 from 'secp256k1';\nimport { Hash, createHash } from 'crypto';\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 Signature(r, s);\n  const normalizedSig = sig.normalizeS();\n  return {\n    R: new Uint8Array(bigIntToBufferBE(normalizedSig.r)),\n    S: new Uint8Array(bigIntToBufferBE(normalizedSig.s)),\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 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  hash?: Hash,\n  shouldHash = true\n): string {\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  const truePub = commonKeychain.slice(0, 66);\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"]}
@@ -1,2 +1,3 @@
1
1
  export * from './ecdsa';
2
+ export * from './ecdsa-dkls';
2
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tss/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC"}
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -11,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
11
15
  };
12
16
  Object.defineProperty(exports, "__esModule", { value: true });
13
17
  __exportStar(require("./ecdsa"), exports);
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZWNkc2EnO1xuIl19
18
+ __exportStar(require("./ecdsa-dkls"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHNzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIsK0NBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lY2RzYSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZHNhLWRrbHMnO1xuIl19
@@ -0,0 +1,14 @@
1
+ /// <reference types="node" />
2
+ export interface HashCommitDecommit {
3
+ commitment: Buffer;
4
+ decommitment: HashDecommitment;
5
+ }
6
+ export interface HashDecommitment {
7
+ secret: Buffer;
8
+ blindingFactor: Buffer;
9
+ }
10
+ export interface SchnorrProof {
11
+ vPoint: bigint;
12
+ r: bigint;
13
+ }
14
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +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"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSGFzaENvbW1pdERlY29tbWl0IHtcbiAgY29tbWl0bWVudDogQnVmZmVyO1xuICBkZWNvbW1pdG1lbnQ6IEhhc2hEZWNvbW1pdG1lbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzaERlY29tbWl0bWVudCB7XG4gIHNlY3JldDogQnVmZmVyO1xuICBibGluZGluZ0ZhY3RvcjogQnVmZmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaG5vcnJQcm9vZiB7XG4gIHZQb2ludDogYmlnaW50O1xuICByOiBiaWdpbnQ7XG59XG4iXX0=
@@ -20,9 +20,9 @@ export declare function hexToBigInt(hex: string): bigint;
20
20
  * @returns {string} - the hex value
21
21
  */
22
22
  export declare function bigIntToHex(bigint: bigint, hexLength?: number): string;
23
- export declare function bigIntToBufferLE(n: bigint, bytes?: number): Buffer;
23
+ export declare function bigIntToBufferLE(n: bigint, minBytes?: number): Buffer;
24
24
  export declare function bigIntFromBufferLE(buf: Buffer): bigint;
25
- export declare function bigIntToBufferBE(n: bigint, bytes?: number): Buffer;
25
+ export declare function bigIntToBufferBE(n: bigint, minBytes?: number): Buffer;
26
26
  export declare function bigIntFromBufferBE(buf: Buffer): bigint;
27
27
  export declare function bigIntFromU8ABE(buf: Uint8Array): bigint;
28
28
  export declare function clamp(u: bigint): bigint;
@@ -50,4 +50,10 @@ export declare function randomPositiveCoPrimeLessThan(x: bigint): Promise<bigint
50
50
  * @returns {Promise<bigint>}
51
51
  */
52
52
  export declare function randomBigInt(bitlength: number): Promise<bigint>;
53
+ /**
54
+ * @param seed - used to construct derivation path deterministically
55
+ * @param isMaster - if set, path starts with prefix `m/`
56
+ * @return path `(m/)/999999/a/b` where `a` and `b` are 7-byte pseudorandom numbers based on seed
57
+ */
58
+ export declare function getDerivationPath(seed: string, isMaster?: boolean): string;
53
59
  //# sourceMappingURL=util.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAI5C;;;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,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAQlE;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAEtD;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAQlE;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"}
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
@@ -1,9 +1,13 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
- 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.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;
4
7
  const paillier_bigint_1 = require("paillier-bigint");
5
8
  const bigint_crypto_utils_1 = require("bigint-crypto-utils");
6
9
  const bigint_mod_arith_1 = require("bigint-mod-arith");
10
+ const crypto_1 = __importDefault(require("crypto"));
7
11
  /**
8
12
  * Returns a bigint array from a hex string array
9
13
  * @param values
@@ -53,12 +57,12 @@ function bigIntToHex(bigint, hexLength) {
53
57
  return hex;
54
58
  }
55
59
  exports.bigIntToHex = bigIntToHex;
56
- function bigIntToBufferLE(n, bytes) {
60
+ function bigIntToBufferLE(n, minBytes) {
57
61
  let v = n.toString(16);
58
62
  v = '0'.slice(0, v.length % 2) + v;
59
63
  const buf = Buffer.from(v, 'hex').reverse();
60
- if (bytes && buf.length < bytes) {
61
- return Buffer.concat([buf, Buffer.alloc(bytes - buf.length)]);
64
+ if (minBytes && buf.length < minBytes) {
65
+ return Buffer.concat([buf, Buffer.alloc(minBytes - buf.length)]);
62
66
  }
63
67
  return buf;
64
68
  }
@@ -67,12 +71,12 @@ function bigIntFromBufferLE(buf) {
67
71
  return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));
68
72
  }
69
73
  exports.bigIntFromBufferLE = bigIntFromBufferLE;
70
- function bigIntToBufferBE(n, bytes) {
74
+ function bigIntToBufferBE(n, minBytes) {
71
75
  let v = n.toString(16);
72
76
  v = '0'.slice(0, v.length % 2) + v;
73
77
  const buf = Buffer.from(v, 'hex');
74
- if (bytes && buf.length < bytes) {
75
- return Buffer.concat([Buffer.alloc(bytes - buf.length), buf]);
78
+ if (minBytes && buf.length < minBytes) {
79
+ return Buffer.concat([Buffer.alloc(minBytes - buf.length), buf]);
76
80
  }
77
81
  return buf;
78
82
  }
@@ -107,8 +111,8 @@ exports.getPaillierPublicKey = getPaillierPublicKey;
107
111
  */
108
112
  async function randomPositiveCoPrimeTo(x) {
109
113
  while (true) {
110
- const y = await randomBigInt(bigint_crypto_utils_1.bitLength(x));
111
- if (y > BigInt(0) && bigint_mod_arith_1.gcd(x, y) === BigInt(1)) {
114
+ const y = await randomBigInt((0, bigint_crypto_utils_1.bitLength)(x));
115
+ if (y > BigInt(0) && (0, bigint_mod_arith_1.gcd)(x, y) === BigInt(1)) {
112
116
  return y;
113
117
  }
114
118
  }
@@ -124,8 +128,8 @@ async function randomPositiveCoPrimeLessThan(x) {
124
128
  throw new Error('x must be larger than 2');
125
129
  }
126
130
  while (true) {
127
- const y = await randomBigInt(bigint_crypto_utils_1.bitLength(x));
128
- if (y > BigInt(0) && y < x && bigint_mod_arith_1.gcd(x, y) === BigInt(1)) {
131
+ const y = await randomBigInt((0, bigint_crypto_utils_1.bitLength)(x));
132
+ if (y > BigInt(0) && y < x && (0, bigint_mod_arith_1.gcd)(x, y) === BigInt(1)) {
129
133
  return y;
130
134
  }
131
135
  }
@@ -137,7 +141,25 @@ exports.randomPositiveCoPrimeLessThan = randomPositiveCoPrimeLessThan;
137
141
  * @returns {Promise<bigint>}
138
142
  */
139
143
  async function randomBigInt(bitlength) {
140
- return bigIntFromBufferBE(Buffer.from(await bigint_crypto_utils_1.randBits(bitlength, true)));
144
+ return bigIntFromBufferBE(Buffer.from(await (0, bigint_crypto_utils_1.randBits)(bitlength, true)));
141
145
  }
142
146
  exports.randomBigInt = randomBigInt;
143
- //# 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';\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, bytes?: 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 (bytes && buf.length < bytes) {\n    return Buffer.concat([buf, Buffer.alloc(bytes - 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, bytes?: 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 (bytes && buf.length < bytes) {\n    return Buffer.concat([Buffer.alloc(bytes - 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"]}
147
+ /**
148
+ * @param seed - used to construct derivation path deterministically
149
+ * @param isMaster - if set, path starts with prefix `m/`
150
+ * @return path `(m/)/999999/a/b` where `a` and `b` are 7-byte pseudorandom numbers based on seed
151
+ */
152
+ function getDerivationPath(seed, isMaster = true) {
153
+ const derivationPathInput = sha256(sha256(`${seed}`)).toString('hex');
154
+ const derivationPathParts = [
155
+ parseInt(derivationPathInput.slice(0, 7), 16),
156
+ parseInt(derivationPathInput.slice(7, 14), 16),
157
+ ];
158
+ const prefix = isMaster ? 'm/' : '';
159
+ return prefix + '999999/' + derivationPathParts.join('/');
160
+ }
161
+ exports.getDerivationPath = getDerivationPath;
162
+ function sha256(input) {
163
+ return crypto_1.default.createHash('sha256').update(input).digest();
164
+ }
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/util.ts"],"names":[],"mappings":";;;;;;AAAA,qDAA4C;AAC5C,6DAA0D;AAC1D,uDAAuC;AACvC,oDAA4B;AAE5B;;;GAGG;AACH,SAAgB,wBAAwB,CAAC,MAAgB;IACvD,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1B,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;AACL,CAAC;AAJD,4DAIC;AAED;;;;GAIG;AACH,SAAgB,wBAAwB,CAAC,MAAgB,EAAE,SAAkB;IAC3E,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QAC1B,OAAO,WAAW,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC;AAJD,4DAIC;AAED,SAAgB,WAAW,CAAC,GAAW;IACrC,+DAA+D;IAC/D,4DAA4D;IAC5D,8DAA8D;IAC9D,mDAAmD;IACnD,mBAAmB;IACnB,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAE;QAC5B,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;KACpB;IACD,OAAO,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;AAC5B,CAAC;AAVD,kCAUC;AAED;;;;;;GAMG;AACH,SAAgB,WAAW,CAAC,MAAc,EAAE,SAAkB;IAC5D,IAAI,GAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC9B,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IACzC,IAAI,SAAS,EAAE;QACb,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;KACpC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAPD,kCAOC;AAED,SAAgB,gBAAgB,CAAC,CAAS,EAAE,QAAiB;IAC3D,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACnC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;IAC5C,IAAI,QAAQ,IAAI,GAAG,CAAC,MAAM,GAAG,QAAQ,EAAE;QACrC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;KAClE;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AARD,4CAQC;AAED,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,OAAO,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AACnE,CAAC;AAFD,gDAEC;AAED,SAAgB,gBAAgB,CAAC,CAAS,EAAE,QAAiB;IAC3D,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACnC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IAClC,IAAI,QAAQ,IAAI,GAAG,CAAC,MAAM,GAAG,QAAQ,EAAE;QACrC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;KAClE;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AARD,4CAQC;AAED,SAAgB,kBAAkB,CAAC,GAAW;IAC5C,OAAO,MAAM,CAAC,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;AAC5C,CAAC;AAFD,gDAEC;AAED,SAAgB,eAAe,CAAC,GAAe;IAC7C,OAAO,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9C,CAAC;AAFD,0CAEC;AAED,SAAgB,KAAK,CAAC,CAAS;IAC7B,CAAC,IAAI,MAAM,CAAC,oEAAoE,CAAC,CAAC;IAClF,CAAC,IAAI,MAAM,CAAC,oEAAoE,CAAC,CAAC;IAClF,OAAO,CAAC,CAAC;AACX,CAAC;AAJD,sBAIC;AAED;;;;GAIG;AACH,SAAgB,oBAAoB,CAAC,CAAS;IAC5C,OAAO,IAAI,2BAAS,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACzC,CAAC;AAFD,oDAEC;AAED;;;;GAIG;AACI,KAAK,UAAU,uBAAuB,CAAC,CAAS;IACrD,OAAO,IAAI,EAAE;QACX,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,IAAA,+BAAS,EAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,IAAA,sBAAG,EAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,EAAE;YAC5C,OAAO,CAAC,CAAC;SACV;KACF;AACH,CAAC;AAPD,0DAOC;AAED;;;;GAIG;AACI,KAAK,UAAU,6BAA6B,CAAC,CAAS;IAC3D,IAAI,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE;QAClB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;KAC5C;IACD,OAAO,IAAI,EAAE;QACX,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,IAAA,+BAAS,EAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,IAAA,sBAAG,EAAC,CAAC,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,EAAE;YACrD,OAAO,CAAC,CAAC;SACV;KACF;AACH,CAAC;AAVD,sEAUC;AAED;;;;GAIG;AACI,KAAK,UAAU,YAAY,CAAC,SAAiB;IAClD,OAAO,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,IAAA,8BAAQ,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AAC1E,CAAC;AAFD,oCAEC;AAED;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,IAAY,EAAE,QAAQ,GAAG,IAAI;IAC7D,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtE,MAAM,mBAAmB,GAAG;QAC1B,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;QAC7C,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;KAC/C,CAAC;IACF,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;IACpC,OAAO,MAAM,GAAG,SAAS,GAAG,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC5D,CAAC;AARD,8CAQC;AAED,SAAS,MAAM,CAAC,KAAwB;IACtC,OAAO,gBAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;AAC5D,CAAC","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"]}