@bitgo-beta/sdk-lib-mpc 8.2.1-alpha.3 → 8.2.1-alpha.300

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 (102) hide show
  1. package/CHANGELOG.md +657 -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/ed25519.d.ts +20 -0
  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 +7 -2
  12. package/dist/src/curves/index.d.ts.map +1 -1
  13. package/dist/src/curves/index.js +22 -1
  14. package/dist/src/curves/{baseCurve.d.ts → secp256k1.d.ts} +11 -13
  15. package/dist/src/curves/secp256k1.d.ts.map +1 -0
  16. package/dist/src/curves/secp256k1.js +61 -0
  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 +35 -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 +4 -0
  24. package/dist/src/curves/util.d.ts.map +1 -0
  25. package/dist/src/curves/util.js +42 -0
  26. package/dist/src/hashCommitment.d.ts +16 -0
  27. package/dist/src/hashCommitment.d.ts.map +1 -0
  28. package/dist/src/hashCommitment.js +44 -0
  29. package/dist/src/index.d.ts +6 -1
  30. package/dist/src/index.d.ts.map +1 -1
  31. package/dist/src/index.js +35 -3
  32. package/dist/src/openssl/index.js +6 -2
  33. package/dist/src/openssl/openssl.d.ts +1 -2
  34. package/dist/src/openssl/openssl.d.ts.map +1 -1
  35. package/dist/src/openssl/openssl.js +4 -12
  36. package/dist/src/safePrime.d.ts +3 -0
  37. package/dist/src/safePrime.d.ts.map +1 -0
  38. package/dist/src/safePrime.js +19 -0
  39. package/dist/src/schnorrProof.d.ts +21 -0
  40. package/dist/src/schnorrProof.d.ts.map +1 -0
  41. package/dist/src/schnorrProof.js +61 -0
  42. package/dist/src/shamir/index.d.ts +3 -0
  43. package/dist/src/shamir/index.d.ts.map +1 -0
  44. package/dist/src/shamir/index.js +19 -0
  45. package/dist/src/shamir/shamir.d.ts +38 -0
  46. package/dist/src/shamir/shamir.d.ts.map +1 -0
  47. package/dist/src/shamir/shamir.js +136 -0
  48. package/dist/src/shamir/types.d.ts +5 -0
  49. package/dist/src/shamir/types.d.ts.map +1 -0
  50. package/dist/src/shamir/types.js +3 -0
  51. package/dist/src/tss/ecdsa/index.d.ts +4 -1
  52. package/dist/src/tss/ecdsa/index.d.ts.map +1 -1
  53. package/dist/src/tss/ecdsa/index.js +28 -11
  54. package/dist/src/tss/ecdsa/paillierproof.d.ts +24 -0
  55. package/dist/src/tss/ecdsa/paillierproof.d.ts.map +1 -0
  56. package/dist/src/tss/ecdsa/paillierproof.js +86 -0
  57. package/dist/src/tss/ecdsa/primes.d.ts +2 -0
  58. package/dist/src/tss/ecdsa/primes.d.ts.map +1 -0
  59. package/dist/src/tss/ecdsa/primes.js +1846 -0
  60. package/dist/src/tss/ecdsa/rangeproof.d.ts +3 -5
  61. package/dist/src/tss/ecdsa/rangeproof.d.ts.map +1 -1
  62. package/dist/src/tss/ecdsa/rangeproof.js +123 -141
  63. package/dist/src/tss/ecdsa/types.d.ts +97 -9
  64. package/dist/src/tss/ecdsa/types.d.ts.map +1 -1
  65. package/dist/src/tss/ecdsa/types.js +128 -1
  66. package/dist/src/tss/ecdsa/zkVProof.d.ts +24 -0
  67. package/dist/src/tss/ecdsa/zkVProof.d.ts.map +1 -0
  68. package/dist/src/tss/ecdsa/zkVProof.js +70 -0
  69. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts +42 -0
  70. package/dist/src/tss/ecdsa-dkls/commsLayer.d.ts.map +1 -0
  71. package/dist/src/tss/ecdsa-dkls/commsLayer.js +235 -0
  72. package/dist/src/tss/ecdsa-dkls/dkg.d.ts +57 -0
  73. package/dist/src/tss/ecdsa-dkls/dkg.d.ts.map +1 -0
  74. package/dist/src/tss/ecdsa-dkls/dkg.js +321 -0
  75. package/dist/src/tss/ecdsa-dkls/dsg.d.ts +47 -0
  76. package/dist/src/tss/ecdsa-dkls/dsg.d.ts.map +1 -0
  77. package/dist/src/tss/ecdsa-dkls/dsg.js +266 -0
  78. package/dist/src/tss/ecdsa-dkls/index.d.ts +6 -0
  79. package/dist/src/tss/ecdsa-dkls/index.d.ts.map +1 -0
  80. package/dist/src/tss/ecdsa-dkls/index.js +42 -0
  81. package/dist/src/tss/ecdsa-dkls/types.d.ts +118 -0
  82. package/dist/src/tss/ecdsa-dkls/types.d.ts.map +1 -0
  83. package/dist/src/tss/ecdsa-dkls/types.js +165 -0
  84. package/dist/src/tss/ecdsa-dkls/util.d.ts +26 -0
  85. package/dist/src/tss/ecdsa-dkls/util.d.ts.map +1 -0
  86. package/dist/src/tss/ecdsa-dkls/util.js +276 -0
  87. package/dist/src/tss/index.d.ts +2 -1
  88. package/dist/src/tss/index.d.ts.map +1 -1
  89. package/dist/src/tss/index.js +10 -15
  90. package/dist/src/types.d.ts +13 -0
  91. package/dist/src/types.d.ts.map +1 -0
  92. package/dist/src/types.js +3 -0
  93. package/dist/src/util.d.ts +55 -3
  94. package/dist/src/util.d.ts.map +1 -1
  95. package/dist/src/util.js +144 -12
  96. package/dist/tsconfig.tsbuildinfo +1 -3588
  97. package/package.json +27 -6
  98. package/dist/src/curves/baseCurve.d.ts.map +0 -1
  99. package/dist/src/curves/baseCurve.js +0 -6
  100. package/dist/src/openssl/opensslbytes.d.ts +0 -4
  101. package/dist/src/openssl/opensslbytes.d.ts.map +0 -1
  102. package/dist/src/openssl/opensslbytes.js +0 -20
