@bitgo-beta/sdk-api 1.10.1-beta.99 → 1.10.1-beta.991
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 +905 -0
- package/dist/package.json +13 -25
- package/dist/src/api.d.ts +3 -3
- package/dist/src/api.d.ts.map +1 -1
- package/dist/src/api.js +39 -33
- package/dist/src/bitgoAPI.d.ts +64 -11
- package/dist/src/bitgoAPI.d.ts.map +1 -1
- package/dist/src/bitgoAPI.js +357 -121
- package/dist/src/encrypt.d.ts +4 -4
- package/dist/src/encrypt.d.ts.map +1 -1
- package/dist/src/encrypt.js +44 -7
- package/dist/src/index.js +6 -2
- package/dist/src/types.d.ts +54 -43
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/types.js +4 -2
- package/dist/src/util.d.ts +12 -0
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +57 -4
- package/dist/src/v1/blockchain.js +25 -12
- package/dist/src/v1/keychains.js +27 -22
- package/dist/src/v1/markets.js +10 -5
- package/dist/src/v1/pendingapproval.d.ts.map +1 -1
- package/dist/src/v1/pendingapproval.js +57 -18
- package/dist/src/v1/pendingapprovals.d.ts.map +1 -1
- package/dist/src/v1/pendingapprovals.js +41 -7
- package/dist/src/v1/signPsbt.d.ts +14 -0
- package/dist/src/v1/signPsbt.d.ts.map +1 -0
- package/dist/src/v1/signPsbt.js +69 -0
- package/dist/src/v1/transactionBuilder.js +144 -92
- package/dist/src/v1/travelRule.js +60 -23
- package/dist/src/v1/verifyAddress.d.ts +6 -0
- package/dist/src/v1/verifyAddress.d.ts.map +1 -0
- package/dist/src/v1/verifyAddress.js +50 -0
- package/dist/src/v1/wallet.d.ts.map +1 -1
- package/dist/src/v1/wallet.js +428 -224
- package/dist/src/v1/wallets.js +93 -37
- package/package.json +13 -25
- package/dist/web/main.js +0 -2
- package/dist/web/main.js.LICENSE.txt +0 -110
package/dist/src/v1/wallet.js
CHANGED
|
@@ -2,6 +2,42 @@
|
|
|
2
2
|
/**
|
|
3
3
|
* @hidden
|
|
4
4
|
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
17
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
18
|
+
}) : function(o, v) {
|
|
19
|
+
o["default"] = v;
|
|
20
|
+
});
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
38
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
39
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
40
|
+
};
|
|
5
41
|
/**
|
|
6
42
|
*/
|
|
7
43
|
//
|
|
@@ -11,14 +47,15 @@
|
|
|
11
47
|
// Copyright 2014, BitGo, Inc. All Rights Reserved.
|
|
12
48
|
//
|
|
13
49
|
const unspents_1 = require("@bitgo-beta/unspents");
|
|
50
|
+
const assert_1 = __importDefault(require("assert"));
|
|
51
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
14
52
|
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
53
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
54
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
55
|
+
const signPsbt_1 = require("./signPsbt");
|
|
56
|
+
const util_1 = require("../util");
|
|
15
57
|
const TransactionBuilder = require('./transactionBuilder');
|
|
16
|
-
const utxolib = require("@bitgo-beta/utxo-lib");
|
|
17
58
|
const PendingApproval = require('./pendingapproval');
|
|
18
|
-
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
19
|
-
const Bluebird = require("bluebird");
|
|
20
|
-
const co = Bluebird.coroutine;
|
|
21
|
-
const _ = require("lodash");
|
|
22
59
|
const { getExternalChainCode, getInternalChainCode, isChainCode, scriptTypeForChain } = utxolib.bitgo;
|
|
23
60
|
const request = require('superagent');
|
|
24
61
|
//
|
|
@@ -144,13 +181,15 @@ Wallet.prototype.get = function (params, callback) {
|
|
|
144
181
|
params = params || {};
|
|
145
182
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
146
183
|
const self = this;
|
|
147
|
-
return
|
|
184
|
+
return Promise.resolve(this.bitgo
|
|
148
185
|
.get(this.url())
|
|
149
186
|
.result()
|
|
150
187
|
.then(function (res) {
|
|
151
188
|
self.wallet = res;
|
|
152
189
|
return self;
|
|
153
|
-
}))
|
|
190
|
+
}))
|
|
191
|
+
.then(callback)
|
|
192
|
+
.catch(callback);
|
|
154
193
|
};
|
|
155
194
|
//
|
|
156
195
|
// updateApprovalsRequired
|
|
@@ -162,7 +201,7 @@ Wallet.prototype.updateApprovalsRequired = function (params, callback) {
|
|
|
162
201
|
params = params || {};
|
|
163
202
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
164
203
|
if (params.approvalsRequired === undefined ||
|
|
165
|
-
!
|
|
204
|
+
!lodash_1.default.isInteger(params.approvalsRequired) ||
|
|
166
205
|
params.approvalsRequired < 1) {
|
|
167
206
|
throw new Error('invalid approvalsRequired: must be a nonzero positive number');
|
|
168
207
|
}
|
|
@@ -170,19 +209,21 @@ Wallet.prototype.updateApprovalsRequired = function (params, callback) {
|
|
|
170
209
|
const currentApprovalsRequired = this.approvalsRequired();
|
|
171
210
|
if (currentApprovalsRequired === params.approvalsRequired) {
|
|
172
211
|
// no-op, just return the current wallet
|
|
173
|
-
return
|
|
212
|
+
return (0, util_1.tryPromise)(function () {
|
|
174
213
|
return self.wallet;
|
|
175
|
-
})
|
|
214
|
+
})
|
|
215
|
+
.then(callback)
|
|
216
|
+
.catch(callback);
|
|
176
217
|
}
|
|
177
|
-
return
|
|
218
|
+
return Promise.resolve(this.bitgo.put(this.url()).send(params).result()).then(callback).catch(callback);
|
|
178
219
|
};
|
|
179
220
|
/**
|
|
180
221
|
* Returns the correct chain for change, taking into consideration segwit
|
|
181
222
|
*/
|
|
182
223
|
Wallet.prototype.getChangeChain = function (params) {
|
|
183
224
|
let useSegwitChange = !!this.bitgo.getConstants().enableSegwit;
|
|
184
|
-
if (!
|
|
185
|
-
if (!
|
|
225
|
+
if (!lodash_1.default.isUndefined(params.segwitChange)) {
|
|
226
|
+
if (!lodash_1.default.isBoolean(params.segwitChange)) {
|
|
186
227
|
throw new Error('segwitChange must be a boolean');
|
|
187
228
|
}
|
|
188
229
|
// if segwit is disabled through the constants, segwit change should still not be created
|
|
@@ -213,7 +254,7 @@ Wallet.prototype.createAddress = function (params, callback) {
|
|
|
213
254
|
if (chain === null || chain === undefined) {
|
|
214
255
|
chain = defaultChain;
|
|
215
256
|
}
|
|
216
|
-
return
|
|
257
|
+
return Promise.resolve(this.bitgo
|
|
217
258
|
.post(this.url('/address/' + chain))
|
|
218
259
|
.send(params)
|
|
219
260
|
.result()
|
|
@@ -222,7 +263,9 @@ Wallet.prototype.createAddress = function (params, callback) {
|
|
|
222
263
|
self.validateAddress(addr);
|
|
223
264
|
}
|
|
224
265
|
return addr;
|
|
225
|
-
}))
|
|
266
|
+
}))
|
|
267
|
+
.then(callback)
|
|
268
|
+
.catch(callback);
|
|
226
269
|
};
|
|
227
270
|
/**
|
|
228
271
|
* Generate address locally without calling server
|
|
@@ -232,7 +275,7 @@ Wallet.prototype.createAddress = function (params, callback) {
|
|
|
232
275
|
Wallet.prototype.generateAddress = function ({ segwit, path, keychains, threshold }) {
|
|
233
276
|
const isSegwit = !!segwit;
|
|
234
277
|
let signatureThreshold = 2;
|
|
235
|
-
if (
|
|
278
|
+
if (lodash_1.default.isInteger(threshold)) {
|
|
236
279
|
signatureThreshold = threshold;
|
|
237
280
|
if (signatureThreshold <= 0) {
|
|
238
281
|
throw new Error('threshold has to be positive');
|
|
@@ -250,15 +293,15 @@ Wallet.prototype.generateAddress = function ({ segwit, path, keychains, threshol
|
|
|
250
293
|
const derivedKeys = rootKeys.map(function (k) {
|
|
251
294
|
const hdnode = utxo_lib_1.bip32.fromBase58(k.xpub);
|
|
252
295
|
const derivationPath = k.path + (k.walletSubPath || '') + path;
|
|
253
|
-
return hdnode.derivePath(sdk_core_1.sanitizeLegacyPath(derivationPath)).publicKey;
|
|
296
|
+
return hdnode.derivePath((0, sdk_core_1.sanitizeLegacyPath)(derivationPath)).publicKey;
|
|
254
297
|
});
|
|
255
298
|
const pathComponents = path.split('/');
|
|
256
|
-
const normalizedPathComponents =
|
|
299
|
+
const normalizedPathComponents = lodash_1.default.map(pathComponents, (component) => {
|
|
257
300
|
if (component && component.length > 0) {
|
|
258
301
|
return parseInt(component, 10);
|
|
259
302
|
}
|
|
260
303
|
});
|
|
261
|
-
const pathDetails =
|
|
304
|
+
const pathDetails = lodash_1.default.filter(normalizedPathComponents, lodash_1.default.isInteger);
|
|
262
305
|
const addressDetails = {
|
|
263
306
|
chainPath: path,
|
|
264
307
|
path: path,
|
|
@@ -267,10 +310,10 @@ Wallet.prototype.generateAddress = function ({ segwit, path, keychains, threshol
|
|
|
267
310
|
wallet: this.id(),
|
|
268
311
|
};
|
|
269
312
|
const { scriptPubKey: outputScript, redeemScript, witnessScript, } = utxolib.bitgo.outputScripts.createOutputScript2of3(derivedKeys, isSegwit ? 'p2shP2wsh' : 'p2sh');
|
|
270
|
-
addressDetails.witnessScript = witnessScript
|
|
271
|
-
addressDetails.redeemScript = redeemScript
|
|
313
|
+
addressDetails.witnessScript = witnessScript?.toString('hex');
|
|
314
|
+
addressDetails.redeemScript = redeemScript?.toString('hex');
|
|
272
315
|
addressDetails.outputScript = outputScript.toString('hex');
|
|
273
|
-
addressDetails.address = utxolib.address.fromOutputScript(outputScript, sdk_core_1.getNetwork(network));
|
|
316
|
+
addressDetails.address = utxolib.address.fromOutputScript(outputScript, (0, sdk_core_1.getNetwork)(network));
|
|
274
317
|
return addressDetails;
|
|
275
318
|
};
|
|
276
319
|
//
|
|
@@ -301,7 +344,7 @@ Wallet.prototype.addresses = function (params, callback) {
|
|
|
301
344
|
const chain = params.chain;
|
|
302
345
|
if (chain !== null && chain !== undefined) {
|
|
303
346
|
if (Array.isArray(chain)) {
|
|
304
|
-
query.chain =
|
|
347
|
+
query.chain = lodash_1.default.uniq(lodash_1.default.filter(chain, lodash_1.default.isInteger));
|
|
305
348
|
}
|
|
306
349
|
else {
|
|
307
350
|
if (chain !== 0 && chain !== 1) {
|
|
@@ -311,32 +354,32 @@ Wallet.prototype.addresses = function (params, callback) {
|
|
|
311
354
|
}
|
|
312
355
|
}
|
|
313
356
|
if (params.limit) {
|
|
314
|
-
if (!
|
|
357
|
+
if (!lodash_1.default.isInteger(params.limit)) {
|
|
315
358
|
throw new Error('invalid limit argument, expecting number');
|
|
316
359
|
}
|
|
317
360
|
query.limit = params.limit;
|
|
318
361
|
}
|
|
319
362
|
if (params.skip) {
|
|
320
|
-
if (!
|
|
363
|
+
if (!lodash_1.default.isInteger(params.skip)) {
|
|
321
364
|
throw new Error('invalid skip argument, expecting number');
|
|
322
365
|
}
|
|
323
366
|
query.skip = params.skip;
|
|
324
367
|
}
|
|
325
368
|
if (params.sort) {
|
|
326
|
-
if (!
|
|
369
|
+
if (!lodash_1.default.isNumber(params.sort)) {
|
|
327
370
|
throw new Error('invalid sort argument, expecting number');
|
|
328
371
|
}
|
|
329
372
|
query.sort = params.sort;
|
|
330
373
|
}
|
|
331
374
|
const url = this.url('/addresses');
|
|
332
|
-
return
|
|
375
|
+
return Promise.resolve(this.bitgo.get(url).query(query).result()).then(callback).catch(callback);
|
|
333
376
|
};
|
|
334
377
|
Wallet.prototype.stats = function (params, callback) {
|
|
335
378
|
params = params || {};
|
|
336
379
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
337
380
|
const args = [];
|
|
338
381
|
if (params.limit) {
|
|
339
|
-
if (!
|
|
382
|
+
if (!lodash_1.default.isInteger(params.limit)) {
|
|
340
383
|
throw new Error('invalid limit argument, expecting number');
|
|
341
384
|
}
|
|
342
385
|
args.push('limit=' + params.limit);
|
|
@@ -346,7 +389,7 @@ Wallet.prototype.stats = function (params, callback) {
|
|
|
346
389
|
query = '?' + args.join('&');
|
|
347
390
|
}
|
|
348
391
|
const url = this.url('/stats' + query);
|
|
349
|
-
return
|
|
392
|
+
return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);
|
|
350
393
|
};
|
|
351
394
|
/**
|
|
352
395
|
* Refresh the wallet object by syncing with the back-end
|
|
@@ -354,18 +397,19 @@ Wallet.prototype.stats = function (params, callback) {
|
|
|
354
397
|
* @returns {Wallet}
|
|
355
398
|
*/
|
|
356
399
|
Wallet.prototype.refresh = function (params, callback) {
|
|
357
|
-
return
|
|
400
|
+
return async function () {
|
|
358
401
|
// when set to true, gpk returns the private data of safe wallets
|
|
359
|
-
const query =
|
|
402
|
+
const query = lodash_1.default.extend({}, lodash_1.default.pick(params, ['gpk']));
|
|
360
403
|
// @ts-expect-error - no implicit this
|
|
361
|
-
const res =
|
|
404
|
+
const res = await this.bitgo.get(this.url()).query(query).result();
|
|
362
405
|
// @ts-expect-error - no implicit this
|
|
363
406
|
this.wallet = res;
|
|
364
407
|
// @ts-expect-error - no implicit this
|
|
365
408
|
return this;
|
|
366
|
-
}
|
|
409
|
+
}
|
|
367
410
|
.call(this)
|
|
368
|
-
.
|
|
411
|
+
.then(callback)
|
|
412
|
+
.catch(callback);
|
|
369
413
|
};
|
|
370
414
|
//
|
|
371
415
|
// address
|
|
@@ -378,7 +422,7 @@ Wallet.prototype.address = function (params, callback) {
|
|
|
378
422
|
params = params || {};
|
|
379
423
|
sdk_core_1.common.validateParams(params, ['address'], [], callback);
|
|
380
424
|
const url = this.url('/addresses/' + params.address);
|
|
381
|
-
return
|
|
425
|
+
return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);
|
|
382
426
|
};
|
|
383
427
|
/**
|
|
384
428
|
* Freeze the wallet for a duration of choice, stopping BitGo from signing any transactions.
|
|
@@ -388,11 +432,13 @@ Wallet.prototype.freeze = function (params, callback) {
|
|
|
388
432
|
params = params || {};
|
|
389
433
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
390
434
|
if (params.duration) {
|
|
391
|
-
if (!
|
|
435
|
+
if (!lodash_1.default.isNumber(params.duration)) {
|
|
392
436
|
throw new Error('invalid duration - should be number of seconds');
|
|
393
437
|
}
|
|
394
438
|
}
|
|
395
|
-
return
|
|
439
|
+
return Promise.resolve(this.bitgo.post(this.url('/freeze')).send(params).result())
|
|
440
|
+
.then(callback)
|
|
441
|
+
.catch(callback);
|
|
396
442
|
};
|
|
397
443
|
//
|
|
398
444
|
// delete
|
|
@@ -401,7 +447,7 @@ Wallet.prototype.freeze = function (params, callback) {
|
|
|
401
447
|
Wallet.prototype.delete = function (params, callback) {
|
|
402
448
|
params = params || {};
|
|
403
449
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
404
|
-
return
|
|
450
|
+
return Promise.resolve(this.bitgo.del(this.url()).result()).then(callback).catch(callback);
|
|
405
451
|
};
|
|
406
452
|
//
|
|
407
453
|
// labels
|
|
@@ -411,7 +457,7 @@ Wallet.prototype.labels = function (params, callback) {
|
|
|
411
457
|
params = params || {};
|
|
412
458
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
413
459
|
const url = this.bitgo.url('/labels/' + this.id());
|
|
414
|
-
return
|
|
460
|
+
return Promise.resolve(this.bitgo.get(url).result('labels')).then(callback).catch(callback);
|
|
415
461
|
};
|
|
416
462
|
/**
|
|
417
463
|
* Rename a wallet
|
|
@@ -424,7 +470,9 @@ Wallet.prototype.setWalletName = function (params, callback) {
|
|
|
424
470
|
params = params || {};
|
|
425
471
|
sdk_core_1.common.validateParams(params, ['label'], [], callback);
|
|
426
472
|
const url = this.bitgo.url('/wallet/' + this.id());
|
|
427
|
-
return
|
|
473
|
+
return Promise.resolve(this.bitgo.put(url).send({ label: params.label }).result())
|
|
474
|
+
.then(callback)
|
|
475
|
+
.catch(callback);
|
|
428
476
|
};
|
|
429
477
|
//
|
|
430
478
|
// setLabel
|
|
@@ -438,7 +486,9 @@ Wallet.prototype.setLabel = function (params, callback) {
|
|
|
438
486
|
throw new Error('Invalid bitcoin address: ' + params.address);
|
|
439
487
|
}
|
|
440
488
|
const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);
|
|
441
|
-
return
|
|
489
|
+
return Promise.resolve(this.bitgo.put(url).send({ label: params.label }).result())
|
|
490
|
+
.then(callback)
|
|
491
|
+
.catch(callback);
|
|
442
492
|
};
|
|
443
493
|
//
|
|
444
494
|
// deleteLabel
|
|
@@ -452,7 +502,7 @@ Wallet.prototype.deleteLabel = function (params, callback) {
|
|
|
452
502
|
throw new Error('Invalid bitcoin address: ' + params.address);
|
|
453
503
|
}
|
|
454
504
|
const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);
|
|
455
|
-
return
|
|
505
|
+
return Promise.resolve(this.bitgo.del(url).result()).then(callback).catch(callback);
|
|
456
506
|
};
|
|
457
507
|
//
|
|
458
508
|
// unspents
|
|
@@ -471,7 +521,7 @@ Wallet.prototype.unspents = function (params, callback) {
|
|
|
471
521
|
const allUnspents = [];
|
|
472
522
|
const self = this;
|
|
473
523
|
const getUnspentsBatch = function (skip, limit) {
|
|
474
|
-
const queryObject =
|
|
524
|
+
const queryObject = lodash_1.default.cloneDeep(params);
|
|
475
525
|
if (skip > 0) {
|
|
476
526
|
queryObject.skip = skip;
|
|
477
527
|
}
|
|
@@ -506,7 +556,7 @@ Wallet.prototype.unspents = function (params, callback) {
|
|
|
506
556
|
return allUnspents;
|
|
507
557
|
});
|
|
508
558
|
};
|
|
509
|
-
return getUnspentsBatch(0, params.limit).
|
|
559
|
+
return getUnspentsBatch(0, params.limit).then(callback).catch(callback);
|
|
510
560
|
};
|
|
511
561
|
/**
|
|
512
562
|
* List the unspents (paged) for a given wallet, returning the result as an object of unspents, count, skip and total
|
|
@@ -527,53 +577,55 @@ Wallet.prototype.unspents = function (params, callback) {
|
|
|
527
577
|
Wallet.prototype.unspentsPaged = function (params, callback) {
|
|
528
578
|
params = params || {};
|
|
529
579
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
530
|
-
if (!
|
|
580
|
+
if (!lodash_1.default.isUndefined(params.limit) && !lodash_1.default.isInteger(params.limit)) {
|
|
531
581
|
throw new Error('invalid limit - should be number');
|
|
532
582
|
}
|
|
533
|
-
if (!
|
|
583
|
+
if (!lodash_1.default.isUndefined(params.skip) && !lodash_1.default.isInteger(params.skip)) {
|
|
534
584
|
throw new Error('invalid skip - should be number');
|
|
535
585
|
}
|
|
536
|
-
if (!
|
|
586
|
+
if (!lodash_1.default.isUndefined(params.minConfirms) && !lodash_1.default.isInteger(params.minConfirms)) {
|
|
537
587
|
throw new Error('invalid minConfirms - should be number');
|
|
538
588
|
}
|
|
539
|
-
if (!
|
|
589
|
+
if (!lodash_1.default.isUndefined(params.target) && !lodash_1.default.isNumber(params.target)) {
|
|
540
590
|
throw new Error('invalid target - should be number');
|
|
541
591
|
}
|
|
542
|
-
if (!
|
|
592
|
+
if (!lodash_1.default.isUndefined(params.instant) && !lodash_1.default.isBoolean(params.instant)) {
|
|
543
593
|
throw new Error('invalid instant flag - should be boolean');
|
|
544
594
|
}
|
|
545
|
-
if (!
|
|
595
|
+
if (!lodash_1.default.isUndefined(params.segwit) && !lodash_1.default.isBoolean(params.segwit)) {
|
|
546
596
|
throw new Error('invalid segwit flag - should be boolean');
|
|
547
597
|
}
|
|
548
|
-
if (!
|
|
598
|
+
if (!lodash_1.default.isUndefined(params.targetWalletUnspents) && !lodash_1.default.isInteger(params.targetWalletUnspents)) {
|
|
549
599
|
throw new Error('invalid targetWalletUnspents flag - should be number');
|
|
550
600
|
}
|
|
551
|
-
if (!
|
|
601
|
+
if (!lodash_1.default.isUndefined(params.minSize) && !lodash_1.default.isNumber(params.minSize)) {
|
|
552
602
|
throw new Error('invalid argument: minSize must be a number');
|
|
553
603
|
}
|
|
554
|
-
if (!
|
|
604
|
+
if (!lodash_1.default.isUndefined(params.instant) && !lodash_1.default.isUndefined(params.minConfirms)) {
|
|
555
605
|
throw new Error('only one of instant and minConfirms may be defined');
|
|
556
606
|
}
|
|
557
|
-
if (!
|
|
607
|
+
if (!lodash_1.default.isUndefined(params.targetWalletUnspents) && lodash_1.default.isUndefined(params.target)) {
|
|
558
608
|
throw new Error('targetWalletUnspents can only be specified in conjunction with a target');
|
|
559
609
|
}
|
|
560
|
-
if (!
|
|
610
|
+
if (!lodash_1.default.isUndefined(params.allowLedgerSegwit) && !lodash_1.default.isBoolean(params.allowLedgerSegwit)) {
|
|
561
611
|
throw new Error('invalid argument: allowLedgerSegwit must be a boolean');
|
|
562
612
|
}
|
|
563
|
-
const queryObject =
|
|
564
|
-
if (!
|
|
613
|
+
const queryObject = lodash_1.default.cloneDeep(params);
|
|
614
|
+
if (!lodash_1.default.isUndefined(params.target)) {
|
|
565
615
|
// skip and limit are unavailable when a target is specified
|
|
566
616
|
delete queryObject.skip;
|
|
567
617
|
delete queryObject.limit;
|
|
568
618
|
}
|
|
569
619
|
queryObject.segwit = true;
|
|
570
|
-
if (!
|
|
620
|
+
if (!lodash_1.default.isUndefined(params.segwit)) {
|
|
571
621
|
queryObject.segwit = params.segwit;
|
|
572
622
|
}
|
|
573
|
-
if (!
|
|
623
|
+
if (!lodash_1.default.isUndefined(params.allowLedgerSegwit)) {
|
|
574
624
|
queryObject.allowLedgerSegwit = params.allowLedgerSegwit;
|
|
575
625
|
}
|
|
576
|
-
return
|
|
626
|
+
return Promise.resolve(this.bitgo.get(this.url('/unspents')).query(queryObject).result())
|
|
627
|
+
.then(callback)
|
|
628
|
+
.catch(callback);
|
|
577
629
|
};
|
|
578
630
|
//
|
|
579
631
|
// transactions
|
|
@@ -585,37 +637,37 @@ Wallet.prototype.transactions = function (params, callback) {
|
|
|
585
637
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
586
638
|
const args = [];
|
|
587
639
|
if (params.limit) {
|
|
588
|
-
if (!
|
|
640
|
+
if (!lodash_1.default.isInteger(params.limit)) {
|
|
589
641
|
throw new Error('invalid limit argument, expecting number');
|
|
590
642
|
}
|
|
591
643
|
args.push('limit=' + params.limit);
|
|
592
644
|
}
|
|
593
645
|
if (params.skip) {
|
|
594
|
-
if (!
|
|
646
|
+
if (!lodash_1.default.isInteger(params.skip)) {
|
|
595
647
|
throw new Error('invalid skip argument, expecting number');
|
|
596
648
|
}
|
|
597
649
|
args.push('skip=' + params.skip);
|
|
598
650
|
}
|
|
599
651
|
if (params.minHeight) {
|
|
600
|
-
if (!
|
|
652
|
+
if (!lodash_1.default.isInteger(params.minHeight)) {
|
|
601
653
|
throw new Error('invalid minHeight argument, expecting number');
|
|
602
654
|
}
|
|
603
655
|
args.push('minHeight=' + params.minHeight);
|
|
604
656
|
}
|
|
605
657
|
if (params.maxHeight) {
|
|
606
|
-
if (!
|
|
658
|
+
if (!lodash_1.default.isInteger(params.maxHeight) || params.maxHeight < 0) {
|
|
607
659
|
throw new Error('invalid maxHeight argument, expecting positive integer');
|
|
608
660
|
}
|
|
609
661
|
args.push('maxHeight=' + params.maxHeight);
|
|
610
662
|
}
|
|
611
663
|
if (params.minConfirms) {
|
|
612
|
-
if (!
|
|
664
|
+
if (!lodash_1.default.isInteger(params.minConfirms) || params.minConfirms < 0) {
|
|
613
665
|
throw new Error('invalid minConfirms argument, expecting positive integer');
|
|
614
666
|
}
|
|
615
667
|
args.push('minConfirms=' + params.minConfirms);
|
|
616
668
|
}
|
|
617
|
-
if (!
|
|
618
|
-
if (!
|
|
669
|
+
if (!lodash_1.default.isUndefined(params.compact)) {
|
|
670
|
+
if (!lodash_1.default.isBoolean(params.compact)) {
|
|
619
671
|
throw new Error('invalid compact argument, expecting boolean');
|
|
620
672
|
}
|
|
621
673
|
args.push('compact=' + params.compact);
|
|
@@ -625,7 +677,7 @@ Wallet.prototype.transactions = function (params, callback) {
|
|
|
625
677
|
query = '?' + args.join('&');
|
|
626
678
|
}
|
|
627
679
|
const url = this.url('/tx' + query);
|
|
628
|
-
return
|
|
680
|
+
return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);
|
|
629
681
|
};
|
|
630
682
|
//
|
|
631
683
|
// transaction
|
|
@@ -634,7 +686,7 @@ Wallet.prototype.getTransaction = function (params, callback) {
|
|
|
634
686
|
params = params || {};
|
|
635
687
|
sdk_core_1.common.validateParams(params, ['id'], [], callback);
|
|
636
688
|
const url = this.url('/tx/' + params.id);
|
|
637
|
-
return
|
|
689
|
+
return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);
|
|
638
690
|
};
|
|
639
691
|
//
|
|
640
692
|
// pollForTransaction
|
|
@@ -647,10 +699,10 @@ Wallet.prototype.pollForTransaction = function (params, callback) {
|
|
|
647
699
|
const self = this;
|
|
648
700
|
params = params || {};
|
|
649
701
|
sdk_core_1.common.validateParams(params, ['id'], [], callback);
|
|
650
|
-
if (params.delay && !
|
|
702
|
+
if (params.delay && !lodash_1.default.isNumber(params.delay)) {
|
|
651
703
|
throw new Error('invalid delay parameter');
|
|
652
704
|
}
|
|
653
|
-
if (params.timeout && !
|
|
705
|
+
if (params.timeout && !lodash_1.default.isNumber(params.timeout)) {
|
|
654
706
|
throw new Error('invalid timeout parameter');
|
|
655
707
|
}
|
|
656
708
|
params.delay = params.delay || 1000;
|
|
@@ -666,7 +718,7 @@ Wallet.prototype.pollForTransaction = function (params, callback) {
|
|
|
666
718
|
if (err.status !== 404 || new Date().valueOf() - start.valueOf() > params.timeout) {
|
|
667
719
|
throw err;
|
|
668
720
|
}
|
|
669
|
-
return
|
|
721
|
+
return new Promise((resolve) => setTimeout(resolve, params.delay)).then(function () {
|
|
670
722
|
return doNextPoll();
|
|
671
723
|
});
|
|
672
724
|
});
|
|
@@ -680,7 +732,7 @@ Wallet.prototype.getWalletTransactionBySequenceId = function (params, callback)
|
|
|
680
732
|
params = params || {};
|
|
681
733
|
sdk_core_1.common.validateParams(params, ['sequenceId'], [], callback);
|
|
682
734
|
const url = this.url('/tx/sequence/' + params.sequenceId);
|
|
683
|
-
return
|
|
735
|
+
return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);
|
|
684
736
|
};
|
|
685
737
|
//
|
|
686
738
|
// Key chains
|
|
@@ -688,30 +740,31 @@ Wallet.prototype.getWalletTransactionBySequenceId = function (params, callback)
|
|
|
688
740
|
// The user key chain is typically the first keychain of the wallet and has the encrypted xpriv stored on BitGo.
|
|
689
741
|
// Useful when trying to get the users' keychain from the server before decrypting to sign a transaction.
|
|
690
742
|
Wallet.prototype.getEncryptedUserKeychain = function (params, callback) {
|
|
691
|
-
return
|
|
743
|
+
return async function () {
|
|
692
744
|
params = params || {};
|
|
693
745
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
694
746
|
// @ts-expect-error - no implicit this
|
|
695
747
|
const self = this;
|
|
696
|
-
|
|
748
|
+
async function tryKeyChain(index) {
|
|
697
749
|
if (!self.keychains || index >= self.keychains.length) {
|
|
698
750
|
const error = new Error('No encrypted keychains on this wallet.');
|
|
699
751
|
error.code = 'no_encrypted_keychain_on_wallet';
|
|
700
752
|
throw error;
|
|
701
753
|
}
|
|
702
754
|
const params = { xpub: self.keychains[index].xpub };
|
|
703
|
-
const keychain =
|
|
755
|
+
const keychain = await self.bitgo.keychains().get(params);
|
|
704
756
|
// If we find the xprv, then this is probably the user keychain we're looking for
|
|
705
757
|
keychain.walletSubPath = self.keychains[index].path;
|
|
706
758
|
if (keychain.encryptedXprv) {
|
|
707
759
|
return keychain;
|
|
708
760
|
}
|
|
709
761
|
return tryKeyChain(index + 1);
|
|
710
|
-
}
|
|
762
|
+
}
|
|
711
763
|
return tryKeyChain(0);
|
|
712
|
-
}
|
|
764
|
+
}
|
|
713
765
|
.call(this)
|
|
714
|
-
.
|
|
766
|
+
.then(callback)
|
|
767
|
+
.catch(callback);
|
|
715
768
|
};
|
|
716
769
|
//
|
|
717
770
|
// createTransaction
|
|
@@ -728,23 +781,23 @@ Wallet.prototype.getEncryptedUserKeychain = function (params, callback) {
|
|
|
728
781
|
// Returns:
|
|
729
782
|
// callback(err, { transactionHex: string, unspents: [inputs], fee: satoshis })
|
|
730
783
|
Wallet.prototype.createTransaction = function (params, callback) {
|
|
731
|
-
params =
|
|
784
|
+
params = lodash_1.default.extend({}, params);
|
|
732
785
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
733
|
-
if ((!
|
|
734
|
-
(!
|
|
735
|
-
(!
|
|
736
|
-
(!
|
|
737
|
-
(!
|
|
738
|
-
(!
|
|
739
|
-
(!
|
|
786
|
+
if ((!lodash_1.default.isNumber(params.fee) && !lodash_1.default.isUndefined(params.fee)) ||
|
|
787
|
+
(!lodash_1.default.isNumber(params.feeRate) && !lodash_1.default.isUndefined(params.feeRate)) ||
|
|
788
|
+
(!lodash_1.default.isNumber(params.minConfirms) && !lodash_1.default.isUndefined(params.minConfirms)) ||
|
|
789
|
+
(!lodash_1.default.isBoolean(params.forceChangeAtEnd) && !lodash_1.default.isUndefined(params.forceChangeAtEnd)) ||
|
|
790
|
+
(!lodash_1.default.isString(params.changeAddress) && !lodash_1.default.isUndefined(params.changeAddress)) ||
|
|
791
|
+
(!lodash_1.default.isBoolean(params.validate) && !lodash_1.default.isUndefined(params.validate)) ||
|
|
792
|
+
(!lodash_1.default.isBoolean(params.instant) && !lodash_1.default.isUndefined(params.instant))) {
|
|
740
793
|
throw new Error('invalid argument');
|
|
741
794
|
}
|
|
742
|
-
if (!
|
|
795
|
+
if (!lodash_1.default.isObject(params.recipients)) {
|
|
743
796
|
throw new Error('expecting recipients object');
|
|
744
797
|
}
|
|
745
798
|
params.validate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();
|
|
746
799
|
params.wallet = this;
|
|
747
|
-
return TransactionBuilder.createTransaction(params).
|
|
800
|
+
return TransactionBuilder.createTransaction(params).then(callback).catch(callback);
|
|
748
801
|
};
|
|
749
802
|
//
|
|
750
803
|
// signTransaction
|
|
@@ -760,12 +813,17 @@ Wallet.prototype.createTransaction = function (params, callback) {
|
|
|
760
813
|
// Returns:
|
|
761
814
|
// callback(err, transaction)
|
|
762
815
|
Wallet.prototype.signTransaction = function (params, callback) {
|
|
763
|
-
params =
|
|
816
|
+
params = lodash_1.default.extend({}, params);
|
|
817
|
+
if (params.psbt) {
|
|
818
|
+
return (0, util_1.tryPromise)(() => (0, signPsbt_1.signPsbtRequest)(params))
|
|
819
|
+
.then(callback)
|
|
820
|
+
.catch(callback);
|
|
821
|
+
}
|
|
764
822
|
sdk_core_1.common.validateParams(params, ['transactionHex'], [], callback);
|
|
765
823
|
if (!Array.isArray(params.unspents)) {
|
|
766
824
|
throw new Error('expecting the unspents array');
|
|
767
825
|
}
|
|
768
|
-
if ((!
|
|
826
|
+
if ((!lodash_1.default.isObject(params.keychain) || !params.keychain.xprv) && !lodash_1.default.isString(params.signingKey)) {
|
|
769
827
|
// allow passing in a WIF private key for legacy safe wallet support
|
|
770
828
|
const error = new Error('expecting keychain object with xprv or signingKey WIF');
|
|
771
829
|
error.code = 'missing_keychain_or_signingKey';
|
|
@@ -779,7 +837,8 @@ Wallet.prototype.signTransaction = function (params, callback) {
|
|
|
779
837
|
tx: result.transactionHex,
|
|
780
838
|
};
|
|
781
839
|
})
|
|
782
|
-
.
|
|
840
|
+
.then(callback)
|
|
841
|
+
.catch(callback);
|
|
783
842
|
};
|
|
784
843
|
//
|
|
785
844
|
// send
|
|
@@ -792,13 +851,13 @@ Wallet.prototype.signTransaction = function (params, callback) {
|
|
|
792
851
|
Wallet.prototype.sendTransaction = function (params, callback) {
|
|
793
852
|
params = params || {};
|
|
794
853
|
sdk_core_1.common.validateParams(params, ['tx'], ['message', 'otp'], callback);
|
|
795
|
-
return
|
|
854
|
+
return Promise.resolve(this.bitgo.post(this.bitgo.url('/tx/send')).send(params).result())
|
|
796
855
|
.then(function (body) {
|
|
797
856
|
if (body.pendingApproval) {
|
|
798
|
-
return
|
|
857
|
+
return lodash_1.default.extend(body, { status: 'pendingApproval' });
|
|
799
858
|
}
|
|
800
859
|
if (body.otp) {
|
|
801
|
-
return
|
|
860
|
+
return lodash_1.default.extend(body, { status: 'otp' });
|
|
802
861
|
}
|
|
803
862
|
return {
|
|
804
863
|
status: 'accepted',
|
|
@@ -808,7 +867,8 @@ Wallet.prototype.sendTransaction = function (params, callback) {
|
|
|
808
867
|
instantId: body.instantId,
|
|
809
868
|
};
|
|
810
869
|
})
|
|
811
|
-
.
|
|
870
|
+
.then(callback)
|
|
871
|
+
.catch(callback);
|
|
812
872
|
};
|
|
813
873
|
/**
|
|
814
874
|
* Share the wallet with an existing BitGo user.
|
|
@@ -820,7 +880,7 @@ Wallet.prototype.sendTransaction = function (params, callback) {
|
|
|
820
880
|
Wallet.prototype.createShare = function (params, callback) {
|
|
821
881
|
params = params || {};
|
|
822
882
|
sdk_core_1.common.validateParams(params, ['user', 'permissions'], [], callback);
|
|
823
|
-
if (params.keychain && !
|
|
883
|
+
if (params.keychain && !lodash_1.default.isEmpty(params.keychain)) {
|
|
824
884
|
if (!params.keychain.xpub ||
|
|
825
885
|
!params.keychain.encryptedXprv ||
|
|
826
886
|
!params.keychain.fromPubKey ||
|
|
@@ -829,7 +889,9 @@ Wallet.prototype.createShare = function (params, callback) {
|
|
|
829
889
|
throw new Error('requires keychain parameters - xpub, encryptedXprv, fromPubKey, toPubKey, path');
|
|
830
890
|
}
|
|
831
891
|
}
|
|
832
|
-
return
|
|
892
|
+
return Promise.resolve(this.bitgo.post(this.url('/share')).send(params).result())
|
|
893
|
+
.then(callback)
|
|
894
|
+
.catch(callback);
|
|
833
895
|
};
|
|
834
896
|
//
|
|
835
897
|
// createInvite
|
|
@@ -849,7 +911,9 @@ Wallet.prototype.createInvite = function (params, callback) {
|
|
|
849
911
|
if (params.message) {
|
|
850
912
|
options.message = params.message;
|
|
851
913
|
}
|
|
852
|
-
return
|
|
914
|
+
return Promise.resolve(this.bitgo.post(this.url('/invite')).send(options).result())
|
|
915
|
+
.then(callback)
|
|
916
|
+
.catch(callback);
|
|
853
917
|
};
|
|
854
918
|
//
|
|
855
919
|
// confirmInviteAndShareWallet
|
|
@@ -869,7 +933,7 @@ Wallet.prototype.confirmInviteAndShareWallet = function (params, callback) {
|
|
|
869
933
|
.listInvites()
|
|
870
934
|
.then(function (invites) {
|
|
871
935
|
const outgoing = invites.outgoing;
|
|
872
|
-
const invite =
|
|
936
|
+
const invite = lodash_1.default.find(outgoing, function (out) {
|
|
873
937
|
return out.id === params.walletInviteId;
|
|
874
938
|
});
|
|
875
939
|
if (!invite) {
|
|
@@ -887,7 +951,8 @@ Wallet.prototype.confirmInviteAndShareWallet = function (params, callback) {
|
|
|
887
951
|
// @ts-expect-error - no implicit this
|
|
888
952
|
return this.bitgo.put(this.bitgo.url('/walletinvite/' + params.walletInviteId));
|
|
889
953
|
})
|
|
890
|
-
.
|
|
954
|
+
.then(callback)
|
|
955
|
+
.catch(callback);
|
|
891
956
|
};
|
|
892
957
|
//
|
|
893
958
|
// sendCoins
|
|
@@ -910,12 +975,12 @@ Wallet.prototype.confirmInviteAndShareWallet = function (params, callback) {
|
|
|
910
975
|
Wallet.prototype.sendCoins = function (params, callback) {
|
|
911
976
|
params = params || {};
|
|
912
977
|
sdk_core_1.common.validateParams(params, ['address'], ['message'], callback);
|
|
913
|
-
if (!
|
|
978
|
+
if (!lodash_1.default.isNumber(params.amount)) {
|
|
914
979
|
throw new Error('invalid argument for amount - number expected');
|
|
915
980
|
}
|
|
916
981
|
params.recipients = {};
|
|
917
982
|
params.recipients[params.address] = params.amount;
|
|
918
|
-
return this.sendMany(params).
|
|
983
|
+
return this.sendMany(params).then(callback).catch(callback);
|
|
919
984
|
};
|
|
920
985
|
//
|
|
921
986
|
// sendMany
|
|
@@ -937,16 +1002,16 @@ Wallet.prototype.sendMany = function (params, callback) {
|
|
|
937
1002
|
params = params || {};
|
|
938
1003
|
sdk_core_1.common.validateParams(params, [], ['message', 'otp'], callback);
|
|
939
1004
|
const self = this;
|
|
940
|
-
if (!
|
|
1005
|
+
if (!lodash_1.default.isObject(params.recipients)) {
|
|
941
1006
|
throw new Error('expecting recipients object');
|
|
942
1007
|
}
|
|
943
|
-
if (params.fee && !
|
|
1008
|
+
if (params.fee && !lodash_1.default.isNumber(params.fee)) {
|
|
944
1009
|
throw new Error('invalid argument for fee - number expected');
|
|
945
1010
|
}
|
|
946
|
-
if (params.feeRate && !
|
|
1011
|
+
if (params.feeRate && !lodash_1.default.isNumber(params.feeRate)) {
|
|
947
1012
|
throw new Error('invalid argument for feeRate - number expected');
|
|
948
1013
|
}
|
|
949
|
-
if (params.instant && !
|
|
1014
|
+
if (params.instant && !lodash_1.default.isBoolean(params.instant)) {
|
|
950
1015
|
throw new Error('invalid argument for instant - boolean expected');
|
|
951
1016
|
}
|
|
952
1017
|
let bitgoFee;
|
|
@@ -965,7 +1030,7 @@ Wallet.prototype.sendMany = function (params, callback) {
|
|
|
965
1030
|
'noSplitChange',
|
|
966
1031
|
'comment',
|
|
967
1032
|
];
|
|
968
|
-
const preservedBuildParams =
|
|
1033
|
+
const preservedBuildParams = lodash_1.default.pick(params, acceptedBuildParams);
|
|
969
1034
|
// Get the user keychain
|
|
970
1035
|
const retPromise = this.createAndSignTransaction(params)
|
|
971
1036
|
.then(function (transaction) {
|
|
@@ -986,8 +1051,8 @@ Wallet.prototype.sendMany = function (params, callback) {
|
|
|
986
1051
|
})
|
|
987
1052
|
.then(function (result) {
|
|
988
1053
|
const tx = utxolib.bitgo.createTransactionFromHex(result.tx, utxolib.networks.bitcoin);
|
|
989
|
-
const inputsSum =
|
|
990
|
-
const outputsSum =
|
|
1054
|
+
const inputsSum = lodash_1.default.sumBy(unspentsUsed, 'value');
|
|
1055
|
+
const outputsSum = lodash_1.default.sumBy(tx.outs, 'value');
|
|
991
1056
|
const feeUsed = inputsSum - outputsSum;
|
|
992
1057
|
if (isNaN(feeUsed)) {
|
|
993
1058
|
throw new Error('invalid feeUsed');
|
|
@@ -1024,7 +1089,7 @@ Wallet.prototype.sendMany = function (params, callback) {
|
|
|
1024
1089
|
.then(function () {
|
|
1025
1090
|
return finalResult;
|
|
1026
1091
|
});
|
|
1027
|
-
return
|
|
1092
|
+
return Promise.resolve(retPromise).then(callback).catch(callback);
|
|
1028
1093
|
};
|
|
1029
1094
|
/**
|
|
1030
1095
|
* Accelerate a stuck transaction using Child-Pays-For-Parent (CPFP).
|
|
@@ -1077,11 +1142,11 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1077
1142
|
const estimateChildFee = ({ inputs, parentFee, parentVSize, feeRate }) => {
|
|
1078
1143
|
// calculate how much more we *should* have paid in parent fees,
|
|
1079
1144
|
// had the parent been originally sent with the new fee rate
|
|
1080
|
-
const additionalParentFee =
|
|
1145
|
+
const additionalParentFee = lodash_1.default.ceil((parentVSize * feeRate) / 1000) - parentFee;
|
|
1081
1146
|
// calculate how much we would pay in fees for the child,
|
|
1082
1147
|
// if it were only paying for itself at the new fee rate
|
|
1083
1148
|
const childFee = (estimateTxVSize(inputs) * feeRate) / 1000;
|
|
1084
|
-
return
|
|
1149
|
+
return lodash_1.default.ceil(childFee + additionalParentFee);
|
|
1085
1150
|
};
|
|
1086
1151
|
/**
|
|
1087
1152
|
* Helper function to find additional unspents to use to pay the child tx fees.
|
|
@@ -1097,7 +1162,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1097
1162
|
* the child tx, and the updated inputs for the child tx.
|
|
1098
1163
|
*/
|
|
1099
1164
|
const findAdditionalUnspents = ({ inputs, parentOutputValue, parentFee, parentVSize, maxUnspents }) => {
|
|
1100
|
-
return
|
|
1165
|
+
return async function coFindAdditionalUnspents() {
|
|
1101
1166
|
const additionalUnspents = [];
|
|
1102
1167
|
// ask the server for enough unspents to cover the child fee, assuming
|
|
1103
1168
|
// that it can be done without additional unspents (which is not possible,
|
|
@@ -1108,7 +1173,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1108
1173
|
while (uncoveredChildFee > 0 && additionalUnspents.length < maxUnspents) {
|
|
1109
1174
|
// try to get enough unspents to cover the rest of the child fee
|
|
1110
1175
|
// @ts-expect-error - no implicit this
|
|
1111
|
-
const unspents = (
|
|
1176
|
+
const unspents = (await this.unspents({
|
|
1112
1177
|
minConfirms: 1,
|
|
1113
1178
|
target: uncoveredChildFee,
|
|
1114
1179
|
limit: maxUnspents - additionalUnspents.length,
|
|
@@ -1123,7 +1188,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1123
1188
|
// return enough unspent value to ensure that the minimum change amount
|
|
1124
1189
|
// is achieved for the child tx, and we can't leave out those unspents
|
|
1125
1190
|
// or else the minimum change amount constraint could be violated
|
|
1126
|
-
|
|
1191
|
+
lodash_1.default.forEach(unspents, (unspent) => {
|
|
1127
1192
|
// update the child tx inputs
|
|
1128
1193
|
const unspentChain = getChain(unspent);
|
|
1129
1194
|
if (isChainCode(unspentChain) && scriptTypeForChain(unspentChain) === 'p2shP2wsh') {
|
|
@@ -1148,7 +1213,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1148
1213
|
newChildFee: currentChildFeeEstimate,
|
|
1149
1214
|
newInputs: inputs,
|
|
1150
1215
|
};
|
|
1151
|
-
}
|
|
1216
|
+
}.call(this);
|
|
1152
1217
|
};
|
|
1153
1218
|
/**
|
|
1154
1219
|
* Helper function to get a full copy (including witness data) of an arbitrary tx using only the tx id.
|
|
@@ -1164,7 +1229,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1164
1229
|
const explorerBaseUrl = sdk_core_1.common.Environments[self.bitgo.getEnv()].btcExplorerBaseUrl;
|
|
1165
1230
|
const result = await request.get(`${explorerBaseUrl}/tx/${parentTxId}/hex`);
|
|
1166
1231
|
if (!result.text || !/([a-f0-9]{2})+/.test(result.text)) {
|
|
1167
|
-
throw new Error(`Did not successfully receive parent tx hex. Received '${
|
|
1232
|
+
throw new Error(`Did not successfully receive parent tx hex. Received '${lodash_1.default.truncate(result.text, { length: 100 })}' instead.`);
|
|
1168
1233
|
}
|
|
1169
1234
|
return result.text;
|
|
1170
1235
|
}
|
|
@@ -1179,7 +1244,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1179
1244
|
return outputOrUnspent.chain;
|
|
1180
1245
|
}
|
|
1181
1246
|
if (outputOrUnspent.chainPath !== undefined) {
|
|
1182
|
-
return
|
|
1247
|
+
return lodash_1.default.toNumber(outputOrUnspent.chainPath.split('/')[1]);
|
|
1183
1248
|
}
|
|
1184
1249
|
// no way to tell the chain, let's just blow up now instead
|
|
1185
1250
|
// of blowing up later when the undefined return value is used.
|
|
@@ -1219,14 +1284,14 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1219
1284
|
* (and, if necessary, additional wallet unspents) as inputs
|
|
1220
1285
|
* 7) Broadcast the new child transaction
|
|
1221
1286
|
*/
|
|
1222
|
-
return
|
|
1287
|
+
return async function coAccelerateTransaction() {
|
|
1223
1288
|
params = params || {};
|
|
1224
1289
|
sdk_core_1.common.validateParams(params, ['transactionID'], [], callback);
|
|
1225
1290
|
// validate fee rate
|
|
1226
1291
|
if (params.feeRate === undefined) {
|
|
1227
1292
|
throw new Error('Missing parameter: feeRate');
|
|
1228
1293
|
}
|
|
1229
|
-
if (!
|
|
1294
|
+
if (!lodash_1.default.isFinite(params.feeRate) || params.feeRate <= 0) {
|
|
1230
1295
|
throw new Error('Expecting positive finite number for parameter: feeRate');
|
|
1231
1296
|
}
|
|
1232
1297
|
// validate maxUnspents
|
|
@@ -1234,16 +1299,16 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1234
1299
|
// by default, use at most 100 additional unspents (not including the unspent output from the parent tx)
|
|
1235
1300
|
params.maxAdditionalUnspents = 100;
|
|
1236
1301
|
}
|
|
1237
|
-
if (!
|
|
1302
|
+
if (!lodash_1.default.isInteger(params.maxAdditionalUnspents) || params.maxAdditionalUnspents <= 0) {
|
|
1238
1303
|
throw Error('Expecting positive integer for parameter: maxAdditionalUnspents');
|
|
1239
1304
|
}
|
|
1240
1305
|
// @ts-expect-error - no implicit this
|
|
1241
|
-
const parentTx =
|
|
1306
|
+
const parentTx = await this.getTransaction({ id: params.transactionID });
|
|
1242
1307
|
if (parentTx.confirmations > 0) {
|
|
1243
1308
|
throw new Error(`Transaction ${params.transactionID} is already confirmed and cannot be accelerated`);
|
|
1244
1309
|
}
|
|
1245
1310
|
// get the outputs from the parent tx which are to our wallet
|
|
1246
|
-
const walletOutputs =
|
|
1311
|
+
const walletOutputs = lodash_1.default.filter(parentTx.outputs, (output) => output.isMine);
|
|
1247
1312
|
if (walletOutputs.length === 0) {
|
|
1248
1313
|
throw new Error(`Transaction ${params.transactionID} contains no outputs to this wallet, and thus cannot be accelerated`);
|
|
1249
1314
|
}
|
|
@@ -1252,7 +1317,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1252
1317
|
// An output could be spent already if the output was used in a
|
|
1253
1318
|
// child tx which itself has become stuck due to low fees and is
|
|
1254
1319
|
// also unconfirmed.
|
|
1255
|
-
const sortedOutputs =
|
|
1320
|
+
const sortedOutputs = lodash_1.default.sortBy(walletOutputs, effectiveValue);
|
|
1256
1321
|
let parentUnspentToUse;
|
|
1257
1322
|
let outputToUse;
|
|
1258
1323
|
while (sortedOutputs.length > 0 && parentUnspentToUse === undefined) {
|
|
@@ -1261,11 +1326,11 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1261
1326
|
// TODO: is there a better way to get this unspent?
|
|
1262
1327
|
// TODO: The best we can do here is set minSize = maxSize = outputToUse.value
|
|
1263
1328
|
// @ts-expect-error - no implicit this
|
|
1264
|
-
const unspentsResult =
|
|
1329
|
+
const unspentsResult = await this.unspents({
|
|
1265
1330
|
minSize: outputToUse.value,
|
|
1266
1331
|
maxSize: outputToUse.value,
|
|
1267
1332
|
});
|
|
1268
|
-
parentUnspentToUse =
|
|
1333
|
+
parentUnspentToUse = lodash_1.default.find(unspentsResult, (unspent) => {
|
|
1269
1334
|
// make sure unspent belongs to the given txid
|
|
1270
1335
|
if (unspent.tx_hash !== params.transactionID) {
|
|
1271
1336
|
return false;
|
|
@@ -1278,7 +1343,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1278
1343
|
throw new Error(`Could not find unspent output from parent tx to use as child input`);
|
|
1279
1344
|
}
|
|
1280
1345
|
// get the full hex for the parent tx and decode it to get its vsize
|
|
1281
|
-
const parentTxHex =
|
|
1346
|
+
const parentTxHex = await getParentTxHex({ parentTxId: params.transactionID });
|
|
1282
1347
|
const decodedParent = utxolib.bitgo.createTransactionFromHex(parentTxHex, utxolib.networks.bitcoin);
|
|
1283
1348
|
const parentVSize = decodedParent.virtualSize();
|
|
1284
1349
|
// make sure id from decoded tx and given tx id match
|
|
@@ -1313,7 +1378,7 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1313
1378
|
if (outputToUse.value < childFee + minChangeSize) {
|
|
1314
1379
|
// parent output cannot cover child fee plus the minimum change,
|
|
1315
1380
|
// must find additional unspents to cover the difference
|
|
1316
|
-
const { additional, newChildFee, newInputs } =
|
|
1381
|
+
const { additional, newChildFee, newInputs } = await findAdditionalUnspents({
|
|
1317
1382
|
inputs: childInputs,
|
|
1318
1383
|
parentOutputValue: outputToUse.value,
|
|
1319
1384
|
parentFee: parentTx.fee,
|
|
@@ -1341,14 +1406,14 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1341
1406
|
// the tx builder will reject transactions which have no recipients,
|
|
1342
1407
|
// and such zero-output transactions are forbidden by the Bitcoin protocol,
|
|
1343
1408
|
// so we need at least a single recipient for the change which won't be pruned.
|
|
1344
|
-
const changeAmount =
|
|
1409
|
+
const changeAmount = lodash_1.default.sumBy(unspentsToUse, (unspent) => unspent.value) - childFee;
|
|
1345
1410
|
// @ts-expect-error - no implicit this
|
|
1346
1411
|
const changeChain = this.getChangeChain({});
|
|
1347
1412
|
// @ts-expect-error - no implicit this
|
|
1348
|
-
const changeAddress =
|
|
1413
|
+
const changeAddress = await this.createAddress({ chain: changeChain });
|
|
1349
1414
|
// create the child tx and broadcast
|
|
1350
1415
|
// @ts-expect-error - no implicit this
|
|
1351
|
-
const tx =
|
|
1416
|
+
const tx = await this.createAndSignTransaction({
|
|
1352
1417
|
unspents: unspentsToUse,
|
|
1353
1418
|
recipients: [
|
|
1354
1419
|
{
|
|
@@ -1373,9 +1438,10 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1373
1438
|
}
|
|
1374
1439
|
// @ts-expect-error - no implicit this
|
|
1375
1440
|
return this.sendTransaction(tx);
|
|
1376
|
-
}
|
|
1441
|
+
}
|
|
1377
1442
|
.call(this)
|
|
1378
|
-
.
|
|
1443
|
+
.then(callback)
|
|
1444
|
+
.catch(callback);
|
|
1379
1445
|
};
|
|
1380
1446
|
//
|
|
1381
1447
|
// createAndSignTransaction
|
|
@@ -1388,26 +1454,26 @@ Wallet.prototype.accelerateTransaction = function accelerateTransaction(params,
|
|
|
1388
1454
|
// Returns:
|
|
1389
1455
|
//
|
|
1390
1456
|
Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
1391
|
-
return
|
|
1457
|
+
return async function () {
|
|
1392
1458
|
params = params || {};
|
|
1393
1459
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
1394
|
-
if (!
|
|
1460
|
+
if (!lodash_1.default.isObject(params.recipients)) {
|
|
1395
1461
|
throw new Error('expecting recipients object');
|
|
1396
1462
|
}
|
|
1397
|
-
if (params.fee && !
|
|
1463
|
+
if (params.fee && !lodash_1.default.isNumber(params.fee)) {
|
|
1398
1464
|
throw new Error('invalid argument for fee - number expected');
|
|
1399
1465
|
}
|
|
1400
|
-
if (params.feeRate && !
|
|
1466
|
+
if (params.feeRate && !lodash_1.default.isNumber(params.feeRate)) {
|
|
1401
1467
|
throw new Error('invalid argument for feeRate - number expected');
|
|
1402
1468
|
}
|
|
1403
|
-
if (params.dynamicFeeConfirmTarget && !
|
|
1469
|
+
if (params.dynamicFeeConfirmTarget && !lodash_1.default.isNumber(params.dynamicFeeConfirmTarget)) {
|
|
1404
1470
|
throw new Error('invalid argument for confirmTarget - number expected');
|
|
1405
1471
|
}
|
|
1406
|
-
if (params.instant && !
|
|
1472
|
+
if (params.instant && !lodash_1.default.isBoolean(params.instant)) {
|
|
1407
1473
|
throw new Error('invalid argument for instant - boolean expected');
|
|
1408
1474
|
}
|
|
1409
1475
|
// @ts-expect-error - no implicit this
|
|
1410
|
-
const transaction = (
|
|
1476
|
+
const transaction = (await this.createTransaction(params));
|
|
1411
1477
|
const fee = transaction.fee;
|
|
1412
1478
|
const feeRate = transaction.feeRate;
|
|
1413
1479
|
const estimatedSize = transaction.estimatedSize;
|
|
@@ -1417,7 +1483,7 @@ Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
|
1417
1483
|
// Sign the transaction
|
|
1418
1484
|
try {
|
|
1419
1485
|
// @ts-expect-error - no implicit this
|
|
1420
|
-
const keychain =
|
|
1486
|
+
const keychain = await this.getAndPrepareSigningKeychain(params);
|
|
1421
1487
|
transaction.keychain = keychain;
|
|
1422
1488
|
}
|
|
1423
1489
|
catch (e) {
|
|
@@ -1426,10 +1492,10 @@ Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
|
1426
1492
|
}
|
|
1427
1493
|
// this might be a safe wallet, so let's retrieve the private key info
|
|
1428
1494
|
// @ts-expect-error - no implicit this
|
|
1429
|
-
|
|
1495
|
+
await this.refresh({ gpk: true });
|
|
1430
1496
|
// @ts-expect-error - no implicit this
|
|
1431
|
-
const safeUserKey =
|
|
1432
|
-
if (
|
|
1497
|
+
const safeUserKey = lodash_1.default.get(this.wallet, 'private.userPrivKey');
|
|
1498
|
+
if (lodash_1.default.isString(safeUserKey) && lodash_1.default.isString(params.walletPassphrase)) {
|
|
1433
1499
|
// @ts-expect-error - no implicit this
|
|
1434
1500
|
transaction.signingKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: safeUserKey });
|
|
1435
1501
|
}
|
|
@@ -1439,8 +1505,8 @@ Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
|
1439
1505
|
}
|
|
1440
1506
|
transaction.feeSingleKeyWIF = params.feeSingleKeyWIF;
|
|
1441
1507
|
// @ts-expect-error - no implicit this
|
|
1442
|
-
const result =
|
|
1443
|
-
return
|
|
1508
|
+
const result = await this.signTransaction(transaction);
|
|
1509
|
+
return lodash_1.default.extend(result, {
|
|
1444
1510
|
fee,
|
|
1445
1511
|
feeRate,
|
|
1446
1512
|
instant: params.instant,
|
|
@@ -1449,9 +1515,10 @@ Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
|
1449
1515
|
estimatedSize,
|
|
1450
1516
|
unspents,
|
|
1451
1517
|
});
|
|
1452
|
-
}
|
|
1518
|
+
}
|
|
1453
1519
|
.call(this)
|
|
1454
|
-
.
|
|
1520
|
+
.then(callback)
|
|
1521
|
+
.catch(callback);
|
|
1455
1522
|
};
|
|
1456
1523
|
//
|
|
1457
1524
|
// getAndPrepareSigningKeychain
|
|
@@ -1471,8 +1538,8 @@ Wallet.prototype.createAndSignTransaction = function (params, callback) {
|
|
|
1471
1538
|
Wallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {
|
|
1472
1539
|
params = params || {};
|
|
1473
1540
|
// If keychain with xprv is already provided, use it
|
|
1474
|
-
if (
|
|
1475
|
-
return
|
|
1541
|
+
if (lodash_1.default.isObject(params.keychain) && params.keychain.xprv) {
|
|
1542
|
+
return Promise.resolve(params.keychain);
|
|
1476
1543
|
}
|
|
1477
1544
|
sdk_core_1.common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);
|
|
1478
1545
|
if ((params.walletPassphrase && params.xprv) || (!params.walletPassphrase && !params.xprv)) {
|
|
@@ -1489,6 +1556,9 @@ Wallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {
|
|
|
1489
1556
|
catch (e) {
|
|
1490
1557
|
throw new Error('Unable to decrypt user keychain');
|
|
1491
1558
|
}
|
|
1559
|
+
if (keychain.xpub && utxo_lib_1.bip32.fromBase58(keychain.xprv).neutered().toBase58() !== keychain.xpub) {
|
|
1560
|
+
throw new Error('derived xpub does not match stored xpub');
|
|
1561
|
+
}
|
|
1492
1562
|
return keychain;
|
|
1493
1563
|
});
|
|
1494
1564
|
}
|
|
@@ -1503,8 +1573,8 @@ Wallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {
|
|
|
1503
1573
|
if (xpub === params.xprv) {
|
|
1504
1574
|
throw new Error('xprv provided was not a private key (found xpub instead)');
|
|
1505
1575
|
}
|
|
1506
|
-
const walletXpubs =
|
|
1507
|
-
if (!
|
|
1576
|
+
const walletXpubs = lodash_1.default.map(self.keychains, 'xpub');
|
|
1577
|
+
if (!lodash_1.default.includes(walletXpubs, xpub)) {
|
|
1508
1578
|
throw new Error('xprv provided was not a keychain on this wallet!');
|
|
1509
1579
|
}
|
|
1510
1580
|
// get the keychain object from bitgo to find the path and (potential) wallet structure
|
|
@@ -1528,7 +1598,7 @@ Wallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {
|
|
|
1528
1598
|
*/
|
|
1529
1599
|
Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
1530
1600
|
const self = this;
|
|
1531
|
-
return
|
|
1601
|
+
return (async function () {
|
|
1532
1602
|
// maximum number of inputs for fanout transaction
|
|
1533
1603
|
// (when fanning out, we take all the unspents and make a bigger number of outputs)
|
|
1534
1604
|
const MAX_FANOUT_INPUT_COUNT = 80;
|
|
@@ -1539,7 +1609,7 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1539
1609
|
const validate = params.validate === undefined ? true : params.validate;
|
|
1540
1610
|
const target = params.target;
|
|
1541
1611
|
// the target must be defined, be a number, be at least two, and be a natural number
|
|
1542
|
-
if (!
|
|
1612
|
+
if (!lodash_1.default.isNumber(target) || target < 2 || target % 1 !== 0) {
|
|
1543
1613
|
throw new Error('Target needs to be a positive integer');
|
|
1544
1614
|
}
|
|
1545
1615
|
if (target > MAX_FANOUT_OUTPUT_COUNT) {
|
|
@@ -1549,7 +1619,7 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1549
1619
|
if (minConfirms === undefined) {
|
|
1550
1620
|
minConfirms = 1;
|
|
1551
1621
|
}
|
|
1552
|
-
if (!
|
|
1622
|
+
if (!lodash_1.default.isNumber(minConfirms) || minConfirms < 0) {
|
|
1553
1623
|
throw new Error('minConfirms needs to be an integer >= 0');
|
|
1554
1624
|
}
|
|
1555
1625
|
/**
|
|
@@ -1567,18 +1637,18 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1567
1637
|
// initialize placeholder array
|
|
1568
1638
|
const almostEqualParts = new Array(partCount);
|
|
1569
1639
|
// fill the first remainder parts with the value partSize+1
|
|
1570
|
-
|
|
1640
|
+
lodash_1.default.fill(almostEqualParts, partSize + 1, 0, remainder);
|
|
1571
1641
|
// fill the remaining parts with the value partSize
|
|
1572
|
-
|
|
1642
|
+
lodash_1.default.fill(almostEqualParts, partSize, remainder);
|
|
1573
1643
|
// assert the correctness of the almost equal parts
|
|
1574
1644
|
// TODO: add check for the biggest deviation between any two parts and make sure it's <= 1
|
|
1575
|
-
if (
|
|
1645
|
+
if ((0, lodash_1.default)(almostEqualParts).sum() !== total || (0, lodash_1.default)(almostEqualParts).size() !== partCount) {
|
|
1576
1646
|
throw new Error('part sum or part count mismatch');
|
|
1577
1647
|
}
|
|
1578
1648
|
return almostEqualParts;
|
|
1579
1649
|
};
|
|
1580
1650
|
// first, let's take all the wallet's unspents (with min confirms if necessary)
|
|
1581
|
-
const allUnspents = (
|
|
1651
|
+
const allUnspents = (await self.unspents({ minConfirms: minConfirms }));
|
|
1582
1652
|
if (allUnspents.length < 1) {
|
|
1583
1653
|
throw new Error('No unspents to branch out');
|
|
1584
1654
|
}
|
|
@@ -1592,22 +1662,22 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1592
1662
|
throw new Error('Too many unspents');
|
|
1593
1663
|
}
|
|
1594
1664
|
// this is all the money that is currently in the wallet
|
|
1595
|
-
const grossAmount =
|
|
1665
|
+
const grossAmount = (0, lodash_1.default)(allUnspents).map('value').sum();
|
|
1596
1666
|
// in order to not modify the params object, we create a copy
|
|
1597
|
-
const txParams =
|
|
1667
|
+
const txParams = lodash_1.default.extend({}, params);
|
|
1598
1668
|
txParams.unspents = allUnspents;
|
|
1599
1669
|
txParams.recipients = {};
|
|
1600
1670
|
// create target amount of new addresses for this wallet
|
|
1601
|
-
const newAddressPromises =
|
|
1602
|
-
const newAddresses =
|
|
1671
|
+
const newAddressPromises = lodash_1.default.range(target).map(() => self.createAddress({ chain: self.getChangeChain(params), validate: validate }));
|
|
1672
|
+
const newAddresses = await Promise.all(newAddressPromises);
|
|
1603
1673
|
// let's find a nice, equal distribution of our Satoshis among the new addresses
|
|
1604
1674
|
const splitAmounts = splitNumberIntoCloseNaturalNumbers(grossAmount, target);
|
|
1605
1675
|
// map the newly created addresses to the almost components amounts we just calculated
|
|
1606
|
-
txParams.recipients =
|
|
1676
|
+
txParams.recipients = lodash_1.default.zipObject(lodash_1.default.map(newAddresses, 'address'), splitAmounts);
|
|
1607
1677
|
txParams.noSplitChange = true;
|
|
1608
1678
|
// attempt to create a transaction. As it is a wallet-sweeping transaction with no fee, we expect it to fail
|
|
1609
1679
|
try {
|
|
1610
|
-
|
|
1680
|
+
await self.sendMany(txParams);
|
|
1611
1681
|
}
|
|
1612
1682
|
catch (error) {
|
|
1613
1683
|
// as expected, the transaction creation did indeed fail due to insufficient fees
|
|
@@ -1615,7 +1685,7 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1615
1685
|
// however, let's make sure it wasn't something else
|
|
1616
1686
|
if (!error.fee && (!error.result || !error.result.fee)) {
|
|
1617
1687
|
// if the error does not contain a fee property, it is something else that has gone awry, and we throw it
|
|
1618
|
-
const debugParams =
|
|
1688
|
+
const debugParams = lodash_1.default.omit(txParams, ['walletPassphrase', 'xprv']);
|
|
1619
1689
|
error.message += `\n\nTX PARAMS:\n ${JSON.stringify(debugParams, null, 4)}`;
|
|
1620
1690
|
throw error;
|
|
1621
1691
|
}
|
|
@@ -1637,20 +1707,22 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1637
1707
|
// that means that the distribution has to be recalculated
|
|
1638
1708
|
const remainingSplitAmounts = splitNumberIntoCloseNaturalNumbers(netAmount, target);
|
|
1639
1709
|
// and the distribution again mapped to the new addresses
|
|
1640
|
-
txParams.recipients =
|
|
1710
|
+
txParams.recipients = lodash_1.default.zipObject(lodash_1.default.map(newAddresses, 'address'), remainingSplitAmounts);
|
|
1641
1711
|
}
|
|
1642
1712
|
// this time, the transaction creation should work
|
|
1643
1713
|
let fanoutTx;
|
|
1644
1714
|
try {
|
|
1645
|
-
fanoutTx =
|
|
1715
|
+
fanoutTx = await self.sendMany(txParams);
|
|
1646
1716
|
}
|
|
1647
1717
|
catch (e) {
|
|
1648
|
-
const debugParams =
|
|
1718
|
+
const debugParams = lodash_1.default.omit(txParams, ['walletPassphrase', 'xprv']);
|
|
1649
1719
|
e.message += `\n\nTX PARAMS:\n ${JSON.stringify(debugParams, null, 4)}`;
|
|
1650
1720
|
throw e;
|
|
1651
1721
|
}
|
|
1652
|
-
return
|
|
1653
|
-
})()
|
|
1722
|
+
return Promise.resolve(fanoutTx).then(callback).catch(callback);
|
|
1723
|
+
})()
|
|
1724
|
+
.then(callback)
|
|
1725
|
+
.catch(callback);
|
|
1654
1726
|
};
|
|
1655
1727
|
/**
|
|
1656
1728
|
* Determine whether to fan out or coalesce a wallet's unspents
|
|
@@ -1661,7 +1733,7 @@ Wallet.prototype.fanOutUnspents = function (params, callback) {
|
|
|
1661
1733
|
Wallet.prototype.regroupUnspents = function (params, callback) {
|
|
1662
1734
|
params = params || {};
|
|
1663
1735
|
const target = params.target;
|
|
1664
|
-
if (!
|
|
1736
|
+
if (!lodash_1.default.isNumber(target) || target < 1 || target % 1 !== 0) {
|
|
1665
1737
|
// the target must be defined, be a number, be at least one, and be a natural number
|
|
1666
1738
|
throw new Error('Target needs to be a positive integer');
|
|
1667
1739
|
}
|
|
@@ -1669,7 +1741,7 @@ Wallet.prototype.regroupUnspents = function (params, callback) {
|
|
|
1669
1741
|
if (minConfirms === undefined) {
|
|
1670
1742
|
minConfirms = 1;
|
|
1671
1743
|
}
|
|
1672
|
-
if (!
|
|
1744
|
+
if (!lodash_1.default.isNumber(minConfirms) || minConfirms < 0) {
|
|
1673
1745
|
throw new Error('minConfirms needs to be an integer equal to or bigger than 0');
|
|
1674
1746
|
}
|
|
1675
1747
|
const self = this;
|
|
@@ -1705,14 +1777,14 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1705
1777
|
if (target === undefined) {
|
|
1706
1778
|
target = 1;
|
|
1707
1779
|
}
|
|
1708
|
-
else if (!
|
|
1780
|
+
else if (!lodash_1.default.isNumber(target) || target < 1 || target % 1 !== 0) {
|
|
1709
1781
|
// the target must be defined, be a number, be at least one, and be a natural number
|
|
1710
1782
|
throw new Error('Target needs to be a positive integer');
|
|
1711
1783
|
}
|
|
1712
|
-
if (params.maxSize && !
|
|
1784
|
+
if (params.maxSize && !lodash_1.default.isNumber(params.maxSize)) {
|
|
1713
1785
|
throw new Error('maxSize should be a number');
|
|
1714
1786
|
}
|
|
1715
|
-
if (params.minSize && !
|
|
1787
|
+
if (params.minSize && !lodash_1.default.isNumber(params.minSize)) {
|
|
1716
1788
|
throw new Error('minSize should be a number');
|
|
1717
1789
|
}
|
|
1718
1790
|
// maximum number of inputs per transaction for consolidation
|
|
@@ -1729,7 +1801,7 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1729
1801
|
throw new Error('Maximum consolidation input count cannot be bigger than ' + MAX_INPUT_COUNT);
|
|
1730
1802
|
}
|
|
1731
1803
|
const maxIterationCount = params.maxIterationCount || -1;
|
|
1732
|
-
if ((params.maxIterationCount && (!
|
|
1804
|
+
if ((params.maxIterationCount && (!lodash_1.default.isNumber(maxIterationCount) || maxIterationCount < 1)) ||
|
|
1733
1805
|
maxIterationCount % 1 !== 0) {
|
|
1734
1806
|
throw new Error('Maximum iteration count needs to be an integer equal to or bigger than 1');
|
|
1735
1807
|
}
|
|
@@ -1737,7 +1809,7 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1737
1809
|
if (minConfirms === undefined) {
|
|
1738
1810
|
minConfirms = 1;
|
|
1739
1811
|
}
|
|
1740
|
-
if (!
|
|
1812
|
+
if (!lodash_1.default.isNumber(minConfirms) || minConfirms < 0) {
|
|
1741
1813
|
throw new Error('minConfirms needs to be an integer equal to or bigger than 0');
|
|
1742
1814
|
}
|
|
1743
1815
|
let minSize = params.minSize || 0;
|
|
@@ -1762,7 +1834,7 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1762
1834
|
* Consolidate one batch of up to MAX_INPUT_COUNT unspents.
|
|
1763
1835
|
* @returns {*}
|
|
1764
1836
|
*/
|
|
1765
|
-
|
|
1837
|
+
async function runNextConsolidation() {
|
|
1766
1838
|
const consolidationTransactions = [];
|
|
1767
1839
|
let isFinalConsolidation = false;
|
|
1768
1840
|
iterationCount++;
|
|
@@ -1785,7 +1857,7 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1785
1857
|
if (params.maxSize) {
|
|
1786
1858
|
queryParams.maxSize = params.maxSize;
|
|
1787
1859
|
}
|
|
1788
|
-
const allUnspents = (
|
|
1860
|
+
const allUnspents = (await self.unspents(queryParams));
|
|
1789
1861
|
// this consolidation is essentially just a waste of money
|
|
1790
1862
|
if (allUnspents.length <= target) {
|
|
1791
1863
|
if (iterationCount <= 1) {
|
|
@@ -1809,11 +1881,11 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1809
1881
|
isFinalConsolidation = inputCount === targetInputCount || iterationCount === maxIterationCount;
|
|
1810
1882
|
const currentChunk = allUnspents.splice(0, inputCount);
|
|
1811
1883
|
const changeChain = self.getChangeChain(params);
|
|
1812
|
-
const newAddress = (
|
|
1813
|
-
const txParams =
|
|
1884
|
+
const newAddress = (await self.createAddress({ chain: changeChain, validate: validate }));
|
|
1885
|
+
const txParams = lodash_1.default.extend({}, params);
|
|
1814
1886
|
const currentAddress = newAddress;
|
|
1815
1887
|
// the total amount that we are consolidating within this batch
|
|
1816
|
-
const grossAmount =
|
|
1888
|
+
const grossAmount = (0, lodash_1.default)(currentChunk).map('value').sum(); // before fees
|
|
1817
1889
|
txParams.unspents = currentChunk;
|
|
1818
1890
|
txParams.recipients = {};
|
|
1819
1891
|
txParams.recipients[newAddress.address] = grossAmount;
|
|
@@ -1823,14 +1895,14 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1823
1895
|
}
|
|
1824
1896
|
// let's attempt to create this transaction. We expect it to fail because no fee is set.
|
|
1825
1897
|
try {
|
|
1826
|
-
|
|
1898
|
+
await self.sendMany(txParams);
|
|
1827
1899
|
}
|
|
1828
1900
|
catch (error) {
|
|
1829
1901
|
// this error should occur due to insufficient funds
|
|
1830
1902
|
// however, let's make sure it wasn't something else
|
|
1831
1903
|
if (!error.fee && (!error.result || !error.result.fee)) {
|
|
1832
1904
|
// if the error does not contain a fee property, it is something else that has gone awry, and we throw it
|
|
1833
|
-
const debugParams =
|
|
1905
|
+
const debugParams = lodash_1.default.omit(txParams, ['walletPassphrase', 'xprv']);
|
|
1834
1906
|
error.message += `\n\nTX PARAMS:\n ${JSON.stringify(debugParams, null, 4)}`;
|
|
1835
1907
|
throw error;
|
|
1836
1908
|
}
|
|
@@ -1856,15 +1928,15 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1856
1928
|
// this transaction, on the other hand, should be created with no issues, because an appropriate fee is set
|
|
1857
1929
|
let sentTx;
|
|
1858
1930
|
try {
|
|
1859
|
-
sentTx =
|
|
1931
|
+
sentTx = await self.sendMany(txParams);
|
|
1860
1932
|
}
|
|
1861
1933
|
catch (e) {
|
|
1862
|
-
const debugParams =
|
|
1934
|
+
const debugParams = lodash_1.default.omit(txParams, ['walletPassphrase', 'xprv']);
|
|
1863
1935
|
e.message += `\n\nTX PARAMS:\n ${JSON.stringify(debugParams, null, 4)}`;
|
|
1864
1936
|
throw e;
|
|
1865
1937
|
}
|
|
1866
1938
|
consolidationTransactions.push(sentTx);
|
|
1867
|
-
if (
|
|
1939
|
+
if (lodash_1.default.isFunction(params.progressCallback)) {
|
|
1868
1940
|
params.progressCallback({
|
|
1869
1941
|
txid: sentTx.hash,
|
|
1870
1942
|
destination: currentAddress,
|
|
@@ -1879,32 +1951,33 @@ Wallet.prototype.consolidateUnspents = function (params, callback) {
|
|
|
1879
1951
|
// this last consolidation has not yet brought the unspents count down to the target unspent count
|
|
1880
1952
|
// therefore, we proceed by consolidating yet another batch
|
|
1881
1953
|
// before we do that, we wait 1 second so that the newly created unspent will be fetched in the next batch
|
|
1882
|
-
|
|
1883
|
-
consolidationTransactions.push(...(
|
|
1954
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
1955
|
+
consolidationTransactions.push(...(await runNextConsolidation()));
|
|
1884
1956
|
}
|
|
1885
1957
|
// this is the final consolidation transaction. We return all the ones we've had so far
|
|
1886
1958
|
return consolidationTransactions;
|
|
1887
|
-
}
|
|
1888
|
-
return runNextConsolidation(
|
|
1959
|
+
}
|
|
1960
|
+
return runNextConsolidation()
|
|
1889
1961
|
.catch(function (err) {
|
|
1890
1962
|
if (err.message === 'Done') {
|
|
1891
1963
|
return;
|
|
1892
1964
|
}
|
|
1893
1965
|
throw err;
|
|
1894
1966
|
})
|
|
1895
|
-
.
|
|
1967
|
+
.then(callback)
|
|
1968
|
+
.catch(callback);
|
|
1896
1969
|
};
|
|
1897
1970
|
Wallet.prototype.shareWallet = function (params, callback) {
|
|
1898
1971
|
params = params || {};
|
|
1899
1972
|
sdk_core_1.common.validateParams(params, ['email', 'permissions'], ['walletPassphrase', 'message'], callback);
|
|
1900
|
-
if (params.reshare !== undefined && !
|
|
1973
|
+
if (params.reshare !== undefined && !lodash_1.default.isBoolean(params.reshare)) {
|
|
1901
1974
|
throw new Error('Expected reshare to be a boolean.');
|
|
1902
1975
|
}
|
|
1903
|
-
if (params.skipKeychain !== undefined && !
|
|
1976
|
+
if (params.skipKeychain !== undefined && !lodash_1.default.isBoolean(params.skipKeychain)) {
|
|
1904
1977
|
throw new Error('Expected skipKeychain to be a boolean. ');
|
|
1905
1978
|
}
|
|
1906
1979
|
const needsKeychain = !params.skipKeychain && params.permissions.indexOf('spend') !== -1;
|
|
1907
|
-
if (params.disableEmail !== undefined && !
|
|
1980
|
+
if (params.disableEmail !== undefined && !lodash_1.default.isBoolean(params.disableEmail)) {
|
|
1908
1981
|
throw new Error('Expected disableEmail to be a boolean.');
|
|
1909
1982
|
}
|
|
1910
1983
|
const self = this;
|
|
@@ -1927,8 +2000,8 @@ Wallet.prototype.shareWallet = function (params, callback) {
|
|
|
1927
2000
|
catch (e) {
|
|
1928
2001
|
throw new Error('Unable to decrypt user keychain');
|
|
1929
2002
|
}
|
|
1930
|
-
const eckey = sdk_core_1.makeRandomKey();
|
|
1931
|
-
const secret = sdk_core_1.getSharedSecret(eckey, Buffer.from(sharing.pubkey, 'hex')).toString('hex');
|
|
2003
|
+
const eckey = (0, sdk_core_1.makeRandomKey)();
|
|
2004
|
+
const secret = (0, sdk_core_1.getSharedSecret)(eckey, Buffer.from(sharing.pubkey, 'hex')).toString('hex');
|
|
1932
2005
|
const newEncryptedXprv = self.bitgo.encrypt({ password: secret, input: keychain.xprv });
|
|
1933
2006
|
sharedKeychain = {
|
|
1934
2007
|
xpub: keychain.xpub,
|
|
@@ -1957,46 +2030,59 @@ Wallet.prototype.shareWallet = function (params, callback) {
|
|
|
1957
2030
|
}
|
|
1958
2031
|
return self.createShare(options);
|
|
1959
2032
|
})
|
|
1960
|
-
.
|
|
2033
|
+
.then(callback)
|
|
2034
|
+
.catch(callback);
|
|
1961
2035
|
};
|
|
1962
2036
|
Wallet.prototype.removeUser = function (params, callback) {
|
|
1963
2037
|
params = params || {};
|
|
1964
2038
|
sdk_core_1.common.validateParams(params, ['user'], [], callback);
|
|
1965
|
-
return
|
|
2039
|
+
return Promise.resolve(this.bitgo
|
|
1966
2040
|
.del(this.url('/user/' + params.user))
|
|
1967
2041
|
.send()
|
|
1968
|
-
.result())
|
|
2042
|
+
.result())
|
|
2043
|
+
.then(callback)
|
|
2044
|
+
.catch(callback);
|
|
1969
2045
|
};
|
|
1970
2046
|
Wallet.prototype.getPolicy = function (params, callback) {
|
|
1971
2047
|
params = params || {};
|
|
1972
2048
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
1973
|
-
return
|
|
2049
|
+
return Promise.resolve(this.bitgo.get(this.url('/policy')).send().result())
|
|
2050
|
+
.then(callback)
|
|
2051
|
+
.catch(callback);
|
|
1974
2052
|
};
|
|
1975
2053
|
Wallet.prototype.getPolicyStatus = function (params, callback) {
|
|
1976
2054
|
params = params || {};
|
|
1977
2055
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
1978
|
-
return
|
|
2056
|
+
return Promise.resolve(this.bitgo.get(this.url('/policy/status')).send().result())
|
|
2057
|
+
.then(callback)
|
|
2058
|
+
.catch(callback);
|
|
1979
2059
|
};
|
|
1980
2060
|
Wallet.prototype.setPolicyRule = function (params, callback) {
|
|
1981
2061
|
params = params || {};
|
|
1982
2062
|
sdk_core_1.common.validateParams(params, ['id', 'type'], ['message'], callback);
|
|
1983
|
-
if (!
|
|
2063
|
+
if (!lodash_1.default.isObject(params.condition)) {
|
|
1984
2064
|
throw new Error('missing parameter: conditions object');
|
|
1985
2065
|
}
|
|
1986
|
-
if (!
|
|
2066
|
+
if (!lodash_1.default.isObject(params.action)) {
|
|
1987
2067
|
throw new Error('missing parameter: action object');
|
|
1988
2068
|
}
|
|
1989
|
-
return
|
|
2069
|
+
return Promise.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result())
|
|
2070
|
+
.then(callback)
|
|
2071
|
+
.catch(callback);
|
|
1990
2072
|
};
|
|
1991
2073
|
Wallet.prototype.removePolicyRule = function (params, callback) {
|
|
1992
2074
|
params = params || {};
|
|
1993
2075
|
sdk_core_1.common.validateParams(params, ['id'], ['message'], callback);
|
|
1994
|
-
return
|
|
2076
|
+
return Promise.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result())
|
|
2077
|
+
.then(callback)
|
|
2078
|
+
.catch(callback);
|
|
1995
2079
|
};
|
|
1996
2080
|
Wallet.prototype.listWebhooks = function (params, callback) {
|
|
1997
2081
|
params = params || {};
|
|
1998
2082
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
1999
|
-
return
|
|
2083
|
+
return Promise.resolve(this.bitgo.get(this.url('/webhooks')).send().result())
|
|
2084
|
+
.then(callback)
|
|
2085
|
+
.catch(callback);
|
|
2000
2086
|
};
|
|
2001
2087
|
/**
|
|
2002
2088
|
* Simulate wallet webhook, currently for webhooks of type transaction and pending approval
|
|
@@ -2018,43 +2104,49 @@ Wallet.prototype.simulateWebhook = function (params, callback) {
|
|
|
2018
2104
|
// depending on the coin type of the wallet, the txHash has to adhere to its respective format
|
|
2019
2105
|
// but the server takes care of that
|
|
2020
2106
|
// only take the txHash and pendingApprovalId properties
|
|
2021
|
-
const filteredParams =
|
|
2107
|
+
const filteredParams = lodash_1.default.pick(params, ['txHash', 'pendingApprovalId']);
|
|
2022
2108
|
const webhookId = params.webhookId;
|
|
2023
|
-
return
|
|
2109
|
+
return Promise.resolve(this.bitgo
|
|
2024
2110
|
.post(this.url('/webhooks/' + webhookId + '/simulate'))
|
|
2025
2111
|
.send(filteredParams)
|
|
2026
|
-
.result())
|
|
2112
|
+
.result())
|
|
2113
|
+
.then(callback)
|
|
2114
|
+
.catch(callback);
|
|
2027
2115
|
};
|
|
2028
2116
|
Wallet.prototype.addWebhook = function (params, callback) {
|
|
2029
2117
|
params = params || {};
|
|
2030
2118
|
sdk_core_1.common.validateParams(params, ['url', 'type'], [], callback);
|
|
2031
|
-
return
|
|
2119
|
+
return Promise.resolve(this.bitgo.post(this.url('/webhooks')).send(params).result())
|
|
2120
|
+
.then(callback)
|
|
2121
|
+
.catch(callback);
|
|
2032
2122
|
};
|
|
2033
2123
|
Wallet.prototype.removeWebhook = function (params, callback) {
|
|
2034
2124
|
params = params || {};
|
|
2035
2125
|
sdk_core_1.common.validateParams(params, ['url', 'type'], [], callback);
|
|
2036
|
-
return
|
|
2126
|
+
return Promise.resolve(this.bitgo.del(this.url('/webhooks')).send(params).result())
|
|
2127
|
+
.then(callback)
|
|
2128
|
+
.catch(callback);
|
|
2037
2129
|
};
|
|
2038
2130
|
Wallet.prototype.estimateFee = function (params, callback) {
|
|
2039
2131
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
2040
2132
|
if (params.amount && params.recipients) {
|
|
2041
2133
|
throw new Error('cannot specify both amount as well as recipients');
|
|
2042
2134
|
}
|
|
2043
|
-
if (params.recipients && !
|
|
2135
|
+
if (params.recipients && !lodash_1.default.isObject(params.recipients)) {
|
|
2044
2136
|
throw new Error('recipients must be array of { address: abc, amount: 100000 } objects');
|
|
2045
2137
|
}
|
|
2046
|
-
if (params.amount && !
|
|
2138
|
+
if (params.amount && !lodash_1.default.isNumber(params.amount)) {
|
|
2047
2139
|
throw new Error('invalid amount argument, expecting number');
|
|
2048
2140
|
}
|
|
2049
2141
|
const recipients = params.recipients || [];
|
|
2050
2142
|
if (params.amount) {
|
|
2051
2143
|
// only the amount was passed in, so we need to make a false recipient to run createTransaction with
|
|
2052
2144
|
recipients.push({
|
|
2053
|
-
address: sdk_core_1.common.Environments[this.bitgo.env].signingAddress,
|
|
2145
|
+
address: sdk_core_1.common.Environments[this.bitgo.env].signingAddress, // any address will do
|
|
2054
2146
|
amount: params.amount,
|
|
2055
2147
|
});
|
|
2056
2148
|
}
|
|
2057
|
-
const transactionParams =
|
|
2149
|
+
const transactionParams = lodash_1.default.extend({}, params);
|
|
2058
2150
|
transactionParams.amount = undefined;
|
|
2059
2151
|
transactionParams.recipients = recipients;
|
|
2060
2152
|
return this.createTransaction(transactionParams).then(function (tx) {
|
|
@@ -2069,12 +2161,16 @@ Wallet.prototype.estimateFee = function (params, callback) {
|
|
|
2069
2161
|
Wallet.prototype.updatePolicyRule = function (params, callback) {
|
|
2070
2162
|
params = params || {};
|
|
2071
2163
|
sdk_core_1.common.validateParams(params, ['id', 'type'], [], callback);
|
|
2072
|
-
return
|
|
2164
|
+
return Promise.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result())
|
|
2165
|
+
.then(callback)
|
|
2166
|
+
.catch(callback);
|
|
2073
2167
|
};
|
|
2074
2168
|
Wallet.prototype.deletePolicyRule = function (params, callback) {
|
|
2075
2169
|
params = params || {};
|
|
2076
2170
|
sdk_core_1.common.validateParams(params, ['id'], [], callback);
|
|
2077
|
-
return
|
|
2171
|
+
return Promise.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result())
|
|
2172
|
+
.then(callback)
|
|
2173
|
+
.catch(callback);
|
|
2078
2174
|
};
|
|
2079
2175
|
//
|
|
2080
2176
|
// getBitGoFee
|
|
@@ -2083,13 +2179,121 @@ Wallet.prototype.deletePolicyRule = function (params, callback) {
|
|
|
2083
2179
|
Wallet.prototype.getBitGoFee = function (params, callback) {
|
|
2084
2180
|
params = params || {};
|
|
2085
2181
|
sdk_core_1.common.validateParams(params, [], [], callback);
|
|
2086
|
-
if (!
|
|
2182
|
+
if (!lodash_1.default.isNumber(params.amount)) {
|
|
2087
2183
|
throw new Error('invalid amount argument');
|
|
2088
2184
|
}
|
|
2089
|
-
if (params.instant && !
|
|
2185
|
+
if (params.instant && !lodash_1.default.isBoolean(params.instant)) {
|
|
2090
2186
|
throw new Error('invalid instant argument');
|
|
2091
2187
|
}
|
|
2092
|
-
return
|
|
2188
|
+
return Promise.resolve(this.bitgo.get(this.url('/billing/fee')).query(params).result())
|
|
2189
|
+
.then(callback)
|
|
2190
|
+
.catch(callback);
|
|
2191
|
+
};
|
|
2192
|
+
/*
|
|
2193
|
+
* @params
|
|
2194
|
+
* walletPassphrase: passphrase of wallet used to decrypt the encrypted keys
|
|
2195
|
+
* unspents: array of unspents to recover
|
|
2196
|
+
* recoveryDestination: destination address to recover funds to
|
|
2197
|
+
* feeRate: fee rate to use for the recovery transaction
|
|
2198
|
+
* userKey: encrypted user key
|
|
2199
|
+
* backupKey: encrypted backup key
|
|
2200
|
+
* */
|
|
2201
|
+
Wallet.prototype.recover = async function (params) {
|
|
2202
|
+
if (lodash_1.default.isUndefined(params.walletPassphrase)) {
|
|
2203
|
+
throw new Error('missing walletPassphrase');
|
|
2204
|
+
}
|
|
2205
|
+
if (lodash_1.default.isUndefined(params.unspents)) {
|
|
2206
|
+
throw new Error('missing unspents');
|
|
2207
|
+
}
|
|
2208
|
+
if (lodash_1.default.isUndefined(params.recoveryDestination)) {
|
|
2209
|
+
throw new Error('invalid recoveryDestination');
|
|
2210
|
+
}
|
|
2211
|
+
if (lodash_1.default.isUndefined(params.feeRate)) {
|
|
2212
|
+
throw new Error('invalid feeRate');
|
|
2213
|
+
}
|
|
2214
|
+
if (lodash_1.default.isUndefined(params.userKey)) {
|
|
2215
|
+
throw new Error('invalid userKey');
|
|
2216
|
+
}
|
|
2217
|
+
if (lodash_1.default.isUndefined(params.backupKey)) {
|
|
2218
|
+
throw new Error('invalid backupKey');
|
|
2219
|
+
}
|
|
2220
|
+
const totalInputAmount = BigInt(utxolib.bitgo.unspentSum(params.unspents));
|
|
2221
|
+
if (totalInputAmount <= BigInt(0)) {
|
|
2222
|
+
throw new sdk_core_1.ErrorNoInputToRecover();
|
|
2223
|
+
}
|
|
2224
|
+
const outputSize = unspents_1.VirtualSizes.txP2wshOutputSize;
|
|
2225
|
+
const approximateSize = unspents_1.VirtualSizes.txSegOverheadVSize + outputSize + unspents_1.VirtualSizes.txP2shInputSize * params.unspents.length;
|
|
2226
|
+
const approximateTxFee = BigInt(approximateSize * params.feeRate);
|
|
2227
|
+
const recoveryAmount = totalInputAmount - approximateTxFee;
|
|
2228
|
+
const recipients = [{ address: params.recoveryDestination, amount: Number(recoveryAmount) }];
|
|
2229
|
+
const unsignedTx = await this.createTransaction({
|
|
2230
|
+
unspents: params.unspents,
|
|
2231
|
+
recipients,
|
|
2232
|
+
fee: Number(approximateTxFee),
|
|
2233
|
+
});
|
|
2234
|
+
const parsedUnsignedTx = utxolib.bitgo.createTransactionFromHex(unsignedTx.transactionHex, utxolib.networks.bitcoin);
|
|
2235
|
+
(0, assert_1.default)(parsedUnsignedTx.ins.length === params.unspents.length);
|
|
2236
|
+
(0, assert_1.default)(parsedUnsignedTx.outs.length === 1);
|
|
2237
|
+
(0, assert_1.default)(lodash_1.default.sumBy(params.unspents, 'value') - lodash_1.default.sumBy(parsedUnsignedTx.outs, 'value') === Number(approximateTxFee));
|
|
2238
|
+
const plainUserKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.userKey });
|
|
2239
|
+
const halfSignedTx = await this.signTransaction({ ...unsignedTx, signingKey: plainUserKey });
|
|
2240
|
+
const plainBackupKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.backupKey });
|
|
2241
|
+
const fullSignedTx = await this.signTransaction({
|
|
2242
|
+
...unsignedTx,
|
|
2243
|
+
transactionHex: halfSignedTx.tx,
|
|
2244
|
+
signingKey: plainBackupKey,
|
|
2245
|
+
});
|
|
2246
|
+
return fullSignedTx.tx;
|
|
2247
|
+
};
|
|
2248
|
+
/*
|
|
2249
|
+
* @params
|
|
2250
|
+
* walletPassphrase: passphrase of wallet used to decrypt the encrypted keys
|
|
2251
|
+
* unspents: array of unspents to recover
|
|
2252
|
+
* recoveryDestination: destination address to recover funds to
|
|
2253
|
+
* feeRate: fee rate to use for the recovery transaction
|
|
2254
|
+
* userKey: encrypted user key
|
|
2255
|
+
* */
|
|
2256
|
+
Wallet.prototype.sweep = async function (params) {
|
|
2257
|
+
if (lodash_1.default.isUndefined(params.walletPassphrase)) {
|
|
2258
|
+
throw new Error('missing walletPassphrase');
|
|
2259
|
+
}
|
|
2260
|
+
if (lodash_1.default.isUndefined(params.unspents)) {
|
|
2261
|
+
throw new Error('missing unspents');
|
|
2262
|
+
}
|
|
2263
|
+
if (lodash_1.default.isUndefined(params.recoveryDestination)) {
|
|
2264
|
+
throw new Error('invalid recoveryDestination');
|
|
2265
|
+
}
|
|
2266
|
+
if (lodash_1.default.isUndefined(params.feeRate)) {
|
|
2267
|
+
throw new Error('invalid feeRate');
|
|
2268
|
+
}
|
|
2269
|
+
if (lodash_1.default.isUndefined(params.userKey)) {
|
|
2270
|
+
throw new Error('invalid userKey');
|
|
2271
|
+
}
|
|
2272
|
+
const totalInputAmount = BigInt(utxolib.bitgo.unspentSum(params.unspents));
|
|
2273
|
+
if (totalInputAmount <= BigInt(0)) {
|
|
2274
|
+
throw new sdk_core_1.ErrorNoInputToRecover();
|
|
2275
|
+
}
|
|
2276
|
+
const outputSize = unspents_1.VirtualSizes.txP2wshOutputSize;
|
|
2277
|
+
const approximateSize = unspents_1.VirtualSizes.txSegOverheadVSize + outputSize + unspents_1.VirtualSizes.txP2shInputSize * params.unspents.length;
|
|
2278
|
+
const approximateTxFee = BigInt(approximateSize * params.feeRate);
|
|
2279
|
+
const recoveryAmount = totalInputAmount - approximateTxFee;
|
|
2280
|
+
const recipients = [{ address: params.recoveryDestination, amount: Number(recoveryAmount) }];
|
|
2281
|
+
const unsignedTx = await this.createTransaction({
|
|
2282
|
+
unspents: params.unspents,
|
|
2283
|
+
recipients,
|
|
2284
|
+
fee: Number(approximateTxFee),
|
|
2285
|
+
});
|
|
2286
|
+
const parsedUnsignedTx = utxolib.bitgo.createTransactionFromHex(unsignedTx.transactionHex, utxolib.networks.bitcoin);
|
|
2287
|
+
(0, assert_1.default)(parsedUnsignedTx.ins.length === params.unspents.length);
|
|
2288
|
+
(0, assert_1.default)(parsedUnsignedTx.outs.length === 1);
|
|
2289
|
+
(0, assert_1.default)(lodash_1.default.sumBy(params.unspents, 'value') - lodash_1.default.sumBy(parsedUnsignedTx.outs, 'value') === Number(approximateTxFee));
|
|
2290
|
+
const plainUserKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.userKey });
|
|
2291
|
+
const halfSignedTx = await this.signTransaction({ ...unsignedTx, signingKey: plainUserKey });
|
|
2292
|
+
return await this.sendTransaction({
|
|
2293
|
+
tx: halfSignedTx.tx,
|
|
2294
|
+
suppressBroadcast: true,
|
|
2295
|
+
otp: params.otp,
|
|
2296
|
+
});
|
|
2093
2297
|
};
|
|
2094
2298
|
module.exports = Wallet;
|
|
2095
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../../src/v1/wallet.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @hidden\n */\n\n/**\n */\n//\n// Wallet Object\n// BitGo accessor for a specific wallet\n//\n// Copyright 2014, BitGo, Inc.  All Rights Reserved.\n//\n\nimport { VirtualSizes } from '@bitgo-beta/unspents';\n\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nconst TransactionBuilder = require('./transactionBuilder');\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nconst PendingApproval = require('./pendingapproval');\n\nimport { common, getNetwork, getSharedSecret, makeRandomKey, sanitizeLegacyPath } from '@bitgo-beta/sdk-core';\nimport * as Bluebird from 'bluebird';\nconst co = Bluebird.coroutine;\nimport * as _ from 'lodash';\nconst { getExternalChainCode, getInternalChainCode, isChainCode, scriptTypeForChain } = utxolib.bitgo;\nconst request = require('superagent');\n\n//\n// Constructor\n//\nconst Wallet = function (bitgo, wallet) {\n  // @ts-expect-error - no implicit this\n  (this.bitgo as any) = bitgo;\n  // @ts-expect-error - no implicit this\n  this.wallet = wallet;\n  // @ts-expect-error - no implicit this\n  this.keychains = [];\n\n  if (wallet.private) {\n    // @ts-expect-error - no implicit this\n    this.keychains = wallet.private.keychains;\n  }\n};\n\nWallet.prototype.toJSON = function () {\n  return this.wallet;\n};\n\n//\n// id\n// Get the id of this wallet.\n//\nWallet.prototype.id = function () {\n  return this.wallet.id;\n};\n\n//\n// label\n// Get the label of this wallet.\n//\nWallet.prototype.label = function () {\n  return this.wallet.label;\n};\n\n//\n// balance\n// Get the balance of this wallet.\n//\nWallet.prototype.balance = function () {\n  return this.wallet.balance;\n};\n\n//\n// balance\n// Get the spendable balance of this wallet.\n// This is the total of all unspents except those that are unconfirmed and external\n//\nWallet.prototype.spendableBalance = function () {\n  return this.wallet.spendableBalance;\n};\n\n//\n// confirmedBalance\n// Get the confirmedBalance of this wallet.\n//\nWallet.prototype.confirmedBalance = function () {\n  return this.wallet.confirmedBalance;\n};\n\n//\n// canSendInstant\n// Returns if the wallet can send instant transactions\n// This is impacted by the choice of backup key provider\n//\nWallet.prototype.canSendInstant = function () {\n  return this.wallet && this.wallet.canSendInstant;\n};\n\n//\n// instant balance\n// Get the instant balance of this wallet.\n// This is the total of all unspents that may be spent instantly.\n//\nWallet.prototype.instantBalance = function () {\n  if (!this.canSendInstant()) {\n    throw new Error('not an instant wallet');\n  }\n  return this.wallet.instantBalance;\n};\n\n//\n// unconfirmedSends\n// Get the balance of unconfirmedSends of this wallet.\n//\nWallet.prototype.unconfirmedSends = function () {\n  return this.wallet.unconfirmedSends;\n};\n\n//\n// unconfirmedReceives\n// Get the balance of unconfirmedReceives balance of this wallet.\n//\nWallet.prototype.unconfirmedReceives = function () {\n  return this.wallet.unconfirmedReceives;\n};\n\n//\n// type\n// Get the type of this wallet, e.g. 'safehd'\n//\nWallet.prototype.type = function () {\n  return this.wallet.type;\n};\n\nWallet.prototype.url = function (extra) {\n  extra = extra || '';\n  return this.bitgo.url('/wallet/' + this.id() + extra);\n};\n\n//\n// pendingApprovals\n// returns the pending approvals list for this wallet as pending approval objects\n//\nWallet.prototype.pendingApprovals = function () {\n  const self = this;\n  return this.wallet.pendingApprovals.map(function (p) {\n    return new PendingApproval(self.bitgo, p, self);\n  });\n};\n\n//\n// approvalsRequired\n// returns the number of approvals required to approve pending approvals involving this wallet\n//\nWallet.prototype.approvalsRequired = function () {\n  return this.wallet.approvalsRequired || 1;\n};\n\n//\n// get\n// Refetches this wallet and returns it\n//\nWallet.prototype.get = function (params, callback): Bluebird<any> {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const self = this;\n\n  return Bluebird.resolve(\n    this.bitgo\n      .get(this.url())\n      .result()\n      .then(function (res) {\n        self.wallet = res;\n        return self;\n      })\n  ).nodeify(callback);\n};\n\n//\n// updateApprovalsRequired\n// Updates the number of approvals required on a pending approval involving this wallet.\n// The approvals required is by default 1, but this function allows you to update the\n// number such that 1 <= approvalsRequired <= walletAdmins.length - 1\n//\nWallet.prototype.updateApprovalsRequired = function (params, callback): Bluebird<any> {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (\n    params.approvalsRequired === undefined ||\n    !_.isInteger(params.approvalsRequired) ||\n    params.approvalsRequired < 1\n  ) {\n    throw new Error('invalid approvalsRequired: must be a nonzero positive number');\n  }\n\n  const self = this;\n  const currentApprovalsRequired = this.approvalsRequired();\n  if (currentApprovalsRequired === params.approvalsRequired) {\n    // no-op, just return the current wallet\n    return Bluebird.try(function () {\n      return self.wallet;\n    }).nodeify(callback);\n  }\n\n  return Bluebird.resolve(this.bitgo.put(this.url()).send(params).result()).nodeify(callback);\n};\n\n/**\n * Returns the correct chain for change, taking into consideration segwit\n */\nWallet.prototype.getChangeChain = function (params) {\n  let useSegwitChange = !!this.bitgo.getConstants().enableSegwit;\n  if (!_.isUndefined(params.segwitChange)) {\n    if (!_.isBoolean(params.segwitChange)) {\n      throw new Error('segwitChange must be a boolean');\n    }\n\n    // if segwit is disabled through the constants, segwit change should still not be created\n    useSegwitChange = this.bitgo.getConstants().enableSegwit && params.segwitChange;\n  }\n  return useSegwitChange ? getInternalChainCode('p2shP2wsh') : getInternalChainCode('p2sh');\n};\n\n//\n// createAddress\n// Creates a new address for use with this wallet.\n//\nWallet.prototype.createAddress = function (params, callback) {\n  const self = this;\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (this.type() === 'safe') {\n    throw new Error('You are using a legacy wallet that cannot create a new address');\n  }\n\n  // Default to client-side address validation on, for safety. Use validate=false to disable.\n  const shouldValidate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n\n  const allowExisting = params.allowExisting;\n  if (typeof allowExisting !== 'boolean') {\n    params.allowExisting = allowExisting === 'true';\n  }\n\n  const isSegwit = this.bitgo.getConstants().enableSegwit;\n  const defaultChain = isSegwit ? getExternalChainCode('p2shP2wsh') : getExternalChainCode('p2sh');\n\n  let chain = params.chain;\n  if (chain === null || chain === undefined) {\n    chain = defaultChain;\n  }\n  return Bluebird.resolve(\n    this.bitgo\n      .post(this.url('/address/' + chain))\n      .send(params)\n      .result()\n      .then(function (addr) {\n        if (shouldValidate) {\n          self.validateAddress(addr);\n        }\n        return addr;\n      })\n  ).nodeify(callback);\n};\n\n/**\n * Generate address locally without calling server\n * @param params\n *\n */\nWallet.prototype.generateAddress = function ({ segwit, path, keychains, threshold }) {\n  const isSegwit = !!segwit;\n  let signatureThreshold = 2;\n  if (_.isInteger(threshold)) {\n    signatureThreshold = threshold;\n    if (signatureThreshold <= 0) {\n      throw new Error('threshold has to be positive');\n    }\n  }\n\n  const pathRegex = /^\\/1?[01]\\/\\d+$/;\n  if (!path.match(pathRegex)) {\n    throw new Error('unsupported path: ' + path);\n  }\n\n  let rootKeys = this.keychains;\n  if (Array.isArray(keychains)) {\n    rootKeys = keychains;\n  }\n\n  const network = common.Environments[this.bitgo.getEnv()].network;\n\n  const derivedKeys = rootKeys.map(function (k) {\n    const hdnode = bip32.fromBase58(k.xpub);\n    const derivationPath = k.path + (k.walletSubPath || '') + path;\n    return hdnode.derivePath(sanitizeLegacyPath(derivationPath)).publicKey;\n  });\n\n  const pathComponents = path.split('/');\n  const normalizedPathComponents = _.map(pathComponents, (component) => {\n    if (component && component.length > 0) {\n      return parseInt(component, 10);\n    }\n  });\n  const pathDetails = _.filter(normalizedPathComponents, _.isInteger);\n\n  const addressDetails: any = {\n    chainPath: path,\n    path: path,\n    chain: pathDetails[0],\n    index: pathDetails[1],\n    wallet: this.id(),\n  };\n\n  const {\n    scriptPubKey: outputScript,\n    redeemScript,\n    witnessScript,\n  } = utxolib.bitgo.outputScripts.createOutputScript2of3(derivedKeys, isSegwit ? 'p2shP2wsh' : 'p2sh');\n\n  addressDetails.witnessScript = witnessScript?.toString('hex');\n  addressDetails.redeemScript = redeemScript?.toString('hex');\n  addressDetails.outputScript = outputScript.toString('hex');\n  addressDetails.address = utxolib.address.fromOutputScript(outputScript, getNetwork(network));\n\n  return addressDetails;\n};\n\n//\n// validateAddress\n// Validates an address and path by calculating it locally from the keychain xpubs\n//\nWallet.prototype.validateAddress = function (params) {\n  common.validateParams(params, ['address', 'path'], []);\n  const isSegwit = !!params.witnessScript && params.witnessScript.length > 0;\n\n  const generatedAddress = this.generateAddress({ path: params.path, segwit: isSegwit });\n  if (generatedAddress.address !== params.address) {\n    throw new Error('address validation failure: ' + params.address + ' vs. ' + generatedAddress.address);\n  }\n};\n\n//\n// addresses\n// Gets the addresses of a HD wallet.\n// Options include:\n//  limit: the number of addresses to get\n//\nWallet.prototype.addresses = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const query: any = {};\n  if (params.details) {\n    query.details = 1;\n  }\n\n  const chain = params.chain;\n  if (chain !== null && chain !== undefined) {\n    if (Array.isArray(chain)) {\n      query.chain = _.uniq(_.filter(chain, _.isInteger));\n    } else {\n      if (chain !== 0 && chain !== 1) {\n        throw new Error('invalid chain argument, expecting 0 or 1');\n      }\n      query.chain = chain;\n    }\n  }\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    query.limit = params.limit;\n  }\n  if (params.skip) {\n    if (!_.isInteger(params.skip)) {\n      throw new Error('invalid skip argument, expecting number');\n    }\n    query.skip = params.skip;\n  }\n  if (params.sort) {\n    if (!_.isNumber(params.sort)) {\n      throw new Error('invalid sort argument, expecting number');\n    }\n    query.sort = params.sort;\n  }\n\n  const url = this.url('/addresses');\n  return Bluebird.resolve(this.bitgo.get(url).query(query).result()).nodeify(callback);\n};\n\nWallet.prototype.stats = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  const args: string[] = [];\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    args.push('limit=' + params.limit);\n  }\n  let query = '';\n  if (args.length) {\n    query = '?' + args.join('&');\n  }\n\n  const url = this.url('/stats' + query);\n\n  return Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);\n};\n\n/**\n * Refresh the wallet object by syncing with the back-end\n * @param callback\n * @returns {Wallet}\n */\nWallet.prototype.refresh = function (params, callback) {\n  return co(function* () {\n    // when set to true, gpk returns the private data of safe wallets\n    const query = _.extend({}, _.pick(params, ['gpk']));\n    // @ts-expect-error - no implicit this\n    const res = yield this.bitgo.get(this.url()).query(query).result();\n    // @ts-expect-error - no implicit this\n    this.wallet = res;\n    // @ts-expect-error - no implicit this\n    return this;\n  })\n    .call(this)\n    .asCallback(callback);\n};\n\n//\n// address\n// Gets information about a single address on a HD wallet.\n// Information includes index, path, redeemScript, sent, received, txCount and balance\n// Options include:\n//  address: the address on this wallet to get\n//\nWallet.prototype.address = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  const url = this.url('/addresses/' + params.address);\n\n  return Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);\n};\n\n/**\n * Freeze the wallet for a duration of choice, stopping BitGo from signing any transactions.\n * @param {number} limit The duration to freeze the wallet for in seconds, defaults to 3600.\n */\nWallet.prototype.freeze = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  if (params.duration) {\n    if (!_.isNumber(params.duration)) {\n      throw new Error('invalid duration - should be number of seconds');\n    }\n  }\n\n  return Bluebird.resolve(this.bitgo.post(this.url('/freeze')).send(params).result()).nodeify(callback);\n};\n\n//\n// delete\n// Deletes the wallet\n//\nWallet.prototype.delete = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Bluebird.resolve(this.bitgo.del(this.url()).result()).nodeify(callback);\n};\n\n//\n// labels\n// List the labels for the addresses in a given wallet\n//\nWallet.prototype.labels = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const url = this.bitgo.url('/labels/' + this.id());\n\n  return Bluebird.resolve(this.bitgo.get(url).result('labels')).nodeify(callback);\n};\n\n/**\n * Rename a wallet\n * @param params\n *  - label: the wallet's intended new name\n * @param callback\n * @returns {*}\n */\nWallet.prototype.setWalletName = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['label'], [], callback);\n\n  const url = this.bitgo.url('/wallet/' + this.id());\n  return Bluebird.resolve(this.bitgo.put(url).send({ label: params.label }).result()).nodeify(callback);\n};\n\n//\n// setLabel\n// Sets a label on the provided address\n//\nWallet.prototype.setLabel = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address', 'label'], [], callback);\n\n  const self = this;\n\n  if (!self.bitgo.verifyAddress({ address: params.address })) {\n    throw new Error('Invalid bitcoin address: ' + params.address);\n  }\n\n  const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);\n\n  return Bluebird.resolve(this.bitgo.put(url).send({ label: params.label }).result()).nodeify(callback);\n};\n\n//\n// deleteLabel\n// Deletes the label associated with the provided address\n//\nWallet.prototype.deleteLabel = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  const self = this;\n\n  if (!self.bitgo.verifyAddress({ address: params.address })) {\n    throw new Error('Invalid bitcoin address: ' + params.address);\n  }\n\n  const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);\n\n  return Bluebird.resolve(this.bitgo.del(url).result()).nodeify(callback);\n};\n\n//\n// unspents\n// List ALL the unspents for a given wallet\n// This method will return a paged list of all unspents\n//\n// Parameters include:\n//   limit:  the optional limit of unspents to collect in BTC\n//   minConf: only include results with this number of confirmations\n//   target: the amount of btc to find to spend\n//   instant: only find instant transactions (must specify a target)\n//\nWallet.prototype.unspents = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const allUnspents: any[] = [];\n  const self = this;\n\n  const getUnspentsBatch = function (skip, limit?) {\n    const queryObject = _.cloneDeep(params);\n    if (skip > 0) {\n      queryObject.skip = skip;\n    }\n    if (limit && limit > 0) {\n      queryObject.limit = limit;\n    }\n\n    return self.unspentsPaged(queryObject).then(function (result) {\n      // The API has its own limit handling. For example, the API does not support limits bigger than 500. If the limit\n      // specified here is bigger than that, we will have to do multiple requests with necessary limit adjustment.\n      for (let i = 0; i < result.unspents.length; i++) {\n        const unspent = result.unspents[i];\n        allUnspents.push(unspent);\n      }\n\n      // Our limit adjustment makes sure that we never fetch more unspents than we need, meaning that if we hit the\n      // limit, we hit it precisely\n      if (allUnspents.length >= params.limit) {\n        return allUnspents; // we aren't interested in any further unspents\n      }\n\n      const totalUnspentCount = result.total;\n      // if no target is specified and the SDK indicates that there has been a limit, we need to fetch another batch\n      if (!params.target && totalUnspentCount && totalUnspentCount > allUnspents.length) {\n        // we need to fetch the next batch\n        // let's just offset the current skip by the count\n        const newSkip = skip + result.count;\n        let newLimit: number | undefined;\n        if (limit > 0) {\n          // we set the new limit to be precisely the number of missing unspents to hit our own limit\n          newLimit = limit - allUnspents.length;\n        }\n        return getUnspentsBatch(newSkip, newLimit);\n      }\n\n      return allUnspents;\n    });\n  };\n\n  return getUnspentsBatch(0, params.limit).nodeify(callback);\n};\n\n/**\n * List the unspents (paged) for a given wallet, returning the result as an object of unspents, count, skip and total\n * This method may not return all the unspents as the list is paged by the API\n * @param params\n * @param params.limit the optional limit of unspents to collect in BTC\n * @param params.skip index in list of unspents to start paging from\n * @param params.minConfirms only include results with this number of confirmations\n * @param params.target the amount of btc to find to spend\n * @param params.instant only find instant transactions (must specify a target)\n * @param params.targetWalletUnspents desired number of unspents to have in the wallet after the tx goes through (requires target)\n * @param params.minSize minimum unspent size in satoshis\n * @param params.segwit request segwit unspents (defaults to true if undefined)\n * @param params.allowLedgerSegwit allow segwit unspents for ledger devices (defaults to false if undefined)\n * @param callback\n * @returns {*}\n */\nWallet.prototype.unspentsPaged = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  if (!_.isUndefined(params.limit) && !_.isInteger(params.limit)) {\n    throw new Error('invalid limit - should be number');\n  }\n  if (!_.isUndefined(params.skip) && !_.isInteger(params.skip)) {\n    throw new Error('invalid skip - should be number');\n  }\n  if (!_.isUndefined(params.minConfirms) && !_.isInteger(params.minConfirms)) {\n    throw new Error('invalid minConfirms - should be number');\n  }\n  if (!_.isUndefined(params.target) && !_.isNumber(params.target)) {\n    throw new Error('invalid target - should be number');\n  }\n  if (!_.isUndefined(params.instant) && !_.isBoolean(params.instant)) {\n    throw new Error('invalid instant flag - should be boolean');\n  }\n  if (!_.isUndefined(params.segwit) && !_.isBoolean(params.segwit)) {\n    throw new Error('invalid segwit flag - should be boolean');\n  }\n  if (!_.isUndefined(params.targetWalletUnspents) && !_.isInteger(params.targetWalletUnspents)) {\n    throw new Error('invalid targetWalletUnspents flag - should be number');\n  }\n  if (!_.isUndefined(params.minSize) && !_.isNumber(params.minSize)) {\n    throw new Error('invalid argument: minSize must be a number');\n  }\n  if (!_.isUndefined(params.instant) && !_.isUndefined(params.minConfirms)) {\n    throw new Error('only one of instant and minConfirms may be defined');\n  }\n  if (!_.isUndefined(params.targetWalletUnspents) && _.isUndefined(params.target)) {\n    throw new Error('targetWalletUnspents can only be specified in conjunction with a target');\n  }\n  if (!_.isUndefined(params.allowLedgerSegwit) && !_.isBoolean(params.allowLedgerSegwit)) {\n    throw new Error('invalid argument: allowLedgerSegwit must be a boolean');\n  }\n\n  const queryObject = _.cloneDeep(params);\n\n  if (!_.isUndefined(params.target)) {\n    // skip and limit are unavailable when a target is specified\n    delete queryObject.skip;\n    delete queryObject.limit;\n  }\n\n  queryObject.segwit = true;\n  if (!_.isUndefined(params.segwit)) {\n    queryObject.segwit = params.segwit;\n  }\n\n  if (!_.isUndefined(params.allowLedgerSegwit)) {\n    queryObject.allowLedgerSegwit = params.allowLedgerSegwit;\n  }\n\n  return Bluebird.resolve(this.bitgo.get(this.url('/unspents')).query(queryObject).result()).nodeify(callback);\n};\n\n//\n// transactions\n// List the transactions for a given wallet\n// Options include:\n//     TODO:  Add iterators for start/count/etc\nWallet.prototype.transactions = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const args: string[] = [];\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    args.push('limit=' + params.limit);\n  }\n  if (params.skip) {\n    if (!_.isInteger(params.skip)) {\n      throw new Error('invalid skip argument, expecting number');\n    }\n    args.push('skip=' + params.skip);\n  }\n  if (params.minHeight) {\n    if (!_.isInteger(params.minHeight)) {\n      throw new Error('invalid minHeight argument, expecting number');\n    }\n    args.push('minHeight=' + params.minHeight);\n  }\n  if (params.maxHeight) {\n    if (!_.isInteger(params.maxHeight) || params.maxHeight < 0) {\n      throw new Error('invalid maxHeight argument, expecting positive integer');\n    }\n    args.push('maxHeight=' + params.maxHeight);\n  }\n  if (params.minConfirms) {\n    if (!_.isInteger(params.minConfirms) || params.minConfirms < 0) {\n      throw new Error('invalid minConfirms argument, expecting positive integer');\n    }\n    args.push('minConfirms=' + params.minConfirms);\n  }\n  if (!_.isUndefined(params.compact)) {\n    if (!_.isBoolean(params.compact)) {\n      throw new Error('invalid compact argument, expecting boolean');\n    }\n    args.push('compact=' + params.compact);\n  }\n  let query = '';\n  if (args.length) {\n    query = '?' + args.join('&');\n  }\n\n  const url = this.url('/tx' + query);\n\n  return Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);\n};\n\n//\n// transaction\n// Get a transaction by ID for a given wallet\nWallet.prototype.getTransaction = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  const url = this.url('/tx/' + params.id);\n\n  return Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);\n};\n\n//\n// pollForTransaction\n// Poll a transaction until successful or times out\n// Parameters:\n//   id: the txid\n//   delay: delay between polls in ms (default: 1000)\n//   timeout: timeout in ms (default: 10000)\nWallet.prototype.pollForTransaction = function (params, callback) {\n  const self = this;\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n  if (params.delay && !_.isNumber(params.delay)) {\n    throw new Error('invalid delay parameter');\n  }\n  if (params.timeout && !_.isNumber(params.timeout)) {\n    throw new Error('invalid timeout parameter');\n  }\n  params.delay = params.delay || 1000;\n  params.timeout = params.timeout || 10000;\n\n  const start = new Date();\n\n  const doNextPoll = function () {\n    return self\n      .getTransaction(params)\n      .then(function (res) {\n        return res;\n      })\n      .catch(function (err) {\n        if (err.status !== 404 || new Date().valueOf() - start.valueOf() > params.timeout) {\n          throw err;\n        }\n        return Bluebird.delay(params.delay).then(function () {\n          return doNextPoll();\n        });\n      });\n  };\n\n  return doNextPoll();\n};\n\n//\n// transaction by sequence id\n// Get a transaction by sequence id for a given wallet\nWallet.prototype.getWalletTransactionBySequenceId = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['sequenceId'], [], callback);\n\n  const url = this.url('/tx/sequence/' + params.sequenceId);\n\n  return Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);\n};\n\n//\n// Key chains\n// Gets the user key chain for this wallet\n// The user key chain is typically the first keychain of the wallet and has the encrypted xpriv stored on BitGo.\n// Useful when trying to get the users' keychain from the server before decrypting to sign a transaction.\nWallet.prototype.getEncryptedUserKeychain = function (params, callback) {\n  return co(function* () {\n    params = params || {};\n    common.validateParams(params, [], [], callback);\n    // @ts-expect-error - no implicit this\n    const self = this;\n\n    const tryKeyChain = co(function* (index) {\n      if (!self.keychains || index >= self.keychains.length) {\n        const error: any = new Error('No encrypted keychains on this wallet.');\n        error.code = 'no_encrypted_keychain_on_wallet';\n        throw error;\n      }\n\n      const params = { xpub: self.keychains[index].xpub };\n\n      const keychain = yield self.bitgo.keychains().get(params);\n      // If we find the xprv, then this is probably the user keychain we're looking for\n      keychain.walletSubPath = self.keychains[index].path;\n      if (keychain.encryptedXprv) {\n        return keychain;\n      }\n      return tryKeyChain(index + 1);\n    });\n\n    return tryKeyChain(0);\n  })\n    .call(this)\n    .asCallback(callback);\n};\n\n//\n// createTransaction\n// Create a transaction (unsigned). To sign it, do signTransaction\n// Parameters:\n//   recipients - object of recipient addresses and the amount to send to each e.g. {address:1500, address2:1500}\n//   fee      - the blockchain fee to send (optional)\n//   feeRate  - the fee per kb to send (optional)\n//   minConfirms - minimum number of confirms to use when gathering unspents\n//   forceChangeAtEnd - force change address to be last output (optional)\n//   noSplitChange - disable automatic change splitting for purposes of unspent management\n//   changeAddress - override the change address (optional)\n//   validate - extra verification of change addresses (which are always verified server-side) (defaults to global config)\n// Returns:\n//   callback(err, { transactionHex: string, unspents: [inputs], fee: satoshis })\nWallet.prototype.createTransaction = function (params, callback) {\n  params = _.extend({}, params);\n  common.validateParams(params, [], [], callback);\n\n  if (\n    (!_.isNumber(params.fee) && !_.isUndefined(params.fee)) ||\n    (!_.isNumber(params.feeRate) && !_.isUndefined(params.feeRate)) ||\n    (!_.isNumber(params.minConfirms) && !_.isUndefined(params.minConfirms)) ||\n    (!_.isBoolean(params.forceChangeAtEnd) && !_.isUndefined(params.forceChangeAtEnd)) ||\n    (!_.isString(params.changeAddress) && !_.isUndefined(params.changeAddress)) ||\n    (!_.isBoolean(params.validate) && !_.isUndefined(params.validate)) ||\n    (!_.isBoolean(params.instant) && !_.isUndefined(params.instant))\n  ) {\n    throw new Error('invalid argument');\n  }\n\n  if (!_.isObject(params.recipients)) {\n    throw new Error('expecting recipients object');\n  }\n\n  params.validate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n  params.wallet = this;\n\n  return TransactionBuilder.createTransaction(params).nodeify(callback);\n};\n\n//\n// signTransaction\n// Sign a previously created transaction with a keychain\n// Parameters:\n// transactionHex - serialized form of the transaction in hex\n// unspents - array of unspent information, where each unspent is a chainPath\n//            and redeemScript with the same index as the inputs in the\n//            transactionHex\n// keychain - Keychain containing the xprv to sign with.\n// signingKey - For legacy safe wallets, the private key string.\n// validate - extra verification of signatures (which are always verified server-side) (defaults to global config)\n// Returns:\n//   callback(err, transaction)\nWallet.prototype.signTransaction = function (params, callback) {\n  params = _.extend({}, params);\n  common.validateParams(params, ['transactionHex'], [], callback);\n\n  if (!Array.isArray(params.unspents)) {\n    throw new Error('expecting the unspents array');\n  }\n\n  if ((!_.isObject(params.keychain) || !params.keychain.xprv) && !_.isString(params.signingKey)) {\n    // allow passing in a WIF private key for legacy safe wallet support\n    const error: any = new Error('expecting keychain object with xprv or signingKey WIF');\n    error.code = 'missing_keychain_or_signingKey';\n    throw error;\n  }\n\n  params.validate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n  params.bitgo = this.bitgo;\n  return TransactionBuilder.signTransaction(params)\n    .then(function (result) {\n      return {\n        tx: result.transactionHex,\n      };\n    })\n    .nodeify(callback);\n};\n\n//\n// send\n// Send a transaction to the Bitcoin network via BitGo.\n// One of the keys is typically signed, and BitGo will sign the other (if approved) and relay it to the P2P network.\n// Parameters:\n//   tx  - the hex encoded, signed transaction to send\n// Returns:\n//\nWallet.prototype.sendTransaction = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['tx'], ['message', 'otp'], callback);\n\n  return Bluebird.resolve(this.bitgo.post(this.bitgo.url('/tx/send')).send(params).result())\n    .then(function (body) {\n      if (body.pendingApproval) {\n        return _.extend(body, { status: 'pendingApproval' });\n      }\n\n      if (body.otp) {\n        return _.extend(body, { status: 'otp' });\n      }\n\n      return {\n        status: 'accepted',\n        tx: body.transaction,\n        hash: body.transactionHash,\n        instant: body.instant,\n        instantId: body.instantId,\n      };\n    })\n    .nodeify(callback);\n};\n\n/**\n * Share the wallet with an existing BitGo user.\n * @param {string} user The recipient's user id, must have a corresponding user record in our database.\n * @param {keychain} keychain The keychain to be shared with the recipient.\n * @param {string} permissions A comma-separated value string that specifies the recipient's permissions if the share is accepted.\n * @param {string} message The message to be used for this share.\n */\nWallet.prototype.createShare = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['user', 'permissions'], [], callback);\n\n  if (params.keychain && !_.isEmpty(params.keychain)) {\n    if (\n      !params.keychain.xpub ||\n      !params.keychain.encryptedXprv ||\n      !params.keychain.fromPubKey ||\n      !params.keychain.toPubKey ||\n      !params.keychain.path\n    ) {\n      throw new Error('requires keychain parameters - xpub, encryptedXprv, fromPubKey, toPubKey, path');\n    }\n  }\n\n  return Bluebird.resolve(this.bitgo.post(this.url('/share')).send(params).result()).nodeify(callback);\n};\n\n//\n// createInvite\n// invite a non BitGo customer to join a wallet\n// Parameters:\n//   email - the recipient's email address\n//   permissions - the recipient's permissions if the share is accepted\n// Returns:\n//\nWallet.prototype.createInvite = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['email', 'permissions'], ['message'], callback);\n\n  const options: any = {\n    toEmail: params.email,\n    permissions: params.permissions,\n  };\n\n  if (params.message) {\n    options.message = params.message;\n  }\n\n  return Bluebird.resolve(this.bitgo.post(this.url('/invite')).send(options).result()).nodeify(callback);\n};\n\n//\n// confirmInviteAndShareWallet\n// confirm my invite on this wallet to a recipient who has\n// subsequently signed up by creating the actual wallet share\n// Parameters:\n//   walletInviteId - the wallet invite id\n//   walletPassphrase - required if the wallet share success is expected\n// Returns:\n//\nWallet.prototype.confirmInviteAndShareWallet = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['walletInviteId'], ['walletPassphrase'], callback);\n\n  const self = this;\n  return this.bitgo\n    .wallets()\n    .listInvites()\n    .then(function (invites) {\n      const outgoing = invites.outgoing;\n      const invite = _.find(outgoing, function (out) {\n        return out.id === params.walletInviteId;\n      });\n      if (!invite) {\n        throw new Error('wallet invite not found');\n      }\n\n      const options = {\n        email: invite.toEmail,\n        permissions: invite.permissions,\n        message: invite.message,\n        walletPassphrase: params.walletPassphrase,\n      };\n\n      return self.shareWallet(options);\n    })\n    .then(function () {\n      // @ts-expect-error - no implicit this\n      return this.bitgo.put(this.bitgo.url('/walletinvite/' + params.walletInviteId));\n    })\n    .nodeify(callback);\n};\n\n//\n// sendCoins\n// Send coins to a destination address from this wallet using the user key.\n// 1. Gets the user keychain by checking the wallet for a key which has an encrypted xpriv\n// 2. Decrypts user key\n// 3. Creates the transaction with default fee\n// 4. Signs transaction with decrypted user key\n// 3. Sends the transaction to BitGo\n//\n// Parameters:\n//   address - the destination address\n//   amount - the amount in satoshis to be sent\n//   message - optional message to attach to transaction\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   xprv - the private key in string form, if walletPassphrase is not available\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.sendCoins = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], ['message'], callback);\n\n  if (!_.isNumber(params.amount)) {\n    throw new Error('invalid argument for amount - number expected');\n  }\n\n  params.recipients = {};\n  params.recipients[params.address] = params.amount;\n\n  return this.sendMany(params).nodeify(callback);\n};\n\n//\n// sendMany\n// Send coins to multiple destination addresses from this wallet using the user key.\n// 1. Gets the user keychain by checking the wallet for a key which has an encrypted xpriv\n// 2. Decrypts user key\n// 3. Creates the transaction with default fee\n// 4. Signs transaction with decrypted user key\n// 3. Sends the transaction to BitGo\n//\n// Parameters:\n//   recipients - array of { address: string, amount: number, travelInfo: object } to send to\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   xprv - the private key in string form, if walletPassphrase is not available\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.sendMany = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], ['message', 'otp'], callback);\n  const self = this;\n\n  if (!_.isObject(params.recipients)) {\n    throw new Error('expecting recipients object');\n  }\n\n  if (params.fee && !_.isNumber(params.fee)) {\n    throw new Error('invalid argument for fee - number expected');\n  }\n\n  if (params.feeRate && !_.isNumber(params.feeRate)) {\n    throw new Error('invalid argument for feeRate - number expected');\n  }\n\n  if (params.instant && !_.isBoolean(params.instant)) {\n    throw new Error('invalid argument for instant - boolean expected');\n  }\n\n  let bitgoFee;\n  let travelInfos;\n  let finalResult;\n  let unspentsUsed;\n\n  const acceptedBuildParams = [\n    'numBlocks',\n    'feeRate',\n    'minConfirms',\n    'enforceMinConfirmsForChange',\n    'targetWalletUnspents',\n    'message',\n    'minValue',\n    'maxValue',\n    'noSplitChange',\n    'comment',\n  ];\n  const preservedBuildParams = _.pick(params, acceptedBuildParams);\n\n  // Get the user keychain\n  const retPromise = this.createAndSignTransaction(params)\n    .then(function (transaction) {\n      // Send the transaction\n      bitgoFee = transaction.bitgoFee;\n      travelInfos = transaction.travelInfos;\n      unspentsUsed = transaction.unspents;\n      return self.sendTransaction({\n        tx: transaction.tx,\n        message: params.message,\n        sequenceId: params.sequenceId,\n        instant: params.instant,\n        otp: params.otp,\n        // The below params are for logging only, and do not impact the API call\n        estimatedSize: transaction.estimatedSize,\n        buildParams: preservedBuildParams,\n      });\n    })\n    .then(function (result) {\n      const tx = utxolib.bitgo.createTransactionFromHex(result.tx, utxolib.networks.bitcoin);\n      const inputsSum = _.sumBy(unspentsUsed, 'value');\n      const outputsSum = _.sumBy(tx.outs, 'value');\n      const feeUsed = inputsSum - outputsSum;\n      if (isNaN(feeUsed)) {\n        throw new Error('invalid feeUsed');\n      }\n      (result.fee = feeUsed), (result.feeRate = (feeUsed * 1000) / tx.virtualSize());\n      result.travelInfos = travelInfos;\n      if (bitgoFee) {\n        result.bitgoFee = bitgoFee;\n      }\n      finalResult = result;\n\n      // Handle sending travel infos if they exist, but make sure we never fail here.\n      // Error or result (with possible sub-errors) will be provided in travelResult\n      if (travelInfos && travelInfos.length) {\n        try {\n          return self\n            .pollForTransaction({ id: result.hash })\n            .then(function () {\n              return self.bitgo.travelRule().sendMany(result);\n            })\n            .then(function (res) {\n              finalResult.travelResult = res;\n            })\n            .catch(function (err) {\n              // catch async errors\n              finalResult.travelResult = { error: err.message };\n            });\n        } catch (err) {\n          // catch synchronous errors\n          finalResult.travelResult = { error: err.message };\n        }\n      }\n    })\n    .then(function () {\n      return finalResult;\n    });\n  return Bluebird.resolve(retPromise).nodeify(callback);\n};\n\n/**\n * Accelerate a stuck transaction using Child-Pays-For-Parent (CPFP).\n *\n * This should only be used for stuck transactions which have no unconfirmed inputs.\n *\n * @param {Object} params - Input parameters\n * @param {String} params.transactionID - ID of transaction to accelerate\n * @param {Number} params.feeRate - New effective fee rate for stuck transaction (sat per 1000 bytes)\n * @param {Number} params.maxAdditionalUnspents - Maximum additional unspents to use from the wallet to cover any child fees that the parent unspent output cannot cover. Defaults to 100.\n * @param {String} params.walletPassphrase - The passphrase which should be used to decrypt the wallet private key. One of either walletPassphrase or xprv is required.\n * @param {String} params.xprv - The private key for the wallet. One of either walletPassphrase or xprv is required.\n * @param {Function} callback\n * @returns Result of sendTransaction() on the child transaction\n */\nWallet.prototype.accelerateTransaction = function accelerateTransaction(params, callback) {\n  const self = this;\n  /**\n   * Helper function to estimate a transactions size in virtual bytes.\n   * Actual transactions may be slightly fewer virtual bytes, due to\n   * the fact that valid ECSDA signatures have a variable length\n   * between 8 and 73 virtual bytes.\n   *\n   * @param inputs.segwit The number of segwit inputs to the transaction\n   * @param inputs.P2SH The number of P2SH inputs to the transaction\n   * @param inputs.P2PKH The number of P2PKH inputs to the transaction\n   */\n  const estimateTxVSize = (inputs) => {\n    const segwit = inputs.segwit || 0;\n    const P2SH = inputs.P2SH || 0;\n    const P2PKH = inputs.P2PKH || 0;\n\n    const childFeeInfo = TransactionBuilder.calculateMinerFeeInfo({\n      nP2shInputs: P2SH,\n      nP2pkhInputs: P2PKH,\n      nP2shP2wshInputs: segwit,\n      nOutputs: 1,\n      feeRate: 1,\n    });\n\n    return childFeeInfo.size;\n  };\n\n  /**\n   * Calculate the number of satoshis that should be paid in fees by the child transaction\n   *\n   * @param inputs Inputs to the child transaction which are passed to estimateTxVSize\n   * @param parentFee The number of satoshis the parent tx originally paid in fees\n   * @param parentVSize The number of virtual bytes in the parent tx\n   * @param feeRate The new fee rate which should be paid by the combined CPFP transaction\n   * @returns {number} The number of satoshis the child tx should pay in fees\n   */\n  const estimateChildFee = ({ inputs, parentFee, parentVSize, feeRate }) => {\n    // calculate how much more we *should* have paid in parent fees,\n    // had the parent been originally sent with the new fee rate\n    const additionalParentFee = _.ceil((parentVSize * feeRate) / 1000) - parentFee;\n\n    // calculate how much we would pay in fees for the child,\n    // if it were only paying for itself at the new fee rate\n    const childFee = (estimateTxVSize(inputs) * feeRate) / 1000;\n\n    return _.ceil(childFee + additionalParentFee);\n  };\n\n  /**\n   * Helper function to find additional unspents to use to pay the child tx fees.\n   * This function is called when the the parent tx output is not sufficient to\n   * cover the total fees which should be paid by the child tx.\n   *\n   * @param inputs Inputs to the child transaction which are passed to estimateTxVSize\n   * @param parentOutputValue The value of the output from the parent tx which we are using as an input to the child tx\n   * @param parentFee The number of satoshis the parent tx originally paid in fees\n   * @param parentVSize The number of virtual bytes in the parent tx\n   * @param maxUnspents The maximum number of additional unspents which should be used to cover the remaining child fees\n   * @returns An object with the additional unspents to use, the updated number of satoshis which should be paid by\n   *          the child tx, and the updated inputs for the child tx.\n   */\n  const findAdditionalUnspents = ({ inputs, parentOutputValue, parentFee, parentVSize, maxUnspents }) => {\n    return co(function* coFindAdditionalUnspents() {\n      const additionalUnspents: any[] = [];\n\n      // ask the server for enough unspents to cover the child fee, assuming\n      // that it can be done without additional unspents (which is not possible,\n      // since if that were the case, findAdditionalUnspents would not have been\n      // called in the first place. This will be corrected before returning)\n      let currentChildFeeEstimate = estimateChildFee({ inputs, parentFee, parentVSize, feeRate: params.feeRate });\n      let uncoveredChildFee = currentChildFeeEstimate - parentOutputValue;\n\n      while (uncoveredChildFee > 0 && additionalUnspents.length < maxUnspents) {\n        // try to get enough unspents to cover the rest of the child fee\n        // @ts-expect-error - no implicit this\n        const unspents = (yield this.unspents({\n          minConfirms: 1,\n          target: uncoveredChildFee,\n          limit: maxUnspents - additionalUnspents.length,\n        })) as any;\n\n        if (unspents.length === 0) {\n          // no more unspents are available\n          break;\n        }\n\n        let additionalUnspentValue = 0;\n\n        // consume all unspents returned by the server, even if we don't need\n        // all of them to cover the child fee. This is because the server will\n        // return enough unspent value to ensure that the minimum change amount\n        // is achieved for the child tx, and we can't leave out those unspents\n        // or else the minimum change amount constraint could be violated\n        _.forEach(unspents, (unspent) => {\n          // update the child tx inputs\n          const unspentChain = getChain(unspent);\n          if (isChainCode(unspentChain) && scriptTypeForChain(unspentChain) === 'p2shP2wsh') {\n            inputs.segwit++;\n          } else {\n            inputs.P2SH++;\n          }\n\n          additionalUnspents.push(unspent);\n          additionalUnspentValue += unspent.value;\n        });\n\n        currentChildFeeEstimate = estimateChildFee({ inputs, parentFee, parentVSize, feeRate: params.feeRate });\n        uncoveredChildFee = currentChildFeeEstimate - parentOutputValue - additionalUnspentValue;\n      }\n\n      if (uncoveredChildFee > 0) {\n        // Unable to find enough unspents to cover the child fee\n        throw new Error(`Insufficient confirmed unspents available to cover the child fee`);\n      }\n\n      // found enough unspents\n      return {\n        additional: additionalUnspents,\n        newChildFee: currentChildFeeEstimate,\n        newInputs: inputs,\n      };\n    }).call(this);\n  };\n\n  /**\n   * Helper function to get a full copy (including witness data) of an arbitrary tx using only the tx id.\n   *\n   * We have to use an external service for this (currently blockstream.info), since\n   * the v1 indexer service (based on bitcoinj) does not have segwit support and\n   * does not return any segwit related fields in the tx hex.\n   *\n   * @param parentTxId The ID of the transaction to get the full hex of\n   * @returns {Bluebird<any>} The full hex for the specified transaction\n   */\n  async function getParentTxHex({ parentTxId }: { parentTxId: string }): Promise<string> {\n    const explorerBaseUrl = common.Environments[self.bitgo.getEnv()].btcExplorerBaseUrl;\n    const result = await request.get(`${explorerBaseUrl}/tx/${parentTxId}/hex`);\n\n    if (!result.text || !/([a-f0-9]{2})+/.test(result.text)) {\n      throw new Error(\n        `Did not successfully receive parent tx hex. Received '${_.truncate(result.text, { length: 100 })}' instead.`\n      );\n    }\n\n    return result.text;\n  }\n\n  /**\n   * Helper function to get the chain from an unspent or tx output.\n   *\n   * @param outputOrUnspent The output or unspent whose chain should be determined\n   * @returns {number} The chain for the given output or unspent\n   */\n  const getChain = (outputOrUnspent) => {\n    if (outputOrUnspent.chain !== undefined) {\n      return outputOrUnspent.chain;\n    }\n\n    if (outputOrUnspent.chainPath !== undefined) {\n      return _.toNumber(outputOrUnspent.chainPath.split('/')[1]);\n    }\n\n    // no way to tell the chain, let's just blow up now instead\n    // of blowing up later when the undefined return value is used.\n    // Note: for unspents the field to use is 'address', but for outputs\n    // the field to use is 'account'\n    throw Error(`Could not get chain for output on account ${outputOrUnspent.account || outputOrUnspent.address}`);\n  };\n\n  /**\n   * Helper function to calculate the actual value contribution an output or unspent will\n   * contribute to a transaction, were it to be used. Each type of output or unspent\n   * will have a different value contribution since each type has a different number\n   * of virtual bytes, and thus will cause a different fee to be paid.\n   *\n   * @param outputOrUnspent Output or unspent whose effective value should be determined\n   * @returns {number} The actual number of satoshis that this unspent or output\n   *                   would contribute to a transaction, were it to be used.\n   */\n  const effectiveValue = (outputOrUnspent) => {\n    const chain = getChain(outputOrUnspent);\n    if (isChainCode(chain) && scriptTypeForChain(chain) === 'p2shP2wsh') {\n      // VirtualSizes.txP2shP2wshInputSize is in bytes, so we need to convert to kB\n      return outputOrUnspent.value - (VirtualSizes.txP2shP2wshInputSize * params.feeRate) / 1000;\n    }\n    // VirtualSizes.txP2shInputSize is in bytes, so we need to convert to kB\n    return outputOrUnspent.value - (VirtualSizes.txP2shInputSize * params.feeRate) / 1000;\n  };\n\n  /**\n   * Coroutine which actually implements the accelerateTransaction algorithm\n   *\n   * Described at a high level, the algorithm is as follows:\n   * 1) Find appropriate output from parent transaction to use as child transaction input\n   * 2) Find unspent corresponding to parent transaction output. If not found, return to step 1.\n   * 3) Determine if parent transaction unspent can cover entire child fee, plus minimum change\n   * 4) If yes, go to step 6\n   * 5) Otherwise, find additional unspents from the wallet to use to cover the remaining child fee\n   * 6) Create and sign the child transaction, using the parent transaction output\n   *    (and, if necessary, additional wallet unspents) as inputs\n   * 7) Broadcast the new child transaction\n   */\n  return co(function* coAccelerateTransaction(): any {\n    params = params || {};\n    common.validateParams(params, ['transactionID'], [], callback);\n\n    // validate fee rate\n    if (params.feeRate === undefined) {\n      throw new Error('Missing parameter: feeRate');\n    }\n    if (!_.isFinite(params.feeRate) || params.feeRate <= 0) {\n      throw new Error('Expecting positive finite number for parameter: feeRate');\n    }\n\n    // validate maxUnspents\n    if (params.maxAdditionalUnspents === undefined) {\n      // by default, use at most 100 additional unspents (not including the unspent output from the parent tx)\n      params.maxAdditionalUnspents = 100;\n    }\n\n    if (!_.isInteger(params.maxAdditionalUnspents) || params.maxAdditionalUnspents <= 0) {\n      throw Error('Expecting positive integer for parameter: maxAdditionalUnspents');\n    }\n\n    // @ts-expect-error - no implicit this\n    const parentTx = yield this.getTransaction({ id: params.transactionID });\n    if (parentTx.confirmations > 0) {\n      throw new Error(`Transaction ${params.transactionID} is already confirmed and cannot be accelerated`);\n    }\n\n    // get the outputs from the parent tx which are to our wallet\n    const walletOutputs = _.filter(parentTx.outputs, (output) => output.isMine);\n\n    if (walletOutputs.length === 0) {\n      throw new Error(\n        `Transaction ${params.transactionID} contains no outputs to this wallet, and thus cannot be accelerated`\n      );\n    }\n\n    // use an output from the parent with largest effective value,\n    // but check to make sure the output is actually unspent.\n    // An output could be spent already if the output was used in a\n    // child tx which itself has become stuck due to low fees and is\n    // also unconfirmed.\n    const sortedOutputs = _.sortBy(walletOutputs, effectiveValue);\n    let parentUnspentToUse;\n    let outputToUse;\n\n    while (sortedOutputs.length > 0 && parentUnspentToUse === undefined) {\n      outputToUse = sortedOutputs.pop();\n\n      // find the unspent corresponding to this particular output\n      // TODO: is there a better way to get this unspent?\n      // TODO: The best we can do here is set minSize = maxSize = outputToUse.value\n      // @ts-expect-error - no implicit this\n      const unspentsResult = yield this.unspents({\n        minSize: outputToUse.value,\n        maxSize: outputToUse.value,\n      });\n\n      parentUnspentToUse = _.find(unspentsResult, (unspent) => {\n        // make sure unspent belongs to the given txid\n        if (unspent.tx_hash !== params.transactionID) {\n          return false;\n        }\n        // make sure unspent has correct v_out index\n        return unspent.tx_output_n === outputToUse.vout;\n      });\n    }\n\n    if (parentUnspentToUse === undefined) {\n      throw new Error(`Could not find unspent output from parent tx to use as child input`);\n    }\n\n    // get the full hex for the parent tx and decode it to get its vsize\n    const parentTxHex = yield getParentTxHex({ parentTxId: params.transactionID });\n    const decodedParent = utxolib.bitgo.createTransactionFromHex(parentTxHex, utxolib.networks.bitcoin);\n    const parentVSize = decodedParent.virtualSize();\n\n    // make sure id from decoded tx and given tx id match\n    // this should catch problems emanating from the use of an external service\n    // for getting the complete parent tx hex\n    if (decodedParent.getId() !== params.transactionID) {\n      throw new Error(\n        `Decoded transaction id is ${decodedParent.getId()}, which does not match given txid ${params.transactionID}`\n      );\n    }\n\n    // make sure new fee rate is greater than the parent's current fee rate\n    // virtualSize is returned in vbytes, so we need to convert to kvB\n    const parentRate = (1000 * parentTx.fee) / parentVSize;\n    if (params.feeRate <= parentRate) {\n      throw new Error(\n        `Cannot lower fee rate! (Parent tx fee rate is ${parentRate} sat/kB, and requested fee rate was ${params.feeRate} sat/kB)`\n      );\n    }\n\n    // determine if parent output can cover child fee\n    const isParentOutputSegwit =\n      isChainCode(outputToUse.chain) && scriptTypeForChain(outputToUse.chain) === 'p2shP2wsh';\n\n    let childInputs = {\n      segwit: isParentOutputSegwit ? 1 : 0,\n      P2SH: isParentOutputSegwit ? 0 : 1,\n    };\n\n    let childFee = estimateChildFee({\n      inputs: childInputs,\n      parentFee: parentTx.fee,\n      feeRate: params.feeRate,\n      parentVSize,\n    });\n\n    const unspentsToUse = [parentUnspentToUse];\n\n    // try to get the min change size from the server, otherwise default to 0.1 BTC\n    // TODO: minChangeSize is not currently a constant defined on the client and should be added\n    // @ts-expect-error - no implicit this\n    const minChangeSize = this.bitgo.getConstants().minChangeSize || 1e7;\n\n    if (outputToUse.value < childFee + minChangeSize) {\n      // parent output cannot cover child fee plus the minimum change,\n      // must find additional unspents to cover the difference\n      const { additional, newChildFee, newInputs } = yield findAdditionalUnspents({\n        inputs: childInputs,\n        parentOutputValue: outputToUse.value,\n        parentFee: parentTx.fee,\n        maxUnspents: params.maxAdditionalUnspents,\n        parentVSize,\n      });\n      childFee = newChildFee;\n      childInputs = newInputs;\n      unspentsToUse.push(...additional);\n    }\n\n    // sanity check the fee rate we're paying for the combined tx\n    // to make sure it's under the max fee rate. Only the child tx\n    // can break this limit, but the combined tx shall not\n    // @ts-expect-error - no implicit this\n    const maxFeeRate = this.bitgo.getConstants().maxFeeRate;\n    const childVSize = estimateTxVSize(childInputs);\n    const combinedVSize = childVSize + parentVSize;\n    const combinedFee = parentTx.fee + childFee;\n    // combined fee rate must be in sat/kB, so we need to convert\n    const combinedFeeRate = (1000 * combinedFee) / combinedVSize;\n\n    if (combinedFeeRate > maxFeeRate) {\n      throw new Error(\n        `Transaction cannot be accelerated. Combined fee rate of ${combinedFeeRate} sat/kB exceeds maximum fee rate of ${maxFeeRate} sat/kB`\n      );\n    }\n\n    // create a new change address and determine change amount.\n    // the tx builder will reject transactions which have no recipients,\n    // and such zero-output transactions are forbidden by the Bitcoin protocol,\n    // so we need at least a single recipient for the change which won't be pruned.\n    const changeAmount = _.sumBy(unspentsToUse, (unspent) => unspent.value) - childFee;\n    // @ts-expect-error - no implicit this\n    const changeChain = this.getChangeChain({});\n    // @ts-expect-error - no implicit this\n    const changeAddress = yield this.createAddress({ chain: changeChain });\n\n    // create the child tx and broadcast\n    // @ts-expect-error - no implicit this\n    const tx = yield this.createAndSignTransaction({\n      unspents: unspentsToUse,\n      recipients: [\n        {\n          address: changeAddress.address,\n          amount: changeAmount,\n        },\n      ],\n      fee: childFee,\n      bitgoFee: {\n        amount: 0,\n        address: '',\n      },\n      xprv: params.xprv,\n      walletPassphrase: params.walletPassphrase,\n    });\n\n    // child fee rate must be in sat/kB, so we need to convert\n    const childFeeRate = (1000 * childFee) / childVSize;\n    if (childFeeRate > maxFeeRate) {\n      // combined tx is within max fee rate limits, but the child tx is not.\n      // in this case, we need to use the ignoreMaxFeeRate flag to get the child tx to be accepted\n      tx.ignoreMaxFeeRate = true;\n    }\n\n    // @ts-expect-error - no implicit this\n    return this.sendTransaction(tx);\n  })\n    .call(this)\n    .asCallback(callback);\n};\n\n//\n// createAndSignTransaction\n// INTERNAL function to create and sign a transaction\n//\n// Parameters:\n//   recipients - array of { address, amount } to send to\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.createAndSignTransaction = function (params, callback) {\n  return co(function* () {\n    params = params || {};\n    common.validateParams(params, [], [], callback);\n\n    if (!_.isObject(params.recipients)) {\n      throw new Error('expecting recipients object');\n    }\n\n    if (params.fee && !_.isNumber(params.fee)) {\n      throw new Error('invalid argument for fee - number expected');\n    }\n\n    if (params.feeRate && !_.isNumber(params.feeRate)) {\n      throw new Error('invalid argument for feeRate - number expected');\n    }\n\n    if (params.dynamicFeeConfirmTarget && !_.isNumber(params.dynamicFeeConfirmTarget)) {\n      throw new Error('invalid argument for confirmTarget - number expected');\n    }\n\n    if (params.instant && !_.isBoolean(params.instant)) {\n      throw new Error('invalid argument for instant - boolean expected');\n    }\n\n    // @ts-expect-error - no implicit this\n    const transaction = (yield this.createTransaction(params)) as any;\n    const fee = transaction.fee;\n    const feeRate = transaction.feeRate;\n    const estimatedSize = transaction.estimatedSize;\n    const bitgoFee = transaction.bitgoFee;\n    const travelInfos = transaction.travelInfos;\n    const unspents = transaction.unspents;\n\n    // Sign the transaction\n    try {\n      // @ts-expect-error - no implicit this\n      const keychain = yield this.getAndPrepareSigningKeychain(params);\n      transaction.keychain = keychain;\n    } catch (e) {\n      if (e.code !== 'no_encrypted_keychain_on_wallet') {\n        throw e;\n      }\n      // this might be a safe wallet, so let's retrieve the private key info\n      // @ts-expect-error - no implicit this\n      yield this.refresh({ gpk: true });\n      // @ts-expect-error - no implicit this\n      const safeUserKey = _.get(this.wallet, 'private.userPrivKey');\n      if (_.isString(safeUserKey) && _.isString(params.walletPassphrase)) {\n        // @ts-expect-error - no implicit this\n        transaction.signingKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: safeUserKey });\n      } else {\n        throw e;\n      }\n    }\n\n    transaction.feeSingleKeyWIF = params.feeSingleKeyWIF;\n    // @ts-expect-error - no implicit this\n    const result = yield this.signTransaction(transaction);\n    return _.extend(result, {\n      fee,\n      feeRate,\n      instant: params.instant,\n      bitgoFee,\n      travelInfos,\n      estimatedSize,\n      unspents,\n    });\n  })\n    .call(this)\n    .asCallback(callback);\n};\n\n//\n// getAndPrepareSigningKeychain\n// INTERNAL function to get the user keychain for signing.\n// Caller must provider either a keychain, or walletPassphrase or xprv as a string\n// If the caller provides the keychain with xprv, it is simply returned.\n// If the caller provides the encrypted xprv (walletPassphrase), then fetch the keychain object and decrypt\n// Otherwise if the xprv is provided, fetch the keychain object and augment it with the xprv.\n//\n// Parameters:\n//   keychain - keychain with xprv\n//   xprv - the private key in string form\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n// Returns:\n//   Keychain object containing xprv, xpub and paths\n//\nWallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {\n  params = params || {};\n\n  // If keychain with xprv is already provided, use it\n  if (_.isObject(params.keychain) && params.keychain.xprv) {\n    return Bluebird.resolve(params.keychain);\n  }\n\n  common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n\n  if ((params.walletPassphrase && params.xprv) || (!params.walletPassphrase && !params.xprv)) {\n    throw new Error('must provide exactly one of xprv or walletPassphrase');\n  }\n\n  const self = this;\n\n  // Caller provided a wallet passphrase\n  if (params.walletPassphrase) {\n    return self.getEncryptedUserKeychain().then(function (keychain) {\n      // Decrypt the user key with a passphrase\n      try {\n        keychain.xprv = self.bitgo.decrypt({ password: params.walletPassphrase, input: keychain.encryptedXprv });\n      } catch (e) {\n        throw new Error('Unable to decrypt user keychain');\n      }\n      return keychain;\n    });\n  }\n\n  // Caller provided an xprv - validate and construct keychain object\n  let xpub;\n  try {\n    xpub = bip32.fromBase58(params.xprv).neutered().toBase58();\n  } catch (e) {\n    throw new Error('Unable to parse the xprv');\n  }\n\n  if (xpub === params.xprv) {\n    throw new Error('xprv provided was not a private key (found xpub instead)');\n  }\n\n  const walletXpubs = _.map(self.keychains, 'xpub');\n  if (!_.includes(walletXpubs, xpub)) {\n    throw new Error('xprv provided was not a keychain on this wallet!');\n  }\n\n  // get the keychain object from bitgo to find the path and (potential) wallet structure\n  return self.bitgo\n    .keychains()\n    .get({ xpub: xpub })\n    .then(function (keychain) {\n      keychain.xprv = params.xprv;\n      return keychain;\n    });\n};\n\n/**\n * Takes a wallet's unspents and fans them out into a larger number of equally sized unspents\n * @param params\n *  target: set how many unspents you want to have in the end\n *  minConfirms: minimum number of confirms the unspents must have\n *  xprv: private key to sign transaction\n *  walletPassphrase: wallet passphrase to decrypt the wallet's private key\n * @param callback\n * @returns {*}\n */\nWallet.prototype.fanOutUnspents = function (params, callback) {\n  const self = this;\n  return Bluebird.coroutine(function* () {\n    // maximum number of inputs for fanout transaction\n    // (when fanning out, we take all the unspents and make a bigger number of outputs)\n    const MAX_FANOUT_INPUT_COUNT = 80;\n    // maximum number of outputs for fanout transaction\n    const MAX_FANOUT_OUTPUT_COUNT = 300;\n    params = params || {};\n    common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n    const validate = params.validate === undefined ? true : params.validate;\n\n    const target = params.target;\n    // the target must be defined, be a number, be at least two, and be a natural number\n    if (!_.isNumber(target) || target < 2 || target % 1 !== 0) {\n      throw new Error('Target needs to be a positive integer');\n    }\n    if (target > MAX_FANOUT_OUTPUT_COUNT) {\n      throw new Error('Fan out target too high');\n    }\n\n    let minConfirms = params.minConfirms;\n    if (minConfirms === undefined) {\n      minConfirms = 1;\n    }\n    if (!_.isNumber(minConfirms) || minConfirms < 0) {\n      throw new Error('minConfirms needs to be an integer >= 0');\n    }\n\n    /**\n     * Split a natural number N into n almost equally sized (±1) natural numbers.\n     * In order to calculate the sizes of the parts, we calculate floor(N/n), and thus have the base size of all parts.\n     * If N % n !== 0, this leaves us with a remainder r where r < n. We distribute r equally among the n parts by\n     * adding 1 to the first r parts.\n     * @param total\n     * @param partCount\n     * @returns {Array}\n     */\n    const splitNumberIntoCloseNaturalNumbers = function (total, partCount) {\n      const partSize = Math.floor(total / partCount);\n      const remainder = total - partSize * partCount;\n      // initialize placeholder array\n      const almostEqualParts = new Array(partCount);\n      // fill the first remainder parts with the value partSize+1\n      _.fill(almostEqualParts, partSize + 1, 0, remainder);\n      // fill the remaining parts with the value partSize\n      _.fill(almostEqualParts, partSize, remainder);\n      // assert the correctness of the almost equal parts\n      // TODO: add check for the biggest deviation between any two parts and make sure it's <= 1\n      if (_(almostEqualParts).sum() !== total || _(almostEqualParts).size() !== partCount) {\n        throw new Error('part sum or part count mismatch');\n      }\n      return almostEqualParts;\n    };\n\n    // first, let's take all the wallet's unspents (with min confirms if necessary)\n    const allUnspents = (yield self.unspents({ minConfirms: minConfirms })) as any;\n    if (allUnspents.length < 1) {\n      throw new Error('No unspents to branch out');\n    }\n\n    // this consolidation is essentially just a waste of money\n    if (allUnspents.length >= target) {\n      throw new Error('Fan out target has to be bigger than current number of unspents');\n    }\n\n    // we have at the very minimum 81 inputs, and 81 outputs. That transaction will be big\n    // in the medium run, this algorithm could be reworked to only work with a subset of the transactions\n    if (allUnspents.length > MAX_FANOUT_INPUT_COUNT) {\n      throw new Error('Too many unspents');\n    }\n\n    // this is all the money that is currently in the wallet\n    const grossAmount = _(allUnspents).map('value').sum();\n\n    // in order to not modify the params object, we create a copy\n    const txParams = _.extend({}, params);\n    txParams.unspents = allUnspents;\n    txParams.recipients = {};\n\n    // create target amount of new addresses for this wallet\n    const newAddressPromises = _.range(target).map(() =>\n      self.createAddress({ chain: self.getChangeChain(params), validate: validate })\n    );\n    const newAddresses = yield Bluebird.all(newAddressPromises);\n    // let's find a nice, equal distribution of our Satoshis among the new addresses\n    const splitAmounts = splitNumberIntoCloseNaturalNumbers(grossAmount, target);\n    // map the newly created addresses to the almost components amounts we just calculated\n    txParams.recipients = _.zipObject(_.map(newAddresses, 'address'), splitAmounts);\n    txParams.noSplitChange = true;\n    // attempt to create a transaction. As it is a wallet-sweeping transaction with no fee, we expect it to fail\n    try {\n      yield self.sendMany(txParams);\n    } catch (error) {\n      // as expected, the transaction creation did indeed fail due to insufficient fees\n      // the error suggests a fee value which we then use for the transaction\n      // however, let's make sure it wasn't something else\n      if (!error.fee && (!error.result || !error.result.fee)) {\n        // if the error does not contain a fee property, it is something else that has gone awry, and we throw it\n        const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n        error.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n        throw error;\n      }\n      const baseFee = error.fee || error.result.fee;\n      let totalFee = baseFee;\n      if (error.result.bitgoFee && error.result.bitgoFee.amount) {\n        totalFee += error.result.bitgoFee.amount;\n        txParams.bitgoFee = error.result.bitgoFee;\n      }\n\n      // Need to clear these out since only 1 may be set\n      delete txParams.fee;\n      txParams.originalFeeRate = txParams.feeRate;\n      delete txParams.feeRate;\n      delete txParams.feeTxConfirmTarget;\n      txParams.fee = baseFee;\n      // in order to maintain the equal distribution, we need to subtract the fee from the cumulative funds\n      // in case some unspents got pruned, we need to use error.result.available\n      const netAmount = error.result.available - totalFee; // after fees\n      // that means that the distribution has to be recalculated\n      const remainingSplitAmounts = splitNumberIntoCloseNaturalNumbers(netAmount, target);\n      // and the distribution again mapped to the new addresses\n      txParams.recipients = _.zipObject(_.map(newAddresses, 'address'), remainingSplitAmounts);\n    }\n\n    // this time, the transaction creation should work\n    let fanoutTx;\n    try {\n      fanoutTx = yield self.sendMany(txParams);\n    } catch (e) {\n      const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n      e.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n      throw e;\n    }\n\n    return Bluebird.resolve(fanoutTx).asCallback(callback);\n  })().asCallback(callback);\n};\n\n/**\n * Determine whether to fan out or coalesce a wallet's unspents\n * @param params\n * @param callback\n * @returns {Request|Promise.<T>|*}\n */\nWallet.prototype.regroupUnspents = function (params, callback) {\n  params = params || {};\n  const target = params.target;\n  if (!_.isNumber(target) || target < 1 || target % 1 !== 0) {\n    // the target must be defined, be a number, be at least one, and be a natural number\n    throw new Error('Target needs to be a positive integer');\n  }\n\n  let minConfirms = params.minConfirms;\n  if (minConfirms === undefined) {\n    minConfirms = 1;\n  }\n  if (!_.isNumber(minConfirms) || minConfirms < 0) {\n    throw new Error('minConfirms needs to be an integer equal to or bigger than 0');\n  }\n\n  const self = this;\n  return self.unspents({ minConfirms: minConfirms }).then(function (unspents) {\n    if (unspents.length === target) {\n      return unspents;\n    } else if (unspents.length > target) {\n      return self.consolidateUnspents(params, callback);\n    } else if (unspents.length < target) {\n      return self.fanOutUnspents(params, callback);\n    }\n  });\n};\n\n/**\n * Consolidate a wallet's unspents into fewer unspents\n * @param params\n *  target: set how many unspents you want to have in the end\n *  maxInputCountPerConsolidation: set how many maximum inputs are to be permitted per consolidation batch\n *  xprv: private key to sign transaction\n *  walletPassphrase: wallet passphrase to decrypt the wallet's private key\n *  maxIterationCount: maximum number of iterations to be performed until function stops\n *  progressCallback: method to be called with object outlining current progress details\n * @param callback\n * @returns {*}\n */\nWallet.prototype.consolidateUnspents = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n  const validate = params.validate === undefined ? true : params.validate;\n\n  let target = params.target;\n  if (target === undefined) {\n    target = 1;\n  } else if (!_.isNumber(target) || target < 1 || target % 1 !== 0) {\n    // the target must be defined, be a number, be at least one, and be a natural number\n    throw new Error('Target needs to be a positive integer');\n  }\n\n  if (params.maxSize && !_.isNumber(params.maxSize)) {\n    throw new Error('maxSize should be a number');\n  }\n\n  if (params.minSize && !_.isNumber(params.minSize)) {\n    throw new Error('minSize should be a number');\n  }\n\n  // maximum number of inputs per transaction for consolidation\n  const MAX_INPUT_COUNT = 200;\n  let maxInputCount = params.maxInputCountPerConsolidation;\n  if (maxInputCount === undefined) {\n    // null or unidentified, because equality to zero returns true in if(! clause\n    maxInputCount = MAX_INPUT_COUNT;\n  }\n  if (typeof maxInputCount !== 'number' || maxInputCount < 2 || maxInputCount % 1 !== 0) {\n    throw new Error('Maximum consolidation input count needs to be an integer equal to or bigger than 2');\n  } else if (maxInputCount > MAX_INPUT_COUNT) {\n    throw new Error('Maximum consolidation input count cannot be bigger than ' + MAX_INPUT_COUNT);\n  }\n\n  const maxIterationCount = params.maxIterationCount || -1;\n  if (\n    (params.maxIterationCount && (!_.isNumber(maxIterationCount) || maxIterationCount < 1)) ||\n    maxIterationCount % 1 !== 0\n  ) {\n    throw new Error('Maximum iteration count needs to be an integer equal to or bigger than 1');\n  }\n\n  let minConfirms = params.minConfirms;\n  if (minConfirms === undefined) {\n    minConfirms = 1;\n  }\n  if (!_.isNumber(minConfirms) || minConfirms < 0) {\n    throw new Error('minConfirms needs to be an integer equal to or bigger than 0');\n  }\n\n  let minSize = params.minSize || 0;\n  if (params.feeRate) {\n    // fee rate is in satoshis per kB, input size in bytes\n    const feeBasedMinSize = Math.ceil((VirtualSizes.txP2shInputSize * params.feeRate) / 1000);\n    if (params.minSize && minSize < feeBasedMinSize) {\n      throw new Error('provided minSize too low due to too high fee rate');\n    }\n    minSize = Math.max(feeBasedMinSize, minSize);\n\n    if (!params.minSize) {\n      // fee rate-based min size needs no logging if it was set explicitly\n      console.log(\n        'Only consolidating unspents larger than ' +\n          minSize +\n          ' satoshis to avoid wasting money on fees. To consolidate smaller unspents, use a lower fee rate.'\n      );\n    }\n  }\n\n  let iterationCount = 0;\n\n  const self = this;\n  let consolidationIndex = 0;\n\n  /**\n   * Consolidate one batch of up to MAX_INPUT_COUNT unspents.\n   * @returns {*}\n   */\n  const runNextConsolidation = co(function* () {\n    const consolidationTransactions: any[] = [];\n    let isFinalConsolidation = false;\n    iterationCount++;\n    /*\n     We take a maximum of unspentBulkSizeLimit unspents from the wallet. We want to make sure that we swipe the wallet\n     clean of all excessive unspents, so we add 1 to the target unspent count to make sure we haven't missed anything.\n     In case there are even more unspents than that, to make the consolidation as fast as possible, we expand our\n     selection to include as many as the maximum permissible number of inputs per consolidation batch.\n     Should the target number of unspents be higher than the maximum number if inputs per consolidation,\n     we still want to fetch them all simply to be able to determine whether or not a consolidation can be performed\n     at all, which is dependent on the number of all unspents being higher than the target.\n     In the next version of the unspents version SDK, we will know the total number of unspents without having to fetch\n     them, and therefore will be able to simplify this method.\n     */\n\n    const queryParams: any = {\n      limit: target + maxInputCount,\n      minConfirms: minConfirms,\n      minSize: minSize,\n    };\n    if (params.maxSize) {\n      queryParams.maxSize = params.maxSize;\n    }\n    const allUnspents = (yield self.unspents(queryParams)) as any;\n    // this consolidation is essentially just a waste of money\n    if (allUnspents.length <= target) {\n      if (iterationCount <= 1) {\n        // this is the first iteration, so the method is incorrect\n        throw new Error('Fewer unspents than consolidation target. Use fanOutUnspents instead.');\n      } else {\n        // it's a later iteration, so the target may have been surpassed (due to confirmations in the background)\n        throw new Error('Done');\n      }\n    }\n\n    const allUnspentsCount = allUnspents.length;\n\n    // how many of the unspents do we want to consolidate?\n    // the +1 is because the consolidated block becomes a new unspent later\n    let targetInputCount = allUnspentsCount - target + 1;\n    targetInputCount = Math.min(targetInputCount, allUnspents.length);\n\n    // if the targetInputCount requires more inputs than we allow per batch, we reduce the number\n    const inputCount = Math.min(targetInputCount, maxInputCount);\n\n    // if either the number of inputs left to coalesce equals the number we will coalesce in this iteration\n    // or if the number of iterations matches the maximum permitted number\n    isFinalConsolidation = inputCount === targetInputCount || iterationCount === maxIterationCount;\n\n    const currentChunk = allUnspents.splice(0, inputCount);\n    const changeChain = self.getChangeChain(params);\n    const newAddress = (yield self.createAddress({ chain: changeChain, validate: validate })) as any;\n    const txParams = _.extend({}, params);\n    const currentAddress = newAddress;\n    // the total amount that we are consolidating within this batch\n    const grossAmount = _(currentChunk).map('value').sum(); // before fees\n\n    txParams.unspents = currentChunk;\n    txParams.recipients = {};\n    txParams.recipients[newAddress.address] = grossAmount;\n    txParams.noSplitChange = true;\n\n    if (txParams.unspents.length <= 1) {\n      throw new Error('Done');\n    }\n\n    // let's attempt to create this transaction. We expect it to fail because no fee is set.\n    try {\n      yield self.sendMany(txParams);\n    } catch (error) {\n      // this error should occur due to insufficient funds\n      // however, let's make sure it wasn't something else\n      if (!error.fee && (!error.result || !error.result.fee)) {\n        // if the error does not contain a fee property, it is something else that has gone awry, and we throw it\n        const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n        error.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n        throw error;\n      }\n      const baseFee = error.fee || error.result.fee;\n      let bitgoFee = 0;\n      let totalFee = baseFee;\n      if (error.result.bitgoFee && error.result.bitgoFee.amount) {\n        bitgoFee = error.result.bitgoFee.amount;\n        totalFee += bitgoFee;\n        txParams.bitgoFee = error.result.bitgoFee;\n      }\n\n      // if the net amount is negative, it should be replaced with the minimum output size\n      const netAmount = Math.max(error.result.available - totalFee, self.bitgo.getConstants().minOutputSize);\n      // Need to clear these out since only 1 may be set\n      delete txParams.fee;\n      txParams.originalFeeRate = txParams.feeRate;\n      delete txParams.feeRate;\n      delete txParams.feeTxConfirmTarget;\n\n      // we set the fee explicitly\n      txParams.fee = error.result.available - netAmount - bitgoFee;\n      txParams.recipients[newAddress.address] = netAmount;\n    }\n    // this transaction, on the other hand, should be created with no issues, because an appropriate fee is set\n    let sentTx;\n    try {\n      sentTx = yield self.sendMany(txParams);\n    } catch (e) {\n      const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n      e.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n      throw e;\n    }\n    consolidationTransactions.push(sentTx);\n    if (_.isFunction(params.progressCallback)) {\n      params.progressCallback({\n        txid: sentTx.hash,\n        destination: currentAddress,\n        amount: grossAmount,\n        fee: sentTx.fee,\n        inputCount: inputCount,\n        index: consolidationIndex,\n      });\n    }\n    consolidationIndex++;\n    if (!isFinalConsolidation) {\n      // this last consolidation has not yet brought the unspents count down to the target unspent count\n      // therefore, we proceed by consolidating yet another batch\n      // before we do that, we wait 1 second so that the newly created unspent will be fetched in the next batch\n      yield Bluebird.delay(1000);\n      consolidationTransactions.push(...((yield runNextConsolidation()) as any));\n    }\n    // this is the final consolidation transaction. We return all the ones we've had so far\n    return consolidationTransactions;\n  });\n\n  return runNextConsolidation(this, target)\n    .catch(function (err) {\n      if (err.message === 'Done') {\n        return;\n      }\n      throw err;\n    })\n    .nodeify(callback);\n};\n\nWallet.prototype.shareWallet = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['email', 'permissions'], ['walletPassphrase', 'message'], callback);\n\n  if (params.reshare !== undefined && !_.isBoolean(params.reshare)) {\n    throw new Error('Expected reshare to be a boolean.');\n  }\n\n  if (params.skipKeychain !== undefined && !_.isBoolean(params.skipKeychain)) {\n    throw new Error('Expected skipKeychain to be a boolean. ');\n  }\n  const needsKeychain = !params.skipKeychain && params.permissions.indexOf('spend') !== -1;\n\n  if (params.disableEmail !== undefined && !_.isBoolean(params.disableEmail)) {\n    throw new Error('Expected disableEmail to be a boolean.');\n  }\n\n  const self = this;\n  let sharing;\n  let sharedKeychain;\n  return this.bitgo\n    .getSharingKey({ email: params.email.toLowerCase() })\n    .then(function (result) {\n      sharing = result;\n\n      if (needsKeychain) {\n        return self.getEncryptedUserKeychain({}).then(function (keychain) {\n          // Decrypt the user key with a passphrase\n          if (keychain.encryptedXprv) {\n            if (!params.walletPassphrase) {\n              throw new Error('Missing walletPassphrase argument');\n            }\n            try {\n              keychain.xprv = self.bitgo.decrypt({ password: params.walletPassphrase, input: keychain.encryptedXprv });\n            } catch (e) {\n              throw new Error('Unable to decrypt user keychain');\n            }\n\n            const eckey = makeRandomKey();\n            const secret = getSharedSecret(eckey, Buffer.from(sharing.pubkey, 'hex')).toString('hex');\n            const newEncryptedXprv = self.bitgo.encrypt({ password: secret, input: keychain.xprv });\n\n            sharedKeychain = {\n              xpub: keychain.xpub,\n              encryptedXprv: newEncryptedXprv,\n              fromPubKey: eckey.publicKey.toString('hex'),\n              toPubKey: sharing.pubkey,\n              path: sharing.path,\n            };\n          }\n        });\n      }\n    })\n    .then(function () {\n      interface Options {\n        user: any;\n        permissions: string;\n        reshare: boolean;\n        message: string;\n        disableEmail: any;\n        keychain?: any;\n        skipKeychain?: boolean;\n      }\n\n      const options: Options = {\n        user: sharing.userId,\n        permissions: params.permissions,\n        reshare: params.reshare,\n        message: params.message,\n        disableEmail: params.disableEmail,\n      };\n      if (sharedKeychain) {\n        options.keychain = sharedKeychain;\n      } else if (params.skipKeychain) {\n        options.keychain = {};\n      }\n\n      return self.createShare(options);\n    })\n    .nodeify(callback);\n};\n\nWallet.prototype.removeUser = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['user'], [], callback);\n\n  return Bluebird.resolve(\n    this.bitgo\n      .del(this.url('/user/' + params.user))\n      .send()\n      .result()\n  ).nodeify(callback);\n};\n\nWallet.prototype.getPolicy = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Bluebird.resolve(this.bitgo.get(this.url('/policy')).send().result()).nodeify(callback);\n};\n\nWallet.prototype.getPolicyStatus = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Bluebird.resolve(this.bitgo.get(this.url('/policy/status')).send().result()).nodeify(callback);\n};\n\nWallet.prototype.setPolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id', 'type'], ['message'], callback);\n\n  if (!_.isObject(params.condition)) {\n    throw new Error('missing parameter: conditions object');\n  }\n\n  if (!_.isObject(params.action)) {\n    throw new Error('missing parameter: action object');\n  }\n\n  return Bluebird.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result()).nodeify(callback);\n};\n\nWallet.prototype.removePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], ['message'], callback);\n\n  return Bluebird.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result()).nodeify(callback);\n};\n\nWallet.prototype.listWebhooks = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Bluebird.resolve(this.bitgo.get(this.url('/webhooks')).send().result()).nodeify(callback);\n};\n\n/**\n * Simulate wallet webhook, currently for webhooks of type transaction and pending approval\n * @param params\n * - webhookId (required): id of the webhook to be simulated\n * - txHash (optional but required for transaction webhooks) hash of the simulated transaction\n * - pendingApprovalId (optional but required for pending approval webhooks) id of the simulated pending approval\n * @param callback\n * @returns {*}\n */\nWallet.prototype.simulateWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['webhookId'], ['txHash', 'pendingApprovalId'], callback);\n\n  const hasTxHash = !!params.txHash;\n  const hasPendingApprovalId = !!params.pendingApprovalId;\n\n  if ((hasTxHash && hasPendingApprovalId) || (!hasTxHash && !hasPendingApprovalId)) {\n    throw new Error('must supply either txHash or pendingApprovalId, but not both');\n  }\n\n  // depending on the coin type of the wallet, the txHash has to adhere to its respective format\n  // but the server takes care of that\n\n  // only take the txHash and pendingApprovalId properties\n  const filteredParams = _.pick(params, ['txHash', 'pendingApprovalId']);\n\n  const webhookId = params.webhookId;\n  return Bluebird.resolve(\n    this.bitgo\n      .post(this.url('/webhooks/' + webhookId + '/simulate'))\n      .send(filteredParams)\n      .result()\n  ).nodeify(callback);\n};\n\nWallet.prototype.addWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['url', 'type'], [], callback);\n\n  return Bluebird.resolve(this.bitgo.post(this.url('/webhooks')).send(params).result()).nodeify(callback);\n};\n\nWallet.prototype.removeWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['url', 'type'], [], callback);\n\n  return Bluebird.resolve(this.bitgo.del(this.url('/webhooks')).send(params).result()).nodeify(callback);\n};\n\nWallet.prototype.estimateFee = function (params, callback) {\n  common.validateParams(params, [], [], callback);\n\n  if (params.amount && params.recipients) {\n    throw new Error('cannot specify both amount as well as recipients');\n  }\n  if (params.recipients && !_.isObject(params.recipients)) {\n    throw new Error('recipients must be array of { address: abc, amount: 100000 } objects');\n  }\n  if (params.amount && !_.isNumber(params.amount)) {\n    throw new Error('invalid amount argument, expecting number');\n  }\n\n  const recipients = params.recipients || [];\n\n  if (params.amount) {\n    // only the amount was passed in, so we need to make a false recipient to run createTransaction with\n    recipients.push({\n      address: common.Environments[this.bitgo.env].signingAddress, // any address will do\n      amount: params.amount,\n    });\n  }\n\n  const transactionParams = _.extend({}, params);\n  transactionParams.amount = undefined;\n  transactionParams.recipients = recipients;\n\n  return this.createTransaction(transactionParams).then(function (tx) {\n    return {\n      estimatedSize: tx.estimatedSize,\n      fee: tx.fee,\n      feeRate: tx.feeRate,\n    };\n  });\n};\n\n// Not fully implemented / released on SDK. Testing for now.\nWallet.prototype.updatePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id', 'type'], [], callback);\n\n  return Bluebird.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result()).nodeify(callback);\n};\n\nWallet.prototype.deletePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  return Bluebird.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result()).nodeify(callback);\n};\n\n//\n// getBitGoFee\n// Get the required on-transaction BitGo fee\n//\nWallet.prototype.getBitGoFee = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (!_.isNumber(params.amount)) {\n    throw new Error('invalid amount argument');\n  }\n  if (params.instant && !_.isBoolean(params.instant)) {\n    throw new Error('invalid instant argument');\n  }\n  return Bluebird.resolve(this.bitgo.get(this.url('/billing/fee')).query(params).result()).nodeify(callback);\n};\n\nexport = Wallet;\n"]}
|
|
2299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../../src/v1/wallet.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @hidden\n */\n\n/**\n */\n//\n// Wallet Object\n// BitGo accessor for a specific wallet\n//\n// Copyright 2014, BitGo, Inc.  All Rights Reserved.\n//\n\nimport { VirtualSizes } from '@bitgo-beta/unspents';\nimport assert from 'assert';\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport {\n  common,\n  ErrorNoInputToRecover,\n  getNetwork,\n  getSharedSecret,\n  makeRandomKey,\n  sanitizeLegacyPath,\n} from '@bitgo-beta/sdk-core';\nimport _ from 'lodash';\nimport { signPsbtRequest } from './signPsbt';\nimport { tryPromise } from '../util';\n\nconst TransactionBuilder = require('./transactionBuilder');\nconst PendingApproval = require('./pendingapproval');\n\nconst { getExternalChainCode, getInternalChainCode, isChainCode, scriptTypeForChain } = utxolib.bitgo;\nconst request = require('superagent');\n\n//\n// Constructor\n//\nconst Wallet = function (bitgo, wallet) {\n  // @ts-expect-error - no implicit this\n  (this.bitgo as any) = bitgo;\n  // @ts-expect-error - no implicit this\n  this.wallet = wallet;\n  // @ts-expect-error - no implicit this\n  this.keychains = [];\n\n  if (wallet.private) {\n    // @ts-expect-error - no implicit this\n    this.keychains = wallet.private.keychains;\n  }\n};\n\nWallet.prototype.toJSON = function () {\n  return this.wallet;\n};\n\n//\n// id\n// Get the id of this wallet.\n//\nWallet.prototype.id = function () {\n  return this.wallet.id;\n};\n\n//\n// label\n// Get the label of this wallet.\n//\nWallet.prototype.label = function () {\n  return this.wallet.label;\n};\n\n//\n// balance\n// Get the balance of this wallet.\n//\nWallet.prototype.balance = function () {\n  return this.wallet.balance;\n};\n\n//\n// balance\n// Get the spendable balance of this wallet.\n// This is the total of all unspents except those that are unconfirmed and external\n//\nWallet.prototype.spendableBalance = function () {\n  return this.wallet.spendableBalance;\n};\n\n//\n// confirmedBalance\n// Get the confirmedBalance of this wallet.\n//\nWallet.prototype.confirmedBalance = function () {\n  return this.wallet.confirmedBalance;\n};\n\n//\n// canSendInstant\n// Returns if the wallet can send instant transactions\n// This is impacted by the choice of backup key provider\n//\nWallet.prototype.canSendInstant = function () {\n  return this.wallet && this.wallet.canSendInstant;\n};\n\n//\n// instant balance\n// Get the instant balance of this wallet.\n// This is the total of all unspents that may be spent instantly.\n//\nWallet.prototype.instantBalance = function () {\n  if (!this.canSendInstant()) {\n    throw new Error('not an instant wallet');\n  }\n  return this.wallet.instantBalance;\n};\n\n//\n// unconfirmedSends\n// Get the balance of unconfirmedSends of this wallet.\n//\nWallet.prototype.unconfirmedSends = function () {\n  return this.wallet.unconfirmedSends;\n};\n\n//\n// unconfirmedReceives\n// Get the balance of unconfirmedReceives balance of this wallet.\n//\nWallet.prototype.unconfirmedReceives = function () {\n  return this.wallet.unconfirmedReceives;\n};\n\n//\n// type\n// Get the type of this wallet, e.g. 'safehd'\n//\nWallet.prototype.type = function () {\n  return this.wallet.type;\n};\n\nWallet.prototype.url = function (extra) {\n  extra = extra || '';\n  return this.bitgo.url('/wallet/' + this.id() + extra);\n};\n\n//\n// pendingApprovals\n// returns the pending approvals list for this wallet as pending approval objects\n//\nWallet.prototype.pendingApprovals = function () {\n  const self = this;\n  return this.wallet.pendingApprovals.map(function (p) {\n    return new PendingApproval(self.bitgo, p, self);\n  });\n};\n\n//\n// approvalsRequired\n// returns the number of approvals required to approve pending approvals involving this wallet\n//\nWallet.prototype.approvalsRequired = function () {\n  return this.wallet.approvalsRequired || 1;\n};\n\n//\n// get\n// Refetches this wallet and returns it\n//\nWallet.prototype.get = function (params, callback): Promise<any> {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const self = this;\n\n  return Promise.resolve(\n    this.bitgo\n      .get(this.url())\n      .result()\n      .then(function (res) {\n        self.wallet = res;\n        return self;\n      })\n  )\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// updateApprovalsRequired\n// Updates the number of approvals required on a pending approval involving this wallet.\n// The approvals required is by default 1, but this function allows you to update the\n// number such that 1 <= approvalsRequired <= walletAdmins.length - 1\n//\nWallet.prototype.updateApprovalsRequired = function (params, callback): Promise<any> {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (\n    params.approvalsRequired === undefined ||\n    !_.isInteger(params.approvalsRequired) ||\n    params.approvalsRequired < 1\n  ) {\n    throw new Error('invalid approvalsRequired: must be a nonzero positive number');\n  }\n\n  const self = this;\n  const currentApprovalsRequired = this.approvalsRequired();\n  if (currentApprovalsRequired === params.approvalsRequired) {\n    // no-op, just return the current wallet\n    return tryPromise(function () {\n      return self.wallet;\n    })\n      .then(callback)\n      .catch(callback);\n  }\n\n  return Promise.resolve(this.bitgo.put(this.url()).send(params).result()).then(callback).catch(callback);\n};\n\n/**\n * Returns the correct chain for change, taking into consideration segwit\n */\nWallet.prototype.getChangeChain = function (params) {\n  let useSegwitChange = !!this.bitgo.getConstants().enableSegwit;\n  if (!_.isUndefined(params.segwitChange)) {\n    if (!_.isBoolean(params.segwitChange)) {\n      throw new Error('segwitChange must be a boolean');\n    }\n\n    // if segwit is disabled through the constants, segwit change should still not be created\n    useSegwitChange = this.bitgo.getConstants().enableSegwit && params.segwitChange;\n  }\n  return useSegwitChange ? getInternalChainCode('p2shP2wsh') : getInternalChainCode('p2sh');\n};\n\n//\n// createAddress\n// Creates a new address for use with this wallet.\n//\nWallet.prototype.createAddress = function (params, callback) {\n  const self = this;\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (this.type() === 'safe') {\n    throw new Error('You are using a legacy wallet that cannot create a new address');\n  }\n\n  // Default to client-side address validation on, for safety. Use validate=false to disable.\n  const shouldValidate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n\n  const allowExisting = params.allowExisting;\n  if (typeof allowExisting !== 'boolean') {\n    params.allowExisting = allowExisting === 'true';\n  }\n\n  const isSegwit = this.bitgo.getConstants().enableSegwit;\n  const defaultChain = isSegwit ? getExternalChainCode('p2shP2wsh') : getExternalChainCode('p2sh');\n\n  let chain = params.chain;\n  if (chain === null || chain === undefined) {\n    chain = defaultChain;\n  }\n  return Promise.resolve(\n    this.bitgo\n      .post(this.url('/address/' + chain))\n      .send(params)\n      .result()\n      .then(function (addr) {\n        if (shouldValidate) {\n          self.validateAddress(addr);\n        }\n        return addr;\n      })\n  )\n    .then(callback)\n    .catch(callback);\n};\n\n/**\n * Generate address locally without calling server\n * @param params\n *\n */\nWallet.prototype.generateAddress = function ({ segwit, path, keychains, threshold }) {\n  const isSegwit = !!segwit;\n  let signatureThreshold = 2;\n  if (_.isInteger(threshold)) {\n    signatureThreshold = threshold;\n    if (signatureThreshold <= 0) {\n      throw new Error('threshold has to be positive');\n    }\n  }\n\n  const pathRegex = /^\\/1?[01]\\/\\d+$/;\n  if (!path.match(pathRegex)) {\n    throw new Error('unsupported path: ' + path);\n  }\n\n  let rootKeys = this.keychains;\n  if (Array.isArray(keychains)) {\n    rootKeys = keychains;\n  }\n\n  const network = common.Environments[this.bitgo.getEnv()].network;\n\n  const derivedKeys = rootKeys.map(function (k) {\n    const hdnode = bip32.fromBase58(k.xpub);\n    const derivationPath = k.path + (k.walletSubPath || '') + path;\n    return hdnode.derivePath(sanitizeLegacyPath(derivationPath)).publicKey;\n  });\n\n  const pathComponents = path.split('/');\n  const normalizedPathComponents = _.map(pathComponents, (component) => {\n    if (component && component.length > 0) {\n      return parseInt(component, 10);\n    }\n  });\n  const pathDetails = _.filter(normalizedPathComponents, _.isInteger);\n\n  const addressDetails: any = {\n    chainPath: path,\n    path: path,\n    chain: pathDetails[0],\n    index: pathDetails[1],\n    wallet: this.id(),\n  };\n\n  const {\n    scriptPubKey: outputScript,\n    redeemScript,\n    witnessScript,\n  } = utxolib.bitgo.outputScripts.createOutputScript2of3(derivedKeys, isSegwit ? 'p2shP2wsh' : 'p2sh');\n\n  addressDetails.witnessScript = witnessScript?.toString('hex');\n  addressDetails.redeemScript = redeemScript?.toString('hex');\n  addressDetails.outputScript = outputScript.toString('hex');\n  addressDetails.address = utxolib.address.fromOutputScript(outputScript, getNetwork(network));\n\n  return addressDetails;\n};\n\n//\n// validateAddress\n// Validates an address and path by calculating it locally from the keychain xpubs\n//\nWallet.prototype.validateAddress = function (params) {\n  common.validateParams(params, ['address', 'path'], []);\n  const isSegwit = !!params.witnessScript && params.witnessScript.length > 0;\n\n  const generatedAddress = this.generateAddress({ path: params.path, segwit: isSegwit });\n  if (generatedAddress.address !== params.address) {\n    throw new Error('address validation failure: ' + params.address + ' vs. ' + generatedAddress.address);\n  }\n};\n\n//\n// addresses\n// Gets the addresses of a HD wallet.\n// Options include:\n//  limit: the number of addresses to get\n//\nWallet.prototype.addresses = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const query: any = {};\n  if (params.details) {\n    query.details = 1;\n  }\n\n  const chain = params.chain;\n  if (chain !== null && chain !== undefined) {\n    if (Array.isArray(chain)) {\n      query.chain = _.uniq(_.filter(chain, _.isInteger));\n    } else {\n      if (chain !== 0 && chain !== 1) {\n        throw new Error('invalid chain argument, expecting 0 or 1');\n      }\n      query.chain = chain;\n    }\n  }\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    query.limit = params.limit;\n  }\n  if (params.skip) {\n    if (!_.isInteger(params.skip)) {\n      throw new Error('invalid skip argument, expecting number');\n    }\n    query.skip = params.skip;\n  }\n  if (params.sort) {\n    if (!_.isNumber(params.sort)) {\n      throw new Error('invalid sort argument, expecting number');\n    }\n    query.sort = params.sort;\n  }\n\n  const url = this.url('/addresses');\n  return Promise.resolve(this.bitgo.get(url).query(query).result()).then(callback).catch(callback);\n};\n\nWallet.prototype.stats = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  const args: string[] = [];\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    args.push('limit=' + params.limit);\n  }\n  let query = '';\n  if (args.length) {\n    query = '?' + args.join('&');\n  }\n\n  const url = this.url('/stats' + query);\n\n  return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);\n};\n\n/**\n * Refresh the wallet object by syncing with the back-end\n * @param callback\n * @returns {Wallet}\n */\nWallet.prototype.refresh = function (params, callback) {\n  return async function () {\n    // when set to true, gpk returns the private data of safe wallets\n    const query = _.extend({}, _.pick(params, ['gpk']));\n    // @ts-expect-error - no implicit this\n    const res = await this.bitgo.get(this.url()).query(query).result();\n    // @ts-expect-error - no implicit this\n    this.wallet = res;\n    // @ts-expect-error - no implicit this\n    return this;\n  }\n    .call(this)\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// address\n// Gets information about a single address on a HD wallet.\n// Information includes index, path, redeemScript, sent, received, txCount and balance\n// Options include:\n//  address: the address on this wallet to get\n//\nWallet.prototype.address = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  const url = this.url('/addresses/' + params.address);\n\n  return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);\n};\n\n/**\n * Freeze the wallet for a duration of choice, stopping BitGo from signing any transactions.\n * @param {number} limit The duration to freeze the wallet for in seconds, defaults to 3600.\n */\nWallet.prototype.freeze = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  if (params.duration) {\n    if (!_.isNumber(params.duration)) {\n      throw new Error('invalid duration - should be number of seconds');\n    }\n  }\n\n  return Promise.resolve(this.bitgo.post(this.url('/freeze')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// delete\n// Deletes the wallet\n//\nWallet.prototype.delete = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Promise.resolve(this.bitgo.del(this.url()).result()).then(callback).catch(callback);\n};\n\n//\n// labels\n// List the labels for the addresses in a given wallet\n//\nWallet.prototype.labels = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const url = this.bitgo.url('/labels/' + this.id());\n\n  return Promise.resolve(this.bitgo.get(url).result('labels')).then(callback).catch(callback);\n};\n\n/**\n * Rename a wallet\n * @param params\n *  - label: the wallet's intended new name\n * @param callback\n * @returns {*}\n */\nWallet.prototype.setWalletName = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['label'], [], callback);\n\n  const url = this.bitgo.url('/wallet/' + this.id());\n  return Promise.resolve(this.bitgo.put(url).send({ label: params.label }).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// setLabel\n// Sets a label on the provided address\n//\nWallet.prototype.setLabel = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address', 'label'], [], callback);\n\n  const self = this;\n\n  if (!self.bitgo.verifyAddress({ address: params.address })) {\n    throw new Error('Invalid bitcoin address: ' + params.address);\n  }\n\n  const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);\n\n  return Promise.resolve(this.bitgo.put(url).send({ label: params.label }).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// deleteLabel\n// Deletes the label associated with the provided address\n//\nWallet.prototype.deleteLabel = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  const self = this;\n\n  if (!self.bitgo.verifyAddress({ address: params.address })) {\n    throw new Error('Invalid bitcoin address: ' + params.address);\n  }\n\n  const url = this.bitgo.url('/labels/' + this.id() + '/' + params.address);\n\n  return Promise.resolve(this.bitgo.del(url).result()).then(callback).catch(callback);\n};\n\n//\n// unspents\n// List ALL the unspents for a given wallet\n// This method will return a paged list of all unspents\n//\n// Parameters include:\n//   limit:  the optional limit of unspents to collect in BTC\n//   minConf: only include results with this number of confirmations\n//   target: the amount of btc to find to spend\n//   instant: only find instant transactions (must specify a target)\n//\nWallet.prototype.unspents = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const allUnspents: any[] = [];\n  const self = this;\n\n  const getUnspentsBatch = function (skip, limit?) {\n    const queryObject = _.cloneDeep(params);\n    if (skip > 0) {\n      queryObject.skip = skip;\n    }\n    if (limit && limit > 0) {\n      queryObject.limit = limit;\n    }\n\n    return self.unspentsPaged(queryObject).then(function (result) {\n      // The API has its own limit handling. For example, the API does not support limits bigger than 500. If the limit\n      // specified here is bigger than that, we will have to do multiple requests with necessary limit adjustment.\n      for (let i = 0; i < result.unspents.length; i++) {\n        const unspent = result.unspents[i];\n        allUnspents.push(unspent);\n      }\n\n      // Our limit adjustment makes sure that we never fetch more unspents than we need, meaning that if we hit the\n      // limit, we hit it precisely\n      if (allUnspents.length >= params.limit) {\n        return allUnspents; // we aren't interested in any further unspents\n      }\n\n      const totalUnspentCount = result.total;\n      // if no target is specified and the SDK indicates that there has been a limit, we need to fetch another batch\n      if (!params.target && totalUnspentCount && totalUnspentCount > allUnspents.length) {\n        // we need to fetch the next batch\n        // let's just offset the current skip by the count\n        const newSkip = skip + result.count;\n        let newLimit: number | undefined;\n        if (limit > 0) {\n          // we set the new limit to be precisely the number of missing unspents to hit our own limit\n          newLimit = limit - allUnspents.length;\n        }\n        return getUnspentsBatch(newSkip, newLimit);\n      }\n\n      return allUnspents;\n    });\n  };\n\n  return getUnspentsBatch(0, params.limit).then(callback).catch(callback);\n};\n\n/**\n * List the unspents (paged) for a given wallet, returning the result as an object of unspents, count, skip and total\n * This method may not return all the unspents as the list is paged by the API\n * @param params\n * @param params.limit the optional limit of unspents to collect in BTC\n * @param params.skip index in list of unspents to start paging from\n * @param params.minConfirms only include results with this number of confirmations\n * @param params.target the amount of btc to find to spend\n * @param params.instant only find instant transactions (must specify a target)\n * @param params.targetWalletUnspents desired number of unspents to have in the wallet after the tx goes through (requires target)\n * @param params.minSize minimum unspent size in satoshis\n * @param params.segwit request segwit unspents (defaults to true if undefined)\n * @param params.allowLedgerSegwit allow segwit unspents for ledger devices (defaults to false if undefined)\n * @param callback\n * @returns {*}\n */\nWallet.prototype.unspentsPaged = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  if (!_.isUndefined(params.limit) && !_.isInteger(params.limit)) {\n    throw new Error('invalid limit - should be number');\n  }\n  if (!_.isUndefined(params.skip) && !_.isInteger(params.skip)) {\n    throw new Error('invalid skip - should be number');\n  }\n  if (!_.isUndefined(params.minConfirms) && !_.isInteger(params.minConfirms)) {\n    throw new Error('invalid minConfirms - should be number');\n  }\n  if (!_.isUndefined(params.target) && !_.isNumber(params.target)) {\n    throw new Error('invalid target - should be number');\n  }\n  if (!_.isUndefined(params.instant) && !_.isBoolean(params.instant)) {\n    throw new Error('invalid instant flag - should be boolean');\n  }\n  if (!_.isUndefined(params.segwit) && !_.isBoolean(params.segwit)) {\n    throw new Error('invalid segwit flag - should be boolean');\n  }\n  if (!_.isUndefined(params.targetWalletUnspents) && !_.isInteger(params.targetWalletUnspents)) {\n    throw new Error('invalid targetWalletUnspents flag - should be number');\n  }\n  if (!_.isUndefined(params.minSize) && !_.isNumber(params.minSize)) {\n    throw new Error('invalid argument: minSize must be a number');\n  }\n  if (!_.isUndefined(params.instant) && !_.isUndefined(params.minConfirms)) {\n    throw new Error('only one of instant and minConfirms may be defined');\n  }\n  if (!_.isUndefined(params.targetWalletUnspents) && _.isUndefined(params.target)) {\n    throw new Error('targetWalletUnspents can only be specified in conjunction with a target');\n  }\n  if (!_.isUndefined(params.allowLedgerSegwit) && !_.isBoolean(params.allowLedgerSegwit)) {\n    throw new Error('invalid argument: allowLedgerSegwit must be a boolean');\n  }\n\n  const queryObject = _.cloneDeep(params);\n\n  if (!_.isUndefined(params.target)) {\n    // skip and limit are unavailable when a target is specified\n    delete queryObject.skip;\n    delete queryObject.limit;\n  }\n\n  queryObject.segwit = true;\n  if (!_.isUndefined(params.segwit)) {\n    queryObject.segwit = params.segwit;\n  }\n\n  if (!_.isUndefined(params.allowLedgerSegwit)) {\n    queryObject.allowLedgerSegwit = params.allowLedgerSegwit;\n  }\n\n  return Promise.resolve(this.bitgo.get(this.url('/unspents')).query(queryObject).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// transactions\n// List the transactions for a given wallet\n// Options include:\n//     TODO:  Add iterators for start/count/etc\nWallet.prototype.transactions = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  const args: string[] = [];\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit argument, expecting number');\n    }\n    args.push('limit=' + params.limit);\n  }\n  if (params.skip) {\n    if (!_.isInteger(params.skip)) {\n      throw new Error('invalid skip argument, expecting number');\n    }\n    args.push('skip=' + params.skip);\n  }\n  if (params.minHeight) {\n    if (!_.isInteger(params.minHeight)) {\n      throw new Error('invalid minHeight argument, expecting number');\n    }\n    args.push('minHeight=' + params.minHeight);\n  }\n  if (params.maxHeight) {\n    if (!_.isInteger(params.maxHeight) || params.maxHeight < 0) {\n      throw new Error('invalid maxHeight argument, expecting positive integer');\n    }\n    args.push('maxHeight=' + params.maxHeight);\n  }\n  if (params.minConfirms) {\n    if (!_.isInteger(params.minConfirms) || params.minConfirms < 0) {\n      throw new Error('invalid minConfirms argument, expecting positive integer');\n    }\n    args.push('minConfirms=' + params.minConfirms);\n  }\n  if (!_.isUndefined(params.compact)) {\n    if (!_.isBoolean(params.compact)) {\n      throw new Error('invalid compact argument, expecting boolean');\n    }\n    args.push('compact=' + params.compact);\n  }\n  let query = '';\n  if (args.length) {\n    query = '?' + args.join('&');\n  }\n\n  const url = this.url('/tx' + query);\n\n  return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);\n};\n\n//\n// transaction\n// Get a transaction by ID for a given wallet\nWallet.prototype.getTransaction = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  const url = this.url('/tx/' + params.id);\n\n  return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);\n};\n\n//\n// pollForTransaction\n// Poll a transaction until successful or times out\n// Parameters:\n//   id: the txid\n//   delay: delay between polls in ms (default: 1000)\n//   timeout: timeout in ms (default: 10000)\nWallet.prototype.pollForTransaction = function (params, callback) {\n  const self = this;\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n  if (params.delay && !_.isNumber(params.delay)) {\n    throw new Error('invalid delay parameter');\n  }\n  if (params.timeout && !_.isNumber(params.timeout)) {\n    throw new Error('invalid timeout parameter');\n  }\n  params.delay = params.delay || 1000;\n  params.timeout = params.timeout || 10000;\n\n  const start = new Date();\n\n  const doNextPoll = function () {\n    return self\n      .getTransaction(params)\n      .then(function (res) {\n        return res;\n      })\n      .catch(function (err) {\n        if (err.status !== 404 || new Date().valueOf() - start.valueOf() > params.timeout) {\n          throw err;\n        }\n        return new Promise((resolve) => setTimeout(resolve, params.delay)).then(function () {\n          return doNextPoll();\n        });\n      });\n  };\n\n  return doNextPoll();\n};\n\n//\n// transaction by sequence id\n// Get a transaction by sequence id for a given wallet\nWallet.prototype.getWalletTransactionBySequenceId = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['sequenceId'], [], callback);\n\n  const url = this.url('/tx/sequence/' + params.sequenceId);\n\n  return Promise.resolve(this.bitgo.get(url).result()).then(callback).catch(callback);\n};\n\n//\n// Key chains\n// Gets the user key chain for this wallet\n// The user key chain is typically the first keychain of the wallet and has the encrypted xpriv stored on BitGo.\n// Useful when trying to get the users' keychain from the server before decrypting to sign a transaction.\nWallet.prototype.getEncryptedUserKeychain = function (params, callback) {\n  return async function () {\n    params = params || {};\n    common.validateParams(params, [], [], callback);\n    // @ts-expect-error - no implicit this\n    const self = this;\n\n    async function tryKeyChain(index) {\n      if (!self.keychains || index >= self.keychains.length) {\n        const error: any = new Error('No encrypted keychains on this wallet.');\n        error.code = 'no_encrypted_keychain_on_wallet';\n        throw error;\n      }\n\n      const params = { xpub: self.keychains[index].xpub };\n\n      const keychain = await self.bitgo.keychains().get(params);\n      // If we find the xprv, then this is probably the user keychain we're looking for\n      keychain.walletSubPath = self.keychains[index].path;\n      if (keychain.encryptedXprv) {\n        return keychain;\n      }\n      return tryKeyChain(index + 1);\n    }\n\n    return tryKeyChain(0);\n  }\n    .call(this)\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// createTransaction\n// Create a transaction (unsigned). To sign it, do signTransaction\n// Parameters:\n//   recipients - object of recipient addresses and the amount to send to each e.g. {address:1500, address2:1500}\n//   fee      - the blockchain fee to send (optional)\n//   feeRate  - the fee per kb to send (optional)\n//   minConfirms - minimum number of confirms to use when gathering unspents\n//   forceChangeAtEnd - force change address to be last output (optional)\n//   noSplitChange - disable automatic change splitting for purposes of unspent management\n//   changeAddress - override the change address (optional)\n//   validate - extra verification of change addresses (which are always verified server-side) (defaults to global config)\n// Returns:\n//   callback(err, { transactionHex: string, unspents: [inputs], fee: satoshis })\nWallet.prototype.createTransaction = function (params, callback) {\n  params = _.extend({}, params);\n  common.validateParams(params, [], [], callback);\n\n  if (\n    (!_.isNumber(params.fee) && !_.isUndefined(params.fee)) ||\n    (!_.isNumber(params.feeRate) && !_.isUndefined(params.feeRate)) ||\n    (!_.isNumber(params.minConfirms) && !_.isUndefined(params.minConfirms)) ||\n    (!_.isBoolean(params.forceChangeAtEnd) && !_.isUndefined(params.forceChangeAtEnd)) ||\n    (!_.isString(params.changeAddress) && !_.isUndefined(params.changeAddress)) ||\n    (!_.isBoolean(params.validate) && !_.isUndefined(params.validate)) ||\n    (!_.isBoolean(params.instant) && !_.isUndefined(params.instant))\n  ) {\n    throw new Error('invalid argument');\n  }\n\n  if (!_.isObject(params.recipients)) {\n    throw new Error('expecting recipients object');\n  }\n\n  params.validate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n  params.wallet = this;\n\n  return TransactionBuilder.createTransaction(params).then(callback).catch(callback);\n};\n\n//\n// signTransaction\n// Sign a previously created transaction with a keychain\n// Parameters:\n// transactionHex - serialized form of the transaction in hex\n// unspents - array of unspent information, where each unspent is a chainPath\n//            and redeemScript with the same index as the inputs in the\n//            transactionHex\n// keychain - Keychain containing the xprv to sign with.\n// signingKey - For legacy safe wallets, the private key string.\n// validate - extra verification of signatures (which are always verified server-side) (defaults to global config)\n// Returns:\n//   callback(err, transaction)\nWallet.prototype.signTransaction = function (params, callback) {\n  params = _.extend({}, params);\n\n  if (params.psbt) {\n    return tryPromise(() => signPsbtRequest(params))\n      .then(callback)\n      .catch(callback);\n  }\n\n  common.validateParams(params, ['transactionHex'], [], callback);\n\n  if (!Array.isArray(params.unspents)) {\n    throw new Error('expecting the unspents array');\n  }\n\n  if ((!_.isObject(params.keychain) || !params.keychain.xprv) && !_.isString(params.signingKey)) {\n    // allow passing in a WIF private key for legacy safe wallet support\n    const error: any = new Error('expecting keychain object with xprv or signingKey WIF');\n    error.code = 'missing_keychain_or_signingKey';\n    throw error;\n  }\n\n  params.validate = params.validate !== undefined ? params.validate : this.bitgo.getValidate();\n  params.bitgo = this.bitgo;\n  return TransactionBuilder.signTransaction(params)\n    .then(function (result) {\n      return {\n        tx: result.transactionHex,\n      };\n    })\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// send\n// Send a transaction to the Bitcoin network via BitGo.\n// One of the keys is typically signed, and BitGo will sign the other (if approved) and relay it to the P2P network.\n// Parameters:\n//   tx  - the hex encoded, signed transaction to send\n// Returns:\n//\nWallet.prototype.sendTransaction = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['tx'], ['message', 'otp'], callback);\n\n  return Promise.resolve(this.bitgo.post(this.bitgo.url('/tx/send')).send(params).result())\n    .then(function (body) {\n      if (body.pendingApproval) {\n        return _.extend(body, { status: 'pendingApproval' });\n      }\n\n      if (body.otp) {\n        return _.extend(body, { status: 'otp' });\n      }\n\n      return {\n        status: 'accepted',\n        tx: body.transaction,\n        hash: body.transactionHash,\n        instant: body.instant,\n        instantId: body.instantId,\n      };\n    })\n    .then(callback)\n    .catch(callback);\n};\n\n/**\n * Share the wallet with an existing BitGo user.\n * @param {string} user The recipient's user id, must have a corresponding user record in our database.\n * @param {keychain} keychain The keychain to be shared with the recipient.\n * @param {string} permissions A comma-separated value string that specifies the recipient's permissions if the share is accepted.\n * @param {string} message The message to be used for this share.\n */\nWallet.prototype.createShare = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['user', 'permissions'], [], callback);\n\n  if (params.keychain && !_.isEmpty(params.keychain)) {\n    if (\n      !params.keychain.xpub ||\n      !params.keychain.encryptedXprv ||\n      !params.keychain.fromPubKey ||\n      !params.keychain.toPubKey ||\n      !params.keychain.path\n    ) {\n      throw new Error('requires keychain parameters - xpub, encryptedXprv, fromPubKey, toPubKey, path');\n    }\n  }\n\n  return Promise.resolve(this.bitgo.post(this.url('/share')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// createInvite\n// invite a non BitGo customer to join a wallet\n// Parameters:\n//   email - the recipient's email address\n//   permissions - the recipient's permissions if the share is accepted\n// Returns:\n//\nWallet.prototype.createInvite = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['email', 'permissions'], ['message'], callback);\n\n  const options: any = {\n    toEmail: params.email,\n    permissions: params.permissions,\n  };\n\n  if (params.message) {\n    options.message = params.message;\n  }\n\n  return Promise.resolve(this.bitgo.post(this.url('/invite')).send(options).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// confirmInviteAndShareWallet\n// confirm my invite on this wallet to a recipient who has\n// subsequently signed up by creating the actual wallet share\n// Parameters:\n//   walletInviteId - the wallet invite id\n//   walletPassphrase - required if the wallet share success is expected\n// Returns:\n//\nWallet.prototype.confirmInviteAndShareWallet = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['walletInviteId'], ['walletPassphrase'], callback);\n\n  const self = this;\n  return this.bitgo\n    .wallets()\n    .listInvites()\n    .then(function (invites) {\n      const outgoing = invites.outgoing;\n      const invite = _.find(outgoing, function (out) {\n        return out.id === params.walletInviteId;\n      });\n      if (!invite) {\n        throw new Error('wallet invite not found');\n      }\n\n      const options = {\n        email: invite.toEmail,\n        permissions: invite.permissions,\n        message: invite.message,\n        walletPassphrase: params.walletPassphrase,\n      };\n\n      return self.shareWallet(options);\n    })\n    .then(function () {\n      // @ts-expect-error - no implicit this\n      return this.bitgo.put(this.bitgo.url('/walletinvite/' + params.walletInviteId));\n    })\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// sendCoins\n// Send coins to a destination address from this wallet using the user key.\n// 1. Gets the user keychain by checking the wallet for a key which has an encrypted xpriv\n// 2. Decrypts user key\n// 3. Creates the transaction with default fee\n// 4. Signs transaction with decrypted user key\n// 3. Sends the transaction to BitGo\n//\n// Parameters:\n//   address - the destination address\n//   amount - the amount in satoshis to be sent\n//   message - optional message to attach to transaction\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   xprv - the private key in string form, if walletPassphrase is not available\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.sendCoins = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], ['message'], callback);\n\n  if (!_.isNumber(params.amount)) {\n    throw new Error('invalid argument for amount - number expected');\n  }\n\n  params.recipients = {};\n  params.recipients[params.address] = params.amount;\n\n  return this.sendMany(params).then(callback).catch(callback);\n};\n\n//\n// sendMany\n// Send coins to multiple destination addresses from this wallet using the user key.\n// 1. Gets the user keychain by checking the wallet for a key which has an encrypted xpriv\n// 2. Decrypts user key\n// 3. Creates the transaction with default fee\n// 4. Signs transaction with decrypted user key\n// 3. Sends the transaction to BitGo\n//\n// Parameters:\n//   recipients - array of { address: string, amount: number, travelInfo: object } to send to\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   xprv - the private key in string form, if walletPassphrase is not available\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.sendMany = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], ['message', 'otp'], callback);\n  const self = this;\n\n  if (!_.isObject(params.recipients)) {\n    throw new Error('expecting recipients object');\n  }\n\n  if (params.fee && !_.isNumber(params.fee)) {\n    throw new Error('invalid argument for fee - number expected');\n  }\n\n  if (params.feeRate && !_.isNumber(params.feeRate)) {\n    throw new Error('invalid argument for feeRate - number expected');\n  }\n\n  if (params.instant && !_.isBoolean(params.instant)) {\n    throw new Error('invalid argument for instant - boolean expected');\n  }\n\n  let bitgoFee;\n  let travelInfos;\n  let finalResult;\n  let unspentsUsed;\n\n  const acceptedBuildParams = [\n    'numBlocks',\n    'feeRate',\n    'minConfirms',\n    'enforceMinConfirmsForChange',\n    'targetWalletUnspents',\n    'message',\n    'minValue',\n    'maxValue',\n    'noSplitChange',\n    'comment',\n  ];\n  const preservedBuildParams = _.pick(params, acceptedBuildParams);\n\n  // Get the user keychain\n  const retPromise = this.createAndSignTransaction(params)\n    .then(function (transaction) {\n      // Send the transaction\n      bitgoFee = transaction.bitgoFee;\n      travelInfos = transaction.travelInfos;\n      unspentsUsed = transaction.unspents;\n      return self.sendTransaction({\n        tx: transaction.tx,\n        message: params.message,\n        sequenceId: params.sequenceId,\n        instant: params.instant,\n        otp: params.otp,\n        // The below params are for logging only, and do not impact the API call\n        estimatedSize: transaction.estimatedSize,\n        buildParams: preservedBuildParams,\n      });\n    })\n    .then(function (result) {\n      const tx = utxolib.bitgo.createTransactionFromHex(result.tx, utxolib.networks.bitcoin);\n      const inputsSum = _.sumBy(unspentsUsed, 'value');\n      const outputsSum = _.sumBy(tx.outs, 'value');\n      const feeUsed = inputsSum - outputsSum;\n      if (isNaN(feeUsed)) {\n        throw new Error('invalid feeUsed');\n      }\n      (result.fee = feeUsed), (result.feeRate = (feeUsed * 1000) / tx.virtualSize());\n      result.travelInfos = travelInfos;\n      if (bitgoFee) {\n        result.bitgoFee = bitgoFee;\n      }\n      finalResult = result;\n\n      // Handle sending travel infos if they exist, but make sure we never fail here.\n      // Error or result (with possible sub-errors) will be provided in travelResult\n      if (travelInfos && travelInfos.length) {\n        try {\n          return self\n            .pollForTransaction({ id: result.hash })\n            .then(function () {\n              return self.bitgo.travelRule().sendMany(result);\n            })\n            .then(function (res) {\n              finalResult.travelResult = res;\n            })\n            .catch(function (err) {\n              // catch async errors\n              finalResult.travelResult = { error: err.message };\n            });\n        } catch (err) {\n          // catch synchronous errors\n          finalResult.travelResult = { error: err.message };\n        }\n      }\n    })\n    .then(function () {\n      return finalResult;\n    });\n  return Promise.resolve(retPromise).then(callback).catch(callback);\n};\n\n/**\n * Accelerate a stuck transaction using Child-Pays-For-Parent (CPFP).\n *\n * This should only be used for stuck transactions which have no unconfirmed inputs.\n *\n * @param {Object} params - Input parameters\n * @param {String} params.transactionID - ID of transaction to accelerate\n * @param {Number} params.feeRate - New effective fee rate for stuck transaction (sat per 1000 bytes)\n * @param {Number} params.maxAdditionalUnspents - Maximum additional unspents to use from the wallet to cover any child fees that the parent unspent output cannot cover. Defaults to 100.\n * @param {String} params.walletPassphrase - The passphrase which should be used to decrypt the wallet private key. One of either walletPassphrase or xprv is required.\n * @param {String} params.xprv - The private key for the wallet. One of either walletPassphrase or xprv is required.\n * @param {Function} callback\n * @returns Result of sendTransaction() on the child transaction\n */\nWallet.prototype.accelerateTransaction = function accelerateTransaction(params, callback) {\n  const self = this;\n  /**\n   * Helper function to estimate a transactions size in virtual bytes.\n   * Actual transactions may be slightly fewer virtual bytes, due to\n   * the fact that valid ECSDA signatures have a variable length\n   * between 8 and 73 virtual bytes.\n   *\n   * @param inputs.segwit The number of segwit inputs to the transaction\n   * @param inputs.P2SH The number of P2SH inputs to the transaction\n   * @param inputs.P2PKH The number of P2PKH inputs to the transaction\n   */\n  const estimateTxVSize = (inputs) => {\n    const segwit = inputs.segwit || 0;\n    const P2SH = inputs.P2SH || 0;\n    const P2PKH = inputs.P2PKH || 0;\n\n    const childFeeInfo = TransactionBuilder.calculateMinerFeeInfo({\n      nP2shInputs: P2SH,\n      nP2pkhInputs: P2PKH,\n      nP2shP2wshInputs: segwit,\n      nOutputs: 1,\n      feeRate: 1,\n    });\n\n    return childFeeInfo.size;\n  };\n\n  /**\n   * Calculate the number of satoshis that should be paid in fees by the child transaction\n   *\n   * @param inputs Inputs to the child transaction which are passed to estimateTxVSize\n   * @param parentFee The number of satoshis the parent tx originally paid in fees\n   * @param parentVSize The number of virtual bytes in the parent tx\n   * @param feeRate The new fee rate which should be paid by the combined CPFP transaction\n   * @returns {number} The number of satoshis the child tx should pay in fees\n   */\n  const estimateChildFee = ({ inputs, parentFee, parentVSize, feeRate }) => {\n    // calculate how much more we *should* have paid in parent fees,\n    // had the parent been originally sent with the new fee rate\n    const additionalParentFee = _.ceil((parentVSize * feeRate) / 1000) - parentFee;\n\n    // calculate how much we would pay in fees for the child,\n    // if it were only paying for itself at the new fee rate\n    const childFee = (estimateTxVSize(inputs) * feeRate) / 1000;\n\n    return _.ceil(childFee + additionalParentFee);\n  };\n\n  /**\n   * Helper function to find additional unspents to use to pay the child tx fees.\n   * This function is called when the the parent tx output is not sufficient to\n   * cover the total fees which should be paid by the child tx.\n   *\n   * @param inputs Inputs to the child transaction which are passed to estimateTxVSize\n   * @param parentOutputValue The value of the output from the parent tx which we are using as an input to the child tx\n   * @param parentFee The number of satoshis the parent tx originally paid in fees\n   * @param parentVSize The number of virtual bytes in the parent tx\n   * @param maxUnspents The maximum number of additional unspents which should be used to cover the remaining child fees\n   * @returns An object with the additional unspents to use, the updated number of satoshis which should be paid by\n   *          the child tx, and the updated inputs for the child tx.\n   */\n  const findAdditionalUnspents = ({ inputs, parentOutputValue, parentFee, parentVSize, maxUnspents }) => {\n    return async function coFindAdditionalUnspents() {\n      const additionalUnspents: any[] = [];\n\n      // ask the server for enough unspents to cover the child fee, assuming\n      // that it can be done without additional unspents (which is not possible,\n      // since if that were the case, findAdditionalUnspents would not have been\n      // called in the first place. This will be corrected before returning)\n      let currentChildFeeEstimate = estimateChildFee({ inputs, parentFee, parentVSize, feeRate: params.feeRate });\n      let uncoveredChildFee = currentChildFeeEstimate - parentOutputValue;\n\n      while (uncoveredChildFee > 0 && additionalUnspents.length < maxUnspents) {\n        // try to get enough unspents to cover the rest of the child fee\n        // @ts-expect-error - no implicit this\n        const unspents = (await this.unspents({\n          minConfirms: 1,\n          target: uncoveredChildFee,\n          limit: maxUnspents - additionalUnspents.length,\n        })) as any;\n\n        if (unspents.length === 0) {\n          // no more unspents are available\n          break;\n        }\n\n        let additionalUnspentValue = 0;\n\n        // consume all unspents returned by the server, even if we don't need\n        // all of them to cover the child fee. This is because the server will\n        // return enough unspent value to ensure that the minimum change amount\n        // is achieved for the child tx, and we can't leave out those unspents\n        // or else the minimum change amount constraint could be violated\n        _.forEach(unspents, (unspent) => {\n          // update the child tx inputs\n          const unspentChain = getChain(unspent);\n          if (isChainCode(unspentChain) && scriptTypeForChain(unspentChain) === 'p2shP2wsh') {\n            inputs.segwit++;\n          } else {\n            inputs.P2SH++;\n          }\n\n          additionalUnspents.push(unspent);\n          additionalUnspentValue += unspent.value;\n        });\n\n        currentChildFeeEstimate = estimateChildFee({ inputs, parentFee, parentVSize, feeRate: params.feeRate });\n        uncoveredChildFee = currentChildFeeEstimate - parentOutputValue - additionalUnspentValue;\n      }\n\n      if (uncoveredChildFee > 0) {\n        // Unable to find enough unspents to cover the child fee\n        throw new Error(`Insufficient confirmed unspents available to cover the child fee`);\n      }\n\n      // found enough unspents\n      return {\n        additional: additionalUnspents,\n        newChildFee: currentChildFeeEstimate,\n        newInputs: inputs,\n      };\n    }.call(this);\n  };\n\n  /**\n   * Helper function to get a full copy (including witness data) of an arbitrary tx using only the tx id.\n   *\n   * We have to use an external service for this (currently blockstream.info), since\n   * the v1 indexer service (based on bitcoinj) does not have segwit support and\n   * does not return any segwit related fields in the tx hex.\n   *\n   * @param parentTxId The ID of the transaction to get the full hex of\n   * @returns {Bluebird<any>} The full hex for the specified transaction\n   */\n  async function getParentTxHex({ parentTxId }: { parentTxId: string }): Promise<string> {\n    const explorerBaseUrl = common.Environments[self.bitgo.getEnv()].btcExplorerBaseUrl;\n    const result = await request.get(`${explorerBaseUrl}/tx/${parentTxId}/hex`);\n\n    if (!result.text || !/([a-f0-9]{2})+/.test(result.text)) {\n      throw new Error(\n        `Did not successfully receive parent tx hex. Received '${_.truncate(result.text, { length: 100 })}' instead.`\n      );\n    }\n\n    return result.text;\n  }\n\n  /**\n   * Helper function to get the chain from an unspent or tx output.\n   *\n   * @param outputOrUnspent The output or unspent whose chain should be determined\n   * @returns {number} The chain for the given output or unspent\n   */\n  const getChain = (outputOrUnspent) => {\n    if (outputOrUnspent.chain !== undefined) {\n      return outputOrUnspent.chain;\n    }\n\n    if (outputOrUnspent.chainPath !== undefined) {\n      return _.toNumber(outputOrUnspent.chainPath.split('/')[1]);\n    }\n\n    // no way to tell the chain, let's just blow up now instead\n    // of blowing up later when the undefined return value is used.\n    // Note: for unspents the field to use is 'address', but for outputs\n    // the field to use is 'account'\n    throw Error(`Could not get chain for output on account ${outputOrUnspent.account || outputOrUnspent.address}`);\n  };\n\n  /**\n   * Helper function to calculate the actual value contribution an output or unspent will\n   * contribute to a transaction, were it to be used. Each type of output or unspent\n   * will have a different value contribution since each type has a different number\n   * of virtual bytes, and thus will cause a different fee to be paid.\n   *\n   * @param outputOrUnspent Output or unspent whose effective value should be determined\n   * @returns {number} The actual number of satoshis that this unspent or output\n   *                   would contribute to a transaction, were it to be used.\n   */\n  const effectiveValue = (outputOrUnspent) => {\n    const chain = getChain(outputOrUnspent);\n    if (isChainCode(chain) && scriptTypeForChain(chain) === 'p2shP2wsh') {\n      // VirtualSizes.txP2shP2wshInputSize is in bytes, so we need to convert to kB\n      return outputOrUnspent.value - (VirtualSizes.txP2shP2wshInputSize * params.feeRate) / 1000;\n    }\n    // VirtualSizes.txP2shInputSize is in bytes, so we need to convert to kB\n    return outputOrUnspent.value - (VirtualSizes.txP2shInputSize * params.feeRate) / 1000;\n  };\n\n  /**\n   * Coroutine which actually implements the accelerateTransaction algorithm\n   *\n   * Described at a high level, the algorithm is as follows:\n   * 1) Find appropriate output from parent transaction to use as child transaction input\n   * 2) Find unspent corresponding to parent transaction output. If not found, return to step 1.\n   * 3) Determine if parent transaction unspent can cover entire child fee, plus minimum change\n   * 4) If yes, go to step 6\n   * 5) Otherwise, find additional unspents from the wallet to use to cover the remaining child fee\n   * 6) Create and sign the child transaction, using the parent transaction output\n   *    (and, if necessary, additional wallet unspents) as inputs\n   * 7) Broadcast the new child transaction\n   */\n  return async function coAccelerateTransaction() {\n    params = params || {};\n    common.validateParams(params, ['transactionID'], [], callback);\n\n    // validate fee rate\n    if (params.feeRate === undefined) {\n      throw new Error('Missing parameter: feeRate');\n    }\n    if (!_.isFinite(params.feeRate) || params.feeRate <= 0) {\n      throw new Error('Expecting positive finite number for parameter: feeRate');\n    }\n\n    // validate maxUnspents\n    if (params.maxAdditionalUnspents === undefined) {\n      // by default, use at most 100 additional unspents (not including the unspent output from the parent tx)\n      params.maxAdditionalUnspents = 100;\n    }\n\n    if (!_.isInteger(params.maxAdditionalUnspents) || params.maxAdditionalUnspents <= 0) {\n      throw Error('Expecting positive integer for parameter: maxAdditionalUnspents');\n    }\n\n    // @ts-expect-error - no implicit this\n    const parentTx = await this.getTransaction({ id: params.transactionID });\n    if (parentTx.confirmations > 0) {\n      throw new Error(`Transaction ${params.transactionID} is already confirmed and cannot be accelerated`);\n    }\n\n    // get the outputs from the parent tx which are to our wallet\n    const walletOutputs = _.filter(parentTx.outputs, (output) => output.isMine);\n\n    if (walletOutputs.length === 0) {\n      throw new Error(\n        `Transaction ${params.transactionID} contains no outputs to this wallet, and thus cannot be accelerated`\n      );\n    }\n\n    // use an output from the parent with largest effective value,\n    // but check to make sure the output is actually unspent.\n    // An output could be spent already if the output was used in a\n    // child tx which itself has become stuck due to low fees and is\n    // also unconfirmed.\n    const sortedOutputs = _.sortBy(walletOutputs, effectiveValue);\n    let parentUnspentToUse;\n    let outputToUse;\n\n    while (sortedOutputs.length > 0 && parentUnspentToUse === undefined) {\n      outputToUse = sortedOutputs.pop();\n\n      // find the unspent corresponding to this particular output\n      // TODO: is there a better way to get this unspent?\n      // TODO: The best we can do here is set minSize = maxSize = outputToUse.value\n      // @ts-expect-error - no implicit this\n      const unspentsResult = await this.unspents({\n        minSize: outputToUse.value,\n        maxSize: outputToUse.value,\n      });\n\n      parentUnspentToUse = _.find(unspentsResult, (unspent) => {\n        // make sure unspent belongs to the given txid\n        if (unspent.tx_hash !== params.transactionID) {\n          return false;\n        }\n        // make sure unspent has correct v_out index\n        return unspent.tx_output_n === outputToUse.vout;\n      });\n    }\n\n    if (parentUnspentToUse === undefined) {\n      throw new Error(`Could not find unspent output from parent tx to use as child input`);\n    }\n\n    // get the full hex for the parent tx and decode it to get its vsize\n    const parentTxHex = await getParentTxHex({ parentTxId: params.transactionID });\n    const decodedParent = utxolib.bitgo.createTransactionFromHex(parentTxHex, utxolib.networks.bitcoin);\n    const parentVSize = decodedParent.virtualSize();\n\n    // make sure id from decoded tx and given tx id match\n    // this should catch problems emanating from the use of an external service\n    // for getting the complete parent tx hex\n    if (decodedParent.getId() !== params.transactionID) {\n      throw new Error(\n        `Decoded transaction id is ${decodedParent.getId()}, which does not match given txid ${params.transactionID}`\n      );\n    }\n\n    // make sure new fee rate is greater than the parent's current fee rate\n    // virtualSize is returned in vbytes, so we need to convert to kvB\n    const parentRate = (1000 * parentTx.fee) / parentVSize;\n    if (params.feeRate <= parentRate) {\n      throw new Error(\n        `Cannot lower fee rate! (Parent tx fee rate is ${parentRate} sat/kB, and requested fee rate was ${params.feeRate} sat/kB)`\n      );\n    }\n\n    // determine if parent output can cover child fee\n    const isParentOutputSegwit =\n      isChainCode(outputToUse.chain) && scriptTypeForChain(outputToUse.chain) === 'p2shP2wsh';\n\n    let childInputs = {\n      segwit: isParentOutputSegwit ? 1 : 0,\n      P2SH: isParentOutputSegwit ? 0 : 1,\n    };\n\n    let childFee = estimateChildFee({\n      inputs: childInputs,\n      parentFee: parentTx.fee,\n      feeRate: params.feeRate,\n      parentVSize,\n    });\n\n    const unspentsToUse = [parentUnspentToUse];\n\n    // try to get the min change size from the server, otherwise default to 0.1 BTC\n    // TODO: minChangeSize is not currently a constant defined on the client and should be added\n    // @ts-expect-error - no implicit this\n    const minChangeSize = this.bitgo.getConstants().minChangeSize || 1e7;\n\n    if (outputToUse.value < childFee + minChangeSize) {\n      // parent output cannot cover child fee plus the minimum change,\n      // must find additional unspents to cover the difference\n      const { additional, newChildFee, newInputs } = await findAdditionalUnspents({\n        inputs: childInputs,\n        parentOutputValue: outputToUse.value,\n        parentFee: parentTx.fee,\n        maxUnspents: params.maxAdditionalUnspents,\n        parentVSize,\n      });\n      childFee = newChildFee;\n      childInputs = newInputs;\n      unspentsToUse.push(...additional);\n    }\n\n    // sanity check the fee rate we're paying for the combined tx\n    // to make sure it's under the max fee rate. Only the child tx\n    // can break this limit, but the combined tx shall not\n    // @ts-expect-error - no implicit this\n    const maxFeeRate = this.bitgo.getConstants().maxFeeRate;\n    const childVSize = estimateTxVSize(childInputs);\n    const combinedVSize = childVSize + parentVSize;\n    const combinedFee = parentTx.fee + childFee;\n    // combined fee rate must be in sat/kB, so we need to convert\n    const combinedFeeRate = (1000 * combinedFee) / combinedVSize;\n\n    if (combinedFeeRate > maxFeeRate) {\n      throw new Error(\n        `Transaction cannot be accelerated. Combined fee rate of ${combinedFeeRate} sat/kB exceeds maximum fee rate of ${maxFeeRate} sat/kB`\n      );\n    }\n\n    // create a new change address and determine change amount.\n    // the tx builder will reject transactions which have no recipients,\n    // and such zero-output transactions are forbidden by the Bitcoin protocol,\n    // so we need at least a single recipient for the change which won't be pruned.\n    const changeAmount = _.sumBy(unspentsToUse, (unspent) => unspent.value) - childFee;\n    // @ts-expect-error - no implicit this\n    const changeChain = this.getChangeChain({});\n    // @ts-expect-error - no implicit this\n    const changeAddress = await this.createAddress({ chain: changeChain });\n\n    // create the child tx and broadcast\n    // @ts-expect-error - no implicit this\n    const tx = await this.createAndSignTransaction({\n      unspents: unspentsToUse,\n      recipients: [\n        {\n          address: changeAddress.address,\n          amount: changeAmount,\n        },\n      ],\n      fee: childFee,\n      bitgoFee: {\n        amount: 0,\n        address: '',\n      },\n      xprv: params.xprv,\n      walletPassphrase: params.walletPassphrase,\n    });\n\n    // child fee rate must be in sat/kB, so we need to convert\n    const childFeeRate = (1000 * childFee) / childVSize;\n    if (childFeeRate > maxFeeRate) {\n      // combined tx is within max fee rate limits, but the child tx is not.\n      // in this case, we need to use the ignoreMaxFeeRate flag to get the child tx to be accepted\n      tx.ignoreMaxFeeRate = true;\n    }\n\n    // @ts-expect-error - no implicit this\n    return this.sendTransaction(tx);\n  }\n    .call(this)\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// createAndSignTransaction\n// INTERNAL function to create and sign a transaction\n//\n// Parameters:\n//   recipients - array of { address, amount } to send to\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n//   (See transactionBuilder.createTransaction for other passthrough params)\n// Returns:\n//\nWallet.prototype.createAndSignTransaction = function (params, callback) {\n  return async function () {\n    params = params || {};\n    common.validateParams(params, [], [], callback);\n\n    if (!_.isObject(params.recipients)) {\n      throw new Error('expecting recipients object');\n    }\n\n    if (params.fee && !_.isNumber(params.fee)) {\n      throw new Error('invalid argument for fee - number expected');\n    }\n\n    if (params.feeRate && !_.isNumber(params.feeRate)) {\n      throw new Error('invalid argument for feeRate - number expected');\n    }\n\n    if (params.dynamicFeeConfirmTarget && !_.isNumber(params.dynamicFeeConfirmTarget)) {\n      throw new Error('invalid argument for confirmTarget - number expected');\n    }\n\n    if (params.instant && !_.isBoolean(params.instant)) {\n      throw new Error('invalid argument for instant - boolean expected');\n    }\n\n    // @ts-expect-error - no implicit this\n    const transaction = (await this.createTransaction(params)) as any;\n    const fee = transaction.fee;\n    const feeRate = transaction.feeRate;\n    const estimatedSize = transaction.estimatedSize;\n    const bitgoFee = transaction.bitgoFee;\n    const travelInfos = transaction.travelInfos;\n    const unspents = transaction.unspents;\n\n    // Sign the transaction\n    try {\n      // @ts-expect-error - no implicit this\n      const keychain = await this.getAndPrepareSigningKeychain(params);\n      transaction.keychain = keychain;\n    } catch (e) {\n      if (e.code !== 'no_encrypted_keychain_on_wallet') {\n        throw e;\n      }\n      // this might be a safe wallet, so let's retrieve the private key info\n      // @ts-expect-error - no implicit this\n      await this.refresh({ gpk: true });\n      // @ts-expect-error - no implicit this\n      const safeUserKey = _.get(this.wallet, 'private.userPrivKey');\n      if (_.isString(safeUserKey) && _.isString(params.walletPassphrase)) {\n        // @ts-expect-error - no implicit this\n        transaction.signingKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: safeUserKey });\n      } else {\n        throw e;\n      }\n    }\n\n    transaction.feeSingleKeyWIF = params.feeSingleKeyWIF;\n    // @ts-expect-error - no implicit this\n    const result = await this.signTransaction(transaction);\n    return _.extend(result, {\n      fee,\n      feeRate,\n      instant: params.instant,\n      bitgoFee,\n      travelInfos,\n      estimatedSize,\n      unspents,\n    });\n  }\n    .call(this)\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// getAndPrepareSigningKeychain\n// INTERNAL function to get the user keychain for signing.\n// Caller must provider either a keychain, or walletPassphrase or xprv as a string\n// If the caller provides the keychain with xprv, it is simply returned.\n// If the caller provides the encrypted xprv (walletPassphrase), then fetch the keychain object and decrypt\n// Otherwise if the xprv is provided, fetch the keychain object and augment it with the xprv.\n//\n// Parameters:\n//   keychain - keychain with xprv\n//   xprv - the private key in string form\n//   walletPassphrase - the passphrase to be used to decrypt the user key on this wallet\n// Returns:\n//   Keychain object containing xprv, xpub and paths\n//\nWallet.prototype.getAndPrepareSigningKeychain = function (params, callback) {\n  params = params || {};\n\n  // If keychain with xprv is already provided, use it\n  if (_.isObject(params.keychain) && params.keychain.xprv) {\n    return Promise.resolve(params.keychain);\n  }\n\n  common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n  if ((params.walletPassphrase && params.xprv) || (!params.walletPassphrase && !params.xprv)) {\n    throw new Error('must provide exactly one of xprv or walletPassphrase');\n  }\n\n  const self = this;\n\n  // Caller provided a wallet passphrase\n  if (params.walletPassphrase) {\n    return self.getEncryptedUserKeychain().then(function (keychain) {\n      // Decrypt the user key with a passphrase\n      try {\n        keychain.xprv = self.bitgo.decrypt({ password: params.walletPassphrase, input: keychain.encryptedXprv });\n      } catch (e) {\n        throw new Error('Unable to decrypt user keychain');\n      }\n\n      if (keychain.xpub && bip32.fromBase58(keychain.xprv).neutered().toBase58() !== keychain.xpub) {\n        throw new Error('derived xpub does not match stored xpub');\n      }\n      return keychain;\n    });\n  }\n\n  // Caller provided an xprv - validate and construct keychain object\n  let xpub;\n  try {\n    xpub = bip32.fromBase58(params.xprv).neutered().toBase58();\n  } catch (e) {\n    throw new Error('Unable to parse the xprv');\n  }\n\n  if (xpub === params.xprv) {\n    throw new Error('xprv provided was not a private key (found xpub instead)');\n  }\n\n  const walletXpubs = _.map(self.keychains, 'xpub');\n  if (!_.includes(walletXpubs, xpub)) {\n    throw new Error('xprv provided was not a keychain on this wallet!');\n  }\n\n  // get the keychain object from bitgo to find the path and (potential) wallet structure\n  return self.bitgo\n    .keychains()\n    .get({ xpub: xpub })\n    .then(function (keychain) {\n      keychain.xprv = params.xprv;\n      return keychain;\n    });\n};\n\n/**\n * Takes a wallet's unspents and fans them out into a larger number of equally sized unspents\n * @param params\n *  target: set how many unspents you want to have in the end\n *  minConfirms: minimum number of confirms the unspents must have\n *  xprv: private key to sign transaction\n *  walletPassphrase: wallet passphrase to decrypt the wallet's private key\n * @param callback\n * @returns {*}\n */\nWallet.prototype.fanOutUnspents = function (params, callback) {\n  const self = this;\n  return (async function () {\n    // maximum number of inputs for fanout transaction\n    // (when fanning out, we take all the unspents and make a bigger number of outputs)\n    const MAX_FANOUT_INPUT_COUNT = 80;\n    // maximum number of outputs for fanout transaction\n    const MAX_FANOUT_OUTPUT_COUNT = 300;\n    params = params || {};\n    common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n    const validate = params.validate === undefined ? true : params.validate;\n\n    const target = params.target;\n    // the target must be defined, be a number, be at least two, and be a natural number\n    if (!_.isNumber(target) || target < 2 || target % 1 !== 0) {\n      throw new Error('Target needs to be a positive integer');\n    }\n    if (target > MAX_FANOUT_OUTPUT_COUNT) {\n      throw new Error('Fan out target too high');\n    }\n\n    let minConfirms = params.minConfirms;\n    if (minConfirms === undefined) {\n      minConfirms = 1;\n    }\n    if (!_.isNumber(minConfirms) || minConfirms < 0) {\n      throw new Error('minConfirms needs to be an integer >= 0');\n    }\n\n    /**\n     * Split a natural number N into n almost equally sized (±1) natural numbers.\n     * In order to calculate the sizes of the parts, we calculate floor(N/n), and thus have the base size of all parts.\n     * If N % n !== 0, this leaves us with a remainder r where r < n. We distribute r equally among the n parts by\n     * adding 1 to the first r parts.\n     * @param total\n     * @param partCount\n     * @returns {Array}\n     */\n    const splitNumberIntoCloseNaturalNumbers = function (total, partCount) {\n      const partSize = Math.floor(total / partCount);\n      const remainder = total - partSize * partCount;\n      // initialize placeholder array\n      const almostEqualParts = new Array(partCount);\n      // fill the first remainder parts with the value partSize+1\n      _.fill(almostEqualParts, partSize + 1, 0, remainder);\n      // fill the remaining parts with the value partSize\n      _.fill(almostEqualParts, partSize, remainder);\n      // assert the correctness of the almost equal parts\n      // TODO: add check for the biggest deviation between any two parts and make sure it's <= 1\n      if (_(almostEqualParts).sum() !== total || _(almostEqualParts).size() !== partCount) {\n        throw new Error('part sum or part count mismatch');\n      }\n      return almostEqualParts;\n    };\n\n    // first, let's take all the wallet's unspents (with min confirms if necessary)\n    const allUnspents = (await self.unspents({ minConfirms: minConfirms })) as any;\n    if (allUnspents.length < 1) {\n      throw new Error('No unspents to branch out');\n    }\n\n    // this consolidation is essentially just a waste of money\n    if (allUnspents.length >= target) {\n      throw new Error('Fan out target has to be bigger than current number of unspents');\n    }\n\n    // we have at the very minimum 81 inputs, and 81 outputs. That transaction will be big\n    // in the medium run, this algorithm could be reworked to only work with a subset of the transactions\n    if (allUnspents.length > MAX_FANOUT_INPUT_COUNT) {\n      throw new Error('Too many unspents');\n    }\n\n    // this is all the money that is currently in the wallet\n    const grossAmount = _(allUnspents).map('value').sum();\n\n    // in order to not modify the params object, we create a copy\n    const txParams = _.extend({}, params);\n    txParams.unspents = allUnspents;\n    txParams.recipients = {};\n\n    // create target amount of new addresses for this wallet\n    const newAddressPromises = _.range(target).map(() =>\n      self.createAddress({ chain: self.getChangeChain(params), validate: validate })\n    );\n    const newAddresses = await Promise.all(newAddressPromises);\n    // let's find a nice, equal distribution of our Satoshis among the new addresses\n    const splitAmounts = splitNumberIntoCloseNaturalNumbers(grossAmount, target);\n    // map the newly created addresses to the almost components amounts we just calculated\n    txParams.recipients = _.zipObject(_.map(newAddresses, 'address'), splitAmounts);\n    txParams.noSplitChange = true;\n    // attempt to create a transaction. As it is a wallet-sweeping transaction with no fee, we expect it to fail\n    try {\n      await self.sendMany(txParams);\n    } catch (error) {\n      // as expected, the transaction creation did indeed fail due to insufficient fees\n      // the error suggests a fee value which we then use for the transaction\n      // however, let's make sure it wasn't something else\n      if (!error.fee && (!error.result || !error.result.fee)) {\n        // if the error does not contain a fee property, it is something else that has gone awry, and we throw it\n        const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n        error.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n        throw error;\n      }\n      const baseFee = error.fee || error.result.fee;\n      let totalFee = baseFee;\n      if (error.result.bitgoFee && error.result.bitgoFee.amount) {\n        totalFee += error.result.bitgoFee.amount;\n        txParams.bitgoFee = error.result.bitgoFee;\n      }\n\n      // Need to clear these out since only 1 may be set\n      delete txParams.fee;\n      txParams.originalFeeRate = txParams.feeRate;\n      delete txParams.feeRate;\n      delete txParams.feeTxConfirmTarget;\n      txParams.fee = baseFee;\n      // in order to maintain the equal distribution, we need to subtract the fee from the cumulative funds\n      // in case some unspents got pruned, we need to use error.result.available\n      const netAmount = error.result.available - totalFee; // after fees\n      // that means that the distribution has to be recalculated\n      const remainingSplitAmounts = splitNumberIntoCloseNaturalNumbers(netAmount, target);\n      // and the distribution again mapped to the new addresses\n      txParams.recipients = _.zipObject(_.map(newAddresses, 'address'), remainingSplitAmounts);\n    }\n\n    // this time, the transaction creation should work\n    let fanoutTx;\n    try {\n      fanoutTx = await self.sendMany(txParams);\n    } catch (e) {\n      const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n      e.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n      throw e;\n    }\n\n    return Promise.resolve(fanoutTx).then(callback).catch(callback);\n  })()\n    .then(callback)\n    .catch(callback);\n};\n\n/**\n * Determine whether to fan out or coalesce a wallet's unspents\n * @param params\n * @param callback\n * @returns {Request|Promise.<T>|*}\n */\nWallet.prototype.regroupUnspents = function (params, callback) {\n  params = params || {};\n  const target = params.target;\n  if (!_.isNumber(target) || target < 1 || target % 1 !== 0) {\n    // the target must be defined, be a number, be at least one, and be a natural number\n    throw new Error('Target needs to be a positive integer');\n  }\n\n  let minConfirms = params.minConfirms;\n  if (minConfirms === undefined) {\n    minConfirms = 1;\n  }\n  if (!_.isNumber(minConfirms) || minConfirms < 0) {\n    throw new Error('minConfirms needs to be an integer equal to or bigger than 0');\n  }\n\n  const self = this;\n  return self.unspents({ minConfirms: minConfirms }).then(function (unspents) {\n    if (unspents.length === target) {\n      return unspents;\n    } else if (unspents.length > target) {\n      return self.consolidateUnspents(params, callback);\n    } else if (unspents.length < target) {\n      return self.fanOutUnspents(params, callback);\n    }\n  });\n};\n\n/**\n * Consolidate a wallet's unspents into fewer unspents\n * @param params\n *  target: set how many unspents you want to have in the end\n *  maxInputCountPerConsolidation: set how many maximum inputs are to be permitted per consolidation batch\n *  xprv: private key to sign transaction\n *  walletPassphrase: wallet passphrase to decrypt the wallet's private key\n *  maxIterationCount: maximum number of iterations to be performed until function stops\n *  progressCallback: method to be called with object outlining current progress details\n * @param callback\n * @returns {*}\n */\nWallet.prototype.consolidateUnspents = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], ['walletPassphrase', 'xprv'], callback);\n  const validate = params.validate === undefined ? true : params.validate;\n\n  let target = params.target;\n  if (target === undefined) {\n    target = 1;\n  } else if (!_.isNumber(target) || target < 1 || target % 1 !== 0) {\n    // the target must be defined, be a number, be at least one, and be a natural number\n    throw new Error('Target needs to be a positive integer');\n  }\n\n  if (params.maxSize && !_.isNumber(params.maxSize)) {\n    throw new Error('maxSize should be a number');\n  }\n\n  if (params.minSize && !_.isNumber(params.minSize)) {\n    throw new Error('minSize should be a number');\n  }\n\n  // maximum number of inputs per transaction for consolidation\n  const MAX_INPUT_COUNT = 200;\n  let maxInputCount = params.maxInputCountPerConsolidation;\n  if (maxInputCount === undefined) {\n    // null or unidentified, because equality to zero returns true in if(! clause\n    maxInputCount = MAX_INPUT_COUNT;\n  }\n  if (typeof maxInputCount !== 'number' || maxInputCount < 2 || maxInputCount % 1 !== 0) {\n    throw new Error('Maximum consolidation input count needs to be an integer equal to or bigger than 2');\n  } else if (maxInputCount > MAX_INPUT_COUNT) {\n    throw new Error('Maximum consolidation input count cannot be bigger than ' + MAX_INPUT_COUNT);\n  }\n\n  const maxIterationCount = params.maxIterationCount || -1;\n  if (\n    (params.maxIterationCount && (!_.isNumber(maxIterationCount) || maxIterationCount < 1)) ||\n    maxIterationCount % 1 !== 0\n  ) {\n    throw new Error('Maximum iteration count needs to be an integer equal to or bigger than 1');\n  }\n\n  let minConfirms = params.minConfirms;\n  if (minConfirms === undefined) {\n    minConfirms = 1;\n  }\n  if (!_.isNumber(minConfirms) || minConfirms < 0) {\n    throw new Error('minConfirms needs to be an integer equal to or bigger than 0');\n  }\n\n  let minSize = params.minSize || 0;\n  if (params.feeRate) {\n    // fee rate is in satoshis per kB, input size in bytes\n    const feeBasedMinSize = Math.ceil((VirtualSizes.txP2shInputSize * params.feeRate) / 1000);\n    if (params.minSize && minSize < feeBasedMinSize) {\n      throw new Error('provided minSize too low due to too high fee rate');\n    }\n    minSize = Math.max(feeBasedMinSize, minSize);\n\n    if (!params.minSize) {\n      // fee rate-based min size needs no logging if it was set explicitly\n      console.log(\n        'Only consolidating unspents larger than ' +\n          minSize +\n          ' satoshis to avoid wasting money on fees. To consolidate smaller unspents, use a lower fee rate.'\n      );\n    }\n  }\n\n  let iterationCount = 0;\n\n  const self = this;\n  let consolidationIndex = 0;\n\n  /**\n   * Consolidate one batch of up to MAX_INPUT_COUNT unspents.\n   * @returns {*}\n   */\n  async function runNextConsolidation() {\n    const consolidationTransactions: any[] = [];\n    let isFinalConsolidation = false;\n    iterationCount++;\n    /*\n     We take a maximum of unspentBulkSizeLimit unspents from the wallet. We want to make sure that we swipe the wallet\n     clean of all excessive unspents, so we add 1 to the target unspent count to make sure we haven't missed anything.\n     In case there are even more unspents than that, to make the consolidation as fast as possible, we expand our\n     selection to include as many as the maximum permissible number of inputs per consolidation batch.\n     Should the target number of unspents be higher than the maximum number if inputs per consolidation,\n     we still want to fetch them all simply to be able to determine whether or not a consolidation can be performed\n     at all, which is dependent on the number of all unspents being higher than the target.\n     In the next version of the unspents version SDK, we will know the total number of unspents without having to fetch\n     them, and therefore will be able to simplify this method.\n     */\n\n    const queryParams: any = {\n      limit: target + maxInputCount,\n      minConfirms: minConfirms,\n      minSize: minSize,\n    };\n    if (params.maxSize) {\n      queryParams.maxSize = params.maxSize;\n    }\n    const allUnspents = (await self.unspents(queryParams)) as any;\n    // this consolidation is essentially just a waste of money\n    if (allUnspents.length <= target) {\n      if (iterationCount <= 1) {\n        // this is the first iteration, so the method is incorrect\n        throw new Error('Fewer unspents than consolidation target. Use fanOutUnspents instead.');\n      } else {\n        // it's a later iteration, so the target may have been surpassed (due to confirmations in the background)\n        throw new Error('Done');\n      }\n    }\n\n    const allUnspentsCount = allUnspents.length;\n\n    // how many of the unspents do we want to consolidate?\n    // the +1 is because the consolidated block becomes a new unspent later\n    let targetInputCount = allUnspentsCount - target + 1;\n    targetInputCount = Math.min(targetInputCount, allUnspents.length);\n\n    // if the targetInputCount requires more inputs than we allow per batch, we reduce the number\n    const inputCount = Math.min(targetInputCount, maxInputCount);\n\n    // if either the number of inputs left to coalesce equals the number we will coalesce in this iteration\n    // or if the number of iterations matches the maximum permitted number\n    isFinalConsolidation = inputCount === targetInputCount || iterationCount === maxIterationCount;\n\n    const currentChunk = allUnspents.splice(0, inputCount);\n    const changeChain = self.getChangeChain(params);\n    const newAddress = (await self.createAddress({ chain: changeChain, validate: validate })) as any;\n    const txParams = _.extend({}, params);\n    const currentAddress = newAddress;\n    // the total amount that we are consolidating within this batch\n    const grossAmount = _(currentChunk).map('value').sum(); // before fees\n\n    txParams.unspents = currentChunk;\n    txParams.recipients = {};\n    txParams.recipients[newAddress.address] = grossAmount;\n    txParams.noSplitChange = true;\n\n    if (txParams.unspents.length <= 1) {\n      throw new Error('Done');\n    }\n\n    // let's attempt to create this transaction. We expect it to fail because no fee is set.\n    try {\n      await self.sendMany(txParams);\n    } catch (error) {\n      // this error should occur due to insufficient funds\n      // however, let's make sure it wasn't something else\n      if (!error.fee && (!error.result || !error.result.fee)) {\n        // if the error does not contain a fee property, it is something else that has gone awry, and we throw it\n        const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n        error.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n        throw error;\n      }\n      const baseFee = error.fee || error.result.fee;\n      let bitgoFee = 0;\n      let totalFee = baseFee;\n      if (error.result.bitgoFee && error.result.bitgoFee.amount) {\n        bitgoFee = error.result.bitgoFee.amount;\n        totalFee += bitgoFee;\n        txParams.bitgoFee = error.result.bitgoFee;\n      }\n\n      // if the net amount is negative, it should be replaced with the minimum output size\n      const netAmount = Math.max(error.result.available - totalFee, self.bitgo.getConstants().minOutputSize);\n      // Need to clear these out since only 1 may be set\n      delete txParams.fee;\n      txParams.originalFeeRate = txParams.feeRate;\n      delete txParams.feeRate;\n      delete txParams.feeTxConfirmTarget;\n\n      // we set the fee explicitly\n      txParams.fee = error.result.available - netAmount - bitgoFee;\n      txParams.recipients[newAddress.address] = netAmount;\n    }\n    // this transaction, on the other hand, should be created with no issues, because an appropriate fee is set\n    let sentTx;\n    try {\n      sentTx = await self.sendMany(txParams);\n    } catch (e) {\n      const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);\n      e.message += `\\n\\nTX PARAMS:\\n ${JSON.stringify(debugParams, null, 4)}`;\n      throw e;\n    }\n    consolidationTransactions.push(sentTx);\n    if (_.isFunction(params.progressCallback)) {\n      params.progressCallback({\n        txid: sentTx.hash,\n        destination: currentAddress,\n        amount: grossAmount,\n        fee: sentTx.fee,\n        inputCount: inputCount,\n        index: consolidationIndex,\n      });\n    }\n    consolidationIndex++;\n    if (!isFinalConsolidation) {\n      // this last consolidation has not yet brought the unspents count down to the target unspent count\n      // therefore, we proceed by consolidating yet another batch\n      // before we do that, we wait 1 second so that the newly created unspent will be fetched in the next batch\n      await new Promise((resolve) => setTimeout(resolve, 1000));\n      consolidationTransactions.push(...((await runNextConsolidation()) as any));\n    }\n    // this is the final consolidation transaction. We return all the ones we've had so far\n    return consolidationTransactions;\n  }\n\n  return runNextConsolidation()\n    .catch(function (err) {\n      if (err.message === 'Done') {\n        return;\n      }\n      throw err;\n    })\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.shareWallet = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['email', 'permissions'], ['walletPassphrase', 'message'], callback);\n\n  if (params.reshare !== undefined && !_.isBoolean(params.reshare)) {\n    throw new Error('Expected reshare to be a boolean.');\n  }\n\n  if (params.skipKeychain !== undefined && !_.isBoolean(params.skipKeychain)) {\n    throw new Error('Expected skipKeychain to be a boolean. ');\n  }\n  const needsKeychain = !params.skipKeychain && params.permissions.indexOf('spend') !== -1;\n\n  if (params.disableEmail !== undefined && !_.isBoolean(params.disableEmail)) {\n    throw new Error('Expected disableEmail to be a boolean.');\n  }\n\n  const self = this;\n  let sharing;\n  let sharedKeychain;\n  return this.bitgo\n    .getSharingKey({ email: params.email.toLowerCase() })\n    .then(function (result) {\n      sharing = result;\n\n      if (needsKeychain) {\n        return self.getEncryptedUserKeychain({}).then(function (keychain) {\n          // Decrypt the user key with a passphrase\n          if (keychain.encryptedXprv) {\n            if (!params.walletPassphrase) {\n              throw new Error('Missing walletPassphrase argument');\n            }\n            try {\n              keychain.xprv = self.bitgo.decrypt({ password: params.walletPassphrase, input: keychain.encryptedXprv });\n            } catch (e) {\n              throw new Error('Unable to decrypt user keychain');\n            }\n\n            const eckey = makeRandomKey();\n            const secret = getSharedSecret(eckey, Buffer.from(sharing.pubkey, 'hex')).toString('hex');\n            const newEncryptedXprv = self.bitgo.encrypt({ password: secret, input: keychain.xprv });\n\n            sharedKeychain = {\n              xpub: keychain.xpub,\n              encryptedXprv: newEncryptedXprv,\n              fromPubKey: eckey.publicKey.toString('hex'),\n              toPubKey: sharing.pubkey,\n              path: sharing.path,\n            };\n          }\n        });\n      }\n    })\n    .then(function () {\n      interface Options {\n        user: any;\n        permissions: string;\n        reshare: boolean;\n        message: string;\n        disableEmail: any;\n        keychain?: any;\n        skipKeychain?: boolean;\n      }\n\n      const options: Options = {\n        user: sharing.userId,\n        permissions: params.permissions,\n        reshare: params.reshare,\n        message: params.message,\n        disableEmail: params.disableEmail,\n      };\n      if (sharedKeychain) {\n        options.keychain = sharedKeychain;\n      } else if (params.skipKeychain) {\n        options.keychain = {};\n      }\n\n      return self.createShare(options);\n    })\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.removeUser = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['user'], [], callback);\n\n  return Promise.resolve(\n    this.bitgo\n      .del(this.url('/user/' + params.user))\n      .send()\n      .result()\n  )\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.getPolicy = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.url('/policy')).send().result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.getPolicyStatus = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.url('/policy/status')).send().result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.setPolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id', 'type'], ['message'], callback);\n\n  if (!_.isObject(params.condition)) {\n    throw new Error('missing parameter: conditions object');\n  }\n\n  if (!_.isObject(params.action)) {\n    throw new Error('missing parameter: action object');\n  }\n\n  return Promise.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.removePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], ['message'], callback);\n\n  return Promise.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.listWebhooks = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.url('/webhooks')).send().result())\n    .then(callback)\n    .catch(callback);\n};\n\n/**\n * Simulate wallet webhook, currently for webhooks of type transaction and pending approval\n * @param params\n * - webhookId (required): id of the webhook to be simulated\n * - txHash (optional but required for transaction webhooks) hash of the simulated transaction\n * - pendingApprovalId (optional but required for pending approval webhooks) id of the simulated pending approval\n * @param callback\n * @returns {*}\n */\nWallet.prototype.simulateWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['webhookId'], ['txHash', 'pendingApprovalId'], callback);\n\n  const hasTxHash = !!params.txHash;\n  const hasPendingApprovalId = !!params.pendingApprovalId;\n\n  if ((hasTxHash && hasPendingApprovalId) || (!hasTxHash && !hasPendingApprovalId)) {\n    throw new Error('must supply either txHash or pendingApprovalId, but not both');\n  }\n\n  // depending on the coin type of the wallet, the txHash has to adhere to its respective format\n  // but the server takes care of that\n\n  // only take the txHash and pendingApprovalId properties\n  const filteredParams = _.pick(params, ['txHash', 'pendingApprovalId']);\n\n  const webhookId = params.webhookId;\n  return Promise.resolve(\n    this.bitgo\n      .post(this.url('/webhooks/' + webhookId + '/simulate'))\n      .send(filteredParams)\n      .result()\n  )\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.addWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['url', 'type'], [], callback);\n\n  return Promise.resolve(this.bitgo.post(this.url('/webhooks')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.removeWebhook = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['url', 'type'], [], callback);\n\n  return Promise.resolve(this.bitgo.del(this.url('/webhooks')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.estimateFee = function (params, callback) {\n  common.validateParams(params, [], [], callback);\n\n  if (params.amount && params.recipients) {\n    throw new Error('cannot specify both amount as well as recipients');\n  }\n  if (params.recipients && !_.isObject(params.recipients)) {\n    throw new Error('recipients must be array of { address: abc, amount: 100000 } objects');\n  }\n  if (params.amount && !_.isNumber(params.amount)) {\n    throw new Error('invalid amount argument, expecting number');\n  }\n\n  const recipients = params.recipients || [];\n\n  if (params.amount) {\n    // only the amount was passed in, so we need to make a false recipient to run createTransaction with\n    recipients.push({\n      address: common.Environments[this.bitgo.env].signingAddress, // any address will do\n      amount: params.amount,\n    });\n  }\n\n  const transactionParams = _.extend({}, params);\n  transactionParams.amount = undefined;\n  transactionParams.recipients = recipients;\n\n  return this.createTransaction(transactionParams).then(function (tx) {\n    return {\n      estimatedSize: tx.estimatedSize,\n      fee: tx.fee,\n      feeRate: tx.feeRate,\n    };\n  });\n};\n\n// Not fully implemented / released on SDK. Testing for now.\nWallet.prototype.updatePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id', 'type'], [], callback);\n\n  return Promise.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\nWallet.prototype.deletePolicyRule = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  return Promise.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// getBitGoFee\n// Get the required on-transaction BitGo fee\n//\nWallet.prototype.getBitGoFee = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, [], [], callback);\n  if (!_.isNumber(params.amount)) {\n    throw new Error('invalid amount argument');\n  }\n  if (params.instant && !_.isBoolean(params.instant)) {\n    throw new Error('invalid instant argument');\n  }\n  return Promise.resolve(this.bitgo.get(this.url('/billing/fee')).query(params).result())\n    .then(callback)\n    .catch(callback);\n};\n\n/*\n * @params\n *  walletPassphrase: passphrase of wallet used to decrypt the encrypted keys\n *  unspents: array of unspents to recover\n *  recoveryDestination: destination address to recover funds to\n *  feeRate: fee rate to use for the recovery transaction\n *  userKey: encrypted user key\n *  backupKey: encrypted backup key\n * */\nWallet.prototype.recover = async function (params) {\n  if (_.isUndefined(params.walletPassphrase)) {\n    throw new Error('missing walletPassphrase');\n  }\n  if (_.isUndefined(params.unspents)) {\n    throw new Error('missing unspents');\n  }\n  if (_.isUndefined(params.recoveryDestination)) {\n    throw new Error('invalid recoveryDestination');\n  }\n  if (_.isUndefined(params.feeRate)) {\n    throw new Error('invalid feeRate');\n  }\n  if (_.isUndefined(params.userKey)) {\n    throw new Error('invalid userKey');\n  }\n  if (_.isUndefined(params.backupKey)) {\n    throw new Error('invalid backupKey');\n  }\n\n  const totalInputAmount = BigInt(utxolib.bitgo.unspentSum(params.unspents));\n  if (totalInputAmount <= BigInt(0)) {\n    throw new ErrorNoInputToRecover();\n  }\n\n  const outputSize = VirtualSizes.txP2wshOutputSize;\n  const approximateSize =\n    VirtualSizes.txSegOverheadVSize + outputSize + VirtualSizes.txP2shInputSize * params.unspents.length;\n  const approximateTxFee = BigInt(approximateSize * params.feeRate);\n  const recoveryAmount = totalInputAmount - approximateTxFee;\n  const recipients = [{ address: params.recoveryDestination, amount: Number(recoveryAmount) }];\n\n  const unsignedTx = await this.createTransaction({\n    unspents: params.unspents,\n    recipients,\n    fee: Number(approximateTxFee),\n  });\n\n  const parsedUnsignedTx = utxolib.bitgo.createTransactionFromHex(unsignedTx.transactionHex, utxolib.networks.bitcoin);\n  assert(parsedUnsignedTx.ins.length === params.unspents.length);\n  assert(parsedUnsignedTx.outs.length === 1);\n  assert(_.sumBy(params.unspents, 'value') - _.sumBy(parsedUnsignedTx.outs, 'value') === Number(approximateTxFee));\n\n  const plainUserKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.userKey });\n  const halfSignedTx = await this.signTransaction({ ...unsignedTx, signingKey: plainUserKey });\n\n  const plainBackupKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.backupKey });\n  const fullSignedTx = await this.signTransaction({\n    ...unsignedTx,\n    transactionHex: halfSignedTx.tx,\n    signingKey: plainBackupKey,\n  });\n  return fullSignedTx.tx;\n};\n\n/*\n * @params\n *  walletPassphrase: passphrase of wallet used to decrypt the encrypted keys\n *  unspents: array of unspents to recover\n *  recoveryDestination: destination address to recover funds to\n *  feeRate: fee rate to use for the recovery transaction\n *  userKey: encrypted user key\n * */\nWallet.prototype.sweep = async function (params) {\n  if (_.isUndefined(params.walletPassphrase)) {\n    throw new Error('missing walletPassphrase');\n  }\n  if (_.isUndefined(params.unspents)) {\n    throw new Error('missing unspents');\n  }\n  if (_.isUndefined(params.recoveryDestination)) {\n    throw new Error('invalid recoveryDestination');\n  }\n  if (_.isUndefined(params.feeRate)) {\n    throw new Error('invalid feeRate');\n  }\n  if (_.isUndefined(params.userKey)) {\n    throw new Error('invalid userKey');\n  }\n\n  const totalInputAmount = BigInt(utxolib.bitgo.unspentSum(params.unspents));\n  if (totalInputAmount <= BigInt(0)) {\n    throw new ErrorNoInputToRecover();\n  }\n\n  const outputSize = VirtualSizes.txP2wshOutputSize;\n  const approximateSize =\n    VirtualSizes.txSegOverheadVSize + outputSize + VirtualSizes.txP2shInputSize * params.unspents.length;\n  const approximateTxFee = BigInt(approximateSize * params.feeRate);\n  const recoveryAmount = totalInputAmount - approximateTxFee;\n  const recipients = [{ address: params.recoveryDestination, amount: Number(recoveryAmount) }];\n\n  const unsignedTx = await this.createTransaction({\n    unspents: params.unspents,\n    recipients,\n    fee: Number(approximateTxFee),\n  });\n\n  const parsedUnsignedTx = utxolib.bitgo.createTransactionFromHex(unsignedTx.transactionHex, utxolib.networks.bitcoin);\n  assert(parsedUnsignedTx.ins.length === params.unspents.length);\n  assert(parsedUnsignedTx.outs.length === 1);\n  assert(_.sumBy(params.unspents, 'value') - _.sumBy(parsedUnsignedTx.outs, 'value') === Number(approximateTxFee));\n\n  const plainUserKey = this.bitgo.decrypt({ password: params.walletPassphrase, input: params.userKey });\n  const halfSignedTx = await this.signTransaction({ ...unsignedTx, signingKey: plainUserKey });\n\n  return await this.sendTransaction({\n    tx: halfSignedTx.tx,\n    suppressBroadcast: true,\n    otp: params.otp,\n  });\n};\n\nexport = Wallet;\n"]}
|