PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.TokenTransaction = void 0;
const assert_1 = __importDefault(require("assert"));
const sdk_core_1 = require("@vechain/sdk-core");
const sdk_core_2 = require("@bitgo/sdk-core");
const transaction_1 = require("./transaction");
const utils_1 = __importDefault(require("../utils"));
class TokenTransaction extends transaction_1.Transaction {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._type = sdk_core_2.TransactionType.Send;
    }
    get tokenAddress() {
        return this._tokenAddress;
    }
    set tokenAddress(address) {
        this._tokenAddress = address;
    }
    buildClauses() {
        if (!this.tokenAddress) {
            throw new Error('Token address is not set');
        }
        this.clauses = this.recipients.map((recipient) => {
            const data = utils_1.default.getTransferTokenData(recipient.address, String(recipient.amount));
            return {
                to: this.tokenAddress,
                value: '0x0',
                data,
            };
        });
    }
    toJson() {
        const json = {
            id: this.id,
            chainTag: this.chainTag,
            blockRef: this.blockRef,
            expiration: this.expiration,
            recipients: this.recipients,
            gasPriceCoef: this.gasPriceCoef,
            gas: this.gas,
            dependsOn: this.dependsOn,
            nonce: this.nonce,
            sender: this.sender,
            feePayer: this.feePayerAddress,
            tokenAddress: this.tokenAddress,
        };
        return json;
    }
    fromDeserializedSignedTransaction(signedTx) {
        try {
            if (!signedTx || !signedTx.body) {
                throw new sdk_core_2.InvalidTransactionError('Invalid transaction: missing transaction body');
            }
            // Store the raw transaction
            this.rawTransaction = signedTx;
            // Set transaction body properties
            const body = signedTx.body;
            this.chainTag = body.chainTag;
            this.blockRef = body.blockRef;
            this.expiration = body.expiration;
            this.clauses = body.clauses;
            this.gasPriceCoef = typeof body.gasPriceCoef === 'number' ? body.gasPriceCoef : 128;
            this.gas = Number(body.gas);
            this.dependsOn = body.dependsOn;
            this.nonce = String(body.nonce);
            // Set recipients from clauses
            (0, assert_1.default)(body.clauses[0].to, 'token address not found in the clauses');
            this.tokenAddress = body.clauses[0].to;
            this.recipients = body.clauses.map((clause) => utils_1.default.decodeTransferTokenData(clause.data));
            this.loadInputsAndOutputs();
            // Set sender address
            if (signedTx.signature && signedTx.origin) {
                this.sender = signedTx.origin.toString().toLowerCase();
            }
            // Set signatures if present
            if (signedTx.signature) {
                // First signature is sender's signature
                this.senderSignature = Buffer.from(signedTx.signature.slice(0, sdk_core_1.Secp256k1.SIGNATURE_LENGTH));
                // If there's additional signature data, it's the fee payer's signature
                if (signedTx.signature.length > sdk_core_1.Secp256k1.SIGNATURE_LENGTH) {
                    this.feePayerSignature = Buffer.from(signedTx.signature.slice(sdk_core_1.Secp256k1.SIGNATURE_LENGTH));
                }
            }
        }
        catch (e) {
            throw new sdk_core_2.InvalidTransactionError(`Failed to deserialize transaction: ${e.message}`);
        }
    }
}
exports.TokenTransaction = TokenTransaction;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenTransaction.js","sourceRoot":"","sources":["../../../../src/lib/transaction/tokenTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { Secp256k1, Transaction as VetTransaction } from '@vechain/sdk-core';\n\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { InvalidTransactionError, TransactionType } from '@bitgo/sdk-core';\nimport { Transaction } from './transaction';\nimport utils from '../utils';\n\nimport { VetTransactionData } from '../iface';\n\nexport class TokenTransaction extends Transaction {\n  private _tokenAddress: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._type = TransactionType.Send;\n  }\n\n  get tokenAddress(): string {\n    return this._tokenAddress;\n  }\n\n  set tokenAddress(address: string) {\n    this._tokenAddress = address;\n  }\n\n  buildClauses(): void {\n    if (!this.tokenAddress) {\n      throw new Error('Token address is not set');\n    }\n    this.clauses = this.recipients.map((recipient) => {\n      const data = utils.getTransferTokenData(recipient.address, String(recipient.amount));\n      return {\n        to: this.tokenAddress,\n        value: '0x0',\n        data,\n      };\n    });\n  }\n\n  toJson(): VetTransactionData {\n    const json: VetTransactionData = {\n      id: this.id,\n      chainTag: this.chainTag,\n      blockRef: this.blockRef,\n      expiration: this.expiration,\n      recipients: this.recipients,\n      gasPriceCoef: this.gasPriceCoef,\n      gas: this.gas,\n      dependsOn: this.dependsOn,\n      nonce: this.nonce,\n      sender: this.sender,\n      feePayer: this.feePayerAddress,\n      tokenAddress: this.tokenAddress,\n    };\n\n    return json;\n  }\n\n  fromDeserializedSignedTransaction(signedTx: VetTransaction): void {\n    try {\n      if (!signedTx || !signedTx.body) {\n        throw new InvalidTransactionError('Invalid transaction: missing transaction body');\n      }\n\n      // Store the raw transaction\n      this.rawTransaction = signedTx;\n\n      // Set transaction body properties\n      const body = signedTx.body;\n      this.chainTag = body.chainTag;\n      this.blockRef = body.blockRef;\n      this.expiration = body.expiration;\n      this.clauses = body.clauses;\n      this.gasPriceCoef = typeof body.gasPriceCoef === 'number' ? body.gasPriceCoef : 128;\n      this.gas = Number(body.gas);\n      this.dependsOn = body.dependsOn;\n      this.nonce = String(body.nonce);\n      // Set recipients from clauses\n      assert(body.clauses[0].to, 'token address not found in the clauses');\n      this.tokenAddress = body.clauses[0].to;\n      this.recipients = body.clauses.map((clause) => utils.decodeTransferTokenData(clause.data));\n      this.loadInputsAndOutputs();\n\n      // Set sender address\n      if (signedTx.signature && signedTx.origin) {\n        this.sender = signedTx.origin.toString().toLowerCase();\n      }\n\n      // Set signatures if present\n      if (signedTx.signature) {\n        // First signature is sender's signature\n        this.senderSignature = Buffer.from(signedTx.signature.slice(0, Secp256k1.SIGNATURE_LENGTH));\n\n        // If there's additional signature data, it's the fee payer's signature\n        if (signedTx.signature.length > Secp256k1.SIGNATURE_LENGTH) {\n          this.feePayerSignature = Buffer.from(signedTx.signature.slice(Secp256k1.SIGNATURE_LENGTH));\n        }\n      }\n    } catch (e) {\n      throw new InvalidTransactionError(`Failed to deserialize transaction: ${e.message}`);\n    }\n  }\n}\n"]}

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


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