PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ClaimBuilder = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const txwrapper_polkadot_1 = require("@substrate/txwrapper-polkadot");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const iface_1 = require("./iface");
const transactionBuilder_1 = require("./transactionBuilder");
const txnSchema_1 = require("./txnSchema");
const utils_1 = __importDefault(require("./utils"));
class ClaimBuilder extends transactionBuilder_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
    }
    /**
     *
     * Pay out all the stakers behind a single validator for a single era.
     * Any account can create this transaction.
     *
     * @returns {UnsignedTransaction} an unsigned Dot transaction
     *
     * @see https://polkadot.js.org/docs/substrate/extrinsics/#payoutstakersvalidator_stash-accountid32-era-u32
     */
    buildTransaction() {
        const baseTxInfo = this.createBaseTxInfo();
        return txwrapper_polkadot_1.methods.staking.payoutStakers({
            validatorStash: this._validatorStash,
            era: this._claimEra,
        }, baseTxInfo.baseTxInfo, baseTxInfo.options);
    }
    /**
     * Get the transaction type.
     */
    get transactionType() {
        return sdk_core_1.TransactionType.StakingClaim;
    }
    /**
     *
     * The stash account of the validator.
     *
     * @param {string} validatorStash
     * @returns {ClaimBuilder} This claim builder.
     *
     */
    validatorStash(validatorStash) {
        this.validateAddress(validatorStash);
        this._validatorStash = validatorStash.address;
        return this;
    }
    /**
     * The era to claim.
     *
     * @param {string} claimEra
     * @returns {ClaimBuilder} This claim builder.
     *
     */
    claimEra(claimEra) {
        this.validateValue(new bignumber_js_1.default(claimEra));
        this._claimEra = claimEra;
        return this;
    }
    /** @inheritdoc */
    validateDecodedTransaction(decodedTxn) {
        if (decodedTxn.method?.name === iface_1.MethodNames.PayoutStakers) {
            const txMethod = decodedTxn.method.args;
            const claimEra = txMethod.era;
            const validatorStash = txMethod.validatorStash;
            const validationResult = txnSchema_1.ClaimTransactionSchema.validate({ claimEra, validatorStash });
            if (validationResult.error) {
                throw new sdk_core_1.InvalidTransactionError(`Claim Transaction validation failed: ${validationResult.error.message}`);
            }
        }
    }
    /** @inheritdoc */
    fromImplementation(rawTransaction) {
        const tx = super.fromImplementation(rawTransaction);
        if (this._method?.name === iface_1.MethodNames.PayoutStakers) {
            const txMethod = this._method.args;
            this.validatorStash({
                address: utils_1.default.decodeDotAddress(txMethod.validatorStash, utils_1.default.getAddressFormat(this._coinConfig.name)),
            });
            this.claimEra(txMethod.era);
        }
        else {
            throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected payoutStakers`);
        }
        return tx;
    }
    /** @inheritdoc */
    validateTransaction(_) {
        super.validateTransaction(_);
        this.validateFields(this._claimEra, this._validatorStash);
    }
    /**
     *
     * The stash account of the validator.
     *
     * @param {string} claimEra
     * @param {string} validatorStash
     * @throws {Error} If the expected fields are not valid.
     *
     */
    validateFields(claimEra, validatorStash) {
        const validationResult = txnSchema_1.ClaimTransactionSchema.validate({
            claimEra,
            validatorStash,
        });
        if (validationResult.error) {
            throw new sdk_core_1.InvalidTransactionError(`Claim Builder Transaction validation failed: ${validationResult.error.message}`);
        }
    }
}
exports.ClaimBuilder = ClaimBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"claimBuilder.js","sourceRoot":"","sources":["../../../src/lib/claimBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseAddress, DotAssetTypes, InvalidTransactionError, TransactionType } from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';\nimport { methods } from '@substrate/txwrapper-polkadot';\nimport BigNumber from 'bignumber.js';\nimport { ClaimArgs, MethodNames } from './iface';\nimport { Transaction } from './transaction';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { ClaimTransactionSchema } from './txnSchema';\nimport utils from './utils';\n\nexport class ClaimBuilder extends TransactionBuilder {\n  protected _validatorStash: string;\n  protected _claimEra: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   *\n   * Pay out all the stakers behind a single validator for a single era.\n   * Any account can create this transaction.\n   *\n   * @returns {UnsignedTransaction} an unsigned Dot transaction\n   *\n   * @see https://polkadot.js.org/docs/substrate/extrinsics/#payoutstakersvalidator_stash-accountid32-era-u32\n   */\n  protected buildTransaction(): UnsignedTransaction {\n    const baseTxInfo = this.createBaseTxInfo();\n    return methods.staking.payoutStakers(\n      {\n        validatorStash: this._validatorStash,\n        era: this._claimEra,\n      },\n      baseTxInfo.baseTxInfo,\n      baseTxInfo.options\n    );\n  }\n\n  /**\n   * Get the transaction type.\n   */\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingClaim;\n  }\n\n  /**\n   *\n   * The stash account of the validator.\n   *\n   * @param {string} validatorStash\n   * @returns {ClaimBuilder} This claim builder.\n   *\n   */\n  validatorStash(validatorStash: BaseAddress): this {\n    this.validateAddress(validatorStash);\n    this._validatorStash = validatorStash.address;\n    return this;\n  }\n\n  /**\n   * The era to claim.\n   *\n   * @param {string} claimEra\n   * @returns {ClaimBuilder} This claim builder.\n   *\n   */\n  claimEra(claimEra: string): this {\n    this.validateValue(new BigNumber(claimEra));\n    this._claimEra = claimEra;\n    return this;\n  }\n\n  /** @inheritdoc */\n  validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void {\n    if (decodedTxn.method?.name === MethodNames.PayoutStakers) {\n      const txMethod = decodedTxn.method.args as unknown as ClaimArgs;\n      const claimEra = txMethod.era;\n      const validatorStash = txMethod.validatorStash;\n      const validationResult = ClaimTransactionSchema.validate({ claimEra, validatorStash });\n      if (validationResult.error) {\n        throw new InvalidTransactionError(`Claim Transaction validation failed: ${validationResult.error.message}`);\n      }\n    }\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = super.fromImplementation(rawTransaction);\n    if (this._method?.name === MethodNames.PayoutStakers) {\n      const txMethod = this._method.args as ClaimArgs;\n      this.validatorStash({\n        address: utils.decodeDotAddress(\n          txMethod.validatorStash,\n          utils.getAddressFormat(this._coinConfig.name as DotAssetTypes)\n        ),\n      });\n      this.claimEra(txMethod.era);\n    } else {\n      throw new InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected payoutStakers`);\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(_: Transaction): void {\n    super.validateTransaction(_);\n    this.validateFields(this._claimEra, this._validatorStash);\n  }\n\n  /**\n   *\n   * The stash account of the validator.\n   *\n   * @param {string} claimEra\n   * @param {string} validatorStash\n   * @throws {Error} If the expected fields are not valid.\n   *\n   */\n  private validateFields(claimEra: string, validatorStash: string): void {\n    const validationResult = ClaimTransactionSchema.validate({\n      claimEra,\n      validatorStash,\n    });\n\n    if (validationResult.error) {\n      throw new InvalidTransactionError(\n        `Claim Builder Transaction validation failed: ${validationResult.error.message}`\n      );\n    }\n  }\n}\n"]}

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


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