@ledgerhq/hw-app-btc 6.7.0 → 6.9.1-6.9.1-taproot.0.0

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 (164) hide show
  1. package/lib/Btc.d.ts +7 -3
  2. package/lib/Btc.d.ts.map +1 -1
  3. package/lib/Btc.js +95 -26
  4. package/lib/Btc.js.map +1 -1
  5. package/lib/BtcNew.d.ts +70 -0
  6. package/lib/BtcNew.d.ts.map +1 -0
  7. package/lib/BtcNew.js +372 -0
  8. package/lib/BtcNew.js.map +1 -0
  9. package/lib/BtcOld.d.ts +114 -0
  10. package/lib/BtcOld.d.ts.map +1 -0
  11. package/lib/BtcOld.js +138 -0
  12. package/lib/BtcOld.js.map +1 -0
  13. package/lib/bip32.d.ts +8 -0
  14. package/lib/bip32.d.ts.map +1 -1
  15. package/lib/bip32.js +32 -3
  16. package/lib/bip32.js.map +1 -1
  17. package/lib/buffertools.d.ts +28 -0
  18. package/lib/buffertools.d.ts.map +1 -0
  19. package/lib/buffertools.js +100 -0
  20. package/lib/buffertools.js.map +1 -0
  21. package/lib/createTransaction.d.ts.map +1 -1
  22. package/lib/getWalletPublicKey.d.ts +1 -1
  23. package/lib/getWalletPublicKey.d.ts.map +1 -1
  24. package/lib/getWalletPublicKey.js.map +1 -1
  25. package/lib/hashPublicKey.d.ts +1 -1
  26. package/lib/hashPublicKey.d.ts.map +1 -1
  27. package/lib/index.d.ts +3 -0
  28. package/lib/index.d.ts.map +1 -0
  29. package/lib/index.js +8 -0
  30. package/lib/index.js.map +1 -0
  31. package/lib/newops/appClient.d.ts +14 -0
  32. package/lib/newops/appClient.d.ts.map +1 -0
  33. package/lib/newops/appClient.js +242 -0
  34. package/lib/newops/appClient.js.map +1 -0
  35. package/lib/newops/clientCommands.d.ts +61 -0
  36. package/lib/newops/clientCommands.d.ts.map +1 -0
  37. package/lib/newops/clientCommands.js +331 -0
  38. package/lib/newops/clientCommands.js.map +1 -0
  39. package/lib/newops/merkelizedPsbt.d.ts +15 -0
  40. package/lib/newops/merkelizedPsbt.d.ts.map +1 -0
  41. package/lib/newops/merkelizedPsbt.js +91 -0
  42. package/lib/newops/merkelizedPsbt.js.map +1 -0
  43. package/lib/newops/merkle.d.ts +29 -0
  44. package/lib/newops/merkle.d.ts.map +1 -0
  45. package/lib/newops/merkle.js +133 -0
  46. package/lib/newops/merkle.js.map +1 -0
  47. package/lib/newops/merkleMap.d.ts +15 -0
  48. package/lib/newops/merkleMap.d.ts.map +1 -0
  49. package/lib/newops/merkleMap.js +37 -0
  50. package/lib/newops/merkleMap.js.map +1 -0
  51. package/lib/newops/policy.d.ts +14 -0
  52. package/lib/newops/policy.d.ts.map +1 -0
  53. package/lib/newops/policy.js +40 -0
  54. package/lib/newops/policy.js.map +1 -0
  55. package/lib/newops/psbtExtractor.d.ts +4 -0
  56. package/lib/newops/psbtExtractor.d.ts.map +1 -0
  57. package/lib/newops/psbtExtractor.js +36 -0
  58. package/lib/newops/psbtExtractor.js.map +1 -0
  59. package/lib/newops/psbtFinalizer.d.ts +7 -0
  60. package/lib/newops/psbtFinalizer.d.ts.map +1 -0
  61. package/lib/newops/psbtFinalizer.js +111 -0
  62. package/lib/newops/psbtFinalizer.js.map +1 -0
  63. package/lib/newops/psbtv2.d.ts +129 -0
  64. package/lib/newops/psbtv2.d.ts.map +1 -0
  65. package/lib/newops/psbtv2.js +478 -0
  66. package/lib/newops/psbtv2.js.map +1 -0
  67. package/lib/varint.d.ts.map +1 -1
  68. package/lib/varint.js +1 -0
  69. package/lib/varint.js.map +1 -1
  70. package/lib-es/Btc.d.ts +7 -3
  71. package/lib-es/Btc.d.ts.map +1 -1
  72. package/lib-es/Btc.js +92 -26
  73. package/lib-es/Btc.js.map +1 -1
  74. package/lib-es/BtcNew.d.ts +70 -0
  75. package/lib-es/BtcNew.d.ts.map +1 -0
  76. package/lib-es/BtcNew.js +370 -0
  77. package/lib-es/BtcNew.js.map +1 -0
  78. package/lib-es/BtcOld.d.ts +114 -0
  79. package/lib-es/BtcOld.d.ts.map +1 -0
  80. package/lib-es/BtcOld.js +136 -0
  81. package/lib-es/BtcOld.js.map +1 -0
  82. package/lib-es/bip32.d.ts +8 -0
  83. package/lib-es/bip32.d.ts.map +1 -1
  84. package/lib-es/bip32.js +26 -2
  85. package/lib-es/bip32.js.map +1 -1
  86. package/lib-es/buffertools.d.ts +28 -0
  87. package/lib-es/buffertools.d.ts.map +1 -0
  88. package/lib-es/buffertools.js +94 -0
  89. package/lib-es/buffertools.js.map +1 -0
  90. package/lib-es/createTransaction.d.ts.map +1 -1
  91. package/lib-es/getWalletPublicKey.d.ts +1 -1
  92. package/lib-es/getWalletPublicKey.d.ts.map +1 -1
  93. package/lib-es/getWalletPublicKey.js.map +1 -1
  94. package/lib-es/hashPublicKey.d.ts +1 -1
  95. package/lib-es/hashPublicKey.d.ts.map +1 -1
  96. package/lib-es/index.d.ts +3 -0
  97. package/lib-es/index.d.ts.map +1 -0
  98. package/lib-es/index.js +3 -0
  99. package/lib-es/index.js.map +1 -0
  100. package/lib-es/newops/appClient.d.ts +14 -0
  101. package/lib-es/newops/appClient.d.ts.map +1 -0
  102. package/lib-es/newops/appClient.js +239 -0
  103. package/lib-es/newops/appClient.js.map +1 -0
  104. package/lib-es/newops/clientCommands.d.ts +61 -0
  105. package/lib-es/newops/clientCommands.d.ts.map +1 -0
  106. package/lib-es/newops/clientCommands.js +328 -0
  107. package/lib-es/newops/clientCommands.js.map +1 -0
  108. package/lib-es/newops/merkelizedPsbt.d.ts +15 -0
  109. package/lib-es/newops/merkelizedPsbt.d.ts.map +1 -0
  110. package/lib-es/newops/merkelizedPsbt.js +88 -0
  111. package/lib-es/newops/merkelizedPsbt.js.map +1 -0
  112. package/lib-es/newops/merkle.d.ts +29 -0
  113. package/lib-es/newops/merkle.d.ts.map +1 -0
  114. package/lib-es/newops/merkle.js +129 -0
  115. package/lib-es/newops/merkle.js.map +1 -0
  116. package/lib-es/newops/merkleMap.d.ts +15 -0
  117. package/lib-es/newops/merkleMap.d.ts.map +1 -0
  118. package/lib-es/newops/merkleMap.js +34 -0
  119. package/lib-es/newops/merkleMap.js.map +1 -0
  120. package/lib-es/newops/policy.d.ts +14 -0
  121. package/lib-es/newops/policy.d.ts.map +1 -0
  122. package/lib-es/newops/policy.js +36 -0
  123. package/lib-es/newops/policy.js.map +1 -0
  124. package/lib-es/newops/psbtExtractor.d.ts +4 -0
  125. package/lib-es/newops/psbtExtractor.d.ts.map +1 -0
  126. package/lib-es/newops/psbtExtractor.js +32 -0
  127. package/lib-es/newops/psbtExtractor.js.map +1 -0
  128. package/lib-es/newops/psbtFinalizer.d.ts +7 -0
  129. package/lib-es/newops/psbtFinalizer.d.ts.map +1 -0
  130. package/lib-es/newops/psbtFinalizer.js +107 -0
  131. package/lib-es/newops/psbtFinalizer.js.map +1 -0
  132. package/lib-es/newops/psbtv2.d.ts +129 -0
  133. package/lib-es/newops/psbtv2.d.ts.map +1 -0
  134. package/lib-es/newops/psbtv2.js +475 -0
  135. package/lib-es/newops/psbtv2.js.map +1 -0
  136. package/lib-es/varint.d.ts.map +1 -1
  137. package/lib-es/varint.js +1 -0
  138. package/lib-es/varint.js.map +1 -1
  139. package/package.json +6 -3
  140. package/src/Btc.ts +42 -25
  141. package/src/BtcNew.ts +326 -0
  142. package/src/BtcOld.ts +156 -0
  143. package/src/bip32.ts +34 -2
  144. package/src/buffertools.ts +102 -0
  145. package/src/createTransaction.ts +1 -1
  146. package/src/getWalletPublicKey.ts +6 -1
  147. package/src/hashPublicKey.ts +1 -1
  148. package/src/index.ts +2 -0
  149. package/src/newops/appClient.ts +178 -0
  150. package/src/newops/clientCommands.ts +312 -0
  151. package/src/newops/merkelizedPsbt.ts +55 -0
  152. package/src/newops/merkle.ts +123 -0
  153. package/src/newops/merkleMap.ts +39 -0
  154. package/src/newops/policy.ts +52 -0
  155. package/src/newops/psbtExtractor.ts +33 -0
  156. package/src/newops/psbtFinalizer.ts +110 -0
  157. package/src/newops/psbtv2.ts +548 -0
  158. package/src/varint.ts +2 -0
  159. package/tests/Btc.integration.test.ts +89 -0
  160. package/tests/Btc.test.ts +6 -0
  161. package/tests/newops/BtcNew.test.ts +646 -0
  162. package/tests/newops/common.ts +25 -0
  163. package/tests/newops/merkle.test.ts +97 -0
  164. package/tests/trustedInputs.test.ts +4 -0
