@ledgerhq/hw-app-btc 10.0.1 → 10.0.2-next.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.
- package/CHANGELOG.md +7 -0
- package/lib/Btc.d.ts.map +1 -1
- package/lib/Btc.js +72 -97
- package/lib/Btc.js.map +1 -1
- package/lib/BtcNew.js +217 -313
- package/lib/BtcNew.js.map +1 -1
- package/lib/BtcOld.js +46 -106
- package/lib/BtcOld.js.map +1 -1
- package/lib/bip32.js +12 -12
- package/lib/bip32.js.map +1 -1
- package/lib/buffertools.js +66 -69
- package/lib/buffertools.js.map +1 -1
- package/lib/compressPublicKey.js +3 -3
- package/lib/compressPublicKey.js.map +1 -1
- package/lib/constants.js +1 -1
- package/lib/createTransaction.d.ts +1 -1
- package/lib/createTransaction.d.ts.map +1 -1
- package/lib/createTransaction.js +285 -398
- package/lib/createTransaction.js.map +1 -1
- package/lib/debug.js +11 -13
- package/lib/debug.js.map +1 -1
- package/lib/finalizeInput.js +23 -62
- package/lib/finalizeInput.js.map +1 -1
- package/lib/getAppAndVersion.d.ts +1 -1
- package/lib/getAppAndVersion.d.ts.map +1 -1
- package/lib/getAppAndVersion.js +29 -72
- package/lib/getAppAndVersion.js.map +1 -1
- package/lib/getTrustedInput.js +108 -251
- package/lib/getTrustedInput.js.map +1 -1
- package/lib/getTrustedInputBIP143.js +9 -10
- package/lib/getTrustedInputBIP143.js.map +1 -1
- package/lib/getWalletPublicKey.d.ts +1 -1
- package/lib/getWalletPublicKey.d.ts.map +1 -1
- package/lib/getWalletPublicKey.js +27 -73
- package/lib/getWalletPublicKey.js.map +1 -1
- package/lib/hashPublicKey.js +4 -4
- package/lib/hashPublicKey.js.map +1 -1
- package/lib/index.js +3 -3
- package/lib/index.js.map +1 -1
- package/lib/newops/accounttype.d.ts +2 -2
- package/lib/newops/accounttype.d.ts.map +1 -1
- package/lib/newops/accounttype.js +85 -125
- package/lib/newops/accounttype.js.map +1 -1
- package/lib/newops/appClient.js +98 -205
- package/lib/newops/appClient.js.map +1 -1
- package/lib/newops/clientCommands.js +122 -213
- package/lib/newops/clientCommands.js.map +1 -1
- package/lib/newops/merkelizedPsbt.js +28 -75
- package/lib/newops/merkelizedPsbt.js.map +1 -1
- package/lib/newops/merkle.js +38 -67
- package/lib/newops/merkle.js.map +1 -1
- package/lib/newops/merkleMap.js +11 -12
- package/lib/newops/merkleMap.js.map +1 -1
- package/lib/newops/policy.d.ts +1 -1
- package/lib/newops/policy.d.ts.map +1 -1
- package/lib/newops/policy.js +17 -18
- package/lib/newops/policy.js.map +1 -1
- package/lib/newops/psbtExtractor.js +9 -9
- package/lib/newops/psbtExtractor.js.map +1 -1
- package/lib/newops/psbtFinalizer.js +22 -22
- package/lib/newops/psbtFinalizer.js.map +1 -1
- package/lib/newops/psbtv2.d.ts +1 -1
- package/lib/newops/psbtv2.d.ts.map +1 -1
- package/lib/newops/psbtv2.js +227 -286
- package/lib/newops/psbtv2.js.map +1 -1
- package/lib/serializeTransaction.js +13 -15
- package/lib/serializeTransaction.js.map +1 -1
- package/lib/shouldUseTrustedInputForSegwit.js +4 -5
- package/lib/shouldUseTrustedInputForSegwit.js.map +1 -1
- package/lib/signMessage.js +47 -99
- package/lib/signMessage.js.map +1 -1
- package/lib/signP2SHTransaction.d.ts +1 -1
- package/lib/signP2SHTransaction.d.ts.map +1 -1
- package/lib/signP2SHTransaction.js +91 -187
- package/lib/signP2SHTransaction.js.map +1 -1
- package/lib/signTransaction.js +8 -9
- package/lib/signTransaction.js.map +1 -1
- package/lib/splitTransaction.js +50 -54
- package/lib/splitTransaction.js.map +1 -1
- package/lib/startUntrustedHashTransactionInput.js +65 -167
- package/lib/startUntrustedHashTransactionInput.js.map +1 -1
- package/lib/types.js +1 -1
- package/lib/varint.js +10 -10
- package/lib/varint.js.map +1 -1
- package/lib-es/Btc.d.ts.map +1 -1
- package/lib-es/Btc.js +58 -84
- package/lib-es/Btc.js.map +1 -1
- package/lib-es/BtcNew.js +205 -302
- package/lib-es/BtcNew.js.map +1 -1
- package/lib-es/BtcOld.js +35 -96
- package/lib-es/BtcOld.js.map +1 -1
- package/lib-es/bip32.js +7 -7
- package/lib-es/bip32.js.map +1 -1
- package/lib-es/buffertools.js +62 -67
- package/lib-es/buffertools.js.map +1 -1
- package/lib-es/compressPublicKey.js +2 -2
- package/lib-es/compressPublicKey.js.map +1 -1
- package/lib-es/constants.js +12 -12
- package/lib-es/constants.js.map +1 -1
- package/lib-es/createTransaction.d.ts +1 -1
- package/lib-es/createTransaction.d.ts.map +1 -1
- package/lib-es/createTransaction.js +271 -384
- package/lib-es/createTransaction.js.map +1 -1
- package/lib-es/debug.js +10 -12
- package/lib-es/debug.js.map +1 -1
- package/lib-es/finalizeInput.js +20 -59
- package/lib-es/finalizeInput.js.map +1 -1
- package/lib-es/getAppAndVersion.d.ts +1 -1
- package/lib-es/getAppAndVersion.d.ts.map +1 -1
- package/lib-es/getAppAndVersion.js +27 -70
- package/lib-es/getAppAndVersion.js.map +1 -1
- package/lib-es/getTrustedInput.js +104 -247
- package/lib-es/getTrustedInput.js.map +1 -1
- package/lib-es/getTrustedInputBIP143.js +5 -6
- package/lib-es/getTrustedInputBIP143.js.map +1 -1
- package/lib-es/getWalletPublicKey.d.ts +1 -1
- package/lib-es/getWalletPublicKey.d.ts.map +1 -1
- package/lib-es/getWalletPublicKey.js +25 -71
- package/lib-es/getWalletPublicKey.js.map +1 -1
- package/lib-es/newops/accounttype.d.ts +2 -2
- package/lib-es/newops/accounttype.d.ts.map +1 -1
- package/lib-es/newops/accounttype.js +79 -123
- package/lib-es/newops/accounttype.js.map +1 -1
- package/lib-es/newops/appClient.js +92 -200
- package/lib-es/newops/appClient.js.map +1 -1
- package/lib-es/newops/clientCommands.js +117 -214
- package/lib-es/newops/clientCommands.js.map +1 -1
- package/lib-es/newops/merkelizedPsbt.js +25 -73
- package/lib-es/newops/merkelizedPsbt.js.map +1 -1
- package/lib-es/newops/merkle.js +36 -66
- package/lib-es/newops/merkle.js.map +1 -1
- package/lib-es/newops/merkleMap.js +8 -10
- package/lib-es/newops/merkleMap.js.map +1 -1
- package/lib-es/newops/policy.d.ts +1 -1
- package/lib-es/newops/policy.d.ts.map +1 -1
- package/lib-es/newops/policy.js +12 -14
- package/lib-es/newops/policy.js.map +1 -1
- package/lib-es/newops/psbtExtractor.js +7 -7
- package/lib-es/newops/psbtExtractor.js.map +1 -1
- package/lib-es/newops/psbtFinalizer.js +19 -19
- package/lib-es/newops/psbtFinalizer.js.map +1 -1
- package/lib-es/newops/psbtv2.d.ts +1 -1
- package/lib-es/newops/psbtv2.d.ts.map +1 -1
- package/lib-es/newops/psbtv2.js +225 -286
- package/lib-es/newops/psbtv2.js.map +1 -1
- package/lib-es/serializeTransaction.js +11 -13
- package/lib-es/serializeTransaction.js.map +1 -1
- package/lib-es/shouldUseTrustedInputForSegwit.js +1 -2
- package/lib-es/shouldUseTrustedInputForSegwit.js.map +1 -1
- package/lib-es/signMessage.js +44 -96
- package/lib-es/signMessage.js.map +1 -1
- package/lib-es/signP2SHTransaction.d.ts +1 -1
- package/lib-es/signP2SHTransaction.d.ts.map +1 -1
- package/lib-es/signP2SHTransaction.js +84 -180
- package/lib-es/signP2SHTransaction.js.map +1 -1
- package/lib-es/signTransaction.js +6 -7
- package/lib-es/signTransaction.js.map +1 -1
- package/lib-es/splitTransaction.js +46 -50
- package/lib-es/splitTransaction.js.map +1 -1
- package/lib-es/startUntrustedHashTransactionInput.js +62 -164
- package/lib-es/startUntrustedHashTransactionInput.js.map +1 -1
- package/lib-es/varint.js +9 -9
- package/lib-es/varint.js.map +1 -1
- package/package.json +5 -6
- package/src/Btc.ts +28 -5
|
@@ -7,261 +7,118 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
7
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
8
|
});
|
|
9
9
|
};
|
|
10
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
11
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
12
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
13
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
14
|
-
function step(op) {
|
|
15
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
16
|
-
while (_) try {
|
|
17
|
-
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;
|
|
18
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
19
|
-
switch (op[0]) {
|
|
20
|
-
case 0: case 1: t = op; break;
|
|
21
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
22
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
23
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
24
|
-
default:
|
|
25
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
26
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
27
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
28
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
29
|
-
if (t[2]) _.ops.pop();
|
|
30
|
-
_.trys.pop(); continue;
|
|
31
|
-
}
|
|
32
|
-
op = body.call(thisArg, _);
|
|
33
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
34
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
var __values = (this && this.__values) || function(o) {
|
|
38
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
39
|
-
if (m) return m.call(o);
|
|
40
|
-
if (o && typeof o.length === "number") return {
|
|
41
|
-
next: function () {
|
|
42
|
-
if (o && i >= o.length) o = void 0;
|
|
43
|
-
return { value: o && o[i++], done: !o };
|
|
44
|
-
}
|
|
45
|
-
};
|
|
46
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
47
|
-
};
|
|
48
10
|
import invariant from "invariant";
|
|
49
11
|
import { MAX_SCRIPT_BLOCK } from "./constants";
|
|
50
12
|
import { createVarint } from "./varint";
|
|
51
13
|
export function getTrustedInputRaw(transport, transactionData, indexLookup) {
|
|
52
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
return [4 /*yield*/, transport.send(0xe0, 0x42, firstRound ? 0x00 : 0x80, 0x00, data)];
|
|
68
|
-
case 1:
|
|
69
|
-
trustedInput = _a.sent();
|
|
70
|
-
res = trustedInput.slice(0, trustedInput.length - 2).toString("hex");
|
|
71
|
-
return [2 /*return*/, res];
|
|
72
|
-
}
|
|
73
|
-
});
|
|
14
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
15
|
+
let data;
|
|
16
|
+
let firstRound = false;
|
|
17
|
+
if (typeof indexLookup === "number") {
|
|
18
|
+
firstRound = true;
|
|
19
|
+
const prefix = Buffer.alloc(4);
|
|
20
|
+
prefix.writeUInt32BE(indexLookup, 0);
|
|
21
|
+
data = Buffer.concat([prefix, transactionData], transactionData.length + 4);
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
data = transactionData;
|
|
25
|
+
}
|
|
26
|
+
const trustedInput = yield transport.send(0xe0, 0x42, firstRound ? 0x00 : 0x80, 0x00, data);
|
|
27
|
+
const res = trustedInput.slice(0, trustedInput.length - 2).toString("hex");
|
|
28
|
+
return res;
|
|
74
29
|
});
|
|
75
30
|
}
|
|
76
|
-
export function getTrustedInput(transport, indexLookup, transaction, additionals) {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
if (offset + blockSize !== script.length) {
|
|
105
|
-
scriptBlocks.push(script.slice(offset, offset + blockSize));
|
|
106
|
-
}
|
|
107
|
-
else {
|
|
108
|
-
scriptBlocks.push(Buffer.concat([script.slice(offset, offset + blockSize), seq]));
|
|
109
|
-
}
|
|
110
|
-
offset += blockSize;
|
|
111
|
-
}
|
|
112
|
-
// Handle case when no script length: we still want to pass the sequence
|
|
113
|
-
// relatable: https://github.com/LedgerHQ/ledger-live-desktop/issues/1386
|
|
114
|
-
if (script.length === 0) {
|
|
115
|
-
scriptBlocks.push(seq);
|
|
116
|
-
}
|
|
117
|
-
_b.label = 1;
|
|
118
|
-
case 1:
|
|
119
|
-
_b.trys.push([1, 6, 7, 8]);
|
|
120
|
-
scriptBlocks_1 = __values(scriptBlocks), scriptBlocks_1_1 = scriptBlocks_1.next();
|
|
121
|
-
_b.label = 2;
|
|
122
|
-
case 2:
|
|
123
|
-
if (!!scriptBlocks_1_1.done) return [3 /*break*/, 5];
|
|
124
|
-
scriptBlock = scriptBlocks_1_1.value;
|
|
125
|
-
return [4 /*yield*/, getTrustedInputRaw(transport, scriptBlock)];
|
|
126
|
-
case 3:
|
|
127
|
-
res = _b.sent();
|
|
128
|
-
_b.label = 4;
|
|
129
|
-
case 4:
|
|
130
|
-
scriptBlocks_1_1 = scriptBlocks_1.next();
|
|
131
|
-
return [3 /*break*/, 2];
|
|
132
|
-
case 5: return [3 /*break*/, 8];
|
|
133
|
-
case 6:
|
|
134
|
-
e_3_1 = _b.sent();
|
|
135
|
-
e_3 = { error: e_3_1 };
|
|
136
|
-
return [3 /*break*/, 8];
|
|
137
|
-
case 7:
|
|
138
|
-
try {
|
|
139
|
-
if (scriptBlocks_1_1 && !scriptBlocks_1_1.done && (_a = scriptBlocks_1["return"])) _a.call(scriptBlocks_1);
|
|
140
|
-
}
|
|
141
|
-
finally { if (e_3) throw e_3.error; }
|
|
142
|
-
return [7 /*endfinally*/];
|
|
143
|
-
case 8: return [2 /*return*/, res];
|
|
144
|
-
}
|
|
145
|
-
});
|
|
146
|
-
}); };
|
|
147
|
-
processWholeScriptBlock = function (block) {
|
|
148
|
-
return getTrustedInputRaw(transport, block);
|
|
149
|
-
};
|
|
150
|
-
return [4 /*yield*/, getTrustedInputRaw(transport, Buffer.concat([
|
|
151
|
-
transaction.version,
|
|
152
|
-
transaction.timestamp || Buffer.alloc(0),
|
|
153
|
-
transaction.nVersionGroupId || Buffer.alloc(0),
|
|
154
|
-
createVarint(inputs.length),
|
|
155
|
-
]), indexLookup)];
|
|
156
|
-
case 1:
|
|
157
|
-
_c.sent();
|
|
158
|
-
_c.label = 2;
|
|
159
|
-
case 2:
|
|
160
|
-
_c.trys.push([2, 8, 9, 10]);
|
|
161
|
-
inputs_1 = __values(inputs), inputs_1_1 = inputs_1.next();
|
|
162
|
-
_c.label = 3;
|
|
163
|
-
case 3:
|
|
164
|
-
if (!!inputs_1_1.done) return [3 /*break*/, 7];
|
|
165
|
-
input = inputs_1_1.value;
|
|
166
|
-
isXSTV2 = isXST &&
|
|
167
|
-
Buffer.compare(version, Buffer.from([0x02, 0x00, 0x00, 0x00])) === 0;
|
|
168
|
-
treeField = isDecred
|
|
169
|
-
? input.tree || Buffer.from([0x00])
|
|
170
|
-
: Buffer.alloc(0);
|
|
171
|
-
data = Buffer.concat([
|
|
172
|
-
input.prevout,
|
|
173
|
-
treeField,
|
|
174
|
-
isXSTV2 ? Buffer.from([0x00]) : createVarint(input.script.length),
|
|
175
|
-
]);
|
|
176
|
-
return [4 /*yield*/, getTrustedInputRaw(transport, data)];
|
|
177
|
-
case 4:
|
|
178
|
-
_c.sent();
|
|
179
|
-
// iteration (eachSeries) ended
|
|
180
|
-
// TODO notify progress
|
|
181
|
-
// deferred.notify("input");
|
|
182
|
-
// Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
|
|
183
|
-
return [4 /*yield*/, (isDecred
|
|
184
|
-
? processWholeScriptBlock(Buffer.concat([input.script, input.sequence]))
|
|
185
|
-
: isXSTV2
|
|
186
|
-
? processWholeScriptBlock(input.sequence)
|
|
187
|
-
: processScriptBlocks(input.script, input.sequence))];
|
|
188
|
-
case 5:
|
|
189
|
-
// iteration (eachSeries) ended
|
|
190
|
-
// TODO notify progress
|
|
191
|
-
// deferred.notify("input");
|
|
192
|
-
// Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
|
|
193
|
-
_c.sent();
|
|
194
|
-
_c.label = 6;
|
|
195
|
-
case 6:
|
|
196
|
-
inputs_1_1 = inputs_1.next();
|
|
197
|
-
return [3 /*break*/, 3];
|
|
198
|
-
case 7: return [3 /*break*/, 10];
|
|
199
|
-
case 8:
|
|
200
|
-
e_1_1 = _c.sent();
|
|
201
|
-
e_1 = { error: e_1_1 };
|
|
202
|
-
return [3 /*break*/, 10];
|
|
203
|
-
case 9:
|
|
204
|
-
try {
|
|
205
|
-
if (inputs_1_1 && !inputs_1_1.done && (_a = inputs_1["return"])) _a.call(inputs_1);
|
|
206
|
-
}
|
|
207
|
-
finally { if (e_1) throw e_1.error; }
|
|
208
|
-
return [7 /*endfinally*/];
|
|
209
|
-
case 10: return [4 /*yield*/, getTrustedInputRaw(transport, createVarint(outputs.length))];
|
|
210
|
-
case 11:
|
|
211
|
-
_c.sent();
|
|
212
|
-
_c.label = 12;
|
|
213
|
-
case 12:
|
|
214
|
-
_c.trys.push([12, 17, 18, 19]);
|
|
215
|
-
outputs_1 = __values(outputs), outputs_1_1 = outputs_1.next();
|
|
216
|
-
_c.label = 13;
|
|
217
|
-
case 13:
|
|
218
|
-
if (!!outputs_1_1.done) return [3 /*break*/, 16];
|
|
219
|
-
output = outputs_1_1.value;
|
|
220
|
-
data = Buffer.concat([
|
|
221
|
-
output.amount,
|
|
222
|
-
isDecred ? Buffer.from([0x00, 0x00]) : Buffer.alloc(0),
|
|
223
|
-
createVarint(output.script.length),
|
|
224
|
-
output.script,
|
|
225
|
-
]);
|
|
226
|
-
return [4 /*yield*/, getTrustedInputRaw(transport, data)];
|
|
227
|
-
case 14:
|
|
228
|
-
_c.sent();
|
|
229
|
-
_c.label = 15;
|
|
230
|
-
case 15:
|
|
231
|
-
outputs_1_1 = outputs_1.next();
|
|
232
|
-
return [3 /*break*/, 13];
|
|
233
|
-
case 16: return [3 /*break*/, 19];
|
|
234
|
-
case 17:
|
|
235
|
-
e_2_1 = _c.sent();
|
|
236
|
-
e_2 = { error: e_2_1 };
|
|
237
|
-
return [3 /*break*/, 19];
|
|
238
|
-
case 18:
|
|
239
|
-
try {
|
|
240
|
-
if (outputs_1_1 && !outputs_1_1.done && (_b = outputs_1["return"])) _b.call(outputs_1);
|
|
241
|
-
}
|
|
242
|
-
finally { if (e_2) throw e_2.error; }
|
|
243
|
-
return [7 /*endfinally*/];
|
|
244
|
-
case 19:
|
|
245
|
-
endData = [];
|
|
246
|
-
if (nExpiryHeight && nExpiryHeight.length > 0) {
|
|
247
|
-
endData.push(nExpiryHeight);
|
|
248
|
-
}
|
|
249
|
-
if (extraData && extraData.length > 0) {
|
|
250
|
-
endData.push(extraData);
|
|
251
|
-
}
|
|
252
|
-
if (endData.length) {
|
|
253
|
-
data = Buffer.concat(endData);
|
|
254
|
-
extraPart = isDecred
|
|
255
|
-
? data
|
|
256
|
-
: Buffer.concat([createVarint(data.length), data]);
|
|
257
|
-
}
|
|
258
|
-
return [4 /*yield*/, processScriptBlocks(Buffer.concat([locktime, extraPart || Buffer.alloc(0)]))];
|
|
259
|
-
case 20:
|
|
260
|
-
res = _c.sent();
|
|
261
|
-
invariant(res, "missing result in processScriptBlocks");
|
|
262
|
-
return [2 /*return*/, res];
|
|
31
|
+
export function getTrustedInput(transport, indexLookup, transaction, additionals = []) {
|
|
32
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
+
const { version, inputs, outputs, locktime, nExpiryHeight, extraData } = transaction;
|
|
34
|
+
if (!outputs || !locktime) {
|
|
35
|
+
throw new Error("getTrustedInput: locktime & outputs is expected");
|
|
36
|
+
}
|
|
37
|
+
const isDecred = additionals.includes("decred");
|
|
38
|
+
const isXST = additionals.includes("stealthcoin");
|
|
39
|
+
const processScriptBlocks = (script, sequence) => __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
const seq = sequence || Buffer.alloc(0);
|
|
41
|
+
const scriptBlocks = [];
|
|
42
|
+
let offset = 0;
|
|
43
|
+
while (offset !== script.length) {
|
|
44
|
+
const blockSize = script.length - offset > MAX_SCRIPT_BLOCK
|
|
45
|
+
? MAX_SCRIPT_BLOCK
|
|
46
|
+
: script.length - offset;
|
|
47
|
+
if (offset + blockSize !== script.length) {
|
|
48
|
+
scriptBlocks.push(script.slice(offset, offset + blockSize));
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
scriptBlocks.push(Buffer.concat([script.slice(offset, offset + blockSize), seq]));
|
|
52
|
+
}
|
|
53
|
+
offset += blockSize;
|
|
54
|
+
}
|
|
55
|
+
// Handle case when no script length: we still want to pass the sequence
|
|
56
|
+
// relatable: https://github.com/LedgerHQ/ledger-live-desktop/issues/1386
|
|
57
|
+
if (script.length === 0) {
|
|
58
|
+
scriptBlocks.push(seq);
|
|
263
59
|
}
|
|
60
|
+
let res;
|
|
61
|
+
for (const scriptBlock of scriptBlocks) {
|
|
62
|
+
res = yield getTrustedInputRaw(transport, scriptBlock);
|
|
63
|
+
}
|
|
64
|
+
return res;
|
|
264
65
|
});
|
|
66
|
+
const processWholeScriptBlock = (block) => getTrustedInputRaw(transport, block);
|
|
67
|
+
yield getTrustedInputRaw(transport, Buffer.concat([
|
|
68
|
+
transaction.version,
|
|
69
|
+
transaction.timestamp || Buffer.alloc(0),
|
|
70
|
+
transaction.nVersionGroupId || Buffer.alloc(0),
|
|
71
|
+
createVarint(inputs.length),
|
|
72
|
+
]), indexLookup);
|
|
73
|
+
for (const input of inputs) {
|
|
74
|
+
const isXSTV2 = isXST &&
|
|
75
|
+
Buffer.compare(version, Buffer.from([0x02, 0x00, 0x00, 0x00])) === 0;
|
|
76
|
+
const treeField = isDecred
|
|
77
|
+
? input.tree || Buffer.from([0x00])
|
|
78
|
+
: Buffer.alloc(0);
|
|
79
|
+
const data = Buffer.concat([
|
|
80
|
+
input.prevout,
|
|
81
|
+
treeField,
|
|
82
|
+
isXSTV2 ? Buffer.from([0x00]) : createVarint(input.script.length),
|
|
83
|
+
]);
|
|
84
|
+
yield getTrustedInputRaw(transport, data);
|
|
85
|
+
// iteration (eachSeries) ended
|
|
86
|
+
// TODO notify progress
|
|
87
|
+
// deferred.notify("input");
|
|
88
|
+
// Reference: https://github.com/StealthSend/Stealth/commit/5be35d6c2c500b32ed82e5d6913d66d18a4b0a7f#diff-e8db9b851adc2422aadfffca88f14c91R566
|
|
89
|
+
yield (isDecred
|
|
90
|
+
? processWholeScriptBlock(Buffer.concat([input.script, input.sequence]))
|
|
91
|
+
: isXSTV2
|
|
92
|
+
? processWholeScriptBlock(input.sequence)
|
|
93
|
+
: processScriptBlocks(input.script, input.sequence));
|
|
94
|
+
}
|
|
95
|
+
yield getTrustedInputRaw(transport, createVarint(outputs.length));
|
|
96
|
+
for (const output of outputs) {
|
|
97
|
+
const data = Buffer.concat([
|
|
98
|
+
output.amount,
|
|
99
|
+
isDecred ? Buffer.from([0x00, 0x00]) : Buffer.alloc(0),
|
|
100
|
+
createVarint(output.script.length),
|
|
101
|
+
output.script,
|
|
102
|
+
]);
|
|
103
|
+
yield getTrustedInputRaw(transport, data);
|
|
104
|
+
}
|
|
105
|
+
const endData = [];
|
|
106
|
+
if (nExpiryHeight && nExpiryHeight.length > 0) {
|
|
107
|
+
endData.push(nExpiryHeight);
|
|
108
|
+
}
|
|
109
|
+
if (extraData && extraData.length > 0) {
|
|
110
|
+
endData.push(extraData);
|
|
111
|
+
}
|
|
112
|
+
let extraPart;
|
|
113
|
+
if (endData.length) {
|
|
114
|
+
const data = Buffer.concat(endData);
|
|
115
|
+
extraPart = isDecred
|
|
116
|
+
? data
|
|
117
|
+
: Buffer.concat([createVarint(data.length), data]);
|
|
118
|
+
}
|
|
119
|
+
const res = yield processScriptBlocks(Buffer.concat([locktime, extraPart || Buffer.alloc(0)]));
|
|
120
|
+
invariant(res, "missing result in processScriptBlocks");
|
|
121
|
+
return res;
|
|
265
122
|
});
|
|
266
123
|
}
|
|
267
124
|
//# sourceMappingURL=getTrustedInput.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTrustedInput.js","sourceRoot":"","sources":["../src/getTrustedInput.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"getTrustedInput.js","sourceRoot":"","sources":["../src/getTrustedInput.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
import shajs from "sha.js";
|
|
2
2
|
import { serializeTransaction } from "./serializeTransaction";
|
|
3
|
-
export function getTrustedInputBIP143(transport, indexLookup, transaction, additionals) {
|
|
4
|
-
if (additionals === void 0) { additionals = []; }
|
|
3
|
+
export function getTrustedInputBIP143(transport, indexLookup, transaction, additionals = []) {
|
|
5
4
|
if (!transaction) {
|
|
6
5
|
throw new Error("getTrustedInputBIP143: missing tx");
|
|
7
6
|
}
|
|
8
|
-
|
|
7
|
+
const isDecred = additionals.includes("decred");
|
|
9
8
|
if (isDecred) {
|
|
10
9
|
throw new Error("Decred does not implement BIP143");
|
|
11
10
|
}
|
|
12
|
-
|
|
11
|
+
let hash = shajs("sha256")
|
|
13
12
|
.update(shajs("sha256").update(serializeTransaction(transaction, true)).digest())
|
|
14
13
|
.digest();
|
|
15
|
-
|
|
14
|
+
const data = Buffer.alloc(4);
|
|
16
15
|
data.writeUInt32LE(indexLookup, 0);
|
|
17
|
-
|
|
16
|
+
const { outputs, locktime } = transaction;
|
|
18
17
|
if (!outputs || !locktime) {
|
|
19
18
|
throw new Error("getTrustedInputBIP143: locktime & outputs is expected");
|
|
20
19
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTrustedInputBIP143.js","sourceRoot":"","sources":["../src/getTrustedInputBIP143.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,QAAQ,CAAC;AAE3B,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,MAAM,UAAU,qBAAqB,CACnC,SAAoB,EACpB,WAAmB,EACnB,WAAwB,EACxB,
|
|
1
|
+
{"version":3,"file":"getTrustedInputBIP143.js","sourceRoot":"","sources":["../src/getTrustedInputBIP143.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,QAAQ,CAAC;AAE3B,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,MAAM,UAAU,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,KAAK,CAAC,QAAQ,CAAC;SACvB,MAAM,CACL,KAAK,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,oBAAoB,CAAC,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"}
|
|
@@ -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
|
|
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,
|
|
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,14 +1,3 @@
|
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
|
2
|
-
__assign = Object.assign || function(t) {
|
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
-
s = arguments[i];
|
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
-
t[p] = s[p];
|
|
7
|
-
}
|
|
8
|
-
return t;
|
|
9
|
-
};
|
|
10
|
-
return __assign.apply(this, arguments);
|
|
11
|
-
};
|
|
12
1
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
13
2
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
14
3
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -18,72 +7,37 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
18
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
19
8
|
});
|
|
20
9
|
};
|
|
21
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
23
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
-
function step(op) {
|
|
26
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
-
while (_) try {
|
|
28
|
-
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;
|
|
29
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
-
switch (op[0]) {
|
|
31
|
-
case 0: case 1: t = op; break;
|
|
32
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
-
default:
|
|
36
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
-
if (t[2]) _.ops.pop();
|
|
41
|
-
_.trys.pop(); continue;
|
|
42
|
-
}
|
|
43
|
-
op = body.call(thisArg, _);
|
|
44
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
10
|
import { bip32asBuffer } from "./bip32";
|
|
49
|
-
|
|
11
|
+
const addressFormatMap = {
|
|
50
12
|
legacy: 0,
|
|
51
13
|
p2sh: 1,
|
|
52
14
|
bech32: 2,
|
|
53
|
-
cashaddr: 3
|
|
15
|
+
cashaddr: 3,
|
|
54
16
|
};
|
|
55
17
|
export function getWalletPublicKey(transport, options) {
|
|
56
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
.toString("hex");
|
|
80
|
-
return [2 /*return*/, {
|
|
81
|
-
publicKey: publicKey,
|
|
82
|
-
bitcoinAddress: bitcoinAddress,
|
|
83
|
-
chainCode: chainCode
|
|
84
|
-
}];
|
|
85
|
-
}
|
|
86
|
-
});
|
|
18
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
19
|
+
const { path, verify, format } = Object.assign({ verify: false, format: "legacy" }, options);
|
|
20
|
+
if (!(format in addressFormatMap)) {
|
|
21
|
+
throw new Error("btc.getWalletPublicKey invalid format=" + format);
|
|
22
|
+
}
|
|
23
|
+
const buffer = bip32asBuffer(path);
|
|
24
|
+
const p1 = verify ? 1 : 0;
|
|
25
|
+
const p2 = addressFormatMap[format];
|
|
26
|
+
const response = yield transport.send(0xe0, 0x40, p1, p2, buffer);
|
|
27
|
+
const publicKeyLength = response[0];
|
|
28
|
+
const addressLength = response[1 + publicKeyLength];
|
|
29
|
+
const publicKey = response.slice(1, 1 + publicKeyLength).toString("hex");
|
|
30
|
+
const bitcoinAddress = response
|
|
31
|
+
.slice(1 + publicKeyLength + 1, 1 + publicKeyLength + 1 + addressLength)
|
|
32
|
+
.toString("ascii");
|
|
33
|
+
const chainCode = response
|
|
34
|
+
.slice(1 + publicKeyLength + 1 + addressLength, 1 + publicKeyLength + 1 + addressLength + 32)
|
|
35
|
+
.toString("hex");
|
|
36
|
+
return {
|
|
37
|
+
publicKey,
|
|
38
|
+
bitcoinAddress,
|
|
39
|
+
chainCode,
|
|
40
|
+
};
|
|
87
41
|
});
|
|
88
42
|
}
|
|
89
43
|
//# sourceMappingURL=getWalletPublicKey.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getWalletPublicKey.js","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"getWalletPublicKey.js","sourceRoot":"","sources":["../src/getWalletPublicKey.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAWxC,MAAM,gBAAgB,GAAG;IACvB,MAAM,EAAE,CAAC;IACT,IAAI,EAAE,CAAC;IACP,MAAM,EAAE,CAAC;IACT,QAAQ,EAAE,CAAC;CACZ,CAAC;AACF,MAAM,UAAgB,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,aAAa,CAAC,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"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import { DefaultDescriptorTemplate } from "./policy";
|
|
3
3
|
import { PsbtV2 } from "./psbtv2";
|
|
4
|
-
export
|
|
4
|
+
export type SpendingCondition = {
|
|
5
5
|
scriptPubKey: Buffer;
|
|
6
6
|
redeemScript?: Buffer;
|
|
7
7
|
};
|
|
8
|
-
export
|
|
8
|
+
export type SpentOutput = {
|
|
9
9
|
cond: SpendingCondition;
|
|
10
10
|
amount: Buffer;
|
|
11
11
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"accounttype.d.ts","sourceRoot":"","sources":["../../src/newops/accounttype.ts"],"names":[],"mappings":";AAYA,OAAO,EAAE,yBAAyB,EAAE,MAAM,UAAU,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,
|
|
1
|
+
{"version":3,"file":"accounttype.d.ts","sourceRoot":"","sources":["../../src/newops/accounttype.ts"],"names":[],"mappings":"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"}
|