PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.StakingRawMsgAuthorizeBuilder = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const transaction_1 = require("./transaction");
const web3_js_1 = require("@solana/web3.js");
const assert_1 = __importDefault(require("assert"));
const constants_1 = require("./constants");
class StakingRawMsgAuthorizeBuilder extends sdk_core_1.BaseTransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._transaction = new transaction_1.Transaction(_coinConfig);
    }
    get transactionType() {
        return sdk_core_1.TransactionType.StakingAuthorizeRaw;
    }
    /** @inheritdoc */
    initBuilder(tx) {
        if (this.validateTransaction(tx)) {
            this.transactionMessage(tx.solTransaction.serializeMessage().toString('base64'));
        }
    }
    /**
     * The raw message generated by Solana CLI.
     *
     * @param {string} msg msg generated by 'solana stake-authorize-check.
     * @returns {StakeBuilder} This staking builder.
     *
     */
    transactionMessage(msg) {
        this.validateMessage(msg);
        this._transactionMessage = msg;
        return this;
    }
    /** @inheritdoc */
    async buildImplementation() {
        (0, assert_1.default)(this._transactionMessage, 'missing transaction message');
        this.validateMessage(this._transactionMessage);
        const solTransaction = web3_js_1.Transaction.populate(web3_js_1.Message.from(Buffer.from(this._transactionMessage, 'base64')), []);
        // this is workaround for solana web3.js generate wrong signing message
        const serialized = solTransaction.serialize({ requireAllSignatures: false }).toString('base64');
        this.transaction.fromRawTransaction(serialized);
        this.transaction.setTransactionType(this.transactionType);
        (0, assert_1.default)(this._transactionMessage === this.transaction.signablePayload.toString('base64'), 'wrong signing message');
        return this.transaction;
    }
    validateTransaction(tx) {
        return this.validateMessage(tx.solTransaction.serializeMessage().toString('base64'));
    }
    async build() {
        return this.buildImplementation();
    }
    validateMessage(msg) {
        const tx = web3_js_1.Transaction.populate(web3_js_1.Message.from(Buffer.from(msg, 'base64')), []);
        const instructions = tx.instructions;
        if (instructions.length !== 2 && instructions.length !== 3) {
            throw new Error(`Invalid transaction, expected 2 instruction, got ${instructions.length}`);
        }
        for (const instruction of instructions) {
            switch (instruction.programId.toString()) {
                case web3_js_1.SystemProgram.programId.toString():
                    const instructionName = web3_js_1.SystemInstruction.decodeInstructionType(instruction);
                    if (instructionName !== constants_1.nonceAdvanceInstruction) {
                        throw new Error(`Invalid system instruction : ${instructionName}`);
                    }
                    break;
                case web3_js_1.StakeProgram.programId.toString():
                    const data = instruction.data.toString('hex');
                    if (data !== constants_1.validInstructionData && data !== constants_1.validInstructionData2) {
                        throw new Error(`Invalid staking instruction data: ${data}`);
                    }
                    break;
                default:
                    throw new Error(`Invalid transaction, instruction program id not supported: ${instruction.programId.toString()}`);
            }
        }
        return true;
    }
    fromImplementation(rawTransaction) {
        const tx = new transaction_1.Transaction(this._coinConfig);
        tx.fromRawTransaction(rawTransaction);
        this.initBuilder(tx);
        return this.transaction;
    }
    signImplementation(key) {
        throw new sdk_core_1.NotSupported('Method not supported on this builder');
    }
    get transaction() {
        return this._transaction;
    }
    validateAddress(address, addressFormat) {
        throw new sdk_core_1.NotSupported('Method not supported on this builder');
    }
    validateKey(key) {
        throw new sdk_core_1.NotSupported('Method not supported on this builder');
    }
    validateRawTransaction(rawTransaction) {
        const tx = new transaction_1.Transaction(this._coinConfig);
        tx.fromRawTransaction(rawTransaction);
        this.validateTransaction(tx);
    }
    validateValue(value) {
        throw new sdk_core_1.NotSupported('Method not supported on this builder');
    }
}
exports.StakingRawMsgAuthorizeBuilder = StakingRawMsgAuthorizeBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingRawMsgAuthorizeBuilder.js","sourceRoot":"","sources":["../../../src/lib/stakingRawMsgAuthorizeBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport {\n  BaseAddress,\n  BaseKey,\n  BaseTransaction,\n  BaseTransactionBuilder,\n  NotSupported,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { Transaction } from './transaction';\nimport {\n  Transaction as SOLTransaction,\n  Message as SOLMessage,\n  SystemProgram,\n  SystemInstruction,\n  StakeProgram,\n} from '@solana/web3.js';\n\nimport assert from 'assert';\nimport BigNumber from 'bignumber.js';\nimport { nonceAdvanceInstruction, validInstructionData, validInstructionData2 } from './constants';\n\nexport class StakingRawMsgAuthorizeBuilder extends BaseTransactionBuilder {\n  protected _transaction: Transaction;\n  protected _transactionMessage: string;\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._transaction = new Transaction(_coinConfig);\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.StakingAuthorizeRaw;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    if (this.validateTransaction(tx)) {\n      this.transactionMessage(tx.solTransaction.serializeMessage().toString('base64'));\n    }\n  }\n\n  /**\n   * The raw message generated by Solana CLI.\n   *\n   * @param {string} msg msg generated by 'solana stake-authorize-check.\n   * @returns {StakeBuilder} This staking builder.\n   *\n   */\n  transactionMessage(msg: string): this {\n    this.validateMessage(msg);\n    this._transactionMessage = msg;\n    return this;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    assert(this._transactionMessage, 'missing transaction message');\n\n    this.validateMessage(this._transactionMessage);\n    const solTransaction = SOLTransaction.populate(\n      SOLMessage.from(Buffer.from(this._transactionMessage, 'base64')),\n      []\n    );\n    // this is workaround for solana web3.js generate wrong signing message\n    const serialized = solTransaction.serialize({ requireAllSignatures: false }).toString('base64');\n    this.transaction.fromRawTransaction(serialized);\n    this.transaction.setTransactionType(this.transactionType);\n    assert(this._transactionMessage === this.transaction.signablePayload.toString('base64'), 'wrong signing message');\n    return this.transaction;\n  }\n\n  validateTransaction(tx: Transaction): boolean {\n    return this.validateMessage(tx.solTransaction.serializeMessage().toString('base64'));\n  }\n\n  async build(): Promise<Transaction> {\n    return this.buildImplementation();\n  }\n\n  protected validateMessage(msg: string): boolean {\n    const tx = SOLTransaction.populate(SOLMessage.from(Buffer.from(msg, 'base64')), []);\n    const instructions = tx.instructions;\n    if (instructions.length !== 2 && instructions.length !== 3) {\n      throw new Error(`Invalid transaction, expected 2 instruction, got ${instructions.length}`);\n    }\n    for (const instruction of instructions) {\n      switch (instruction.programId.toString()) {\n        case SystemProgram.programId.toString():\n          const instructionName = SystemInstruction.decodeInstructionType(instruction);\n          if (instructionName !== nonceAdvanceInstruction) {\n            throw new Error(`Invalid system instruction : ${instructionName}`);\n          }\n          break;\n        case StakeProgram.programId.toString():\n          const data = instruction.data.toString('hex');\n          if (data !== validInstructionData && data !== validInstructionData2) {\n            throw new Error(`Invalid staking instruction data: ${data}`);\n          }\n          break;\n        default:\n          throw new Error(\n            `Invalid transaction, instruction program id not supported: ${instruction.programId.toString()}`\n          );\n      }\n    }\n    return true;\n  }\n\n  protected fromImplementation(rawTransaction: string): Transaction {\n    const tx = new Transaction(this._coinConfig);\n    tx.fromRawTransaction(rawTransaction);\n    this.initBuilder(tx);\n    return this.transaction;\n  }\n\n  protected signImplementation(key: BaseKey): BaseTransaction {\n    throw new NotSupported('Method not supported on this builder');\n  }\n\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    throw new NotSupported('Method not supported on this builder');\n  }\n\n  validateKey(key: BaseKey): void {\n    throw new NotSupported('Method not supported on this builder');\n  }\n\n  validateRawTransaction(rawTransaction: string): void {\n    const tx = new Transaction(this._coinConfig);\n    tx.fromRawTransaction(rawTransaction);\n    this.validateTransaction(tx);\n  }\n\n  validateValue(value: BigNumber): void {\n    throw new NotSupported('Method not supported on this builder');\n  }\n}\n"]}

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


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