PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-trx/dist/src/lib
Просмотр файла: transaction.js
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Transaction = void 0;
const crypto_1 = require("crypto");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const tron_1 = require("../../resources/protobuf/tron");
const sdk_core_1 = require("@bitgo/sdk-core");
const enum_1 = require("./enum");
const utils_1 = require("./utils");
/**
* Tron transaction model.
*/
class Transaction extends sdk_core_1.BaseTransaction {
/**
* Public constructor.
*
* @param coinConfig
* @param rawTransaction
*/
constructor(coinConfig, rawTransaction) {
super(coinConfig);
if (rawTransaction) {
if (!rawTransaction.txID) {
throw new sdk_core_1.ParseTransactionError('Transaction has no id');
}
this._id = rawTransaction.txID;
this._transaction = rawTransaction;
this._decodedRawDataHex = (0, utils_1.decodeTransaction)(rawTransaction.raw_data_hex);
// Destination depends on the contract type
this.recordRawDataFields(this._decodedRawDataHex);
}
}
/**
* Parse the transaction raw data and record the most important fields.
*
* @param rawData Object from a tron transaction
*/
recordRawDataFields(rawData) {
// Contract-agnostic fields
this._validFrom = rawData.timestamp;
this._validTo = rawData.expiration;
let output, input;
// Contract-specific fields
switch (rawData.contractType) {
case enum_1.ContractType.Transfer:
this._type = sdk_core_1.TransactionType.Send;
const value = new bignumber_js_1.default(rawData.contract[0].parameter.value.amount).toFixed(0);
output = {
address: rawData.contract[0].parameter.value.to_address,
value,
};
input = {
address: rawData.contract[0].parameter.value.owner_address,
value,
};
break;
case enum_1.ContractType.AccountPermissionUpdate:
this._type = sdk_core_1.TransactionType.WalletInitialization;
output = {
address: rawData.contract.owner_address,
value: '0',
};
input = {
address: rawData.contract.owner_address,
value: '0',
};
break;
case enum_1.ContractType.TriggerSmartContract:
this._type = sdk_core_1.TransactionType.ContractCall;
const contractCallValues = rawData.contract[0].parameter.value;
const contractAddress = contractCallValues.contract_address;
if (utils_1.tokenMainnetContractAddresses.includes(contractAddress) ||
utils_1.tokenTestnetContractAddresses.includes(contractAddress)) {
// this is then a token smart contract transaction and the data must be decoded
const types = ['address', 'uint256'];
const data = Buffer.from(contractCallValues.data, 'base64').toString('hex');
const decodedData = (0, utils_1.decodeDataParams)(types, data);
const recipient_address = (0, utils_1.getBase58AddressFromHex)(decodedData[0]);
const value = decodedData[1].toString();
output = {
address: recipient_address,
value,
};
input = {
address: contractCallValues.owner_address,
contractAddress,
data,
value,
};
break;
}
output = {
address: contractCallValues.owner_address,
value: '0',
};
input = {
address: contractCallValues.owner_address,
contractAddress,
data: contractCallValues.data,
value: '0',
};
break;
default:
throw new sdk_core_1.ParseTransactionError('Unsupported contract type');
}
this._inputs = [input];
this._outputs = [output];
}
/**
* Recalculate and update the transaction id. This should be done after changing any transaction
* field since the the id is a hash of the transaction body.
*/
updateId() {
if (!this._transaction) {
throw new sdk_core_1.ParseTransactionError('Empty transaction');
}
const hexBuffer = Buffer.from(this._transaction.raw_data_hex, 'hex');
const newTxid = (0, crypto_1.createHash)('sha256').update(hexBuffer).digest('hex');
this._transaction.txID = newTxid;
this._id = newTxid;
}
/**
* Extend the expiration date by the given number of milliseconds.
*
* @param extensionMs The number of milliseconds to extend the expiration by
*/
extendExpiration(extensionMs) {
if (extensionMs < 0) {
throw new sdk_core_1.ExtendTransactionError('Invalid extension range. Must be positive a integer');
}
if (!this._transaction) {
throw new sdk_core_1.ExtendTransactionError('Empty transaction');
}
if (this._transaction.signature && this._transaction.signature.length > 0) {
throw new sdk_core_1.ExtendTransactionError('Cannot extend a signed transaction');
}
const rawDataHex = this._transaction.raw_data_hex;
const bytes = Buffer.from(rawDataHex, 'hex');
let raw;
try {
raw = tron_1.protocol.Transaction.raw.decode(bytes);
const newExpiration = new bignumber_js_1.default(raw.expiration).plus(extensionMs).toNumber();
raw.expiration = newExpiration;
const newRawDataHex = Buffer.from(tron_1.protocol.Transaction.raw.encode(raw).finish()).toString('hex');
// Set the internal variables to account for the new expiration date
this._transaction.raw_data_hex = newRawDataHex;
this._transaction.raw_data.expiration = newExpiration;
this._decodedRawDataHex = (0, utils_1.decodeTransaction)(newRawDataHex);
this.recordRawDataFields(this._decodedRawDataHex);
this.updateId();
}
catch (e) {
throw new sdk_core_1.ExtendTransactionError('There was an error decoding the initial raw_data_hex from the serialized tx.');
}
}
/**
* Get the signatures associated with this transaction.
*/
get signature() {
if (this._transaction && this._transaction.signature) {
return this._transaction.signature;
}
return [];
}
/**
* Get the time in milliseconds this transaction becomes valid and can be broadcasted to the
* network.
*/
get validFrom() {
return this._validFrom;
}
/**
* Get the expiration time in milliseconds.
*/
get validTo() {
return this._validTo;
}
/** @inheritdoc */
get outputs() {
return this._outputs;
}
/** @inheritdoc */
get inputs() {
return this._inputs;
}
/** @inheritdoc */
canSign(key) {
// Tron transaction do not contain the owners account address so it is not possible to check the
// private key with any but the account main address. This is not enough to fail this check, so
// it is a no-op.
return true;
}
/**
* Sets this transaction
*
* @param {Transaction} tx transaction
*/
setTransactionReceipt(tx) {
this._transaction = tx;
this.updateId();
}
/**
* Set the transaction type
*
* @param {TransactionType} transactionType The transaction type to be set
*/
setTransactionType(transactionType) {
this._type = transactionType;
}
/** @inheritdoc */
toJson() {
if (!this._transaction) {
throw new sdk_core_1.ParseTransactionError('Empty transaction');
}
return this._transaction;
}
/** @inheritdoc */
toBroadcastFormat() {
return JSON.stringify(this.toJson());
}
}
exports.Transaction = Transaction;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport BigNumber from 'bignumber.js';\nimport { protocol } from '../../resources/protobuf/tron';\nimport {\n  BaseKey,\n  BaseTransaction,\n  ExtendTransactionError,\n  ParseTransactionError,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { ContractType } from './enum';\nimport {\n  decodeTransaction,\n  decodeDataParams,\n  getBase58AddressFromHex,\n  tokenMainnetContractAddresses,\n  tokenTestnetContractAddresses,\n} from './utils';\nimport { ContractEntry, RawData, TransactionReceipt, TransferContract, TriggerSmartContract } from './iface';\n\n/**\n * Tron transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  // Tron specific fields\n  protected _validFrom: number;\n  protected _validTo: number;\n  protected _inputs: ContractEntry[];\n  protected _outputs: ContractEntry[];\n\n  private _decodedRawDataHex: RawData;\n  private _transaction?: TransactionReceipt;\n\n  /**\n   * Public constructor.\n   *\n   * @param coinConfig\n   * @param rawTransaction\n   */\n  constructor(coinConfig: Readonly<CoinConfig>, rawTransaction?: TransactionReceipt) {\n    super(coinConfig);\n    if (rawTransaction) {\n      if (!rawTransaction.txID) {\n        throw new ParseTransactionError('Transaction has no id');\n      }\n      this._id = rawTransaction.txID;\n      this._transaction = rawTransaction;\n      this._decodedRawDataHex = decodeTransaction(rawTransaction.raw_data_hex);\n\n      // Destination depends on the contract type\n      this.recordRawDataFields(this._decodedRawDataHex);\n    }\n  }\n\n  /**\n   * Parse the transaction raw data and record the most important fields.\n   *\n   * @param rawData Object from a tron transaction\n   */\n  private recordRawDataFields(rawData: RawData) {\n    // Contract-agnostic fields\n    this._validFrom = rawData.timestamp;\n    this._validTo = rawData.expiration;\n\n    let output: ContractEntry, input: ContractEntry;\n    // Contract-specific fields\n    switch (rawData.contractType) {\n      case ContractType.Transfer:\n        this._type = TransactionType.Send;\n        const value = new BigNumber((rawData.contract[0] as TransferContract).parameter.value.amount).toFixed(0);\n        output = {\n          address: (rawData.contract[0] as TransferContract).parameter.value.to_address,\n          value,\n        };\n        input = {\n          address: (rawData.contract[0] as TransferContract).parameter.value.owner_address,\n          value,\n        };\n        break;\n      case ContractType.AccountPermissionUpdate:\n        this._type = TransactionType.WalletInitialization;\n        output = {\n          address: (rawData.contract as any).owner_address,\n          value: '0',\n        };\n        input = {\n          address: (rawData.contract as any).owner_address,\n          value: '0',\n        };\n        break;\n      case ContractType.TriggerSmartContract:\n        this._type = TransactionType.ContractCall;\n        const contractCallValues = (rawData.contract[0] as TriggerSmartContract).parameter.value;\n        const contractAddress = contractCallValues.contract_address;\n        if (\n          tokenMainnetContractAddresses.includes(contractAddress) ||\n          tokenTestnetContractAddresses.includes(contractAddress)\n        ) {\n          // this is then a token smart contract transaction and the data must be decoded\n          const types = ['address', 'uint256'];\n          const data = Buffer.from(contractCallValues.data, 'base64').toString('hex');\n          const decodedData = decodeDataParams(types, data);\n          const recipient_address = getBase58AddressFromHex(decodedData[0]);\n          const value = decodedData[1].toString();\n          output = {\n            address: recipient_address,\n            value,\n          };\n          input = {\n            address: contractCallValues.owner_address,\n            contractAddress,\n            data,\n            value,\n          };\n          break;\n        }\n        output = {\n          address: contractCallValues.owner_address,\n          value: '0',\n        };\n        input = {\n          address: contractCallValues.owner_address,\n          contractAddress,\n          data: contractCallValues.data,\n          value: '0',\n        };\n        break;\n      default:\n        throw new ParseTransactionError('Unsupported contract type');\n    }\n    this._inputs = [input];\n    this._outputs = [output];\n  }\n\n  /**\n   * Recalculate and update the transaction id. This should be done after changing any transaction\n   * field since the the id is a hash of the transaction body.\n   */\n  private updateId(): void {\n    if (!this._transaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const hexBuffer = Buffer.from(this._transaction.raw_data_hex, 'hex');\n    const newTxid = createHash('sha256').update(hexBuffer).digest('hex');\n    this._transaction.txID = newTxid;\n    this._id = newTxid;\n  }\n\n  /**\n   * Extend the expiration date by the given number of milliseconds.\n   *\n   * @param extensionMs The number of milliseconds to extend the expiration by\n   */\n  extendExpiration(extensionMs: number): void {\n    if (extensionMs < 0) {\n      throw new ExtendTransactionError('Invalid extension range. Must be positive a integer');\n    }\n\n    if (!this._transaction) {\n      throw new ExtendTransactionError('Empty transaction');\n    }\n\n    if (this._transaction.signature && this._transaction.signature.length > 0) {\n      throw new ExtendTransactionError('Cannot extend a signed transaction');\n    }\n\n    const rawDataHex = this._transaction.raw_data_hex;\n    const bytes = Buffer.from(rawDataHex, 'hex');\n    let raw;\n    try {\n      raw = protocol.Transaction.raw.decode(bytes);\n      const newExpiration = new BigNumber(raw.expiration).plus(extensionMs).toNumber();\n      raw.expiration = newExpiration;\n      const newRawDataHex = Buffer.from(protocol.Transaction.raw.encode(raw).finish()).toString('hex');\n      // Set the internal variables to account for the new expiration date\n      this._transaction.raw_data_hex = newRawDataHex;\n      this._transaction.raw_data.expiration = newExpiration;\n      this._decodedRawDataHex = decodeTransaction(newRawDataHex);\n      this.recordRawDataFields(this._decodedRawDataHex);\n      this.updateId();\n    } catch (e) {\n      throw new ExtendTransactionError('There was an error decoding the initial raw_data_hex from the serialized tx.');\n    }\n  }\n\n  /**\n   * Get the signatures associated with this transaction.\n   */\n  get signature(): string[] {\n    if (this._transaction && this._transaction.signature) {\n      return this._transaction.signature;\n    }\n    return [];\n  }\n  /**\n   * Get the time in milliseconds this transaction becomes valid and can be broadcasted to the\n   * network.\n   */\n  get validFrom(): number {\n    return this._validFrom;\n  }\n\n  /**\n   * Get the expiration time in milliseconds.\n   */\n  get validTo(): number {\n    return this._validTo;\n  }\n\n  /** @inheritdoc */\n  get outputs(): ContractEntry[] {\n    return this._outputs;\n  }\n\n  /** @inheritdoc */\n  get inputs(): ContractEntry[] {\n    return this._inputs;\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // Tron transaction do not contain the owners account address so it is not possible to check the\n    // private key with any but the account main address. This is not enough to fail this check, so\n    // it is a no-op.\n    return true;\n  }\n\n  /**\n   * Sets this transaction\n   *\n   * @param {Transaction} tx transaction\n   */\n  setTransactionReceipt(tx: TransactionReceipt) {\n    this._transaction = tx;\n    this.updateId();\n  }\n\n  /**\n   * Set the transaction type\n   *\n   * @param {TransactionType} transactionType The transaction type to be set\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  /** @inheritdoc */\n  toJson(): TransactionReceipt {\n    if (!this._transaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): any {\n    return JSON.stringify(this.toJson());\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!