@ledgerhq/hw-app-btc 10.0.1 → 10.0.2-nightly.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 (166) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +7 -0
  3. package/lib/Btc.d.ts.map +1 -1
  4. package/lib/Btc.js +72 -97
  5. package/lib/Btc.js.map +1 -1
  6. package/lib/BtcNew.js +217 -313
  7. package/lib/BtcNew.js.map +1 -1
  8. package/lib/BtcOld.js +46 -106
  9. package/lib/BtcOld.js.map +1 -1
  10. package/lib/bip32.js +12 -12
  11. package/lib/bip32.js.map +1 -1
  12. package/lib/buffertools.js +66 -69
  13. package/lib/buffertools.js.map +1 -1
  14. package/lib/compressPublicKey.js +3 -3
  15. package/lib/compressPublicKey.js.map +1 -1
  16. package/lib/constants.js +1 -1
  17. package/lib/createTransaction.d.ts +1 -1
  18. package/lib/createTransaction.d.ts.map +1 -1
  19. package/lib/createTransaction.js +285 -398
  20. package/lib/createTransaction.js.map +1 -1
  21. package/lib/debug.js +11 -13
  22. package/lib/debug.js.map +1 -1
  23. package/lib/finalizeInput.js +23 -62
  24. package/lib/finalizeInput.js.map +1 -1
  25. package/lib/getAppAndVersion.d.ts +1 -1
  26. package/lib/getAppAndVersion.d.ts.map +1 -1
  27. package/lib/getAppAndVersion.js +29 -72
  28. package/lib/getAppAndVersion.js.map +1 -1
  29. package/lib/getTrustedInput.js +108 -251
  30. package/lib/getTrustedInput.js.map +1 -1
  31. package/lib/getTrustedInputBIP143.js +9 -10
  32. package/lib/getTrustedInputBIP143.js.map +1 -1
  33. package/lib/getWalletPublicKey.d.ts +1 -1
  34. package/lib/getWalletPublicKey.d.ts.map +1 -1
  35. package/lib/getWalletPublicKey.js +27 -73
  36. package/lib/getWalletPublicKey.js.map +1 -1
  37. package/lib/hashPublicKey.js +4 -4
  38. package/lib/hashPublicKey.js.map +1 -1
  39. package/lib/index.js +3 -3
  40. package/lib/index.js.map +1 -1
  41. package/lib/newops/accounttype.d.ts +2 -2
  42. package/lib/newops/accounttype.d.ts.map +1 -1
  43. package/lib/newops/accounttype.js +85 -125
  44. package/lib/newops/accounttype.js.map +1 -1
  45. package/lib/newops/appClient.js +98 -205
  46. package/lib/newops/appClient.js.map +1 -1
  47. package/lib/newops/clientCommands.js +122 -213
  48. package/lib/newops/clientCommands.js.map +1 -1
  49. package/lib/newops/merkelizedPsbt.js +28 -75
  50. package/lib/newops/merkelizedPsbt.js.map +1 -1
  51. package/lib/newops/merkle.js +38 -67
  52. package/lib/newops/merkle.js.map +1 -1
  53. package/lib/newops/merkleMap.js +11 -12
  54. package/lib/newops/merkleMap.js.map +1 -1
  55. package/lib/newops/policy.d.ts +1 -1
  56. package/lib/newops/policy.d.ts.map +1 -1
  57. package/lib/newops/policy.js +17 -18
  58. package/lib/newops/policy.js.map +1 -1
  59. package/lib/newops/psbtExtractor.js +9 -9
  60. package/lib/newops/psbtExtractor.js.map +1 -1
  61. package/lib/newops/psbtFinalizer.js +22 -22
  62. package/lib/newops/psbtFinalizer.js.map +1 -1
  63. package/lib/newops/psbtv2.d.ts +1 -1
  64. package/lib/newops/psbtv2.d.ts.map +1 -1
  65. package/lib/newops/psbtv2.js +227 -286
  66. package/lib/newops/psbtv2.js.map +1 -1
  67. package/lib/serializeTransaction.js +13 -15
  68. package/lib/serializeTransaction.js.map +1 -1
  69. package/lib/shouldUseTrustedInputForSegwit.js +4 -5
  70. package/lib/shouldUseTrustedInputForSegwit.js.map +1 -1
  71. package/lib/signMessage.js +47 -99
  72. package/lib/signMessage.js.map +1 -1
  73. package/lib/signP2SHTransaction.d.ts +1 -1
  74. package/lib/signP2SHTransaction.d.ts.map +1 -1
  75. package/lib/signP2SHTransaction.js +91 -187
  76. package/lib/signP2SHTransaction.js.map +1 -1
  77. package/lib/signTransaction.js +8 -9
  78. package/lib/signTransaction.js.map +1 -1
  79. package/lib/splitTransaction.js +50 -54
  80. package/lib/splitTransaction.js.map +1 -1
  81. package/lib/startUntrustedHashTransactionInput.js +65 -167
  82. package/lib/startUntrustedHashTransactionInput.js.map +1 -1
  83. package/lib/types.js +1 -1
  84. package/lib/varint.js +10 -10
  85. package/lib/varint.js.map +1 -1
  86. package/lib-es/Btc.d.ts.map +1 -1
  87. package/lib-es/Btc.js +58 -84
  88. package/lib-es/Btc.js.map +1 -1
  89. package/lib-es/BtcNew.js +205 -302
  90. package/lib-es/BtcNew.js.map +1 -1
  91. package/lib-es/BtcOld.js +35 -96
  92. package/lib-es/BtcOld.js.map +1 -1
  93. package/lib-es/bip32.js +7 -7
  94. package/lib-es/bip32.js.map +1 -1
  95. package/lib-es/buffertools.js +62 -67
  96. package/lib-es/buffertools.js.map +1 -1
  97. package/lib-es/compressPublicKey.js +2 -2
  98. package/lib-es/compressPublicKey.js.map +1 -1
  99. package/lib-es/constants.js +12 -12
  100. package/lib-es/constants.js.map +1 -1
  101. package/lib-es/createTransaction.d.ts +1 -1
  102. package/lib-es/createTransaction.d.ts.map +1 -1
  103. package/lib-es/createTransaction.js +271 -384
  104. package/lib-es/createTransaction.js.map +1 -1
  105. package/lib-es/debug.js +10 -12
  106. package/lib-es/debug.js.map +1 -1
  107. package/lib-es/finalizeInput.js +20 -59
  108. package/lib-es/finalizeInput.js.map +1 -1
  109. package/lib-es/getAppAndVersion.d.ts +1 -1
  110. package/lib-es/getAppAndVersion.d.ts.map +1 -1
  111. package/lib-es/getAppAndVersion.js +27 -70
  112. package/lib-es/getAppAndVersion.js.map +1 -1
  113. package/lib-es/getTrustedInput.js +104 -247
  114. package/lib-es/getTrustedInput.js.map +1 -1
  115. package/lib-es/getTrustedInputBIP143.js +5 -6
  116. package/lib-es/getTrustedInputBIP143.js.map +1 -1
  117. package/lib-es/getWalletPublicKey.d.ts +1 -1
  118. package/lib-es/getWalletPublicKey.d.ts.map +1 -1
  119. package/lib-es/getWalletPublicKey.js +25 -71
  120. package/lib-es/getWalletPublicKey.js.map +1 -1
  121. package/lib-es/newops/accounttype.d.ts +2 -2
  122. package/lib-es/newops/accounttype.d.ts.map +1 -1
  123. package/lib-es/newops/accounttype.js +79 -123
  124. package/lib-es/newops/accounttype.js.map +1 -1
  125. package/lib-es/newops/appClient.js +92 -200
  126. package/lib-es/newops/appClient.js.map +1 -1
  127. package/lib-es/newops/clientCommands.js +117 -214
  128. package/lib-es/newops/clientCommands.js.map +1 -1
  129. package/lib-es/newops/merkelizedPsbt.js +25 -73
  130. package/lib-es/newops/merkelizedPsbt.js.map +1 -1
  131. package/lib-es/newops/merkle.js +36 -66
  132. package/lib-es/newops/merkle.js.map +1 -1
  133. package/lib-es/newops/merkleMap.js +8 -10
  134. package/lib-es/newops/merkleMap.js.map +1 -1
  135. package/lib-es/newops/policy.d.ts +1 -1
  136. package/lib-es/newops/policy.d.ts.map +1 -1
  137. package/lib-es/newops/policy.js +12 -14
  138. package/lib-es/newops/policy.js.map +1 -1
  139. package/lib-es/newops/psbtExtractor.js +7 -7
  140. package/lib-es/newops/psbtExtractor.js.map +1 -1
  141. package/lib-es/newops/psbtFinalizer.js +19 -19
  142. package/lib-es/newops/psbtFinalizer.js.map +1 -1
  143. package/lib-es/newops/psbtv2.d.ts +1 -1
  144. package/lib-es/newops/psbtv2.d.ts.map +1 -1
  145. package/lib-es/newops/psbtv2.js +225 -286
  146. package/lib-es/newops/psbtv2.js.map +1 -1
  147. package/lib-es/serializeTransaction.js +11 -13
  148. package/lib-es/serializeTransaction.js.map +1 -1
  149. package/lib-es/shouldUseTrustedInputForSegwit.js +1 -2
  150. package/lib-es/shouldUseTrustedInputForSegwit.js.map +1 -1
  151. package/lib-es/signMessage.js +44 -96
  152. package/lib-es/signMessage.js.map +1 -1
  153. package/lib-es/signP2SHTransaction.d.ts +1 -1
  154. package/lib-es/signP2SHTransaction.d.ts.map +1 -1
  155. package/lib-es/signP2SHTransaction.js +84 -180
  156. package/lib-es/signP2SHTransaction.js.map +1 -1
  157. package/lib-es/signTransaction.js +6 -7
  158. package/lib-es/signTransaction.js.map +1 -1
  159. package/lib-es/splitTransaction.js +46 -50
  160. package/lib-es/splitTransaction.js.map +1 -1
  161. package/lib-es/startUntrustedHashTransactionInput.js +62 -164
  162. package/lib-es/startUntrustedHashTransactionInput.js.map +1 -1
  163. package/lib-es/varint.js +9 -9
  164. package/lib-es/varint.js.map +1 -1
  165. package/package.json +5 -6
  166. package/src/Btc.ts +28 -5
