@bitgo-beta/sdk-coin-trx 1.2.3-alpha.31 → 1.2.3-alpha.310

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.
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -11,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
11
15
  }) : function(o, v) {
12
16
  o["default"] = v;
13
17
  });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
21
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
22
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
23
37
  };
@@ -79,7 +93,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
79
93
  const keyPair = new keyPair_1.KeyPair({ prv: key.key });
80
94
  // Since the key pair was generated using a private key, it will always have a prv attribute,
81
95
  // hence it is safe to use non-null operator
82
- signedTransaction = utils_1.signTransaction(keyPair.getKeys().prv, this.transaction.toJson());
96
+ signedTransaction = (0, utils_1.signTransaction)(keyPair.getKeys().prv, this.transaction.toJson());
83
97
  }
84
98
  catch (e) {
85
99
  throw new sdk_core_1.SigningError('Failed to sign transaction via helper.');
@@ -123,7 +137,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
123
137
  /** @inheritdoc */
124
138
  validateAddress(address) {
125
139
  // assumes a base 58 address for our addresses
126
- if (!utils_1.isBase58Address(address.address)) {
140
+ if (!(0, utils_1.isBase58Address)(address.address)) {
127
141
  throw new Error(address.address + ' is not a valid base58 address.');
128
142
  }
129
143
  }
@@ -171,13 +185,13 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
171
185
  else {
172
186
  throw new sdk_core_1.InvalidTransactionError('Transaction is not an object or stringified json');
173
187
  }
174
- const decodedRawDataHex = utils_1.decodeTransaction(currTransaction.raw_data_hex);
188
+ const decodedRawDataHex = (0, utils_1.decodeTransaction)(currTransaction.raw_data_hex);
175
189
  if (!currTransaction.txID) {
176
190
  throw new sdk_core_1.InvalidTransactionError('Transaction ID is empty');
177
191
  }
178
192
  // Validate the transaction ID from the raw data hex
179
193
  const hexBuffer = Buffer.from(currTransaction.raw_data_hex, 'hex');
180
- const currTxID = crypto_1.createHash('sha256').update(hexBuffer).digest('hex');
194
+ const currTxID = (0, crypto_1.createHash)('sha256').update(hexBuffer).digest('hex');
181
195
  if (currTransaction.txID !== currTxID) {
182
196
  throw new sdk_core_1.InvalidTransactionError('Transaction has not have a valid id');
183
197
  }
@@ -197,7 +211,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
197
211
  /** @inheritdoc */
198
212
  validateTransaction(transaction) {
199
213
  const hexBuffer = Buffer.from(transaction.toJson().raw_data_hex, 'hex');
200
- const txId = crypto_1.createHash('sha256').update(hexBuffer).digest('hex');
214
+ const txId = (0, crypto_1.createHash)('sha256').update(hexBuffer).digest('hex');
201
215
  if (transaction.id !== txId) {
202
216
  throw new sdk_core_1.InvalidTransactionError(transaction.id + ' is not a valid transaction id. Expecting: ' + txId);
203
217
  }
@@ -212,4 +226,4 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
212
226
  }
213
227
  }
214
228
  exports.TransactionBuilder = TransactionBuilder;
215
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport * as _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n} from '@bitgo-beta/sdk-core';\nimport { TransactionReceipt } from './iface';\nimport { Address } from './address';\nimport { signTransaction, isBase58Address, decodeTransaction } from './utils';\nimport { Transaction } from './transaction';\nimport { KeyPair } from './keyPair';\n\n/**\n * Tron transaction builder.\n */\nexport class TransactionBuilder extends BaseTransactionBuilder {\n  // transaction being built\n  private _transaction: Transaction;\n  /**\n   * Public constructor.\n   *\n   * @param {CoinConfig} _coinConfig Configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Parse transaction takes in raw JSON directly from the node.\n   *\n   * @param {TransactionReceipt} rawTransaction The Tron transaction in JSON format as returned by the Tron lib or a stringifyed version of such JSON.\n   * @returns {Transaction} Tron transaction\n   */\n  protected fromImplementation(rawTransaction: TransactionReceipt | string): Transaction {\n    let tx;\n    if (typeof rawTransaction === 'string') {\n      const transaction = JSON.parse(rawTransaction);\n      tx = new Transaction(this._coinConfig, transaction);\n    } else {\n      tx = new Transaction(this._coinConfig, rawTransaction);\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (!this.transaction.inputs) {\n      throw new SigningError('Transaction has no sender');\n    }\n\n    if (!this.transaction.outputs) {\n      throw new SigningError('Transaction has no receiver');\n    }\n    return this.applySignature(key);\n  }\n\n  protected applySignature(key: BaseKey): Transaction {\n    const oldTransaction = this.transaction.toJson();\n    // Store the original signatures to compare them with the new ones in a later step. Signatures\n    // can be undefined if this is the first time the transaction is being signed\n    const oldSignatureCount = oldTransaction.signature ? oldTransaction.signature.length : 0;\n    let signedTransaction: TransactionReceipt;\n    try {\n      const keyPair = new KeyPair({ prv: key.key });\n      // Since the key pair was generated using a private key, it will always have a prv attribute,\n      // hence it is safe to use non-null operator\n      signedTransaction = signTransaction(keyPair.getKeys().prv!, this.transaction.toJson());\n    } catch (e) {\n      throw new SigningError('Failed to sign transaction via helper.');\n    }\n\n    // Ensure that we have more signatures than what we started with\n    if (!signedTransaction.signature || oldSignatureCount >= signedTransaction.signature.length) {\n      throw new SigningError('Transaction signing did not return an additional signature.');\n    }\n\n    return new Transaction(this._coinConfig, signedTransaction);\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    // This is a no-op since Tron transactions are built from\n    if (!this.transaction.id) {\n      throw new BuildTransactionError('A valid transaction must have an id');\n    }\n    return Promise.resolve(this.transaction);\n  }\n\n  initBuilder(tx: TransactionReceipt | string) {\n    this.transaction = this.fromImplementation(tx);\n  }\n\n  /**\n   * Extend the validity of this transaction by the given amount of time\n   *\n   * @param {number} extensionMs The number of milliseconds to extend the validTo time\n   * @returns {undefined}\n   */\n  extendValidTo(extensionMs: number): void {\n    this.transaction.extendExpiration(extensionMs);\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThanOrEqualTo(0)) {\n      throw new Error('Value cannot be below zero.');\n    }\n\n    // max long in Java - assumed upper limit for a TRX transaction\n    if (value.isGreaterThan(new BigNumber('9223372036854775807'))) {\n      throw new Error('Value cannot be greater than handled by the javatron node.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateAddress(address: Address): void {\n    // assumes a base 58 address for our addresses\n    if (!isBase58Address(address.address)) {\n      throw new Error(address.address + ' is not a valid base58 address.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    try {\n      new KeyPair({ prv: key.key });\n    } catch (err) {\n      throw new Error('The provided key is not valid');\n    }\n  }\n\n  /**\n   * Validate the contents of a raw transaction. The validation\n   * phase is to compare the raw-data-hex to the raw-data of the\n   * transaction.\n   *\n   * The contents to be validated are\n   * 1. The transaction id\n   * 2. The expiration date\n   * 3. The timestamp\n   * 4. The contract\n   *\n   * @param {TransactionReceipt | string} rawTransaction The raw transaction to be validated\n   */\n  validateRawTransaction(rawTransaction: TransactionReceipt | string): void {\n    // TODO: Validation of signature\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    let currTransaction: TransactionReceipt;\n    // rawTransaction can be either Stringified JSON OR\n    // it can be a regular JSON object (not stringified).\n    if (typeof rawTransaction === 'string') {\n      try {\n        currTransaction = JSON.parse(rawTransaction);\n      } catch (e) {\n        throw new ParseTransactionError('There was error in parsing the JSON string');\n      }\n    } else if (_.isObject(rawTransaction)) {\n      currTransaction = rawTransaction;\n    } else {\n      throw new InvalidTransactionError('Transaction is not an object or stringified json');\n    }\n    const decodedRawDataHex = decodeTransaction(currTransaction.raw_data_hex);\n    if (!currTransaction.txID) {\n      throw new InvalidTransactionError('Transaction ID is empty');\n    }\n    // Validate the transaction ID from the raw data hex\n    const hexBuffer = Buffer.from(currTransaction.raw_data_hex, 'hex');\n    const currTxID = createHash('sha256').update(hexBuffer).digest('hex');\n    if (currTransaction.txID !== currTxID) {\n      throw new InvalidTransactionError('Transaction has not have a valid id');\n    }\n    // Validate the expiration time from the raw-data-hex\n    if (currTransaction.raw_data.expiration !== decodedRawDataHex.expiration) {\n      throw new InvalidTransactionError('Transaction has not have a valid expiration');\n    }\n    // Validate the timestamp from the raw-data-hex\n    if (currTransaction.raw_data.timestamp !== decodedRawDataHex.timestamp) {\n      throw new InvalidTransactionError('Transaction has not have a valid timetamp');\n    }\n    // Transaction contract must exist\n    if (!currTransaction.raw_data.contract) {\n      throw new InvalidTransactionError('Transaction contracts are empty');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction: Transaction): void {\n    const hexBuffer = Buffer.from(transaction.toJson().raw_data_hex, 'hex');\n    const txId = createHash('sha256').update(hexBuffer).digest('hex');\n    if (transaction.id !== txId) {\n      throw new InvalidTransactionError(transaction.id + ' is not a valid transaction id. Expecting: ' + txId);\n    }\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n}\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport * as _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n} from '@bitgo-beta/sdk-core';\nimport { TransactionReceipt } from './iface';\nimport { Address } from './address';\nimport { signTransaction, isBase58Address, decodeTransaction } from './utils';\nimport { Transaction } from './transaction';\nimport { KeyPair } from './keyPair';\n\n/**\n * Tron transaction builder.\n */\nexport class TransactionBuilder extends BaseTransactionBuilder {\n  // transaction being built\n  private _transaction: Transaction;\n  /**\n   * Public constructor.\n   *\n   * @param {CoinConfig} _coinConfig Configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Parse transaction takes in raw JSON directly from the node.\n   *\n   * @param {TransactionReceipt} rawTransaction The Tron transaction in JSON format as returned by the Tron lib or a stringifyed version of such JSON.\n   * @returns {Transaction} Tron transaction\n   */\n  protected fromImplementation(rawTransaction: TransactionReceipt | string): Transaction {\n    let tx;\n    if (typeof rawTransaction === 'string') {\n      const transaction = JSON.parse(rawTransaction);\n      tx = new Transaction(this._coinConfig, transaction);\n    } else {\n      tx = new Transaction(this._coinConfig, rawTransaction);\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (!this.transaction.inputs) {\n      throw new SigningError('Transaction has no sender');\n    }\n\n    if (!this.transaction.outputs) {\n      throw new SigningError('Transaction has no receiver');\n    }\n    return this.applySignature(key);\n  }\n\n  protected applySignature(key: BaseKey): Transaction {\n    const oldTransaction = this.transaction.toJson();\n    // Store the original signatures to compare them with the new ones in a later step. Signatures\n    // can be undefined if this is the first time the transaction is being signed\n    const oldSignatureCount = oldTransaction.signature ? oldTransaction.signature.length : 0;\n    let signedTransaction: TransactionReceipt;\n    try {\n      const keyPair = new KeyPair({ prv: key.key });\n      // Since the key pair was generated using a private key, it will always have a prv attribute,\n      // hence it is safe to use non-null operator\n      signedTransaction = signTransaction(keyPair.getKeys().prv!, this.transaction.toJson());\n    } catch (e) {\n      throw new SigningError('Failed to sign transaction via helper.');\n    }\n\n    // Ensure that we have more signatures than what we started with\n    if (!signedTransaction.signature || oldSignatureCount >= signedTransaction.signature.length) {\n      throw new SigningError('Transaction signing did not return an additional signature.');\n    }\n\n    return new Transaction(this._coinConfig, signedTransaction);\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    // This is a no-op since Tron transactions are built from\n    if (!this.transaction.id) {\n      throw new BuildTransactionError('A valid transaction must have an id');\n    }\n    return Promise.resolve(this.transaction);\n  }\n\n  initBuilder(tx: TransactionReceipt | string) {\n    this.transaction = this.fromImplementation(tx);\n  }\n\n  /**\n   * Extend the validity of this transaction by the given amount of time\n   *\n   * @param {number} extensionMs The number of milliseconds to extend the validTo time\n   * @returns {undefined}\n   */\n  extendValidTo(extensionMs: number): void {\n    this.transaction.extendExpiration(extensionMs);\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThanOrEqualTo(0)) {\n      throw new Error('Value cannot be below zero.');\n    }\n\n    // max long in Java - assumed upper limit for a TRX transaction\n    if (value.isGreaterThan(new BigNumber('9223372036854775807'))) {\n      throw new Error('Value cannot be greater than handled by the javatron node.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateAddress(address: Address): void {\n    // assumes a base 58 address for our addresses\n    if (!isBase58Address(address.address)) {\n      throw new Error(address.address + ' is not a valid base58 address.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    try {\n      new KeyPair({ prv: key.key });\n    } catch (err) {\n      throw new Error('The provided key is not valid');\n    }\n  }\n\n  /**\n   * Validate the contents of a raw transaction. The validation\n   * phase is to compare the raw-data-hex to the raw-data of the\n   * transaction.\n   *\n   * The contents to be validated are\n   * 1. The transaction id\n   * 2. The expiration date\n   * 3. The timestamp\n   * 4. The contract\n   *\n   * @param {TransactionReceipt | string} rawTransaction The raw transaction to be validated\n   */\n  validateRawTransaction(rawTransaction: TransactionReceipt | string): void {\n    // TODO: Validation of signature\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    let currTransaction: TransactionReceipt;\n    // rawTransaction can be either Stringified JSON OR\n    // it can be a regular JSON object (not stringified).\n    if (typeof rawTransaction === 'string') {\n      try {\n        currTransaction = JSON.parse(rawTransaction);\n      } catch (e) {\n        throw new ParseTransactionError('There was error in parsing the JSON string');\n      }\n    } else if (_.isObject(rawTransaction)) {\n      currTransaction = rawTransaction;\n    } else {\n      throw new InvalidTransactionError('Transaction is not an object or stringified json');\n    }\n    const decodedRawDataHex = decodeTransaction(currTransaction.raw_data_hex);\n    if (!currTransaction.txID) {\n      throw new InvalidTransactionError('Transaction ID is empty');\n    }\n    // Validate the transaction ID from the raw data hex\n    const hexBuffer = Buffer.from(currTransaction.raw_data_hex, 'hex');\n    const currTxID = createHash('sha256').update(hexBuffer).digest('hex');\n    if (currTransaction.txID !== currTxID) {\n      throw new InvalidTransactionError('Transaction has not have a valid id');\n    }\n    // Validate the expiration time from the raw-data-hex\n    if (currTransaction.raw_data.expiration !== decodedRawDataHex.expiration) {\n      throw new InvalidTransactionError('Transaction has not have a valid expiration');\n    }\n    // Validate the timestamp from the raw-data-hex\n    if (currTransaction.raw_data.timestamp !== decodedRawDataHex.timestamp) {\n      throw new InvalidTransactionError('Transaction has not have a valid timetamp');\n    }\n    // Transaction contract must exist\n    if (!currTransaction.raw_data.contract) {\n      throw new InvalidTransactionError('Transaction contracts are empty');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction: Transaction): void {\n    const hexBuffer = Buffer.from(transaction.toJson().raw_data_hex, 'hex');\n    const txId = createHash('sha256').update(hexBuffer).digest('hex');\n    if (transaction.id !== txId) {\n      throw new InvalidTransactionError(transaction.id + ' is not a valid transaction id. Expecting: ' + txId);\n    }\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n}\n"]}
@@ -1,12 +1,11 @@
1
- /// <reference types="node" />
2
1
  import { TransferContract, RawData, AccountPermissionUpdateContract, TransactionReceipt, TriggerSmartContract } from './iface';
3
2
  export declare const tokenMainnetContractAddresses: string[];
4
3
  export declare const tokenTestnetContractAddresses: string[];
5
4
  /**
6
5
  * Tron-specific helper functions
7
6
  */
8
- export declare type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;
9
- export declare type ByteArray = number[];
7
+ export type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;
8
+ export type ByteArray = number[];
10
9
  /**
11
10
  * @param address
12
11
  */
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -11,56 +15,86 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
11
15
  }) : function(o, v) {
12
16
  o["default"] = v;
13
17
  });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
