PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-sol/dist/src/lib

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.StakingDeactivateBuilder = void 0;
const assert_1 = __importDefault(require("assert"));
const sdk_core_1 = require("@bitgo/sdk-core");
const constants_1 = require("./constants");
const transactionBuilder_1 = require("./transactionBuilder");
const utils_1 = require("./utils");
class StakingDeactivateBuilder extends transactionBuilder_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._isMarinade = false;
    }
    get transactionType() {
        return sdk_core_1.TransactionType.StakingDeactivate;
    }
    /** @inheritdoc */
    initBuilder(tx) {
        super.initBuilder(tx);
        const stakingAddresses = [];
        for (const instruction of this._instructionsData) {
            if (instruction.type === constants_1.InstructionBuilderTypes.StakingDeactivate) {
                const deactivateInstruction = instruction;
                this.isMarinade(deactivateInstruction.params.isMarinade ?? false);
                if (!deactivateInstruction.params.isMarinade) {
                    this.sender(deactivateInstruction.params.fromAddress);
                }
                if (deactivateInstruction.params.isMarinade) {
                    this.recipients(deactivateInstruction.params.recipients ?? []);
                }
                stakingAddresses.push(deactivateInstruction.params.stakingAddress);
                if (deactivateInstruction.params.amount && deactivateInstruction.params.unstakingAddress) {
                    this.amount(deactivateInstruction.params.amount);
                    this.unstakingAddress(deactivateInstruction.params.unstakingAddress);
                }
            }
        }
        if (stakingAddresses.length > 1) {
            this.stakingAddresses(stakingAddresses);
        }
        else {
            if (!this._isMarinade) {
                this.stakingAddress(stakingAddresses[0]);
            }
        }
    }
    /**
     * The staking address of the staking account.
     *
     * @param {string} stakingAddress public address of the staking account
     * @returns {StakingDeactivateBuilder} This staking deactivate builder.
     *
     * @see https://docs.solana.com/staking/stake-accounts#account-address
     */
    stakingAddress(stakingAddress) {
        (0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
        this._stakingAddress = stakingAddress;
        return this;
    }
    /**
     * The staking addresses of the staking account.
     *
     * @param {string[]} stakingAddresses public address of the staking accounts
     * @returns {StakingDeactivateBuilder} This staking deactivate builder.
     *
     * @see https://docs.solana.com/staking/stake-accounts#account-address
     */
    stakingAddresses(stakingAddresses) {
        for (const stakingAddress of stakingAddresses) {
            (0, utils_1.validateAddress)(stakingAddress, 'stakingAddress');
        }
        this._stakingAddresses = stakingAddresses;
        return this;
    }
    /**
     * Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used
     * when partially unstaking. If not given then the entire staked amount will be unstaked.
     *
     * @param {string} amount The partial amount to unstake, expressed in Lamports.
     * @returns {StakingDeactivateBuilder} This staking builder.
     *
     * @see https://docs.solana.com/cli/delegate-stake#split-stake
     */
    amount(amount) {
        if (!(0, utils_1.isValidStakingAmount)(amount)) {
            throw new sdk_core_1.BuildTransactionError('If given, amount cannot be zero or less');
        }
        this._amount = amount;
        return this;
    }
    /**
     * Setter to set the recipients object
     *
     * @param recipients RecipientEntry[] - The recipients object
     * @returns {StakingDeactivateBuilder} This staking builder.
     */
    recipients(recipients) {
        this._recipients = recipients;
        return this;
    }
    /**
     * When partially unstaking move the amount to unstake to this account and initiate the
     * unstake process. The original stake account will continue staking.
     *
     * @param {string} unstakingAddress An account used to unstake a partial amount.
     * @returns {StakingDeactivateBuilder} This staking builder.
     *
     * @see https://docs.solana.com/cli/delegate-stake#split-stake
     */
    unstakingAddress(unstakingAddress) {
        (0, utils_1.validateAddress)(unstakingAddress, 'unstakingAddress');
        this._unstakingAddress = unstakingAddress;
        return this;
    }
    /**
     * Set isMarinade flag
     * @param {boolean} flag - true if the transaction is for Marinade, false by default if not set
     * @returns {StakingActivateBuilder} This staking builder
     */
    isMarinade(flag) {
        this._isMarinade = flag;
        return this;
    }
    /** @inheritdoc */
    async buildImplementation() {
        (0, assert_1.default)(this._sender, 'Sender must be set before building the transaction');
        (0, assert_1.default)(this._isMarinade !== undefined, 'isMarinade must be set before building the transaction');
        if (this._stakingAddresses && this._stakingAddresses.length > 0) {
            this._instructionsData = [];
            for (const stakingAddress of this._stakingAddresses) {
                const stakingDeactivateData = {
                    type: constants_1.InstructionBuilderTypes.StakingDeactivate,
                    params: {
                        fromAddress: this._sender,
                        stakingAddress: stakingAddress,
                    },
                };
                this._instructionsData.push(stakingDeactivateData);
            }
        }
        else {
            if (!this._isMarinade) {
                // we don't need stakingAddress in marinade staking deactivate txn
                (0, assert_1.default)(this._stakingAddress, 'Staking address must be set before building the transaction');
            }
            if (this._sender === this._stakingAddress) {
                throw new sdk_core_1.BuildTransactionError('Sender address cannot be the same as the Staking address');
            }
            if (this._amount && !this._isMarinade) {
                (0, assert_1.default)(this._unstakingAddress, 'When partially unstaking the unstaking address must be set before building the transaction');
            }
            this._instructionsData = [];
            if (this._unstakingAddress && !this._isMarinade) {
                (0, assert_1.default)(this._amount, 'If an unstaking address is given then a partial amount to unstake must also be set before building the transaction');
                const stakingFundUnstakeAddress = {
                    type: constants_1.InstructionBuilderTypes.Transfer,
                    params: {
                        fromAddress: this._sender,
                        amount: constants_1.STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT.toString(),
                        toAddress: this._unstakingAddress,
                    },
                };
                this._instructionsData.push(stakingFundUnstakeAddress);
            }
            const stakingDeactivateData = {
                type: constants_1.InstructionBuilderTypes.StakingDeactivate,
                params: {
                    fromAddress: this._sender,
                    stakingAddress: this._stakingAddress,
                    amount: this._amount,
                    unstakingAddress: this._unstakingAddress,
                    isMarinade: this._isMarinade,
                    recipients: this._recipients,
                },
            };
            this._instructionsData.push(stakingDeactivateData);
        }
        return await super.buildImplementation();
    }
}
exports.StakingDeactivateBuilder = StakingDeactivateBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingDeactivateBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingDeactivateBuilder.ts"],"names":[],"mappings":";;;;;;AACA,oDAA4B;AAE5B,8CAAoF;AACpF,2CAAwF;AAGxF,6DAA0D;AAC1D,mCAAgE;AAEhE,MAAa,wBAAyB,SAAQ,uCAAkB;IAQ9D,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;QAJX,gBAAW,GAAG,KAAK,CAAC;IAK9B,CAAC;IAED,IAAc,eAAe;QAC3B,OAAO,0BAAe,CAAC,iBAAiB,CAAC;IAC3C,CAAC;IAED,kBAAkB;IAClB,WAAW,CAAC,EAAe;QACzB,KAAK,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACtB,MAAM,gBAAgB,GAAa,EAAE,CAAC;QACtC,KAAK,MAAM,WAAW,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACjD,IAAI,WAAW,CAAC,IAAI,KAAK,mCAAuB,CAAC,iBAAiB,EAAE,CAAC;gBACnE,MAAM,qBAAqB,GAAsB,WAAW,CAAC;gBAC7D,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,UAAU,IAAI,KAAK,CAAC,CAAC;gBAClE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;oBAC7C,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;gBACxD,CAAC;gBACD,IAAI,qBAAqB,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;oBAC5C,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;gBACjE,CAAC;gBACD,gBAAgB,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;gBACnE,IAAI,qBAAqB,CAAC,MAAM,CAAC,MAAM,IAAI,qBAAqB,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;oBACzF,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;oBACjD,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;gBACvE,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACtB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3C,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,cAAsB;QACnC,IAAA,uBAAe,EAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;QAClD,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;OAOG;IACH,gBAAgB,CAAC,gBAA0B;QACzC,KAAK,MAAM,cAAc,IAAI,gBAAgB,EAAE,CAAC;YAC9C,IAAA,uBAAe,EAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;QACpD,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;;OAQG;IACH,MAAM,CAAC,MAAc;QACnB,IAAI,CAAC,IAAA,4BAAoB,EAAC,MAAM,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,gCAAqB,CAAC,yCAAyC,CAAC,CAAC;QAC7E,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,UAAuB;QAChC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;;;OAQG;IACH,gBAAgB,CAAC,gBAAwB;QACvC,IAAA,uBAAe,EAAC,gBAAgB,EAAE,kBAAkB,CAAC,CAAC;QACtD,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,UAAU,CAAC,IAAa;QACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,kBAAkB;IACR,KAAK,CAAC,mBAAmB;QACjC,IAAA,gBAAM,EAAC,IAAI,CAAC,OAAO,EAAE,oDAAoD,CAAC,CAAC;QAC3E,IAAA,gBAAM,EAAC,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE,wDAAwD,CAAC,CAAC;QAEjG,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChE,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;YAC5B,KAAK,MAAM,cAAc,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACpD,MAAM,qBAAqB,GAAsB;oBAC/C,IAAI,EAAE,mCAAuB,CAAC,iBAAiB;oBAC/C,MAAM,EAAE;wBACN,WAAW,EAAE,IAAI,CAAC,OAAO;wBACzB,cAAc,EAAE,cAAc;qBAC/B;iBACF,CAAC;gBACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACrD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACtB,kEAAkE;gBAClE,IAAA,gBAAM,EAAC,IAAI,CAAC,eAAe,EAAE,6DAA6D,CAAC,CAAC;YAC9F,CAAC;YAED,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC;gBAC1C,MAAM,IAAI,gCAAqB,CAAC,0DAA0D,CAAC,CAAC;YAC9F,CAAC;YAED,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACtC,IAAA,gBAAM,EACJ,IAAI,CAAC,iBAAiB,EACtB,4FAA4F,CAC7F,CAAC;YACJ,CAAC;YACD,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;YAC5B,IAAI,IAAI,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBAChD,IAAA,gBAAM,EACJ,IAAI,CAAC,OAAO,EACZ,oHAAoH,CACrH,CAAC;gBACF,MAAM,yBAAyB,GAAa;oBAC1C,IAAI,EAAE,mCAAuB,CAAC,QAAQ;oBACtC,MAAM,EAAE;wBACN,WAAW,EAAE,IAAI,CAAC,OAAO;wBACzB,MAAM,EAAE,4CAAgC,CAAC,QAAQ,EAAE;wBACnD,SAAS,EAAE,IAAI,CAAC,iBAAiB;qBAClC;iBACF,CAAC;gBACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;YACzD,CAAC;YAED,MAAM,qBAAqB,GAAsB;gBAC/C,IAAI,EAAE,mCAAuB,CAAC,iBAAiB;gBAC/C,MAAM,EAAE;oBACN,WAAW,EAAE,IAAI,CAAC,OAAO;oBACzB,cAAc,EAAE,IAAI,CAAC,eAAe;oBACpC,MAAM,EAAE,IAAI,CAAC,OAAO;oBACpB,gBAAgB,EAAE,IAAI,CAAC,iBAAiB;oBACxC,UAAU,EAAE,IAAI,CAAC,WAAW;oBAC5B,UAAU,EAAE,IAAI,CAAC,WAAW;iBAC7B;aACF,CAAC;YACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACrD,CAAC;QACD,OAAO,MAAM,KAAK,CAAC,mBAAmB,EAAE,CAAC;IAC3C,CAAC;CACF;AAlMD,4DAkMC","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport assert from 'assert';\n\nimport { BuildTransactionError, Recipient, TransactionType } from '@bitgo/sdk-core';\nimport { InstructionBuilderTypes, STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT } from './constants';\nimport { StakingDeactivate, Transfer } from './iface';\nimport { Transaction } from './transaction';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { isValidStakingAmount, validateAddress } from './utils';\n\nexport class StakingDeactivateBuilder extends TransactionBuilder {\n  protected _stakingAddress: string;\n  protected _stakingAddresses: string[];\n  protected _amount?: string;\n  protected _unstakingAddress: string;\n  protected _isMarinade = false;\n  protected _recipients: Recipient[];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingDeactivate;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    const stakingAddresses: string[] = [];\n    for (const instruction of this._instructionsData) {\n      if (instruction.type === InstructionBuilderTypes.StakingDeactivate) {\n        const deactivateInstruction: StakingDeactivate = instruction;\n        this.isMarinade(deactivateInstruction.params.isMarinade ?? false);\n        if (!deactivateInstruction.params.isMarinade) {\n          this.sender(deactivateInstruction.params.fromAddress);\n        }\n        if (deactivateInstruction.params.isMarinade) {\n          this.recipients(deactivateInstruction.params.recipients ?? []);\n        }\n        stakingAddresses.push(deactivateInstruction.params.stakingAddress);\n        if (deactivateInstruction.params.amount && deactivateInstruction.params.unstakingAddress) {\n          this.amount(deactivateInstruction.params.amount);\n          this.unstakingAddress(deactivateInstruction.params.unstakingAddress);\n        }\n      }\n    }\n    if (stakingAddresses.length > 1) {\n      this.stakingAddresses(stakingAddresses);\n    } else {\n      if (!this._isMarinade) {\n        this.stakingAddress(stakingAddresses[0]);\n      }\n    }\n  }\n\n  /**\n   * The staking address of the staking account.\n   *\n   * @param {string} stakingAddress public address of the staking account\n   * @returns {StakingDeactivateBuilder} This staking deactivate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddress(stakingAddress: string): this {\n    validateAddress(stakingAddress, 'stakingAddress');\n    this._stakingAddress = stakingAddress;\n    return this;\n  }\n\n  /**\n   * The staking addresses of the staking account.\n   *\n   * @param {string[]} stakingAddresses public address of the staking accounts\n   * @returns {StakingDeactivateBuilder} This staking deactivate builder.\n   *\n   * @see https://docs.solana.com/staking/stake-accounts#account-address\n   */\n  stakingAddresses(stakingAddresses: string[]): this {\n    for (const stakingAddress of stakingAddresses) {\n      validateAddress(stakingAddress, 'stakingAddress');\n    }\n    this._stakingAddresses = stakingAddresses;\n    return this;\n  }\n\n  /**\n   * Optional amount to unstake expressed in Lamports, 1 SOL = 1_000_000_000 lamports, to be used\n   * when partially unstaking. If not given then the entire staked amount will be unstaked.\n   *\n   * @param {string} amount The partial amount to unstake, expressed in Lamports.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  amount(amount: string): this {\n    if (!isValidStakingAmount(amount)) {\n      throw new BuildTransactionError('If given, amount cannot be zero or less');\n    }\n    this._amount = amount;\n    return this;\n  }\n\n  /**\n   * Setter to set the recipients object\n   *\n   * @param recipients RecipientEntry[] - The recipients object\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   */\n  recipients(recipients: Recipient[]): this {\n    this._recipients = recipients;\n    return this;\n  }\n\n  /**\n   * When partially unstaking move the amount to unstake to this account and initiate the\n   * unstake process. The original stake account will continue staking.\n   *\n   * @param {string} unstakingAddress An account used to unstake a partial amount.\n   * @returns {StakingDeactivateBuilder} This staking builder.\n   *\n   * @see https://docs.solana.com/cli/delegate-stake#split-stake\n   */\n  unstakingAddress(unstakingAddress: string): this {\n    validateAddress(unstakingAddress, 'unstakingAddress');\n    this._unstakingAddress = unstakingAddress;\n    return this;\n  }\n\n  /**\n   * Set isMarinade flag\n   * @param {boolean} flag - true if the transaction is for Marinade, false by default if not set\n   * @returns {StakingActivateBuilder} This staking builder\n   */\n  isMarinade(flag: boolean): this {\n    this._isMarinade = flag;\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    assert(this._sender, 'Sender must be set before building the transaction');\n    assert(this._isMarinade !== undefined, 'isMarinade must be set before building the transaction');\n\n    if (this._stakingAddresses && this._stakingAddresses.length > 0) {\n      this._instructionsData = [];\n      for (const stakingAddress of this._stakingAddresses) {\n        const stakingDeactivateData: StakingDeactivate = {\n          type: InstructionBuilderTypes.StakingDeactivate,\n          params: {\n            fromAddress: this._sender,\n            stakingAddress: stakingAddress,\n          },\n        };\n        this._instructionsData.push(stakingDeactivateData);\n      }\n    } else {\n      if (!this._isMarinade) {\n        // we don't need stakingAddress in marinade staking deactivate txn\n        assert(this._stakingAddress, 'Staking address must be set before building the transaction');\n      }\n\n      if (this._sender === this._stakingAddress) {\n        throw new BuildTransactionError('Sender address cannot be the same as the Staking address');\n      }\n\n      if (this._amount && !this._isMarinade) {\n        assert(\n          this._unstakingAddress,\n          'When partially unstaking the unstaking address must be set before building the transaction'\n        );\n      }\n      this._instructionsData = [];\n      if (this._unstakingAddress && !this._isMarinade) {\n        assert(\n          this._amount,\n          'If an unstaking address is given then a partial amount to unstake must also be set before building the transaction'\n        );\n        const stakingFundUnstakeAddress: Transfer = {\n          type: InstructionBuilderTypes.Transfer,\n          params: {\n            fromAddress: this._sender,\n            amount: STAKE_ACCOUNT_RENT_EXEMPT_AMOUNT.toString(),\n            toAddress: this._unstakingAddress,\n          },\n        };\n        this._instructionsData.push(stakingFundUnstakeAddress);\n      }\n\n      const stakingDeactivateData: StakingDeactivate = {\n        type: InstructionBuilderTypes.StakingDeactivate,\n        params: {\n          fromAddress: this._sender,\n          stakingAddress: this._stakingAddress,\n          amount: this._amount,\n          unstakingAddress: this._unstakingAddress,\n          isMarinade: this._isMarinade,\n          recipients: this._recipients,\n        },\n      };\n      this._instructionsData.push(stakingDeactivateData);\n    }\n    return await super.buildImplementation();\n  }\n}\n"]}

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


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