PHP WebShell

Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/src/bitgo/wallet/psbt

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

"use strict";
/**
 * Contains helper methods for getting and sorting root nodes from a PSBT.
 */
Object.defineProperty(exports, "__esModule", { value: true });
exports.ErrorNoMultiSigInputFound = void 0;
exports.getUnsortedRootNodes = getUnsortedRootNodes;
exports.sortRootNodes = sortRootNodes;
exports.getSortedRootNodes = getSortedRootNodes;
const assert = require("assert");
const bs58check = require("bs58check");
const types_1 = require("../../types");
const bip32_1 = require("bip32");
const noble_ecc_1 = require("../../../noble_ecc");
const outputScripts_1 = require("../../outputScripts");
const transaction_1 = require("../../transaction");
const Psbt_1 = require("../Psbt");
/**
 * Error thrown when no multi-sig input is found in a PSBT.
 * */
class ErrorNoMultiSigInputFound extends Error {
    constructor(message) {
        super(message);
    }
}
exports.ErrorNoMultiSigInputFound = ErrorNoMultiSigInputFound;
/**
 * Retrieves unsorted root BIP32Interface nodes from a PSBT if available.
 * @param psbt - The PSBT from which to extract the global Xpubs.
 * @returns An array of BIP32Interface objects or undefined if not available.
 */
function getUnsortedRootNodes(psbt) {
    const bip32s = psbt.data.globalMap.globalXpub?.map((xpub) => (0, bip32_1.BIP32Factory)(noble_ecc_1.ecc).fromBase58(bs58check.encode(xpub.extendedPubkey)));
    assert(!bip32s || (0, types_1.isTriple)(bip32s), `Invalid globalXpubs in PSBT. Expected 3 or none. Got ${bip32s?.length}`);
    return bip32s;
}
/**
 * Determines if the given public keys' permutation matches a specified script.
 * @param params - Object containing public keys, permutation, script public key, script type, and network.
 * @returns A boolean indicating if the permutation matches the script.
 */
function matchesScript({ pubKeys, perm, scriptPubKey, parsedScriptType, network, }) {
    const pubKeysPerm = [pubKeys[perm[0]], pubKeys[perm[1]], pubKeys[perm[2]]];
    const scriptTypes = (0, Psbt_1.toScriptType2Of3s)(parsedScriptType);
    return scriptTypes.some((scriptType) => (0, outputScripts_1.createOutputScript2of3)(pubKeysPerm, scriptType, network).scriptPubKey.equals(scriptPubKey));
}
/**
 * Finds the correct order of public keys to match a given script.
 * @param pubKeys - Array of public keys involved in the script.
 * @param scriptPubKey - The script public key to match against.
 * @param parsedScriptType - The parsed script type.
 * @param network - Bitcoin network.
 * @returns The order of public keys that match the script.
 */
function findSortOrderOfPubKeys(pubKeys, scriptPubKey, parsedScriptType, network) {
    const permutations = [
        [0, 1, 2],
        [0, 2, 1],
        [1, 0, 2],
        [1, 2, 0],
        [2, 0, 1],
        [2, 1, 0],
    ];
    const order = permutations.find((perm) => matchesScript({ pubKeys, perm, scriptPubKey, parsedScriptType, network }));
    assert(order, 'Could not find sort order of multi sig public keys');
    return order;
}
/**
 * Extracts multi-sig input data, including script type, script public key, and derivation path, from the first relevant PSBT input.
 * @param psbt - The PSBT to extract data from.
 * @returns An object containing the parsed script type, script public key, and derivation path.
 */