21
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
22
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
23
37
  };
24
38
  Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.decodeDataParams = exports.encodeDataParams = exports.toHex = exports.isValidRawTransactionFormat = exports.isValidTxJsonString = exports.decodeAccountPermissionUpdateContract = exports.decodeTriggerSmartContract = exports.decodeTransferContract = exports.isValidHex = exports.decodeRawTransaction = exports.decodeTransaction = exports.getRawAddressFromPubKey = exports.signString = exports.signTransaction = exports.getBase58AddressFromHex = exports.getBase58AddressFromByteArray = exports.getAddressFromPriKey = exports.getPubKeyFromPriKey = exports.getHexAddressFromBase58Address = exports.verifySignature = exports.getHexAddressFromByteArray = exports.getByteArrayFromHexAddress = exports.isBase58Address = exports.tokenTestnetContractAddresses = exports.tokenMainnetContractAddresses = void 0;
39
+ exports.tokenTestnetContractAddresses = exports.tokenMainnetContractAddresses = void 0;
40
+ exports.isBase58Address = isBase58Address;
41
+ exports.getByteArrayFromHexAddress = getByteArrayFromHexAddress;
42
+ exports.getHexAddressFromByteArray = getHexAddressFromByteArray;
43
+ exports.verifySignature = verifySignature;
44
+ exports.getHexAddressFromBase58Address = getHexAddressFromBase58Address;
45
+ exports.getPubKeyFromPriKey = getPubKeyFromPriKey;
46
+ exports.getAddressFromPriKey = getAddressFromPriKey;
47
+ exports.getBase58AddressFromByteArray = getBase58AddressFromByteArray;
48
+ exports.getBase58AddressFromHex = getBase58AddressFromHex;
49
+ exports.signTransaction = signTransaction;
50
+ exports.signString = signString;
51
+ exports.getRawAddressFromPubKey = getRawAddressFromPubKey;
52
+ exports.decodeTransaction = decodeTransaction;
53
+ exports.decodeRawTransaction = decodeRawTransaction;
54
+ exports.isValidHex = isValidHex;
55
+ exports.decodeTransferContract = decodeTransferContract;
56
+ exports.decodeTriggerSmartContract = decodeTriggerSmartContract;
57
+ exports.decodeAccountPermissionUpdateContract = decodeAccountPermissionUpdateContract;
58
+ exports.isValidTxJsonString = isValidTxJsonString;
59
+ exports.isValidRawTransactionFormat = isValidRawTransactionFormat;
60
+ exports.toHex = toHex;
61
+ exports.encodeDataParams = encodeDataParams;
62
+ exports.decodeDataParams = decodeDataParams;
26
63
  const assert_1 = __importDefault(require("assert"));
