PHP WebShell

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

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

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
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 iface_1 = require("./iface");
const utils_1 = __importStar(require("./utils"));
const types_1 = require("./mystenlab/types");
const constants_1 = require("./constants");
const buffer_1 = require("buffer");
const bcs_1 = require("@mysten/bcs");
const bs58_1 = __importDefault(require("bs58"));
const TransactionDataBlock_1 = require("./mystenlab/builder/TransactionDataBlock");
const builder_1 = require("./mystenlab/builder");
const blake2b_1 = __importDefault(require("@bitgo/blake2b"));
const hash_1 = require("./mystenlab/cryptography/hash");
class Transaction extends sdk_core_1.BaseTransaction {
    constructor(_coinConfig) {
        super(_coinConfig);
    }
    get suiTransaction() {
        return this._suiTransaction;
    }
    setSuiTransaction(tx) {
        this._suiTransaction = tx;
    }
    /** @inheritDoc **/
    get id() {
        const dataBytes = this.getDataBytes();
        const hash = (0, hash_1.hashTypedData)('TransactionData', dataBytes);
        this._id = bs58_1.default.encode(hash);
        return this._id;
    }
    addSignature(publicKey, signature) {
        this._signatures.push(signature.toString('hex'));
        this._signature = { publicKey, signature };
        this.serialize();
    }
    get suiSignature() {
        return this._signature;
    }
    get serializedSig() {
        return this._serializedSig;
    }
    setSerializedSig(publicKey, signature) {
        const pubKey = buffer_1.Buffer.from(publicKey.pub, 'hex');
        const serialized_sig = new Uint8Array(1 + signature.length + pubKey.length);
        serialized_sig.set(constants_1.SIGNATURE_SCHEME_BYTES);
        serialized_sig.set(signature, 1);
        serialized_sig.set(pubKey, 1 + signature.length);
        this._serializedSig = serialized_sig;
    }
    /** @inheritdoc */
    canSign(key) {
        return true;
    }
    /**
     * Sign this transaction
     *
     * @param {KeyPair} signer key
     */
    sign(signer) {
        if (!this._suiTransaction) {
            throw new sdk_core_1.InvalidTransactionError('empty transaction to sign');
        }
        const intentMessage = this.signablePayload;
        const signature = signer.signMessageinUint8Array(intentMessage);
        this.setSerializedSig({ pub: signer.getKeys().pub }, buffer_1.Buffer.from(signature));
        this.addSignature({ pub: signer.getKeys().pub }, buffer_1.Buffer.from(signature));
    }
    /** @inheritdoc */
    toBroadcastFormat() {
        if (!this._suiTransaction) {
            throw new sdk_core_1.InvalidTransactionError('Empty transaction');
        }
        return this.serialize();
    }
    /**
     * Set the transaction type.
     *
     * @param {TransactionType} transactionType The transaction type to be set.
     */
    transactionType(transactionType) {
        this._type = transactionType;
    }
    getDataBytes() {
        const txData = this.getTxData();
        const txSer = builder_1.builder.ser('TransactionData', { V1: txData }, { maxSize: TransactionDataBlock_1.TRANSACTION_DATA_MAX_SIZE });
        return txSer.toBytes();
    }
    /** @inheritDoc */
    get signablePayload() {
        const dataBytes = this.getDataBytes();
        const intentMessage = this.messageWithIntent(utils_1.IntentScope.TransactionData, dataBytes);
        return buffer_1.Buffer.from((0, blake2b_1.default)(32).update(intentMessage).digest('binary'));
    }
    messageWithIntent(scope, message) {
        const intent = this.intentWithScope(scope);
        const intentMessage = new Uint8Array(intent.length + message.length);
        intentMessage.set(intent);
        intentMessage.set(message, intent.length);
        return intentMessage;
    }
    intentWithScope(scope) {
        return [scope, utils_1.IntentVersion.V0, utils_1.AppId.Sui];
    }
    serialize() {
        const dataBytes = this.getDataBytes();
        this._id = bs58_1.default.encode((0, hash_1.hashTypedData)('TransactionData', dataBytes));
        return (0, bcs_1.toB64)(dataBytes);
    }
    static deserializeSuiTransaction(serializedTx) {
        const data = (0, bcs_1.fromB64)(serializedTx);
        const transactionBlock = TransactionDataBlock_1.TransactionBlockDataBuilder.fromBytes(data);
        const inputs = transactionBlock.inputs.map((txInput) => txInput.value);
        const transactions = transactionBlock.transactions;
        const txType = this.getSuiTransactionType(transactions);
        return {
            id: transactionBlock.getDigest(),
            type: txType,
            sender: (0, types_1.normalizeSuiAddress)(transactionBlock.sender),
            tx: {
                inputs: inputs,
                transactions: transactions,
            },
            gasData: {
                payment: this.normalizeCoins(transactionBlock.gasConfig.payment),
                owner: (0, types_1.normalizeSuiAddress)(transactionBlock.gasConfig.owner),
                price: Number(transactionBlock.gasConfig.price),
                budget: Number(transactionBlock.gasConfig.budget),
            },
        };
    }
    static getSuiTransactionType(transactions) {
        // tricky to determine custom tx purely from a serialized tx, we can rely on following logic
        if (transactions.length == 1) {
            return utils_1.default.getSuiTransactionType(transactions[0]);
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.WalrusStakeWithPool)) {
            return iface_1.SuiTransactionType.WalrusStakeWithPool;
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.WalrusRequestWithdrawStake)) {
            return iface_1.SuiTransactionType.WalrusRequestWithdrawStake;
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.WalrusWithdrawStake)) {
            return iface_1.SuiTransactionType.WalrusWithdrawStake;
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.AddStake)) {
            return iface_1.SuiTransactionType.AddStake;
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.WithdrawStake)) {
            return iface_1.SuiTransactionType.WithdrawStake;
        }
        if (transactions.some((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.TokenTransfer)) {
            return iface_1.SuiTransactionType.TokenTransfer;
        }
        if (transactions.every((tx) => utils_1.default.getSuiTransactionType(tx) === iface_1.SuiTransactionType.Transfer)) {
            return iface_1.SuiTransactionType.Transfer;
        }
        return iface_1.SuiTransactionType.CustomTx;
    }
    static getProperGasData(k) {
        return {
            payment: [this.normalizeSuiObjectRef(k.gasData.payment)],
            owner: utils_1.default.normalizeHexId(k.gasData.owner),
            price: Number(k.gasData.price),
            budget: Number(k.gasData.budget),
        };
    }
    static normalizeCoins(coins) {
        return coins.map((coin) => {
            return this.normalizeSuiObjectRef(coin);
        });
    }
    static normalizeSuiObjectRef(obj) {
        return {
            objectId: (0, types_1.normalizeSuiObjectId)(obj.objectId),
            version: Number(obj.version),
            digest: obj.digest,
        };
    }
    /**
     * When building transactions with > 255 input gas payment objects, we first use MergeCoins Tranasactions to merge the
     * additional inputs into the gas coin & slice them from the payment in gasData. When initializing the builder using
     * decoded tx data, we need to get these inputs from MergeCoins & add them back to the gas payment to be able to
     * rebuild from a raw transaction.
     */
    getInputGasPaymentObjectsFromTx(tx) {
        const txInputs = tx.inputs;
        const transactions = tx.transactions;
        const inputGasPaymentObjects = [];
        transactions.forEach((transaction) => {
            if (transaction.kind === 'MergeCoins') {
                const { destination, sources } = transaction;
                if (destination.kind === 'GasCoin') {
                    sources.forEach((source) => {
                        if (source.kind === 'Input') {
                            let input = txInputs[source.index];
                            if ('value' in input) {
                                input = input.value;
                            }
                            if ('Object' in input && (0, utils_1.isImmOrOwnedObj)(input.Object)) {
                                inputGasPaymentObjects.push(input.Object.ImmOrOwned);
                            }
                        }
                    });
                }
            }
        });
        return inputGasPaymentObjects;
    }
}
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  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  PublicKey as BasePublicKey,\n  Signature,\n  TransactionType as BitGoTransactionType,\n} from '@bitgo/sdk-core';\nimport { SuiProgrammableTransaction, SuiTransaction, SuiTransactionType, TxData } from './iface';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport utils, { AppId, Intent, IntentScope, IntentVersion, isImmOrOwnedObj } from './utils';\nimport { GasData, normalizeSuiAddress, normalizeSuiObjectId, SuiObjectRef } from './mystenlab/types';\nimport { SIGNATURE_SCHEME_BYTES } from './constants';\nimport { Buffer } from 'buffer';\nimport { fromB64, toB64 } from '@mysten/bcs';\nimport bs58 from 'bs58';\nimport { KeyPair } from './keyPair';\nimport { TRANSACTION_DATA_MAX_SIZE, TransactionBlockDataBuilder } from './mystenlab/builder/TransactionDataBlock';\nimport { builder, MergeCoinsTransaction, TransactionType } from './mystenlab/builder';\nimport blake2b from '@bitgo/blake2b';\nimport { hashTypedData } from './mystenlab/cryptography/hash';\n\nexport abstract class Transaction<T> extends BaseTransaction {\n  protected _suiTransaction: SuiTransaction<T>;\n  protected _signature: Signature;\n  private _serializedSig: Uint8Array;\n\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  get suiTransaction(): SuiTransaction<T> {\n    return this._suiTransaction;\n  }\n\n  setSuiTransaction(tx: SuiTransaction<T>): void {\n    this._suiTransaction = tx;\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    const dataBytes = this.getDataBytes();\n    const hash = hashTypedData('TransactionData', dataBytes);\n    this._id = bs58.encode(hash);\n    return this._id;\n  }\n\n  addSignature(publicKey: BasePublicKey, signature: Buffer): void {\n    this._signatures.push(signature.toString('hex'));\n    this._signature = { publicKey, signature };\n    this.serialize();\n  }\n\n  get suiSignature(): Signature {\n    return this._signature;\n  }\n\n  get serializedSig(): Uint8Array {\n    return this._serializedSig;\n  }\n\n  setSerializedSig(publicKey: BasePublicKey, signature: Buffer): void {\n    const pubKey = Buffer.from(publicKey.pub, 'hex');\n    const serialized_sig = new Uint8Array(1 + signature.length + pubKey.length);\n    serialized_sig.set(SIGNATURE_SCHEME_BYTES);\n    serialized_sig.set(signature, 1);\n    serialized_sig.set(pubKey, 1 + signature.length);\n    this._serializedSig = serialized_sig;\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  /**\n   * Sign this transaction\n   *\n   * @param {KeyPair} signer key\n   */\n\n  sign(signer: KeyPair): void {\n    if (!this._suiTransaction) {\n      throw new InvalidTransactionError('empty transaction to sign');\n    }\n\n    const intentMessage = this.signablePayload;\n    const signature = signer.signMessageinUint8Array(intentMessage);\n\n    this.setSerializedSig({ pub: signer.getKeys().pub }, Buffer.from(signature));\n    this.addSignature({ pub: signer.getKeys().pub }, Buffer.from(signature));\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._suiTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this.serialize();\n  }\n\n  /** @inheritdoc */\n  abstract toJson(): TxData;\n\n  /**\n   * Set the transaction type.\n   *\n   * @param {TransactionType} transactionType The transaction type to be set.\n   */\n  transactionType(transactionType: BitGoTransactionType): void {\n    this._type = transactionType;\n  }\n\n  /**\n   *  get the correct txData with transaction type\n   */\n  abstract getTxData(): TxData;\n\n  /**\n   * Load the input and output data on this transaction.\n   */\n  abstract loadInputsAndOutputs(): void;\n\n  /**\n   * Sets this transaction payload\n   *\n   * @param rawTransaction\n   */\n  abstract fromRawTransaction(rawTransaction: string): void;\n\n  getDataBytes(): Uint8Array {\n    const txData = this.getTxData();\n    const txSer = builder.ser('TransactionData', { V1: txData }, { maxSize: TRANSACTION_DATA_MAX_SIZE });\n    return txSer.toBytes();\n  }\n\n  /** @inheritDoc */\n  get signablePayload(): Buffer {\n    const dataBytes = this.getDataBytes();\n    const intentMessage = this.messageWithIntent(IntentScope.TransactionData, dataBytes);\n    return Buffer.from(blake2b(32).update(intentMessage).digest('binary'));\n  }\n\n  private messageWithIntent(scope: IntentScope, message: Uint8Array) {\n    const intent = this.intentWithScope(scope);\n    const intentMessage = new Uint8Array(intent.length + message.length);\n    intentMessage.set(intent);\n    intentMessage.set(message, intent.length);\n    return intentMessage;\n  }\n\n  private intentWithScope(scope: IntentScope): Intent {\n    return [scope, IntentVersion.V0, AppId.Sui];\n  }\n\n  serialize(): string {\n    const dataBytes = this.getDataBytes();\n    this._id = bs58.encode(hashTypedData('TransactionData', dataBytes));\n    return toB64(dataBytes);\n  }\n\n  static deserializeSuiTransaction(serializedTx: string): SuiTransaction<SuiProgrammableTransaction> {\n    const data = fromB64(serializedTx);\n    const transactionBlock = TransactionBlockDataBuilder.fromBytes(data);\n    const inputs = transactionBlock.inputs.map((txInput) => txInput.value);\n    const transactions = transactionBlock.transactions;\n    const txType = this.getSuiTransactionType(transactions);\n    return {\n      id: transactionBlock.getDigest(),\n      type: txType,\n      sender: normalizeSuiAddress(transactionBlock.sender!),\n      tx: {\n        inputs: inputs,\n        transactions: transactions,\n      },\n      gasData: {\n        payment: this.normalizeCoins(transactionBlock.gasConfig.payment!),\n        owner: normalizeSuiAddress(transactionBlock.gasConfig.owner!),\n        price: Number(transactionBlock.gasConfig.price as string),\n        budget: Number(transactionBlock.gasConfig.budget as string),\n      },\n    };\n  }\n\n  private static getSuiTransactionType(transactions: TransactionType[]): SuiTransactionType {\n    // tricky to determine custom tx purely from a serialized tx, we can rely on following logic\n    if (transactions.length == 1) {\n      return utils.getSuiTransactionType(transactions[0]);\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.WalrusStakeWithPool)) {\n      return SuiTransactionType.WalrusStakeWithPool;\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.WalrusRequestWithdrawStake)) {\n      return SuiTransactionType.WalrusRequestWithdrawStake;\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.WalrusWithdrawStake)) {\n      return SuiTransactionType.WalrusWithdrawStake;\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.AddStake)) {\n      return SuiTransactionType.AddStake;\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.WithdrawStake)) {\n      return SuiTransactionType.WithdrawStake;\n    }\n    if (transactions.some((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.TokenTransfer)) {\n      return SuiTransactionType.TokenTransfer;\n    }\n    if (transactions.every((tx) => utils.getSuiTransactionType(tx) === SuiTransactionType.Transfer)) {\n      return SuiTransactionType.Transfer;\n    }\n\n    return SuiTransactionType.CustomTx;\n  }\n\n  static getProperGasData(k: any): GasData {\n    return {\n      payment: [this.normalizeSuiObjectRef(k.gasData.payment)],\n      owner: utils.normalizeHexId(k.gasData.owner),\n      price: Number(k.gasData.price),\n      budget: Number(k.gasData.budget),\n    };\n  }\n\n  private static normalizeCoins(coins: any[]): SuiObjectRef[] {\n    return coins.map((coin) => {\n      return this.normalizeSuiObjectRef(coin);\n    });\n  }\n\n  private static normalizeSuiObjectRef(obj: SuiObjectRef): SuiObjectRef {\n    return {\n      objectId: normalizeSuiObjectId(obj.objectId),\n      version: Number(obj.version),\n      digest: obj.digest,\n    };\n  }\n\n  /**\n   * When building transactions with > 255 input gas payment objects, we first use MergeCoins Tranasactions to merge the\n   * additional inputs into the gas coin & slice them from the payment in gasData. When initializing the builder using\n   * decoded tx data, we need to get these inputs from MergeCoins & add them back to the gas payment to be able to\n   * rebuild from a raw transaction.\n   */\n  protected getInputGasPaymentObjectsFromTx(tx: SuiProgrammableTransaction): SuiObjectRef[] {\n    const txInputs = tx.inputs;\n    const transactions = tx.transactions;\n    const inputGasPaymentObjects: SuiObjectRef[] = [];\n\n    transactions.forEach((transaction) => {\n      if (transaction.kind === 'MergeCoins') {\n        const { destination, sources } = transaction as MergeCoinsTransaction;\n        if (destination.kind === 'GasCoin') {\n          sources.forEach((source) => {\n            if (source.kind === 'Input') {\n              let input = txInputs[source.index];\n              if ('value' in input) {\n                input = input.value;\n              }\n              if ('Object' in input && isImmOrOwnedObj(input.Object)) {\n                inputGasPaymentObjects.push(input.Object.ImmOrOwned);\n              }\n            }\n          });\n        }\n      }\n    });\n\n    return inputGasPaymentObjects;\n  }\n}\n"]}

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


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