package/lib/bip32.d.ts CHANGED
@@ -1,3 +1,11 @@
1
1
  /// <reference types="node" />
2
+ export declare function pathElementsToBuffer(paths: number[]): Buffer;
2
3
  export declare function bip32asBuffer(path: string): Buffer;
4
+ export declare function pathArrayToString(pathElements: number[]): string;
5
+ export declare function pathStringToArray(path: string): number[];
6
+ export declare function pubkeyFromXpub(xpub: string): Buffer;
7
+ export declare function getXpubComponents(xpub: string): {
8
+ chaincode: Buffer;
9
+ pubkey: Buffer;
10
+ };
3
11
  //# sourceMappingURL=bip32.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"bip32.d.ts","sourceRoot":"","sources":["../src/bip32.ts"],"names":[],"mappings":";AACA,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAQlD"}
1
+ {"version":3,"file":"bip32.d.ts","sourceRoot":"","sources":["../src/bip32.ts"],"names":[],"mappings":";AAGA,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,CAO5D;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAGlD;AAED,wBAAgB,iBAAiB,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,MAAM,CAKhE;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAExD;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAGnD;AAED,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,MAAM,GACX;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAMvC"}
package/lib/bip32.js CHANGED
@@ -3,10 +3,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  exports.__esModule = true;
6
- exports.bip32asBuffer = void 0;
6
+ exports.getXpubComponents = exports.pubkeyFromXpub = exports.pathStringToArray = exports.pathArrayToString = exports.bip32asBuffer = exports.pathElementsToBuffer = void 0;
7
7
  var bip32_path_1 = __importDefault(require("bip32-path"));
