PHP WebShell

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

Просмотр файла: bip322.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;
    };
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.serializeBIP322BroadcastableMessage = serializeBIP322BroadcastableMessage;
exports.deserializeBIP322BroadcastableMessage = deserializeBIP322BroadcastableMessage;
exports.verifyTransactionFromBroadcastableMessage = verifyTransactionFromBroadcastableMessage;
exports.generateBIP322MessageListAndVerifyFromMessageBroadcastable = generateBIP322MessageListAndVerifyFromMessageBroadcastable;
const sdk_core_1 = require("@bitgo/sdk-core");
const utxo_core_1 = require("@bitgo/utxo-core");
const utxo_lib_1 = require("@bitgo/utxo-lib");
const t = __importStar(require("io-ts"));
const BIP322MessageInfo = t.type({
    address: t.string,
    message: t.string,
    pubkeys: t.array(t.string),
    scriptType: t.union([
        t.literal('p2sh'),
        t.literal('p2shP2wsh'),
        t.literal('p2wsh'),
        t.literal('p2tr'),
        t.literal('p2trMusig2'),
    ]),
});
const BIP322MessageBroadcastable = t.type({
    txHex: t.string,
    messageInfo: t.array(BIP322MessageInfo),
});
function serializeBIP322BroadcastableMessage(message) {
    return Buffer.from(JSON.stringify(message), 'utf8').toString('hex');
}
function deserializeBIP322BroadcastableMessage(hex) {
    const json = JSON.parse(Buffer.from(hex, 'hex').toString('utf8'));
    return (0, sdk_core_1.decodeOrElse)(BIP322MessageBroadcastable.name, BIP322MessageBroadcastable, json, (error) => {
        throw new Error(`Failed to decode ${BIP322MessageBroadcastable.name}: ${error}`);
    });
}
function verifyTransactionFromBroadcastableMessage(message, coinName) {
    let network = utxo_lib_1.networks.bitcoin;
    if (coinName === 'tbtc4') {
        network = utxo_lib_1.networks.bitcoinTestnet4;
    }
    else if (coinName !== 'btc') {
        throw new Error('Only tbtc4 or btc coinNames are supported.');
    }
    if (utxo_lib_1.bitgo.isPsbt(message.txHex)) {
        const psbt = utxo_lib_1.bitgo.createPsbtFromBuffer(Buffer.from(message.txHex, 'hex'), network);
        try {
            utxo_core_1.bip322.assertBip322PsbtProof(psbt, message.messageInfo);
            return true;
        }
        catch (error) {
            return false;
        }
    }
    else {
        const tx = utxo_lib_1.bitgo.createTransactionFromBuffer(Buffer.from(message.txHex, 'hex'), network, { amountType: 'bigint' });
        try {
            utxo_core_1.bip322.assertBip322TxProof(tx, message.messageInfo);
            return true;
        }
        catch (error) {
            return false;
        }
    }
}
function generateBIP322MessageListAndVerifyFromMessageBroadcastable(messageBroadcastables, coinName) {
    // Map from the address to the message. If there are duplicates of the address, make sure that the
    // message is the same. If there are duplicate addresses and the messages are not the same, throw an error.
    const addressMap = new Map();
    messageBroadcastables.forEach((message, index) => {
        if (verifyTransactionFromBroadcastableMessage(message, coinName)) {
            message.messageInfo.forEach((info) => {
                const { address, message: msg } = info;
                if (addressMap.has(address)) {
                    if (addressMap.get(address) !== msg) {
                        throw new Error(`Duplicate address ${address} has different messages`);
                    }
                }
                else {
                    addressMap.set(address, msg);
                }
            });
        }
        else {
            throw new Error(`Message Broadcastable ${index} did not have a successful validation`);
        }
    });
    return Array.from(addressMap.entries()).map(([address, message]) => ({
        address,
        message,
    }));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bip322.js","sourceRoot":"","sources":["../../../src/transaction/bip322.ts"],"names":[],"mappings":"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","sourcesContent":["import { decodeOrElse } from '@bitgo/sdk-core';\nimport { bip322 } from '@bitgo/utxo-core';\nimport { bitgo, networks, Network } from '@bitgo/utxo-lib';\nimport * as t from 'io-ts';\n\nconst BIP322MessageInfo = t.type({\n  address: t.string,\n  message: t.string,\n  pubkeys: t.array(t.string),\n  scriptType: t.union([\n    t.literal('p2sh'),\n    t.literal('p2shP2wsh'),\n    t.literal('p2wsh'),\n    t.literal('p2tr'),\n    t.literal('p2trMusig2'),\n  ]),\n});\n\nexport type BIP322MessageInfo = t.TypeOf<typeof BIP322MessageInfo>;\n\nconst BIP322MessageBroadcastable = t.type({\n  txHex: t.string,\n  messageInfo: t.array(BIP322MessageInfo),\n});\n\nexport type BIP322MessageBroadcastable = t.TypeOf<typeof BIP322MessageBroadcastable>;\n\nexport function serializeBIP322BroadcastableMessage(message: BIP322MessageBroadcastable): string {\n  return Buffer.from(JSON.stringify(message), 'utf8').toString('hex');\n}\n\nexport function deserializeBIP322BroadcastableMessage(hex: string): BIP322MessageBroadcastable {\n  const json = JSON.parse(Buffer.from(hex, 'hex').toString('utf8'));\n  return decodeOrElse(BIP322MessageBroadcastable.name, BIP322MessageBroadcastable, json, (error) => {\n    throw new Error(`Failed to decode ${BIP322MessageBroadcastable.name}: ${error}`);\n  });\n}\n\nexport function verifyTransactionFromBroadcastableMessage(\n  message: BIP322MessageBroadcastable,\n  coinName: string\n): boolean {\n  let network: Network = networks.bitcoin;\n  if (coinName === 'tbtc4') {\n    network = networks.bitcoinTestnet4;\n  } else if (coinName !== 'btc') {\n    throw new Error('Only tbtc4 or btc coinNames are supported.');\n  }\n  if (bitgo.isPsbt(message.txHex)) {\n    const psbt = bitgo.createPsbtFromBuffer(Buffer.from(message.txHex, 'hex'), network);\n    try {\n      bip322.assertBip322PsbtProof(psbt, message.messageInfo);\n      return true;\n    } catch (error) {\n      return false;\n    }\n  } else {\n    const tx = bitgo.createTransactionFromBuffer(Buffer.from(message.txHex, 'hex'), network, { amountType: 'bigint' });\n    try {\n      bip322.assertBip322TxProof(tx, message.messageInfo);\n      return true;\n    } catch (error) {\n      return false;\n    }\n  }\n}\n\nexport function generateBIP322MessageListAndVerifyFromMessageBroadcastable(\n  messageBroadcastables: BIP322MessageBroadcastable[],\n  coinName: string\n): { address: string; message: string }[] {\n  // Map from the address to the message. If there are duplicates of the address, make sure that the\n  // message is the same. If there are duplicate addresses and the messages are not the same, throw an error.\n  const addressMap = new Map<string, string>();\n\n  messageBroadcastables.forEach((message, index) => {\n    if (verifyTransactionFromBroadcastableMessage(message, coinName)) {\n      message.messageInfo.forEach((info) => {\n        const { address, message: msg } = info;\n        if (addressMap.has(address)) {\n          if (addressMap.get(address) !== msg) {\n            throw new Error(`Duplicate address ${address} has different messages`);\n          }\n        } else {\n          addressMap.set(address, msg);\n        }\n      });\n    } else {\n      throw new Error(`Message Broadcastable ${index} did not have a successful validation`);\n    }\n  });\n\n  return Array.from(addressMap.entries()).map(([address, message]) => ({\n    address,\n    message,\n  }));\n}\n"]}

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


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