function getFirstMultiSigInputData(psbt) {
    function getScriptPubKey(input, prevOutIndex) {
        const scriptPubKey = input.witnessUtxo?.script ??
            (input.nonWitnessUtxo
                ? (0, transaction_1.createTransactionFromBuffer)(input.nonWitnessUtxo, psbt.network, { amountType: 'bigint' }).outs[prevOutIndex]
                    .script
                : undefined);
        assert(scriptPubKey, 'Input scriptPubKey can not be found');
        return scriptPubKey;
    }
    function getDerivationPath(input) {
        const bip32Dv = input?.bip32Derivation ?? input?.tapBip32Derivation;
        assert(bip32Dv?.length, 'Input Bip32Derivation can not be found');
        return bip32Dv[0].path;
    }
    const txInputs = psbt.txInputs;
    for (let i = 0; i < psbt.data.inputs.length; i++) {
        const input = psbt.data.inputs[i];
        const parsedScriptType = (0, Psbt_1.getPsbtInputScriptType)(input);
        if (parsedScriptType === 'p2shP2pk') {
            continue;
        }
        const scriptPubKey = getScriptPubKey(input, txInputs[i].index);
        const derivationPath = getDerivationPath(input);
        return { parsedScriptType, scriptPubKey, derivationPath };
    }
    throw new ErrorNoMultiSigInputFound('No multi sig input found');
}
/**
 * Sorts given root nodes based on the script compatibility with the PSBT's multi-sig inputs.
 * @param psbt - The PSBT containing multi-sig inputs.
 * @param rootNodes - Array of root nodes to sort.
 * @returns An array of BIP32Interface objects in the order that matches the multi-sig script.
 */
function sortRootNodes(psbt, rootNodes) {
    const { parsedScriptType, scriptPubKey, derivationPath } = getFirstMultiSigInputData(psbt);
    const pubKeys = rootNodes.map((rootNode) => rootNode.derivePath(derivationPath).publicKey);
    const order = findSortOrderOfPubKeys(pubKeys, scriptPubKey, parsedScriptType, psbt.network);
    return order.map((i) => rootNodes[i]);
}
/**
 * Retrieves sorted root nodes from a PSBT, ensuring they are ordered according to script compatibility.
 * @param psbt - The PSBT to extract and sort root nodes from.
 * @returns An array of sorted BIP32Interface root nodes.
 */
