@bitgo-beta/sdk-api 1.10.1-beta.99 → 1.10.1-beta.990

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/CHANGELOG.md +905 -0
  2. package/dist/package.json +13 -25
  3. package/dist/src/api.d.ts +3 -3
  4. package/dist/src/api.d.ts.map +1 -1
  5. package/dist/src/api.js +39 -33
  6. package/dist/src/bitgoAPI.d.ts +64 -11
  7. package/dist/src/bitgoAPI.d.ts.map +1 -1
  8. package/dist/src/bitgoAPI.js +357 -121
  9. package/dist/src/encrypt.d.ts +4 -4
  10. package/dist/src/encrypt.d.ts.map +1 -1
  11. package/dist/src/encrypt.js +44 -7
  12. package/dist/src/index.js +6 -2
  13. package/dist/src/types.d.ts +54 -43
  14. package/dist/src/types.d.ts.map +1 -1
  15. package/dist/src/types.js +4 -2
  16. package/dist/src/util.d.ts +12 -0
  17. package/dist/src/util.d.ts.map +1 -1
  18. package/dist/src/util.js +57 -4
  19. package/dist/src/v1/blockchain.js +25 -12
  20. package/dist/src/v1/keychains.js +27 -22
  21. package/dist/src/v1/markets.js +10 -5
  22. package/dist/src/v1/pendingapproval.d.ts.map +1 -1
  23. package/dist/src/v1/pendingapproval.js +57 -18
  24. package/dist/src/v1/pendingapprovals.d.ts.map +1 -1
  25. package/dist/src/v1/pendingapprovals.js +41 -7
  26. package/dist/src/v1/signPsbt.d.ts +14 -0
  27. package/dist/src/v1/signPsbt.d.ts.map +1 -0
  28. package/dist/src/v1/signPsbt.js +69 -0
  29. package/dist/src/v1/transactionBuilder.js +144 -92
  30. package/dist/src/v1/travelRule.js +60 -23
  31. package/dist/src/v1/verifyAddress.d.ts +6 -0
  32. package/dist/src/v1/verifyAddress.d.ts.map +1 -0
  33. package/dist/src/v1/verifyAddress.js +50 -0
  34. package/dist/src/v1/wallet.d.ts.map +1 -1
  35. package/dist/src/v1/wallet.js +428 -224
  36. package/dist/src/v1/wallets.js +93 -37
  37. package/package.json +13 -25
  38. package/dist/web/main.js +0 -2
  39. package/dist/web/main.js.LICENSE.txt +0 -110
@@ -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 Bluebird.resolve(this.bitgo
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
- })).nodeify(callback);
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
- !_.isInteger(params.approvalsRequired) ||
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 Bluebird.try(function () {
212
+ return (0, util_1.tryPromise)(function () {
174
213
  return self.wallet;
175
- }).nodeify(callback);
214
+ })
215
+ .then(callback)
216
+ .catch(callback);
176
217
  }