27
64
  const hex = __importStar(require("@stablelib/hex"));
28
65
  const tronweb = __importStar(require("tronweb"));
29
66
  const tron_1 = require("../../resources/protobuf/tron");
30
67
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
68
+ const statics_1 = require("@bitgo-beta/statics");
31
69
  const enum_1 = require("./enum");
32
70
  const utils_1 = require("ethers/lib/utils");
33
71
  const ADDRESS_PREFIX_REGEX = /^(41)/;
34
72
  const ADDRESS_PREFIX = '41';
35
- exports.tokenMainnetContractAddresses = [
36
- 'TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8',
37
- 'TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t',
38
- ];
39
- exports.tokenTestnetContractAddresses = [
40
- 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',
41
- 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',
42
- ];
73
+ const getTronTokens = (network = 'mainnet') => {
74
+ return statics_1.coins
75
+ .filter((coin) => coin.family === 'trx')
76
+ .filter((trx) => trx.network.type === network && trx.isToken).map((coins) => coins.contractAddress.toString());
77
+ };
78
+ exports.tokenMainnetContractAddresses = getTronTokens('mainnet');
79
+ exports.tokenTestnetContractAddresses = getTronTokens('testnet');
43
80
  /**
44
81
  * @param address
45
82
  */
46
83
  function isBase58Address(address) {
47
84
  return tronweb.utils.crypto.isAddressValid(address);
48
85
  }
