PHP WebShell

Текущая директория: /opt/BitGoJS/modules/abstract-lightning/dist/src/wallet

Просмотр файла: selfCustodialLightning.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.SelfCustodialLightningWallet = void 0;
exports.updateWalletCoinSpecific = updateWalletCoinSpecific;
const sdkcore = __importStar(require("@bitgo/sdk-core"));
const codecs_1 = require("../codecs");
const lightning_1 = require("./lightning");
const lightning_2 = require("../lightning");
const t = __importStar(require("io-ts"));
function encryptWalletUpdateRequest(wallet, params, userAuthKeyEncryptedPrv) {
    const coinName = wallet.coin();
    const requestWithEncryption = {
        ...params,
    };
    const userAuthXprv = wallet.bitgo.decrypt({
        password: params.passphrase,
        input: userAuthKeyEncryptedPrv,
    });
    if (params.signerTlsKey) {
        requestWithEncryption.encryptedSignerTlsKey = wallet.bitgo.encrypt({
            password: params.passphrase,
            input: params.signerTlsKey,
        });
    }
    if (params.signerAdminMacaroon) {
        requestWithEncryption.encryptedSignerAdminMacaroon = wallet.bitgo.encrypt({
            password: params.passphrase,
            input: params.signerAdminMacaroon,
        });
    }
    if (params.signerMacaroon) {
        requestWithEncryption.encryptedSignerMacaroon = wallet.bitgo.encrypt({
            password: (0, lightning_2.deriveLightningServiceSharedSecret)(coinName, userAuthXprv).toString('hex'),
            input: params.signerMacaroon,
        });
    }
    return t.exact(codecs_1.UpdateLightningWalletEncryptedRequest).encode(requestWithEncryption);
}
/**
 * Updates the coin-specific configuration for a Lightning Wallet.
 *
 * @param {Wallet} wallet - Wallet.
 * @param {UpdateLightningWalletClientRequest} params - The parameters containing the updated wallet-specific details.
 *   - `encryptedSignerMacaroon` (optional): This macaroon is used by the watch-only node to ask the signer node to sign transactions.
 *     Encrypted with ECDH secret key from private key of wallet's user auth key and public key of lightning service.
 *   - `encryptedSignerAdminMacaroon` (optional): Generated when initializing the wallet of the signer node.
 *     Encrypted with client's wallet passphrase.
 *   - `signerHost` (optional): The host address of the Lightning signer node.
 *   - `encryptedSignerTlsKey` (optional): The wallet passphrase encrypted TLS key of the signer.
 *   - `passphrase` (required): The wallet passphrase.
 *   - `signerTlsCert` (optional): The TLS certificate of the signer.
 *   - `watchOnlyAccounts` (optional): These are the accounts used to initialize the watch-only wallet.
 * @returns {Promise<unknown>} A promise resolving to the updated wallet response or throwing an error if the update fails.
 */