8
- function bip32asBuffer(path) {
9
- var paths = !path ? [] : bip32_path_1["default"].fromString(path).toPathArray();
8
+ var bs58check_1 = __importDefault(require("bs58check"));
9
+ function pathElementsToBuffer(paths) {
10
10
  var buffer = Buffer.alloc(1 + paths.length * 4);
11
11
  buffer[0] = paths.length;
12
12
  paths.forEach(function (element, index) {
@@ -14,5 +14,34 @@ function bip32asBuffer(path) {
14
14
  });
15
15
  return buffer;
16
16
  }
17
+ exports.pathElementsToBuffer = pathElementsToBuffer;
18
+ function bip32asBuffer(path) {
19
+ var pathElements = !path ? [] : pathStringToArray(path);
20
+ return pathElementsToBuffer(pathElements);
21
+ }
17
22
  exports.bip32asBuffer = bip32asBuffer;
23
+ function pathArrayToString(pathElements) {
24
+ // Limitation: bippath can't handle and empty path. It shouldn't affect us
25
+ // right now, but might in the future.
26
+ // TODO: Fix support for empty path.
27
+ return bip32_path_1["default"].fromPathArray(pathElements).toString();
28
+ }
29
+ exports.pathArrayToString = pathArrayToString;
30
+ function pathStringToArray(path) {
31
+ return bip32_path_1["default"].fromString(path).toPathArray();
32
+ }
33
+ exports.pathStringToArray = pathStringToArray;
34
+ function pubkeyFromXpub(xpub) {
35
+ var xpubBuf = bs58check_1["default"].decode(xpub);
36
+ return xpubBuf.slice(xpubBuf.length - 33);
37
+ }
38
+ exports.pubkeyFromXpub = pubkeyFromXpub;
39
+ function getXpubComponents(xpub) {
40
+ var xpubBuf = bs58check_1["default"].decode(xpub);
41
+ return {
42
+ chaincode: xpubBuf.slice(13, 13 + 32),
43
+ pubkey: xpubBuf.slice(xpubBuf.length - 33)
44
+ };
45
+ }
46
+ exports.getXpubComponents = getXpubComponents;
18
47
  //# sourceMappingURL=bip32.js.map
package/lib/bip32.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"bip32.js","sourceRoot":"","sources":["../src/bip32.ts"],"names":[],"mappings":";;;;;;AAAA,0DAAiC;AACjC,SAAgB,aAAa,CAAC,IAAY;IACxC,IAAM,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,uBAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;IAClE,IAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClD,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;IACzB,KAAK,CAAC,OAAO,CAAC,UAAC,OAAO,EAAE,KAAK;QAC3B,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC;AARD,sCAQC"}
1
+ {"version":3,"file":"bip32.js","sourceRoot":"","sources":["../src/bip32.ts"],"names":[],"mappings":";;;;;;AAAA,0DAAiC;AACjC,wDAAkC;AAElC,SAAgB,oBAAoB,CAAC,KAAe;IAClD,IAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClD,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;IACzB,KAAK,CAAC,OAAO,CAAC,UAAC,OAAO,EAAE,KAAK;QAC3B,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC;AAPD,oDAOC;AAED,SAAgB,aAAa,CAAC,IAAY;IACxC,IAAM,YAAY,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAC1D,OAAO,oBAAoB,CAAC,YAAY,CAAC,CAAC;AAC5C,CAAC;AAHD,sCAGC;AAED,SAAgB,iBAAiB,CAAC,YAAsB;IACtD,0EAA0E;IAC1E,sCAAsC;IACtC,oCAAoC;IACpC,OAAO,uBAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;AACxD,CAAC;AALD,8CAKC;AAED,SAAgB,iBAAiB,CAAC,IAAY;IAC5C,OAAO,uBAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;AAChD,CAAC;AAFD,8CAEC;AAED,SAAgB,cAAc,CAAC,IAAY;IACzC,IAAM,OAAO,GAAG,sBAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACvC,OAAO,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;AAC5C,CAAC;AAHD,wCAGC;AAED,SAAgB,iBAAiB,CAC/B,IAAY;IAEZ,IAAM,OAAO,GAAG,sBAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACvC,OAAO;QACL,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC;QACrC,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC;KAC3C,CAAC;AACJ,CAAC;AARD,8CAQC"}
@@ -0,0 +1,28 @@
1
+ /// <reference types="node" />
2
+ export declare class BufferWriter {
3
+ private bufs;
4
+ write(alloc: number, fn: (b: Buffer) => void): void;
5
+ writeUInt8(i: number): void;
6
+ writeInt32(i: number): void;
7
+ writeUInt32(i: number): void;
8
+ writeUInt64(i: bigint): void;
9
+ writeVarInt(i: number): void;
10
+ writeSlice(slice: Buffer): void;
11
+ writeVarSlice(slice: Buffer): void;
12
+ buffer(): Buffer;
13
+ }
14
+ export declare class BufferReader {
15
+ buffer: Buffer;
16
+ offset: number;
17
+ constructor(buffer: Buffer, offset?: number);
18
+ available(): number;
19
+ readUInt8(): number;
20
+ readInt32(): number;
21
+ readUInt32(): number;
22
+ readUInt64(): bigint;
23
+ readVarInt(): number;
24
+ readSlice(n: number): Buffer;
25
+ readVarSlice(): Buffer;
26
+ readVector(): Buffer[];
27
+ }
28
+ //# sourceMappingURL=buffertools.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffertools.d.ts","sourceRoot":"","sources":["../src/buffertools.ts"],"names":[],"mappings":";AAEA,qBAAa,YAAY;IACvB,OAAO,CAAC,IAAI,CAAgB;IAE5B,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI,GAAG,IAAI;IAMnD,UAAU,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI3B,UAAU,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI3B,WAAW,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI5B,WAAW,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI5B,WAAW,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAI5B,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAI/B,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,MAAM,IAAI,MAAM;CAGjB;AAED,qBAAa,YAAY;IACJ,MAAM,EAAE,MAAM;IAAS,MAAM,EAAE,MAAM;gBAArC,MAAM,EAAE,MAAM,EAAS,MAAM,GAAE,MAAU;IAE5D,SAAS,IAAI,MAAM;IAInB,SAAS,IAAI,MAAM;IAMnB,SAAS,IAAI,MAAM;IAMnB,UAAU,IAAI,MAAM;IAMpB,UAAU,IAAI,MAAM;IAMpB,UAAU,IAAI,MAAM;IAMpB,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAS5B,YAAY,IAAI,MAAM;IAItB,UAAU,IAAI,MAAM,EAAE;CAMvB"}
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ exports.BufferReader = exports.BufferWriter = void 0;
7
+ var varuint_bitcoin_1 = __importDefault(require("varuint-bitcoin"));
8
+ var BufferWriter = /** @class */ (function () {
9
+ function BufferWriter() {
10
+ this.bufs = [];
11
+ }
12
+ BufferWriter.prototype.write = function (alloc, fn) {
13
+ var b = Buffer.alloc(alloc);
14
+ fn(b);
15
+ this.bufs.push(b);
16
+ };
17
+ BufferWriter.prototype.writeUInt8 = function (i) {
18
+ this.write(1, function (b) { return b.writeUInt8(i, 0); });
19
+ };
20
+ BufferWriter.prototype.writeInt32 = function (i) {
21
+ this.write(4, function (b) { return b.writeInt32LE(i, 0); });
22
+ };
23
+ BufferWriter.prototype.writeUInt32 = function (i) {
24
+ this.write(4, function (b) { return b.writeUInt32LE(i, 0); });
25
+ };
26
+ BufferWriter.prototype.writeUInt64 = function (i) {
27
+ this.write(8, function (b) { return b.writeBigUInt64LE(i, 0); });
28
+ };
29
+ BufferWriter.prototype.writeVarInt = function (i) {
30
+ this.bufs.push(varuint_bitcoin_1["default"].encode(i));
31
+ };
32
+ BufferWriter.prototype.writeSlice = function (slice) {
33
+ this.bufs.push(Buffer.from(slice));
34
+ };
35
+ BufferWriter.prototype.writeVarSlice = function (slice) {
36
+ this.writeVarInt(slice.length);
37
+ this.writeSlice(slice);
38
+ };
39
+ BufferWriter.prototype.buffer = function () {
40
+ return Buffer.concat(this.bufs);
41
+ };
42
+ return BufferWriter;
43
+ }());
44
+ exports.BufferWriter = BufferWriter;
45
+ var BufferReader = /** @class */ (function () {
46
+ function BufferReader(buffer, offset) {
47
+ if (offset === void 0) { offset = 0; }
48
+ this.buffer = buffer;
49
+ this.offset = offset;
50
+ }
51
+ BufferReader.prototype.available = function () {
52
+ return this.buffer.length - this.offset;
53
+ };
54
+ BufferReader.prototype.readUInt8 = function () {
55
+ var result = this.buffer.readUInt8(this.offset);
56
+ this.offset++;
57
+ return result;
58
+ };
59
+ BufferReader.prototype.readInt32 = function () {
60
+ var result = this.buffer.readInt32LE(this.offset);
61
+ this.offset += 4;
62
+ return result;
63
+ };
64
+ BufferReader.prototype.readUInt32 = function () {
65
+ var result = this.buffer.readUInt32LE(this.offset);
66
+ this.offset += 4;
67
+ return result;
68
+ };
69
+ BufferReader.prototype.readUInt64 = function () {
70
+ var result = this.buffer.readBigUInt64LE(this.offset);
71
+ this.offset += 8;
72
+ return result;
73
+ };
74
+ BufferReader.prototype.readVarInt = function () {
75
+ var vi = varuint_bitcoin_1["default"].decode(this.buffer, this.offset);
76
+ this.offset += varuint_bitcoin_1["default"].decode.bytes;
77
+ return vi;
78
+ };
79
+ BufferReader.prototype.readSlice = function (n) {
80
+ if (this.buffer.length < this.offset + n) {
81
+ throw new Error("Cannot read slice out of bounds");
82
+ }
83
+ var result = this.buffer.slice(this.offset, this.offset + n);
84
+ this.offset += n;
85
+ return result;
86
+ };
87
+ BufferReader.prototype.readVarSlice = function () {
88
+ return this.readSlice(this.readVarInt());
89
+ };
90
+ BufferReader.prototype.readVector = function () {
91
+ var count = this.readVarInt();
92
+ var vector = [];
93
+ for (var i = 0; i < count; i++)
94
+ vector.push(this.readVarSlice());
95
+ return vector;
96
+ };
97
+ return BufferReader;
98
+ }());
99
+ exports.BufferReader = BufferReader;
100
+ //# sourceMappingURL=buffertools.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffertools.js","sourceRoot":"","sources":["../src/buffertools.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../src/createTransaction.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAGpD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAS1D,OAAO,KAAK,EAAqB,WAAW,EAAE,MAAM,SAAS,CAAC;AAY9D,YAAY,EAAE,aAAa,EAAE,CAAC;AAW9B;;GAEG;AACH,oBAAY,oBAAoB,GAAG;IACjC,MAAM,EAAE,KAAK,CACX;QAAC,WAAW;QAAE,MAAM;QAAE,MAAM,GAAG,IAAI,GAAG,SAAS;QAAE,MAAM,GAAG,IAAI,GAAG,SAAS;KAAC,CAC5E,CAAC;IACF,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,iBAAiB,CAAC,EAAE,CAAC,IAAI,EAAE;QACzB,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;KACf,KAAK,IAAI,CAAC;IACX,0BAA0B,CAAC,EAAE,MAAM,IAAI,CAAC;IACxC,wBAAwB,CAAC,EAAE,MAAM,IAAI,CAAC;CACvC,CAAC;AACF,wBAAsB,iBAAiB,CACrC,SAAS,EAAE,SAAS,EACpB,GAAG,EAAE,oBAAoB,mBA6W1B"}
1
+ {"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../src/createTransaction.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAGpD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAS1D,OAAO,KAAK,EAAqB,WAAW,EAAE,MAAM,SAAS,CAAC;AAY9D,YAAY,EAAE,aAAa,EAAE,CAAC;AAW9B;;GAEG;AACH,oBAAY,oBAAoB,GAAG;IACjC,MAAM,EAAE,KAAK,CACX;QAAC,WAAW;QAAE,MAAM;QAAE,MAAM,GAAG,IAAI,GAAG,SAAS;QAAE,MAAM,GAAG,IAAI,GAAG,SAAS;KAAC,CAC5E,CAAC;IACF,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,iBAAiB,CAAC,EAAE,CAAC,IAAI,EAAE;QACzB,QAAQ,EAAE,MAAM,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;KACf,KAAK,IAAI,CAAC;IACX,0BAA0B,CAAC,EAAE,MAAM,IAAI,CAAC;IACxC,wBAAwB,CAAC,EAAE,MAAM,IAAI,CAAC;CACvC,CAAC;AACF,wBAAsB,iBAAiB,CACrC,SAAS,EAAE,SAAS,EACpB,GAAG,EAAE,oBAAoB,GACxB,OAAO,CAAC,MAAM,CAAC,CA4WjB"}
@@ -2,7 +2,7 @@ import type Transport from "@ledgerhq/hw-transport";
2
2
  /**
3
3
  * address format is one of legacy | p2sh | bech32 | cashaddr
4
4
  */
5
- export declare type AddressFormat = "legacy" | "p2sh" | "bech32" | "cashaddr";
5
+ export declare type AddressFormat = "legacy" | "p2sh" | "bech32" | "bech32m" | "cashaddr";
6
6
  export declare function getWalletPublicKey(transport: Transport, options: {
7
7
  path: string;
8
8
  verify?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"getWalletPublicKey.d.ts","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAGpD;;GAEG;AACH,oBAAY,aAAa,GAAG,QAAQ,GAAG,MAAM,GAAG,QAAQ,GAAG,UAAU,CAAC;AAOtE,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE;IACP,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,aAAa,CAAC;CACxB,GACA,OAAO,CAAC;IACT,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC,CAgCD"}
1
+ {"version":3,"file":"getWalletPublicKey.d.ts","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAGpD;;GAEG;AACH,oBAAY,aAAa,GACrB,QAAQ,GACR,MAAM,GACN,QAAQ,GACR,SAAS,GACT,UAAU,CAAC;AAOf,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE;IACP,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,aAAa,CAAC;CACxB,GACA,OAAO,CAAC;IACT,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC,CAgCD"}
@@ -1 +1 @@
1
- {"version":3,"file":"getWalletPublicKey.js","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,iCAAwC;AAMxC,IAAM,gBAAgB,GAAG;IACvB,MAAM,EAAE,CAAC;IACT,IAAI,EAAE,CAAC;IACP,MAAM,EAAE,CAAC;IACT,QAAQ,EAAE,CAAC;CACZ,CAAC;AACF,SAAsB,kBAAkB,CACtC,SAAoB,EACpB,OAIC;;;;;;oBAMK,gBACJ,MAAM,EAAE,KAAK,EACb,MAAM,EAAE,QAAQ,IACb,OAAO,CACX,EAJO,IAAI,UAAA,EAAE,MAAM,YAAA,EAAE,MAAM,YAAA,CAI1B;oBAEF,IAAI,CAAC,CAAC,MAAM,IAAI,gBAAgB,CAAC,EAAE;wBACjC,MAAM,IAAI,KAAK,CAAC,wCAAwC,GAAG,MAAM,CAAC,CAAC;qBACpE;oBAEK,MAAM,GAAG,IAAA,qBAAa,EAAC,IAAI,CAAC,CAAC;oBAC7B,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpB,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;oBACnB,qBAAM,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAA;;oBAA3D,QAAQ,GAAG,SAAgD;oBAC3D,eAAe,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;oBAC9B,aAAa,GAAG,QAAQ,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC;oBAC9C,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACnE,cAAc,GAAG,QAAQ;yBAC5B,KAAK,CAAC,CAAC,GAAG,eAAe,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,CAAC;yBACvE,QAAQ,CAAC,OAAO,CAAC,CAAC;oBACf,SAAS,GAAG,QAAQ;yBACvB,KAAK,CACJ,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,EACvC,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,GAAG,EAAE,CAC7C;yBACA,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACnB,sBAAO;4BACL,SAAS,WAAA;4BACT,cAAc,gBAAA;4BACd,SAAS,WAAA;yBACV,EAAC;;;;CACH;AA3CD,gDA2CC"}
1
+ {"version":3,"file":"getWalletPublicKey.js","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,iCAAwC;AAWxC,IAAM,gBAAgB,GAAG;IACvB,MAAM,EAAE,CAAC;IACT,IAAI,EAAE,CAAC;IACP,MAAM,EAAE,CAAC;IACT,QAAQ,EAAE,CAAC;CACZ,CAAC;AACF,SAAsB,kBAAkB,CACtC,SAAoB,EACpB,OAIC;;;;;;oBAMK,gBACJ,MAAM,EAAE,KAAK,EACb,MAAM,EAAE,QAAQ,IACb,OAAO,CACX,EAJO,IAAI,UAAA,EAAE,MAAM,YAAA,EAAE,MAAM,YAAA,CAI1B;oBAEF,IAAI,CAAC,CAAC,MAAM,IAAI,gBAAgB,CAAC,EAAE;wBACjC,MAAM,IAAI,KAAK,CAAC,wCAAwC,GAAG,MAAM,CAAC,CAAC;qBACpE;oBAEK,MAAM,GAAG,IAAA,qBAAa,EAAC,IAAI,CAAC,CAAC;oBAC7B,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpB,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;oBACnB,qBAAM,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAA;;oBAA3D,QAAQ,GAAG,SAAgD;oBAC3D,eAAe,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;oBAC9B,aAAa,GAAG,QAAQ,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC;oBAC9C,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACnE,cAAc,GAAG,QAAQ;yBAC5B,KAAK,CAAC,CAAC,GAAG,eAAe,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,CAAC;yBACvE,QAAQ,CAAC,OAAO,CAAC,CAAC;oBACf,SAAS,GAAG,QAAQ;yBACvB,KAAK,CACJ,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,EACvC,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,GAAG,EAAE,CAC7C;yBACA,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACnB,sBAAO;4BACL,SAAS,WAAA;4BACT,cAAc,gBAAA;4BACd,SAAS,WAAA;yBACV,EAAC;;;;CACH;AA3CD,gDA2CC"}
@@ -1,3 +1,3 @@
1
1
  /// <reference types="node" />
2
- export declare function hashPublicKey(buffer: Buffer): any;
2
+ export declare function hashPublicKey(buffer: Buffer): Buffer;
3
3
  //# sourceMappingURL=hashPublicKey.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"hashPublicKey.d.ts","sourceRoot":"","sources":["../src/hashPublicKey.ts"],"names":[],"mappings":";AAEA,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,GAAG,CAEjD"}
1
+ {"version":3,"file":"hashPublicKey.d.ts","sourceRoot":"","sources":["../src/hashPublicKey.ts"],"names":[],"mappings":";AAEA,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAEpD"}
package/lib/index.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ import Btc from "./Btc";
2
+ export default Btc;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,OAAO,CAAC;AACxB,eAAe,GAAG,CAAC"}
package/lib/index.js ADDED
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ exports.__esModule = true;
6
+ var Btc_1 = __importDefault(require("./Btc"));
7
+ exports["default"] = Btc_1["default"];
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAAA,8CAAwB;AACxB,qBAAe,gBAAG,CAAC"}
@@ -0,0 +1,14 @@
1
+ /// <reference types="node" />
2
+ import Transport from "@ledgerhq/hw-transport";
3
+ import { PsbtV2 } from "./psbtv2";
4
+ import { WalletPolicy } from "./policy";
5
+ export declare class AppClient {
6
+ transport: Transport;
7
+ constructor(transport: Transport);
8
+ private makeRequest;
9
+ getPubkey(display: boolean, pathElements: number[]): Promise<string>;
10
+ getWalletAddress(walletPolicy: WalletPolicy, walletHMAC: Buffer | null, change: number, addressIndex: number, display: boolean): Promise<string>;
11
+ signPsbt(psbt: PsbtV2, walletPolicy: WalletPolicy, walletHMAC: Buffer | null): Promise<Map<number, Buffer>>;
12
+ getMasterFingerprint(): Promise<Buffer>;
13
+ }
14
+ //# sourceMappingURL=appClient.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"appClient.d.ts","sourceRoot":"","sources":["../../src/newops/appClient.ts"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAE/C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAGlC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAoBxC,qBAAa,SAAS;IACpB,SAAS,EAAE,SAAS,CAAC;gBAET,SAAS,EAAE,SAAS;YAIlB,WAAW;IA6BnB,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAcpE,gBAAgB,CACpB,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,MAAM,GAAG,IAAI,EACzB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,MAAM,CAAC;IAkCZ,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,MAAM,GAAG,IAAI,GACxB,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAuDzB,oBAAoB,IAAI,OAAO,CAAC,MAAM,CAAC;CAG9C"}
@@ -0,0 +1,242 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (_) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ var __values = (this && this.__values) || function(o) {
39
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
40
+ if (m) return m.call(o);
41
+ if (o && typeof o.length === "number") return {
42
+ next: function () {
43
+ if (o && i >= o.length) o = void 0;
44
+ return { value: o && o[i++], done: !o };
45
+ }
46
+ };
47
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
48
+ };
49
+ exports.__esModule = true;
50
+ exports.AppClient = void 0;
51
+ var bip32_1 = require("../bip32");
52
+ var merkelizedPsbt_1 = require("./merkelizedPsbt");
53
+ var clientCommands_1 = require("./clientCommands");
54
+ var varint_1 = require("../varint");
55
+ var merkle_1 = require("./merkle");
56
+ var CLA_BTC = 0xe1;
57
+ var CLA_FRAMEWORK = 0xf8;
58
+ var BitcoinIns;
59
+ (function (BitcoinIns) {
60
+ BitcoinIns[BitcoinIns["GET_PUBKEY"] = 0] = "GET_PUBKEY";
61
+ // GET_ADDRESS = 0x01,
62
+ BitcoinIns[BitcoinIns["REGISTER_WALLET"] = 2] = "REGISTER_WALLET";
63
+ BitcoinIns[BitcoinIns["GET_WALLET_ADDRESS"] = 3] = "GET_WALLET_ADDRESS";
64
+ BitcoinIns[BitcoinIns["SIGN_PSBT"] = 4] = "SIGN_PSBT";
65
+ BitcoinIns[BitcoinIns["GET_MASTER_FINGERPRINT"] = 5] = "GET_MASTER_FINGERPRINT";
66
+ })(BitcoinIns || (BitcoinIns = {}));
67
+ var FrameworkIns;
68
+ (function (FrameworkIns) {
69
+ FrameworkIns[FrameworkIns["CONTINUE_INTERRUPTED"] = 1] = "CONTINUE_INTERRUPTED";
70
+ })(FrameworkIns || (FrameworkIns = {}));
71
+ var AppClient = /** @class */ (function () {
72
+ function AppClient(transport) {
73
+ this.transport = transport;
74
+ }
75
+ AppClient.prototype.makeRequest = function (ins, data, cci) {
76
+ return __awaiter(this, void 0, void 0, function () {
77
+ var response, hwRequest, commandResponse;
78
+ return __generator(this, function (_a) {
79
+ switch (_a.label) {
80
+ case 0: return [4 /*yield*/, this.transport.send(CLA_BTC, ins, 0, 0, data, [
81
+ 0x9000,
82
+ 0xe000,
83
+ ])];
84
+ case 1:
85
+ response = _a.sent();
86
+ _a.label = 2;
87
+ case 2:
88
+ if (!(response.readUInt16BE(response.length - 2) === 0xe000)) return [3 /*break*/, 4];
89
+ if (!cci) {
90
+ throw new Error("Unexpected SW_INTERRUPTED_EXECUTION");
91
+ }
92
+ hwRequest = response.slice(0, -2);
93
+ commandResponse = cci.execute(hwRequest);
94
+ return [4 /*yield*/, this.transport.send(CLA_FRAMEWORK, FrameworkIns.CONTINUE_INTERRUPTED, 0, 0, commandResponse, [0x9000, 0xe000])];
95
+ case 3:
96
+ response = _a.sent();
97
+ return [3 /*break*/, 2];
98
+ case 4: return [2 /*return*/, response.slice(0, -2)]; // drop the status word (can only be 0x9000 at this point)
99
+ }
100
+ });
101
+ });
102
+ };
103
+ AppClient.prototype.getPubkey = function (display, pathElements) {
104
+ return __awaiter(this, void 0, void 0, function () {
105
+ var response;
106
+ return __generator(this, function (_a) {
107
+ switch (_a.label) {
108
+ case 0:
109
+ if (pathElements.length > 6) {
110
+ throw new Error("Path too long. At most 6 levels allowed.");
111
+ }
112
+ return [4 /*yield*/, this.makeRequest(BitcoinIns.GET_PUBKEY, Buffer.concat([
113
+ Buffer.of(display ? 1 : 0),
114
+ (0, bip32_1.pathElementsToBuffer)(pathElements),
115
+ ]))];
116
+ case 1:
117
+ response = _a.sent();
118
+ return [2 /*return*/, response.toString("ascii")];
119
+ }
120
+ });
121
+ });
122
+ };
123
+ AppClient.prototype.getWalletAddress = function (walletPolicy, walletHMAC, change, addressIndex, display) {
124
+ return __awaiter(this, void 0, void 0, function () {
125
+ var clientInterpreter, addressIndexBuffer, response;
126
+ return __generator(this, function (_a) {
127
+ switch (_a.label) {
128
+ case 0:
129
+ if (change !== 0 && change !== 1)
130
+ throw new Error("Change can only be 0 or 1");
131
+ if (addressIndex < 0 || !Number.isInteger(addressIndex))
132
+ throw new Error("Invalid address index");
133
+ if (walletHMAC != null && walletHMAC.length != 32) {
134
+ throw new Error("Invalid HMAC length");
135
+ }
136
+ clientInterpreter = new clientCommands_1.ClientCommandInterpreter();
137
+ clientInterpreter.addKnownList(walletPolicy.keys.map(function (k) { return Buffer.from(k, "ascii"); }));
138
+ clientInterpreter.addKnownPreimage(walletPolicy.serialize());
139
+ addressIndexBuffer = Buffer.alloc(4);
140
+ addressIndexBuffer.writeUInt32BE(addressIndex, 0);
141
+ return [4 /*yield*/, this.makeRequest(BitcoinIns.GET_WALLET_ADDRESS, Buffer.concat([
142
+ Buffer.of(display ? 1 : 0),
143
+ walletPolicy.getWalletId(),
144
+ walletHMAC || Buffer.alloc(32, 0),
145
+ Buffer.of(change),
146
+ addressIndexBuffer,
147
+ ]), clientInterpreter)];
148
+ case 1:
149
+ response = _a.sent();
150
+ return [2 /*return*/, response.toString("ascii")];
151
+ }
152
+ });
153
+ });
154
+ };
155
+ AppClient.prototype.signPsbt = function (psbt, walletPolicy, walletHMAC) {
156
+ return __awaiter(this, void 0, void 0, function () {
157
+ var merkelizedPsbt, clientInterpreter, _a, _b, map, _c, _d, map, inputMapsRoot, outputMapsRoot, yielded, ret, yielded_1, yielded_1_1, inputAndSig;
158
+ var e_1, _e, e_2, _f, e_3, _g;
159
+ return __generator(this, function (_h) {
160
+ switch (_h.label) {
161
+ case 0:
162
+ merkelizedPsbt = new merkelizedPsbt_1.MerkelizedPsbt(psbt);
163
+ if (walletHMAC != null && walletHMAC.length != 32) {
164
+ throw new Error("Invalid HMAC length");
165
+ }
166
+ clientInterpreter = new clientCommands_1.ClientCommandInterpreter();
167
+ // prepare ClientCommandInterpreter
168
+ clientInterpreter.addKnownList(walletPolicy.keys.map(function (k) { return Buffer.from(k, "ascii"); }));
169
+ clientInterpreter.addKnownPreimage(walletPolicy.serialize());
170
+ clientInterpreter.addKnownMapping(merkelizedPsbt.globalMerkleMap);
171
+ try {
172
+ for (_a = __values(merkelizedPsbt.inputMerkleMaps), _b = _a.next(); !_b.done; _b = _a.next()) {
173
+ map = _b.value;
174
+ clientInterpreter.addKnownMapping(map);
175
+ }
176
+ }
177
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
178
+ finally {
179
+ try {
180
+ if (_b && !_b.done && (_e = _a["return"])) _e.call(_a);
181
+ }
182
+ finally { if (e_1) throw e_1.error; }
183
+ }
184
+ try {
185
+ for (_c = __values(merkelizedPsbt.outputMerkleMaps), _d = _c.next(); !_d.done; _d = _c.next()) {
186
+ map = _d.value;
187
+ clientInterpreter.addKnownMapping(map);
188
+ }
189
+ }
190
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
191
+ finally {
192
+ try {
193
+ if (_d && !_d.done && (_f = _c["return"])) _f.call(_c);
194
+ }
195
+ finally { if (e_2) throw e_2.error; }
196
+ }
197
+ clientInterpreter.addKnownList(merkelizedPsbt.inputMapCommitments);
198
+ inputMapsRoot = new merkle_1.Merkle(merkelizedPsbt.inputMapCommitments.map(function (m) { return (0, merkle_1.hashLeaf)(m); })).getRoot();
199
+ clientInterpreter.addKnownList(merkelizedPsbt.outputMapCommitments);
200
+ outputMapsRoot = new merkle_1.Merkle(merkelizedPsbt.outputMapCommitments.map(function (m) { return (0, merkle_1.hashLeaf)(m); })).getRoot();
201
+ return [4 /*yield*/, this.makeRequest(BitcoinIns.SIGN_PSBT, Buffer.concat([
202
+ merkelizedPsbt.getGlobalKeysValuesRoot(),
203
+ (0, varint_1.createVarint)(merkelizedPsbt.getGlobalInputCount()),
204
+ inputMapsRoot,
205
+ (0, varint_1.createVarint)(merkelizedPsbt.getGlobalOutputCount()),
206
+ outputMapsRoot,
207
+ walletPolicy.getWalletId(),
208
+ walletHMAC || Buffer.alloc(32, 0),
209
+ ]), clientInterpreter)];
210
+ case 1:
211
+ _h.sent();
212
+ yielded = clientInterpreter.getYielded();
213
+ ret = new Map();
214
+ try {
215
+ for (yielded_1 = __values(yielded), yielded_1_1 = yielded_1.next(); !yielded_1_1.done; yielded_1_1 = yielded_1.next()) {
216
+ inputAndSig = yielded_1_1.value;
217
+ ret[inputAndSig[0]] = inputAndSig.slice(1);
218
+ }
219
+ }
220
+ catch (e_3_1) { e_3 = { error: e_3_1 }; }
221
+ finally {
222
+ try {
223
+ if (yielded_1_1 && !yielded_1_1.done && (_g = yielded_1["return"])) _g.call(yielded_1);
224
+ }
225
+ finally { if (e_3) throw e_3.error; }
226
+ }
227
+ return [2 /*return*/, ret];
228
+ }
229
+ });
230
+ });
231
+ };
232
+ AppClient.prototype.getMasterFingerprint = function () {
233
+ return __awaiter(this, void 0, void 0, function () {
234
+ return __generator(this, function (_a) {
235
+ return [2 /*return*/, this.makeRequest(BitcoinIns.GET_MASTER_FINGERPRINT, Buffer.of())];
236
+ });
237
+ });
238
+ };
239
+ return AppClient;
240
+ }());
241
+ exports.AppClient = AppClient;
242
+ //# sourceMappingURL=appClient.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"appClient.js","sourceRoot":"","sources":["../../src/newops/appClient.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,61 @@
1
+ /// <reference types="node" />
2
+ import { Merkle } from "./merkle";
3
+ import { MerkleMap } from "./merkleMap";
4
+ declare enum ClientCommandCode {
5
+ YIELD = 16,
6
+ GET_PREIMAGE = 64,
7
+ GET_MERKLE_LEAF_PROOF = 65,
8
+ GET_MERKLE_LEAF_INDEX = 66,
9
+ GET_MORE_ELEMENTS = 160
10
+ }
11
+ declare abstract class ClientCommand {
12
+ abstract code: ClientCommandCode;
13
+ abstract execute(request: Buffer): Buffer;
14
+ }
15
+ export declare class YieldCommand extends ClientCommand {
16
+ private results;
17
+ code: ClientCommandCode;
18
+ constructor(results: Buffer[]);
19
+ execute(request: Buffer): Buffer;
20
+ }
21
+ export declare class GetPreimageCommand extends ClientCommand {
22
+ private known_preimages;
23
+ private queue;
24
+ code: ClientCommandCode;
25
+ constructor(known_preimages: Map<string, Buffer>, queue: Buffer[]);
26
+ execute(request: Buffer): Buffer;
27
+ }
28
+ export declare class GetMerkleLeafProofCommand extends ClientCommand {
29
+ private known_trees;
30
+ private queue;
31
+ code: ClientCommandCode;
32
+ constructor(known_trees: Map<string, Merkle>, queue: Buffer[]);
33
+ execute(request: Buffer): Buffer;
34
+ }
35
+ export declare class GetMerkleLeafIndexCommand extends ClientCommand {
36
+ private known_trees;
37
+ code: ClientCommandCode;
38
+ constructor(known_trees: Map<string, Merkle>);
39
+ execute(request: Buffer): Buffer;
40
+ }
41
+ export declare class GetMoreElementsCommand extends ClientCommand {
42
+ queue: Buffer[];
43
+ code: ClientCommandCode;
44
+ constructor(queue: Buffer[]);
45
+ execute(request: Buffer): Buffer;
46
+ }
47
+ export declare class ClientCommandInterpreter {
48
+ private roots;
49
+ private preimages;
50
+ private yielded;
51
+ private queue;
52
+ private commands;
53
+ constructor();
54
+ getYielded(): Buffer[];
55
+ addKnownPreimage(preimage: Buffer): void;
56
+ addKnownList(elements: Buffer[]): void;
57
+ addKnownMapping(mm: MerkleMap): void;
58
+ execute(request: Buffer): Buffer;
59
+ }
60
+ export {};
61
+ //# sourceMappingURL=clientCommands.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clientCommands.d.ts","sourceRoot":"","sources":["../../src/newops/clientCommands.ts"],"names":[],"mappings":";AAEA,OAAO,EAAY,MAAM,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,aAAK,iBAAiB;IACpB,KAAK,KAAO;IACZ,YAAY,KAAO;IACnB,qBAAqB,KAAO;IAC5B,qBAAqB,KAAO;IAC5B,iBAAiB,MAAO;CACzB;AAED,uBAAe,aAAa;IAC1B,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAC;IACjC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAC1C;AAED,qBAAa,YAAa,SAAQ,aAAa;IAC7C,OAAO,CAAC,OAAO,CAAW;IAE1B,IAAI,oBAA2B;gBAEnB,OAAO,EAAE,MAAM,EAAE;IAK7B,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAIjC;AAED,qBAAa,kBAAmB,SAAQ,aAAa;IACnD,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,KAAK,CAAW;IAExB,IAAI,oBAAkC;gBAE1B,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE;IAMjE,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CA4CjC;AAED,qBAAa,yBAA0B,SAAQ,aAAa;IAC1D,OAAO,CAAC,WAAW,CAAsB;IACzC,OAAO,CAAC,KAAK,CAAW;IAExB,IAAI,oBAA2C;gBAEnC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE;IAM7D,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAoDjC;AAED,qBAAa,yBAA0B,SAAQ,aAAa;IAC1D,OAAO,CAAC,WAAW,CAAsB;IAEzC,IAAI,oBAA2C;gBAEnC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC;IAK5C,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAuCjC;AAED,qBAAa,sBAAuB,SAAQ,aAAa;IACvD,KAAK,EAAE,MAAM,EAAE,CAAC;IAEhB,IAAI,oBAAuC;gBAE/B,KAAK,EAAE,MAAM,EAAE;IAK3B,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CA4BjC;AAED,qBAAa,wBAAwB;IACnC,OAAO,CAAC,KAAK,CAAkC;IAC/C,OAAO,CAAC,SAAS,CAAkC;IAEnD,OAAO,CAAC,OAAO,CAAgB;IAE/B,OAAO,CAAC,KAAK,CAAgB;IAE7B,OAAO,CAAC,QAAQ,CAAoD;;IAmBpE,UAAU,IAAI,MAAM,EAAE;IAItB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIxC,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,IAAI;IAStC,eAAe,CAAC,EAAE,EAAE,SAAS,GAAG,IAAI;IAKpC,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;CAajC"}