49
- exports.isBase58Address = isBase58Address;
50
86
  /**
51
87
  * @param str
52
88
  */
53
89
  function getByteArrayFromHexAddress(str) {
54
90
  return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));
55
91
  }
56
- exports.getByteArrayFromHexAddress = getByteArrayFromHexAddress;
57
92
  /**
58
93
  * @param arr
59
94
  */
60
95
  function getHexAddressFromByteArray(arr) {
61
96
  return tronweb.utils.code.byteArray2hexStr(arr);
62
97
  }
63
- exports.getHexAddressFromByteArray = getHexAddressFromByteArray;
64
98
  /**
65
99
  * @param messageToVerify
66
100
  * @param base58Address
@@ -79,7 +113,6 @@ function verifySignature(messageToVerify, base58Address, sigHex, useTronHeader =
79
113
  }
80
114
  return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);
81
115
  }
82
- exports.verifySignature = verifySignature;
83
116
  /**
84
117
  * @param base58
85
118
  */
@@ -89,28 +122,24 @@ function getHexAddressFromBase58Address(base58) {
89
122
  const bytes = tronweb.utils.crypto.decodeBase58Address(base58);
90
123
  return getHexAddressFromByteArray(bytes);
91
124
  }
92
- exports.getHexAddressFromBase58Address = getHexAddressFromBase58Address;
93
125
  /**
94
126
  * @param privateKey
95
127
  */
96
128
  function getPubKeyFromPriKey(privateKey) {
97
129
  return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);
98
130
  }
99
- exports.getPubKeyFromPriKey = getPubKeyFromPriKey;
100
131
  /**
101
132
  * @param privateKey
102
133
  */
103
134
  function getAddressFromPriKey(privateKey) {
104
135
  return tronweb.utils.crypto.getAddressFromPriKey(privateKey);
105
136
  }
106
- exports.getAddressFromPriKey = getAddressFromPriKey;
107
137
  /**
108
138
  * @param address
109
139
  */
110
140
  function getBase58AddressFromByteArray(address) {
111
141
  return tronweb.utils.crypto.getBase58CheckAddress(address);
112
142
  }
113
- exports.getBase58AddressFromByteArray = getBase58AddressFromByteArray;
114
143
  /**
115
144
  * @param hex
116
145
  */
@@ -118,7 +147,6 @@ function getBase58AddressFromHex(hex) {
118
147
  const arr = getByteArrayFromHexAddress(hex);
119
148
  return getBase58AddressFromByteArray(arr);
120
149
  }
121
- exports.getBase58AddressFromHex = getBase58AddressFromHex;
122
150
  /**
123
151
  * @param privateKey
124
152
  * @param transaction
@@ -126,7 +154,6 @@ exports.getBase58AddressFromHex = getBase58AddressFromHex;
126
154
  function signTransaction(privateKey, transaction) {
127
155
  return tronweb.utils.crypto.signTransaction(privateKey, transaction);
128
156
  }
129
- exports.signTransaction = signTransaction;
130
157
  /**
131
158
  * @param message
132
159
  * @param privateKey
@@ -135,14 +162,12 @@ exports.signTransaction = signTransaction;
135
162
  function signString(message, privateKey, useTronHeader = true) {
136
163
  return tronweb.Trx.signString(message, privateKey, useTronHeader);
137
164
  }
138
- exports.signString = signString;
139
165
  /**
140
166
  * @param pubBytes
141
167
  */
142
168
  function getRawAddressFromPubKey(pubBytes) {
143
169
  return tronweb.utils.crypto.computeAddress(pubBytes);
144
170
  }
145
- exports.getRawAddressFromPubKey = getRawAddressFromPubKey;
146
171
  /**
147
172
  * Decodes a hex encoded transaction in its protobuf representation.
148
173
  *
@@ -183,7 +208,6 @@ function decodeTransaction(hexString) {
183
208
  fee_limit: +rawTransaction.feeLimit,
184
209
  };
185
210
  }
186
- exports.decodeTransaction = decodeTransaction;
187
211
  /**
188
212
  * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.
189
213
  *
@@ -210,7 +234,6 @@ function decodeRawTransaction(hexString) {
210
234
  blockHash: toHex(raw.refBlockHash),
211
235
  };
212
236
  }
213
- exports.decodeRawTransaction = decodeRawTransaction;
214
237
  /**
215
238
  * Indicates whether the passed string is a safe hex string for tron's purposes.
216
239
  *
@@ -219,7 +242,6 @@ exports.decodeRawTransaction = decodeRawTransaction;
219
242
  function isValidHex(hex) {
220
243
  return /^(0x)?([0-9a-f]{2})+$/i.test(hex);
221
244
  }
222
- exports.isValidHex = isValidHex;
223
245
  /** Deserialize the segment of the txHex which corresponds with the details of the transfer
224
246
  *
225
247
  * @param transferHex is the value property of the "parameter" field of contractList[0]
@@ -258,7 +280,6 @@ function decodeTransferContract(transferHex) {
258
280
  },
259
281
  ];
260
282
  }
261
- exports.decodeTransferContract = decodeTransferContract;
262
283
  /**
263
284
  * Deserialize the segment of the txHex corresponding with trigger smart contract
264
285
  *
@@ -298,7 +319,6 @@ function decodeTriggerSmartContract(base64) {
298
319
  },
299
320
  ];
300
321
  }
301
- exports.decodeTriggerSmartContract = decodeTriggerSmartContract;
302
322
  /**
303
323
  * Deserialize the segment of the txHex corresponding with the details of the contract which updates
304
324
  * account permission
@@ -308,9 +328,9 @@ exports.decodeTriggerSmartContract = decodeTriggerSmartContract;
308
328
  */
