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,{"version":3,"file":"selfCustodialLightning.js","sourceRoot":"","sources":["../../../src/wallet/selfCustodialLightning.ts"],"names":[],"mappings":"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","sourcesContent":["import * as sdkcore from '@bitgo/sdk-core';\nimport { BackupResponse, UpdateLightningWalletClientRequest, UpdateLightningWalletEncryptedRequest } from '../codecs';\nimport { getLightningAuthKeychains, ILightningWallet, LightningWallet } from './lightning';\nimport { createMessageSignature, deriveLightningServiceSharedSecret, isLightningCoinName } from '../lightning';\nimport * as t from 'io-ts';\n\nfunction encryptWalletUpdateRequest(\n  wallet: sdkcore.IWallet,\n  params: UpdateLightningWalletClientRequest,\n  userAuthKeyEncryptedPrv: string\n): UpdateLightningWalletEncryptedRequest {\n  const coinName = wallet.coin() as 'tlnbtc' | 'lnbtc';\n\n  const requestWithEncryption: Partial<UpdateLightningWalletClientRequest & UpdateLightningWalletEncryptedRequest> = {\n    ...params,\n  };\n\n  const userAuthXprv = wallet.bitgo.decrypt({\n    password: params.passphrase,\n    input: userAuthKeyEncryptedPrv,\n  });\n\n  if (params.signerTlsKey) {\n    requestWithEncryption.encryptedSignerTlsKey = wallet.bitgo.encrypt({\n      password: params.passphrase,\n      input: params.signerTlsKey,\n    });\n  }\n\n  if (params.signerAdminMacaroon) {\n    requestWithEncryption.encryptedSignerAdminMacaroon = wallet.bitgo.encrypt({\n      password: params.passphrase,\n      input: params.signerAdminMacaroon,\n    });\n  }\n\n  if (params.signerMacaroon) {\n    requestWithEncryption.encryptedSignerMacaroon = wallet.bitgo.encrypt({\n      password: deriveLightningServiceSharedSecret(coinName, userAuthXprv).toString('hex'),\n      input: params.signerMacaroon,\n    });\n  }\n\n  return t.exact(UpdateLightningWalletEncryptedRequest).encode(requestWithEncryption);\n}\n\n/**\n * Updates the coin-specific configuration for a Lightning Wallet.\n *\n * @param {Wallet} wallet - Wallet.\n * @param {UpdateLightningWalletClientRequest} params - The parameters containing the updated wallet-specific details.\n *   - `encryptedSignerMacaroon` (optional): This macaroon is used by the watch-only node to ask the signer node to sign transactions.\n *     Encrypted with ECDH secret key from private key of wallet's user auth key and public key of lightning service.\n *   - `encryptedSignerAdminMacaroon` (optional): Generated when initializing the wallet of the signer node.\n *     Encrypted with client's wallet passphrase.\n *   - `signerHost` (optional): The host address of the Lightning signer node.\n *   - `encryptedSignerTlsKey` (optional): The wallet passphrase encrypted TLS key of the signer.\n *   - `passphrase` (required): The wallet passphrase.\n *   - `signerTlsCert` (optional): The TLS certificate of the signer.\n *   - `watchOnlyAccounts` (optional): These are the accounts used to initialize the watch-only wallet.\n * @returns {Promise<unknown>} A promise resolving to the updated wallet response or throwing an error if the update fails.\n */\nexport async function updateWalletCoinSpecific(\n  wallet: sdkcore.IWallet,\n  params: UpdateLightningWalletClientRequest\n): Promise<unknown> {\n  if (!isLightningCoinName(wallet.coin())) {\n    throw new Error(`cant update lightning wallet coin specific for coin ${wallet.subType()}`);\n  }\n  if (wallet.subType() !== 'lightningSelfCustody') {\n    throw new Error(`cant update lightning wallet coin specific for wallet type ${wallet.subType()}`);\n  }\n\n  sdkcore.decodeOrElse(\n    UpdateLightningWalletClientRequest.name,\n    UpdateLightningWalletClientRequest,\n    params,\n    (errors) => {\n      // DON'T throw errors from decodeOrElse. It could leak sensitive information.\n      throw new Error(`Invalid params for lightning specific update wallet`);\n    }\n  );\n\n  const { userAuthKey } = await getLightningAuthKeychains(wallet);\n  const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;\n  if (!userAuthKeyEncryptedPrv) {\n    throw new Error(`user auth key is missing encrypted private key`);\n  }\n  const updateRequestWithEncryption = encryptWalletUpdateRequest(wallet, params, userAuthKeyEncryptedPrv);\n  const signature = createMessageSignature(\n    updateRequestWithEncryption,\n    wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv })\n  );\n  const coinSpecific = {\n    [wallet.coin()]: {\n      signedRequest: updateRequestWithEncryption,\n      signature,\n    },\n  };\n  return await wallet.bitgo.put(wallet.url()).send({ coinSpecific }).result();\n}\n\nexport interface ISelfCustodialLightningWallet extends ILightningWallet {\n  /**\n   * Get the channel backup for the given wallet.\n   * @returns {Promise<BackupResponse>} A promise resolving to the channel backup\n   */\n  getChannelBackup(): Promise<BackupResponse>;\n}\n\nexport class SelfCustodialLightningWallet extends LightningWallet implements ISelfCustodialLightningWallet {\n  constructor(wallet: sdkcore.IWallet) {\n    super(wallet);\n    if (wallet.subType() !== 'lightningSelfCustody') {\n      throw new Error(`Invalid lightning wallet type for self custodial lightning: ${wallet.subType()}`);\n    }\n  }\n\n  async getChannelBackup(): Promise<BackupResponse> {\n    const backupResponse = await this.wallet.bitgo\n      .get(this.wallet.baseCoin.url(`/wallet/${this.wallet.id()}/lightning/backup`))\n      .result();\n    return sdkcore.decodeOrElse(BackupResponse.name, BackupResponse, backupResponse, (error) => {\n      throw new Error(`Invalid backup response: ${error}`);\n    });\n  }\n}\n"]}

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


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