@bitgo-beta/sdk-coin-trx 1.2.3-alpha.5 → 1.2.3-alpha.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/src/trx.js CHANGED
@@ -70,6 +70,10 @@ class Trx extends sdk_core_1.BaseCoin {
70
70
  valuelessTransferAllowed() {
71
71
  return true;
72
72
  }
73
+ /** @inheritDoc */
74
+ allowsAccountConsolidations() {
75
+ return true;
76
+ }
73
77
  /**
74
78
  * Checks if this is a valid base58 or hex address
75
79
  * @param address
@@ -130,6 +134,17 @@ class Trx extends sdk_core_1.BaseCoin {
130
134
  async verifyTransaction(params) {
131
135
  return true;
132
136
  }
137
+ /**
138
+ * Derive a user key using the chain path of the address
139
+ * @param key
140
+ * @param path
141
+ * @returns {string} derived private key
142
+ */
143
+ deriveKeyWithPath({ key, path }) {
144
+ const keychain = utxo_lib_1.bip32.fromBase58(key);
145
+ const derivedKeyNode = keychain.derivePath(path);
146
+ return derivedKeyNode.toBase58();
147
+ }
133
148
  /**
134
149
  * Assemble keychain and half-sign prebuilt transaction
135
150
  *
@@ -140,8 +155,18 @@ class Trx extends sdk_core_1.BaseCoin {
140
155
  * @returns Bluebird<SignedTransaction>
141
156
  */
142
157
  async signTransaction(params) {
158
+ var _a, _b;
143
159
  const txBuilder = builder_1.getBuilder(this.getChain()).from(params.txPrebuild.txHex);
144
- txBuilder.sign({ key: params.prv });
160
+ let key;
161
+ const { chain, index } = (_b = (_a = params.txPrebuild) === null || _a === void 0 ? void 0 : _a.addressInfo) !== null && _b !== void 0 ? _b : { chain: 0, index: 0 };
162
+ if (chain === 0 && index === 0) {
163
+ key = params.prv;
164
+ }
165
+ else {
166
+ const derivationPath = `0/0/${chain}/${index}`;
167
+ key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });
168
+ }
169
+ txBuilder.sign({ key });
145
170
  const transaction = await txBuilder.build();