309
329
  function decodeAccountPermissionUpdateContract(base64) {
310
330
  const accountUpdateContract = tron_1.protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();
311
- assert_1.default(accountUpdateContract.ownerAddress);
312
- assert_1.default(accountUpdateContract.owner);
313
- assert_1.default(accountUpdateContract.hasOwnProperty('actives'));
331
+ (0, assert_1.default)(accountUpdateContract.ownerAddress);
332
+ (0, assert_1.default)(accountUpdateContract.owner);
333
+ (0, assert_1.default)(accountUpdateContract.hasOwnProperty('actives'));
314
334
  const ownerAddress = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex')));
315
335
  const owner = createPermission(accountUpdateContract.owner);
316
336
  let witness = undefined;
@@ -325,7 +345,6 @@ function decodeAccountPermissionUpdateContract(base64) {
325
345
  actives: activeList,
326
346
  };
327
347
  }
328
- exports.decodeAccountPermissionUpdateContract = decodeAccountPermissionUpdateContract;
329
348
  /**
330
349
  * @param raw
331
350
  */
@@ -353,7 +372,6 @@ function isValidTxJsonString(rawTransaction) {
353
372
  const transaction = JSON.parse(rawTransaction);
354
373
  return transaction.hasOwnProperty('txID');
355
374
  }