@@ -0,0 +1,2 @@
1
+ export declare const chaincodeBase: bigint;
2
+ //# sourceMappingURL=constant.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constant.d.ts","sourceRoot":"","sources":["../../../src/curves/constant.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,aAAa,QAAiF,CAAC"}
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.chaincodeBase = void 0;
4
+ // 2^256
5
+ exports.chaincodeBase = BigInt('0x010000000000000000000000000000000000000000000000000000000000000000');
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VydmVzL2NvbnN0YW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLFFBQVE7QUFDSyxRQUFBLGFBQWEsR0FBRyxNQUFNLENBQUMsc0VBQXNFLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIDJeMjU2XG5leHBvcnQgY29uc3QgY2hhaW5jb2RlQmFzZSA9IEJpZ0ludCgnMHgwMTAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAnKTtcbiJdfQ==
@@ -0,0 +1,20 @@
1
+ import { BaseCurve } from './types';
2
+ export declare class Ed25519Curve implements BaseCurve {
3
+ static initialized: boolean;
4
+ static initialize(): Promise<Ed25519Curve>;
5
+ scalarRandom(): bigint;
6
+ scalarReduce(s: bigint): bigint;
7
+ scalarNegate(s: bigint): bigint;
8
+ scalarInvert(s: bigint): bigint;
9
+ scalarAdd(x: bigint, y: bigint): bigint;
10
+ scalarSub(x: bigint, y: bigint): bigint;
11
+ scalarMult(x: bigint, y: bigint): bigint;
12
+ basePointMult(n: bigint): bigint;
13
+ pointAdd(p: bigint, q: bigint): bigint;
14
+ pointMultiply(p: bigint, s: bigint): bigint;
15
+ verify(message: Buffer, signature: Buffer, publicKey: bigint): boolean;
16
+ order(): bigint;
17
+ scalarBytes: number;
18
+ pointBytes: number;
19
+ }
20
+ //# sourceMappingURL=ed25519.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ed25519.d.ts","sourceRoot":"","sources":["../../../src/curves/ed25519.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAKpC,qBAAa,YAAa,YAAW,SAAS;IAC5C,MAAM,CAAC,WAAW,UAAS;WAEd,UAAU,IAAI,OAAO,CAAC,YAAY,CAAC;IAShD,YAAY,IAAI,MAAM;IAMtB,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAI/B,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAM/B,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAM/B,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAQvC,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAQvC,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAQxC,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAMhC,QAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAQtC,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAQ3C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;IAYtE,KAAK,IAAI,MAAM;IAIf,WAAW,SAAkB;IAE7B,UAAU,SAAiB;CAC5B"}
@@ -0,0 +1,72 @@
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.Ed25519Curve = void 0;
7
+ const libsodium_wrappers_sumo_1 = __importDefault(require("libsodium-wrappers-sumo"));
8
+ const crypto_1 = require("crypto");
9
+ const util_1 = require("../util");
10
+ const privateKeySize = 32;
11
+ const publicKeySize = 32;
12
+ class Ed25519Curve {
13
+ constructor() {
14
+ this.scalarBytes = privateKeySize;
15
+ this.pointBytes = publicKeySize;
16
+ }
17
+ static async initialize() {
18
+ if (!Ed25519Curve.initialized) {
19
+ await libsodium_wrappers_sumo_1.default.ready;
20
+ Ed25519Curve.initialized = true;
21
+ }
22
+ return new Ed25519Curve();
23
+ }
24
+ scalarRandom() {
25
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_reduce((0, util_1.bigIntFromBufferLE)((0, crypto_1.randomBytes)(64)))));
26
+ }
27
+ scalarReduce(s) {
28
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_reduce((0, util_1.bigIntToBufferLE)(s, 64))));
29
+ }
30
+ scalarNegate(s) {
31
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_negate((0, util_1.bigIntToBufferLE)(s, privateKeySize))));
32
+ }
33
+ scalarInvert(s) {
34
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_invert((0, util_1.bigIntToBufferLE)(s, privateKeySize))));
35
+ }
36
+ scalarAdd(x, y) {
37
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_add((0, util_1.bigIntToBufferLE)(x, privateKeySize), (0, util_1.bigIntToBufferLE)(y, privateKeySize))));
38
+ }
39
+ scalarSub(x, y) {
40
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_sub((0, util_1.bigIntToBufferLE)(x, privateKeySize), (0, util_1.bigIntToBufferLE)(y, privateKeySize))));
41
+ }
42
+ scalarMult(x, y) {
43
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_scalar_mul((0, util_1.bigIntToBufferLE)(x, privateKeySize), (0, util_1.bigIntToBufferLE)(y, privateKeySize))));
44
+ }
45
+ basePointMult(n) {
46
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_scalarmult_ed25519_base_noclamp((0, util_1.bigIntToBufferLE)(n, privateKeySize))));
47
+ }
48
+ pointAdd(p, q) {
49
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_core_ed25519_add((0, util_1.bigIntToBufferLE)(p, publicKeySize), (0, util_1.bigIntToBufferLE)(q, publicKeySize))));
50
+ }
51
+ pointMultiply(p, s) {
52
+ return (0, util_1.bigIntFromBufferLE)(Buffer.from(libsodium_wrappers_sumo_1.default.crypto_scalarmult_ed25519_noclamp((0, util_1.bigIntToBufferLE)(s, publicKeySize), (0, util_1.bigIntToBufferLE)(p, publicKeySize))));
53
+ }
54
+ verify(message, signature, publicKey) {
55
+ const signedMessage = Buffer.concat([signature, message]);
56
+ try {
57
+ // Returns the message which was signed if the signature is valid
58
+ const result = Buffer.from(libsodium_wrappers_sumo_1.default.crypto_sign_open(signedMessage, (0, util_1.bigIntToBufferLE)(publicKey, publicKeySize)));
59
+ return Buffer.compare(message, result) === 0;
60
+ }
61
+ catch (error) {
62
+ // Invalid signature causes an exception
63
+ return false;
64
+ }
65
+ }
66
+ order() {
67
+ return BigInt('0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed') * BigInt('0x08');
68
+ }
69
+ }
70
+ exports.Ed25519Curve = Ed25519Curve;
71
+ Ed25519Curve.initialized = false;
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ed25519.js","sourceRoot":"","sources":["../../../src/curves/ed25519.ts"],"names":[],"mappings":"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","sourcesContent":["import sodium from 'libsodium-wrappers-sumo';\nimport { randomBytes } from 'crypto';\nimport { bigIntFromBufferLE, bigIntToBufferLE } from '../util';\nimport { BaseCurve } from './types';\n\nconst privateKeySize = 32;\nconst publicKeySize = 32;\n\nexport class Ed25519Curve implements BaseCurve {\n  static initialized = false;\n\n  static async initialize(): Promise<Ed25519Curve> {\n    if (!Ed25519Curve.initialized) {\n      await sodium.ready;\n      Ed25519Curve.initialized = true;\n    }\n\n    return new Ed25519Curve();\n  }\n\n  scalarRandom(): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(sodium.crypto_core_ed25519_scalar_reduce(bigIntFromBufferLE(randomBytes(64))))\n    );\n  }\n\n  scalarReduce(s: bigint): bigint {\n    return bigIntFromBufferLE(Buffer.from(sodium.crypto_core_ed25519_scalar_reduce(bigIntToBufferLE(s, 64))));\n  }\n\n  scalarNegate(s: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(sodium.crypto_core_ed25519_scalar_negate(bigIntToBufferLE(s, privateKeySize)))\n    );\n  }\n\n  scalarInvert(s: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(sodium.crypto_core_ed25519_scalar_invert(bigIntToBufferLE(s, privateKeySize)))\n    );\n  }\n\n  scalarAdd(x: bigint, y: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(\n        sodium.crypto_core_ed25519_scalar_add(bigIntToBufferLE(x, privateKeySize), bigIntToBufferLE(y, privateKeySize))\n      )\n    );\n  }\n\n  scalarSub(x: bigint, y: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(\n        sodium.crypto_core_ed25519_scalar_sub(bigIntToBufferLE(x, privateKeySize), bigIntToBufferLE(y, privateKeySize))\n      )\n    );\n  }\n\n  scalarMult(x: bigint, y: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(\n        sodium.crypto_core_ed25519_scalar_mul(bigIntToBufferLE(x, privateKeySize), bigIntToBufferLE(y, privateKeySize))\n      )\n    );\n  }\n\n  basePointMult(n: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(sodium.crypto_scalarmult_ed25519_base_noclamp(bigIntToBufferLE(n, privateKeySize)))\n    );\n  }\n\n  pointAdd(p: bigint, q: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(\n        sodium.crypto_core_ed25519_add(bigIntToBufferLE(p, publicKeySize), bigIntToBufferLE(q, publicKeySize))\n      )\n    );\n  }\n\n  pointMultiply(p: bigint, s: bigint): bigint {\n    return bigIntFromBufferLE(\n      Buffer.from(\n        sodium.crypto_scalarmult_ed25519_noclamp(bigIntToBufferLE(s, publicKeySize), bigIntToBufferLE(p, publicKeySize))\n      )\n    );\n  }\n\n  verify(message: Buffer, signature: Buffer, publicKey: bigint): boolean {\n    const signedMessage = Buffer.concat([signature, message]);\n    try {\n      // Returns the message which was signed if the signature is valid\n      const result = Buffer.from(sodium.crypto_sign_open(signedMessage, bigIntToBufferLE(publicKey, publicKeySize)));\n      return Buffer.compare(message, result) === 0;\n    } catch (error) {\n      // Invalid signature causes an exception\n      return false;\n    }\n  }\n\n  order(): bigint {\n    return BigInt('0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed') * BigInt('0x08');\n  }\n\n  scalarBytes = privateKeySize;\n\n  pointBytes = publicKeySize;\n}\n"]}
@@ -0,0 +1,10 @@
1
+ import { Ed25519Curve } from './ed25519';
2
+ import { PrivateKeychain, PublicKeychain } from './types';
3
+ export declare class Ed25519Bip32HdTree {
4
+ static curve: Ed25519Curve;
5
+ static initialized: boolean;
6
+ static initialize(): Promise<Ed25519Bip32HdTree>;
7
+ publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
8
+ privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
9
+ }
10
+ //# sourceMappingURL=ed25519Bip32HdTree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ed25519Bip32HdTree.d.ts","sourceRoot":"","sources":["../../../src/curves/ed25519Bip32HdTree.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAI1D,qBAAa,kBAAkB;IAC7B,MAAM,CAAC,KAAK,EAAE,YAAY,CAAsB;IAChD,MAAM,CAAC,WAAW,UAAS;WAEd,UAAU,IAAI,OAAO,CAAC,kBAAkB,CAAC;IAStD,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc;IAepE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe;CAqBxE"}
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Ed25519Bip32HdTree = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const util_1 = require("../util");
6
+ const ed25519_1 = require("./ed25519");
7
+ const util_2 = require("./util");
8
+ const constant_1 = require("./constant");
9
+ class Ed25519Bip32HdTree {
10
+ static async initialize() {
11
+ if (!Ed25519Bip32HdTree.initialized) {
12
+ await ed25519_1.Ed25519Curve.initialize();
13
+ Ed25519Bip32HdTree.initialized = true;
14
+ }
15
+ return new Ed25519Bip32HdTree();
16
+ }
17
+ publicDerive(keychain, path) {
18
+ const indices = (0, util_2.pathToIndices)(path);
19
+ function deriveIndex(acc, index) {
20
+ const [pk, chaincode] = acc;
21
+ const [zout, iout] = deriveEd25519Helper(index, chaincode, pk);
22
+ const zl = zout.slice(0, 32);
23
+ // left = kl + 8 * trunc28(zl)
24
+ const t = BigInt(8) * (0, util_1.bigIntFromBufferLE)(zl.slice(0, 28));
25
+ const left = Ed25519Bip32HdTree.curve.pointAdd(pk, Ed25519Bip32HdTree.curve.basePointMult(t));
26
+ return [left, (0, util_1.bigIntFromBufferBE)(iout.slice(32))];
27
+ }
28
+ const subkey = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.chaincode], indices.shift()));
29
+ return { pk: subkey[0], chaincode: subkey[1] };
30
+ }
31
+ privateDerive(keychain, path) {
32
+ const indices = (0, util_2.pathToIndices)(path);
33
+ function deriveIndex(acc, index) {
34
+ const [pk, sk, prefix, chaincode] = acc;
35
+ const [zout, iout] = deriveEd25519Helper(index, chaincode, pk, sk);
36
+ const zl = zout.slice(0, 32);
37
+ const zr = zout.slice(32);
38
+ // left = kl + 8 * trunc28(zl)
39
+ const t = BigInt(8) * (0, util_1.bigIntFromBufferLE)(zl.slice(0, 28));
40
+ const left_pk = Ed25519Bip32HdTree.curve.pointAdd(pk, Ed25519Bip32HdTree.curve.basePointMult(t));
41
+ const left_sk = Ed25519Bip32HdTree.curve.scalarAdd(sk, t);
42
+ // right = zr + kr
43
+ const right = (prefix + (0, util_1.bigIntFromBufferBE)(zr)) % constant_1.chaincodeBase;
44
+ return [left_pk, left_sk, right, (0, util_1.bigIntFromBufferBE)(iout.slice(32))];
45
+ }
46
+ const [pk, sk, prefix, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.sk, keychain.prefix, keychain.chaincode], indices.shift()));
47
+ return { pk, sk, prefix, chaincode };
48
+ }
49
+ }
50
+ exports.Ed25519Bip32HdTree = Ed25519Bip32HdTree;
51
+ Ed25519Bip32HdTree.curve = new ed25519_1.Ed25519Curve();
52
+ Ed25519Bip32HdTree.initialized = false;
53
+ function deriveEd25519Helper(index = 0, chaincode, pk, sk) {
54
+ const zmac = (0, crypto_1.createHmac)('sha512', (0, util_1.bigIntToBufferBE)(chaincode, 32));
55
+ const imac = (0, crypto_1.createHmac)('sha512', (0, util_1.bigIntToBufferBE)(chaincode, 32));
56
+ const seri = Buffer.alloc(4);
57
+ seri.writeUInt32LE(index, 0);
58
+ if (((index >>> 0) & 0x80000000) === 0) {
59
+ // Normal derivation:
60
+ // Z = HMAC-SHA512(Key = cpar, Data = 0x02 || serP(point(kpar)) || ser32(i)).
61
+ // I = HMAC-SHA512(Key = cpar, Data = 0x03 || serP(point(kpar)) || ser32(i)).
62
+ zmac.update('\x02');
63
+ zmac.update((0, util_1.bigIntToBufferLE)(pk, 32));
64
+ zmac.update(seri);
65
+ imac.update('\x03');
66
+ imac.update((0, util_1.bigIntToBufferLE)(pk, 32));
67
+ imac.update(seri);
68
+ }
69
+ else {
70
+ if (sk === undefined) {
71
+ throw new Error("Can't performed hardened derivation without private key");
72
+ }
73
+ // Hardened derivation:
74
+ // Z = HMAC-SHA512(Key = cpar, Data = 0x00 || ser256(left(kpar)) || ser32(i)).
75
+ // I = HMAC-SHA512(Key = cpar, Data = 0x01 || ser256(left(kpar)) || ser32(i)).
76
+ zmac.update('\x00');
77
+ zmac.update((0, util_1.bigIntToBufferLE)(sk, 32));
78
+ zmac.update(seri);
79
+ imac.update('\x01');
80
+ imac.update((0, util_1.bigIntToBufferLE)(sk, 32));
81
+ imac.update(seri);
82
+ }
83
+ return [zmac.digest(), imac.digest()];
84
+ }
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ed25519Bip32HdTree.js","sourceRoot":"","sources":["../../../src/curves/ed25519Bip32HdTree.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHmac } from 'crypto';\nimport { bigIntFromBufferBE, bigIntFromBufferLE, bigIntToBufferBE, bigIntToBufferLE } from '../util';\nimport { Ed25519Curve } from './ed25519';\nimport { PrivateKeychain, PublicKeychain } from './types';\nimport { pathToIndices } from './util';\nimport { chaincodeBase } from './constant';\n\nexport class Ed25519Bip32HdTree {\n  static curve: Ed25519Curve = new Ed25519Curve();\n  static initialized = false;\n\n  static async initialize(): Promise<Ed25519Bip32HdTree> {\n    if (!Ed25519Bip32HdTree.initialized) {\n      await Ed25519Curve.initialize();\n      Ed25519Bip32HdTree.initialized = true;\n    }\n\n    return new Ed25519Bip32HdTree();\n  }\n\n  publicDerive(keychain: PublicKeychain, path: string): PublicKeychain {\n    const indices = pathToIndices(path);\n    function deriveIndex(acc: bigint[], index: number | undefined): bigint[] {\n      const [pk, chaincode] = acc;\n      const [zout, iout] = deriveEd25519Helper(index, chaincode, pk);\n      const zl = zout.slice(0, 32);\n      // left = kl + 8 * trunc28(zl)\n      const t = BigInt(8) * bigIntFromBufferLE(zl.slice(0, 28));\n      const left = Ed25519Bip32HdTree.curve.pointAdd(pk, Ed25519Bip32HdTree.curve.basePointMult(t));\n      return [left, bigIntFromBufferBE(iout.slice(32))];\n    }\n    const subkey = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.chaincode], indices.shift()));\n    return { pk: subkey[0], chaincode: subkey[1] };\n  }\n\n  privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain {\n    const indices = pathToIndices(path);\n    function deriveIndex(acc: bigint[], index: number | undefined): bigint[] {\n      const [pk, sk, prefix, chaincode] = acc;\n      const [zout, iout] = deriveEd25519Helper(index, chaincode, pk, sk);\n      const zl = zout.slice(0, 32);\n      const zr = zout.slice(32);\n      // left = kl + 8 * trunc28(zl)\n      const t = BigInt(8) * bigIntFromBufferLE(zl.slice(0, 28));\n      const left_pk = Ed25519Bip32HdTree.curve.pointAdd(pk, Ed25519Bip32HdTree.curve.basePointMult(t));\n      const left_sk = Ed25519Bip32HdTree.curve.scalarAdd(sk, t);\n      // right = zr + kr\n      const right = (prefix + bigIntFromBufferBE(zr)) % chaincodeBase;\n      return [left_pk, left_sk, right, bigIntFromBufferBE(iout.slice(32))];\n    }\n    const [pk, sk, prefix, chaincode] = indices.reduce(\n      deriveIndex,\n      deriveIndex([keychain.pk, keychain.sk, keychain.prefix!, keychain.chaincode], indices.shift())\n    );\n    return { pk, sk, prefix, chaincode };\n  }\n}\n\nfunction deriveEd25519Helper(index: number | undefined = 0, chaincode: bigint, pk: bigint, sk?: bigint): Buffer[] {\n  const zmac = createHmac('sha512', bigIntToBufferBE(chaincode, 32));\n  const imac = createHmac('sha512', bigIntToBufferBE(chaincode, 32));\n  const seri = Buffer.alloc(4);\n  seri.writeUInt32LE(index, 0);\n  if (((index >>> 0) & 0x80000000) === 0) {\n    // Normal derivation:\n    // Z = HMAC-SHA512(Key = cpar, Data = 0x02 || serP(point(kpar)) || ser32(i)).\n    // I = HMAC-SHA512(Key = cpar, Data = 0x03 || serP(point(kpar)) || ser32(i)).\n    zmac.update('\\x02');\n    zmac.update(bigIntToBufferLE(pk, 32));\n    zmac.update(seri);\n    imac.update('\\x03');\n    imac.update(bigIntToBufferLE(pk, 32));\n    imac.update(seri);\n  } else {\n    if (sk === undefined) {\n      throw new Error(\"Can't performed hardened derivation without private key\");\n    }\n    // Hardened derivation:\n    // Z = HMAC-SHA512(Key = cpar, Data = 0x00 || ser256(left(kpar)) || ser32(i)).\n    // I = HMAC-SHA512(Key = cpar, Data = 0x01 || ser256(left(kpar)) || ser32(i)).\n    zmac.update('\\x00');\n    zmac.update(bigIntToBufferLE(sk, 32));\n    zmac.update(seri);\n    imac.update('\\x01');\n    imac.update(bigIntToBufferLE(sk, 32));\n    imac.update(seri);\n  }\n  return [zmac.digest(), imac.digest()];\n}\n"]}
@@ -1,3 +1,8 @@
1
- import curve from './baseCurve';
2
- export default curve;
1
+ export * from './types';
2
+ export * from './util';
3
+ export * from './constant';
4
+ export * from './secp256k1';
5
+ export * from './secp256k1Bip32HdTree';
6
+ export * from './ed25519';
7
+ export * from './ed25519Bip32HdTree';
3
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/curves/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,aAAa,CAAC;AAChC,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/curves/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,wBAAwB,CAAC;AACvC,cAAc,WAAW,CAAC;AAC1B,cAAc,sBAAsB,CAAC"}
@@ -1,3 +1,24 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
2
16
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VydmVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY3VydmUgZnJvbSAnLi9iYXNlQ3VydmUnO1xuZXhwb3J0IGRlZmF1bHQgY3VydmU7XG4iXX0=
17
+ __exportStar(require("./types"), exports);
18
+ __exportStar(require("./util"), exports);
19
+ __exportStar(require("./constant"), exports);
20
+ __exportStar(require("./secp256k1"), exports);
21
+ __exportStar(require("./secp256k1Bip32HdTree"), exports);
22
+ __exportStar(require("./ed25519"), exports);
23
+ __exportStar(require("./ed25519Bip32HdTree"), exports);
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VydmVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDZDQUEyQjtBQUMzQiw4Q0FBNEI7QUFDNUIseURBQXVDO0FBQ3ZDLDRDQUEwQjtBQUMxQix1REFBcUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0YW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VjcDI1NmsxJztcbmV4cG9ydCAqIGZyb20gJy4vc2VjcDI1NmsxQmlwMzJIZFRyZWUnO1xuZXhwb3J0ICogZnJvbSAnLi9lZDI1NTE5JztcbmV4cG9ydCAqIGZyb20gJy4vZWQyNTUxOUJpcDMySGRUcmVlJztcbiJdfQ==
@@ -1,20 +1,18 @@
1
- /**
2
- * Base Interface for supporting elliptic curve parameters
3
- */
4
- /// <reference types="node" />
5
- interface BaseCurve {
6
- scalarReduce(s: bigint): bigint;
7
- scalarNegate(s: bigint): bigint;
8
- scalarInvert(s: bigint): bigint;
1
+ import { BaseCurve } from './types';
2
+ export declare class Secp256k1Curve implements BaseCurve {
9
3
  scalarRandom(): bigint;
10
4
  scalarAdd(x: bigint, y: bigint): bigint;
11
5
  scalarSub(x: bigint, y: bigint): bigint;
12
6
  scalarMult(x: bigint, y: bigint): bigint;
13
- basePointMult(n: bigint): bigint;
14
- pointAdd(p: bigint, q: bigint): bigint;
7
+ scalarReduce(s: bigint): bigint;
8
+ scalarNegate(s: bigint): bigint;
9
+ scalarInvert(s: bigint): bigint;
10
+ pointAdd(a: bigint, b: bigint): bigint;
15
11
  pointMultiply(p: bigint, s: bigint): bigint;
12
+ basePointMult(n: bigint): bigint;
16
13
  verify(message: Buffer, signature: Buffer, publicKey: bigint): boolean;
17
- order: () => bigint;
14
+ order(): bigint;
15
+ scalarBytes: number;
16
+ pointBytes: number;
18
17
  }
19
- export default BaseCurve;
20
- //# sourceMappingURL=baseCurve.d.ts.map
18
+ //# sourceMappingURL=secp256k1.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"secp256k1.d.ts","sourceRoot":"","sources":["../../../src/curves/secp256k1.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAQpC,qBAAa,cAAe,YAAW,SAAS;IAC9C,YAAY,IAAI,MAAM;IAItB,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAIvC,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAKvC,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAIxC,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAI/B,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAI/B,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAI/B,QAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAMtC,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM;IAK3C,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAKhC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;IAMtE,KAAK,IAAI,MAAM;IAIf,WAAW,SAAkB;IAG7B,UAAU,SAAiB;CAC5B"}
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Secp256k1Curve = void 0;
4
+ const util_1 = require("../util");
5
+ const secp256k1_1 = require("@noble/curves/secp256k1");
6
+ const modular_1 = require("@noble/curves/abstract/modular");
7
+ const order = secp256k1_1.secp256k1.CURVE.n;
8
+ const privateKeySize = 32;
9
+ const publicKeySize = 33;
10
+ class Secp256k1Curve {
11
+ constructor() {
12
+ this.scalarBytes = privateKeySize;
13
+ // Always use compressed points.
14
+ this.pointBytes = publicKeySize;
15
+ }
16
+ scalarRandom() {
17
+ return (0, util_1.bigIntFromU8ABE)(secp256k1_1.secp256k1.utils.randomPrivateKey());
18
+ }
19
+ scalarAdd(x, y) {
20
+ return (0, modular_1.mod)(x + y, order);
21
+ }
22
+ scalarSub(x, y) {
23
+ const negatedY = order - y;
24
+ return (0, modular_1.mod)(x + negatedY, order);
25
+ }
26
+ scalarMult(x, y) {
27
+ return (0, modular_1.mod)(x * y, order);
28
+ }
29
+ scalarReduce(s) {
30
+ return (0, modular_1.mod)(s, order);
31
+ }
32
+ scalarNegate(s) {
33
+ return order - s;
34
+ }
35
+ scalarInvert(s) {
36
+ return (0, modular_1.invert)(s, order);
37
+ }
38
+ pointAdd(a, b) {
39
+ const pointA = secp256k1_1.secp256k1.ProjectivePoint.fromHex((0, util_1.bigIntToBufferBE)(a, privateKeySize));
40
+ const pointB = secp256k1_1.secp256k1.ProjectivePoint.fromHex((0, util_1.bigIntToBufferBE)(b, privateKeySize));
41
+ return (0, util_1.bigIntFromU8ABE)(pointA.add(pointB).toRawBytes(true));
42
+ }
43
+ pointMultiply(p, s) {
44
+ const pointA = secp256k1_1.secp256k1.ProjectivePoint.fromHex((0, util_1.bigIntToBufferBE)(p, privateKeySize));
45
+ return (0, util_1.bigIntFromU8ABE)(pointA.multiply(s).toRawBytes(true));
46
+ }
47
+ basePointMult(n) {
48
+ const point = (0, util_1.bigIntToBufferBE)(n, privateKeySize);
49
+ return (0, util_1.bigIntFromU8ABE)(secp256k1_1.secp256k1.getPublicKey(point, true));
50
+ }
51
+ verify(message, signature, publicKey) {
52
+ const sig = secp256k1_1.secp256k1.Signature.fromCompact(Buffer.from(signature.subarray(1))).addRecoveryBit(signature[0]);
53
+ const pubFromSig = sig.recoverPublicKey(message).toRawBytes(true);
54
+ return Buffer.from(pubFromSig).equals((0, util_1.bigIntToBufferBE)(publicKey, publicKeySize));
55
+ }
56
+ order() {
57
+ return order;
58
+ }
59
+ }
60
+ exports.Secp256k1Curve = Secp256k1Curve;
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcDI1NmsxLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2N1cnZlcy9zZWNwMjU2azEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsa0NBQTREO0FBRTVELHVEQUE0RDtBQUM1RCw0REFBNkQ7QUFFN0QsTUFBTSxLQUFLLEdBQUcscUJBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0FBQzNCLE1BQU0sY0FBYyxHQUFHLEVBQUUsQ0FBQztBQUMxQixNQUFNLGFBQWEsR0FBRyxFQUFFLENBQUM7QUFFekIsTUFBYSxjQUFjO0lBQTNCO1FBd0RFLGdCQUFXLEdBQUcsY0FBYyxDQUFDO1FBRTdCLGdDQUFnQztRQUNoQyxlQUFVLEdBQUcsYUFBYSxDQUFDO0lBQzdCLENBQUM7SUEzREMsWUFBWTtRQUNWLE9BQU8sSUFBQSxzQkFBZSxFQUFDLHFCQUFJLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBRUQsU0FBUyxDQUFDLENBQVMsRUFBRSxDQUFTO1FBQzVCLE9BQU8sSUFBQSxhQUFHLEVBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsU0FBUyxDQUFDLENBQVMsRUFBRSxDQUFTO1FBQzVCLE1BQU0sUUFBUSxHQUFHLEtBQUssR0FBRyxDQUFDLENBQUM7UUFDM0IsT0FBTyxJQUFBLGFBQUcsRUFBQyxDQUFDLEdBQUcsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxVQUFVLENBQUMsQ0FBUyxFQUFFLENBQVM7UUFDN0IsT0FBTyxJQUFBLGFBQUcsRUFBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxZQUFZLENBQUMsQ0FBUztRQUNwQixPQUFPLElBQUEsYUFBRyxFQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2QixDQUFDO0lBRUQsWUFBWSxDQUFDLENBQVM7UUFDcEIsT0FBTyxLQUFLLEdBQUcsQ0FBQyxDQUFDO0lBQ25CLENBQUM7SUFFRCxZQUFZLENBQUMsQ0FBUztRQUNwQixPQUFPLElBQUEsZ0JBQU0sRUFBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELFFBQVEsQ0FBQyxDQUFTLEVBQUUsQ0FBUztRQUMzQixNQUFNLE1BQU0sR0FBRyxxQkFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsSUFBQSx1QkFBZ0IsRUFBQyxDQUFDLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztRQUNqRixNQUFNLE1BQU0sR0FBRyxxQkFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsSUFBQSx1QkFBZ0IsRUFBQyxDQUFDLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztRQUNqRixPQUFPLElBQUEsc0JBQWUsRUFBQyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxhQUFhLENBQUMsQ0FBUyxFQUFFLENBQVM7UUFDaEMsTUFBTSxNQUFNLEdBQUcscUJBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLElBQUEsdUJBQWdCLEVBQUMsQ0FBQyxFQUFFLGNBQWMsQ0FBQyxDQUFDLENBQUM7UUFDakYsT0FBTyxJQUFBLHNCQUFlLEVBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsYUFBYSxDQUFDLENBQVM7UUFDckIsTUFBTSxLQUFLLEdBQUcsSUFBQSx1QkFBZ0IsRUFBQyxDQUFDLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDbEQsT0FBTyxJQUFBLHNCQUFlLEVBQUMscUJBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELE1BQU0sQ0FBQyxPQUFlLEVBQUUsU0FBaUIsRUFBRSxTQUFpQjtRQUMxRCxNQUFNLEdBQUcsR0FBRyxxQkFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEcsTUFBTSxVQUFVLEdBQUcsR0FBRyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsRSxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUEsdUJBQWdCLEVBQUMsU0FBUyxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUVELEtBQUs7UUFDSCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7Q0FNRjtBQTVERCx3Q0E0REMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBiaWdJbnRGcm9tVThBQkUsIGJpZ0ludFRvQnVmZmVyQkUgfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7IEJhc2VDdXJ2ZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgc2VjcDI1NmsxIGFzIHNlY3AgfSBmcm9tICdAbm9ibGUvY3VydmVzL3NlY3AyNTZrMSc7XG5pbXBvcnQgeyBtb2QsIGludmVydCB9IGZyb20gJ0Bub2JsZS9jdXJ2ZXMvYWJzdHJhY3QvbW9kdWxhcic7XG5cbmNvbnN0IG9yZGVyID0gc2VjcC5DVVJWRS5uO1xuY29uc3QgcHJpdmF0ZUtleVNpemUgPSAzMjtcbmNvbnN0IHB1YmxpY0tleVNpemUgPSAzMztcblxuZXhwb3J0IGNsYXNzIFNlY3AyNTZrMUN1cnZlIGltcGxlbWVudHMgQmFzZUN1cnZlIHtcbiAgc2NhbGFyUmFuZG9tKCk6IGJpZ2ludCB7XG4gICAgcmV0dXJuIGJpZ0ludEZyb21VOEFCRShzZWNwLnV0aWxzLnJhbmRvbVByaXZhdGVLZXkoKSk7XG4gIH1cblxuICBzY2FsYXJBZGQoeDogYmlnaW50LCB5OiBiaWdpbnQpOiBiaWdpbnQge1xuICAgIHJldHVybiBtb2QoeCArIHksIG9yZGVyKTtcbiAgfVxuXG4gIHNjYWxhclN1Yih4OiBiaWdpbnQsIHk6IGJpZ2ludCk6IGJpZ2ludCB7XG4gICAgY29uc3QgbmVnYXRlZFkgPSBvcmRlciAtIHk7XG4gICAgcmV0dXJuIG1vZCh4ICsgbmVnYXRlZFksIG9yZGVyKTtcbiAgfVxuXG4gIHNjYWxhck11bHQoeDogYmlnaW50LCB5OiBiaWdpbnQpOiBiaWdpbnQge1xuICAgIHJldHVybiBtb2QoeCAqIHksIG9yZGVyKTtcbiAgfVxuXG4gIHNjYWxhclJlZHVjZShzOiBiaWdpbnQpOiBiaWdpbnQge1xuICAgIHJldHVybiBtb2Qocywgb3JkZXIpO1xuICB9XG5cbiAgc2NhbGFyTmVnYXRlKHM6IGJpZ2ludCk6IGJpZ2ludCB7XG4gICAgcmV0dXJuIG9yZGVyIC0gcztcbiAgfVxuXG4gIHNjYWxhckludmVydChzOiBiaWdpbnQpOiBiaWdpbnQge1xuICAgIHJldHVybiBpbnZlcnQocywgb3JkZXIpO1xuICB9XG5cbiAgcG9pbnRBZGQoYTogYmlnaW50LCBiOiBiaWdpbnQpOiBiaWdpbnQge1xuICAgIGNvbnN0IHBvaW50QSA9IHNlY3AuUHJvamVjdGl2ZVBvaW50LmZyb21IZXgoYmlnSW50VG9CdWZmZXJCRShhLCBwcml2YXRlS2V5U2l6ZSkpO1xuICAgIGNvbnN0IHBvaW50QiA9IHNlY3AuUHJvamVjdGl2ZVBvaW50LmZyb21IZXgoYmlnSW50VG9CdWZmZXJCRShiLCBwcml2YXRlS2V5U2l6ZSkpO1xuICAgIHJldHVybiBiaWdJbnRGcm9tVThBQkUocG9pbnRBLmFkZChwb2ludEIpLnRvUmF3Qnl0ZXModHJ1ZSkpO1xuICB9XG5cbiAgcG9pbnRNdWx0aXBseShwOiBiaWdpbnQsIHM6IGJpZ2ludCk6IGJpZ2ludCB7XG4gICAgY29uc3QgcG9pbnRBID0gc2VjcC5Qcm9qZWN0aXZlUG9pbnQuZnJvbUhleChiaWdJbnRUb0J1ZmZlckJFKHAsIHByaXZhdGVLZXlTaXplKSk7XG4gICAgcmV0dXJuIGJpZ0ludEZyb21VOEFCRShwb2ludEEubXVsdGlwbHkocykudG9SYXdCeXRlcyh0cnVlKSk7XG4gIH1cblxuICBiYXNlUG9pbnRNdWx0KG46IGJpZ2ludCk6IGJpZ2ludCB7XG4gICAgY29uc3QgcG9pbnQgPSBiaWdJbnRUb0J1ZmZlckJFKG4sIHByaXZhdGVLZXlTaXplKTtcbiAgICByZXR1cm4gYmlnSW50RnJvbVU4QUJFKHNlY3AuZ2V0UHVibGljS2V5KHBvaW50LCB0cnVlKSk7XG4gIH1cblxuICB2ZXJpZnkobWVzc2FnZTogQnVmZmVyLCBzaWduYXR1cmU6IEJ1ZmZlciwgcHVibGljS2V5OiBiaWdpbnQpOiBib29sZWFuIHtcbiAgICBjb25zdCBzaWcgPSBzZWNwLlNpZ25hdHVyZS5mcm9tQ29tcGFjdChCdWZmZXIuZnJvbShzaWduYXR1cmUuc3ViYXJyYXkoMSkpKS5hZGRSZWNvdmVyeUJpdChzaWduYXR1cmVbMF0pO1xuICAgIGNvbnN0IHB1YkZyb21TaWcgPSBzaWcucmVjb3ZlclB1YmxpY0tleShtZXNzYWdlKS50b1Jhd0J5dGVzKHRydWUpO1xuICAgIHJldHVybiBCdWZmZXIuZnJvbShwdWJGcm9tU2lnKS5lcXVhbHMoYmlnSW50VG9CdWZmZXJCRShwdWJsaWNLZXksIHB1YmxpY0tleVNpemUpKTtcbiAgfVxuXG4gIG9yZGVyKCk6IGJpZ2ludCB7XG4gICAgcmV0dXJuIG9yZGVyO1xuICB9XG5cbiAgc2NhbGFyQnl0ZXMgPSBwcml2YXRlS2V5U2l6ZTtcblxuICAvLyBBbHdheXMgdXNlIGNvbXByZXNzZWQgcG9pbnRzLlxuICBwb2ludEJ5dGVzID0gcHVibGljS2V5U2l6ZTtcbn1cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ import { PrivateKeychain, PublicKeychain } from './types';
2
+ import { Secp256k1Curve } from './secp256k1';
3
+ export declare class Secp256k1Bip32HdTree {
4
+ static curve: Secp256k1Curve;
5
+ publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
6
+ privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
7
+ }
8
+ //# sourceMappingURL=secp256k1Bip32HdTree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"secp256k1Bip32HdTree.d.ts","sourceRoot":"","sources":["../../../src/curves/secp256k1Bip32HdTree.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAI7C,qBAAa,oBAAoB;IAC/B,MAAM,CAAC,KAAK,EAAE,cAAc,CAAwB;IAEpD,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc;IAiBpE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe;CAiBxE"}
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Secp256k1Bip32HdTree = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const secp256k1_1 = require("./secp256k1");
6
+ const util_1 = require("../util");
7
+ const util_2 = require("./util");
8
+ class Secp256k1Bip32HdTree {
9
+ publicDerive(keychain, path) {
10
+ const indices = (0, util_2.pathToIndices)(path);
11
+ function deriveIndex(acc, index) {
12
+ const [pk, chaincode] = acc;
13
+ const I = deriveSecp256k1Helper(index, chaincode, pk);
14
+ const il = (0, util_1.bigIntFromBufferBE)(I.slice(0, 32));
15
+ const ir = (0, util_1.bigIntFromBufferBE)(I.slice(32));
16
+ const left_pk = Secp256k1Bip32HdTree.curve.pointAdd(pk, Secp256k1Bip32HdTree.curve.basePointMult(il));
17
+ return [left_pk, ir];
18
+ }
19
+ const [pk, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.chaincode], indices.shift()));
20
+ return { pk, chaincode };
21
+ }
22
+ privateDerive(keychain, path) {
23
+ const indices = (0, util_2.pathToIndices)(path);
24
+ function deriveIndex(acc, index) {
25
+ const [pk, sk, chaincode] = acc;
26
+ const I = deriveSecp256k1Helper(index, chaincode, pk, sk);
27
+ const il = (0, util_1.bigIntFromBufferBE)(I.slice(0, 32));
28
+ const ir = (0, util_1.bigIntFromBufferBE)(I.slice(32));
29
+ const left_pk = Secp256k1Bip32HdTree.curve.pointAdd(pk, Secp256k1Bip32HdTree.curve.basePointMult(il));
30
+ const left_sk = Secp256k1Bip32HdTree.curve.scalarAdd(sk, il);
31
+ return [left_pk, left_sk, ir];
32
+ }
33
+ const [pk, sk, chaincode] = indices.reduce(deriveIndex, deriveIndex([keychain.pk, keychain.sk, keychain.chaincode], indices.shift()));
34
+ return { pk, sk, chaincode };
35
+ }
36
+ }
37
+ exports.Secp256k1Bip32HdTree = Secp256k1Bip32HdTree;
38
+ Secp256k1Bip32HdTree.curve = new secp256k1_1.Secp256k1Curve();
39
+ function deriveSecp256k1Helper(index = 0, chaincode, pk, sk) {
40
+ const data = Buffer.alloc(33 + 4);
41
+ if (((index >>> 0) & 0x80000000) === 0) {
42
+ (0, util_1.bigIntToBufferBE)(pk, 33).copy(data);
43
+ }
44
+ else {
45
+ if (sk === undefined) {
46
+ throw new Error("Can't performed hardened derivation without private key");
47
+ }
48
+ data[0] = 0;
49
+ (0, util_1.bigIntToBufferBE)(sk, 32).copy(data, 1);
50
+ }
51
+ data.writeUInt32BE(index, 33);
52
+ return (0, crypto_1.createHmac)('sha512', (0, util_1.bigIntToBufferBE)(chaincode, 32)).update(data).digest();
53
+ }
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcDI1NmsxQmlwMzJIZFRyZWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VydmVzL3NlY3AyNTZrMUJpcDMySGRUcmVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1DQUFvQztBQUdwQywyQ0FBNkM7QUFDN0Msa0NBQStEO0FBQy9ELGlDQUF1QztBQUV2QyxNQUFhLG9CQUFvQjtJQUcvQixZQUFZLENBQUMsUUFBd0IsRUFBRSxJQUFZO1FBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUEsb0JBQWEsRUFBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxTQUFTLFdBQVcsQ0FBQyxHQUFhLEVBQUUsS0FBeUI7WUFDM0QsTUFBTSxDQUFDLEVBQUUsRUFBRSxTQUFTLENBQUMsR0FBRyxHQUFHLENBQUM7WUFDNUIsTUFBTSxDQUFDLEdBQUcscUJBQXFCLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUN0RCxNQUFNLEVBQUUsR0FBRyxJQUFBLHlCQUFrQixFQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDOUMsTUFBTSxFQUFFLEdBQUcsSUFBQSx5QkFBa0IsRUFBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDM0MsTUFBTSxPQUFPLEdBQUcsb0JBQW9CLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsb0JBQW9CLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3RHLE9BQU8sQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDdkIsQ0FBQztRQUNELE1BQU0sQ0FBQyxFQUFFLEVBQUUsU0FBUyxDQUFDLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FDcEMsV0FBVyxFQUNYLFdBQVcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsUUFBUSxD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LENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVIbWFjIH0gZnJvbSAnY3J5cHRvJztcblxuaW1wb3J0IHsgUHJpdmF0ZUtleWNoYWluLCBQdWJsaWNLZXljaGFpbiB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgU2VjcDI1NmsxQ3VydmUgfSBmcm9tICcuL3NlY3AyNTZrMSc7XG5pbXBvcnQgeyBiaWdJbnRGcm9tQnVmZmVyQkUsIGJpZ0ludFRvQnVmZmVyQkUgfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7IHBhdGhUb0luZGljZXMgfSBmcm9tICcuL3V0aWwnO1xuXG5leHBvcnQgY2xhc3MgU2VjcDI1NmsxQmlwMzJIZFRyZWUge1xuICBzdGF0aWMgY3VydmU6IFNlY3AyNTZrMUN1cnZlID0gbmV3IFNlY3AyNTZrMUN1cnZlKCk7XG5cbiAgcHVibGljRGVyaXZlKGtleWNoYWluOiBQdWJsaWNLZXljaGFpbiwgcGF0aDogc3RyaW5nKTogUHVibGljS2V5Y2hhaW4ge1xuICAgIGNvbnN0IGluZGljZXMgPSBwYXRoVG9JbmRpY2VzKHBhdGgpO1xuICAgIGZ1bmN0aW9uIGRlcml2ZUluZGV4KGFjYzogYmlnaW50W10sIGluZGV4OiBudW1iZXIgfCB1bmRlZmluZWQpOiBiaWdpbnRbXSB7XG4gICAgICBjb25zdCBbcGssIGNoYWluY29kZV0gPSBhY2M7XG4gICAgICBjb25zdCBJID0gZGVyaXZlU2VjcDI1NmsxSGVscGVyKGluZGV4LCBjaGFpbmNvZGUsIHBrKTtcbiAgICAgIGNvbnN0IGlsID0gYmlnSW50RnJvbUJ1ZmZlckJFKEkuc2xpY2UoMCwgMzIpKTtcbiAgICAgIGNvbnN0IGlyID0gYmlnSW50RnJvbUJ1ZmZlckJFKEkuc2xpY2UoMzIpKTtcbiAgICAgIGNvbnN0IGxlZnRfcGsgPSBTZWNwMjU2azFCaXAzMkhkVHJlZS5jdXJ2ZS5wb2ludEFkZChwaywgU2VjcDI1NmsxQmlwMzJIZFRyZWUuY3VydmUuYmFzZVBvaW50TXVsdChpbCkpO1xuICAgICAgcmV0dXJuIFtsZWZ0X3BrLCBpcl07XG4gICAgfVxuICAgIGNvbnN0IFtwaywgY2hhaW5jb2RlXSA9IGluZGljZXMucmVkdWNlKFxuICAgICAgZGVyaXZlSW5kZXgsXG4gICAgICBkZXJpdmVJbmRleChba2V5Y2hhaW4ucGssIGtleWNoYWluLmNoYWluY29kZV0sIGluZGljZXMuc2hpZnQoKSlcbiAgICApO1xuICAgIHJldHVybiB7IHBrLCBjaGFpbmNvZGUgfTtcbiAgfVxuXG4gIHByaXZhdGVEZXJpdmUoa2V5Y2hhaW46IFByaXZhdGVLZXljaGFpbiwgcGF0aDogc3RyaW5nKTogUHJpdmF0ZUtleWNoYWluIHtcbiAgICBjb25zdCBpbmRpY2VzID0gcGF0aFRvSW5kaWNlcyhwYXRoKTtcbiAgICBmdW5jdGlvbiBkZXJpdmVJbmRleChhY2M6IGJpZ2ludFtdLCBpbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkKTogYmlnaW50W10ge1xuICAgICAgY29uc3QgW3BrLCBzaywgY2hhaW5jb2RlXSA9IGFjYztcbiAgICAgIGNvbnN0IEkgPSBkZXJpdmVTZWNwMjU2azFIZWxwZXIoaW5kZXgsIGNoYWluY29kZSwgcGssIHNrKTtcbiAgICAgIGNvbnN0IGlsID0gYmlnSW50RnJvbUJ1ZmZlckJFKEkuc2xpY2UoMCwgMzIpKTtcbiAgICAgIGNvbnN0IGlyID0gYmlnSW50RnJvbUJ1ZmZlckJFKEkuc2xpY2UoMzIpKTtcbiAgICAgIGNvbnN0IGxlZnRfcGsgPSBTZWNwMjU2azFCaXAzMkhkVHJlZS5jdXJ2ZS5wb2ludEFkZChwaywgU2VjcDI1NmsxQmlwMzJIZFRyZWUuY3VydmUuYmFzZVBvaW50TXVsdChpbCkpO1xuICAgICAgY29uc3QgbGVmdF9zayA9IFNlY3AyNTZrMUJpcDMySGRUcmVlLmN1cnZlLnNjYWxhckFkZChzaywgaWwpO1xuICAgICAgcmV0dXJuIFtsZWZ0X3BrLCBsZWZ0X3NrLCBpcl07XG4gICAgfVxuICAgIGNvbnN0IFtwaywgc2ssIGNoYWluY29kZV0gPSBpbmRpY2VzLnJlZHVjZShcbiAgICAgIGRlcml2ZUluZGV4LFxuICAgICAgZGVyaXZlSW5kZXgoW2tleWNoYWluLnBrLCBrZXljaGFpbi5zaywga2V5Y2hhaW4uY2hhaW5jb2RlXSwgaW5kaWNlcy5zaGlmdCgpKVxuICAgICk7XG4gICAgcmV0dXJuIHsgcGssIHNrLCBjaGFpbmNvZGUgfTtcbiAgfVxufVxuXG5mdW5jdGlvbiBkZXJpdmVTZWNwMjU2azFIZWxwZXIoaW5kZXg6IG51bWJlciB8IHVuZGVmaW5lZCA9IDAsIGNoYWluY29kZTogYmlnaW50LCBwazogYmlnaW50LCBzaz86IGJpZ2ludCk6IEJ1ZmZlciB7XG4gIGNvbnN0IGRhdGEgPSBCdWZmZXIuYWxsb2MoMzMgKyA0KTtcbiAgaWYgKCgoaW5kZXggPj4+IDApICYgMHg4MDAwMDAwMCkgPT09IDApIHtcbiAgICBiaWdJbnRUb0J1ZmZlckJFKHBrLCAzMykuY29weShkYXRhKTtcbiAgfSBlbHNlIHtcbiAgICBpZiAoc2sgPT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiQ2FuJ3QgcGVyZm9ybWVkIGhhcmRlbmVkIGRlcml2YXRpb24gd2l0aG91dCBwcml2YXRlIGtleVwiKTtcbiAgICB9XG4gICAgZGF0YVswXSA9IDA7XG4gICAgYmlnSW50VG9CdWZmZXJCRShzaywgMzIpLmNvcHkoZGF0YSwgMSk7XG4gIH1cbiAgZGF0YS53cml0ZVVJbnQzMkJFKGluZGV4LCAzMyk7XG4gIHJldHVybiBjcmVhdGVIbWFjKCdzaGE1MTInLCBiaWdJbnRUb0J1ZmZlckJFKGNoYWluY29kZSwgMzIpKS51cGRhdGUoZGF0YSkuZGlnZXN0KCk7XG59XG4iXX0=
@@ -0,0 +1,35 @@
1
+ export type PublicKeychain = {
2
+ pk: bigint;
3
+ chaincode: bigint;
4
+ };
5
+ export type PrivateKeychain = PublicKeychain & {
6
+ sk: bigint;
7
+ prefix?: bigint;
8
+ };
9
+ /**
10
+ * An interface for calculating a subkey in an HD key scheme.
11
+ */
12
+ export interface HDTree {
13
+ publicDerive(keychain: PublicKeychain, path: string): PublicKeychain;
14
+ privateDerive(keychain: PrivateKeychain, path: string): PrivateKeychain;
15
+ }
16
+ /**
17
+ * Base Interface for supporting elliptic curve parameters
18
+ */
19
+ export interface BaseCurve {
20
+ scalarReduce(s: bigint): bigint;
21
+ scalarNegate(s: bigint): bigint;
22
+ scalarInvert(s: bigint): bigint;
23
+ scalarRandom(): bigint;
24
+ scalarAdd(x: bigint, y: bigint): bigint;
25
+ scalarSub(x: bigint, y: bigint): bigint;
26
+ scalarMult(x: bigint, y: bigint): bigint;
27
+ basePointMult(n: bigint): bigint;
28
+ pointAdd(p: bigint, q: bigint): bigint;
29
+ pointMultiply(p: bigint, s: bigint): bigint;
30
+ verify(message: Buffer, signature: Buffer, publicKey: bigint): boolean;
31
+ order: () => bigint;
32
+ scalarBytes: number;
33
+ pointBytes: number;
34
+ }
35
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/curves/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG;IAE3B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,cAAc,GAAG;IAE7C,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,YAAY,CAAC,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,GAAG,cAAc,CAAC;IAErE,aAAa,CAAC,QAAQ,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe,CAAC;CACzE;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IAGxB,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAGhC,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAGhC,YAAY,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAEhC,YAAY,IAAI,MAAM,CAAC;IAGvB,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAGxC,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAGxC,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAEzC,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAEjC,QAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAEvC,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAE5C,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC;IAEvE,KAAK,EAAE,MAAM,MAAM,CAAC;IAEpB,WAAW,EAAE,MAAM,CAAC;IAEpB,UAAU,EAAE,MAAM,CAAC;CACpB"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY3VydmVzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBQdWJsaWNLZXljaGFpbiA9IHtcbiAgLy8gcHVibGljIGtleVxuICBwazogYmlnaW50O1xuICBjaGFpbmNvZGU6IGJpZ2ludDtcbn07XG5cbmV4cG9ydCB0eXBlIFByaXZhdGVLZXljaGFpbiA9IFB1YmxpY0tleWNoYWluICYge1xuICAvLyBzZWNyZXQga2V5XG4gIHNrOiBiaWdpbnQ7XG4gIHByZWZpeD86IGJpZ2ludDtcbn07XG5cbi8qKlxuICogQW4gaW50ZXJmYWNlIGZvciBjYWxjdWxhdGluZyBhIHN1YmtleSBpbiBhbiBIRCBrZXkgc2NoZW1lLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEhEVHJlZSB7XG4gIHB1YmxpY0Rlcml2ZShrZXljaGFpbjogUHVibGljS2V5Y2hhaW4sIHBhdGg6IHN0cmluZyk6IFB1YmxpY0tleWNoYWluO1xuXG4gIHByaXZhdGVEZXJpdmUoa2V5Y2hhaW46IFByaXZhdGVLZXljaGFpbiwgcGF0aDogc3RyaW5nKTogUHJpdmF0ZUtleWNoYWluO1xufVxuXG4vKipcbiAqIEJhc2UgSW50ZXJmYWNlIGZvciBzdXBwb3J0aW5nIGVsbGlwdGljIGN1cnZlIHBhcmFtZXRlcnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCYXNlQ3VydmUge1xuICAvLyBGdW5jdGlvbiB0aGF0IHJlZHVjZXMgYSBzY2FsYXIgbW9kdWxvIHRoZSBvcmRlciBvZiB0aGVcbiAgLy8gY3VydmUuXG4gIHNjYWxhclJlZHVjZShzOiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIEZ1bmN0aW9uIHRoYXQgcmV0dXJucyB0aGUgbmVnYXRlZCBmaWVsZCBlbGVtZW50IG1vZHVsb1xuICAvLyB0aGUgb3JkZXIgb2YgdGhlIGN1cnZlLlxuICBzY2FsYXJOZWdhdGUoczogYmlnaW50KTogYmlnaW50O1xuICAvLyBGdW5jdGlvbiB0aGF0IHJldHVybnMgdGhlIG1vZHVsYXIgbXVsdGlwbGljYXRpdmUgaW52ZXJzZVxuICAvLyBvZiBhIGZpZWxkIGVsZW1lbnQuXG4gIHNjYWxhckludmVydChzOiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIEZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhIHJhbmRvbSBmaWVsZCBlbGVtZW50LlxuICBzY2FsYXJSYW5kb20oKTogYmlnaW50O1xuICAvLyAgRnVuY3Rpb24gdGhhdCByZXR1cm5zIHRoZSBzdW0gb2YgdHdvIGZpZWxkIGVsZW1lbnRzIG1vZHVsb1xuICAvLyAgdGhlIG9yZGVyIG9mIHRoZSBjdXJ2ZS5cbiAgc2NhbGFyQWRkKHg6IGJpZ2ludCwgeTogYmlnaW50KTogYmlnaW50O1xuICAvLyBGdW5jdGlvbiB0aGF0IHJldHVybnMgdGhlIGRpZmZlcmVuY2Ugb2YgdHdvIGZpZWxkIGVsZW1lbnRzXG4gIC8vIG1vZHVsbyB0aGUgb3JkZXIgb2YgdGhlIGN1cnZlLlxuICBzY2FsYXJTdWIoeDogYmlnaW50LCB5OiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIEZ1bmN0aW9uIHRoYXQgcmV0dXJucyB0aGUgcHJvZHVjdCBvZiB0d28gZmllbGQgZWxlbWVudHNcbiAgLy8gbW9kdWxvIHRoZSBvcmRlciBvZiB0aGUgY3VydmUuXG4gIHNjYWxhck11bHQoeDogYmlnaW50LCB5OiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIEZ1bmN0aW9uIHRoYXQgbXVsdGlwbGllcyBhIGdyb3VwIGVsZW1lbnQgYnkgYSBmaWVsZCBlbGVtZW50LlxuICBiYXNlUG9pbnRNdWx0KG46IGJpZ2ludCk6IGJpZ2ludDtcbiAgLy8gRnVuY3Rpb24gdGhhdCBhZGRzIHR3byBncm91cCBlbGVtZW50cy5cbiAgcG9pbnRBZGQocDogYmlnaW50LCBxOiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIE11bHRpcGx5IGEgcG9pbnQgYnkgYSBzY2FsYXIuXG4gIHBvaW50TXVsdGlwbHkocDogYmlnaW50LCBzOiBiaWdpbnQpOiBiaWdpbnQ7XG4gIC8vIEZ1bmN0aW9uIHRoYXQgdmVyaWZpZXMgYSBzaWduYXR1cmUuXG4gIHZlcmlmeShtZXNzYWdlOiBCdWZmZXIsIHNpZ25hdHVyZTogQnVmZmVyLCBwdWJsaWNLZXk6IGJpZ2ludCk6IGJvb2xlYW47XG4gIC8vIG9yZGVyIG9mIHRoZSBjdXJ2ZVxuICBvcmRlcjogKCkgPT4gYmlnaW50O1xuICAvLyB0aGUgc2l6ZSBvZiBzY2FsYXIgb2YgdGhlIGN1cnZlIGluIGJ5dGVzXG4gIHNjYWxhckJ5dGVzOiBudW1iZXI7XG4gIC8vIHRoZSBzaXplIG9mIHBvaW50IG9mIHRoZSBjdXJ2ZSBpbiBieXRlc1xuICBwb2ludEJ5dGVzOiBudW1iZXI7XG59XG4iXX0=
@@ -0,0 +1,4 @@
1
+ export declare function pathToIndices(path: string): number[];
2
+ export declare function auditEddsaPrivateKey(privateKey: string, commonKeychain: string): void;
3
+ export declare function auditEcdsaPrivateKey(privateKey: string, commonKeychain: string): void;
4
+ //# sourceMappingURL=util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/curves/util.ts"],"names":[],"mappings":"AAAA,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAKpD;AAED,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,IAAI,CAoBrF;AAED,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,IAAI,CASrF"}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.pathToIndices = pathToIndices;
4
+ exports.auditEddsaPrivateKey = auditEddsaPrivateKey;
5
+ exports.auditEcdsaPrivateKey = auditEcdsaPrivateKey;
6
+ function pathToIndices(path) {
7
+ return path
8
+ .replace(/^m?\//, '')
9
+ .split('/')
10
+ .map((index) => parseInt(index, 10));
11
+ }
12
+ function auditEddsaPrivateKey(privateKey, commonKeychain) {
13
+ // For TSS validation, we would need GPG private key for full implementation
14
+ // This is a simplified validation of key format
15
+ if (commonKeychain.length !== 128) {
16
+ throw new Error('Invalid common keychain');
17
+ }
18
+ const parsedKey = JSON.parse(privateKey);
19
+ if ('uShare' in parsedKey) {
20
+ // If the key is in JSON format, we need to check the private key length
21
+ const privateKeyLength = parsedKey.uShare.seed.length + parsedKey.uShare.chaincode.length;
22
+ if (privateKeyLength !== 128) {
23
+ throw new Error('Invalid private key');
24
+ }
25
+ }
26
+ else {
27
+ // If the key is not in JSON format, we need to check the length directly
28
+ if (privateKey.length !== 128) {
29
+ throw new Error('Invalid private key');
30
+ }
31
+ }
32
+ }
33
+ function auditEcdsaPrivateKey(privateKey, commonKeychain) {
34
+ if (commonKeychain.length !== 130 && commonKeychain.length !== 0) {
35
+ throw new Error('Invalid common keychain');
36
+ }
37
+ // DKLs key chains do not have a fixed length but we know for sure they are greater than 192 in length
38
+ if (privateKey.length !== 128 && privateKey.length !== 192 && privateKey.length <= 192) {
39
+ throw new Error('Invalid private key');
40
+ }
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jdXJ2ZXMvdXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUtDO0FBRUQsb0RBb0JDO0FBRUQsb0RBU0M7QUF0Q0QsU0FBZ0IsYUFBYSxDQUFDLElBQVk7SUFDeEMsT0FBTyxJQUFJO1NBQ1IsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUM7U0FDcEIsS0FBSyxDQUFDLEdBQUcsQ0FBQztTQUNWLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ3pDLENBQUM7QUFFRCxTQUFnQixvQkFBb0IsQ0FBQyxVQUFrQixFQUFFLGNBQXNCO0lBQzdFLDRFQUE0RTtJQUM1RSxnREFBZ0Q7SUFDaEQsSUFBSSxjQUFjLENBQUMsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ2xDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN6QyxJQUFJLFFBQVEsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUMxQix3RUFBd0U7UUFDeEUsTUFBTSxnQkFBZ0IsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO1FBQzFGLElBQUksZ0JBQWdCLEtBQUssR0FBRyxFQUFFLENBQUM7WUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ3pDLENBQUM7SUFDSCxDQUFDO1NBQU0sQ0FBQztRQUNOLHlFQUF5RTtRQUN6RSxJQUFJLFVBQVUsQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7WUFDOUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ3pDLENBQUM7SUFDSCxDQUFDO0FBQ0gsQ0FBQztBQUVELFNBQWdCLG9CQUFvQixDQUFDLFVBQWtCLEVBQUUsY0FBc0I7SUFDN0UsSUFBSSxjQUFjLENBQUMsTUFBTSxLQUFLLEdBQUcsSUFBSSxjQUFjLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ2pFLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsc0dBQXNHO0lBQ3RHLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxHQUFHLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxHQUFHLElBQUksVUFBVSxDQUFDLE1BQU0sSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUN2RixNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDekMsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gcGF0aFRvSW5kaWNlcyhwYXRoOiBzdHJpbmcpOiBudW1iZXJbXSB7XG4gIHJldHVybiBwYXRoXG4gICAgLnJlcGxhY2UoL15tP1xcLy8sICcnKVxuICAgIC5zcGxpdCgnLycpXG4gICAgLm1hcCgoaW5kZXgpID0+IHBhcnNlSW50KGluZGV4LCAxMCkpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYXVkaXRFZGRzYVByaXZhdGVLZXkocHJpdmF0ZUtleTogc3RyaW5nLCBjb21tb25LZXljaGFpbjogc3RyaW5nKTogdm9pZCB7XG4gIC8vIEZvciBUU1MgdmFsaWRhdGlvbiwgd2Ugd291bGQgbmVlZCBHUEcgcHJpdmF0ZSBrZXkgZm9yIGZ1bGwgaW1wbGVtZW50YXRpb25cbiAgLy8gVGhpcyBpcyBhIHNpbXBsaWZpZWQgdmFsaWRhdGlvbiBvZiBrZXkgZm9ybWF0XG4gIGlmIChjb21tb25LZXljaGFpbi5sZW5ndGggIT09IDEyOCkge1xuICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBjb21tb24ga2V5Y2hhaW4nKTtcbiAgfVxuXG4gIGNvbnN0IHBhcnNlZEtleSA9IEpTT04ucGFyc2UocHJpdmF0ZUtleSk7XG4gIGlmICgndVNoYXJlJyBpbiBwYXJzZWRLZXkpIHtcbiAgICAvLyBJZiB0aGUga2V5IGlzIGluIEpTT04gZm9ybWF0LCB3ZSBuZWVkIHRvIGNoZWNrIHRoZSBwcml2YXRlIGtleSBsZW5ndGhcbiAgICBjb25zdCBwcml2YXRlS2V5TGVuZ3RoID0gcGFyc2VkS2V5LnVTaGFyZS5zZWVkLmxlbmd0aCArIHBhcnNlZEtleS51U2hhcmUuY2hhaW5jb2RlLmxlbmd0aDtcbiAgICBpZiAocHJpdmF0ZUtleUxlbmd0aCAhPT0gMTI4KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgcHJpdmF0ZSBrZXknKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgLy8gSWYgdGhlIGtleSBpcyBub3QgaW4gSlNPTiBmb3JtYXQsIHdlIG5lZWQgdG8gY2hlY2sgdGhlIGxlbmd0aCBkaXJlY3RseVxuICAgIGlmIChwcml2YXRlS2V5Lmxlbmd0aCAhPT0gMTI4KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0ludmFsaWQgcHJpdmF0ZSBrZXknKTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGF1ZGl0RWNkc2FQcml2YXRlS2V5KHByaXZhdGVLZXk6IHN0cmluZywgY29tbW9uS2V5Y2hhaW46IHN0cmluZyk6IHZvaWQge1xuICBpZiAoY29tbW9uS2V5Y2hhaW4ubGVuZ3RoICE9PSAxMzAgJiYgY29tbW9uS2V5Y2hhaW4ubGVuZ3RoICE9PSAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIGNvbW1vbiBrZXljaGFpbicpO1xuICB9XG5cbiAgLy8gREtMcyBrZXkgY2hhaW5zIGRvIG5vdCBoYXZlIGEgZml4ZWQgbGVuZ3RoIGJ1dCB3ZSBrbm93IGZvciBzdXJlIHRoZXkgYXJlIGdyZWF0ZXIgdGhhbiAxOTIgaW4gbGVuZ3RoXG4gIGlmIChwcml2YXRlS2V5Lmxlbmd0aCAhPT0gMTI4ICYmIHByaXZhdGVLZXkubGVuZ3RoICE9PSAxOTIgJiYgcHJpdmF0ZUtleS5sZW5ndGggPD0gMTkyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIHByaXZhdGUga2V5Jyk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,16 @@
1
+ import { HashCommitDecommit, HashDecommitment } from './types';
2
+ /**
3
+ * Create hash commitment and decommietment of a secret value.
4
+ * @param secret The secret value/message.
5
+ * @param r The randomness/nonce to be added to the commmitment.
6
+ * @returns The created commitment and decommitment.
7
+ */
8
+ export declare function createCommitment(secret: Buffer, r?: Buffer): HashCommitDecommit;
9
+ /**
10
+ * Verify hash commitment and decommietment of a secret value.
11
+ * @param commitment The commitment.
12
+ * @param decommietment The decommitment.
13
+ * @returns True if verification succeeds.
14
+ */
15
+ export declare function verifyCommitment(commitment: Buffer, decommietment: HashDecommitment): boolean;
16
+ //# sourceMappingURL=hashCommitment.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hashCommitment.d.ts","sourceRoot":"","sources":["../../src/hashCommitment.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAK/D;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAE,MAAyC,GAAG,kBAAkB,CAWjH;AAaD;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,aAAa,EAAE,gBAAgB,GAAG,OAAO,CAE7F"}