PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-trx/dist/src/lib
Просмотр файла: utils.js
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.tokenTestnetContractAddresses = exports.tokenMainnetContractAddresses = void 0;
exports.isBase58Address = isBase58Address;
exports.getByteArrayFromHexAddress = getByteArrayFromHexAddress;
exports.getHexAddressFromByteArray = getHexAddressFromByteArray;
exports.verifySignature = verifySignature;
exports.getHexAddressFromBase58Address = getHexAddressFromBase58Address;
exports.getPubKeyFromPriKey = getPubKeyFromPriKey;
exports.getAddressFromPriKey = getAddressFromPriKey;
exports.getBase58AddressFromByteArray = getBase58AddressFromByteArray;
exports.getBase58AddressFromHex = getBase58AddressFromHex;
exports.signTransaction = signTransaction;
exports.signString = signString;
exports.getRawAddressFromPubKey = getRawAddressFromPubKey;
exports.decodeTransaction = decodeTransaction;
exports.decodeRawTransaction = decodeRawTransaction;
exports.isValidHex = isValidHex;
exports.decodeTransferContract = decodeTransferContract;
exports.decodeTriggerSmartContract = decodeTriggerSmartContract;
exports.decodeAccountPermissionUpdateContract = decodeAccountPermissionUpdateContract;
exports.isValidTxJsonString = isValidTxJsonString;
exports.isValidRawTransactionFormat = isValidRawTransactionFormat;
exports.toHex = toHex;
exports.encodeDataParams = encodeDataParams;
exports.decodeDataParams = decodeDataParams;
const assert_1 = __importDefault(require("assert"));
const hex = __importStar(require("@stablelib/hex"));
const tronweb = __importStar(require("tronweb"));
const tron_1 = require("../../resources/protobuf/tron");
const sdk_core_1 = require("@bitgo/sdk-core");
const statics_1 = require("@bitgo/statics");
const enum_1 = require("./enum");
const utils_1 = require("ethers/lib/utils");
const ADDRESS_PREFIX_REGEX = /^(41)/;
const ADDRESS_PREFIX = '41';
const getTronTokens = (network = 'mainnet') => {
return statics_1.coins
.filter((coin) => coin.family === 'trx')
.filter((trx) => trx.network.type === network && trx.isToken).map((coins) => coins.contractAddress.toString());
};
exports.tokenMainnetContractAddresses = getTronTokens('mainnet');
exports.tokenTestnetContractAddresses = getTronTokens('testnet');
/**
* @param address
*/
function isBase58Address(address) {
return tronweb.utils.crypto.isAddressValid(address);
}
/**
* @param str
*/
function getByteArrayFromHexAddress(str) {
return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));
}
/**
* @param arr
*/
function getHexAddressFromByteArray(arr) {
return tronweb.utils.code.byteArray2hexStr(arr);
}
/**
* @param messageToVerify
* @param base58Address
* @param sigHex
* @param useTronHeader
*/
function verifySignature(messageToVerify, base58Address, sigHex, useTronHeader = true) {
if (!isValidHex(sigHex)) {
throw new sdk_core_1.UtilsError('signature is not in a valid format, needs to be hexadecimal');
}
if (!isValidHex(messageToVerify)) {
throw new sdk_core_1.UtilsError('message is not in a valid format, needs to be hexadecimal');
}
if (!isBase58Address(base58Address)) {
throw new sdk_core_1.UtilsError('address needs to be base58 encoded');
}
return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);
}
/**
* @param base58
*/
function getHexAddressFromBase58Address(base58) {
// pulled from: https://github.com/TRON-US/tronweb/blob/dcb8efa36a5ebb65c4dab3626e90256a453f3b0d/src/utils/help.js#L17
// but they don't surface this call in index.js
const bytes = tronweb.utils.crypto.decodeBase58Address(base58);
return getHexAddressFromByteArray(bytes);
}
/**
* @param privateKey
*/
function getPubKeyFromPriKey(privateKey) {
return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);
}
/**
* @param privateKey
*/
function getAddressFromPriKey(privateKey) {
return tronweb.utils.crypto.getAddressFromPriKey(privateKey);
}
/**
* @param address
*/
function getBase58AddressFromByteArray(address) {
return tronweb.utils.crypto.getBase58CheckAddress(address);
}
/**
* @param hex
*/
function getBase58AddressFromHex(hex) {
const arr = getByteArrayFromHexAddress(hex);
return getBase58AddressFromByteArray(arr);
}
/**
* @param privateKey
* @param transaction
*/
function signTransaction(privateKey, transaction) {
return tronweb.utils.crypto.signTransaction(privateKey, transaction);
}
/**
* @param message
* @param privateKey
* @param useTronHeader
*/
function signString(message, privateKey, useTronHeader = true) {
return tronweb.Trx.signString(message, privateKey, useTronHeader);
}
/**
* @param pubBytes
*/
function getRawAddressFromPubKey(pubBytes) {
return tronweb.utils.crypto.computeAddress(pubBytes);
}
/**
* Decodes a hex encoded transaction in its protobuf representation.
*
* @param hexString raw_data_hex field from tron transactions
*/
function decodeTransaction(hexString) {
const rawTransaction = decodeRawTransaction(hexString);
// there should not be multiple contracts in this data
if (rawTransaction.contracts.length !== 1) {
throw new sdk_core_1.UtilsError('Number of contracts is greater than 1.');
}
let contract;
let contractType;
// ensure the contract type is supported
switch (rawTransaction.contracts[0].parameter.type_url) {
case 'type.googleapis.com/protocol.TransferContract':
contractType = enum_1.ContractType.Transfer;
contract = exports.decodeTransferContract(rawTransaction.contracts[0].parameter.value);
break;
case 'type.googleapis.com/protocol.AccountPermissionUpdateContract':
contractType = enum_1.ContractType.AccountPermissionUpdate;
contract = exports.decodeAccountPermissionUpdateContract(rawTransaction.contracts[0].parameter.value);
break;
case 'type.googleapis.com/protocol.TriggerSmartContract':
contractType = enum_1.ContractType.TriggerSmartContract;
contract = exports.decodeTriggerSmartContract(rawTransaction.contracts[0].parameter.value);
break;
default:
throw new sdk_core_1.UtilsError('Unsupported contract type');
}
return {
contractType,
contract,
expiration: rawTransaction.expiration,
timestamp: rawTransaction.timestamp,
ref_block_bytes: rawTransaction.blockBytes,
ref_block_hash: rawTransaction.blockHash,
fee_limit: +rawTransaction.feeLimit,
};
}
/**
* Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.
*
* @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.
* @example
* @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}
*/
function decodeRawTransaction(hexString) {
const bytes = Buffer.from(hexString, 'hex');
let raw;
try {
// we need to decode our raw_data_hex field first
raw = tron_1.protocol.Transaction.raw.decode(bytes);
}
catch (e) {
throw new sdk_core_1.UtilsError('There was an error decoding the initial raw_data_hex from the serialized tx.');
}
return {
expiration: Number(raw.expiration),
timestamp: Number(raw.timestamp),
contracts: raw.contract,
blockBytes: toHex(raw.refBlockBytes),
feeLimit: raw.feeLimit,
blockHash: toHex(raw.refBlockHash),
};
}
/**
* Indicates whether the passed string is a safe hex string for tron's purposes.
*
* @param hex A valid hex string must be a string made of numbers and characters and has an even length.
*/
function isValidHex(hex) {
return /^(0x)?([0-9a-f]{2})+$/i.test(hex);
}
/** Deserialize the segment of the txHex which corresponds with the details of the transfer
*
* @param transferHex is the value property of the "parameter" field of contractList[0]
* */
function decodeTransferContract(transferHex) {
const contractBytes = Buffer.from(transferHex, 'base64');
let transferContract;
try {
transferContract = tron_1.protocol.TransferContract.decode(contractBytes);
}
catch (e) {
throw new sdk_core_1.UtilsError('There was an error decoding the transfer contract in the transaction.');
}
if (!transferContract.ownerAddress) {
throw new sdk_core_1.UtilsError('Owner address does not exist in this transfer contract.');
}
if (!transferContract.toAddress) {
throw new sdk_core_1.UtilsError('Destination address does not exist in this transfer contract.');
}
if (!transferContract.hasOwnProperty('amount')) {
throw new sdk_core_1.UtilsError('Amount does not exist in this transfer contract.');
}
// deserialize attributes
const owner_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(transferContract.ownerAddress, 'base64').toString('hex')));
const to_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(transferContract.toAddress, 'base64').toString('hex')));
const amount = transferContract.amount;
return [
{
parameter: {
value: {
amount: Number(amount),
owner_address,
to_address,
},
},
},
];
}
/**
* Deserialize the segment of the txHex corresponding with trigger smart contract
*
* @param {string} base64
* @returns {AccountPermissionUpdateContract}
*/
function decodeTriggerSmartContract(base64) {
let contractCallDecoded;
try {
contractCallDecoded = tron_1.protocol.TriggerSmartContract.decode(Buffer.from(base64, 'base64')).toJSON();
}
catch (e) {
throw new sdk_core_1.UtilsError('There was an error decoding the contract call in the transaction.');
}
if (!contractCallDecoded.ownerAddress) {
throw new sdk_core_1.UtilsError('Owner address does not exist in this contract call.');
}
if (!contractCallDecoded.contractAddress) {
throw new sdk_core_1.UtilsError('Destination contract address does not exist in this contract call.');
}
if (!contractCallDecoded.data) {
throw new sdk_core_1.UtilsError('Data does not exist in this contract call.');
}
// deserialize attributes
const owner_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.ownerAddress, 'base64').toString('hex')));
const contract_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.contractAddress, 'base64').toString('hex')));
const data = contractCallDecoded.data;
return [
{
parameter: {
value: {
data: data,
owner_address,
contract_address,
},
},
},
];
}
/**
* Deserialize the segment of the txHex corresponding with the details of the contract which updates
* account permission
*
* @param {string} base64
* @returns {AccountPermissionUpdateContract}
*/
function decodeAccountPermissionUpdateContract(base64) {
const accountUpdateContract = tron_1.protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();
(0, assert_1.default)(accountUpdateContract.ownerAddress);
(0, assert_1.default)(accountUpdateContract.owner);
(0, assert_1.default)(accountUpdateContract.hasOwnProperty('actives'));
const ownerAddress = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex')));
const owner = createPermission(accountUpdateContract.owner);
let witness = undefined;
if (accountUpdateContract.witness) {
witness = createPermission(accountUpdateContract.witness);
}
const activeList = accountUpdateContract.actives.map((active) => createPermission(active));
return {
ownerAddress,
owner,
witness,
actives: activeList,
};
}
/**
* @param raw
*/
function createPermission(raw) {
let permissionType;
const permission = raw.permissionName.toLowerCase().trim();
if (permission === 'owner') {
permissionType = enum_1.PermissionType.Owner;
}
else if (permission === 'witness') {
permissionType = enum_1.PermissionType.Witness;
}
else if (permission.substr(0, 6) === 'active') {
permissionType = enum_1.PermissionType.Active;
}
else {
throw new sdk_core_1.UtilsError('Permission type not parseable.');
}
return { type: permissionType, threshold: raw.threshold };
}
/**
* @param rawTransaction
*/
function isValidTxJsonString(rawTransaction) {
const transaction = JSON.parse(rawTransaction);
return transaction.hasOwnProperty('txID');
}
/**
* Returns whether the provided raw transaction accommodates to bitgo's preferred format
*
* @param {any} rawTransaction - The raw transaction to be checked
* @returns {boolean} the validation result
*/
function isValidRawTransactionFormat(rawTransaction) {
if (typeof rawTransaction === 'string' && (isValidHex(rawTransaction) || isValidTxJsonString(rawTransaction))) {
return true;
}
return false;
}
/**
* Returns an hex string of the given buffer
*
* @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex
* @returns {string} - the hex value
*/
function toHex(buffer) {
return hex.encode(buffer, true);
}
/**
* Returns a Keccak-256 encoded string of the parameters
*
* @param types - strings describing the types of the values
* @param values - value to encode
* @param methodId - the first 4 bytes of the function selector
*/
function encodeDataParams(types, values, methodId) {
types.forEach((type, index) => {
if (type == 'address') {
values[index] = values[index].replace(ADDRESS_PREFIX_REGEX, '0x');
}
});
const abiCoder = new utils_1.AbiCoder();
let data;
try {
data = abiCoder.encode(types, values);
}
catch (e) {
throw new sdk_core_1.UtilsError(`There was an error encoding the data params. Error = ${JSON.stringify(e)}`);
}
if (methodId) {
return (0, utils_1.hexConcat)([methodId, data]).replace(/^(0x)/, '');
}
else {
return data.replace(/^(0x)/, '');
}
}
/**
* Returns the decoded values according to the array of types
*
* @param types - strings describing the types of the values
* @param data - encoded string
*/
function decodeDataParams(types, data) {
const abiCoder = new utils_1.AbiCoder();
data = '0x' + data.substring(8);
return abiCoder.decode(types, data).reduce((obj, arg, index) => {
if (types[index] == 'address')
arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();
obj.push(arg);
return obj;
}, []);
}
//# 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/sdk-core';\nimport { TronErc20Coin, coins } from '@bitgo/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"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!