356
- exports.isValidTxJsonString = isValidTxJsonString;
357
375
  /**
358
376
  * Returns whether the provided raw transaction accommodates to bitgo's preferred format
359
377
  *
@@ -366,7 +384,6 @@ function isValidRawTransactionFormat(rawTransaction) {
366
384
  }
367
385
  return false;
368
386
  }
369
- exports.isValidRawTransactionFormat = isValidRawTransactionFormat;
370
387
  /**
371
388
  * Returns an hex string of the given buffer
372
389
  *
@@ -376,7 +393,6 @@ exports.isValidRawTransactionFormat = isValidRawTransactionFormat;
376
393
  function toHex(buffer) {
377
394
  return hex.encode(buffer, true);
378
395
  }
379
- exports.toHex = toHex;
380
396
  /**
381
397
  * Returns a Keccak-256 encoded string of the parameters
382
398
  *
@@ -396,16 +412,15 @@ function encodeDataParams(types, values, methodId) {
396
412
  data = abiCoder.encode(types, values);
397
413
  }
398
414
  catch (e) {
399
- throw new sdk_core_1.UtilsError('There was an error encoding the data params.');
415
+ throw new sdk_core_1.UtilsError(`There was an error encoding the data params. Error = ${JSON.stringify(e)}`);
400
416
  }
401
417
  if (methodId) {
402
- return utils_1.hexConcat([methodId, data]).replace(/^(0x)/, '');
418
+ return (0, utils_1.hexConcat)([methodId, data]).replace(/^(0x)/, '');
403
419
  }
404
420
  else {
405
421
  return data.replace(/^(0x)/, '');
406
422
  }
407
423
  }
408
- exports.encodeDataParams = encodeDataParams;
409
424
  /**
410
425
  * Returns the decoded values according to the array of types
411
426
  *
@@ -422,5 +437,4 @@ function decodeDataParams(types, data) {
422
437
  return obj;
423
438
  }, []);
424
439
  }
425
- exports.decodeDataParams = decodeDataParams;
426
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport * as hex from '@stablelib/hex';\nimport * as tronweb from 'tronweb';\nimport { protocol } from '../../resources/protobuf/tron';\n\nimport { UtilsError } from '@bitgo-beta/sdk-core';\nimport {\n  TransferContract,\n  RawData,\n  AccountPermissionUpdateContract,\n  TransactionReceipt,\n  Permission,\n  TriggerSmartContract,\n} from './iface';\nimport { ContractType, PermissionType } from './enum';\nimport { AbiCoder, hexConcat } from 'ethers/lib/utils';\n\nconst ADDRESS_PREFIX_REGEX = /^(41)/;\nconst ADDRESS_PREFIX = '41';\n\nexport const tokenMainnetContractAddresses = [\n  'TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8',\n  'TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t',\n];\nexport const tokenTestnetContractAddresses = [\n  'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',\n  'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',\n];\n\n/**\n * Tron-specific helper functions\n */\nexport type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;\nexport type ByteArray = number[];\n\n/**\n * @param address\n */\nexport function isBase58Address(address: string): boolean {\n  return tronweb.utils.crypto.isAddressValid(address);\n}\n\n/**\n * @param str\n */\nexport function getByteArrayFromHexAddress(str: string): ByteArray {\n  return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));\n}\n\n/**\n * @param arr\n */\nexport function getHexAddressFromByteArray(arr: ByteArray): string {\n  return tronweb.utils.code.byteArray2hexStr(arr);\n}\n\n/**\n * @param messageToVerify\n * @param base58Address\n * @param sigHex\n * @param useTronHeader\n */\nexport function verifySignature(\n  messageToVerify: string,\n  base58Address: string,\n  sigHex: string,\n  useTronHeader = true\n): boolean {\n  if (!isValidHex(sigHex)) {\n    throw new UtilsError('signature is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isValidHex(messageToVerify)) {\n    throw new UtilsError('message is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isBase58Address(base58Address)) {\n    throw new UtilsError('address needs to be base58 encoded');\n  }\n\n  return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);\n}\n\n/**\n * @param base58\n */\nexport function getHexAddressFromBase58Address(base58: string): string {\n  // pulled from: https://github.com/TRON-US/tronweb/blob/dcb8efa36a5ebb65c4dab3626e90256a453f3b0d/src/utils/help.js#L17\n  // but they don't surface this call in index.js\n  const bytes = tronweb.utils.crypto.decodeBase58Address(base58);\n  return getHexAddressFromByteArray(bytes);\n}\n\n/**\n * @param privateKey\n */\nexport function getPubKeyFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);\n}\n\n/**\n * @param privateKey\n */\nexport function getAddressFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getAddressFromPriKey(privateKey);\n}\n\n/**\n * @param address\n */\nexport function getBase58AddressFromByteArray(address: ByteArray): string {\n  return tronweb.utils.crypto.getBase58CheckAddress(address);\n}\n\n/**\n * @param hex\n */\nexport function getBase58AddressFromHex(hex: string): string {\n  const arr = getByteArrayFromHexAddress(hex);\n  return getBase58AddressFromByteArray(arr);\n}\n\n/**\n * @param privateKey\n * @param transaction\n */\nexport function signTransaction(privateKey: string | ByteArray, transaction: TransactionReceipt): TransactionReceipt {\n  return tronweb.utils.crypto.signTransaction(privateKey, transaction);\n}\n\n/**\n * @param message\n * @param privateKey\n * @param useTronHeader\n */\nexport function signString(message: string, privateKey: string | ByteArray, useTronHeader = true): string {\n  return tronweb.Trx.signString(message, privateKey, useTronHeader);\n}\n\n/**\n * @param pubBytes\n */\nexport function getRawAddressFromPubKey(pubBytes: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.computeAddress(pubBytes);\n}\n\n/**\n * Decodes a hex encoded transaction in its protobuf representation.\n *\n * @param hexString raw_data_hex field from tron transactions\n */\nexport function decodeTransaction(hexString: string): RawData {\n  const rawTransaction = decodeRawTransaction(hexString);\n\n  // there should not be multiple contracts in this data\n  if (rawTransaction.contracts.length !== 1) {\n    throw new UtilsError('Number of contracts is greater than 1.');\n  }\n\n  let contract: TransferContract[] | AccountPermissionUpdateContract[] | TriggerSmartContract[];\n  let contractType: ContractType;\n  // ensure the contract type is supported\n  switch (rawTransaction.contracts[0].parameter.type_url) {\n    case 'type.googleapis.com/protocol.TransferContract':\n      contractType = ContractType.Transfer;\n      contract = exports.decodeTransferContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.AccountPermissionUpdateContract':\n      contractType = ContractType.AccountPermissionUpdate;\n      contract = exports.decodeAccountPermissionUpdateContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.TriggerSmartContract':\n      contractType = ContractType.TriggerSmartContract;\n      contract = exports.decodeTriggerSmartContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    default:\n      throw new UtilsError('Unsupported contract type');\n  }\n\n  return {\n    contractType,\n    contract,\n    expiration: rawTransaction.expiration,\n    timestamp: rawTransaction.timestamp,\n    ref_block_bytes: rawTransaction.blockBytes,\n    ref_block_hash: rawTransaction.blockHash,\n    fee_limit: +rawTransaction.feeLimit,\n  };\n}\n\n/**\n * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.\n *\n * @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.\n * @example\n * @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}\n */\nexport function decodeRawTransaction(hexString: string): {\n  expiration: number;\n  timestamp: number;\n  contracts: Array<any>;\n  blockBytes: string;\n  blockHash: string;\n  feeLimit: string;\n} {\n  const bytes = Buffer.from(hexString, 'hex');\n\n  let raw;\n  try {\n    // we need to decode our raw_data_hex field first\n    raw = protocol.Transaction.raw.decode(bytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the initial raw_data_hex from the serialized tx.');\n  }\n\n  return {\n    expiration: Number(raw.expiration),\n    timestamp: Number(raw.timestamp),\n    contracts: raw.contract,\n    blockBytes: toHex(raw.refBlockBytes),\n    feeLimit: raw.feeLimit,\n    blockHash: toHex(raw.refBlockHash),\n  };\n}\n\n/**\n * Indicates whether the passed string is a safe hex string for tron's purposes.\n *\n * @param hex A valid hex string must be a string made of numbers and characters and has an even length.\n */\nexport function isValidHex(hex: string): boolean {\n  return /^(0x)?([0-9a-f]{2})+$/i.test(hex);\n}\n\n/** Deserialize the segment of the txHex which corresponds with the details of the transfer\n *\n * @param transferHex is the value property of the \"parameter\" field of contractList[0]\n * */\nexport function decodeTransferContract(transferHex: string): TransferContract[] {\n  const contractBytes = Buffer.from(transferHex, 'base64');\n  let transferContract;\n\n  try {\n    transferContract = protocol.TransferContract.decode(contractBytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the transfer contract in the transaction.');\n  }\n\n  if (!transferContract.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.toAddress) {\n    throw new UtilsError('Destination address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.hasOwnProperty('amount')) {\n    throw new UtilsError('Amount does not exist in this transfer contract.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const to_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.toAddress, 'base64').toString('hex'))\n  );\n  const amount = transferContract.amount;\n\n  return [\n    {\n      parameter: {\n        value: {\n          amount: Number(amount),\n          owner_address,\n          to_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with trigger smart contract\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeTriggerSmartContract(base64: string): TriggerSmartContract[] {\n  let contractCallDecoded;\n  try {\n    contractCallDecoded = protocol.TriggerSmartContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the contract call in the transaction.');\n  }\n\n  if (!contractCallDecoded.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.contractAddress) {\n    throw new UtilsError('Destination contract address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.data) {\n    throw new UtilsError('Data does not exist in this contract call.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.ownerAddress, 'base64').toString('hex'))\n  );\n  const contract_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.contractAddress, 'base64').toString('hex'))\n  );\n  const data = contractCallDecoded.data;\n  return [\n    {\n      parameter: {\n        value: {\n          data: data,\n          owner_address,\n          contract_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with the details of the contract which updates\n * account permission\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeAccountPermissionUpdateContract(base64: string): AccountPermissionUpdateContract {\n  const accountUpdateContract = protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  assert(accountUpdateContract.ownerAddress);\n  assert(accountUpdateContract.owner);\n  assert(accountUpdateContract.hasOwnProperty('actives'));\n\n  const ownerAddress = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const owner: Permission = createPermission(accountUpdateContract.owner);\n  let witness: Permission | undefined = undefined;\n  if (accountUpdateContract.witness) {\n    witness = createPermission(accountUpdateContract.witness);\n  }\n  const activeList = accountUpdateContract.actives.map((active) => createPermission(active));\n\n  return {\n    ownerAddress,\n    owner,\n    witness,\n    actives: activeList,\n  };\n}\n\n/**\n * @param raw\n */\nfunction createPermission(raw: { permissionName: string; threshold: number }): Permission {\n  let permissionType: PermissionType;\n  const permission = raw.permissionName.toLowerCase().trim();\n  if (permission === 'owner') {\n    permissionType = PermissionType.Owner;\n  } else if (permission === 'witness') {\n    permissionType = PermissionType.Witness;\n  } else if (permission.substr(0, 6) === 'active') {\n    permissionType = PermissionType.Active;\n  } else {\n    throw new UtilsError('Permission type not parseable.');\n  }\n  return { type: permissionType, threshold: raw.threshold };\n}\n\n/**\n * @param rawTransaction\n */\nexport function isValidTxJsonString(rawTransaction: string): boolean {\n  const transaction = JSON.parse(rawTransaction);\n  return transaction.hasOwnProperty('txID');\n}\n\n/**\n * Returns whether the provided raw transaction accommodates to bitgo's preferred format\n *\n * @param {any} rawTransaction - The raw transaction to be checked\n * @returns {boolean} the validation result\n */\nexport function isValidRawTransactionFormat(rawTransaction: any): boolean {\n  if (typeof rawTransaction === 'string' && (isValidHex(rawTransaction) || isValidTxJsonString(rawTransaction))) {\n    return true;\n  }\n  return false;\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Returns a Keccak-256 encoded string of the parameters\n *\n * @param types - strings describing the types of the values\n * @param values - value to encode\n * @param methodId - the first 4 bytes of the function selector\n */\nexport function encodeDataParams(types: string[], values: any[], methodId?: string): string {\n  types.forEach((type, index) => {\n    if (type == 'address') {\n      values[index] = values[index].replace(ADDRESS_PREFIX_REGEX, '0x');\n    }\n  });\n\n  const abiCoder = new AbiCoder();\n  let data;\n  try {\n    data = abiCoder.encode(types, values);\n  } catch (e) {\n    throw new UtilsError('There was an error encoding the data params.');\n  }\n  if (methodId) {\n    return hexConcat([methodId, data]).replace(/^(0x)/, '');\n  } else {\n    return data.replace(/^(0x)/, '');\n  }\n}\n\n/**\n * Returns the decoded values according to the array of types\n *\n * @param types - strings describing the types of the values\n * @param data - encoded string\n */\nexport function decodeDataParams(types: string[], data: string): any[] {\n  const abiCoder = new AbiCoder();\n  data = '0x' + data.substring(8);\n  return abiCoder.decode(types, data).reduce((obj, arg, index) => {\n    if (types[index] == 'address') arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();\n    obj.push(arg);\n    return obj;\n  }, []);\n}\n"]}
440
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport * as hex from '@stablelib/hex';\nimport * as tronweb from 'tronweb';\nimport { protocol } from '../../resources/protobuf/tron';\n\nimport { UtilsError } from '@bitgo-beta/sdk-core';\nimport { TronErc20Coin, coins } from '@bitgo-beta/statics';\nimport {\n  TransferContract,\n  RawData,\n  AccountPermissionUpdateContract,\n  TransactionReceipt,\n  Permission,\n  TriggerSmartContract,\n} from './iface';\nimport { ContractType, PermissionType } from './enum';\nimport { AbiCoder, hexConcat } from 'ethers/lib/utils';\n\nconst ADDRESS_PREFIX_REGEX = /^(41)/;\nconst ADDRESS_PREFIX = '41';\n\nconst getTronTokens = (network = 'mainnet') => {\n  return (\n    coins\n      .filter((coin) => coin.family === 'trx')\n      .filter((trx) => trx.network.type === network && trx.isToken) as unknown as TronErc20Coin[]\n  ).map((coins) => coins.contractAddress.toString());\n};\n\nexport const tokenMainnetContractAddresses = getTronTokens('mainnet');\nexport const tokenTestnetContractAddresses = getTronTokens('testnet');\n/**\n * Tron-specific helper functions\n */\nexport type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;\nexport type ByteArray = number[];\n\n/**\n * @param address\n */\nexport function isBase58Address(address: string): boolean {\n  return tronweb.utils.crypto.isAddressValid(address);\n}\n\n/**\n * @param str\n */\nexport function getByteArrayFromHexAddress(str: string): ByteArray {\n  return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));\n}\n\n/**\n * @param arr\n */\nexport function getHexAddressFromByteArray(arr: ByteArray): string {\n  return tronweb.utils.code.byteArray2hexStr(arr);\n}\n\n/**\n * @param messageToVerify\n * @param base58Address\n * @param sigHex\n * @param useTronHeader\n */\nexport function verifySignature(\n  messageToVerify: string,\n  base58Address: string,\n  sigHex: string,\n  useTronHeader = true\n): boolean {\n  if (!isValidHex(sigHex)) {\n    throw new UtilsError('signature is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isValidHex(messageToVerify)) {\n    throw new UtilsError('message is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isBase58Address(base58Address)) {\n    throw new UtilsError('address needs to be base58 encoded');\n  }\n\n  return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);\n}\n\n/**\n * @param base58\n */\nexport function getHexAddressFromBase58Address(base58: string): string {\n  // pulled from: https://github.com/TRON-US/tronweb/blob/dcb8efa36a5ebb65c4dab3626e90256a453f3b0d/src/utils/help.js#L17\n  // but they don't surface this call in index.js\n  const bytes = tronweb.utils.crypto.decodeBase58Address(base58);\n  return getHexAddressFromByteArray(bytes);\n}\n\n/**\n * @param privateKey\n */\nexport function getPubKeyFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);\n}\n\n/**\n * @param privateKey\n */\nexport function getAddressFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getAddressFromPriKey(privateKey);\n}\n\n/**\n * @param address\n */\nexport function getBase58AddressFromByteArray(address: ByteArray): string {\n  return tronweb.utils.crypto.getBase58CheckAddress(address);\n}\n\n/**\n * @param hex\n */\nexport function getBase58AddressFromHex(hex: string): string {\n  const arr = getByteArrayFromHexAddress(hex);\n  return getBase58AddressFromByteArray(arr);\n}\n\n/**\n * @param privateKey\n * @param transaction\n */\nexport function signTransaction(privateKey: string | ByteArray, transaction: TransactionReceipt): TransactionReceipt {\n  return tronweb.utils.crypto.signTransaction(privateKey, transaction);\n}\n\n/**\n * @param message\n * @param privateKey\n * @param useTronHeader\n */\nexport function signString(message: string, privateKey: string | ByteArray, useTronHeader = true): string {\n  return tronweb.Trx.signString(message, privateKey, useTronHeader);\n}\n\n/**\n * @param pubBytes\n */\nexport function getRawAddressFromPubKey(pubBytes: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.computeAddress(pubBytes);\n}\n\n/**\n * Decodes a hex encoded transaction in its protobuf representation.\n *\n * @param hexString raw_data_hex field from tron transactions\n */\nexport function decodeTransaction(hexString: string): RawData {\n  const rawTransaction = decodeRawTransaction(hexString);\n\n  // there should not be multiple contracts in this data\n  if (rawTransaction.contracts.length !== 1) {\n    throw new UtilsError('Number of contracts is greater than 1.');\n  }\n\n  let contract: TransferContract[] | AccountPermissionUpdateContract[] | TriggerSmartContract[];\n  let contractType: ContractType;\n  // ensure the contract type is supported\n  switch (rawTransaction.contracts[0].parameter.type_url) {\n    case 'type.googleapis.com/protocol.TransferContract':\n      contractType = ContractType.Transfer;\n      contract = exports.decodeTransferContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.AccountPermissionUpdateContract':\n      contractType = ContractType.AccountPermissionUpdate;\n      contract = exports.decodeAccountPermissionUpdateContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.TriggerSmartContract':\n      contractType = ContractType.TriggerSmartContract;\n      contract = exports.decodeTriggerSmartContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    default:\n      throw new UtilsError('Unsupported contract type');\n  }\n\n  return {\n    contractType,\n    contract,\n    expiration: rawTransaction.expiration,\n    timestamp: rawTransaction.timestamp,\n    ref_block_bytes: rawTransaction.blockBytes,\n    ref_block_hash: rawTransaction.blockHash,\n    fee_limit: +rawTransaction.feeLimit,\n  };\n}\n\n/**\n * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.\n *\n * @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.\n * @example\n * @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}\n */\nexport function decodeRawTransaction(hexString: string): {\n  expiration: number;\n  timestamp: number;\n  contracts: Array<any>;\n  blockBytes: string;\n  blockHash: string;\n  feeLimit: string;\n} {\n  const bytes = Buffer.from(hexString, 'hex');\n\n  let raw;\n  try {\n    // we need to decode our raw_data_hex field first\n    raw = protocol.Transaction.raw.decode(bytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the initial raw_data_hex from the serialized tx.');\n  }\n\n  return {\n    expiration: Number(raw.expiration),\n    timestamp: Number(raw.timestamp),\n    contracts: raw.contract,\n    blockBytes: toHex(raw.refBlockBytes),\n    feeLimit: raw.feeLimit,\n    blockHash: toHex(raw.refBlockHash),\n  };\n}\n\n/**\n * Indicates whether the passed string is a safe hex string for tron's purposes.\n *\n * @param hex A valid hex string must be a string made of numbers and characters and has an even length.\n */\nexport function isValidHex(hex: string): boolean {\n  return /^(0x)?([0-9a-f]{2})+$/i.test(hex);\n}\n\n/** Deserialize the segment of the txHex which corresponds with the details of the transfer\n *\n * @param transferHex is the value property of the \"parameter\" field of contractList[0]\n * */\nexport function decodeTransferContract(transferHex: string): TransferContract[] {\n  const contractBytes = Buffer.from(transferHex, 'base64');\n  let transferContract;\n\n  try {\n    transferContract = protocol.TransferContract.decode(contractBytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the transfer contract in the transaction.');\n  }\n\n  if (!transferContract.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.toAddress) {\n    throw new UtilsError('Destination address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.hasOwnProperty('amount')) {\n    throw new UtilsError('Amount does not exist in this transfer contract.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const to_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.toAddress, 'base64').toString('hex'))\n  );\n  const amount = transferContract.amount;\n\n  return [\n    {\n      parameter: {\n        value: {\n          amount: Number(amount),\n          owner_address,\n          to_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with trigger smart contract\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeTriggerSmartContract(base64: string): TriggerSmartContract[] {\n  let contractCallDecoded;\n  try {\n    contractCallDecoded = protocol.TriggerSmartContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the contract call in the transaction.');\n  }\n\n  if (!contractCallDecoded.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.contractAddress) {\n    throw new UtilsError('Destination contract address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.data) {\n    throw new UtilsError('Data does not exist in this contract call.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.ownerAddress, 'base64').toString('hex'))\n  );\n  const contract_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.contractAddress, 'base64').toString('hex'))\n  );\n  const data = contractCallDecoded.data;\n  return [\n    {\n      parameter: {\n        value: {\n          data: data,\n          owner_address,\n          contract_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with the details of the contract which updates\n * account permission\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeAccountPermissionUpdateContract(base64: string): AccountPermissionUpdateContract {\n  const accountUpdateContract = protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  assert(accountUpdateContract.ownerAddress);\n  assert(accountUpdateContract.owner);\n  assert(accountUpdateContract.hasOwnProperty('actives'));\n\n  const ownerAddress = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const owner: Permission = createPermission(accountUpdateContract.owner);\n  let witness: Permission | undefined = undefined;\n  if (accountUpdateContract.witness) {\n    witness = createPermission(accountUpdateContract.witness);\n  }\n  const activeList = accountUpdateContract.actives.map((active) => createPermission(active));\n\n  return {\n    ownerAddress,\n    owner,\n    witness,\n    actives: activeList,\n  };\n}\n\n/**\n * @param raw\n */\nfunction createPermission(raw: { permissionName: string; threshold: number }): Permission {\n  let permissionType: PermissionType;\n  const permission = raw.permissionName.toLowerCase().trim();\n  if (permission === 'owner') {\n    permissionType = PermissionType.Owner;\n  } else if (permission === 'witness') {\n    permissionType = PermissionType.Witness;\n  } else if (permission.substr(0, 6) === 'active') {\n    permissionType = PermissionType.Active;\n  } else {\n    throw new UtilsError('Permission type not parseable.');\n  }\n  return { type: permissionType, threshold: raw.threshold };\n}\n\n/**\n * @param rawTransaction\n */\nexport function isValidTxJsonString(rawTransaction: string): boolean {\n  const transaction = JSON.parse(rawTransaction);\n  return transaction.hasOwnProperty('txID');\n}\n\n/**\n * Returns whether the provided raw transaction accommodates to bitgo's preferred format\n *\n * @param {any} rawTransaction - The raw transaction to be checked\n * @returns {boolean} the validation result\n */\nexport function isValidRawTransactionFormat(rawTransaction: any): boolean {\n  if (typeof rawTransaction === 'string' && (isValidHex(rawTransaction) || isValidTxJsonString(rawTransaction))) {\n    return true;\n  }\n  return false;\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Returns a Keccak-256 encoded string of the parameters\n *\n * @param types - strings describing the types of the values\n * @param values - value to encode\n * @param methodId - the first 4 bytes of the function selector\n */\nexport function encodeDataParams(types: string[], values: any[], methodId?: string): string {\n  types.forEach((type, index) => {\n    if (type == 'address') {\n      values[index] = values[index].replace(ADDRESS_PREFIX_REGEX, '0x');\n    }\n  });\n\n  const abiCoder = new AbiCoder();\n  let data;\n  try {\n    data = abiCoder.encode(types, values);\n  } catch (e) {\n    throw new UtilsError(`There was an error encoding the data params. Error = ${JSON.stringify(e)}`);\n  }\n  if (methodId) {\n    return hexConcat([methodId, data]).replace(/^(0x)/, '');\n  } else {\n    return data.replace(/^(0x)/, '');\n  }\n}\n\n/**\n * Returns the decoded values according to the array of types\n *\n * @param types - strings describing the types of the values\n * @param data - encoded string\n */\nexport function decodeDataParams(types: string[], data: string): any[] {\n  const abiCoder = new AbiCoder();\n  data = '0x' + data.substring(8);\n  return abiCoder.decode(types, data).reduce((obj, arg, index) => {\n    if (types[index] == 'address') arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();\n    obj.push(arg);\n    return obj;\n  }, []);\n}\n"]}