PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.TokenTransferBuilder = void 0;
const abstract_substrate_1 = require("@bitgo/abstract-substrate");
const sdk_core_1 = require("@bitgo/sdk-core");
const txwrapper_core_1 = require("@substrate/txwrapper-core");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const tokenTransferTransaction_1 = require("./tokenTransferTransaction");
class TokenTransferBuilder extends abstract_substrate_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._transaction = new tokenTransferTransaction_1.TokenTransferTransaction(_coinConfig);
    }
    /**
     * Construct a transaction to transfer stake
     * @returns {UnsignedTransaction} an unsigned transfer stake transaction
     */
    buildTransaction() {
        const baseTxInfo = this.createBaseTxInfo();
        return this.transferStake({
            destinationColdkey: this._destinationColdkey,
            hotkey: this._hotkey,
            originNetuid: this._originNetuid,
            destinationNetuid: this._destinationNetuid,
            alphaAmount: this._alphaAmount,
        }, baseTxInfo);
    }
    /** @inheritdoc */
    get transactionType() {
        return sdk_core_1.TransactionType.SendToken;
    }
    /**
     * Set the amount to transfer
     * @param {string} amount to transfer
     * @returns {TokenTransferBuilder} This builder.
     */
    amount(amount) {
        this.validateValue(new bignumber_js_1.default(amount));
        this._alphaAmount = amount;
        return this;
    }
    /**
     * Set the validator hot key address
     * @param {string} hotkey address of validator
     * @returns {TokenTransferBuilder} This builder.
     */
    hotkey(address) {
        this.validateAddress({ address });
        this._hotkey = address;
        return this;
    }
    /**
     * Set the destination cold key address
     * @param {string} address of the destination cold key
     * @returns {TokenTransferBuilder} This builder.
     */
    destinationColdkey(address) {
        this.validateAddress({ address });
        this._destinationColdkey = address;
        return this;
    }
    /**
     * Set the origin netuid of the subnet (root network is 0)
     * @param {string} netuid of subnet
     * @returns {TokenTransferBuilder} This builder.
     */
    originNetuid(netuid) {
        this._originNetuid = netuid;
        return this;
    }
    /**
     * Set the destination netuid of the subnet (root network is 0)
     * @param {string} netuid of subnet
     * @returns {TokenTransferBuilder} This builder.
     */
    destinationNetuid(netuid) {
        this._destinationNetuid = netuid;
        return this;
    }
    /** @inheritdoc */
    fromImplementation(rawTransaction) {
        const tx = super.fromImplementation(rawTransaction);
        if (this._method?.name === abstract_substrate_1.Interface.MethodNames.TransferStake) {
            const txMethod = this._method.args;
            this.amount(txMethod.alphaAmount);
            this.hotkey(txMethod.hotkey);
            this.destinationColdkey(txMethod.destinationColdkey);
            this.originNetuid(txMethod.originNetuid);
            this.destinationNetuid(txMethod.destinationNetuid);
        }
        else {
            throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected ${abstract_substrate_1.Interface.MethodNames.TransferStake}`);
        }
        return tx;
    }
    /** @inheritdoc */
    validateTransaction(_) {
        super.validateTransaction(_);
        this.validateFields(this._destinationColdkey, this._hotkey, this._originNetuid, this._destinationNetuid, this._alphaAmount);
    }
    /**
     * Helper method to validate whether tx params have the correct type and format
     * @param {string} destinationColdkey destination cold key address
     * @param {string} hotkey hotkey address of the validator
     * @param {string} originNetuid netuid of the origin subnet
     * @param {string} destinationNetuid netuid of the destination subnet
     * @param {string} alphaAmount amount to transfer
     * @throws {InvalidTransactionError} if validation fails
     */
    validateFields(destinationColdkey, hotkey, originNetuid, destinationNetuid, alphaAmount) {
        const validationResult = abstract_substrate_1.Schema.TransferStakeTransactionSchema.validate({
            destinationColdkey,
            hotkey,
            originNetuid,
            destinationNetuid,
            alphaAmount,
        });
        if (validationResult.error) {
            throw new sdk_core_1.InvalidTransactionError(`Transaction validation failed: ${validationResult.error.message}`);
        }
    }
    /** @inheritdoc */
    validateDecodedTransaction(decodedTxn, rawTransaction) {
        if (decodedTxn.method?.name === abstract_substrate_1.Interface.MethodNames.TransferStake) {
            const txMethod = decodedTxn.method.args;
            const validationResult = abstract_substrate_1.Schema.TransferStakeTransactionSchema.validate(txMethod);
            if (validationResult.error) {
                throw new sdk_core_1.InvalidTransactionError(`Transfer Transaction validation failed: ${validationResult.error.message}`);
            }
        }
    }
    /**
     * Construct a transaction to transfer stake
     *
     * @param {Interface.TransferStakeArgs} args arguments to be passed to the transferStake method
     * @param {Interface.CreateBaseTxInfo} info txn info required to construct the transferStake txn
     * @returns {UnsignedTransaction} an unsigned stake transaction
     */
    transferStake(args, info) {
        return (0, txwrapper_core_1.defineMethod)({
            method: {
                args,
                name: 'transferStake',
                pallet: 'subtensorModule',
            },
            ...info.baseTxInfo,
        }, info.options);
    }
}
exports.TokenTransferBuilder = TokenTransferBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenTransferBuilder.js","sourceRoot":"","sources":["../../../src/lib/tokenTransferBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Interface, Schema, Transaction, TransactionBuilder } from '@bitgo/abstract-substrate';\nimport { InvalidTransactionError, TransactionType } from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { DecodedSignedTx, DecodedSigningPayload, defineMethod, UnsignedTransaction } from '@substrate/txwrapper-core';\nimport BigNumber from 'bignumber.js';\nimport { TokenTransferTransaction } from './tokenTransferTransaction';\n\nexport class TokenTransferBuilder extends TransactionBuilder {\n  protected _destinationColdkey: string;\n  protected _hotkey: string;\n  protected _originNetuid: string;\n  protected _destinationNetuid: string;\n  protected _alphaAmount: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new TokenTransferTransaction(_coinConfig);\n  }\n\n  /**\n   * Construct a transaction to transfer stake\n   * @returns {UnsignedTransaction} an unsigned transfer stake transaction\n   */\n  protected buildTransaction(): UnsignedTransaction {\n    const baseTxInfo = this.createBaseTxInfo();\n    return this.transferStake(\n      {\n        destinationColdkey: this._destinationColdkey,\n        hotkey: this._hotkey,\n        originNetuid: this._originNetuid,\n        destinationNetuid: this._destinationNetuid,\n        alphaAmount: this._alphaAmount,\n      },\n      baseTxInfo\n    );\n  }\n\n  /** @inheritdoc */\n  protected get transactionType(): TransactionType {\n    return TransactionType.SendToken;\n  }\n\n  /**\n   * Set the amount to transfer\n   * @param {string} amount to transfer\n   * @returns {TokenTransferBuilder} This builder.\n   */\n  amount(amount: string): this {\n    this.validateValue(new BigNumber(amount));\n    this._alphaAmount = amount;\n    return this;\n  }\n\n  /**\n   * Set the validator hot key address\n   * @param {string} hotkey address of validator\n   * @returns {TokenTransferBuilder} This builder.\n   */\n  hotkey(address: string): this {\n    this.validateAddress({ address });\n    this._hotkey = address;\n    return this;\n  }\n\n  /**\n   * Set the destination cold key address\n   * @param {string} address of the destination cold key\n   * @returns {TokenTransferBuilder} This builder.\n   */\n\n  destinationColdkey(address: string): this {\n    this.validateAddress({ address });\n    this._destinationColdkey = address;\n    return this;\n  }\n\n  /**\n   * Set the origin netuid of the subnet (root network is 0)\n   * @param {string} netuid of subnet\n   * @returns {TokenTransferBuilder} This builder.\n   */\n  originNetuid(netuid: string): this {\n    this._originNetuid = netuid;\n    return this;\n  }\n\n  /**\n   * Set the destination netuid of the subnet (root network is 0)\n   * @param {string} netuid of subnet\n   * @returns {TokenTransferBuilder} This builder.\n   */\n  destinationNetuid(netuid: string): this {\n    this._destinationNetuid = netuid;\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = super.fromImplementation(rawTransaction);\n    if (this._method?.name === Interface.MethodNames.TransferStake) {\n      const txMethod = this._method.args as Interface.TransferStakeArgs;\n      this.amount(txMethod.alphaAmount);\n      this.hotkey(txMethod.hotkey);\n      this.destinationColdkey(txMethod.destinationColdkey);\n      this.originNetuid(txMethod.originNetuid);\n      this.destinationNetuid(txMethod.destinationNetuid);\n    } else {\n      throw new InvalidTransactionError(\n        `Invalid Transaction Type: ${this._method?.name}. Expected ${Interface.MethodNames.TransferStake}`\n      );\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(_: Transaction): void {\n    super.validateTransaction(_);\n    this.validateFields(\n      this._destinationColdkey,\n      this._hotkey,\n      this._originNetuid,\n      this._destinationNetuid,\n      this._alphaAmount\n    );\n  }\n\n  /**\n   * Helper method to validate whether tx params have the correct type and format\n   * @param {string} destinationColdkey destination cold key address\n   * @param {string} hotkey hotkey address of the validator\n   * @param {string} originNetuid netuid of the origin subnet\n   * @param {string} destinationNetuid netuid of the destination subnet\n   * @param {string} alphaAmount amount to transfer\n   * @throws {InvalidTransactionError} if validation fails\n   */\n  private validateFields(\n    destinationColdkey: string,\n    hotkey: string,\n    originNetuid: string,\n    destinationNetuid: string,\n    alphaAmount: string\n  ): void {\n    const validationResult = Schema.TransferStakeTransactionSchema.validate({\n      destinationColdkey,\n      hotkey,\n      originNetuid,\n      destinationNetuid,\n      alphaAmount,\n    });\n\n    if (validationResult.error) {\n      throw new InvalidTransactionError(`Transaction validation failed: ${validationResult.error.message}`);\n    }\n  }\n\n  /** @inheritdoc */\n  validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx, rawTransaction: string): void {\n    if (decodedTxn.method?.name === Interface.MethodNames.TransferStake) {\n      const txMethod = decodedTxn.method.args as unknown as Interface.TransferStakeArgs;\n\n      const validationResult = Schema.TransferStakeTransactionSchema.validate(txMethod);\n      if (validationResult.error) {\n        throw new InvalidTransactionError(`Transfer Transaction validation failed: ${validationResult.error.message}`);\n      }\n    }\n  }\n\n  /**\n   * Construct a transaction to transfer stake\n   *\n   * @param {Interface.TransferStakeArgs} args arguments to be passed to the transferStake method\n   * @param {Interface.CreateBaseTxInfo} info txn info required to construct the transferStake txn\n   * @returns {UnsignedTransaction} an unsigned stake transaction\n   */\n\n  private transferStake(args: Interface.TransferStakeArgs, info: Interface.CreateBaseTxInfo): UnsignedTransaction {\n    return defineMethod(\n      {\n        method: {\n          args,\n          name: 'transferStake',\n          pallet: 'subtensorModule',\n        },\n        ...info.baseTxInfo,\n      },\n      info.options\n    );\n  }\n}\n"]}

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


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