PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Nep141Token = void 0;
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const statics_1 = require("@bitgo/statics");
const lib_1 = require("./lib");
const near_1 = require("./near");
class Nep141Token extends near_1.Near {
    constructor(bitgo, tokenConfig) {
        const staticsCoin = tokenConfig.network === statics_1.NetworkType.MAINNET ? statics_1.coins.get('near') : statics_1.coins.get('tnear');
        super(bitgo, staticsCoin);
        this.tokenConfig = tokenConfig;
    }
    static createTokenConstructor(config) {
        return (bitgo) => new Nep141Token(bitgo, config);
    }
    static createTokenConstructors(tokenConfig = [...statics_1.tokens.bitcoin.near.tokens, ...statics_1.tokens.testnet.near.tokens]) {
        const tokensCtors = [];
        for (const token of tokenConfig) {
            const tokenConstructor = Nep141Token.createTokenConstructor(token);
            tokensCtors.push({ name: token.type, coinConstructor: tokenConstructor });
        }
        return tokensCtors;
    }
    get name() {
        return this.tokenConfig.name;
    }
    get coin() {
        return this.tokenConfig.coin;
    }
    get contractAddress() {
        return this.tokenConfig.contractAddress;
    }
    get decimalPlaces() {
        return this.tokenConfig.decimalPlaces;
    }
    get storageDepositAmount() {
        return this.tokenConfig.storageDepositAmount;
    }
    getChain() {
        return this.tokenConfig.type;
    }
    getBaseChain() {
        return this.coin;
    }
    getFullName() {
        return 'Nep141 Token';
    }
    getBaseFactor() {
        return Math.pow(10, this.tokenConfig.decimalPlaces);
    }
    async verifyTransaction(params) {
        const { txPrebuild: txPrebuild, txParams: txParams } = params;
        const rawTx = txPrebuild.txHex;
        let totalAmount = new bignumber_js_1.default(0);
        if (!rawTx) {
            throw new Error('missing required tx prebuild property txHex');
        }
        const coinConfig = statics_1.coins.get(this.getChain());
        const transaction = new lib_1.Transaction(coinConfig);
        transaction.fromRawTransaction(rawTx);
        const explainedTx = transaction.explainTransaction();
        if (txParams.recipients !== undefined) {
            txParams.recipients.forEach((recipient) => {
                if (recipient.tokenName && recipient.tokenName !== coinConfig.name) {
                    throw new Error('incorrect token name specified in recipients');
                }
                recipient.tokenName = coinConfig.name;
            });
            const filteredRecipients = txParams.recipients?.map((recipient) => ({
                address: recipient.address,
                amount: recipient.amount,
                tokenName: recipient.tokenName,
            }));
            const filteredOutputs = explainedTx.outputs.map((output) => ({
                address: output.address,
                amount: output.amount,
                tokenName: output.tokenName,
            }));
            const outputsMatch = JSON.stringify(filteredRecipients) === JSON.stringify(filteredOutputs);
            if (!outputsMatch) {
                throw new Error('Tx outputs does not match with expected txParams recipients');
            }
            for (const recipient of txParams.recipients) {
                totalAmount = totalAmount.plus(recipient.amount);
            }
            if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {
                throw new Error('Tx total amount does not match with expected total amount field');
            }
        }
        if (params.verification?.consolidationToBaseAddress) {
            await this.verifyConsolidationToBaseAddress(params, explainedTx);
        }
        return true;
    }
}
exports.Nep141Token = Nep141Token;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nep141Token.js","sourceRoot":"","sources":["../../src/nep141Token.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BitGoBase, CoinConstructor, NamedCoinConstructor, VerifyTransactionOptions } from '@bitgo/sdk-core';\nimport { coins, Nep141TokenConfig, NetworkType, tokens } from '@bitgo/statics';\n\nimport { Transaction } from './lib';\nimport { Near } from './near';\n\nexport class Nep141Token extends Near {\n  public readonly tokenConfig: Nep141TokenConfig;\n\n  constructor(bitgo: BitGoBase, tokenConfig: Nep141TokenConfig) {\n    const staticsCoin = tokenConfig.network === NetworkType.MAINNET ? coins.get('near') : coins.get('tnear');\n    super(bitgo, staticsCoin);\n    this.tokenConfig = tokenConfig;\n  }\n\n  static createTokenConstructor(config: Nep141TokenConfig): CoinConstructor {\n    return (bitgo: BitGoBase) => new Nep141Token(bitgo, config);\n  }\n\n  static createTokenConstructors(\n    tokenConfig: Nep141TokenConfig[] = [...tokens.bitcoin.near.tokens, ...tokens.testnet.near.tokens]\n  ): NamedCoinConstructor[] {\n    const tokensCtors: NamedCoinConstructor[] = [];\n    for (const token of tokenConfig) {\n      const tokenConstructor = Nep141Token.createTokenConstructor(token);\n      tokensCtors.push({ name: token.type, coinConstructor: tokenConstructor });\n    }\n    return tokensCtors;\n  }\n\n  get name(): string {\n    return this.tokenConfig.name;\n  }\n\n  get coin(): string {\n    return this.tokenConfig.coin;\n  }\n\n  get contractAddress(): string {\n    return this.tokenConfig.contractAddress;\n  }\n\n  get decimalPlaces(): number {\n    return this.tokenConfig.decimalPlaces;\n  }\n\n  get storageDepositAmount(): string {\n    return this.tokenConfig.storageDepositAmount;\n  }\n\n  getChain(): string {\n    return this.tokenConfig.type;\n  }\n\n  getBaseChain(): string {\n    return this.coin;\n  }\n\n  getFullName(): string {\n    return 'Nep141 Token';\n  }\n\n  getBaseFactor(): number {\n    return Math.pow(10, this.tokenConfig.decimalPlaces);\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const rawTx = txPrebuild.txHex;\n    let totalAmount = new BigNumber(0);\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const coinConfig = coins.get(this.getChain());\n    const transaction = new Transaction(coinConfig);\n    transaction.fromRawTransaction(rawTx);\n    const explainedTx = transaction.explainTransaction();\n    if (txParams.recipients !== undefined) {\n      txParams.recipients.forEach((recipient) => {\n        if (recipient.tokenName && recipient.tokenName !== coinConfig.name) {\n          throw new Error('incorrect token name specified in recipients');\n        }\n        recipient.tokenName = coinConfig.name;\n      });\n      const filteredRecipients = txParams.recipients?.map((recipient) => ({\n        address: recipient.address,\n        amount: recipient.amount,\n        tokenName: recipient.tokenName,\n      }));\n      const filteredOutputs = explainedTx.outputs.map((output) => ({\n        address: output.address,\n        amount: output.amount,\n        tokenName: output.tokenName,\n      }));\n      const outputsMatch = JSON.stringify(filteredRecipients) === JSON.stringify(filteredOutputs);\n      if (!outputsMatch) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      for (const recipient of txParams.recipients) {\n        totalAmount = totalAmount.plus(recipient.amount);\n      }\n      if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {\n        throw new Error('Tx total amount does not match with expected total amount field');\n      }\n    }\n\n    if (params.verification?.consolidationToBaseAddress) {\n      await this.verifyConsolidationToBaseAddress(params, explainedTx);\n    }\n\n    return true;\n  }\n}\n"]}

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


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