function getSortedRootNodes(psbt) {
    const unsortedRootNodes = getUnsortedRootNodes(psbt);
    assert(unsortedRootNodes, 'Could not find root nodes in PSBT');
    return sortRootNodes(psbt, unsortedRootNodes);
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUm9vdE5vZGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2JpdGdvL3dhbGxldC9wc2J0L1Jvb3ROb2Rlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7O0dBRUc7OztBQThCSCxvREFNQztBQXdHRCxzQ0FLQztBQU9ELGdEQUlDO0FBMUpELGlDQUFpQztBQUNqQyx1Q0FBdUM7QUFHdkMsdUNBQStDO0FBQy9DLGlDQUFxRDtBQUNyRCxrREFBbUQ7QUFHbkQsdURBQTZEO0FBRTdELG1EQUFnRTtBQUNoRSxrQ0FBb0U7QUFFcEU7O0tBRUs7QUFDTCxNQUFhLHlCQUEwQixTQUFRLEtBQUs7SUFDbEQsWUFBWSxPQUFlO1FBQ3pCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqQixDQUFDO0NBQ0Y7QUFKRCw4REFJQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxJQUFjO0lBQ2pELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUMxRCxJQUFBLG9CQUFZLEVBQUMsZUFBTSxDQUFDLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQ3ZFLENBQUM7SUFDRixNQUFNLENBQUMsQ0FBQyxNQUFNLElBQUksSUFBQSxnQkFBUSxFQUFDLE1BQU0sQ0FBQyxFQUFFLHdEQUF3RCxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUM5RyxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQVMsYUFBYSxDQUFDLEVBQ3JCLE9BQU8sRUFDUCxJQUFJLEVBQ0osWUFBWSxFQUNaLGdCQUFnQixFQUNoQixPQUFPLEdBT1I7SUFDQyxNQUFNLFdBQVcsR0FBbUIsQ0FBQyxPQUFPLENBQUMsSUFB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LENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvbnRhaW5zIGhlbHBlciBtZXRob2RzIGZvciBnZXR0aW5nIGFuZCBzb3J0aW5nIHJvb3Qgbm9kZXMgZnJvbSBhIFBTQlQuXG4gKi9cblxuaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgKiBhcyBiczU4Y2hlY2sgZnJvbSAnYnM1OGNoZWNrJztcblxuaW1wb3J0IHsgVXR4b1BzYnQgfSBmcm9tICcuLi8uLi9VdHhvUHNidCc7XG5pbXBvcnQgeyBpc1RyaXBsZSwgVHJpcGxlIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgQklQMzJGYWN0b3J5LCBCSVAzMkludGVyZmFjZSB9IGZyb20gJ2JpcDMyJztcbmltcG9ydCB7IGVjYyBhcyBlY2NMaWIgfSBmcm9tICcuLi8uLi8uLi9ub2JsZV9lY2MnO1xuaW1wb3J0IHsgUGFyc2VkU2NyaXB0VHlwZTJPZjMgfSBmcm9tICcuLi8uLi9wYXJzZUlucHV0JztcbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi8uLi8uLi9uZXR3b3Jrcyc7XG5pbXBvcnQgeyBjcmVhdGVPdXRwdXRTY3JpcHQyb2YzIH0gZnJvbSAnLi4vLi4vb3V0cHV0U2NyaXB0cyc7XG5pbXBvcnQgeyBQc2J0SW5wdXQgfSBmcm9tICdiaXAxNzQvc3JjL2xpYi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGNyZWF0ZVRyYW5zYWN0aW9uRnJvbUJ1ZmZlciB9IGZyb20gJy4uLy4uL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IGdldFBzYnRJbnB1dFNjcmlwdFR5cGUsIHRvU2NyaXB0VHlwZTJPZjNzIH0gZnJvbSAnLi4vUHNidCc7XG5cbi8qKlxuICogRXJyb3IgdGhyb3duIHdoZW4gbm8gbXVsdGktc2lnIGlucHV0IGlzIGZvdW5kIGluIGEgUFNCVC5cbiAqICovXG5leHBvcnQgY2xhc3MgRXJyb3JOb011bHRpU2lnSW5wdXRGb3VuZCBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgdW5zb3J0ZWQgcm9vdCBCSVAzMkludGVyZmFjZSBub2RlcyBmcm9tIGEgUFNCVCBpZiBhdmFpbGFibGUuXG4gKiBAcGFyYW0gcHNidCAtIFRoZSBQU0JUIGZyb20gd2hpY2ggdG8gZXh0cmFjdCB0aGUgZ2xvYmFsIFhwdWJzLlxuICogQHJldHVybnMgQW4gYXJyYXkgb2YgQklQMzJJbnRlcmZhY2Ugb2JqZWN0cyBvciB1bmRlZmluZWQgaWYgbm90IGF2YWlsYWJsZS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFVuc29ydGVkUm9vdE5vZGVzKHBzYnQ6IFV0eG9Qc2J0KTogVHJpcGxlPEJJUDMySW50ZXJmYWNlPiB8IHVuZGVmaW5lZCB7XG4gIGNvbnN0IGJpcDMycyA9IHBzYnQuZGF0YS5nbG9iYWxNYXAuZ2xvYmFsWHB1Yj8ubWFwKCh4cHViKSA9PlxuICAgIEJJUDMyRmFjdG9yeShlY2NMaWIpLmZyb21CYXNlNTgoYnM1OGNoZWNrLmVuY29kZSh4cHViLmV4dGVuZGVkUHVia2V5KSlcbiAgKTtcbiAgYXNzZXJ0KCFiaXAzMnMgfHwgaXNUcmlwbGUoYmlwMzJzKSwgYEludmFsaWQgZ2xvYmFsWHB1YnMgaW4gUFNCVC4gRXhwZWN0ZWQgMyBvciBub25lLiBHb3QgJHtiaXAzMnM/Lmxlbmd0aH1gKTtcbiAgcmV0dXJuIGJpcDMycztcbn1cblxuLyoqXG4gKiBEZXRlcm1pbmVzIGlmIHRoZSBnaXZlbiBwdWJsaWMga2V5cycgcGVybXV0YXRpb24gbWF0Y2hlcyBhIHNwZWNpZmllZCBzY3JpcHQuXG4gKiBAcGFyYW0gcGFyYW1zIC0gT2JqZWN0IGNvbnRhaW5pbmcgcHVibGljIGtleXMsIHBlcm11dGF0aW9uLCBzY3JpcHQgcHVibGljIGtleSwgc2NyaXB0IHR5cGUsIGFuZCBuZXR3b3JrLlxuICogQHJldHVybnMgQSBib29sZWFuIGluZGljYXRpbmcgaWYgdGhlIHBlcm11dGF0aW9uIG1hdGNoZXMgdGhlIHNjcmlwdC5cbiAqL1xuZnVuY3Rpb24gbWF0Y2hlc1NjcmlwdCh7XG4gIHB1YktleXMsXG4gIHBlcm0sXG4gIHNjcmlwdFB1YktleSxcbiAgcGFyc2VkU2NyaXB0VHlwZSxcbiAgbmV0d29yayxcbn06IHtcbiAgcHViS2V5czogQnVmZmVyW107XG4gIHBlcm06IFRyaXBsZTxudW1iZXI+O1xuICBzY3JpcHRQdWJLZXk6IEJ1ZmZlcjtcbiAgcGFyc2VkU2NyaXB0VHlwZTogUGFyc2VkU2NyaXB0VHlwZTJPZjM7XG4gIG5ldHdvcms6IE5ldHdvcms7XG59KTogYm9vbGVhbiB7XG4gIGNvbnN0IHB1YktleXNQZXJtOiBUcmlwbGU8QnVmZmVyPiA9IFtwdWJLZXlzW3Blcm1bMF1dLCBwdWJLZXlzW3Blcm1bMV1dLCBwdWJLZXlzW3Blcm1bMl1dXTtcbiAgY29uc3Qgc2NyaXB0VHlwZXMgPSB0b1NjcmlwdFR5cGUyT2YzcyhwYXJzZWRTY3JpcHRUeXBlKTtcbiAgcmV0dXJuIHNjcmlwdFR5cGVzLnNvbWUoKHNjcmlwdFR5cGUpID0+XG4gICAgY3JlYXRlT3V0cHV0U2NyaXB0Mm9mMyhwdWJLZXlzUGVybSwgc2NyaXB0VHlwZSwgbmV0d29yaykuc2NyaXB0UHViS2V5LmVxdWFscyhzY3JpcHRQdWJLZXkpXG4gICk7XG59XG5cbi8qKlxuICogRmluZHMgdGhlIGNvcnJlY3Qgb3JkZXIgb2YgcHVibGljIGtleXMgdG8gbWF0Y2ggYSBnaXZlbiBzY3JpcHQuXG4gKiBAcGFyYW0gcHViS2V5cyAtIEFycmF5IG9mIHB1YmxpYyBrZXlzIGludm9sdmVkIGluIHRoZSBzY3JpcHQuXG4gKiBAcGFyYW0gc2NyaXB0UHViS2V5IC0gVGhlIHNjcmlwdCBwdWJsaWMga2V5IHRvIG1hdGNoIGFnYWluc3QuXG4gKiBAcGFyYW0gcGFyc2VkU2NyaXB0VHlwZSAtIFRoZSBwYXJzZWQgc2NyaXB0IHR5cGUuXG4gKiBAcGFyYW0gbmV0d29yayAtIEJpdGNvaW4gbmV0d29yay5cbiAqIEByZXR1cm5zIFRoZSBvcmRlciBvZiBwdWJsaWMga2V5cyB0aGF0IG1hdGNoIHRoZSBzY3JpcHQuXG4gKi9cbmZ1bmN0aW9uIGZpbmRTb3J0T3JkZXJPZlB1YktleXMoXG4gIHB1YktleXM6IFRyaXBsZTxCdWZmZXI+LFxuICBzY3JpcHRQdWJLZXk6IEJ1ZmZlcixcbiAgcGFyc2VkU2NyaXB0VHlwZTogUGFyc2VkU2NyaXB0VHlwZTJPZjMsXG4gIG5ldHdvcms6IE5ldHdvcmtcbik6IFRyaXBsZTxudW1iZXI+IHtcbiAgY29uc3QgcGVybXV0YXRpb25zOiBBcnJheTxUcmlwbGU8bnVtYmVyPj4gPSBbXG4gICAgWzAsIDEsIDJdLFxuICAgIFswLCAyLCAxXSxcbiAgICBbMSwgMCwgMl0sXG4gICAgWzEsIDIsIDBdLFxuICAgIFsyLCAwLCAxXSxcbiAgICBbMiwgMSwgMF0sXG4gIF07XG5cbiAgY29uc3Qgb3JkZXIgPSBwZXJtdXRhdGlvbnMuZmluZCgocGVybSkgPT4gbWF0Y2hlc1NjcmlwdCh7IHB1YktleXMsIHBlcm0sIHNjcmlwdFB1YktleSwgcGFyc2VkU2NyaXB0VHlwZSwgbmV0d29yayB9KSk7XG4gIGFzc2VydChvcmRlciwgJ0NvdWxkIG5vdCBmaW5kIHNvcnQgb3JkZXIgb2YgbXVsdGkgc2lnIHB1YmxpYyBrZXlzJyk7XG4gIHJldHVybiBvcmRlcjtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyBtdWx0aS1zaWcgaW5wdXQgZGF0YSwgaW5jbHVkaW5nIHNjcmlwdCB0eXBlLCBzY3JpcHQgcHVibGljIGtleSwgYW5kIGRlcml2YXRpb24gcGF0aCwgZnJvbSB0aGUgZmlyc3QgcmVsZXZhbnQgUFNCVCBpbnB1dC5cbiAqIEBwYXJhbSBwc2J0IC0gVGhlIFBTQlQgdG8gZXh0cmFjdCBkYXRhIGZyb20uXG4gKiBAcmV0dXJucyBBbiBvYmplY3QgY29udGFpbmluZyB0aGUgcGFyc2VkIHNjcmlwdCB0eXBlLCBzY3JpcHQgcHVibGljIGtleSwgYW5kIGRlcml2YXRpb24gcGF0aC5cbiAqL1xuZnVuY3Rpb24gZ2V0Rmlyc3RNdWx0aVNpZ0lucHV0RGF0YShwc2J0OiBVdHhvUHNidCk6IHtcbiAgcGFyc2VkU2NyaXB0VHlwZTogUGFyc2VkU2NyaXB0VHlwZTJPZjM7XG4gIHNjcmlwdFB1YktleTogQnVmZmVyO1xuICBkZXJpdmF0aW9uUGF0aDogc3RyaW5nO1xufSB7XG4gIGZ1bmN0aW9uIGdldFNjcmlwdFB1YktleShpbnB1dDogUHNidElucHV0LCBwcmV2T3V0SW5kZXg6IG51bWJlcikge1xuICAgIGNvbnN0IHNjcmlwdFB1YktleSA9XG4gICAgICBpbnB1dC53aXRuZXNzVXR4bz8uc2NyaXB0ID8/XG4gICAgICAoaW5wdXQubm9uV2l0bmVzc1V0eG9cbiAgICAgICAgPyBjcmVhdGVUcmFuc2FjdGlvbkZyb21CdWZmZXIoaW5wdXQubm9uV2l0bmVzc1V0eG8sIHBzYnQubmV0d29yaywgeyBhbW91bnRUeXBlOiAnYmlnaW50JyB9KS5vdXRzW3ByZXZPdXRJbmRleF1cbiAgICAgICAgICAgIC5zY3JpcHRcbiAgICAgICAgOiB1bmRlZmluZWQpO1xuICAgIGFzc2VydChzY3JpcHRQdWJLZXksICdJbnB1dCBzY3JpcHRQdWJLZXkgY2FuIG5vdCBiZSBmb3VuZCcpO1xuICAgIHJldHVybiBzY3JpcHRQdWJLZXk7XG4gIH1cblxuICBmdW5jdGlvbiBnZXREZXJpdmF0aW9uUGF0aChpbnB1dDogUHNidElucHV0KSB7XG4gICAgY29uc3QgYmlwMzJEdiA9IGlucHV0Py5iaXAzMkRlcml2YXRpb24gPz8gaW5wdXQ/LnRhcEJpcDMyRGVyaXZhdGlvbjtcbiAgICBhc3NlcnQoYmlwMzJEdj8ubGVuZ3RoLCAnSW5wdXQgQmlwMzJEZXJpdmF0aW9uIGNhbiBub3QgYmUgZm91bmQnKTtcbiAgICByZXR1cm4gYmlwMzJEdlswXS5wYXRoO1xuICB9XG5cbiAgY29uc3QgdHhJbnB1dHMgPSBwc2J0LnR4SW5wdXRzO1xuXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgcHNidC5kYXRhLmlucHV0cy5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IGlucHV0ID0gcHNidC5kYXRhLmlucHV0c1tpXTtcbiAgICBjb25zdCBwYXJzZWRTY3JpcHRUeXBlID0gZ2V0UHNidElucHV0U2NyaXB0VHlwZShpbnB1dCk7XG4gICAgaWYgKHBhcnNlZFNjcmlwdFR5cGUgPT09ICdwMnNoUDJwaycpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBjb25zdCBzY3JpcHRQdWJLZXkgPSBnZXRTY3JpcHRQdWJLZXkoaW5wdXQsIHR4SW5wdXRzW2ldLmluZGV4KTtcbiAgICBjb25zdCBkZXJpdmF0aW9uUGF0aCA9IGdldERlcml2YXRpb25QYXRoKGlucHV0KTtcbiAgICByZXR1cm4geyBwYXJzZWRTY3JpcHRUeXBlLCBzY3JpcHRQdWJLZXksIGRlcml2YXRpb25QYXRoIH07XG4gIH1cblxuICB0aHJvdyBuZXcgRXJyb3JOb011bHRpU2lnSW5wdXRGb3VuZCgnTm8gbXVsdGkgc2lnIGlucHV0IGZvdW5kJyk7XG59XG5cbi8qKlxuICogU29ydHMgZ2l2ZW4gcm9vdCBub2RlcyBiYXNlZCBvbiB0aGUgc2NyaXB0IGNvbXBhdGliaWxpdHkgd2l0aCB0aGUgUFNCVCdzIG11bHRpLXNpZyBpbnB1dHMuXG4gKiBAcGFyYW0gcHNidCAtIFRoZSBQU0JUIGNvbnRhaW5pbmcgbXVsdGktc2lnIGlucHV0cy5cbiAqIEBwYXJhbSByb290Tm9kZXMgLSBBcnJheSBvZiByb290IG5vZGVzIHRvIHNvcnQuXG4gKiBAcmV0dXJucyBBbiBhcnJheSBvZiBCSVAzMkludGVyZmFjZSBvYmplY3RzIGluIHRoZSBvcmRlciB0aGF0IG1hdGNoZXMgdGhlIG11bHRpLXNpZyBzY3JpcHQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzb3J0Um9vdE5vZGVzKHBzYnQ6IFV0eG9Qc2J0LCByb290Tm9kZXM6IFRyaXBsZTxCSVAzMkludGVyZmFjZT4pOiBUcmlwbGU8QklQMzJJbnRlcmZhY2U+IHtcbiAgY29uc3QgeyBwYXJzZWRTY3JpcHRUeXBlLCBzY3JpcHRQdWJLZXksIGRlcml2YXRpb25QYXRoIH0gPSBnZXRGaXJzdE11bHRpU2lnSW5wdXREYXRhKHBzYnQpO1xuICBjb25zdCBwdWJLZXlzID0gcm9vdE5vZGVzLm1hcCgocm9vdE5vZGUpID0+IHJvb3ROb2RlLmRlcml2ZVBhdGgoZGVyaXZhdGlvblBhdGgpLnB1YmxpY0tleSkgYXMgVHJpcGxlPEJ1ZmZlcj47XG4gIGNvbnN0IG9yZGVyID0gZmluZFNvcnRPcmRlck9mUHViS2V5cyhwdWJLZXlzLCBzY3JpcHRQdWJLZXksIHBhcnNlZFNjcmlwdFR5cGUsIHBzYnQubmV0d29yayk7XG4gIHJldHVybiBvcmRlci5tYXAoKGkpID0+IHJvb3ROb2Rlc1tpXSkgYXMgVHJpcGxlPEJJUDMySW50ZXJmYWNlPjtcbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgc29ydGVkIHJvb3Qgbm9kZXMgZnJvbSBhIFBTQlQsIGVuc3VyaW5nIHRoZXkgYXJlIG9yZGVyZWQgYWNjb3JkaW5nIHRvIHNjcmlwdCBjb21wYXRpYmlsaXR5LlxuICogQHBhcmFtIHBzYnQgLSBUaGUgUFNCVCB0byBleHRyYWN0IGFuZCBzb3J0IHJvb3Qgbm9kZXMgZnJvbS5cbiAqIEByZXR1cm5zIEFuIGFycmF5IG9mIHNvcnRlZCBCSVAzMkludGVyZmFjZSByb290IG5vZGVzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0U29ydGVkUm9vdE5vZGVzKHBzYnQ6IFV0eG9Qc2J0KTogVHJpcGxlPEJJUDMySW50ZXJmYWNlPiB7XG4gIGNvbnN0IHVuc29ydGVkUm9vdE5vZGVzID0gZ2V0VW5zb3J0ZWRSb290Tm9kZXMocHNidCk7XG4gIGFzc2VydCh1bnNvcnRlZFJvb3ROb2RlcywgJ0NvdWxkIG5vdCBmaW5kIHJvb3Qgbm9kZXMgaW4gUFNCVCcpO1xuICByZXR1cm4gc29ydFJvb3ROb2Rlcyhwc2J0LCB1bnNvcnRlZFJvb3ROb2Rlcyk7XG59XG4iXX0=

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


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