@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
@@ -0,0 +1,15 @@
1
+ /// <reference types="node" />
2
+ import { MerkleMap } from "./merkleMap";
3
+ import { PsbtV2 } from "./psbtv2";
4
+ export declare class MerkelizedPsbt extends PsbtV2 {
5
+ globalMerkleMap: MerkleMap;
6
+ inputMerkleMaps: MerkleMap[];
7
+ outputMerkleMaps: MerkleMap[];
8
+ inputMapCommitments: Buffer[];
9
+ outputMapCommitments: Buffer[];
10
+ constructor(psbt: PsbtV2);
11
+ getGlobalSize(): number;
12
+ getGlobalKeysValuesRoot(): Buffer;
13
+ private static createMerkleMap;
14
+ }
15
+ //# sourceMappingURL=merkelizedPsbt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkelizedPsbt.d.ts","sourceRoot":"","sources":["../../src/newops/merkelizedPsbt.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,qBAAa,cAAe,SAAQ,MAAM;IACjC,eAAe,EAAE,SAAS,CAAC;IAC3B,eAAe,EAAE,SAAS,EAAE,CAAM;IAClC,gBAAgB,EAAE,SAAS,EAAE,CAAM;IACnC,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC9B,oBAAoB,EAAE,MAAM,EAAE,CAAC;gBAC1B,IAAI,EAAE,MAAM;IAwBxB,aAAa,IAAI,MAAM;IAGvB,uBAAuB,IAAI,MAAM;IAIjC,OAAO,CAAC,MAAM,CAAC,eAAe;CAc/B"}
@@ -0,0 +1,88 @@
1
+ var __extends = (this && this.__extends) || (function () {
2
+ var extendStatics = function (d, b) {
3
+ extendStatics = Object.setPrototypeOf ||
4
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
6
+ return extendStatics(d, b);
7
+ };
8
+ return function (d, b) {
9
+ if (typeof b !== "function" && b !== null)
10
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
11
+ extendStatics(d, b);
12
+ function __() { this.constructor = d; }
13
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
14
+ };
15
+ })();
16
+ var __read = (this && this.__read) || function (o, n) {
17
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
18
+ if (!m) return o;
19
+ var i = m.call(o), r, ar = [], e;
20
+ try {
21
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
22
+ }
23
+ catch (error) { e = { error: error }; }
24
+ finally {
25
+ try {
26
+ if (r && !r.done && (m = i["return"])) m.call(i);
27
+ }
28
+ finally { if (e) throw e.error; }
29
+ }
30
+ return ar;
31
+ };
32
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
33
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
34
+ if (ar || !(i in from)) {
35
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
36
+ ar[i] = from[i];
37
+ }
38
+ }
39
+ return to.concat(ar || Array.prototype.slice.call(from));
40
+ };
41
+ import { MerkleMap } from "./merkleMap";
42
+ import { PsbtV2 } from "./psbtv2";
43
+ var MerkelizedPsbt = /** @class */ (function (_super) {
44
+ __extends(MerkelizedPsbt, _super);
45
+ function MerkelizedPsbt(psbt) {
46
+ var _this = _super.call(this) || this;
47
+ _this.inputMerkleMaps = [];
48
+ _this.outputMerkleMaps = [];
49
+ psbt.copy(_this);
50
+ _this.globalMerkleMap = MerkelizedPsbt.createMerkleMap(_this.globalMap);
51
+ for (var i = 0; i < _this.getGlobalInputCount(); i++) {
52
+ _this.inputMerkleMaps.push(MerkelizedPsbt.createMerkleMap(_this.inputMaps[i]));
53
+ }
54
+ _this.inputMapCommitments = __spreadArray([], __read(_this.inputMerkleMaps.values()), false).map(function (v) {
55
+ return v.commitment();
56
+ });
57
+ for (var i = 0; i < _this.getGlobalOutputCount(); i++) {
58
+ _this.outputMerkleMaps.push(MerkelizedPsbt.createMerkleMap(_this.outputMaps[i]));
59
+ }
60
+ _this.outputMapCommitments = __spreadArray([], __read(_this.outputMerkleMaps.values()), false).map(function (v) {
61
+ return v.commitment();
62
+ });
63
+ return _this;
64
+ }
65
+ // These public functions are for MerkelizedPsbt.
66
+ MerkelizedPsbt.prototype.getGlobalSize = function () {
67
+ return this.globalMap.size;
68
+ };
69
+ MerkelizedPsbt.prototype.getGlobalKeysValuesRoot = function () {
70
+ return this.globalMerkleMap.commitment();
71
+ };
72
+ MerkelizedPsbt.createMerkleMap = function (map) {
73
+ var sortedKeysStrings = __spreadArray([], __read(map.keys()), false).sort();
74
+ var values = sortedKeysStrings.map(function (k) {
75
+ var v = map.get(k);
76
+ if (!v) {
77
+ throw new Error("No value for key " + k);
78
+ }
79
+ return v;
80
+ });
81
+ var sortedKeys = sortedKeysStrings.map(function (k) { return Buffer.from(k, "hex"); });
82
+ var merkleMap = new MerkleMap(sortedKeys, values);
83
+ return merkleMap;
84
+ };
85
+ return MerkelizedPsbt;
86
+ }(PsbtV2));
87
+ export { MerkelizedPsbt };
88
+ //# sourceMappingURL=merkelizedPsbt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkelizedPsbt.js","sourceRoot":"","sources":["../../src/newops/merkelizedPsbt.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC;IAAoC,kCAAM;IAMxC,wBAAY,IAAY;QAAxB,YACE,iBAAO,SAqBR;QA1BM,qBAAe,GAAgB,EAAE,CAAC;QAClC,sBAAgB,GAAgB,EAAE,CAAC;QAKxC,IAAI,CAAC,IAAI,CAAC,KAAI,CAAC,CAAC;QAChB,KAAI,CAAC,eAAe,GAAG,cAAc,CAAC,eAAe,CAAC,KAAI,CAAC,SAAS,CAAC,CAAC;QAEtE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC,EAAE,EAAE;YACnD,KAAI,CAAC,eAAe,CAAC,IAAI,CACvB,cAAc,CAAC,eAAe,CAAC,KAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAClD,CAAC;SACH;QACD,KAAI,CAAC,mBAAmB,GAAG,yBAAI,KAAI,CAAC,eAAe,CAAC,MAAM,EAAE,UAAE,GAAG,CAAC,UAAC,CAAC;YAClE,OAAA,CAAC,CAAC,UAAU,EAAE;QAAd,CAAc,CACf,CAAC;QAEF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC,EAAE,EAAE;YACpD,KAAI,CAAC,gBAAgB,CAAC,IAAI,CACxB,cAAc,CAAC,eAAe,CAAC,KAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CACnD,CAAC;SACH;QACD,KAAI,CAAC,oBAAoB,GAAG,yBAAI,KAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,UAAE,GAAG,CAAC,UAAC,CAAC;YACpE,OAAA,CAAC,CAAC,UAAU,EAAE;QAAd,CAAc,CACf,CAAC;;IACJ,CAAC;IACD,iDAAiD;IACjD,sCAAa,GAAb;QACE,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;IAC7B,CAAC;IACD,gDAAuB,GAAvB;QACE,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;IAC3C,CAAC;IAEc,8BAAe,GAA9B,UAA+B,GAAwB;QACrD,IAAM,iBAAiB,GAAG,yBAAI,GAAG,CAAC,IAAI,EAAE,UAAE,IAAI,EAAE,CAAC;QACjD,IAAM,MAAM,GAAG,iBAAiB,CAAC,GAAG,CAAC,UAAC,CAAC;YACrC,IAAM,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACrB,IAAI,CAAC,CAAC,EAAE;gBACN,MAAM,IAAI,KAAK,CAAC,mBAAmB,GAAG,CAAC,CAAC,CAAC;aAC1C;YACD,OAAO,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;QACH,IAAM,UAAU,GAAG,iBAAiB,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,EAArB,CAAqB,CAAC,CAAC;QAEvE,IAAM,SAAS,GAAG,IAAI,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QACpD,OAAO,SAAS,CAAC;IACnB,CAAC;IACH,qBAAC;AAAD,CAAC,AAnDD,CAAoC,MAAM,GAmDzC"}
@@ -0,0 +1,29 @@
1
+ /// <reference types="node" />
2
+ export declare class Merkle {
3
+ private leaves;
4
+ private rootNode;
5
+ private leafNodes;
6
+ private h;
7
+ constructor(leaves: Buffer[], hasher?: (buf: Buffer) => Buffer);
8
+ getRoot(): Buffer;
9
+ size(): number;
10
+ getLeaves(): Buffer[];
11
+ getLeafHash(index: number): Buffer;
12
+ getProof(index: number): Buffer[];
13
+ calculateRoot(leaves: Buffer[]): {
14
+ root: Node;
15
+ leaves: Node[];
16
+ };
17
+ hashNode(left: Buffer, right: Buffer): Buffer;
18
+ }
19
+ export declare function hashLeaf(buf: Buffer, hashFunction?: (buf: Buffer) => Buffer): Buffer;
20
+ declare class Node {
21
+ leftChild?: Node;
22
+ rightChild?: Node;
23
+ parent?: Node;
24
+ hash: Buffer;
25
+ constructor(left: Node | undefined, right: Node | undefined, hash: Buffer);
26
+ isLeaf(): boolean;
27
+ }
28
+ export {};
29
+ //# sourceMappingURL=merkle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkle.d.ts","sourceRoot":"","sources":["../../src/newops/merkle.ts"],"names":[],"mappings":";AAEA,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAW;IACzB,OAAO,CAAC,QAAQ,CAAO;IACvB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,CAAC,CAA0B;gBAEjC,MAAM,EAAE,MAAM,EAAE,EAChB,MAAM,GAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAsB;IAQjD,OAAO,IAAI,MAAM;IAGjB,IAAI,IAAI,MAAM;IAGd,SAAS,IAAI,MAAM,EAAE;IAGrB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAGlC,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE;IAKjC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG;QAAE,IAAI,EAAE,IAAI,CAAC;QAAC,MAAM,EAAE,IAAI,EAAE,CAAA;KAAE;IAwB/D,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;CAG9C;AAED,wBAAgB,QAAQ,CACtB,GAAG,EAAE,MAAM,EACX,YAAY,GAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAsB,GACpD,MAAM,CAER;AAUD,cAAM,IAAI;IACR,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,UAAU,CAAC,EAAE,IAAI,CAAC;IAClB,MAAM,CAAC,EAAE,IAAI,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;gBACD,IAAI,EAAE,IAAI,GAAG,SAAS,EAAE,KAAK,EAAE,IAAI,GAAG,SAAS,EAAE,IAAI,EAAE,MAAM;IAKzE,MAAM,IAAI,OAAO;CAGlB"}
@@ -0,0 +1,129 @@
1
+ var __read = (this && this.__read) || function (o, n) {
2
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
3
+ if (!m) return o;
4
+ var i = m.call(o), r, ar = [], e;
5
+ try {
6
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
7
+ }
8
+ catch (error) { e = { error: error }; }
9
+ finally {
10
+ try {
11
+ if (r && !r.done && (m = i["return"])) m.call(i);
12
+ }
13
+ finally { if (e) throw e.error; }
14
+ }
15
+ return ar;
16
+ };
17
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
18
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
19
+ if (ar || !(i in from)) {
20
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
21
+ ar[i] = from[i];
22
+ }
23
+ }
24
+ return to.concat(ar || Array.prototype.slice.call(from));
25
+ };
26
+ import { crypto } from "bitcoinjs-lib";
27
+ var Merkle = /** @class */ (function () {
28
+ function Merkle(leaves, hasher) {
29
+ if (hasher === void 0) { hasher = crypto.sha256; }
30
+ this.leaves = leaves;
31
+ this.h = hasher;
32
+ var nodes = this.calculateRoot(leaves);
33
+ this.rootNode = nodes.root;
34
+ this.leafNodes = nodes.leaves;
35
+ }
36
+ Merkle.prototype.getRoot = function () {
37
+ return this.rootNode.hash;
38
+ };
39
+ Merkle.prototype.size = function () {
40
+ return this.leaves.length;
41
+ };
42
+ Merkle.prototype.getLeaves = function () {
43
+ return this.leaves;
44
+ };
45
+ Merkle.prototype.getLeafHash = function (index) {
46
+ return this.leafNodes[index].hash;
47
+ };
48
+ Merkle.prototype.getProof = function (index) {
49
+ if (index >= this.leaves.length)
50
+ throw Error("Index out of bounds");
51
+ return proveNode(this.leafNodes[index]);
52
+ };
53
+ Merkle.prototype.calculateRoot = function (leaves) {
54
+ var n = leaves.length;
55
+ if (n == 0) {
56
+ return {
57
+ root: new Node(undefined, undefined, Buffer.alloc(32, 0)),
58
+ leaves: []
59
+ };
60
+ }
61
+ if (n == 1) {
62
+ var newNode = new Node(undefined, undefined, leaves[0]);
63
+ return { root: newNode, leaves: [newNode] };
64
+ }
65
+ var leftCount = highestPowerOf2LessThan(n);
66
+ var leftBranch = this.calculateRoot(leaves.slice(0, leftCount));
67
+ var rightBranch = this.calculateRoot(leaves.slice(leftCount));
68
+ var leftChild = leftBranch.root;
69
+ var rightChild = rightBranch.root;
70
+ var hash = this.hashNode(leftChild.hash, rightChild.hash);
71
+ var node = new Node(leftChild, rightChild, hash);
72
+ leftChild.parent = node;
73
+ rightChild.parent = node;
74
+ return { root: node, leaves: leftBranch.leaves.concat(rightBranch.leaves) };
75
+ };
76
+ Merkle.prototype.hashNode = function (left, right) {
77
+ return this.h(Buffer.concat([Buffer.of(1), left, right]));
78
+ };
79
+ return Merkle;
80
+ }());
81
+ export { Merkle };
82
+ export function hashLeaf(buf, hashFunction) {
83
+ if (hashFunction === void 0) { hashFunction = crypto.sha256; }
84
+ return hashConcat(Buffer.of(0), buf, hashFunction);
85
+ }
86
+ function hashConcat(bufA, bufB, hashFunction) {
87
+ return hashFunction(Buffer.concat([bufA, bufB]));
88
+ }
89
+ var Node = /** @class */ (function () {
90
+ function Node(left, right, hash) {
91
+ this.leftChild = left;
92
+ this.rightChild = right;
93
+ this.hash = hash;
94
+ }
95
+ Node.prototype.isLeaf = function () {
96
+ return this.leftChild == undefined;
97
+ };
98
+ return Node;
99
+ }());
100
+ function proveNode(node) {
101
+ if (!node.parent) {
102
+ return [];
103
+ }
104
+ if (node.parent.leftChild == node) {
105
+ if (!node.parent.rightChild) {
106
+ throw new Error("Expected right child to exist");
107
+ }
108
+ return __spreadArray([node.parent.rightChild.hash], __read(proveNode(node.parent)), false);
109
+ }
110
+ else {
111
+ if (!node.parent.leftChild) {
112
+ throw new Error("Expected left child to exist");
113
+ }
114
+ return __spreadArray([node.parent.leftChild.hash], __read(proveNode(node.parent)), false);
115
+ }
116
+ }
117
+ function highestPowerOf2LessThan(n) {
118
+ if (n < 2) {
119
+ throw Error("Expected n >= 2");
120
+ }
121
+ if (isPowerOf2(n)) {
122
+ return n / 2;
123
+ }
124
+ return 1 << Math.floor(Math.log2(n));
125
+ }
126
+ function isPowerOf2(n) {
127
+ return (n & (n - 1)) == 0;
128
+ }
129
+ //# sourceMappingURL=merkle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkle.js","sourceRoot":"","sources":["../../src/newops/merkle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /// <reference types="node" />
2
+ import { Merkle } from "./merkle";
3
+ export declare class MerkleMap {
4
+ keys: Buffer[];
5
+ keysTree: Merkle;
6
+ values: Buffer[];
7
+ valuesTree: Merkle;
8
+ /**
9
+ * @param keys Sorted list of (unhashed) keys
10
+ * @param values values, in corresponding order as the keys, and of equal length
11
+ */
12
+ constructor(keys: Buffer[], values: Buffer[]);
13
+ commitment(): Buffer;
14
+ }
15
+ //# sourceMappingURL=merkleMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkleMap.d.ts","sourceRoot":"","sources":["../../src/newops/merkleMap.ts"],"names":[],"mappings":";AACA,OAAO,EAAY,MAAM,EAAE,MAAM,UAAU,CAAC;AAE5C,qBAAa,SAAS;IACpB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB;;;OAGG;gBACS,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;IAkB5C,UAAU,IAAI,MAAM;CAQrB"}
@@ -0,0 +1,34 @@
1
+ import { createVarint } from "../varint";
2
+ import { hashLeaf, Merkle } from "./merkle";
3
+ var MerkleMap = /** @class */ (function () {
4
+ /**
5
+ * @param keys Sorted list of (unhashed) keys
6
+ * @param values values, in corresponding order as the keys, and of equal length
7
+ */
8
+ function MerkleMap(keys, values) {
9
+ if (keys.length != values.length) {
10
+ throw new Error("keys and values should have the same length");
11
+ }
12
+ // Sanity check: verify that keys are actually sorted and with no duplicates
13
+ for (var i = 0; i < keys.length - 1; i++) {
14
+ if (keys[i].toString("hex") >= keys[i + 1].toString("hex")) {
15
+ throw new Error("keys must be in strictly increasing order");
16
+ }
17
+ }
18
+ this.keys = keys;
19
+ this.keysTree = new Merkle(keys.map(function (k) { return hashLeaf(k); }));
20
+ this.values = values;
21
+ this.valuesTree = new Merkle(values.map(function (v) { return hashLeaf(v); }));
22
+ }
23
+ MerkleMap.prototype.commitment = function () {
24
+ // returns a buffer between 65 and 73 (included) bytes long
25
+ return Buffer.concat([
26
+ createVarint(this.keys.length),
27
+ this.keysTree.getRoot(),
28
+ this.valuesTree.getRoot(),
29
+ ]);
30
+ };
31
+ return MerkleMap;
32
+ }());
33
+ export { MerkleMap };
34
+ //# sourceMappingURL=merkleMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merkleMap.js","sourceRoot":"","sources":["../../src/newops/merkleMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAE5C;IAKE;;;OAGG;IACH,mBAAY,IAAc,EAAE,MAAgB;QAC1C,IAAI,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE;YAChC,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;SAChE;QAED,4EAA4E;QAC5E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YACxC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBAC1D,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;aAC9D;SACF;QAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,QAAQ,CAAC,CAAC,CAAC,EAAX,CAAW,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,QAAQ,CAAC,CAAC,CAAC,EAAX,CAAW,CAAC,CAAC,CAAC;IAC/D,CAAC;IAED,8BAAU,GAAV;QACE,2DAA2D;QAC3D,OAAO,MAAM,CAAC,MAAM,CAAC;YACnB,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YAC9B,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;YACvB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE;SAC1B,CAAC,CAAC;IACL,CAAC;IACH,gBAAC;AAAD,CAAC,AAnCD,IAmCC"}
@@ -0,0 +1,14 @@
1
+ /// <reference types="node" />
2
+ export declare type DefaultDescriptorTemplate = "pkh(@0)" | "sh(wpkh(@0))" | "wpkh(@0)" | "tr(@0)";
3
+ export declare class WalletPolicy {
4
+ descriptorTemplate: string;
5
+ keys: string[];
6
+ /**
7
+ * For now, we only support default descriptor templates.
8
+ */
9
+ constructor(descriptorTemplate: DefaultDescriptorTemplate, key: string);
10
+ getWalletId(): Buffer;
11
+ serialize(): Buffer;
12
+ }
13
+ export declare function createKey(masterFingerprint: Buffer, path: number[], xpub: string): string;
14
+ //# sourceMappingURL=policy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../src/newops/policy.ts"],"names":[],"mappings":";AAKA,oBAAY,yBAAyB,GACjC,SAAS,GACT,cAAc,GACd,UAAU,GACV,QAAQ,CAAC;AAEb,qBAAa,YAAY;IACvB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,IAAI,EAAE,MAAM,EAAE,CAAC;IACf;;OAEG;gBACS,kBAAkB,EAAE,yBAAyB,EAAE,GAAG,EAAE,MAAM;IAKtE,WAAW,IAAI,MAAM;IAKrB,SAAS,IAAI,MAAM;CAapB;AAED,wBAAgB,SAAS,CACvB,iBAAiB,EAAE,MAAM,EACzB,IAAI,EAAE,MAAM,EAAE,EACd,IAAI,EAAE,MAAM,GACX,MAAM,CAKR"}
@@ -0,0 +1,36 @@
1
+ import { pathArrayToString } from "../bip32";
2
+ import { BufferWriter } from "../buffertools";
3
+ import { crypto } from "bitcoinjs-lib";
4
+ import { Merkle, hashLeaf } from "./merkle";
5
+ var WalletPolicy = /** @class */ (function () {
6
+ /**
7
+ * For now, we only support default descriptor templates.
8
+ */
9
+ function WalletPolicy(descriptorTemplate, key) {
10
+ this.descriptorTemplate = descriptorTemplate;
11
+ this.keys = [key];
12
+ }
13
+ WalletPolicy.prototype.getWalletId = function () {
14
+ // wallet_id (sha256 of the wallet serialization),
15
+ return crypto.sha256(this.serialize());
16
+ };
17
+ WalletPolicy.prototype.serialize = function () {
18
+ var keyBuffers = this.keys.map(function (k) {
19
+ return Buffer.from(k, "ascii");
20
+ });
21
+ var m = new Merkle(keyBuffers.map(function (k) { return hashLeaf(k); }));
22
+ var buf = new BufferWriter();
23
+ buf.writeUInt8(0x01); // wallet type (policy map)
24
+ buf.writeUInt8(0); // length of wallet name (empty string for default wallets)
25
+ buf.writeVarSlice(Buffer.from(this.descriptorTemplate, "ascii"));
26
+ buf.writeVarInt(this.keys.length), buf.writeSlice(m.getRoot());
27
+ return buf.buffer();
28
+ };
29
+ return WalletPolicy;
30
+ }());
31
+ export { WalletPolicy };
32
+ export function createKey(masterFingerprint, path, xpub) {
33
+ var accountPath = pathArrayToString(path);
34
+ return "[" + masterFingerprint.toString("hex") + accountPath.substring(1) + "]" + xpub + "/**";
35
+ }
36
+ //# sourceMappingURL=policy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/newops/policy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAQ5C;IAGE;;OAEG;IACH,sBAAY,kBAA6C,EAAE,GAAW;QACpE,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;QAC7C,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IACpB,CAAC;IAED,kCAAW,GAAX;QACE,kDAAkD;QAClD,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,gCAAS,GAAT;QACE,IAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,CAAC;YACjC,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,IAAM,CAAC,GAAG,IAAI,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,UAAC,CAAC,IAAK,OAAA,QAAQ,CAAC,CAAC,CAAC,EAAX,CAAW,CAAC,CAAC,CAAC;QAEzD,IAAM,GAAG,GAAG,IAAI,YAAY,EAAE,CAAC;QAC/B,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,2BAA2B;QACjD,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,2DAA2D;QAC9E,GAAG,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,OAAO,CAAC,CAAC,CAAC;QACjE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC/D,OAAO,GAAG,CAAC,MAAM,EAAE,CAAC;IACtB,CAAC;IACH,mBAAC;AAAD,CAAC,AA7BD,IA6BC;;AAED,MAAM,UAAU,SAAS,CACvB,iBAAyB,EACzB,IAAc,EACd,IAAY;IAEZ,IAAM,WAAW,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAC5C,OAAO,MAAI,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,WAAW,CAAC,SAAS,CAClE,CAAC,CACF,SAAI,IAAI,QAAK,CAAC;AACjB,CAAC"}
@@ -0,0 +1,4 @@
1
+ /// <reference types="node" />
2
+ import { PsbtV2 } from "./psbtv2";
3
+ export declare function extract(psbt: PsbtV2): Buffer;
4
+ //# sourceMappingURL=psbtExtractor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"psbtExtractor.d.ts","sourceRoot":"","sources":["../../src/newops/psbtExtractor.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CA6B5C"}
@@ -0,0 +1,32 @@
1
+ import { BufferWriter } from "../buffertools";
2
+ export function extract(psbt) {
3
+ var _a, _b;
4
+ var tx = new BufferWriter();
5
+ tx.writeUInt32(psbt.getGlobalTxVersion());
6
+ var isSegwit = !!psbt.getInputWitnessUtxo(0);
7
+ if (isSegwit) {
8
+ tx.writeSlice(Buffer.of(0, 1));
9
+ }
10
+ var inputCount = psbt.getGlobalInputCount();
11
+ tx.writeVarInt(inputCount);
12
+ var witnessWriter = new BufferWriter();
13
+ for (var i = 0; i < inputCount; i++) {
14
+ tx.writeSlice(psbt.getInputPreviousTxid(i));
15
+ tx.writeUInt32(psbt.getInputOutputIndex(i));
16
+ tx.writeVarSlice((_a = psbt.getInputFinalScriptsig(i)) !== null && _a !== void 0 ? _a : Buffer.of());
17
+ tx.writeUInt32(psbt.getInputSequence(i));
18
+ if (isSegwit) {
19
+ witnessWriter.writeSlice(psbt.getInputFinalScriptwitness(i));
20
+ }
21
+ }
22
+ var outputCount = psbt.getGlobalOutputCount();
23
+ tx.writeVarInt(outputCount);
24
+ for (var i = 0; i < outputCount; i++) {
25
+ tx.writeUInt64(BigInt(psbt.getOutputAmount(i)));
26
+ tx.writeVarSlice(psbt.getOutputScript(i));
27
+ }
28
+ tx.writeSlice(witnessWriter.buffer());
29
+ tx.writeUInt32((_b = psbt.getGlobalFallbackLocktime()) !== null && _b !== void 0 ? _b : 0);
30
+ return tx.buffer();
31
+ }
32
+ //# sourceMappingURL=psbtExtractor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"psbtExtractor.js","sourceRoot":"","sources":["../../src/newops/psbtExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,MAAM,UAAU,OAAO,CAAC,IAAY;;IAClC,IAAM,EAAE,GAAG,IAAI,YAAY,EAAE,CAAC;IAC9B,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;IAE1C,IAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAC/C,IAAI,QAAQ,EAAE;QACZ,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KAChC;IACD,IAAM,UAAU,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC9C,EAAE,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IAC3B,IAAM,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE;QACnC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,EAAE,CAAC,aAAa,CAAC,MAAA,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,mCAAI,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;QAChE,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;QACzC,IAAI,QAAQ,EAAE;YACZ,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC;SAC9D;KACF;IACD,IAAM,WAAW,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChD,EAAE,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,EAAE,EAAE;QACpC,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChD,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;KAC3C;IACD,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC,CAAC;IACtC,EAAE,CAAC,WAAW,CAAC,MAAA,IAAI,CAAC,yBAAyB,EAAE,mCAAI,CAAC,CAAC,CAAC;IACtD,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC;AACrB,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { PsbtV2 } from "./psbtv2";
2
+ /**
3
+ *
4
+ * @param psbt The psbt with all signatures added as partial sigs, either through PSBT_IN_PARTIAL_SIG or PSBT_IN_TAP_KEY_SIG
5
+ */
6
+ export declare function finalize(psbt: PsbtV2): void;
7
+ //# sourceMappingURL=psbtFinalizer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"psbtFinalizer.d.ts","sourceRoot":"","sources":["../../src/newops/psbtFinalizer.ts"],"names":[],"mappings":"AACA,OAAO,EAAU,MAAM,EAAE,MAAM,UAAU,CAAC;AAE1C;;;GAGG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAqE3C"}
@@ -0,0 +1,107 @@
1
+ import { BufferWriter } from "../buffertools";
2
+ import { psbtIn } from "./psbtv2";
3
+ /**
4
+ *
5
+ * @param psbt The psbt with all signatures added as partial sigs, either through PSBT_IN_PARTIAL_SIG or PSBT_IN_TAP_KEY_SIG
6
+ */
7
+ export function finalize(psbt) {
8
+ // First check that each input has a signature
9
+ var inputCount = psbt.getGlobalInputCount();
10
+ for (var i = 0; i < inputCount; i++) {
11
+ var legacyPubkeys = psbt.getInputKeyDatas(i, psbtIn.PARTIAL_SIG);
12
+ var taprootSig = psbt.getInputTapKeySig(i);
13
+ if (legacyPubkeys.length == 0 && !taprootSig) {
14
+ throw Error("No signature for input " + i + " present");
15
+ }
16
+ if (legacyPubkeys.length > 0) {
17
+ if (legacyPubkeys.length > 1) {
18
+ throw Error("Expected exactly one signature, got " + legacyPubkeys.length);
19
+ }
20
+ if (taprootSig) {
21
+ throw Error("Both taproot and non-taproot signatures present.");
22
+ }
23
+ var isSegwitV0 = !!psbt.getInputWitnessUtxo(i);
24
+ var redeemScript = psbt.getInputRedeemScript(i);
25
+ var isWrappedSegwit = !!redeemScript;
26
+ var signature = psbt.getInputPartialSig(i, legacyPubkeys[0]);
27
+ if (!signature)
28
+ throw new Error("Expected partial signature for input " + i);
29
+ if (isSegwitV0) {
30
+ var witnessBuf = new BufferWriter();
31
+ witnessBuf.writeVarInt(2);
32
+ witnessBuf.writeVarInt(signature.length);
33
+ witnessBuf.writeSlice(signature);
34
+ witnessBuf.writeVarInt(legacyPubkeys[0].length);
35
+ witnessBuf.writeSlice(legacyPubkeys[0]);
36
+ psbt.setInputFinalScriptwitness(i, witnessBuf.buffer());
37
+ if (isWrappedSegwit) {
38
+ if (!redeemScript || redeemScript.length == 0) {
39
+ throw new Error("Expected non-empty redeemscript. Can't finalize intput " + i);
40
+ }
41
+ var scriptSigBuf = new BufferWriter();
42
+ // Push redeemScript length
43
+ scriptSigBuf.writeUInt8(redeemScript.length);
44
+ scriptSigBuf.writeSlice(redeemScript);
45
+ psbt.setInputFinalScriptsig(i, scriptSigBuf.buffer());
46
+ }
47
+ }
48
+ else {
49
+ // Legacy input
50
+ var scriptSig = new BufferWriter();
51
+ writePush(scriptSig, signature);
52
+ writePush(scriptSig, legacyPubkeys[0]);
53
+ psbt.setInputFinalScriptsig(i, scriptSig.buffer());
54
+ }
55
+ }
56
+ else {
57
+ // Taproot input
58
+ var signature = psbt.getInputTapKeySig(i);
59
+ if (!signature) {
60
+ throw Error("No taproot signature found");
61
+ }
62
+ if (signature.length != 64) {
63
+ throw Error("Unexpected length of schnorr signature.");
64
+ }
65
+ var witnessBuf = new BufferWriter();
66
+ witnessBuf.writeVarInt(1);
67
+ witnessBuf.writeVarInt(64);
68
+ witnessBuf.writeSlice(signature);
69
+ psbt.setInputFinalScriptwitness(i, witnessBuf.buffer());
70
+ }
71
+ clearFinalizedInput(psbt, i);
72
+ }
73
+ }
74
+ function clearFinalizedInput(psbt, inputIndex) {
75
+ var keyTypes = [
76
+ psbtIn.BIP32_DERIVATION,
77
+ psbtIn.PARTIAL_SIG,
78
+ psbtIn.TAP_BIP32_DERIVATION,
79
+ psbtIn.TAP_KEY_SIG,
80
+ ];
81
+ var witnessUtxoAvailable = !!psbt.getInputWitnessUtxo(inputIndex);
82
+ var nonWitnessUtxoAvailable = !!psbt.getInputNonWitnessUtxo(inputIndex);
83
+ if (witnessUtxoAvailable && nonWitnessUtxoAvailable) {
84
+ // Remove NON_WITNESS_UTXO for segwit v0 as it's only needed while signing.
85
+ // Segwit v1 doesn't have NON_WITNESS_UTXO set.
86
+ // See https://github.com/bitcoin/bips/blob/master/bip-0174.mediawiki#cite_note-7
87
+ keyTypes.push(psbtIn.NON_WITNESS_UTXO);
88
+ }
89
+ psbt.deleteInputEntries(inputIndex, keyTypes);
90
+ }
91
+ function writePush(buf, data) {
92
+ if (data.length <= 75) {
93
+ buf.writeUInt8(data.length);
94
+ }
95
+ else if (data.length <= 256) {
96
+ buf.writeUInt8(76);
97
+ buf.writeUInt8(data.length);
98
+ }
99
+ else if (data.length <= 256 * 256) {
100
+ buf.writeUInt8(77);
101
+ var b = Buffer.alloc(2);
102
+ b.writeUInt16LE(data.length, 0);
103
+ buf.writeSlice(b);
104
+ }
105
+ buf.writeSlice(data);
106
+ }
107
+ //# sourceMappingURL=psbtFinalizer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"psbtFinalizer.js","sourceRoot":"","sources":["../../src/newops/psbtFinalizer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAU,MAAM,UAAU,CAAC;AAE1C;;;GAGG;AACH,MAAM,UAAU,QAAQ,CAAC,IAAY;IACnC,8CAA8C;IAC9C,IAAM,UAAU,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC9C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE;QACnC,IAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;QACnE,IAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,aAAa,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAC5C,MAAM,KAAK,CAAC,4BAA0B,CAAC,aAAU,CAAC,CAAC;SACpD;QACD,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5B,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC5B,MAAM,KAAK,CACT,yCAAuC,aAAa,CAAC,MAAQ,CAC9D,CAAC;aACH;YACD,IAAI,UAAU,EAAE;gBACd,MAAM,KAAK,CAAC,kDAAkD,CAAC,CAAC;aACjE;YAED,IAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;YACjD,IAAM,YAAY,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC;YAClD,IAAM,eAAe,GAAG,CAAC,CAAC,YAAY,CAAC;YACvC,IAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS;gBACZ,MAAM,IAAI,KAAK,CAAC,uCAAuC,GAAG,CAAC,CAAC,CAAC;YAC/D,IAAI,UAAU,EAAE;gBACd,IAAM,UAAU,GAAG,IAAI,YAAY,EAAE,CAAC;gBACtC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAC1B,UAAU,CAAC,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBACzC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;gBACjC,UAAU,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBAChD,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,0BAA0B,CAAC,CAAC,EAAE,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;gBACxD,IAAI,eAAe,EAAE;oBACnB,IAAI,CAAC,YAAY,IAAI,YAAY,CAAC,MAAM,IAAI,CAAC,EAAE;wBAC7C,MAAM,IAAI,KAAK,CACb,yDAAyD,GAAG,CAAC,CAC9D,CAAC;qBACH;oBACD,IAAM,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;oBACxC,2BAA2B;oBAC3B,YAAY,CAAC,UAAU,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;oBAC7C,YAAY,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;oBACtC,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC;iBACvD;aACF;iBAAM;gBACL,eAAe;gBACf,IAAM,SAAS,GAAG,IAAI,YAAY,EAAE,CAAC;gBACrC,SAAS,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;gBAChC,SAAS,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvC,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;aACpD;SACF;aAAM;YACL,gBAAgB;YAChB,IAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC5C,IAAI,CAAC,SAAS,EAAE;gBACd,MAAM,KAAK,CAAC,4BAA4B,CAAC,CAAC;aAC3C;YACD,IAAI,SAAS,CAAC,MAAM,IAAI,EAAE,EAAE;gBAC1B,MAAM,KAAK,CAAC,yCAAyC,CAAC,CAAC;aACxD;YACD,IAAM,UAAU,GAAG,IAAI,YAAY,EAAE,CAAC;YACtC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YAC1B,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YAC3B,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,CAAC,0BAA0B,CAAC,CAAC,EAAE,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;SACzD;QACD,mBAAmB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;KAC9B;AACH,CAAC;AAED,SAAS,mBAAmB,CAAC,IAAY,EAAE,UAAkB;IAC3D,IAAM,QAAQ,GAAG;QACf,MAAM,CAAC,gBAAgB;QACvB,MAAM,CAAC,WAAW;QAClB,MAAM,CAAC,oBAAoB;QAC3B,MAAM,CAAC,WAAW;KACnB,CAAC;IACF,IAAM,oBAAoB,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IACpE,IAAM,uBAAuB,GAAG,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC;IAC1E,IAAI,oBAAoB,IAAI,uBAAuB,EAAE;QACnD,2EAA2E;QAC3E,+CAA+C;QAC/C,iFAAiF;QACjF,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;KACxC;IACD,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;AAChD,CAAC;AAED,SAAS,SAAS,CAAC,GAAiB,EAAE,IAAY;IAChD,IAAI,IAAI,CAAC,MAAM,IAAI,EAAE,EAAE;QACrB,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;KAC7B;SAAM,IAAI,IAAI,CAAC,MAAM,IAAI,GAAG,EAAE;QAC7B,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACnB,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;KAC7B;SAAM,IAAI,IAAI,CAAC,MAAM,IAAI,GAAG,GAAG,GAAG,EAAE;QACnC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACnB,IAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAChC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;KACnB;IACD,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;AACvB,CAAC"}