177
- return Bluebird.resolve(this.bitgo.put(this.url()).send(params).result()).nodeify(callback);
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 (!_.isUndefined(params.segwitChange)) {
185
- if (!_.isBoolean(params.segwitChange)) {
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 Bluebird.resolve(this.bitgo
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
- })).nodeify(callback);
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 (_.isInteger(threshold)) {
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 = _.map(pathComponents, (component) => {
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 = _.filter(normalizedPathComponents, _.isInteger);
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 === null || witnessScript === void 0 ? void 0 : witnessScript.toString('hex');
271
- addressDetails.redeemScript = redeemScript === null || redeemScript === void 0 ? void 0 : redeemScript.toString('hex');
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 = _.uniq(_.filter(chain, _.isInteger));
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 (!_.isInteger(params.limit)) {
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 (!_.isInteger(params.skip)) {
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 (!_.isNumber(params.sort)) {
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 Bluebird.resolve(this.bitgo.get(url).query(query).result()).nodeify(callback);
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 (!_.isInteger(params.limit)) {
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 Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);
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 co(function* () {
400
+ return async function () {
358
401
  // when set to true, gpk returns the private data of safe wallets
359
- const query = _.extend({}, _.pick(params, ['gpk']));
402
+ const query = lodash_1.default.extend({}, lodash_1.default.pick(params, ['gpk']));
360
403
  // @ts-expect-error - no implicit this
361
- const res = yield this.bitgo.get(this.url()).query(query).result();
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
- .asCallback(callback);
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 Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);
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 (!_.isNumber(params.duration)) {
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 Bluebird.resolve(this.bitgo.post(this.url('/freeze')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.del(this.url()).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.get(url).result('labels')).nodeify(callback);
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 Bluebird.resolve(this.bitgo.put(url).send({ label: params.label }).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.put(url).send({ label: params.label }).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.del(url).result()).nodeify(callback);
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 = _.cloneDeep(params);
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).nodeify(callback);
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 (!_.isUndefined(params.limit) && !_.isInteger(params.limit)) {
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 (!_.isUndefined(params.skip) && !_.isInteger(params.skip)) {
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 (!_.isUndefined(params.minConfirms) && !_.isInteger(params.minConfirms)) {
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 (!_.isUndefined(params.target) && !_.isNumber(params.target)) {
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 (!_.isUndefined(params.instant) && !_.isBoolean(params.instant)) {
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 (!_.isUndefined(params.segwit) && !_.isBoolean(params.segwit)) {
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 (!_.isUndefined(params.targetWalletUnspents) && !_.isInteger(params.targetWalletUnspents)) {
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 (!_.isUndefined(params.minSize) && !_.isNumber(params.minSize)) {
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 (!_.isUndefined(params.instant) && !_.isUndefined(params.minConfirms)) {
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 (!_.isUndefined(params.targetWalletUnspents) && _.isUndefined(params.target)) {
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 (!_.isUndefined(params.allowLedgerSegwit) && !_.isBoolean(params.allowLedgerSegwit)) {
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 = _.cloneDeep(params);
564
- if (!_.isUndefined(params.target)) {
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 (!_.isUndefined(params.segwit)) {
620
+ if (!lodash_1.default.isUndefined(params.segwit)) {
571
621
  queryObject.segwit = params.segwit;
572
622
  }
573
- if (!_.isUndefined(params.allowLedgerSegwit)) {
623
+ if (!lodash_1.default.isUndefined(params.allowLedgerSegwit)) {
574
624
  queryObject.allowLedgerSegwit = params.allowLedgerSegwit;
575
625
  }
576
- return Bluebird.resolve(this.bitgo.get(this.url('/unspents')).query(queryObject).result()).nodeify(callback);
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 (!_.isInteger(params.limit)) {
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 (!_.isInteger(params.skip)) {
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 (!_.isInteger(params.minHeight)) {
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 (!_.isInteger(params.maxHeight) || params.maxHeight < 0) {
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 (!_.isInteger(params.minConfirms) || params.minConfirms < 0) {
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 (!_.isUndefined(params.compact)) {
618
- if (!_.isBoolean(params.compact)) {
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 Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);
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 && !_.isNumber(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 && !_.isNumber(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 Bluebird.delay(params.delay).then(function () {
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 Bluebird.resolve(this.bitgo.get(url).result()).nodeify(callback);
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 co(function* () {
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
- const tryKeyChain = co(function* (index) {
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 = yield self.bitgo.keychains().get(params);
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
- .asCallback(callback);
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 = _.extend({}, params);
784
+ params = lodash_1.default.extend({}, params);
732
785
  sdk_core_1.common.validateParams(params, [], [], callback);
733
- if ((!_.isNumber(params.fee) && !_.isUndefined(params.fee)) ||
734
- (!_.isNumber(params.feeRate) && !_.isUndefined(params.feeRate)) ||
735
- (!_.isNumber(params.minConfirms) && !_.isUndefined(params.minConfirms)) ||
736
- (!_.isBoolean(params.forceChangeAtEnd) && !_.isUndefined(params.forceChangeAtEnd)) ||
737
- (!_.isString(params.changeAddress) && !_.isUndefined(params.changeAddress)) ||
738
- (!_.isBoolean(params.validate) && !_.isUndefined(params.validate)) ||
739
- (!_.isBoolean(params.instant) && !_.isUndefined(params.instant))) {
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 (!_.isObject(params.recipients)) {
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).nodeify(callback);
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 = _.extend({}, 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 ((!_.isObject(params.keychain) || !params.keychain.xprv) && !_.isString(params.signingKey)) {
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
- .nodeify(callback);
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 Bluebird.resolve(this.bitgo.post(this.bitgo.url('/tx/send')).send(params).result())
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 _.extend(body, { status: 'pendingApproval' });
857
+ return lodash_1.default.extend(body, { status: 'pendingApproval' });
799
858
  }
800
859
  if (body.otp) {
801
- return _.extend(body, { status: 'otp' });
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
- .nodeify(callback);
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 && !_.isEmpty(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 Bluebird.resolve(this.bitgo.post(this.url('/share')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.post(this.url('/invite')).send(options).result()).nodeify(callback);
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 = _.find(outgoing, function (out) {
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
- .nodeify(callback);
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 (!_.isNumber(params.amount)) {
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).nodeify(callback);
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 (!_.isObject(params.recipients)) {
1005
+ if (!lodash_1.default.isObject(params.recipients)) {
941
1006
  throw new Error('expecting recipients object');
942
1007
  }
943
- if (params.fee && !_.isNumber(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 && !_.isNumber(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 && !_.isBoolean(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 = _.pick(params, acceptedBuildParams);
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 = _.sumBy(unspentsUsed, 'value');
990
- const outputsSum = _.sumBy(tx.outs, 'value');
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 Bluebird.resolve(retPromise).nodeify(callback);
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 = _.ceil((parentVSize * feeRate) / 1000) - parentFee;
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 _.ceil(childFee + additionalParentFee);
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 co(function* coFindAdditionalUnspents() {
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 = (yield this.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
- _.forEach(unspents, (unspent) => {
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
- }).call(this);
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 '${_.truncate(result.text, { length: 100 })}' instead.`);
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 _.toNumber(outputOrUnspent.chainPath.split('/')[1]);
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 co(function* coAccelerateTransaction() {
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 (!_.isFinite(params.feeRate) || params.feeRate <= 0) {
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 (!_.isInteger(params.maxAdditionalUnspents) || params.maxAdditionalUnspents <= 0) {
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 = yield this.getTransaction({ id: params.transactionID });
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 = _.filter(parentTx.outputs, (output) => output.isMine);
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 = _.sortBy(walletOutputs, effectiveValue);
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 = yield this.unspents({
1329
+ const unspentsResult = await this.unspents({
1265
1330
  minSize: outputToUse.value,
1266
1331
  maxSize: outputToUse.value,
1267
1332
  });
1268
- parentUnspentToUse = _.find(unspentsResult, (unspent) => {
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 = yield getParentTxHex({ parentTxId: params.transactionID });
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 } = yield findAdditionalUnspents({
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 = _.sumBy(unspentsToUse, (unspent) => unspent.value) - childFee;
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 = yield this.createAddress({ chain: changeChain });
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 = yield this.createAndSignTransaction({
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
- .asCallback(callback);
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 co(function* () {
1457
+ return async function () {
1392
1458
  params = params || {};
1393
1459
  sdk_core_1.common.validateParams(params, [], [], callback);
1394
- if (!_.isObject(params.recipients)) {
1460
+ if (!lodash_1.default.isObject(params.recipients)) {
1395
1461
  throw new Error('expecting recipients object');
1396
1462
  }
1397
- if (params.fee && !_.isNumber(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 && !_.isNumber(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 && !_.isNumber(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 && !_.isBoolean(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 = (yield this.createTransaction(params));
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 = yield this.getAndPrepareSigningKeychain(params);
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
- yield this.refresh({ gpk: true });
1495
+ await this.refresh({ gpk: true });
1430
1496
  // @ts-expect-error - no implicit this
1431
- const safeUserKey = _.get(this.wallet, 'private.userPrivKey');
1432
- if (_.isString(safeUserKey) && _.isString(params.walletPassphrase)) {
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 = yield this.signTransaction(transaction);
1443
- return _.extend(result, {
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
- .asCallback(callback);
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 (_.isObject(params.keychain) && params.keychain.xprv) {
1475
- return Bluebird.resolve(params.keychain);
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 = _.map(self.keychains, 'xpub');
1507
- if (!_.includes(walletXpubs, xpub)) {
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 Bluebird.coroutine(function* () {
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 (!_.isNumber(target) || target < 2 || target % 1 !== 0) {
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 (!_.isNumber(minConfirms) || minConfirms < 0) {
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
- _.fill(almostEqualParts, partSize + 1, 0, remainder);
1640
+ lodash_1.default.fill(almostEqualParts, partSize + 1, 0, remainder);
1571
1641
  // fill the remaining parts with the value partSize
1572
- _.fill(almostEqualParts, partSize, remainder);
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 (_(almostEqualParts).sum() !== total || _(almostEqualParts).size() !== partCount) {
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 = (yield self.unspents({ minConfirms: minConfirms }));
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 = _(allUnspents).map('value').sum();
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 = _.extend({}, params);
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 = _.range(target).map(() => self.createAddress({ chain: self.getChangeChain(params), validate: validate }));
1602
- const newAddresses = yield Bluebird.all(newAddressPromises);
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 = _.zipObject(_.map(newAddresses, 'address'), splitAmounts);
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
- yield self.sendMany(txParams);
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 = _.omit(txParams, ['walletPassphrase', 'xprv']);
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 = _.zipObject(_.map(newAddresses, 'address'), remainingSplitAmounts);
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 = yield self.sendMany(txParams);
1715
+ fanoutTx = await self.sendMany(txParams);
1646
1716
  }
1647
1717
  catch (e) {
1648
- const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);
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 Bluebird.resolve(fanoutTx).asCallback(callback);
1653
- })().asCallback(callback);
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 (!_.isNumber(target) || target < 1 || target % 1 !== 0) {
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 (!_.isNumber(minConfirms) || minConfirms < 0) {
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 (!_.isNumber(target) || target < 1 || target % 1 !== 0) {
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 && !_.isNumber(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 && !_.isNumber(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 && (!_.isNumber(maxIterationCount) || maxIterationCount < 1)) ||
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 (!_.isNumber(minConfirms) || minConfirms < 0) {
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
- const runNextConsolidation = co(function* () {
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 = (yield self.unspents(queryParams));
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 = (yield self.createAddress({ chain: changeChain, validate: validate }));
1813
- const txParams = _.extend({}, params);
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 = _(currentChunk).map('value').sum(); // before fees
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
- yield self.sendMany(txParams);
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 = _.omit(txParams, ['walletPassphrase', 'xprv']);
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 = yield self.sendMany(txParams);
1931
+ sentTx = await self.sendMany(txParams);
1860
1932
  }
1861
1933
  catch (e) {
1862
- const debugParams = _.omit(txParams, ['walletPassphrase', 'xprv']);
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 (_.isFunction(params.progressCallback)) {
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
- yield Bluebird.delay(1000);
1883
- consolidationTransactions.push(...(yield runNextConsolidation()));
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(this, target)
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
- .nodeify(callback);
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 && !_.isBoolean(params.reshare)) {
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 && !_.isBoolean(params.skipKeychain)) {
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 && !_.isBoolean(params.disableEmail)) {
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
- .nodeify(callback);
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 Bluebird.resolve(this.bitgo
2039
+ return Promise.resolve(this.bitgo
1966
2040
  .del(this.url('/user/' + params.user))
1967
2041
  .send()
1968
- .result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.get(this.url('/policy')).send().result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.get(this.url('/policy/status')).send().result()).nodeify(callback);
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 (!_.isObject(params.condition)) {
2063
+ if (!lodash_1.default.isObject(params.condition)) {
1984
2064
  throw new Error('missing parameter: conditions object');
1985
2065
  }
1986
- if (!_.isObject(params.action)) {
2066
+ if (!lodash_1.default.isObject(params.action)) {
1987
2067
  throw new Error('missing parameter: action object');
1988
2068
  }
1989
- return Bluebird.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.get(this.url('/webhooks')).send().result()).nodeify(callback);
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 = _.pick(params, ['txHash', 'pendingApprovalId']);
2107
+ const filteredParams = lodash_1.default.pick(params, ['txHash', 'pendingApprovalId']);
2022
2108
  const webhookId = params.webhookId;
2023
- return Bluebird.resolve(this.bitgo
2109
+ return Promise.resolve(this.bitgo
2024
2110
  .post(this.url('/webhooks/' + webhookId + '/simulate'))
2025
2111
  .send(filteredParams)
2026
- .result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.post(this.url('/webhooks')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.del(this.url('/webhooks')).send(params).result()).nodeify(callback);
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 && !_.isObject(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 && !_.isNumber(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 = _.extend({}, params);
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 Bluebird.resolve(this.bitgo.put(this.url('/policy/rule')).send(params).result()).nodeify(callback);
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 Bluebird.resolve(this.bitgo.del(this.url('/policy/rule')).send(params).result()).nodeify(callback);
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 (!_.isNumber(params.amount)) {
2182
+ if (!lodash_1.default.isNumber(params.amount)) {
2087
2183
  throw new Error('invalid amount argument');
2088
2184
  }
2089
- if (params.instant && !_.isBoolean(params.instant)) {
2185
+ if (params.instant && !lodash_1.default.isBoolean(params.instant)) {
2090
2186
  throw new Error('invalid instant argument');
2091
2187
  }
2092
- return Bluebird.resolve(this.bitgo.get(this.url('/billing/fee')).query(params).result()).nodeify(callback);
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"]}