@@ -8,267 +8,124 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
8
8
  step((generator = generator.apply(thisArg, _arguments || [])).next());
9
9
  });
10
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
11
  var __importDefault = (this && this.__importDefault) || function (mod) {
50
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
51
13
  };
52
- exports.__esModule = true;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
53
15
  exports.getTrustedInput = exports.getTrustedInputRaw = void 0;
54
- var invariant_1 = __importDefault(require("invariant"));
55
- var constants_1 = require("./constants");
56
- var varint_1 = require("./varint");
16
+ const invariant_1 = __importDefault(require("invariant"));
17
+ const constants_1 = require("./constants");
18
+ const varint_1 = require("./varint");
57
19
  function getTrustedInputRaw(transport, transactionData, indexLookup) {
58
- return __awaiter(this, void 0, void 0, function () {
59
- var data, firstRound, prefix, trustedInput, res;
60
- return __generator(this, function (_a) {
61
- switch (_a.label) {
62
- case 0:
63
- firstRound = false;
64
- if (typeof indexLookup === "number") {
65
- firstRound = true;
66
- prefix = Buffer.alloc(4);
67
- prefix.writeUInt32BE(indexLookup, 0);
68
- data = Buffer.concat([prefix, transactionData], transactionData.length + 4);
69
- }
70
- else {
71
- data = transactionData;
72
- }
73
- return [4 /*yield*/, transport.send(0xe0, 0x42, firstRound ? 0x00 : 0x80, 0x00, data)];
74
- case 1:
75
- trustedInput = _a.sent();
76
- res = trustedInput.slice(0, trustedInput.length - 2).toString("hex");
77
- return [2 /*return*/, res];
78
- }
79
- });
20
+ return __awaiter(this, void 0, void 0, function* () {
21
+ let data;
22
+ let firstRound = false;
23
+ if (typeof indexLookup === "number") {
24
+ firstRound = true;
25
+ const prefix = Buffer.alloc(4);
26
+ prefix.writeUInt32BE(indexLookup, 0);
27
+ data = Buffer.concat([prefix, transactionData], transactionData.length + 4);
28
+ }
29
+ else {
30
+ data = transactionData;
31
+ }
32
+ const trustedInput = yield transport.send(0xe0, 0x42, firstRound ? 0x00 : 0x80, 0x00, data);
33
+ const res = trustedInput.slice(0, trustedInput.length - 2).toString("hex");
34
+ return res;
80
35
  });
81
36
  }
82
37
  exports.getTrustedInputRaw = getTrustedInputRaw;
83
- function getTrustedInput(transport, indexLookup, transaction, additionals) {
84
- if (additionals === void 0) { additionals = []; }
85
- return __awaiter(this, void 0, void 0, function () {
86
- var version, inputs, outputs, locktime, nExpiryHeight, extraData, isDecred, isXST, processScriptBlocks, processWholeScriptBlock, inputs_1, inputs_1_1, input, isXSTV2, treeField, data, e_1_1, outputs_1, outputs_1_1, output, data, e_2_1, endData, extraPart, data, res;
87
- var e_1, _a, e_2, _b;
88
- var _this = this;
89
- return __generator(this, function (_c) {
90
- switch (_c.label) {
91
- case 0:
92
- version = transaction.version, inputs = transaction.inputs, outputs = transaction.outputs, locktime = transaction.locktime, nExpiryHeight = transaction.nExpiryHeight, extraData = transaction.extraData;
93
- if (!outputs || !locktime) {
94
- throw new Error("getTrustedInput: locktime & outputs is expected");
95
- }
96
- isDecred = additionals.includes("decred");
97
- isXST = additionals.includes("stealthcoin");
98
- processScriptBlocks = function (script, sequence) { return __awaiter(_this, void 0, void 0, function () {
99
- var seq, scriptBlocks, offset, blockSize, res, scriptBlocks_1, scriptBlocks_1_1, scriptBlock, e_3_1;
100
- var e_3, _a;
101
- return __generator(this, function (_b) {
102
- switch (_b.label) {
103
- case 0:
104
- seq = sequence || Buffer.alloc(0);
105
- scriptBlocks = [];
106
- offset = 0;
107
- while (offset !== script.length) {
108
- blockSize = script.length - offset > constants_1.MAX_SCRIPT_BLOCK
109
- ? constants_1.MAX_SCRIPT_BLOCK
110
- : script.length - offset;
111
- if (offset + blockSize !== script.length) {
112
- scriptBlocks.push(script.slice(offset, offset + blockSize));
113
- }
114
- else {
115
- scriptBlocks.push(Buffer.concat([script.slice(offset, offset + blockSize), seq]));
116
- }
117
- offset += blockSize;
118
- }
119
- // Handle case when no script length: we still want to pass the sequence
120
- // relatable: https://github.com/LedgerHQ/ledger-live-desktop/issues/1386
121
- if (script.length === 0) {
122
- scriptBlocks.push(seq);
123
- }
124
- _b.label = 1;
125
- case 1:
126
- _b.trys.push([1, 6, 7, 8]);
127
- scriptBlocks_1 = __values(scriptBlocks), scriptBlocks_1_1 = scriptBlocks_1.next();
128
- _b.label = 2;
129
- case 2:
130
- if (!!scriptBlocks_1_1.done) return [3 /*break*/, 5];
131
- scriptBlock = scriptBlocks_1_1.value;
132
- return [4 /*yield*/, getTrustedInputRaw(transport, scriptBlock)];
133
- case 3:
134
- res = _b.sent();
135
- _b.label = 4;
136
- case 4:
137
- scriptBlocks_1_1 = scriptBlocks_1.next();
138
- return [3 /*break*/, 2];
139
- case 5: return [3 /*break*/, 8];
140
- case 6:
141
- e_3_1 = _b.sent();
142
- e_3 = { error: e_3_1 };
143
- return [3 /*break*/, 8];
144
- case 7:
145
- try {
146
- if (scriptBlocks_1_1 && !scriptBlocks_1_1.done && (_a = scriptBlocks_1["return"])) _a.call(scriptBlocks_1);
147
- }
148
- finally { if (e_3) throw e_3.error; }
149
- return [7 /*endfinally*/];
150
- case 8: return [2 /*return*/, res];
151
- }
152
- });
153
- }); };
154
- processWholeScriptBlock = function (block) {
155
- return getTrustedInputRaw(transport, block);
156
- };
157
- return [4 /*yield*/, getTrustedInputRaw(transport, Buffer.concat([
158
- transaction.version,
159
- transaction.timestamp || Buffer.alloc(0),
160
- transaction.nVersionGroupId || Buffer.alloc(0),
161
- (0, varint_1.createVarint)(inputs.length),
162
- ]), indexLookup)];
163
- case 1:
164
- _c.sent();
165
- _c.label = 2;
166
- case 2:
167
- _c.trys.push([2, 8, 9, 10]);
168
- inputs_1 = __values(inputs), inputs_1_1 = inputs_1.next();
169
- _c.label = 3;
170
- case 3:
171
- if (!!inputs_1_1.done) return [3 /*break*/, 7];
172
- input = inputs_1_1.value;
173
- isXSTV2 = isXST &&
174
- Buffer.compare(version, Buffer.from([0x02, 0x00, 0x00, 0x00])) === 0;
175
- treeField = isDecred
176
- ? input.tree || Buffer.from([0x00])
177
- : Buffer.alloc(0);
178
- data = Buffer.concat([
179
- input.prevout,
180
- treeField,
181
- isXSTV2 ? Buffer.from([0x00]) : (0, varint_1.createVarint)(input.script.length),
182
- ]);
183
- return [4 /*yield*/, getTrustedInputRaw(transport, data)];
184
- case 4:
185
- _c.sent();
186
- // iteration (eachSeries) ended
187
- // TODO notify progress
188
- // deferred.notify("input");
189
- // Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
190
- return [4 /*yield*/, (isDecred
191
- ? processWholeScriptBlock(Buffer.concat([input.script, input.sequence]))
192
- : isXSTV2
193
- ? processWholeScriptBlock(input.sequence)
194
- : processScriptBlocks(input.script, input.sequence))];
195
- case 5:
196
- // iteration (eachSeries) ended
197
- // TODO notify progress
198
- // deferred.notify("input");
199
- // Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
200
- _c.sent();
201
- _c.label = 6;
202
- case 6:
203
- inputs_1_1 = inputs_1.next();
204
- return [3 /*break*/, 3];
205
- case 7: return [3 /*break*/, 10];
206
- case 8:
207
- e_1_1 = _c.sent();
208
- e_1 = { error: e_1_1 };
209
- return [3 /*break*/, 10];
210
- case 9:
211
- try {
212
- if (inputs_1_1 && !inputs_1_1.done && (_a = inputs_1["return"])) _a.call(inputs_1);
213
- }
214
- finally { if (e_1) throw e_1.error; }
215
- return [7 /*endfinally*/];
216
- case 10: return [4 /*yield*/, getTrustedInputRaw(transport, (0, varint_1.createVarint)(outputs.length))];
217
- case 11:
218
- _c.sent();
219
- _c.label = 12;
220
- case 12:
221
- _c.trys.push([12, 17, 18, 19]);
222
- outputs_1 = __values(outputs), outputs_1_1 = outputs_1.next();
223
- _c.label = 13;
224
- case 13:
225
- if (!!outputs_1_1.done) return [3 /*break*/, 16];
226
- output = outputs_1_1.value;
227
- data = Buffer.concat([
228
- output.amount,
229
- isDecred ? Buffer.from([0x00, 0x00]) : Buffer.alloc(0),
230
- (0, varint_1.createVarint)(output.script.length),
231
- output.script,
232
- ]);
233
- return [4 /*yield*/, getTrustedInputRaw(transport, data)];
234
- case 14:
235
- _c.sent();
236
- _c.label = 15;
237
- case 15:
238
- outputs_1_1 = outputs_1.next();
239
- return [3 /*break*/, 13];
240
- case 16: return [3 /*break*/, 19];
241
- case 17:
242
- e_2_1 = _c.sent();
243
- e_2 = { error: e_2_1 };
244
- return [3 /*break*/, 19];
245
- case 18:
246
- try {
247
- if (outputs_1_1 && !outputs_1_1.done && (_b = outputs_1["return"])) _b.call(outputs_1);
248
- }
249
- finally { if (e_2) throw e_2.error; }
250
- return [7 /*endfinally*/];
251
- case 19:
252
- endData = [];
253
- if (nExpiryHeight && nExpiryHeight.length > 0) {
254
- endData.push(nExpiryHeight);
255
- }
256
- if (extraData && extraData.length > 0) {
257
- endData.push(extraData);
258
- }
259
- if (endData.length) {
260
- data = Buffer.concat(endData);
261
- extraPart = isDecred
262
- ? data
263
- : Buffer.concat([(0, varint_1.createVarint)(data.length), data]);
264
- }
265
- return [4 /*yield*/, processScriptBlocks(Buffer.concat([locktime, extraPart || Buffer.alloc(0)]))];
266
- case 20:
267
- res = _c.sent();
268
- (0, invariant_1["default"])(res, "missing result in processScriptBlocks");
269
- return [2 /*return*/, res];
38
+ function getTrustedInput(transport, indexLookup, transaction, additionals = []) {
39
+ return __awaiter(this, void 0, void 0, function* () {
40
+ const { version, inputs, outputs, locktime, nExpiryHeight, extraData } = transaction;
41
+ if (!outputs || !locktime) {
42
+ throw new Error("getTrustedInput: locktime & outputs is expected");
43
+ }
44
+ const isDecred = additionals.includes("decred");
45
+ const isXST = additionals.includes("stealthcoin");
46
+ const processScriptBlocks = (script, sequence) => __awaiter(this, void 0, void 0, function* () {
47
+ const seq = sequence || Buffer.alloc(0);
48
+ const scriptBlocks = [];
49
+ let offset = 0;
50
+ while (offset !== script.length) {
51
+ const blockSize = script.length - offset > constants_1.MAX_SCRIPT_BLOCK
52
+ ? constants_1.MAX_SCRIPT_BLOCK
53
+ : script.length - offset;
54
+ if (offset + blockSize !== script.length) {
55
+ scriptBlocks.push(script.slice(offset, offset + blockSize));
56
+ }
57
+ else {
58
+ scriptBlocks.push(Buffer.concat([script.slice(offset, offset + blockSize), seq]));
59
+ }
60
+ offset += blockSize;
61
+ }
62
+ // Handle case when no script length: we still want to pass the sequence
63
+ // relatable: https://github.com/LedgerHQ/ledger-live-desktop/issues/1386
64
+ if (script.length === 0) {
65
+ scriptBlocks.push(seq);
270
66
  }
67
+ let res;
68
+ for (const scriptBlock of scriptBlocks) {
69
+ res = yield getTrustedInputRaw(transport, scriptBlock);
70
+ }
71
+ return res;
271
72
  });
73
+ const processWholeScriptBlock = (block) => getTrustedInputRaw(transport, block);
74
+ yield getTrustedInputRaw(transport, Buffer.concat([
75
+ transaction.version,
76
+ transaction.timestamp || Buffer.alloc(0),
77
+ transaction.nVersionGroupId || Buffer.alloc(0),
78
+ (0, varint_1.createVarint)(inputs.length),
79
+ ]), indexLookup);
80
+ for (const input of inputs) {
81
+ const isXSTV2 = isXST &&
82
+ Buffer.compare(version, Buffer.from([0x02, 0x00, 0x00, 0x00])) === 0;
83
+ const treeField = isDecred
84
+ ? input.tree || Buffer.from([0x00])
85
+ : Buffer.alloc(0);
86
+ const data = Buffer.concat([
87
+ input.prevout,
88
+ treeField,
89
+ isXSTV2 ? Buffer.from([0x00]) : (0, varint_1.createVarint)(input.script.length),
90
+ ]);
91
+ yield getTrustedInputRaw(transport, data);
92
+ // iteration (eachSeries) ended
93
+ // TODO notify progress
94
+ // deferred.notify("input");
95
+ // Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
96
+ yield (isDecred
97
+ ? processWholeScriptBlock(Buffer.concat([input.script, input.sequence]))
98
+ : isXSTV2
99
+ ? processWholeScriptBlock(input.sequence)
100
+ : processScriptBlocks(input.script, input.sequence));
101
+ }
102
+ yield getTrustedInputRaw(transport, (0, varint_1.createVarint)(outputs.length));
103
+ for (const output of outputs) {
104
+ const data = Buffer.concat([
105
+ output.amount,
106
+ isDecred ? Buffer.from([0x00, 0x00]) : Buffer.alloc(0),
107
+ (0, varint_1.createVarint)(output.script.length),
108
+ output.script,
109
+ ]);
110
+ yield getTrustedInputRaw(transport, data);
111
+ }
112
+ const endData = [];
113
+ if (nExpiryHeight && nExpiryHeight.length > 0) {
114
+ endData.push(nExpiryHeight);
115
+ }
116
+ if (extraData && extraData.length > 0) {
117
+ endData.push(extraData);
118
+ }
119
+ let extraPart;
120
+ if (endData.length) {
121
+ const data = Buffer.concat(endData);
122
+ extraPart = isDecred
123
+ ? data
124
+ : Buffer.concat([(0, varint_1.createVarint)(data.length), data]);
125
+ }
126
+ const res = yield processScriptBlocks(Buffer.concat([locktime, extraPart || Buffer.alloc(0)]));
127
+ (0, invariant_1.default)(res, "missing result in processScriptBlocks");
128
+ return res;
272
129
  });
273
130
  }
274
131
  exports.getTrustedInput = getTrustedInput;
@@ -1 +1 @@
1
- {"version":3,"file":"getTrustedInput.js","sourceRoot":"","sources":["../src/getTrustedInput.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"getTrustedInput.js","sourceRoot":"","sources":["../src/getTrustedInput.ts"],"names":[],"mappings":"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"}
@@ -2,25 +2,24 @@
2
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
- exports.__esModule = true;
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.getTrustedInputBIP143 = void 0;
7
- var sha_js_1 = __importDefault(require("sha.js"));
8
- var serializeTransaction_1 = require("./serializeTransaction");
9
- function getTrustedInputBIP143(transport, indexLookup, transaction, additionals) {
10
- if (additionals === void 0) { additionals = []; }
7
+ const sha_js_1 = __importDefault(require("sha.js"));
8
+ const serializeTransaction_1 = require("./serializeTransaction");
9
+ function getTrustedInputBIP143(transport, indexLookup, transaction, additionals = []) {
11
10
  if (!transaction) {
12
11
  throw new Error("getTrustedInputBIP143: missing tx");
13
12
  }
14
- var isDecred = additionals.includes("decred");
13
+ const isDecred = additionals.includes("decred");
15
14
  if (isDecred) {
16
15
  throw new Error("Decred does not implement BIP143");
17
16
  }
18
- var hash = (0, sha_js_1["default"])("sha256")
19
- .update((0, sha_js_1["default"])("sha256").update((0, serializeTransaction_1.serializeTransaction)(transaction, true)).digest())
17
+ let hash = (0, sha_js_1.default)("sha256")
18
+ .update((0, sha_js_1.default)("sha256").update((0, serializeTransaction_1.serializeTransaction)(transaction, true)).digest())
20
19
  .digest();
21
- var data = Buffer.alloc(4);
20
+ const data = Buffer.alloc(4);
22
21
  data.writeUInt32LE(indexLookup, 0);
23
- var outputs = transaction.outputs, locktime = transaction.locktime;
22
+ const { outputs, locktime } = transaction;
24
23
  if (!outputs || !locktime) {
25
24
  throw new Error("getTrustedInputBIP143: locktime & outputs is expected");
26
25
  }
@@ -1 +1 @@
1
- {"version":3,"file":"getTrustedInputBIP143.js","sourceRoot":"","sources":["../src/getTrustedInputBIP143.ts"],"names":[],"mappings":";;;;;;AACA,kDAA2B;AAE3B,+DAA8D;AAC9D,SAAgB,qBAAqB,CACnC,SAAoB,EACpB,WAAmB,EACnB,WAAwB,EACxB,WAA+B;IAA/B,4BAAA,EAAA,gBAA+B;IAE/B,IAAI,CAAC,WAAW,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;KACtD;IAED,IAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAEhD,IAAI,QAAQ,EAAE;QACZ,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IAED,IAAI,IAAI,GAAG,IAAA,mBAAK,EAAC,QAAQ,CAAC;SACvB,MAAM,CACL,IAAA,mBAAK,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAA,2CAAoB,EAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,CACzE;SACA,MAAM,EAAE,CAAC;IACZ,IAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAC3B,IAAA,OAAO,GAAe,WAAW,QAA1B,EAAE,QAAQ,GAAK,WAAW,SAAhB,CAAiB;IAE1C,IAAI,CAAC,OAAO,IAAI,CAAC,QAAQ,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KAC1E;IAED,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;KACvD;IAED,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAChE,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC;AAnCD,sDAmCC"}
1
+ {"version":3,"file":"getTrustedInputBIP143.js","sourceRoot":"","sources":["../src/getTrustedInputBIP143.ts"],"names":[],"mappings":";;;;;;AACA,oDAA2B;AAE3B,iEAA8D;AAC9D,SAAgB,qBAAqB,CACnC,SAAoB,EACpB,WAAmB,EACnB,WAAwB,EACxB,cAA6B,EAAE;IAE/B,IAAI,CAAC,WAAW,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;KACtD;IAED,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAEhD,IAAI,QAAQ,EAAE;QACZ,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IAED,IAAI,IAAI,GAAG,IAAA,gBAAK,EAAC,QAAQ,CAAC;SACvB,MAAM,CACL,IAAA,gBAAK,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAA,2CAAoB,EAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,CACzE;SACA,MAAM,EAAE,CAAC;IACZ,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IACnC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,WAAW,CAAC;IAE1C,IAAI,CAAC,OAAO,IAAI,CAAC,QAAQ,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KAC1E;IAED,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;KACvD;IAED,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAChE,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC;AAnCD,sDAmCC"}
@@ -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" | "bech32m" | "cashaddr";
5
+ export 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,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
+ {"version":3,"file":"getWalletPublicKey.d.ts","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAGpD;;GAEG;AACH,MAAM,MAAM,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,15 +1,4 @@
1
1
  "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
2
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
3
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
4
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -19,74 +8,39 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
19
8
  step((generator = generator.apply(thisArg, _arguments || [])).next());
20
9
  });
21
10
  };
22
- var __generator = (this && this.__generator) || function (thisArg, body) {
23
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
- function verb(n) { return function (v) { return step([n, v]); }; }
26
- function step(op) {
27
- if (f) throw new TypeError("Generator is already executing.");
28
- while (_) try {
29
- 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;
30
- if (y = 0, t) op = [op[0] & 2, t.value];
31
- switch (op[0]) {
32
- case 0: case 1: t = op; break;
33
- case 4: _.label++; return { value: op[1], done: false };
34
- case 5: _.label++; y = op[1]; op = [0]; continue;
35
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
- default:
37
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
- if (t[2]) _.ops.pop();
42
- _.trys.pop(); continue;
43
- }
44
- op = body.call(thisArg, _);
45
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
- }
48
- };
49
- exports.__esModule = true;
11
+ Object.defineProperty(exports, "__esModule", { value: true });
50
12
  exports.getWalletPublicKey = void 0;
51
- var bip32_1 = require("./bip32");
52
- var addressFormatMap = {
13
+ const bip32_1 = require("./bip32");
14
+ const addressFormatMap = {
53
15
  legacy: 0,
54
16
  p2sh: 1,
55
17
  bech32: 2,
56
- cashaddr: 3
18
+ cashaddr: 3,
57
19
  };
58
20
  function getWalletPublicKey(transport, options) {
59
- return __awaiter(this, void 0, void 0, function () {
60
- var _a, path, verify, format, buffer, p1, p2, response, publicKeyLength, addressLength, publicKey, bitcoinAddress, chainCode;
61
- return __generator(this, function (_b) {
62
- switch (_b.label) {
63
- case 0:
64
- _a = __assign({ verify: false, format: "legacy" }, options), path = _a.path, verify = _a.verify, format = _a.format;
65
- if (!(format in addressFormatMap)) {
66
- throw new Error("btc.getWalletPublicKey invalid format=" + format);
67
- }
68
- buffer = (0, bip32_1.bip32asBuffer)(path);
69
- p1 = verify ? 1 : 0;
70
- p2 = addressFormatMap[format];
71
- return [4 /*yield*/, transport.send(0xe0, 0x40, p1, p2, buffer)];
72
- case 1:
73
- response = _b.sent();
74
- publicKeyLength = response[0];
75
- addressLength = response[1 + publicKeyLength];
76
- publicKey = response.slice(1, 1 + publicKeyLength).toString("hex");
77
- bitcoinAddress = response
78
- .slice(1 + publicKeyLength + 1, 1 + publicKeyLength + 1 + addressLength)
79
- .toString("ascii");
80
- chainCode = response
81
- .slice(1 + publicKeyLength + 1 + addressLength, 1 + publicKeyLength + 1 + addressLength + 32)
82
- .toString("hex");
83
- return [2 /*return*/, {
84
- publicKey: publicKey,
85
- bitcoinAddress: bitcoinAddress,
86
- chainCode: chainCode
87
- }];
88
- }
89
- });
21
+ return __awaiter(this, void 0, void 0, function* () {
22
+ const { path, verify, format } = Object.assign({ verify: false, format: "legacy" }, options);
23
+ if (!(format in addressFormatMap)) {
24
+ throw new Error("btc.getWalletPublicKey invalid format=" + format);
25
+ }
26
+ const buffer = (0, bip32_1.bip32asBuffer)(path);
27
+ const p1 = verify ? 1 : 0;
28
+ const p2 = addressFormatMap[format];
29
+ const response = yield transport.send(0xe0, 0x40, p1, p2, buffer);
30
+ const publicKeyLength = response[0];
31
+ const addressLength = response[1 + publicKeyLength];
32
+ const publicKey = response.slice(1, 1 + publicKeyLength).toString("hex");
33
+ const bitcoinAddress = response
34
+ .slice(1 + publicKeyLength + 1, 1 + publicKeyLength + 1 + addressLength)
35
+ .toString("ascii");
36
+ const chainCode = response
37
+ .slice(1 + publicKeyLength + 1 + addressLength, 1 + publicKeyLength + 1 + addressLength + 32)
38
+ .toString("hex");
39
+ return {
40
+ publicKey,
41
+ bitcoinAddress,
42
+ chainCode,
43
+ };
90
44
  });
91
45
  }
92
46
  exports.getWalletPublicKey = getWalletPublicKey;
@@ -1 +1 @@
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
+ {"version":3,"file":"getWalletPublicKey.js","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,mCAAwC;AAWxC,MAAM,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;;QAMD,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,mBAC5B,MAAM,EAAE,KAAK,EACb,MAAM,EAAE,QAAQ,IACb,OAAO,CACX,CAAC;QAEF,IAAI,CAAC,CAAC,MAAM,IAAI,gBAAgB,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,wCAAwC,GAAG,MAAM,CAAC,CAAC;SACpE;QAED,MAAM,MAAM,GAAG,IAAA,qBAAa,EAAC,IAAI,CAAC,CAAC;QACnC,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QAClE,MAAM,eAAe,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACpC,MAAM,aAAa,GAAG,QAAQ,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC;QACpD,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACzE,MAAM,cAAc,GAAG,QAAQ;aAC5B,KAAK,CAAC,CAAC,GAAG,eAAe,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,CAAC;aACvE,QAAQ,CAAC,OAAO,CAAC,CAAC;QACrB,MAAM,SAAS,GAAG,QAAQ;aACvB,KAAK,CACJ,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,EACvC,CAAC,GAAG,eAAe,GAAG,CAAC,GAAG,aAAa,GAAG,EAAE,CAC7C;aACA,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnB,OAAO;YACL,SAAS;YACT,cAAc;YACd,SAAS;SACV,CAAC;IACJ,CAAC;CAAA;AA3CD,gDA2CC"}
@@ -2,12 +2,12 @@
2
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
- exports.__esModule = true;
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.hashPublicKey = void 0;
7
- var ripemd160_1 = __importDefault(require("ripemd160"));
8
- var sha_js_1 = __importDefault(require("sha.js"));
7
+ const ripemd160_1 = __importDefault(require("ripemd160"));
8
+ const sha_js_1 = __importDefault(require("sha.js"));
9
9
  function hashPublicKey(buffer) {
10
- return new ripemd160_1["default"]().update((0, sha_js_1["default"])("sha256").update(buffer).digest()).digest();
10
+ return new ripemd160_1.default().update((0, sha_js_1.default)("sha256").update(buffer).digest()).digest();
11
11
  }
12
12
  exports.hashPublicKey = hashPublicKey;
13
13
  //# sourceMappingURL=hashPublicKey.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"hashPublicKey.js","sourceRoot":"","sources":["../src/hashPublicKey.ts"],"names":[],"mappings":";;;;;;AAAA,wDAAkC;AAClC,kDAAyB;AACzB,SAAgB,aAAa,CAAC,MAAc;IAC1C,OAAO,IAAI,sBAAS,EAAE,CAAC,MAAM,CAAC,IAAA,mBAAG,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;AAChF,CAAC;AAFD,sCAEC"}
1
+ {"version":3,"file":"hashPublicKey.js","sourceRoot":"","sources":["../src/hashPublicKey.ts"],"names":[],"mappings":";;;;;;AAAA,0DAAkC;AAClC,oDAAyB;AACzB,SAAgB,aAAa,CAAC,MAAc;IAC1C,OAAO,IAAI,mBAAS,EAAE,CAAC,MAAM,CAAC,IAAA,gBAAG,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;AAChF,CAAC;AAFD,sCAEC"}