async function updateWalletCoinSpecific(wallet, params) {
    if (!(0, lightning_2.isLightningCoinName)(wallet.coin())) {
        throw new Error(`cant update lightning wallet coin specific for coin ${wallet.subType()}`);
    }
    if (wallet.subType() !== 'lightningSelfCustody') {
        throw new Error(`cant update lightning wallet coin specific for wallet type ${wallet.subType()}`);
    }
    sdkcore.decodeOrElse(codecs_1.UpdateLightningWalletClientRequest.name, codecs_1.UpdateLightningWalletClientRequest, params, (errors) => {
        // DON'T throw errors from decodeOrElse. It could leak sensitive information.
        throw new Error(`Invalid params for lightning specific update wallet`);
    });
    const { userAuthKey } = await (0, lightning_1.getLightningAuthKeychains)(wallet);
    const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;
    if (!userAuthKeyEncryptedPrv) {
        throw new Error(`user auth key is missing encrypted private key`);
    }
    const updateRequestWithEncryption = encryptWalletUpdateRequest(wallet, params, userAuthKeyEncryptedPrv);
    const signature = (0, lightning_2.createMessageSignature)(updateRequestWithEncryption, wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv }));
    const coinSpecific = {
        [wallet.coin()]: {
            signedRequest: updateRequestWithEncryption,
            signature,
        },
    };
    return await wallet.bitgo.put(wallet.url()).send({ coinSpecific }).result();
}
class SelfCustodialLightningWallet extends lightning_1.LightningWallet {
    constructor(wallet) {
        super(wallet);
        if (wallet.subType() !== 'lightningSelfCustody') {
            throw new Error(`Invalid lightning wallet type for self custodial lightning: ${wallet.subType()}`);
        }
    }
    async getChannelBackup() {
        const backupResponse = await this.wallet.bitgo
            .get(this.wallet.baseCoin.url(`/wallet/${this.wallet.id()}/lightning/backup`))
            .result();
        return sdkcore.decodeOrElse(codecs_1.BackupResponse.name, codecs_1.BackupResponse, backupResponse, (error) => {
            throw new Error(`Invalid backup response: ${error}`);
        });
    }
}
exports.SelfCustodialLightningWallet = SelfCustodialLightningWallet;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZkN1c3RvZGlhbExpZ2h0bmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy93YWxsZXQvc2VsZkN1c3RvZGlhbExpZ2h0bmluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUE4REEsNERBc0NDO0FBcEdELHlEQUEyQztBQUMzQyxzQ0FBc0g7QUFDdEgsMkNBQTJGO0FBQzNGLDRDQUErRztBQUMvRyx5Q0FBMkI7QUFFM0IsU0FBUywwQkFBMEIsQ0FDakMsTUFBdUIsRUFDdkIsTUFBMEMsRUFDMUMsdUJBQStCO0lBRS9CLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQXdCLENBQUM7SUFFckQsTUFBTSxxQkFBcUIsR0FBd0Y7UUFDakgsR0FBRyxNQUFNO0tBQ1YsQ0FBQztJQUVGLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQ3hDLFFBQVEsRUFBRSxNQUFNLENBQUMsVUFBVTtRQUMzQixLQUFLLEVBQUUsdUJBQXVCO0tBQy9CLENBQUMsQ0FBQztJQUVILElBQUksTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3hCLHFCQUFxQixDQUFDLHFCQUFxQixHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDO1lBQ2pFLFFBQVEsRUFBRSxNQUFNLENBQUMsVUFBVTtZQUMzQixLQUFLLEVBQUUsTUFBTSxDQUFDLFlBQVk7U0FDM0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksTUFBTSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDL0IscUJBQXFCLENBQUMsNEJBQTRCLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUM7WUFDeEUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxVQUFVO1lBQzNCLEtBQUssRUFBRSxNQUFNLENBQUMsbUJBQW1CO1NBQ2xDLENBQUMsQ0FBQztJQUNMLENB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QUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsV0FBVyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO2FBQzdFLE1BQU0sRUFBRSxDQUFDO1FBQ1osT0FBTyxPQUFPLENBQUMsWUFBWSxDQUFDLHVCQUFjLENBQUMsSUFBSSxFQUFFLHVCQUFjLEVBQUUsY0FBYyxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDekYsTUFBTSxJQUFJLEtBQUssQ0FBQyw0QkFBNEIsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN2RCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWhCRCxvRUFnQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBzZGtjb3JlIGZyb20gJ0BiaXRnby9zZGstY29yZSc7XG5pbXBvcnQgeyBCYWNrdXBSZXNwb25zZSwgVXBkYXRlTGlnaHRuaW5nV2FsbGV0Q2xpZW50UmVxdWVzdCwgVXBkYXRlTGlnaHRuaW5nV2FsbGV0RW5jcnlwdGVkUmVxdWVzdCB9IGZyb20gJy4uL2NvZGVjcyc7XG5pbXBvcnQgeyBnZXRMaWdodG5pbmdBdXRoS2V5Y2hhaW5zLCBJTGlnaHRuaW5nV2FsbGV0LCBMaWdodG5pbmdXYWxsZXQgfSBmcm9tICcuL2xpZ2h0bmluZyc7XG5pbXBvcnQgeyBjcmVhdGVNZXNzYWdlU2lnbmF0dXJlLCBkZXJpdmVMaWdodG5pbmdTZXJ2aWNlU2hhcmVkU2VjcmV0LCBpc0xpZ2h0bmluZ0NvaW5OYW1lIH0gZnJvbSAnLi4vbGlnaHRuaW5nJztcbmltcG9ydCAqIGFzIHQgZnJvbSAnaW8tdHMnO1xuXG5mdW5jdGlvbiBlbmNyeXB0V2FsbGV0VXBkYXRlUmVxdWVzdChcbiAgd2FsbGV0OiBzZGtjb3JlLklXYWxsZXQsXG4gIHBhcmFtczogVXBkYXRlTGlnaHRuaW5nV2FsbGV0Q2xpZW50UmVxdWVzdCxcbiAgdXNlckF1dGhLZXlFbmNyeXB0ZWRQcnY6IHN0cmluZ1xuKTogVXBkYXRlTGlnaHRuaW5nV2FsbGV0RW5jcnlwdGVkUmVxdWVzdCB7XG4gIGNvbnN0IGNvaW5OYW1lID0gd2FsbGV0LmNvaW4oKSBhcyAndGxuYnRjJyB8ICdsbmJ0Yyc7XG5cbiAgY29uc3QgcmVxdWVzdFdpdGhFbmNyeXB0aW9uOiBQYXJ0aWFsPFVwZGF0ZUxpZ2h0bmluZ1dhbGxldENsaWVudFJlcXVlc3QgJiBVcGRhdGVMaWdodG5pbmdXYWxsZXRFbmNyeXB0ZWRSZXF1ZXN0PiA9IHtcbiAgICAuLi5wYXJhbXMsXG4gIH07XG5cbiAgY29uc3QgdXNlckF1dGhYcHJ2ID0gd2FsbGV0LmJpdGdvLmRlY3J5cHQoe1xuICAgIHBhc3N3b3JkOiBwYXJhbXMucGFzc3BocmFzZSxcbiAgICBpbnB1dDogdXNlckF1dGhLZXlFbmNyeXB0ZWRQcnYsXG4gIH0pO1xuXG4gIGlmIChwYXJhbXMuc2lnbmVyVGxzS2V5KSB7XG4gICAgcmVxdWVzdFdpdGhFbmNyeXB0aW9uLmVuY3J5cHRlZFNpZ25lclRsc0tleSA9IHdhbGxldC5iaXRnby5lbmNyeXB0KHtcbiAgICAgIHBhc3N3b3JkOiBwYXJhbXMucGFzc3BocmFzZSxcbiAgICAgIGlucHV0OiBwYXJhbXMuc2lnbmVyVGxzS2V5LFxuICAgIH0pO1xuICB9XG5cbiAgaWYgKHBhcmFtcy5zaWduZXJBZG1pbk1hY2Fyb29uKSB7XG4gICAgcmVxdWVzdFdpdGhFbmNyeXB0aW9uLmVuY3J5cHRlZFNpZ25lckFkbWluTWFjYXJvb24gPSB3YWxsZXQuYml0Z28uZW5jcnlwdCh7XG4gICAgICBwYXNzd29yZDogcGFyYW1zLnBhc3NwaHJhc2UsXG4gICAgICBpbnB1dDogcGFyYW1zLnNpZ25lckFkbWluTWFjYXJvb24sXG4gICAgfSk7XG4gIH1cblxuICBpZiAocGFyYW1zLnNpZ25lck1hY2Fyb29uKSB7XG4gICAgcmVxdWVzdFdpdGhFbmNyeXB0aW9uLmVuY3J5cHRlZFNpZ25lck1hY2Fyb29uID0gd2FsbGV0LmJpdGdvLmVuY3J5cHQoe1xuICAgICAgcGFzc3dvcmQ6IGRlcml2ZUxpZ2h0bmluZ1NlcnZpY2VTaGFyZWRTZWNyZXQoY29pbk5hbWUsIHVzZXJBdXRoWHBydikudG9TdHJpbmcoJ2hleCcpLFxuICAgICAgaW5wdXQ6IHBhcmFtcy5zaWduZXJNYWNhcm9vbixcbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiB0LmV4YWN0KFVwZGF0ZUxpZ2h0bmluZ1dhbGxldEVuY3J5cHRlZFJlcXVlc3QpLmVuY29kZShyZXF1ZXN0V2l0aEVuY3J5cHRpb24pO1xufVxuXG4vKipcbiAqIFVwZGF0ZXMgdGhlIGNvaW4tc3BlY2lmaWMgY29uZmlndXJhdGlvbiBmb3IgYSBMaWdodG5pbmcgV2FsbGV0LlxuICpcbiAqIEBwYXJhbSB7V2FsbGV0fSB3YWxsZXQgLSBXYWxsZXQuXG4gKiBAcGFyYW0ge1VwZGF0ZUxpZ2h0bmluZ1dhbGxldENsaWVudFJlcXVlc3R9IHBhcmFtcyAtIFRoZSBwYXJhbWV0ZXJzIGNvbnRhaW5pbmcgdGhlIHVwZGF0ZWQgd2FsbGV0LXNwZWNpZmljIGRldGFpbHMuXG4gKiAgIC0gYGVuY3J5cHRlZFNpZ25lck1hY2Fyb29uYCAob3B0aW9uYWwpOiBUaGlzIG1hY2Fyb29uIGlzIHVzZWQgYnkgdGhlIHdhdGNoLW9ubHkgbm9kZSB0byBhc2sgdGhlIHNpZ25lciBub2RlIHRvIHNpZ24gdHJhbnNhY3Rpb25zLlxuICogICAgIEVuY3J5cHRlZCB3aXRoIEVDREggc2VjcmV0IGtleSBmcm9tIHByaXZhdGUga2V5IG9mIHdhbGxldCdzIHVzZXIgYXV0aCBrZXkgYW5kIHB1YmxpYyBrZXkgb2YgbGlnaHRuaW5nIHNlcnZpY2UuXG4gKiAgIC0gYGVuY3J5cHRlZFNpZ25lckFkbWluTWFjYXJvb25gIChvcHRpb25hbCk6IEdlbmVyYXRlZCB3aGVuIGluaXRpYWxpemluZyB0aGUgd2FsbGV0IG9mIHRoZSBzaWduZXIgbm9kZS5cbiAqICAgICBFbmNyeXB0ZWQgd2l0aCBjbGllbnQncyB3YWxsZXQgcGFzc3BocmFzZS5cbiAqICAgLSBgc2lnbmVySG9zdGAgKG9wdGlvbmFsKTogVGhlIGhvc3QgYWRkcmVzcyBvZiB0aGUgTGlnaHRuaW5nIHNpZ25lciBub2RlLlxuICogICAtIGBlbmNyeXB0ZWRTaWduZXJUbHNLZXlgIChvcHRpb25hbCk6IFRoZSB3YWxsZXQgcGFzc3BocmFzZSBlbmNyeXB0ZWQgVExTIGtleSBvZiB0aGUgc2lnbmVyLlxuICogICAtIGBwYXNzcGhyYXNlYCAocmVxdWlyZWQpOiBUaGUgd2FsbGV0IHBhc3NwaHJhc2UuXG4gKiAgIC0gYHNpZ25lclRsc0NlcnRgIChvcHRpb25hbCk6IFRoZSBUTFMgY2VydGlmaWNhdGUgb2YgdGhlIHNpZ25lci5cbiAqICAgLSBgd2F0Y2hPbmx5QWNjb3VudHNgIChvcHRpb25hbCk6IFRoZXNlIGFyZSB0aGUgYWNjb3VudHMgdXNlZCB0byBpbml0aWFsaXplIHRoZSB3YXRjaC1vbmx5IHdhbGxldC5cbiAqIEByZXR1cm5zIHtQcm9taXNlPHVua25vd24+fSBBIHByb21pc2UgcmVzb2x2aW5nIHRvIHRoZSB1cGRhdGVkIHdhbGxldCByZXNwb25zZSBvciB0aHJvd2luZyBhbiBlcnJvciBpZiB0aGUgdXBkYXRlIGZhaWxzLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdXBkYXRlV2FsbGV0Q29pblNwZWNpZmljKFxuICB3YWxsZXQ6IHNka2NvcmUuSVdhbGxldCxcbiAgcGFyYW1zOiBVcGRhdGVMaWdodG5pbmdXYWxsZXRDbGllbnRSZXF1ZXN0XG4pOiBQcm9taXNlPHVua25vd24+IHtcbiAgaWYgKCFpc0xpZ2h0bmluZ0NvaW5OYW1lKHdhbGxldC5jb2luKCkpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBjYW50IHVwZGF0ZSBsaWdodG5pbmcgd2FsbGV0IGNvaW4gc3BlY2lmaWMgZm9yIGNvaW4gJHt3YWxsZXQuc3ViVHlwZSgpfWApO1xuICB9XG4gIGlmICh3YWxsZXQuc3ViVHlwZSgpICE9PSAnbGlnaHRuaW5nU2VsZkN1c3RvZHknKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBjYW50IHVwZGF0ZSBsaWdodG5pbmcgd2FsbGV0IGNvaW4gc3BlY2lmaWMgZm9yIHdhbGxldCB0eXBlICR7d2FsbGV0LnN1YlR5cGUoKX1gKTtcbiAgfVxuXG4gIHNka2NvcmUuZGVjb2RlT3JFbHNlKFxuICAgIFVwZGF0ZUxpZ2h0bmluZ1dhbGxldENsaWVudFJlcXVlc3QubmFtZSxcbiAgICBVcGRhdGVMaWdodG5pbmdXYWxsZXRDbGllbnRSZXF1ZXN0LFxuICAgIHBhcmFtcyxcbiAgICAoZXJyb3JzKSA9PiB7XG4gICAgICAvLyBET04nVCB0aHJvdyBlcnJvcnMgZnJvbSBkZWNvZGVPckVsc2UuIEl0IGNvdWxkIGxlYWsgc2Vuc2l0aXZlIGluZm9ybWF0aW9uLlxuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHBhcmFtcyBmb3IgbGlnaHRuaW5nIHNwZWNpZmljIHVwZGF0ZSB3YWxsZXRgKTtcbiAgICB9XG4gICk7XG5cbiAgY29uc3QgeyB1c2VyQXV0aEtleSB9ID0gYXdhaXQgZ2V0TGlnaHRuaW5nQXV0aEtleWNoYWlucyh3YWxsZXQpO1xuICBjb25zdCB1c2VyQXV0aEtleUVuY3J5cHRlZFBydiA9IHVzZXJBdXRoS2V5LmVuY3J5cHRlZFBydjtcbiAgaWYgKCF1c2VyQXV0aEtleUVuY3J5cHRlZFBydikge1xuICAgIHRocm93IG5ldyBFcnJvcihgdXNlciBhdXRoIGtleSBpcyBtaXNzaW5nIGVuY3J5cHRlZCBwcml2YXRlIGtleWApO1xuICB9XG4gIGNvbnN0IHVwZGF0ZVJlcXVlc3RXaXRoRW5jcnlwdGlvbiA9IGVuY3J5cHRXYWxsZXRVcGRhdGVSZXF1ZXN0KHdhbGxldCwgcGFyYW1zLCB1c2VyQXV0aEtleUVuY3J5cHRlZFBydik7XG4gIGNvbnN0IHNpZ25hdHVyZSA9IGNyZWF0ZU1lc3NhZ2VTaWduYXR1cmUoXG4gICAgdXBkYXRlUmVxdWVzdFdpdGhFbmNyeXB0aW9uLFxuICAgIHdhbGxldC5iaXRnby5kZWNyeXB0KHsgcGFzc3dvcmQ6IHBhcmFtcy5wYXNzcGhyYXNlLCBpbnB1dDogdXNlckF1dGhLZXlFbmNyeXB0ZWRQcnYgfSlcbiAgKTtcbiAgY29uc3QgY29pblNwZWNpZmljID0ge1xuICAgIFt3YWxsZXQuY29pbigpXToge1xuICAgICAgc2lnbmVkUmVxdWVzdDogdXBkYXRlUmVxdWVzdFdpdGhFbmNyeXB0aW9uLFxuICAgICAgc2lnbmF0dXJlLFxuICAgIH0sXG4gIH07XG4gIHJldHVybiBhd2FpdCB3YWxsZXQuYml0Z28ucHV0KHdhbGxldC51cmwoKSkuc2VuZCh7IGNvaW5TcGVjaWZpYyB9KS5yZXN1bHQoKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJU2VsZkN1c3RvZGlhbExpZ2h0bmluZ1dhbGxldCBleHRlbmRzIElMaWdodG5pbmdXYWxsZXQge1xuICAvKipcbiAgICogR2V0IHRoZSBjaGFubmVsIGJhY2t1cCBmb3IgdGhlIGdpdmVuIHdhbGxldC5cbiAgICogQHJldHVybnMge1Byb21pc2U8QmFja3VwUmVzcG9uc2U+fSBBIHByb21pc2UgcmVzb2x2aW5nIHRvIHRoZSBjaGFubmVsIGJhY2t1cFxuICAgKi9cbiAgZ2V0Q2hhbm5lbEJhY2t1cCgpOiBQcm9taXNlPEJhY2t1cFJlc3BvbnNlPjtcbn1cblxuZXhwb3J0IGNsYXNzIFNlbGZDdXN0b2RpYWxMaWdodG5pbmdXYWxsZXQgZXh0ZW5kcyBMaWdodG5pbmdXYWxsZXQgaW1wbGVtZW50cyBJU2VsZkN1c3RvZGlhbExpZ2h0bmluZ1dhbGxldCB7XG4gIGNvbnN0cnVjdG9yKHdhbGxldDogc2RrY29yZS5JV2FsbGV0KSB7XG4gICAgc3VwZXIod2FsbGV0KTtcbiAgICBpZiAod2FsbGV0LnN1YlR5cGUoKSAhPT0gJ2xpZ2h0bmluZ1NlbGZDdXN0b2R5Jykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGxpZ2h0bmluZyB3YWxsZXQgdHlwZSBmb3Igc2VsZiBjdXN0b2RpYWwgbGlnaHRuaW5nOiAke3dhbGxldC5zdWJUeXBlKCl9YCk7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgZ2V0Q2hhbm5lbEJhY2t1cCgpOiBQcm9taXNlPEJhY2t1cFJlc3BvbnNlPiB7XG4gICAgY29uc3QgYmFja3VwUmVzcG9uc2UgPSBhd2FpdCB0aGlzLndhbGxldC5iaXRnb1xuICAgICAgLmdldCh0aGlzLndhbGxldC5iYXNlQ29pbi51cmwoYC93YWxsZXQvJHt0aGlzLndhbGxldC5pZCgpfS9saWdodG5pbmcvYmFja3VwYCkpXG4gICAgICAucmVzdWx0KCk7XG4gICAgcmV0dXJuIHNka2NvcmUuZGVjb2RlT3JFbHNlKEJhY2t1cFJlc3BvbnNlLm5hbWUsIEJhY2t1cFJlc3BvbnNlLCBiYWNrdXBSZXNwb25zZSwgKGVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEludmFsaWQgYmFja3VwIHJlc3BvbnNlOiAke2Vycm9yfWApO1xuICAgIH0pO1xuICB9XG59XG4iXX0=

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


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