146
171
  const response = {
147
172
  txHex: JSON.stringify(transaction.toJson()),
@@ -267,16 +292,43 @@ class Trx extends sdk_core_1.BaseCoin {
267
292
  // unfortunately, it doesn't look like most TRON nodes return valid json as body
268
293
  return JSON.parse(response.text);
269
294
  }
295
+ /**
296
+ * Make a query to Trongrid for information such as balance, token balance, solidity calls
297
+ * @param query {Object} key-value pairs of parameters to append after /api
298
+ * @returns {Object} response from Trongrid
299
+ */
300
+ async recoveryGet(query) {
301
+ let nodeUri = '';
302
+ switch (query.node) {
303
+ case NodeTypes.Full:
304
+ nodeUri = sdk_core_1.common.Environments[this.bitgo.getEnv()].tronNodes.full;
305
+ break;
306
+ case NodeTypes.Solidity:
307
+ nodeUri = sdk_core_1.common.Environments[this.bitgo.getEnv()].tronNodes.solidity;
308
+ break;
309
+ default:
310
+ throw new Error('node type not found');
311
+ }
312
+ const response = await request
313
+ .get(nodeUri + query.path)
314
+ .type('json')
315
+ .send(query.jsonObj);
316
+ if (!response.ok) {
317
+ throw new Error('could not reach Tron node');
318
+ }
319
+ // unfortunately, it doesn't look like most TRON nodes return valid json as body
320
+ return JSON.parse(response.text);
321
+ }
270
322
  /**
271
323
  * Query our explorer for the balance of an address
272
324
  * @param address {String} the address encoded in hex
273
325
  * @returns {BigNumber} address balance
274
326
  */
275
- async getAccountFromNode(address) {
276
- return await this.recoveryPost({
277
- path: '/walletsolidity/getaccount',
278
- jsonObj: { address },
279
- node: NodeTypes.Solidity,
327
+ async getAccountBalancesFromNode(address) {
328
+ return await this.recoveryGet({
329
+ path: '/v1/accounts/' + address,
330
+ jsonObj: {},
331
+ node: NodeTypes.Full,
280
332
  });
281
333
  }
282
334
  /**
@@ -297,6 +349,29 @@ class Trx extends sdk_core_1.BaseCoin {
297
349
  node: NodeTypes.Full,
298
350
  });
299
351
  }
352
+ /**
353
+ * Retrieves our build transaction from a node.
354
+ * @param toAddr hex-encoded address
355
+ * @param fromAddr hex-encoded address
356
+ * @param amount
357
+ */
358
+ async getTriggerSmartContractTransaction(toAddr, fromAddr, amount, contractAddr) {
359
+ const functionSelector = 'transfer(address,uint256)';
360
+ const types = ['address', 'uint256'];
361
+ const values = [toAddr, amount];
362
+ const parameter = lib_1.Utils.encodeDataParams(types, values, '');
363
+ return await this.recoveryPost({
364
+ path: '/wallet/triggersmartcontract',
365
+ jsonObj: {
366
+ owner_address: fromAddr,
367
+ contract_address: contractAddr,
368
+ function_selector: functionSelector,
369
+ parameter: parameter,
370
+ fee_limit: 100000000,
371
+ },
372
+ node: NodeTypes.Full,
373
+ });
374
+ }
300
375
  /**
301
376
  * Throws an error if any keys in the ownerKeys collection don't match the keys array we pass
302
377
  * @param ownerKeys
@@ -334,27 +409,94 @@ class Trx extends sdk_core_1.BaseCoin {
334
409
  const bitgoHexAddr = this.pubToHexAddress(this.xpubToUncompressedPub(params.bitgoKey));
335
410
  const recoveryAddressHex = lib_1.Utils.getHexAddressFromBase58Address(params.recoveryDestination);
336
411
  // call the node to get our account balance
337
- const account = await this.getAccountFromNode(bitgoHexAddr);
338
- const recoveryAmount = account.balance;
412
+ const account = await this.getAccountBalancesFromNode(lib_1.Utils.getBase58AddressFromHex(bitgoHexAddr));
413
+ const recoveryAmount = account.data[0].balance;
339
414
  const userXPub = keys[0].neutered().toBase58();
340
415
  const userXPrv = keys[0].toBase58();
341
416
  const backupXPub = keys[1].neutered().toBase58();
417
+ // first construct token txns
418
+ const tokenTxns = [];
419
+ for (const token of account.data[0].trc20) {
420
+ // mainnet tokens
421
+ if (token.TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8) {
422
+ const amount = token.TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8;
423
+ const contractAddr = lib_1.Utils.getHexAddressFromBase58Address('TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8');
424
+ tokenTxns.push((await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))
425
+ .transaction);
426
+ }
427
+ else if (token.TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t) {
428
+ const amount = token.TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t;
429
+ const contractAddr = lib_1.Utils.getHexAddressFromBase58Address('TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t');
430
+ tokenTxns.push((await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))
431
+ .transaction);
432
+ // testnet tokens
433
+ }
434
+ else if (token.TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id) {
435
+ const amount = token.TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id;
436
+ const contractAddr = lib_1.Utils.getHexAddressFromBase58Address('TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id');
437
+ tokenTxns.push((await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))
438
+ .transaction);
439
+ }
440
+ else if (token.TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs) {
441
+ const amount = token.TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs;
442
+ const contractAddr = lib_1.Utils.getHexAddressFromBase58Address('TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs');
443
+ tokenTxns.push((await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))
444
+ .transaction);
445
+ }
446
+ }
342
447
  // construct the tx -
343
448
  // there's an assumption here being made about fees: for a wallet that hasn't been used in awhile, the implication is
344
449
  // it has maximum bandwidth. thus, a recovery should cost the minimum amount (1e6 sun or 1 Tron)
345
450
  if (exports.MINIMUM_TRON_MSIG_TRANSACTION_FEE > recoveryAmount) {
346
451
  throw new Error('Amount of funds to recover wouldnt be able to fund a send');
347
452
  }
348
- const recoveryAmountMinusFees = recoveryAmount - exports.MINIMUM_TRON_MSIG_TRANSACTION_FEE;
349
- const buildTx = await this.getBuildTransaction(recoveryAddressHex, bitgoHexAddr, recoveryAmountMinusFees);
350
453
  const keyHexAddresses = [
351
454
  this.pubToHexAddress(this.xpubToUncompressedPub(userXPub)),
352
455
  this.pubToHexAddress(this.xpubToUncompressedPub(backupXPub)),
353
456
  bitgoHexAddr,
354
457
  ];
355
458
  // run checks to ensure this is a valid tx - permissions match our signer keys
356
- this.checkPermissions(account.owner_permission.keys, keyHexAddresses);
357
- this.checkPermissions(account.active_permission[0].keys, keyHexAddresses);
459
+ const ownerKeys = [];
460
+ for (const key of account.data[0].owner_permission.keys) {
461
+ const address = lib_1.Utils.getHexAddressFromBase58Address(key.address);
462
+ const weight = key.weight;
463
+ ownerKeys.push({ address, weight });
464
+ }
465
+ const activePermissionKeys = [];
466
+ for (const key of account.data[0].active_permission[0].keys) {
467
+ const address = lib_1.Utils.getHexAddressFromBase58Address(key.address);
468
+ const weight = key.weight;
469
+ activePermissionKeys.push({ address, weight });
470
+ }
471
+ this.checkPermissions(ownerKeys, keyHexAddresses);
472
+ this.checkPermissions(activePermissionKeys, keyHexAddresses);
473
+ // build and sign token txns
474
+ const finalTokenTxs = [];
475
+ for (const tokenTxn of tokenTxns) {
476
+ const txBuilder = builder_1.getBuilder(this.getChain()).from(tokenTxn);
477
+ // this tx should be enough to drop into a node
478
+ if (isUnsignedSweep) {
479
+ finalTokenTxs.push((await txBuilder.build()).toJson());
480
+ continue;
481
+ }
482
+ const userPrv = this.xprvToCompressedPrv(userXPrv);
483
+ txBuilder.sign({ key: userPrv });
484
+ // krs recoveries don't get signed
485
+ if (!isKrsRecovery) {
486
+ const backupXPrv = keys[1].toBase58();
487
+ const backupPrv = this.xprvToCompressedPrv(backupXPrv);
488
+ txBuilder.sign({ key: backupPrv });
489
+ }
490
+ finalTokenTxs.push((await txBuilder.build()).toJson());
491
+ }
492
+ // tokens must be recovered before the native asset, so that there is sufficient of the native asset to cover fees
493
+ if (finalTokenTxs.length > 0) {
494
+ return {
495
+ tokenTxs: finalTokenTxs,
496
+ };
497
+ }
498
+ const recoveryAmountMinusFees = recoveryAmount - exports.MINIMUM_TRON_MSIG_TRANSACTION_FEE;
499
+ const buildTx = await this.getBuildTransaction(recoveryAddressHex, bitgoHexAddr, recoveryAmountMinusFees);
358
500
  // construct our tx
359
501
  const txBuilder = builder_1.getBuilder(this.getChain()).from(buildTx);
360
502
  // this tx should be enough to drop into a node
@@ -418,4 +560,4 @@ class Trx extends sdk_core_1.BaseCoin {
418
560
  }
419
561
  }
420
562
  exports.Trx = Trx;
421
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trx.js","sourceRoot":"","sources":["../../src/trx.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,qDAAuC;AACvC,mCAAqC;AAErC,mDAAuD;AACvD,oDAAsC;AACtC,mDAmB8B;AAC9B,+BAAyD;AACzD,2CAA2C;AAE9B,QAAA,iCAAiC,GAAG,GAAG,CAAC;AA8CrD,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,yCAAI,CAAA;IACJ,iDAAQ,CAAA;AACV,CAAC,EAHW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAGpB;AAcD,MAAa,GAAI,SAAQ,mBAAQ;IAG/B,YAAY,KAAgB,EAAE,WAAuC;QACnE,KAAK,CAAC,KAAK,CAAC,CAAC;QAEb,IAAI,CAAC,WAAW,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;SACvE;QAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAChC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC;IACpC,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,kBAAkB;IAClB,sBAAsB;QACpB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,KAAgB,EAAE,WAAuC;QAC7E,OAAO,IAAI,GAAG,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,wBAAwB;QACtB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,cAAc,CAAC,OAAe;QAC5B,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,KAAK,CAAC;SACd;QACD,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,WAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IAC3E,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,OAAe;QAC/B,OAAO,OAAO,CAAC,MAAM,KAAK,EAAE,IAAI,wBAAwB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzE,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,IAAa;QAC3B,4DAA4D;QAC5D,IAAI,CAAC,IAAI,EAAE;YACT,gHAAgH;YAChH,oGAAoG;YACpG,IAAI,GAAG,oBAAW,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;SAC7B;QACD,MAAM,EAAE,GAAG,gBAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAChC,OAAO;YACL,GAAG,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE;YAC7B,GAAG,EAAE,EAAE,CAAC,QAAQ,EAAE;SACnB,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,IAAI;YACF,OAAO,gBAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,CAAC;SAC5C;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE;YACzB,6EAA6E;YAC7E,OAAO,IAAI,CAAC;SACb;QACD,OAAO,IAAI,MAAM,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,MAA+B;QACpD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,MAA4B;QAChD,MAAM,IAAI,oCAAyB,EAAE,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,MAAgC;QACtD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,eAAe,CAAC,MAAkC;QACtD,MAAM,SAAS,GAAG,oBAAU,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAC5E,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC;QACpC,MAAM,WAAW,GAAG,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QAC5C,MAAM,QAAQ,GAAG;YACf,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SAC5C,CAAC;QACF,IAAI,WAAW,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE;YAC9C,OAAO,QAAQ,CAAC;SACjB;QACD,0BAA0B;QAC1B,OAAO;YACL,UAAU,EAAE,QAAQ;SACrB,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,GAAW;QACrB,IAAI;YACF,OAAO,CAAC,gBAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,CAAC;SAC5C;QAAC,MAAM;YACN,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,OAAwB;QAClC,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;YAC/B,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC7C;aAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YACnC,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAChC;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;SAC3D;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,GAAY,EAAE,OAAwB;;QACtD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAEzC,IAAI,GAAG,GAAuB,GAAG,CAAC,GAAG,CAAC;QACtC,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE;YACzB,GAAG,GAAG,MAAA,gBAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,UAAU,0CAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;SACzD;QAED,IAAI,CAAC,GAAG,EAAE;YACR,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;SAClC;QACD,IAAI,GAAG,GAAG,WAAK,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAE9C,0BAA0B;QAC1B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAE7B,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;;OAGG;IACH,qBAAqB,CAAC,IAAY;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;SACjC;QAED,MAAM,SAAS,GAAG,gBAAK,CAAC,UAAU,CAAC,IAAI,EAAE,mBAAQ,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;QACrE,OAAO,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,SAAS,EAAE,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACpG,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,sBAAsB,CAAC,WAAgB;QAC3C,IAAI,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,WAAW,CAAC,QAAQ,EAAE;YAC1D,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAC;SAC3D;IACH,CAAC;IAED,eAAe,CAAC,GAAW;QACzB,MAAM,aAAa,GAAG,WAAK,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG,WAAK,CAAC,uBAAuB,CAAC,aAAa,CAAC,CAAC;QAChE,OAAO,WAAK,CAAC,0BAA0B,CAAC,UAAU,CAAC,CAAC;IACtD,CAAC;IAED,mBAAmB,CAAC,IAAY;QAC9B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;SACjC;QAED,MAAM,MAAM,GAAG,gBAAK,CAAC,UAAU,CAAC,IAAI,EAAE,mBAAQ,CAAC,OAAO,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YACtB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;SAClC;QACD,OAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,YAAY,CAAC,KAAsD;QAC/E,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,QAAQ,KAAK,CAAC,IAAI,EAAE;YAClB,KAAK,SAAS,CAAC,IAAI;gBACjB,OAAO,GAAG,iBAAM,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC;gBAClE,MAAM;YACR,KAAK,SAAS,CAAC,QAAQ;gBACrB,OAAO,GAAG,iBAAM,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC;gBACtE,MAAM;YACR;gBACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;SAC1C;QAED,MAAM,QAAQ,GAAG,MAAM,OAAO;aAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC;aAC1B,IAAI,CAAC,MAAM,CAAC;aACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEvB,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;SAC9C;QAED,gFAAgF;QAChF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACK,KAAK,CAAC,kBAAkB,CAAC,OAAe;QAC9C,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC;YAC7B,IAAI,EAAE,4BAA4B;YAClC,OAAO,EAAE,EAAE,OAAO,EAAE;YACpB,IAAI,EAAE,SAAS,CAAC,QAAQ;SACzB,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,mBAAmB,CAC/B,MAAc,EACd,QAAgB,EAChB,MAAc;QAEd,8DAA8D;QAC9D,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC;YAC7B,IAAI,EAAE,2BAA2B;YACjC,OAAO,EAAE;gBACP,UAAU,EAAE,MAAM;gBAClB,aAAa,EAAE,QAAQ;gBACvB,MAAM;aACP;YACD,IAAI,EAAE,SAAS,CAAC,IAAI;SACrB,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,SAAgD,EAAE,IAAc;QAC/E,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QAExC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACpB,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YACzC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,eAAe,MAAM,uBAAuB,CAAC,CAAC;aAC/D;YAED,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;gBACpB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;aACnE;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,OAAO,CAAC,MAAuB;QACnC,MAAM,aAAa,GAAG,2BAAgB,CAAC,MAAM,CAAC,CAAC;QAC/C,MAAM,eAAe,GAAG,6BAAkB,CAAC,MAAM,CAAC,CAAC;QAEnD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,mBAAmB,CAAC,EAAE;YACpD,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;SACjD;QAED,4BAA4B;QAC5B,MAAM,IAAI,GAAG,uBAAY,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,CAAC;QAE3E,qDAAqD;QACrD,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;QACvF,MAAM,kBAAkB,GAAG,WAAK,CAAC,8BAA8B,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAE5F,2CAA2C;QAC3C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;QAC5D,MAAM,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC;QAEvC,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACpC,MAAM,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC;QAEjD,qBAAqB;QACrB,qHAAqH;QACrH,gGAAgG;QAChG,IAAI,yCAAiC,GAAG,cAAc,EAAE;YACtD,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;SAC9E;QACD,MAAM,uBAAuB,GAAG,cAAc,GAAG,yCAAiC,CAAC;QACnF,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,YAAY,EAAE,uBAAuB,CAAC,CAAC;QAE1G,MAAM,eAAe,GAAG;YACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;YAC1D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;YAC5D,YAAY;SACb,CAAC;QAEF,8EAA8E;QAC9E,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;QACtE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;QAE1E,mBAAmB;QACnB,MAAM,SAAS,GAAI,oBAAU,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEhF,+CAA+C;QAC/C,IAAI,eAAe,EAAE;YACnB,OAAO;gBACL,EAAE,EAAE,CAAC,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;gBACtC,cAAc,EAAE,uBAAuB;aACxC,CAAC;SACH;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QAEnD,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC;QAEjC,kCAAkC;QAClC,IAAI,CAAC,aAAa,EAAE;YAClB,MAAM,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;YACtC,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;YAEvD,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;SACpC;QAED,OAAO;YACL,EAAE,EAAE,CAAC,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;YACtC,cAAc,EAAE,uBAAuB;SACxC,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,kBAAkB,CAAC,MAAiC;QACxD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAC7E,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;SAClD;QACD,MAAM,SAAS,GAAG,oBAAU,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1D,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,OAAO,GAAG;YACd;gBACE,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;gBACtC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,oDAAoD;aACrF;SACF,CAAC;QAEF,MAAM,YAAY,GAAG;YACnB,IAAI;YACJ,cAAc;YACd,cAAc;YACd,SAAS;YACT,eAAe;YACf,KAAK;YACL,WAAW;YACX,YAAY;SACb,CAAC;QAEF,OAAO;YACL,YAAY;YACZ,EAAE,EAAE,EAAE,CAAC,EAAE;YACT,OAAO;YACP,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM;YAC/B,aAAa,EAAE,EAAE;YACjB,YAAY,EAAE,GAAG;YACjB,GAAG,EAAE,MAAM,CAAC,OAAO;YACnB,SAAS,EAAE,EAAE,CAAC,SAAS;YACvB,UAAU,EAAE,EAAE,CAAC,OAAO;SACvB,CAAC;IACJ,CAAC;CACF;AAxbD,kBAwbC","sourcesContent":["/**\n * @prettier\n */\nimport * as secp256k1 from 'secp256k1';\nimport { randomBytes } from 'crypto';\nimport { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';\nimport { bip32, networks } from '@bitgo-beta/utxo-lib';\nimport * as request from 'superagent';\nimport {\n  BaseCoin,\n  BitGoBase,\n  common,\n  getBip32Keys,\n  getIsKrsRecovery,\n  getIsUnsignedSweep,\n  KeyPair,\n  MethodNotImplementedError,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  TransactionExplanation,\n  TransactionFee,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionRecipient as Recipient,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { Interface, Utils, WrappedBuilder } from './lib';\nimport { getBuilder } from './lib/builder';\n\nexport const MINIMUM_TRON_MSIG_TRANSACTION_FEE = 1e6;\n\nexport interface TronSignTransactionOptions extends SignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TxInfo {\n  recipients: Recipient[];\n  from: string;\n  txid: string;\n}\n\nexport interface TronTransactionExplanation extends TransactionExplanation {\n  expiration: number;\n  timestamp: number;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n  txInfo: TxInfo;\n  feeInfo: TransactionFee;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string; // txHex is poorly named here; it is just a wrapped JSON object\n  halfSigned?: {\n    txHex: string; // txHex is poorly named here; it is just a wrapped JSON object\n  };\n  feeInfo: TransactionFee;\n}\n\nexport interface RecoveryOptions {\n  userKey: string; // Box A\n  backupKey: string; // Box B\n  bitgoKey: string; // Box C - this is bitgo's xpub and will be used to derive their root address\n  recoveryDestination: string; // base58 address\n  krsProvider?: string;\n  walletPassphrase?: string;\n}\n\nexport interface RecoveryTransaction {\n  tx: TransactionPrebuild;\n  recoveryAmount: number;\n}\n\nexport enum NodeTypes {\n  Full,\n  Solidity,\n}\n\n/**\n * This structure is not a complete model of the AccountResponse from a node.\n */\nexport interface AccountResponse {\n  address: string;\n  balance: number;\n  owner_permission: {\n    keys: [Interface.PermissionKey];\n  };\n  active_permission: [{ keys: [Interface.PermissionKey] }];\n}\n\nexport class Trx extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** @inheritdoc */\n  transactionDataAllowed() {\n    return true;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Trx(bitgo, staticsCoin);\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return true;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    if (!address) {\n      return false;\n    }\n    return this.isValidHexAddress(address) || Utils.isBase58Address(address);\n  }\n\n  /**\n   * Checks if this is a valid hex address\n   * @param address hex address\n   */\n  isValidHexAddress(address: string): boolean {\n    return address.length === 42 && /^(0x)?([0-9a-f]{2})+$/i.test(address);\n  }\n\n  /**\n   * Generate ed25519 key pair\n   *\n   * @param seed\n   * @returns {Object} object with generated pub, prv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    // TODO: move this and address creation logic to account-lib\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256 bit chain code, both of which must be\n      // random. 512 bits is therefore the maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const hd = bip32.fromSeed(seed);\n    return {\n      pub: hd.neutered().toBase58(),\n      prv: hd.toBase58(),\n    };\n  }\n\n  isValidXpub(xpub: string): boolean {\n    try {\n      return bip32.fromBase58(xpub).isNeutered();\n    } catch (e) {\n      return false;\n    }\n  }\n\n  isValidPub(pub: string): boolean {\n    if (this.isValidXpub(pub)) {\n      // xpubs can be converted into regular pubs, so technically it is a valid pub\n      return true;\n    }\n    return new RegExp('^04[a-zA-Z0-9]{128}$').test(pub);\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new MethodNotImplementedError();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    return true;\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @param params.wallet.addressVersion {String} this is the version of the Algorand multisig address generation format\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: TronSignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = getBuilder(this.getChain()).from(params.txPrebuild.txHex);\n    txBuilder.sign({ key: params.prv });\n    const transaction = await txBuilder.build();\n    const response = {\n      txHex: JSON.stringify(transaction.toJson()),\n    };\n    if (transaction.toJson().signature.length >= 2) {\n      return response;\n    }\n    // Half signed transaction\n    return {\n      halfSigned: response,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether input is valid seed for the coin\n   *\n   * @param prv - the prv to be checked\n   */\n  isValidXprv(prv: string): boolean {\n    try {\n      return !bip32.fromBase58(prv).isNeutered();\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Convert a message to string in hexadecimal format.\n   *\n   * @param message {Buffer|String} message to sign\n   * @return the message as a hexadecimal string\n   */\n  toHexString(message: string | Buffer): string {\n    if (typeof message === 'string') {\n      return Buffer.from(message).toString('hex');\n    } else if (Buffer.isBuffer(message)) {\n      return message.toString('hex');\n    } else {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const toSign = this.toHexString(message);\n\n    let prv: string | undefined = key.prv;\n    if (this.isValidXprv(prv)) {\n      prv = bip32.fromBase58(prv).privateKey?.toString('hex');\n    }\n\n    if (!prv) {\n      throw new Error('no privateKey');\n    }\n    let sig = Utils.signString(toSign, prv, true);\n\n    // remove the preceding 0x\n    sig = sig.replace(/^0x/, '');\n\n    return Buffer.from(sig, 'hex');\n  }\n\n  /**\n   * Converts an xpub to a uncompressed pub\n   * @param xpub\n   */\n  xpubToUncompressedPub(xpub: string): string {\n    if (!this.isValidXpub(xpub)) {\n      throw new Error('invalid xpub');\n    }\n\n    const publicKey = bip32.fromBase58(xpub, networks.bitcoin).publicKey;\n    return Buffer.from(secp256k1.publicKeyConvert(publicKey, false /* compressed */)).toString('hex');\n  }\n\n  /**\n   * Modify prebuild before sending it to the server.\n   * @param buildParams The whitelisted parameters for this prebuild\n   */\n  async getExtraPrebuildParams(buildParams: any): Promise<any> {\n    if (buildParams.recipients[0].data && buildParams.feeLimit) {\n      buildParams.recipients[0].feeLimit = buildParams.feeLimit;\n    }\n  }\n\n  pubToHexAddress(pub: string): string {\n    const byteArrayAddr = Utils.getByteArrayFromHexAddress(pub);\n    const rawAddress = Utils.getRawAddressFromPubKey(byteArrayAddr);\n    return Utils.getHexAddressFromByteArray(rawAddress);\n  }\n\n  xprvToCompressedPrv(xprv: string): string {\n    if (!this.isValidXprv(xprv)) {\n      throw new Error('invalid xprv');\n    }\n\n    const hdNode = bip32.fromBase58(xprv, networks.bitcoin);\n    if (!hdNode.privateKey) {\n      throw new Error('no privateKey');\n    }\n    return hdNode.privateKey.toString('hex');\n  }\n\n  /**\n   * Make a query to Trongrid for information such as balance, token balance, solidity calls\n   * @param query {Object} key-value pairs of parameters to append after /api\n   * @returns {Object} response from Trongrid\n   */\n  private async recoveryPost(query: { path: string; jsonObj: any; node: NodeTypes }): Promise<any> {\n    let nodeUri = '';\n    switch (query.node) {\n      case NodeTypes.Full:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.full;\n        break;\n      case NodeTypes.Solidity:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.solidity;\n        break;\n      default:\n        throw new Error('node type not found');\n    }\n\n    const response = await request\n      .post(nodeUri + query.path)\n      .type('json')\n      .send(query.jsonObj);\n\n    if (!response.ok) {\n      throw new Error('could not reach Tron node');\n    }\n\n    // unfortunately, it doesn't look like most TRON nodes return valid json as body\n    return JSON.parse(response.text);\n  }\n\n  /**\n   * Query our explorer for the balance of an address\n   * @param address {String} the address encoded in hex\n   * @returns {BigNumber} address balance\n   */\n  private async getAccountFromNode(address: string): Promise<AccountResponse> {\n    return await this.recoveryPost({\n      path: '/walletsolidity/getaccount',\n      jsonObj: { address },\n      node: NodeTypes.Solidity,\n    });\n  }\n\n  /**\n   * Retrieves our build transaction from a node.\n   * @param toAddr hex-encoded address\n   * @param fromAddr hex-encoded address\n   * @param amount\n   */\n  private async getBuildTransaction(\n    toAddr: string,\n    fromAddr: string,\n    amount: number\n  ): Promise<Interface.TransactionReceipt> {\n    // our addresses should be base58, we'll have to encode to hex\n    return await this.recoveryPost({\n      path: '/wallet/createtransaction',\n      jsonObj: {\n        to_address: toAddr,\n        owner_address: fromAddr,\n        amount,\n      },\n      node: NodeTypes.Full,\n    });\n  }\n\n  /**\n   * Throws an error if any keys in the ownerKeys collection don't match the keys array we pass\n   * @param ownerKeys\n   * @param keys\n   */\n  checkPermissions(ownerKeys: { address: string; weight: number }[], keys: string[]) {\n    keys = keys.map((k) => k.toUpperCase());\n\n    ownerKeys.map((key) => {\n      const hexKey = key.address.toUpperCase();\n      if (!keys.includes(hexKey)) {\n        throw new Error(`pub address ${hexKey} not found in account`);\n      }\n\n      if (key.weight !== 1) {\n        throw new Error('owner permission is invalid for this structure');\n      }\n    });\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  async recover(params: RecoveryOptions): Promise<RecoveryTransaction> {\n    const isKrsRecovery = getIsKrsRecovery(params);\n    const isUnsignedSweep = getIsUnsignedSweep(params);\n\n    if (!this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('Invalid destination address!');\n    }\n\n    // get our user, backup keys\n    const keys = getBip32Keys(this.bitgo, params, { requireBitGoXpub: false });\n\n    // we need to decode our bitgoKey to a base58 address\n    const bitgoHexAddr = this.pubToHexAddress(this.xpubToUncompressedPub(params.bitgoKey));\n    const recoveryAddressHex = Utils.getHexAddressFromBase58Address(params.recoveryDestination);\n\n    // call the node to get our account balance\n    const account = await this.getAccountFromNode(bitgoHexAddr);\n    const recoveryAmount = account.balance;\n\n    const userXPub = keys[0].neutered().toBase58();\n    const userXPrv = keys[0].toBase58();\n    const backupXPub = keys[1].neutered().toBase58();\n\n    // construct the tx -\n    // there's an assumption here being made about fees: for a wallet that hasn't been used in awhile, the implication is\n    // it has maximum bandwidth. thus, a recovery should cost the minimum amount (1e6 sun or 1 Tron)\n    if (MINIMUM_TRON_MSIG_TRANSACTION_FEE > recoveryAmount) {\n      throw new Error('Amount of funds to recover wouldnt be able to fund a send');\n    }\n    const recoveryAmountMinusFees = recoveryAmount - MINIMUM_TRON_MSIG_TRANSACTION_FEE;\n    const buildTx = await this.getBuildTransaction(recoveryAddressHex, bitgoHexAddr, recoveryAmountMinusFees);\n\n    const keyHexAddresses = [\n      this.pubToHexAddress(this.xpubToUncompressedPub(userXPub)),\n      this.pubToHexAddress(this.xpubToUncompressedPub(backupXPub)),\n      bitgoHexAddr,\n    ];\n\n    // run checks to ensure this is a valid tx - permissions match our signer keys\n    this.checkPermissions(account.owner_permission.keys, keyHexAddresses);\n    this.checkPermissions(account.active_permission[0].keys, keyHexAddresses);\n\n    // construct our tx\n    const txBuilder = (getBuilder(this.getChain()) as WrappedBuilder).from(buildTx);\n\n    // this tx should be enough to drop into a node\n    if (isUnsignedSweep) {\n      return {\n        tx: (await txBuilder.build()).toJson(),\n        recoveryAmount: recoveryAmountMinusFees,\n      };\n    }\n\n    const userPrv = this.xprvToCompressedPrv(userXPrv);\n\n    txBuilder.sign({ key: userPrv });\n\n    // krs recoveries don't get signed\n    if (!isKrsRecovery) {\n      const backupXPrv = keys[1].toBase58();\n      const backupPrv = this.xprvToCompressedPrv(backupXPrv);\n\n      txBuilder.sign({ key: backupPrv });\n    }\n\n    return {\n      tx: (await txBuilder.build()).toJson(),\n      recoveryAmount: recoveryAmountMinusFees,\n    };\n  }\n\n  /**\n   * Explain a Tron transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TronTransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = getBuilder(this.getChain()).from(txHex);\n    const tx = await txBuilder.build();\n    const outputs = [\n      {\n        amount: tx.outputs[0].value.toString(),\n        address: tx.outputs[0].address, // Should turn it into a readable format, aka base58\n      },\n    ];\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'fee',\n      'timestamp',\n      'expiration',\n    ];\n\n    return {\n      displayOrder,\n      id: tx.id,\n      outputs,\n      outputAmount: outputs[0].amount,\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo,\n      timestamp: tx.validFrom,\n      expiration: tx.validTo,\n    };\n  }\n}\n"]}
563
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trx.js","sourceRoot":"","sources":["../../src/trx.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as secp256k1 from 'secp256k1';\nimport { randomBytes } from 'crypto';\nimport { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';\nimport { bip32, networks } from '@bitgo-beta/utxo-lib';\nimport * as request from 'superagent';\nimport {\n  BaseCoin,\n  BitGoBase,\n  common,\n  getBip32Keys,\n  getIsKrsRecovery,\n  getIsUnsignedSweep,\n  KeyPair,\n  MethodNotImplementedError,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  TransactionExplanation,\n  TransactionFee,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionRecipient as Recipient,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { Interface, Utils, WrappedBuilder } from './lib';\nimport { getBuilder } from './lib/builder';\nimport { TransactionReceipt } from './lib/iface';\n\nexport const MINIMUM_TRON_MSIG_TRANSACTION_FEE = 1e6;\n\nexport interface TronSignTransactionOptions extends SignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TxInfo {\n  recipients: Recipient[];\n  from: string;\n  txid: string;\n}\n\nexport interface AddressInfo {\n  address: string;\n  chain: number;\n  index: number;\n}\n\nexport interface TronTransactionExplanation extends TransactionExplanation {\n  expiration: number;\n  timestamp: number;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n  txInfo: TxInfo;\n  addressInfo?: AddressInfo;\n  feeInfo: TransactionFee;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string; // txHex is poorly named here; it is just a wrapped JSON object\n  halfSigned?: {\n    txHex: string; // txHex is poorly named here; it is just a wrapped JSON object\n  };\n  feeInfo: TransactionFee;\n}\n\nexport interface RecoveryOptions {\n  userKey: string; // Box A\n  backupKey: string; // Box B\n  bitgoKey: string; // Box C - this is bitgo's xpub and will be used to derive their root address\n  recoveryDestination: string; // base58 address\n  krsProvider?: string;\n  walletPassphrase?: string;\n}\n\nexport interface RecoveryTransaction {\n  tx?: TransactionPrebuild;\n  recoveryAmount?: number;\n  tokenTxs?: TransactionReceipt[];\n}\n\nexport enum NodeTypes {\n  Full,\n  Solidity,\n}\n\n/**\n * This structure is not a complete model of the AccountResponse from a node.\n */\nexport interface AccountResponse {\n  data: [Interface.AccountInfo];\n}\n\nexport class Trx extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** @inheritdoc */\n  transactionDataAllowed() {\n    return true;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Trx(bitgo, staticsCoin);\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc */\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    if (!address) {\n      return false;\n    }\n    return this.isValidHexAddress(address) || Utils.isBase58Address(address);\n  }\n\n  /**\n   * Checks if this is a valid hex address\n   * @param address hex address\n   */\n  isValidHexAddress(address: string): boolean {\n    return address.length === 42 && /^(0x)?([0-9a-f]{2})+$/i.test(address);\n  }\n\n  /**\n   * Generate ed25519 key pair\n   *\n   * @param seed\n   * @returns {Object} object with generated pub, prv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    // TODO: move this and address creation logic to account-lib\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256 bit chain code, both of which must be\n      // random. 512 bits is therefore the maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const hd = bip32.fromSeed(seed);\n    return {\n      pub: hd.neutered().toBase58(),\n      prv: hd.toBase58(),\n    };\n  }\n\n  isValidXpub(xpub: string): boolean {\n    try {\n      return bip32.fromBase58(xpub).isNeutered();\n    } catch (e) {\n      return false;\n    }\n  }\n\n  isValidPub(pub: string): boolean {\n    if (this.isValidXpub(pub)) {\n      // xpubs can be converted into regular pubs, so technically it is a valid pub\n      return true;\n    }\n    return new RegExp('^04[a-zA-Z0-9]{128}$').test(pub);\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new MethodNotImplementedError();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    return true;\n  }\n\n  /**\n   * Derive a user key using the chain path of the address\n   * @param key\n   * @param path\n   * @returns {string} derived private key\n   */\n  deriveKeyWithPath({ key, path }: { key: string; path: string }): string {\n    const keychain = bip32.fromBase58(key);\n    const derivedKeyNode = keychain.derivePath(path);\n    return derivedKeyNode.toBase58();\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @param params.wallet.addressVersion {String} this is the version of the Algorand multisig address generation format\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: TronSignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = getBuilder(this.getChain()).from(params.txPrebuild.txHex);\n\n    let key;\n    const { chain, index } = params.txPrebuild?.addressInfo ?? { chain: 0, index: 0 };\n    if (chain === 0 && index === 0) {\n      key = params.prv;\n    } else {\n      const derivationPath = `0/0/${chain}/${index}`;\n      key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });\n    }\n    txBuilder.sign({ key });\n\n    const transaction = await txBuilder.build();\n    const response = {\n      txHex: JSON.stringify(transaction.toJson()),\n    };\n    if (transaction.toJson().signature.length >= 2) {\n      return response;\n    }\n    // Half signed transaction\n    return {\n      halfSigned: response,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether input is valid seed for the coin\n   *\n   * @param prv - the prv to be checked\n   */\n  isValidXprv(prv: string): boolean {\n    try {\n      return !bip32.fromBase58(prv).isNeutered();\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Convert a message to string in hexadecimal format.\n   *\n   * @param message {Buffer|String} message to sign\n   * @return the message as a hexadecimal string\n   */\n  toHexString(message: string | Buffer): string {\n    if (typeof message === 'string') {\n      return Buffer.from(message).toString('hex');\n    } else if (Buffer.isBuffer(message)) {\n      return message.toString('hex');\n    } else {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const toSign = this.toHexString(message);\n\n    let prv: string | undefined = key.prv;\n    if (this.isValidXprv(prv)) {\n      prv = bip32.fromBase58(prv).privateKey?.toString('hex');\n    }\n\n    if (!prv) {\n      throw new Error('no privateKey');\n    }\n    let sig = Utils.signString(toSign, prv, true);\n\n    // remove the preceding 0x\n    sig = sig.replace(/^0x/, '');\n\n    return Buffer.from(sig, 'hex');\n  }\n\n  /**\n   * Converts an xpub to a uncompressed pub\n   * @param xpub\n   */\n  xpubToUncompressedPub(xpub: string): string {\n    if (!this.isValidXpub(xpub)) {\n      throw new Error('invalid xpub');\n    }\n\n    const publicKey = bip32.fromBase58(xpub, networks.bitcoin).publicKey;\n    return Buffer.from(secp256k1.publicKeyConvert(publicKey, false /* compressed */)).toString('hex');\n  }\n\n  /**\n   * Modify prebuild before sending it to the server.\n   * @param buildParams The whitelisted parameters for this prebuild\n   */\n  async getExtraPrebuildParams(buildParams: any): Promise<any> {\n    if (buildParams.recipients[0].data && buildParams.feeLimit) {\n      buildParams.recipients[0].feeLimit = buildParams.feeLimit;\n    }\n  }\n\n  pubToHexAddress(pub: string): string {\n    const byteArrayAddr = Utils.getByteArrayFromHexAddress(pub);\n    const rawAddress = Utils.getRawAddressFromPubKey(byteArrayAddr);\n    return Utils.getHexAddressFromByteArray(rawAddress);\n  }\n\n  xprvToCompressedPrv(xprv: string): string {\n    if (!this.isValidXprv(xprv)) {\n      throw new Error('invalid xprv');\n    }\n\n    const hdNode = bip32.fromBase58(xprv, networks.bitcoin);\n    if (!hdNode.privateKey) {\n      throw new Error('no privateKey');\n    }\n    return hdNode.privateKey.toString('hex');\n  }\n\n  /**\n   * Make a query to Trongrid for information such as balance, token balance, solidity calls\n   * @param query {Object} key-value pairs of parameters to append after /api\n   * @returns {Object} response from Trongrid\n   */\n  private async recoveryPost(query: { path: string; jsonObj: any; node: NodeTypes }): Promise<any> {\n    let nodeUri = '';\n    switch (query.node) {\n      case NodeTypes.Full:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.full;\n        break;\n      case NodeTypes.Solidity:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.solidity;\n        break;\n      default:\n        throw new Error('node type not found');\n    }\n\n    const response = await request\n      .post(nodeUri + query.path)\n      .type('json')\n      .send(query.jsonObj);\n\n    if (!response.ok) {\n      throw new Error('could not reach Tron node');\n    }\n\n    // unfortunately, it doesn't look like most TRON nodes return valid json as body\n    return JSON.parse(response.text);\n  }\n\n  /**\n   * Make a query to Trongrid for information such as balance, token balance, solidity calls\n   * @param query {Object} key-value pairs of parameters to append after /api\n   * @returns {Object} response from Trongrid\n   */\n  private async recoveryGet(query: { path: string; jsonObj: any; node: NodeTypes }): Promise<any> {\n    let nodeUri = '';\n    switch (query.node) {\n      case NodeTypes.Full:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.full;\n        break;\n      case NodeTypes.Solidity:\n        nodeUri = common.Environments[this.bitgo.getEnv()].tronNodes.solidity;\n        break;\n      default:\n        throw new Error('node type not found');\n    }\n\n    const response = await request\n      .get(nodeUri + query.path)\n      .type('json')\n      .send(query.jsonObj);\n\n    if (!response.ok) {\n      throw new Error('could not reach Tron node');\n    }\n\n    // unfortunately, it doesn't look like most TRON nodes return valid json as body\n    return JSON.parse(response.text);\n  }\n\n  /**\n   * Query our explorer for the balance of an address\n   * @param address {String} the address encoded in hex\n   * @returns {BigNumber} address balance\n   */\n  private async getAccountBalancesFromNode(address: string): Promise<AccountResponse> {\n    return await this.recoveryGet({\n      path: '/v1/accounts/' + address,\n      jsonObj: {},\n      node: NodeTypes.Full,\n    });\n  }\n\n  /**\n   * Retrieves our build transaction from a node.\n   * @param toAddr hex-encoded address\n   * @param fromAddr hex-encoded address\n   * @param amount\n   */\n  private async getBuildTransaction(\n    toAddr: string,\n    fromAddr: string,\n    amount: number\n  ): Promise<Interface.TransactionReceipt> {\n    // our addresses should be base58, we'll have to encode to hex\n    return await this.recoveryPost({\n      path: '/wallet/createtransaction',\n      jsonObj: {\n        to_address: toAddr,\n        owner_address: fromAddr,\n        amount,\n      },\n      node: NodeTypes.Full,\n    });\n  }\n\n  /**\n   * Retrieves our build transaction from a node.\n   * @param toAddr hex-encoded address\n   * @param fromAddr hex-encoded address\n   * @param amount\n   */\n  private async getTriggerSmartContractTransaction(\n    toAddr: string,\n    fromAddr: string,\n    amount: string,\n    contractAddr: string\n  ): Promise<{ transaction: Interface.TransactionReceipt }> {\n    const functionSelector = 'transfer(address,uint256)';\n    const types = ['address', 'uint256'];\n    const values = [toAddr, amount];\n    const parameter = Utils.encodeDataParams(types, values, '');\n    return await this.recoveryPost({\n      path: '/wallet/triggersmartcontract',\n      jsonObj: {\n        owner_address: fromAddr,\n        contract_address: contractAddr,\n        function_selector: functionSelector,\n        parameter: parameter,\n        fee_limit: 100000000,\n      },\n      node: NodeTypes.Full,\n    });\n  }\n\n  /**\n   * Throws an error if any keys in the ownerKeys collection don't match the keys array we pass\n   * @param ownerKeys\n   * @param keys\n   */\n  checkPermissions(ownerKeys: { address: string; weight: number }[], keys: string[]) {\n    keys = keys.map((k) => k.toUpperCase());\n\n    ownerKeys.map((key) => {\n      const hexKey = key.address.toUpperCase();\n      if (!keys.includes(hexKey)) {\n        throw new Error(`pub address ${hexKey} not found in account`);\n      }\n\n      if (key.weight !== 1) {\n        throw new Error('owner permission is invalid for this structure');\n      }\n    });\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  async recover(params: RecoveryOptions): Promise<RecoveryTransaction> {\n    const isKrsRecovery = getIsKrsRecovery(params);\n    const isUnsignedSweep = getIsUnsignedSweep(params);\n\n    if (!this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('Invalid destination address!');\n    }\n\n    // get our user, backup keys\n    const keys = getBip32Keys(this.bitgo, params, { requireBitGoXpub: false });\n\n    // we need to decode our bitgoKey to a base58 address\n    const bitgoHexAddr = this.pubToHexAddress(this.xpubToUncompressedPub(params.bitgoKey));\n    const recoveryAddressHex = Utils.getHexAddressFromBase58Address(params.recoveryDestination);\n\n    // call the node to get our account balance\n    const account = await this.getAccountBalancesFromNode(Utils.getBase58AddressFromHex(bitgoHexAddr));\n    const recoveryAmount = account.data[0].balance;\n\n    const userXPub = keys[0].neutered().toBase58();\n    const userXPrv = keys[0].toBase58();\n    const backupXPub = keys[1].neutered().toBase58();\n\n    // first construct token txns\n    const tokenTxns: any = [];\n    for (const token of account.data[0].trc20) {\n      // mainnet tokens\n      if (token.TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8) {\n        const amount = token.TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8;\n        const contractAddr = Utils.getHexAddressFromBase58Address('TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8');\n        tokenTxns.push(\n          (await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))\n            .transaction\n        );\n      } else if (token.TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t) {\n        const amount = token.TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t;\n        const contractAddr = Utils.getHexAddressFromBase58Address('TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t');\n        tokenTxns.push(\n          (await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))\n            .transaction\n        );\n\n        // testnet tokens\n      } else if (token.TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id) {\n        const amount = token.TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id;\n        const contractAddr = Utils.getHexAddressFromBase58Address('TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id');\n        tokenTxns.push(\n          (await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))\n            .transaction\n        );\n      } else if (token.TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs) {\n        const amount = token.TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs;\n        const contractAddr = Utils.getHexAddressFromBase58Address('TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs');\n        tokenTxns.push(\n          (await this.getTriggerSmartContractTransaction(recoveryAddressHex, bitgoHexAddr, amount, contractAddr))\n            .transaction\n        );\n      }\n    }\n    // construct the tx -\n    // there's an assumption here being made about fees: for a wallet that hasn't been used in awhile, the implication is\n    // it has maximum bandwidth. thus, a recovery should cost the minimum amount (1e6 sun or 1 Tron)\n    if (MINIMUM_TRON_MSIG_TRANSACTION_FEE > recoveryAmount) {\n      throw new Error('Amount of funds to recover wouldnt be able to fund a send');\n    }\n\n    const keyHexAddresses = [\n      this.pubToHexAddress(this.xpubToUncompressedPub(userXPub)),\n      this.pubToHexAddress(this.xpubToUncompressedPub(backupXPub)),\n      bitgoHexAddr,\n    ];\n\n    // run checks to ensure this is a valid tx - permissions match our signer keys\n    const ownerKeys: { address: string; weight: number }[] = [];\n    for (const key of account.data[0].owner_permission.keys) {\n      const address = Utils.getHexAddressFromBase58Address(key.address);\n      const weight = key.weight;\n      ownerKeys.push({ address, weight });\n    }\n    const activePermissionKeys: { address: string; weight: number }[] = [];\n    for (const key of account.data[0].active_permission[0].keys) {\n      const address = Utils.getHexAddressFromBase58Address(key.address);\n      const weight = key.weight;\n      activePermissionKeys.push({ address, weight });\n    }\n    this.checkPermissions(ownerKeys, keyHexAddresses);\n    this.checkPermissions(activePermissionKeys, keyHexAddresses);\n\n    // build and sign token txns\n    const finalTokenTxs: any = [];\n    for (const tokenTxn of tokenTxns) {\n      const txBuilder = getBuilder(this.getChain()).from(tokenTxn);\n\n      // this tx should be enough to drop into a node\n      if (isUnsignedSweep) {\n        finalTokenTxs.push((await txBuilder.build()).toJson());\n        continue;\n      }\n\n      const userPrv = this.xprvToCompressedPrv(userXPrv);\n\n      txBuilder.sign({ key: userPrv });\n\n      // krs recoveries don't get signed\n      if (!isKrsRecovery) {\n        const backupXPrv = keys[1].toBase58();\n        const backupPrv = this.xprvToCompressedPrv(backupXPrv);\n\n        txBuilder.sign({ key: backupPrv });\n      }\n      finalTokenTxs.push((await txBuilder.build()).toJson());\n    }\n\n    // tokens must be recovered before the native asset, so that there is sufficient of the native asset to cover fees\n    if (finalTokenTxs.length > 0) {\n      return {\n        tokenTxs: finalTokenTxs,\n      };\n    }\n\n    const recoveryAmountMinusFees = recoveryAmount - MINIMUM_TRON_MSIG_TRANSACTION_FEE;\n    const buildTx = await this.getBuildTransaction(recoveryAddressHex, bitgoHexAddr, recoveryAmountMinusFees);\n\n    // construct our tx\n    const txBuilder = (getBuilder(this.getChain()) as WrappedBuilder).from(buildTx);\n\n    // this tx should be enough to drop into a node\n    if (isUnsignedSweep) {\n      return {\n        tx: (await txBuilder.build()).toJson(),\n        recoveryAmount: recoveryAmountMinusFees,\n      };\n    }\n\n    const userPrv = this.xprvToCompressedPrv(userXPrv);\n\n    txBuilder.sign({ key: userPrv });\n\n    // krs recoveries don't get signed\n    if (!isKrsRecovery) {\n      const backupXPrv = keys[1].toBase58();\n      const backupPrv = this.xprvToCompressedPrv(backupXPrv);\n\n      txBuilder.sign({ key: backupPrv });\n    }\n\n    return {\n      tx: (await txBuilder.build()).toJson(),\n      recoveryAmount: recoveryAmountMinusFees,\n    };\n  }\n\n  /**\n   * Explain a Tron transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TronTransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = getBuilder(this.getChain()).from(txHex);\n    const tx = await txBuilder.build();\n    const outputs = [\n      {\n        amount: tx.outputs[0].value.toString(),\n        address: tx.outputs[0].address, // Should turn it into a readable format, aka base58\n      },\n    ];\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'fee',\n      'timestamp',\n      'expiration',\n    ];\n\n    return {\n      displayOrder,\n      id: tx.id,\n      outputs,\n      outputAmount: outputs[0].amount,\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo,\n      timestamp: tx.validFrom,\n      expiration: tx.validTo,\n    };\n  }\n}\n"]}
@@ -0,0 +1,38 @@
1
+ import { Trx } from './trx';
2
+ import { BitGoBase, CoinConstructor, NamedCoinConstructor, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
3
+ import { TrxTokenConfig } from '@bitgo-beta/statics';
4
+ import { Recipient } from '../../sdk-core/src/bitgo/baseCoin/iBaseCoin';
5
+ export { TrxTokenConfig };
6
+ export declare type TronTxInfo = {
7
+ recipients?: Recipient[];
8
+ from?: string;
9
+ txid?: string;
10
+ };
11
+ export declare class TrxToken extends Trx {
12
+ readonly tokenConfig: TrxTokenConfig;
13
+ constructor(bitgo: BitGoBase, tokenConfig: TrxTokenConfig);
14
+ static createTokenConstructor(config: TrxTokenConfig): CoinConstructor;
15
+ static createTokenConstructors(): NamedCoinConstructor[];
16
+ get type(): string;
17
+ get name(): string;
18
+ get coin(): string;
19
+ get network(): string;
20
+ get tokenContractAddress(): string;
21
+ get decimalPlaces(): number;
22
+ getChain(): string;
23
+ getBaseChain(): string;
24
+ getFullName(): string;
25
+ getBaseFactor(): number;
26
+ /**
27
+ * Flag for sending value of 0
28
+ * @returns {boolean} True if okay to send 0 value, false otherwise
29
+ */
30
+ valuelessTransferAllowed(): boolean;
31
+ /**
32
+ * Flag for sending data along with transactions
33
+ * @returns {boolean} True if okay to send tx data (ETH), false otherwise
34
+ */
35
+ transactionDataAllowed(): boolean;
36
+ verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
37
+ }
38
+ //# sourceMappingURL=trxToken.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trxToken.d.ts","sourceRoot":"","sources":["../../src/trxToken.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAClH,OAAO,EAAE,cAAc,EAAiB,MAAM,qBAAqB,CAAC;AAEpE,OAAO,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAC;AAGxE,OAAO,EAAE,cAAc,EAAE,CAAC;AAE1B,oBAAY,UAAU,GAAG;IACvB,UAAU,CAAC,EAAE,SAAS,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,qBAAa,QAAS,SAAQ,GAAG;IAC/B,SAAgB,WAAW,EAAE,cAAc,CAAC;gBAEhC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,cAAc;IAMzD,MAAM,CAAC,sBAAsB,CAAC,MAAM,EAAE,cAAc,GAAG,eAAe;IAItE,MAAM,CAAC,uBAAuB,IAAI,oBAAoB,EAAE;IASxD,IAAI,IAAI,WAEP;IAED,IAAI,IAAI,WAEP;IAED,IAAI,IAAI,WAEP;IAED,IAAI,OAAO,WAEV;IAED,IAAI,oBAAoB,WAEvB;IAED,IAAI,aAAa,WAEhB;IAED,QAAQ;IAIR,YAAY;IAIZ,WAAW;IAIX,aAAa;IAIb;;;OAGG;IACH,wBAAwB;IAIxB;;;OAGG;IACH,sBAAsB;IAIhB,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;CAmB5E"}
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TrxToken = void 0;
7
+ const trx_1 = require("./trx");
8
+ const statics_1 = require("@bitgo-beta/statics");
9
+ const builder_1 = require("./lib/builder");
10
+ const assert_1 = __importDefault(require("assert"));
11
+ class TrxToken extends trx_1.Trx {
12
+ constructor(bitgo, tokenConfig) {
13
+ const staticsCoin = tokenConfig.network === 'Mainnet' ? statics_1.coins.get('trx') : statics_1.coins.get('ttrx');
14
+ super(bitgo, staticsCoin);
15
+ this.tokenConfig = tokenConfig;
16
+ }
17
+ static createTokenConstructor(config) {
18
+ return (bitgo) => new TrxToken(bitgo, config);
19
+ }
20
+ static createTokenConstructors() {
21
+ const tokensCtors = [];
22
+ for (const token of [...statics_1.tokens.bitcoin.trx.tokens, ...statics_1.tokens.testnet.trx.tokens]) {
23
+ const tokenConstructor = TrxToken.createTokenConstructor(token);
24
+ tokensCtors.push({ name: token.type, coinConstructor: tokenConstructor });
25
+ }
26
+ return tokensCtors;
27
+ }
28
+ get type() {
29
+ return this.tokenConfig.type;
30
+ }
31
+ get name() {
32
+ return this.tokenConfig.name;
33
+ }
34
+ get coin() {
35
+ return this.tokenConfig.coin;
36
+ }
37
+ get network() {
38
+ return this.tokenConfig.network;
39
+ }
40
+ get tokenContractAddress() {
41
+ return this.tokenConfig.tokenContractAddress;
42
+ }
43
+ get decimalPlaces() {
44
+ return this.tokenConfig.decimalPlaces;
45
+ }
46
+ getChain() {
47
+ return this.tokenConfig.type;
48
+ }
49
+ getBaseChain() {
50
+ return this.coin;
51
+ }
52
+ getFullName() {
53
+ return 'Tron Token';
54
+ }
55
+ getBaseFactor() {
56
+ return Math.pow(10, this.tokenConfig.decimalPlaces);
57
+ }
58
+ /**
59
+ * Flag for sending value of 0
60
+ * @returns {boolean} True if okay to send 0 value, false otherwise
61
+ */
62
+ valuelessTransferAllowed() {
63
+ return false;
64
+ }
65
+ /**
66
+ * Flag for sending data along with transactions
67
+ * @returns {boolean} True if okay to send tx data (ETH), false otherwise
68
+ */
69
+ transactionDataAllowed() {
70
+ return false;
71
+ }
72
+ async verifyTransaction(params) {
73
+ const { txPrebuild: txPrebuild, txParams: txParams } = params;
74
+ assert_1.default(txPrebuild.txHex, new Error('missing required tx prebuild property txHex'));
75
+ const rawTx = txPrebuild.txHex;
76
+ const txBuilder = builder_1.getBuilder(this.getChain()).from(rawTx);
77
+ const tx = await txBuilder.build();
78
+ const recipients = txParams.recipients || txPrebuild.txInfo.recipients;
79
+ if (!recipients) {
80
+ throw new Error('missing required property recipients');
81
+ }
82
+ if (recipients[0].address === tx.outputs[0].address && recipients[0].amount === tx.outputs[0].value) {
83
+ return true;
84
+ }
85
+ else {
86
+ throw new Error('Tx outputs does not match with expected txParams recipients');
87
+ }
88
+ }
89
+ }
90
+ exports.TrxToken = TrxToken;
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ4VG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJ4VG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsK0JBQTRCO0FBRTVCLGlEQUFvRTtBQUNwRSwyQ0FBMkM7QUFFM0Msb0RBQTRCO0FBVTVCLE1BQWEsUUFBUyxTQUFRLFNBQUc7SUFHL0IsWUFBWSxLQUFnQixFQUFFLFdBQTJCO1FBQ3ZELE1BQU0sV0FBVyxHQUFHLFdBQVcsQ0FBQyxPQUFPLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxlQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzdGLEtBQUssQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDMUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7SUFDakMsQ0FBQztJQUVELE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxNQUFzQjtRQUNsRCxPQUFPLENBQUMsS0FBZ0IsRUFBRSxFQUFFLENBQUMsSUFBSSxRQUFRLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRCxNQUFNLENBQUMsdUJBQXVCO1FBQzVCLE1BQU0sV0FBVyxHQUEyQixFQUFFLENBQUM7UUFDL0MsS0FBSyxNQUFNLEtBQUssSUFBSSxDQUFDLEdBQUcsZ0JBQU0sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxHQUFHLGdCQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNoRixNQUFNLGdCQUFnQixHQUFHLFFBQVEsQ0FBQyxzQkFBc0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNoRSxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLENBQUMsQ0FBQztTQUMzRTtRQUNELE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJLE9BQU87UUFDVCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxJQUFJLG9CQUFvQjtRQUN0QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsb0JBQW9CLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksYUFBYTtRQUNmLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUM7SUFDeEMsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO0lBQy9CLENBQUM7SUFFRCxZQUFZO1FBQ1YsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQztJQUVELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVEOzs7T0FHRztJQUNILHdCQUF3QjtRQUN0QixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRDs7O09BR0c7SUFDSCxzQkFBc0I7UUFDcEIsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsS0FBSyxDQUFDLGlCQUFpQixDQUFDLE1BQWdDO1FBQ3RELE1BQU0sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsR0FBRyxNQUFNLENBQUM7UUFDOUQsZ0JBQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLElBQUksS0FBSyxDQUFDLDZDQUE2QyxDQUFDLENBQUMsQ0FBQztRQUNuRixNQUFNLEtBQUssR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDO1FBRS9CLE1BQU0sU0FBUyxHQUFHLG9CQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFELE1BQU0sRUFBRSxHQUFHLE1BQU0sU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBRW5DLE1BQU0sVUFBVSxHQUFHLFFBQVEsQ0FBQyxVQUFVLElBQUssVUFBVSxDQUFDLE1BQXFCLENBQUMsVUFBVSxDQUFDO1FBQ3ZGLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixNQUFNLElBQUksS0FBSyxDQUFDLHNDQUFzQyxDQUFDLENBQUM7U0FDekQ7UUFFRCxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLEtBQUssRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sS0FBSyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRTtZQUNuRyxPQUFPLElBQUksQ0FBQztTQUNiO2FBQU07WUFDTCxNQUFNLElBQUksS0FBSyxDQUFDLDZEQUE2RCxDQUFDLENBQUM7U0FDaEY7SUFDSCxDQUFDO0NBQ0Y7QUFqR0QsNEJBaUdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJ4IH0gZnJvbSAnLi90cngnO1xuaW1wb3J0IHsgQml0R29CYXNlLCBDb2luQ29uc3RydWN0b3IsIE5hbWVkQ29pbkNvbnN0cnVjdG9yLCBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnMgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBUcnhUb2tlbkNvbmZpZywgY29pbnMsIHRva2VucyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgZ2V0QnVpbGRlciB9IGZyb20gJy4vbGliL2J1aWxkZXInO1xuaW1wb3J0IHsgUmVjaXBpZW50IH0gZnJvbSAnLi4vLi4vc2RrLWNvcmUvc3JjL2JpdGdvL2Jhc2VDb2luL2lCYXNlQ29pbic7XG5pbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmV4cG9ydCB7IFRyeFRva2VuQ29uZmlnIH07XG5cbmV4cG9ydCB0eXBlIFRyb25UeEluZm8gPSB7XG4gIHJlY2lwaWVudHM/OiBSZWNpcGllbnRbXTtcbiAgZnJvbT86IHN0cmluZztcbiAgdHhpZD86IHN0cmluZztcbn07XG5cbmV4cG9ydCBjbGFzcyBUcnhUb2tlbiBleHRlbmRzIFRyeCB7XG4gIHB1YmxpYyByZWFkb25seSB0b2tlbkNvbmZpZzogVHJ4VG9rZW5Db25maWc7XG5cbiAgY29uc3RydWN0b3IoYml0Z286IEJpdEdvQmFzZSwgdG9rZW5Db25maWc6IFRyeFRva2VuQ29uZmlnKSB7XG4gICAgY29uc3Qgc3RhdGljc0NvaW4gPSB0b2tlbkNvbmZpZy5uZXR3b3JrID09PSAnTWFpbm5ldCcgPyBjb2lucy5nZXQoJ3RyeCcpIDogY29pbnMuZ2V0KCd0dHJ4Jyk7XG4gICAgc3VwZXIoYml0Z28sIHN0YXRpY3NDb2luKTtcbiAgICB0aGlzLnRva2VuQ29uZmlnID0gdG9rZW5Db25maWc7XG4gIH1cblxuICBzdGF0aWMgY3JlYXRlVG9rZW5Db25zdHJ1Y3Rvcihjb25maWc6IFRyeFRva2VuQ29uZmlnKTogQ29pbkNvbnN0cnVjdG9yIHtcbiAgICByZXR1cm4gKGJpdGdvOiBCaXRHb0Jhc2UpID0+IG5ldyBUcnhUb2tlbihiaXRnbywgY29uZmlnKTtcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVUb2tlbkNvbnN0cnVjdG9ycygpOiBOYW1lZENvaW5Db25zdHJ1Y3RvcltdIHtcbiAgICBjb25zdCB0b2tlbnNDdG9yczogTmFtZWRDb2luQ29uc3RydWN0b3JbXSA9IFtdO1xuICAgIGZvciAoY29uc3QgdG9rZW4gb2YgWy4uLnRva2Vucy5iaXRjb2luLnRyeC50b2tlbnMsIC4uLnRva2Vucy50ZXN0bmV0LnRyeC50b2tlbnNdKSB7XG4gICAgICBjb25zdCB0b2tlbkNvbnN0cnVjdG9yID0gVHJ4VG9rZW4uY3JlYXRlVG9rZW5Db25zdHJ1Y3Rvcih0b2tlbik7XG4gICAgICB0b2tlbnNDdG9ycy5wdXNoKHsgbmFtZTogdG9rZW4udHlwZSwgY29pbkNvbnN0cnVjdG9yOiB0b2tlbkNvbnN0cnVjdG9yIH0pO1xuICAgIH1cbiAgICByZXR1cm4gdG9rZW5zQ3RvcnM7XG4gIH1cblxuICBnZXQgdHlwZSgpIHtcbiAgICByZXR1cm4gdGhpcy50b2tlbkNvbmZpZy50eXBlO1xuICB9XG5cbiAgZ2V0IG5hbWUoKSB7XG4gICAgcmV0dXJuIHRoaXMudG9rZW5Db25maWcubmFtZTtcbiAgfVxuXG4gIGdldCBjb2luKCkge1xuICAgIHJldHVybiB0aGlzLnRva2VuQ29uZmlnLmNvaW47XG4gIH1cblxuICBnZXQgbmV0d29yaygpIHtcbiAgICByZXR1cm4gdGhpcy50b2tlbkNvbmZpZy5uZXR3b3JrO1xuICB9XG5cbiAgZ2V0IHRva2VuQ29udHJhY3RBZGRyZXNzKCkge1xuICAgIHJldHVybiB0aGlzLnRva2VuQ29uZmlnLnRva2VuQ29udHJhY3RBZGRyZXNzO1xuICB9XG5cbiAgZ2V0IGRlY2ltYWxQbGFjZXMoKSB7XG4gICAgcmV0dXJuIHRoaXMudG9rZW5Db25maWcuZGVjaW1hbFBsYWNlcztcbiAgfVxuXG4gIGdldENoYWluKCkge1xuICAgIHJldHVybiB0aGlzLnRva2VuQ29uZmlnLnR5cGU7XG4gIH1cblxuICBnZXRCYXNlQ2hhaW4oKSB7XG4gICAgcmV0dXJuIHRoaXMuY29pbjtcbiAgfVxuXG4gIGdldEZ1bGxOYW1lKCkge1xuICAgIHJldHVybiAnVHJvbiBUb2tlbic7XG4gIH1cblxuICBnZXRCYXNlRmFjdG9yKCkge1xuICAgIHJldHVybiBNYXRoLnBvdygxMCwgdGhpcy50b2tlbkNvbmZpZy5kZWNpbWFsUGxhY2VzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGbGFnIGZvciBzZW5kaW5nIHZhbHVlIG9mIDBcbiAgICogQHJldHVybnMge2Jvb2xlYW59IFRydWUgaWYgb2theSB0byBzZW5kIDAgdmFsdWUsIGZhbHNlIG90aGVyd2lzZVxuICAgKi9cbiAgdmFsdWVsZXNzVHJhbnNmZXJBbGxvd2VkKCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGbGFnIGZvciBzZW5kaW5nIGRhdGEgYWxvbmcgd2l0aCB0cmFuc2FjdGlvbnNcbiAgICogQHJldHVybnMge2Jvb2xlYW59IFRydWUgaWYgb2theSB0byBzZW5kIHR4IGRhdGEgKEVUSCksIGZhbHNlIG90aGVyd2lzZVxuICAgKi9cbiAgdHJhbnNhY3Rpb25EYXRhQWxsb3dlZCgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBhc3luYyB2ZXJpZnlUcmFuc2FjdGlvbihwYXJhbXM6IFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IHsgdHhQcmVidWlsZDogdHhQcmVidWlsZCwgdHhQYXJhbXM6IHR4UGFyYW1zIH0gPSBwYXJhbXM7XG4gICAgYXNzZXJ0KHR4UHJlYnVpbGQudHhIZXgsIG5ldyBFcnJvcignbWlzc2luZyByZXF1aXJlZCB0eCBwcmVidWlsZCBwcm9wZXJ0eSB0eEhleCcpKTtcbiAgICBjb25zdCByYXdUeCA9IHR4UHJlYnVpbGQudHhIZXg7XG5cbiAgICBjb25zdCB0eEJ1aWxkZXIgPSBnZXRCdWlsZGVyKHRoaXMuZ2V0Q2hhaW4oKSkuZnJvbShyYXdUeCk7XG4gICAgY29uc3QgdHggPSBhd2FpdCB0eEJ1aWxkZXIuYnVpbGQoKTtcblxuICAgIGNvbnN0IHJlY2lwaWVudHMgPSB0eFBhcmFtcy5yZWNpcGllbnRzIHx8ICh0eFByZWJ1aWxkLnR4SW5mbyBhcyBUcm9uVHhJbmZvKS5yZWNpcGllbnRzO1xuICAgIGlmICghcmVjaXBpZW50cykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHJlcXVpcmVkIHByb3BlcnR5IHJlY2lwaWVudHMnKTtcbiAgICB9XG5cbiAgICBpZiAocmVjaXBpZW50c1swXS5hZGRyZXNzID09PSB0eC5vdXRwdXRzWzBdLmFkZHJlc3MgJiYgcmVjaXBpZW50c1swXS5hbW91bnQgPT09IHR4Lm91dHB1dHNbMF0udmFsdWUpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ1R4IG91dHB1dHMgZG9lcyBub3QgbWF0Y2ggd2l0aCBleHBlY3RlZCB0eFBhcmFtcyByZWNpcGllbnRzJyk7XG4gICAgfVxuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/sdk-coin-trx",
3
- "version": "1.2.3-alpha.5",
3
+ "version": "1.2.3-alpha.50",
4
4
  "description": "BitGo SDK coin library for Tron",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -46,20 +46,21 @@
46
46
  ]
47
47
  },
48
48
  "dependencies": {
49
- "@bitgo-beta/sdk-core": "2.4.1-alpha.5",
50
- "@bitgo-beta/statics": "10.0.1-alpha.5",
51
- "@bitgo-beta/utxo-lib": "4.0.1-alpha.5",
49
+ "@bitgo-beta/sdk-core": "2.4.1-alpha.50",
50
+ "@bitgo-beta/statics": "10.0.1-alpha.50",
51
+ "@bitgo-beta/utxo-lib": "4.0.1-alpha.50",
52
52
  "@stablelib/hex": "^1.0.0",
53
53
  "bignumber.js": "^9.0.0",
54
+ "ethers": "^5.7.2",
54
55
  "lodash": "^4.17.14",
55
56
  "protobufjs": "^6.8.9",
56
57
  "secp256k1": "^4.0.2",
57
58
  "superagent": "^3.8.3",
58
- "tronweb": "^3.2.6"
59
+ "tronweb": "^5.0.0"
59
60
  },
60
61
  "devDependencies": {
61
- "@bitgo-beta/sdk-api": "1.6.1-alpha.5",
62
- "@bitgo-beta/sdk-test": "^1.2.4"
62
+ "@bitgo-beta/sdk-api": "1.6.1-alpha.50",
63
+ "@bitgo-beta/sdk-test": "^1.2.18"
63
64
  },
64
- "gitHead": "a86280d9bb6c832d5de2435bed48dfedb52d37cd"
65
+ "gitHead": "da27bbd53fd44a43a75bd1d57f2c82a98d91dd06"
65
66
  }