PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Transaction = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const web3_js_1 = require("@solana/web3.js");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const bs58_1 = __importDefault(require("bs58"));
const constants_1 = require("./constants");
const instructionParamsFactory_1 = require("./instructionParamsFactory");
const utils_1 = require("./utils");
class Transaction extends sdk_core_1.BaseTransaction {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._instructionsData = [];
        this._useTokenAddressTokenName = false;
    }
    get solTransaction() {
        return this._solTransaction;
    }
    set solTransaction(tx) {
        this._solTransaction = tx;
    }
    get numberOfRequiredSignatures() {
        return this._solTransaction.compileMessage().header.numRequiredSignatures;
    }
    get numberOfATACreationInstructions() {
        return this._solTransaction.instructions.filter((instruction) => (0, utils_1.getInstructionType)(instruction) === constants_1.ValidInstructionTypesEnum.InitializeAssociatedTokenAccount).length;
    }
    /** @inheritDoc */
    get signablePayload() {
        return this._solTransaction.serializeMessage();
    }
    /** @inheritDoc **/
    get id() {
        // Solana transaction ID === first signature: https://docs.solana.com/terminology#transaction-id
        if (this._solTransaction.signature) {
            return bs58_1.default.encode(this._solTransaction.signature);
        }
        else {
            return constants_1.UNAVAILABLE_TEXT;
        }
    }
    get lamportsPerSignature() {
        return this._lamportsPerSignature;
    }
    set lamportsPerSignature(lamportsPerSignature) {
        this._lamportsPerSignature = lamportsPerSignature;
    }
    get tokenAccountRentExemptAmount() {
        return this._tokenAccountRentExemptAmount;
    }
    set tokenAccountRentExemptAmount(tokenAccountRentExemptAmount) {
        this._tokenAccountRentExemptAmount = tokenAccountRentExemptAmount;
    }
    /** @inheritDoc */
    get signature() {
        const signatures = [];
        for (const solSignature of this._solTransaction.signatures) {
            if (solSignature.signature) {
                signatures.push(bs58_1.default.encode(solSignature.signature));
            }
        }
        return signatures;
    }
    /**
     * Set the transaction type.
     *
     * @param {TransactionType} transactionType The transaction type to be set.
     */
    setTransactionType(transactionType) {
        this._type = transactionType;
    }
    /**
     * Set the instructionData.
     *
     * @param {InstructionParams[]} instructionData The instruction data to be set.
     */
    setInstructionsData(instructionData) {
        this._instructionsData = instructionData;
    }
    get useTokenAddressTokenName() {
        return this._useTokenAddressTokenName;
    }
    setUseTokenAddressTokenName(value) {
        this._useTokenAddressTokenName = value;
    }
    /** @inheritdoc */
    canSign() {
        return true;
    }
    /**
     * Signs transaction.
     *
     * @param {KeyPair} keyPair Signer keys.
     */
    async sign(keyPair) {
        if (!this._solTransaction || !this._solTransaction.recentBlockhash) {
            throw new sdk_core_1.SigningError('Nonce is required before signing');
        }
        if (!this._solTransaction || !this._solTransaction.feePayer) {
            throw new sdk_core_1.SigningError('feePayer is required before signing');
        }
        const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];
        const signers = [];
        for (const kp of keyPairs) {
            const keys = kp.getKeys(true);
            if (!keys.prv) {
                throw new sdk_core_1.SigningError('Missing private key');
            }
            signers.push({ publicKey: new web3_js_1.PublicKey(keys.pub), secretKey: keys.prv });
        }
        try {
            this._solTransaction.partialSign(...signers);
        }
        catch (e) {
            throw e;
        }
    }
    /** @inheritdoc */
    toBroadcastFormat() {
        if (!this._solTransaction) {
            throw new sdk_core_1.ParseTransactionError('Empty transaction');
        }
        // The signatures can have null signatures (which means they are required but yet unsigned)
        // In order to be able to serializer the txs, we have to change the requireAllSignatures based
        // on if the TX is fully signed or not
        const requireAllSignatures = (0, utils_1.requiresAllSignatures)(this._solTransaction.signatures);
        try {
            // Based on the recomendation encoding found here https://docs.solana.com/developing/clients/jsonrpc-api#sendtransaction
            // We use base64 encoding
            return this._solTransaction.serialize({ requireAllSignatures }).toString('base64');
        }
        catch (e) {
            throw e;
        }
    }
    /**
     * Sets this transaction payload
     *
     * @param rawTransaction
     */
    fromRawTransaction(rawTransaction) {
        try {
            (0, utils_1.isValidRawTransaction)(rawTransaction);
            this._solTransaction = web3_js_1.Transaction.from(Buffer.from(rawTransaction, 'base64'));
            if (this._solTransaction.signature && this._solTransaction.signature !== null) {
                this._id = bs58_1.default.encode(this._solTransaction.signature);
            }
            const transactionType = (0, utils_1.getTransactionType)(this._solTransaction);
            switch (transactionType) {
                case sdk_core_1.TransactionType.WalletInitialization:
                    this.setTransactionType(sdk_core_1.TransactionType.WalletInitialization);
                    break;
                case sdk_core_1.TransactionType.Send:
                    this.setTransactionType(sdk_core_1.TransactionType.Send);
                    break;
                case sdk_core_1.TransactionType.StakingActivate:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingActivate);
                    break;
                case sdk_core_1.TransactionType.StakingDeactivate:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingDeactivate);
                    break;
                case sdk_core_1.TransactionType.StakingWithdraw:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingWithdraw);
                    break;
                case sdk_core_1.TransactionType.AssociatedTokenAccountInitialization:
                    this.setTransactionType(sdk_core_1.TransactionType.AssociatedTokenAccountInitialization);
                    break;
                case sdk_core_1.TransactionType.CloseAssociatedTokenAccount:
                    this.setTransactionType(sdk_core_1.TransactionType.CloseAssociatedTokenAccount);
                    break;
                case sdk_core_1.TransactionType.StakingAuthorize:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingAuthorize);
                    break;
                case sdk_core_1.TransactionType.StakingAuthorizeRaw:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingAuthorizeRaw);
                    break;
                case sdk_core_1.TransactionType.StakingDelegate:
                    this.setTransactionType(sdk_core_1.TransactionType.StakingDelegate);
                    break;
                case sdk_core_1.TransactionType.CustomTx:
                    this.setTransactionType(sdk_core_1.TransactionType.CustomTx);
                    break;
            }
            if (transactionType !== sdk_core_1.TransactionType.StakingAuthorizeRaw) {
                this.loadInputsAndOutputs();
            }
        }
        catch (e) {
            throw e;
        }
    }
    /** @inheritdoc */
    toJson() {
        if (!this._solTransaction) {
            throw new sdk_core_1.ParseTransactionError('Empty transaction');
        }
        let durableNonce;
        if (this._solTransaction.nonceInfo) {
            const nonceInstruction = web3_js_1.SystemInstruction.decodeNonceAdvance(this._solTransaction.nonceInfo.nonceInstruction);
            durableNonce = {
                walletNonceAddress: nonceInstruction.noncePubkey.toString(),
                authWalletAddress: nonceInstruction.authorizedPubkey.toString(),
            };
        }
        const instructionData = (0, instructionParamsFactory_1.instructionParamsFactory)(this._type, this._solTransaction.instructions, this._coinConfig.name, this._instructionsData, this._useTokenAddressTokenName);
        if (this._type) {
            if (!durableNonce &&
                instructionData.length > 1 &&
                instructionData[0].type === constants_1.InstructionBuilderTypes.NonceAdvance) {
                durableNonce = instructionData[0].params;
            }
        }
        const result = {
            id: this._solTransaction.signature ? this.id : undefined,
            feePayer: this._solTransaction.feePayer?.toString(),
            lamportsPerSignature: this.lamportsPerSignature,
            nonce: this.getNonce(),
            durableNonce: durableNonce,
            numSignatures: this.signature.length,
            instructionsData: instructionData,
        };
        return result;
    }
    /**
     * Get the nonce from the Solana Transaction
     * Throws if not set
     */
    getNonce() {
        if (this._solTransaction.recentBlockhash) {
            return this._solTransaction.recentBlockhash;
        }
        else if (this._solTransaction.nonceInfo) {
            return this._solTransaction.nonceInfo.nonce;
        }
        else {
            throw new sdk_core_1.InvalidTransactionError('Nonce is not set');
        }
    }
    /**
     * Load the input and output data on this transaction.
     */
    loadInputsAndOutputs() {
        if (!this._solTransaction || this._solTransaction.instructions?.length === 0) {
            return;
        }
        const outputs = [];
        const inputs = [];
        const instructionParams = (0, instructionParamsFactory_1.instructionParamsFactory)(this.type, this._solTransaction.instructions, this._coinConfig.name, this._instructionsData, this._useTokenAddressTokenName);
        for (const instruction of instructionParams) {
            switch (instruction.type) {
                case constants_1.InstructionBuilderTypes.CreateNonceAccount:
                    inputs.push({
                        address: instruction.params.fromAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.Transfer:
                    inputs.push({
                        address: instruction.params.fromAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    outputs.push({
                        address: instruction.params.toAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.TokenTransfer:
                    inputs.push({
                        address: instruction.params.fromAddress,
                        value: instruction.params.amount,
                        coin: instruction.params.tokenName,
                    });
                    outputs.push({
                        address: instruction.params.toAddress,
                        value: instruction.params.amount,
                        coin: instruction.params.tokenName,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.StakingActivate:
                    inputs.push({
                        address: instruction.params.fromAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    outputs.push({
                        address: instruction.params.stakingAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.StakingDeactivate:
                    if (instruction.params.amount && instruction.params.unstakingAddress) {
                        inputs.push({
                            address: instruction.params.stakingAddress,
                            value: instruction.params.amount,
                            coin: this._coinConfig.name,
                        });
                        outputs.push({
                            address: instruction.params.unstakingAddress,
                            value: instruction.params.amount,
                            coin: this._coinConfig.name,
                        });
                    }
                    break;
                case constants_1.InstructionBuilderTypes.StakingWithdraw:
                    inputs.push({
                        address: instruction.params.stakingAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    outputs.push({
                        address: instruction.params.fromAddress,
                        value: instruction.params.amount,
                        coin: this._coinConfig.name,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount:
                    break;
                case constants_1.InstructionBuilderTypes.CloseAssociatedTokenAccount:
                    break;
                case constants_1.InstructionBuilderTypes.StakingAuthorize:
                    break;
                case constants_1.InstructionBuilderTypes.StakingDelegate:
                    break;
                case constants_1.InstructionBuilderTypes.SetPriorityFee:
                    break;
                case constants_1.InstructionBuilderTypes.CustomInstruction:
                    break;
            }
        }
        this._outputs = outputs;
        this._inputs = inputs;
    }
    /** @inheritDoc */
    explainTransaction() {
        if ((0, utils_1.validateRawMsgInstruction)(this._solTransaction.instructions)) {
            return this.explainRawMsgAuthorizeTransaction();
        }
        const decodedInstructions = (0, instructionParamsFactory_1.instructionParamsFactory)(this._type, this._solTransaction.instructions, this._coinConfig.name, this._instructionsData, this._useTokenAddressTokenName);
        let memo = undefined;
        let durableNonce = undefined;
        let outputAmount = new bignumber_js_1.default(0);
        const outputs = [];
        for (const instruction of decodedInstructions) {
            switch (instruction.type) {
                case constants_1.InstructionBuilderTypes.NonceAdvance:
                    durableNonce = instruction.params;
                    break;
                case constants_1.InstructionBuilderTypes.Memo:
                    memo = instruction.params.memo;
                    break;
                case constants_1.InstructionBuilderTypes.Transfer:
                    const transferInstruction = instruction;
                    outputs.push({
                        address: transferInstruction.params.toAddress,
                        amount: transferInstruction.params.amount,
                    });
                    outputAmount = outputAmount.plus(transferInstruction.params.amount);
                    break;
                case constants_1.InstructionBuilderTypes.TokenTransfer:
                    const tokenTransferInstruction = instruction;
                    outputs.push({
                        address: tokenTransferInstruction.params.toAddress,
                        amount: tokenTransferInstruction.params.amount,
                        tokenName: tokenTransferInstruction.params.tokenName,
                    });
                    break;
                case constants_1.InstructionBuilderTypes.CreateNonceAccount:
                    const createInstruction = instruction;
                    outputs.push({
                        address: createInstruction.params.nonceAddress,
                        amount: createInstruction.params.amount,
                    });
                    outputAmount = outputAmount.plus(createInstruction.params.amount);
                    break;
                case constants_1.InstructionBuilderTypes.StakingActivate:
                    const stakingActivateInstruction = instruction;
                    outputs.push({
                        address: stakingActivateInstruction.params.stakingAddress,
                        amount: stakingActivateInstruction.params.amount,
                    });
                    outputAmount = outputAmount.plus(stakingActivateInstruction.params.amount);
                    break;
                case constants_1.InstructionBuilderTypes.StakingWithdraw:
                    const stakingWithdrawInstruction = instruction;
                    outputs.push({
                        address: stakingWithdrawInstruction.params.fromAddress,
                        amount: stakingWithdrawInstruction.params.amount,
                    });
                    outputAmount = outputAmount.plus(stakingWithdrawInstruction.params.amount);
                    break;
                case constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount:
                    break;
                case constants_1.InstructionBuilderTypes.CustomInstruction:
                    // Custom instructions are arbitrary and cannot be explained
                    break;
                default:
                    continue;
            }
            // After deserializing a transaction, durable nonce details are populated in the nonceInfo field
            if (!durableNonce && this._solTransaction.nonceInfo) {
                const nonceAdvanceInstruction = web3_js_1.SystemInstruction.decodeNonceAdvance(this._solTransaction.nonceInfo.nonceInstruction);
                durableNonce = {
                    authWalletAddress: nonceAdvanceInstruction.authorizedPubkey.toString(),
                    walletNonceAddress: nonceAdvanceInstruction.noncePubkey.toString(),
                };
            }
        }
        return this.getExplainedTransaction(outputAmount, outputs, memo, durableNonce);
    }
    calculateFee() {
        if (this.lamportsPerSignature || this.tokenAccountRentExemptAmount) {
            const signatureFees = this.lamportsPerSignature
                ? new bignumber_js_1.default(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)
                : 0;
            const rentFees = this.tokenAccountRentExemptAmount
                ? new bignumber_js_1.default(this.tokenAccountRentExemptAmount).multipliedBy(this.numberOfATACreationInstructions).toFixed(0)
                : 0;
            return new bignumber_js_1.default(signatureFees).plus(rentFees).toFixed(0);
        }
        return constants_1.UNAVAILABLE_TEXT;
    }
    getExplainedTransaction(outputAmount, outputs, memo = undefined, durableNonce = undefined) {
        const feeString = this.calculateFee();
        return {
            displayOrder: [
                'id',
                'type',
                'blockhash',
                'durableNonce',
                'outputAmount',
                'changeAmount',
                'outputs',
                'changeOutputs',
                'fee',
                'memo',
            ],
            id: this.id,
            type: sdk_core_1.TransactionType[this.type].toString(),
            changeOutputs: [],
            changeAmount: '0',
            outputAmount: outputAmount.toFixed(0),
            outputs: outputs,
            fee: {
                fee: feeString,
                feeRate: this.lamportsPerSignature,
            },
            memo: memo,
            blockhash: this.getNonce(),
            durableNonce: durableNonce,
        };
    }
    explainRawMsgAuthorizeTransaction() {
        const { instructions } = this._solTransaction;
        const nonceInstruction = web3_js_1.SystemInstruction.decodeNonceAdvance(instructions[0]);
        const durableNonce = {
            walletNonceAddress: nonceInstruction.noncePubkey.toString(),
            authWalletAddress: nonceInstruction.authorizedPubkey.toString(),
        };
        const data = instructions[1].data.toString('hex');
        const stakingAuthorizeParams = data === constants_1.validInstructionData
            ? {
                stakingAddress: instructions[1].keys[0].pubkey.toString(),
                oldWithdrawAddress: instructions[1].keys[2].pubkey.toString(),
                newWithdrawAddress: instructions[1].keys[3].pubkey.toString(),
                custodianAddress: instructions[1].keys[4].pubkey.toString(),
            }
            : {
                stakingAddress: instructions[1].keys[0].pubkey.toString(),
                oldWithdrawAddress: '',
                newWithdrawAddress: '',
                oldStakingAuthorityAddress: instructions[1].keys[2].pubkey.toString(),
                newStakingAuthorityAddress: instructions[1].keys[3].pubkey.toString(),
            };
        const feeString = this.calculateFee();
        return {
            displayOrder: [
                'id',
                'type',
                'blockhash',
                'durableNonce',
                'outputAmount',
                'changeAmount',
                'outputs',
                'changeOutputs',
                'fee',
                'memo',
            ],
            id: this.id,
            type: sdk_core_1.TransactionType[this.type].toString(),
            changeOutputs: [],
            changeAmount: '0',
            outputAmount: 0,
            outputs: [],
            fee: {
                fee: feeString,
                feeRate: this.lamportsPerSignature,
            },
            blockhash: this.getNonce(),
            durableNonce: durableNonce,
            stakingAuthorize: stakingAuthorizeParams,
        };
    }
}
exports.Transaction = Transaction;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseTransaction,\n  Entry,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { Blockhash, PublicKey, Signer, Transaction as SolTransaction, SystemInstruction } from '@solana/web3.js';\nimport BigNumber from 'bignumber.js';\nimport base58 from 'bs58';\nimport { KeyPair } from '.';\nimport {\n  InstructionBuilderTypes,\n  UNAVAILABLE_TEXT,\n  validInstructionData,\n  ValidInstructionTypesEnum,\n} from './constants';\nimport {\n  DurableNonceParams,\n  InstructionParams,\n  Memo,\n  Nonce,\n  StakingActivate,\n  StakingAuthorizeParams,\n  StakingWithdraw,\n  TokenTransfer,\n  TransactionExplanation,\n  Transfer,\n  TxData,\n  WalletInit,\n} from './iface';\nimport { instructionParamsFactory } from './instructionParamsFactory';\nimport {\n  getInstructionType,\n  getTransactionType,\n  isValidRawTransaction,\n  requiresAllSignatures,\n  validateRawMsgInstruction,\n} from './utils';\n\nexport class Transaction extends BaseTransaction {\n  protected _solTransaction: SolTransaction;\n  private _lamportsPerSignature: number | undefined;\n  private _tokenAccountRentExemptAmount: string | undefined;\n  protected _type: TransactionType;\n  protected _instructionsData: InstructionParams[] = [];\n  private _useTokenAddressTokenName = false;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  get solTransaction(): SolTransaction {\n    return this._solTransaction;\n  }\n\n  set solTransaction(tx: SolTransaction) {\n    this._solTransaction = tx;\n  }\n\n  private get numberOfRequiredSignatures(): number {\n    return this._solTransaction.compileMessage().header.numRequiredSignatures;\n  }\n\n  private get numberOfATACreationInstructions(): number {\n    return this._solTransaction.instructions.filter(\n      (instruction) => getInstructionType(instruction) === ValidInstructionTypesEnum.InitializeAssociatedTokenAccount\n    ).length;\n  }\n\n  /** @inheritDoc */\n  get signablePayload(): Buffer {\n    return this._solTransaction.serializeMessage();\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    // Solana transaction ID === first signature: https://docs.solana.com/terminology#transaction-id\n    if (this._solTransaction.signature) {\n      return base58.encode(this._solTransaction.signature);\n    } else {\n      return UNAVAILABLE_TEXT;\n    }\n  }\n\n  get lamportsPerSignature(): number | undefined {\n    return this._lamportsPerSignature;\n  }\n\n  set lamportsPerSignature(lamportsPerSignature: number | undefined) {\n    this._lamportsPerSignature = lamportsPerSignature;\n  }\n\n  get tokenAccountRentExemptAmount(): string | undefined {\n    return this._tokenAccountRentExemptAmount;\n  }\n\n  set tokenAccountRentExemptAmount(tokenAccountRentExemptAmount: string | undefined) {\n    this._tokenAccountRentExemptAmount = tokenAccountRentExemptAmount;\n  }\n\n  /** @inheritDoc */\n  get signature(): string[] {\n    const signatures: string[] = [];\n\n    for (const solSignature of this._solTransaction.signatures) {\n      if (solSignature.signature) {\n        signatures.push(base58.encode(solSignature.signature));\n      }\n    }\n\n    return signatures;\n  }\n\n  /**\n   * Set the transaction type.\n   *\n   * @param {TransactionType} transactionType The transaction type to be set.\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  /**\n   * Set the instructionData.\n   *\n   * @param {InstructionParams[]} instructionData The instruction data to be set.\n   */\n  setInstructionsData(instructionData: InstructionParams[]): void {\n    this._instructionsData = instructionData;\n  }\n\n  get useTokenAddressTokenName(): boolean {\n    return this._useTokenAddressTokenName;\n  }\n\n  setUseTokenAddressTokenName(value: boolean): void {\n    this._useTokenAddressTokenName = value;\n  }\n  /** @inheritdoc */\n  canSign(): boolean {\n    return true;\n  }\n\n  /**\n   * Signs transaction.\n   *\n   * @param {KeyPair} keyPair Signer keys.\n   */\n  async sign(keyPair: KeyPair[] | KeyPair): Promise<void> {\n    if (!this._solTransaction || !this._solTransaction.recentBlockhash) {\n      throw new SigningError('Nonce is required before signing');\n    }\n    if (!this._solTransaction || !this._solTransaction.feePayer) {\n      throw new SigningError('feePayer is required before signing');\n    }\n    const keyPairs = keyPair instanceof Array ? keyPair : [keyPair];\n    const signers: Signer[] = [];\n    for (const kp of keyPairs) {\n      const keys = kp.getKeys(true);\n      if (!keys.prv) {\n        throw new SigningError('Missing private key');\n      }\n      signers.push({ publicKey: new PublicKey(keys.pub), secretKey: keys.prv as Uint8Array });\n    }\n    try {\n      this._solTransaction.partialSign(...signers);\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    // The signatures can have null signatures (which means they are required but yet unsigned)\n    // In order to be able to serializer the txs, we have to change the requireAllSignatures based\n    // on if the TX is fully signed or not\n    const requireAllSignatures = requiresAllSignatures(this._solTransaction.signatures);\n    try {\n      // Based on the recomendation encoding found here https://docs.solana.com/developing/clients/jsonrpc-api#sendtransaction\n      // We use base64 encoding\n      return this._solTransaction.serialize({ requireAllSignatures }).toString('base64');\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  fromRawTransaction(rawTransaction: string): void {\n    try {\n      isValidRawTransaction(rawTransaction);\n      this._solTransaction = SolTransaction.from(Buffer.from(rawTransaction, 'base64'));\n      if (this._solTransaction.signature && this._solTransaction.signature !== null) {\n        this._id = base58.encode(this._solTransaction.signature);\n      }\n      const transactionType = getTransactionType(this._solTransaction);\n      switch (transactionType) {\n        case TransactionType.WalletInitialization:\n          this.setTransactionType(TransactionType.WalletInitialization);\n          break;\n        case TransactionType.Send:\n          this.setTransactionType(TransactionType.Send);\n          break;\n        case TransactionType.StakingActivate:\n          this.setTransactionType(TransactionType.StakingActivate);\n          break;\n        case TransactionType.StakingDeactivate:\n          this.setTransactionType(TransactionType.StakingDeactivate);\n          break;\n        case TransactionType.StakingWithdraw:\n          this.setTransactionType(TransactionType.StakingWithdraw);\n          break;\n        case TransactionType.AssociatedTokenAccountInitialization:\n          this.setTransactionType(TransactionType.AssociatedTokenAccountInitialization);\n          break;\n        case TransactionType.CloseAssociatedTokenAccount:\n          this.setTransactionType(TransactionType.CloseAssociatedTokenAccount);\n          break;\n        case TransactionType.StakingAuthorize:\n          this.setTransactionType(TransactionType.StakingAuthorize);\n          break;\n        case TransactionType.StakingAuthorizeRaw:\n          this.setTransactionType(TransactionType.StakingAuthorizeRaw);\n          break;\n        case TransactionType.StakingDelegate:\n          this.setTransactionType(TransactionType.StakingDelegate);\n          break;\n        case TransactionType.CustomTx:\n          this.setTransactionType(TransactionType.CustomTx);\n          break;\n      }\n      if (transactionType !== TransactionType.StakingAuthorizeRaw) {\n        this.loadInputsAndOutputs();\n      }\n    } catch (e) {\n      throw e;\n    }\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._solTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n\n    let durableNonce: DurableNonceParams | undefined;\n    if (this._solTransaction.nonceInfo) {\n      const nonceInstruction = SystemInstruction.decodeNonceAdvance(this._solTransaction.nonceInfo.nonceInstruction);\n      durableNonce = {\n        walletNonceAddress: nonceInstruction.noncePubkey.toString(),\n        authWalletAddress: nonceInstruction.authorizedPubkey.toString(),\n      };\n    }\n    const instructionData = instructionParamsFactory(\n      this._type,\n      this._solTransaction.instructions,\n      this._coinConfig.name,\n      this._instructionsData,\n      this._useTokenAddressTokenName\n    );\n    if (this._type) {\n      if (\n        !durableNonce &&\n        instructionData.length > 1 &&\n        instructionData[0].type === InstructionBuilderTypes.NonceAdvance\n      ) {\n        durableNonce = instructionData[0].params;\n      }\n    }\n    const result: TxData = {\n      id: this._solTransaction.signature ? this.id : undefined,\n      feePayer: this._solTransaction.feePayer?.toString(),\n      lamportsPerSignature: this.lamportsPerSignature,\n      nonce: this.getNonce(),\n      durableNonce: durableNonce,\n      numSignatures: this.signature.length,\n      instructionsData: instructionData,\n    };\n    return result;\n  }\n\n  /**\n   * Get the nonce from the Solana Transaction\n   * Throws if not set\n   */\n  private getNonce(): Blockhash {\n    if (this._solTransaction.recentBlockhash) {\n      return this._solTransaction.recentBlockhash;\n    } else if (this._solTransaction.nonceInfo) {\n      return this._solTransaction.nonceInfo.nonce;\n    } else {\n      throw new InvalidTransactionError('Nonce is not set');\n    }\n  }\n\n  /**\n   * Load the input and output data on this transaction.\n   */\n  loadInputsAndOutputs(): void {\n    if (!this._solTransaction || this._solTransaction.instructions?.length === 0) {\n      return;\n    }\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    const instructionParams = instructionParamsFactory(\n      this.type,\n      this._solTransaction.instructions,\n      this._coinConfig.name,\n      this._instructionsData,\n      this._useTokenAddressTokenName\n    );\n\n    for (const instruction of instructionParams) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.CreateNonceAccount:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.Transfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          outputs.push({\n            address: instruction.params.toAddress,\n            value: instruction.params.amount,\n            coin: instruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          inputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.StakingDeactivate:\n          if (instruction.params.amount && instruction.params.unstakingAddress) {\n            inputs.push({\n              address: instruction.params.stakingAddress,\n              value: instruction.params.amount,\n              coin: this._coinConfig.name,\n            });\n            outputs.push({\n              address: instruction.params.unstakingAddress,\n              value: instruction.params.amount,\n              coin: this._coinConfig.name,\n            });\n          }\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          inputs.push({\n            address: instruction.params.stakingAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          outputs.push({\n            address: instruction.params.fromAddress,\n            value: instruction.params.amount,\n            coin: this._coinConfig.name,\n          });\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          break;\n        case InstructionBuilderTypes.CloseAssociatedTokenAccount:\n          break;\n        case InstructionBuilderTypes.StakingAuthorize:\n          break;\n        case InstructionBuilderTypes.StakingDelegate:\n          break;\n        case InstructionBuilderTypes.SetPriorityFee:\n          break;\n        case InstructionBuilderTypes.CustomInstruction:\n          break;\n      }\n    }\n    this._outputs = outputs;\n    this._inputs = inputs;\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    if (validateRawMsgInstruction(this._solTransaction.instructions)) {\n      return this.explainRawMsgAuthorizeTransaction();\n    }\n    const decodedInstructions = instructionParamsFactory(\n      this._type,\n      this._solTransaction.instructions,\n      this._coinConfig.name,\n      this._instructionsData,\n      this._useTokenAddressTokenName\n    );\n\n    let memo: string | undefined = undefined;\n    let durableNonce: DurableNonceParams | undefined = undefined;\n\n    let outputAmount = new BigNumber(0);\n    const outputs: TransactionRecipient[] = [];\n\n    for (const instruction of decodedInstructions) {\n      switch (instruction.type) {\n        case InstructionBuilderTypes.NonceAdvance:\n          durableNonce = (instruction as Nonce).params;\n          break;\n        case InstructionBuilderTypes.Memo:\n          memo = (instruction as Memo).params.memo;\n          break;\n        case InstructionBuilderTypes.Transfer:\n          const transferInstruction = instruction as Transfer;\n          outputs.push({\n            address: transferInstruction.params.toAddress,\n            amount: transferInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(transferInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.TokenTransfer:\n          const tokenTransferInstruction = instruction as TokenTransfer;\n          outputs.push({\n            address: tokenTransferInstruction.params.toAddress,\n            amount: tokenTransferInstruction.params.amount,\n            tokenName: tokenTransferInstruction.params.tokenName,\n          });\n          break;\n        case InstructionBuilderTypes.CreateNonceAccount:\n          const createInstruction = instruction as WalletInit;\n          outputs.push({\n            address: createInstruction.params.nonceAddress,\n            amount: createInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(createInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingActivate:\n          const stakingActivateInstruction = instruction as StakingActivate;\n          outputs.push({\n            address: stakingActivateInstruction.params.stakingAddress,\n            amount: stakingActivateInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingActivateInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.StakingWithdraw:\n          const stakingWithdrawInstruction = instruction as StakingWithdraw;\n          outputs.push({\n            address: stakingWithdrawInstruction.params.fromAddress,\n            amount: stakingWithdrawInstruction.params.amount,\n          });\n          outputAmount = outputAmount.plus(stakingWithdrawInstruction.params.amount);\n          break;\n        case InstructionBuilderTypes.CreateAssociatedTokenAccount:\n          break;\n        case InstructionBuilderTypes.CustomInstruction:\n          // Custom instructions are arbitrary and cannot be explained\n          break;\n        default:\n          continue;\n      }\n\n      // After deserializing a transaction, durable nonce details are populated in the nonceInfo field\n      if (!durableNonce && this._solTransaction.nonceInfo) {\n        const nonceAdvanceInstruction = SystemInstruction.decodeNonceAdvance(\n          this._solTransaction.nonceInfo.nonceInstruction\n        );\n        durableNonce = {\n          authWalletAddress: nonceAdvanceInstruction.authorizedPubkey.toString(),\n          walletNonceAddress: nonceAdvanceInstruction.noncePubkey.toString(),\n        };\n      }\n    }\n\n    return this.getExplainedTransaction(outputAmount, outputs, memo, durableNonce);\n  }\n\n  private calculateFee(): string {\n    if (this.lamportsPerSignature || this.tokenAccountRentExemptAmount) {\n      const signatureFees = this.lamportsPerSignature\n        ? new BigNumber(this.lamportsPerSignature).multipliedBy(this.numberOfRequiredSignatures).toFixed(0)\n        : 0;\n      const rentFees = this.tokenAccountRentExemptAmount\n        ? new BigNumber(this.tokenAccountRentExemptAmount).multipliedBy(this.numberOfATACreationInstructions).toFixed(0)\n        : 0;\n      return new BigNumber(signatureFees).plus(rentFees).toFixed(0);\n    }\n    return UNAVAILABLE_TEXT;\n  }\n\n  protected getExplainedTransaction(\n    outputAmount: BigNumber,\n    outputs: TransactionRecipient[],\n    memo: undefined | string = undefined,\n    durableNonce: undefined | DurableNonceParams = undefined\n  ): TransactionExplanation {\n    const feeString = this.calculateFee();\n    return {\n      displayOrder: [\n        'id',\n        'type',\n        'blockhash',\n        'durableNonce',\n        'outputAmount',\n        'changeAmount',\n        'outputs',\n        'changeOutputs',\n        'fee',\n        'memo',\n      ],\n      id: this.id,\n      type: TransactionType[this.type].toString(),\n      changeOutputs: [],\n      changeAmount: '0',\n      outputAmount: outputAmount.toFixed(0),\n      outputs: outputs,\n      fee: {\n        fee: feeString,\n        feeRate: this.lamportsPerSignature,\n      },\n      memo: memo,\n      blockhash: this.getNonce(),\n      durableNonce: durableNonce,\n    };\n  }\n\n  private explainRawMsgAuthorizeTransaction(): TransactionExplanation {\n    const { instructions } = this._solTransaction;\n    const nonceInstruction = SystemInstruction.decodeNonceAdvance(instructions[0]);\n    const durableNonce = {\n      walletNonceAddress: nonceInstruction.noncePubkey.toString(),\n      authWalletAddress: nonceInstruction.authorizedPubkey.toString(),\n    };\n    const data = instructions[1].data.toString('hex');\n    const stakingAuthorizeParams: StakingAuthorizeParams =\n      data === validInstructionData\n        ? {\n            stakingAddress: instructions[1].keys[0].pubkey.toString(),\n            oldWithdrawAddress: instructions[1].keys[2].pubkey.toString(),\n            newWithdrawAddress: instructions[1].keys[3].pubkey.toString(),\n            custodianAddress: instructions[1].keys[4].pubkey.toString(),\n          }\n        : {\n            stakingAddress: instructions[1].keys[0].pubkey.toString(),\n            oldWithdrawAddress: '',\n            newWithdrawAddress: '',\n            oldStakingAuthorityAddress: instructions[1].keys[2].pubkey.toString(),\n            newStakingAuthorityAddress: instructions[1].keys[3].pubkey.toString(),\n          };\n    const feeString = this.calculateFee();\n    return {\n      displayOrder: [\n        'id',\n        'type',\n        'blockhash',\n        'durableNonce',\n        'outputAmount',\n        'changeAmount',\n        'outputs',\n        'changeOutputs',\n        'fee',\n        'memo',\n      ],\n      id: this.id,\n      type: TransactionType[this.type].toString(),\n      changeOutputs: [],\n      changeAmount: '0',\n      outputAmount: 0,\n      outputs: [],\n      fee: {\n        fee: feeString,\n        feeRate: this.lamportsPerSignature,\n      },\n      blockhash: this.getNonce(),\n      durableNonce: durableNonce,\n      stakingAuthorize: stakingAuthorizeParams,\n    };\n  }\n}\n"]}

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


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