PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-coin-vet/dist/src/lib/transactionBuilder

Просмотр файла: stakingBuilder.js

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.StakingBuilder = void 0;
const assert_1 = __importDefault(require("assert"));
const sdk_core_1 = require("@bitgo/sdk-core");
const transactionBuilder_1 = require("./transactionBuilder");
const stakingTransaction_1 = require("../transaction/stakingTransaction");
const utils_1 = __importDefault(require("../utils"));
class StakingBuilder extends transactionBuilder_1.TransactionBuilder {
    /**
     * Creates a new StakingBuilder instance.
     *
     * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object
     */
    constructor(_coinConfig) {
        super(_coinConfig);
        this._transaction = new stakingTransaction_1.StakingTransaction(_coinConfig);
    }
    /**
     * Initializes the builder with an existing StakingTransaction.
     *
     * @param {StakingTransaction} tx - The transaction to initialize the builder with
     */
    initBuilder(tx) {
        this._transaction = tx;
    }
    /**
     * Gets the staking transaction instance.
     *
     * @returns {StakingTransaction} The staking transaction
     */
    get stakingTransaction() {
        return this._transaction;
    }
    /**
     * Gets the transaction type for staking.
     *
     * @returns {TransactionType} The transaction type
     */
    get transactionType() {
        return sdk_core_1.TransactionType.ContractCall;
    }
    /**
     * Validates the transaction clauses for staking transaction.
     * @param {TransactionClause[]} clauses - The transaction clauses to validate.
     * @returns {boolean} - Returns true if the clauses are valid, false otherwise.
     */
    isValidTransactionClauses(clauses) {
        try {
            if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {
                return false;
            }
            const clause = clauses[0];
            if (!clause.to || !utils_1.default.isValidAddress(clause.to)) {
                return false;
            }
            // For staking transactions, value must be greater than 0
            if (!clause.value || clause.value === '0x0' || clause.value === '0') {
                return false;
            }
            return true;
        }
        catch (e) {
            return false;
        }
    }
    /**
     * Sets the staking contract address for this staking tx.
     *
     * @param {string} address - The staking contract address
     * @returns {StakingBuilder} This transaction builder
     */
    stakingContractAddress(address) {
        this.validateAddress({ address });
        this.stakingTransaction.stakingContractAddress = address;
        return this;
    }
    /**
     * Sets the amount to stake for this staking tx.
     *
     * @param {string} amount - The amount to stake in wei
     * @returns {StakingBuilder} This transaction builder
     */
    amountToStake(amount) {
        this.stakingTransaction.amountToStake = amount;
        return this;
    }
    /**
     * Sets the staking contract ABI for this staking tx.
     *
     * @param {EthereumAbi} abi - The staking contract ABI
     * @returns {StakingBuilder} This transaction builder
     */
    stakingContractABI(abi) {
        this.stakingTransaction.stakingContractABI = abi;
        return this;
    }
    /**
     * Sets the transaction data for this staking tx.
     *
     * @param {string} data - The transaction data
     * @returns {StakingBuilder} This transaction builder
     */
    transactionData(data) {
        this.stakingTransaction.transactionData = data;
        return this;
    }
    /** @inheritdoc */
    validateTransaction(transaction) {
        if (!transaction) {
            throw new Error('transaction not defined');
        }
        (0, assert_1.default)(transaction.stakingContractAddress, 'Staking contract address is required');
        (0, assert_1.default)(transaction.amountToStake, 'Amount to stake is required');
        (0, assert_1.default)(transaction.stakingContractABI, 'Staking contract ABI is required');
        this.validateAddress({ address: transaction.stakingContractAddress });
    }
    /** @inheritdoc */
    async buildImplementation() {
        this.transaction.type = this.transactionType;
        await this.stakingTransaction.build();
        return this.transaction;
    }
}
exports.StakingBuilder = StakingBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transactionBuilder/stakingBuilder.ts"],"names":[],"mappings":";;;;;;AAAA,oDAA4B;AAE5B,8CAAkD;AAGlD,6DAA0D;AAE1D,0EAAuE;AAEvE,qDAA6B;AAE7B,MAAa,cAAe,SAAQ,uCAAkB;IACpD;;;;OAIG;IACH,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,uCAAkB,CAAC,WAAW,CAAC,CAAC;IAC1D,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,EAAsB;QAChC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACH,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,YAAkC,CAAC;IACjD,CAAC;IAED;;;;OAIG;IACH,IAAc,eAAe;QAC3B,OAAO,0BAAe,CAAC,YAAY,CAAC;IACtC,CAAC;IAED;;;;OAIG;IACO,yBAAyB,CAAC,OAA4B;QAC9D,IAAI,CAAC;YACH,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAChE,OAAO,KAAK,CAAC;YACf,CAAC;YAED,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YAE1B,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,eAAK,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;gBACnD,OAAO,KAAK,CAAC;YACf,CAAC;YAED,yDAAyD;YACzD,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,KAAK,KAAK,IAAI,MAAM,CAAC,KAAK,KAAK,GAAG,EAAE,CAAC;gBACpE,OAAO,KAAK,CAAC;YACf,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,sBAAsB,CAAC,OAAe;QACpC,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QAClC,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,GAAG,OAAO,CAAC;QACzD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,MAAc;QAC1B,IAAI,CAAC,kBAAkB,CAAC,aAAa,GAAG,MAAM,CAAC;QAC/C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,GAAgB;QACjC,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,GAAG,GAAG,CAAC;QACjD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,IAAY;QAC1B,IAAI,CAAC,kBAAkB,CAAC,eAAe,GAAG,IAAI,CAAC;QAC/C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,kBAAkB;IAClB,mBAAmB,CAAC,WAAgC;QAClD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QACD,IAAA,gBAAM,EAAC,WAAW,CAAC,sBAAsB,EAAE,sCAAsC,CAAC,CAAC;QACnF,IAAA,gBAAM,EAAC,WAAW,CAAC,aAAa,EAAE,6BAA6B,CAAC,CAAC;QACjE,IAAA,gBAAM,EAAC,WAAW,CAAC,kBAAkB,EAAE,kCAAkC,CAAC,CAAC;QAC3E,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,sBAAsB,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,kBAAkB;IACR,KAAK,CAAC,mBAAmB;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC;QAC7C,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QACtC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;CACF;AAhID,wCAgIC","sourcesContent":["import assert from 'assert';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { TransactionType } from '@bitgo/sdk-core';\nimport { TransactionClause } from '@vechain/sdk-core';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { Transaction } from '../transaction/transaction';\nimport { StakingTransaction } from '../transaction/stakingTransaction';\nimport EthereumAbi from 'ethereumjs-abi';\nimport utils from '../utils';\n\nexport class StakingBuilder extends TransactionBuilder {\n  /**\n   * Creates a new StakingBuilder instance.\n   *\n   * @param {Readonly<CoinConfig>} _coinConfig - The coin configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new StakingTransaction(_coinConfig);\n  }\n\n  /**\n   * Initializes the builder with an existing StakingTransaction.\n   *\n   * @param {StakingTransaction} tx - The transaction to initialize the builder with\n   */\n  initBuilder(tx: StakingTransaction): void {\n    this._transaction = tx;\n  }\n\n  /**\n   * Gets the staking transaction instance.\n   *\n   * @returns {StakingTransaction} The staking transaction\n   */\n  get stakingTransaction(): StakingTransaction {\n    return this._transaction as StakingTransaction;\n  }\n\n  /**\n   * Gets the transaction type for staking.\n   *\n   * @returns {TransactionType} The transaction type\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.ContractCall;\n  }\n\n  /**\n   * Validates the transaction clauses for staking transaction.\n   * @param {TransactionClause[]} clauses - The transaction clauses to validate.\n   * @returns {boolean} - Returns true if the clauses are valid, false otherwise.\n   */\n  protected isValidTransactionClauses(clauses: TransactionClause[]): boolean {\n    try {\n      if (!clauses || !Array.isArray(clauses) || clauses.length === 0) {\n        return false;\n      }\n\n      const clause = clauses[0];\n\n      if (!clause.to || !utils.isValidAddress(clause.to)) {\n        return false;\n      }\n\n      // For staking transactions, value must be greater than 0\n      if (!clause.value || clause.value === '0x0' || clause.value === '0') {\n        return false;\n      }\n\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Sets the staking contract address for this staking tx.\n   *\n   * @param {string} address - The staking contract address\n   * @returns {StakingBuilder} This transaction builder\n   */\n  stakingContractAddress(address: string): this {\n    this.validateAddress({ address });\n    this.stakingTransaction.stakingContractAddress = address;\n    return this;\n  }\n\n  /**\n   * Sets the amount to stake for this staking tx.\n   *\n   * @param {string} amount - The amount to stake in wei\n   * @returns {StakingBuilder} This transaction builder\n   */\n  amountToStake(amount: string): this {\n    this.stakingTransaction.amountToStake = amount;\n    return this;\n  }\n\n  /**\n   * Sets the staking contract ABI for this staking tx.\n   *\n   * @param {EthereumAbi} abi - The staking contract ABI\n   * @returns {StakingBuilder} This transaction builder\n   */\n  stakingContractABI(abi: EthereumAbi): this {\n    this.stakingTransaction.stakingContractABI = abi;\n    return this;\n  }\n\n  /**\n   * Sets the transaction data for this staking tx.\n   *\n   * @param {string} data - The transaction data\n   * @returns {StakingBuilder} This transaction builder\n   */\n  transactionData(data: string): this {\n    this.stakingTransaction.transactionData = data;\n    return this;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: StakingTransaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    assert(transaction.stakingContractAddress, 'Staking contract address is required');\n    assert(transaction.amountToStake, 'Amount to stake is required');\n    assert(transaction.stakingContractABI, 'Staking contract ABI is required');\n    this.validateAddress({ address: transaction.stakingContractAddress });\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.transaction.type = this.transactionType;\n    await this.stakingTransaction.build();\n    return this.transaction;\n  }\n}\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!