PHP WebShell

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

Просмотр файла: lightning.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.LightningWallet = void 0;
exports.getLightningKeychain = getLightningKeychain;
exports.getLightningAuthKeychains = getLightningAuthKeychains;
const sdkcore = __importStar(require("@bitgo/sdk-core"));
const sdk_core_1 = require("@bitgo/sdk-core");
const t = __importStar(require("io-ts"));
const lightning_1 = require("../lightning");
const codecs_1 = require("../codecs");
const public_types_1 = require("@bitgo/public-types");
/**
 * Get the lightning keychain for the given wallet.
 */
async function getLightningKeychain(wallet) {
    const coin = wallet.baseCoin;
    if (coin.getFamily() !== 'lnbtc') {
        throw new Error(`Invalid coin to get lightning wallet key: ${coin.getFamily()}`);
    }
    const keyIds = wallet.keyIds();
    if (keyIds.length !== 1) {
        throw new Error(`Invalid number of key in lightning wallet: ${keyIds.length}`);
    }
    const keychain = await coin.keychains().get({ id: keyIds[0] });
    return sdkcore.decodeOrElse(codecs_1.LightningKeychain.name, codecs_1.LightningKeychain, keychain, (_) => {
        throw new Error(`Invalid user key`);
    });
}
/**
 * Get the lightning auth keychains for the given wallet.
 */
async function getLightningAuthKeychains(wallet) {
    const coin = wallet.baseCoin;
    if (coin.getFamily() !== 'lnbtc') {
        throw new Error(`Invalid coin to get lightning wallet auth keys: ${coin.getFamily()}`);
    }
    const authKeyIds = wallet.coinSpecific()?.keys;
    if (authKeyIds?.length !== 2) {
        throw new Error(`Invalid number of auth keys in lightning wallet: ${authKeyIds?.length}`);
    }
    const keychains = await Promise.all(authKeyIds.map((id) => coin.keychains().get({ id })));
    const authKeychains = keychains.map((keychain) => {
        return sdkcore.decodeOrElse(codecs_1.LightningAuthKeychain.name, codecs_1.LightningAuthKeychain, keychain, (_) => {
            // DON'T throw errors from decodeOrElse. It could leak sensitive information.
            throw new Error(`Invalid lightning auth key: ${keychain?.id}`);
        });
    });
    const [userAuthKey, nodeAuthKey] = ['userAuth', 'nodeAuth'].map((purpose) => {
        const keychain = authKeychains.find((k) => (0, lightning_1.unwrapLightningCoinSpecific)(k.coinSpecific, coin.getChain()).purpose === purpose);
        if (!keychain) {
            throw new Error(`Missing ${purpose} key`);
        }
        return keychain;
    });
    return { userAuthKey, nodeAuthKey };
}
class LightningWallet {
    constructor(wallet) {
        const coin = wallet.baseCoin;
        if (coin.getFamily() !== 'lnbtc') {
            throw new Error(`Invalid coin for lightning wallet: ${coin.getFamily()}`);
        }
        this.wallet = wallet;
    }
    async createInvoice(params) {
        const createInvoiceResponse = await this.wallet.bitgo
            .post(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice`, 2))
            .send(t.exact(codecs_1.CreateInvoiceBody).encode(params))
            .result();
        return sdkcore.decodeOrElse(codecs_1.Invoice.name, codecs_1.Invoice, createInvoiceResponse, (error) => {
            // DON'T throw errors from decodeOrElse. It could leak sensitive information.
            throw new Error(`Invalid create invoice response ${error}`);
        });
    }
    async getInvoice(paymentHash) {
        const response = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice/${paymentHash}`, 2))
            .result();
        return (0, sdk_core_1.decodeOrElse)(codecs_1.Invoice.name, codecs_1.Invoice, response, (error) => {
            throw new Error(`Invalid get invoice response ${error}`);
        });
    }
    async listInvoices(params) {
        const returnCodec = codecs_1.ListInvoicesResponse;
        const createInvoiceResponse = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice`, 2))
            .query(codecs_1.InvoiceQuery.encode(params))
            .result();
        return sdkcore.decodeOrElse(returnCodec.name, returnCodec, createInvoiceResponse, (error) => {
            throw new Error(`Invalid list invoices response ${error}`);
        });
    }
    async payInvoice(params) {
        const reqId = new sdk_core_1.RequestTracer();
        this.wallet.bitgo.setRequestTracer(reqId);
        const { userAuthKey } = await getLightningAuthKeychains(this.wallet);
        const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;
        if (!userAuthKeyEncryptedPrv) {
            throw new Error(`user auth key is missing encrypted private key`);
        }
        const signature = (0, lightning_1.createMessageSignature)(t.exact(public_types_1.LightningPaymentRequest).encode(params), this.wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv }));
        const paymentIntent = {
            intent: {
                comment: params.comment,
                sequenceId: params.sequenceId,
                intentType: 'payment',
                signedRequest: {
                    invoice: params.invoice,
                    amountMsat: params.amountMsat,
                    feeLimitMsat: params.feeLimitMsat,
                    feeLimitRatio: params.feeLimitRatio,
                },
                signature,
            },
        };
        const transactionRequestCreate = (await this.wallet.bitgo
            .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))
            .send(t.type({ intent: public_types_1.LightningPaymentIntent }).encode(paymentIntent))
            .result());
        if (transactionRequestCreate.state === 'pendingApproval') {
            const pendingApprovals = new sdk_core_1.PendingApprovals(this.wallet.bitgo, this.wallet.baseCoin);
            const pendingApproval = await pendingApprovals.get({ id: transactionRequestCreate.pendingApprovalId });
            return {
                pendingApproval: pendingApproval.toJSON(),
                txRequestId: transactionRequestCreate.txRequestId,
                txRequestState: transactionRequestCreate.state,
            };
        }
        const transfer = await this.wallet.bitgo
            .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestCreate.txRequestId + '/transfers', 2))
            .send()
            .result();
        const transactionRequestSend = await sdk_core_1.commonTssMethods.sendTxRequest(this.wallet.bitgo, this.wallet.id(), transactionRequestCreate.txRequestId, sdk_core_1.RequestType.tx, reqId);
        const coinSpecific = transactionRequestSend.transactions?.[0]?.unsignedTx?.coinSpecific;
        let updatedTransfer = undefined;
        try {
            updatedTransfer = await this.wallet.getTransfer({ id: transfer.id });
        }
        catch (e) {
            // If transfer is not found which is possible in cases where the payment has definitely failed
            // Or even if some unknown error occurs, we will not throw an error here
            // We still want to return the txRequestId, txRequestState and paymentStatus.
        }
        return {
            txRequestId: transactionRequestCreate.txRequestId,
            txRequestState: transactionRequestSend.state,
            paymentStatus: coinSpecific
                ? t.exact(codecs_1.LndCreatePaymentResponse).encode(coinSpecific)
                : undefined,
            transfer: updatedTransfer,
        };
    }
    async withdrawOnchain(params) {
        const reqId = new sdk_core_1.RequestTracer();
        this.wallet.bitgo.setRequestTracer(reqId);
        const paymentIntent = {
            intent: {
                comment: params.comment,
                sequenceId: params.sequenceId,
                onchainRequest: {
                    recipients: params.recipients,
                    satsPerVbyte: params.satsPerVbyte,
                },
                intentType: 'payment',
            },
        };
        const transactionRequestCreate = (await this.wallet.bitgo
            .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))
            .send(t.type({ intent: public_types_1.LightningPaymentIntent }).encode(paymentIntent))
            .result());
        if (!transactionRequestCreate.transactions ||
            transactionRequestCreate.transactions.length === 0 ||
            !transactionRequestCreate.transactions[0].unsignedTx.serializedTxHex) {
            throw new Error(`serialized txHex is missing`);
        }
        const { userAuthKey } = await getLightningAuthKeychains(this.wallet);
        const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;
        if (!userAuthKeyEncryptedPrv) {
            throw new Error(`user auth key is missing encrypted private key`);
        }
        const signature = (0, lightning_1.createMessageSignature)(transactionRequestCreate.transactions[0].unsignedTx.serializedTxHex, this.wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv }));
        const transactionRequestWithSignature = (await this.wallet.bitgo
            .put(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestCreate.txRequestId + '/coinSpecific', 2))
            .send({
            unsignedCoinSpecific: {
                signature,
            },
        })
            .result());
        if (transactionRequestWithSignature.state === 'pendingApproval') {
            const pendingApprovals = new sdk_core_1.PendingApprovals(this.wallet.bitgo, this.wallet.baseCoin);
            const pendingApproval = await pendingApprovals.get({ id: transactionRequestWithSignature.pendingApprovalId });
            return {
                pendingApproval: pendingApproval.toJSON(),
                txRequestId: transactionRequestWithSignature.txRequestId,
                txRequestState: transactionRequestWithSignature.state,
            };
        }
        const transfer = await this.wallet.bitgo
            .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestWithSignature.txRequestId + '/transfers', 2))
            .send()
            .result();
        const transactionRequestSend = await sdk_core_1.commonTssMethods.sendTxRequest(this.wallet.bitgo, this.wallet.id(), transactionRequestWithSignature.txRequestId, sdk_core_1.RequestType.tx, reqId);
        const coinSpecific = transactionRequestSend.transactions?.[0]?.unsignedTx?.coinSpecific;
        let updatedTransfer = undefined;
        try {
            updatedTransfer = await this.wallet.getTransfer({ id: transfer.id });
        }
        catch (e) {
            // If transfer is not found which is possible in cases where the withdraw has definitely failed
            // Or even if some unknown error occurs, we will not throw an error here
            // We still want to return the txRequestId and txRequestState.
        }
        return {
            txRequestId: transactionRequestWithSignature.txRequestId,
            txRequestState: transactionRequestSend.state,
            transfer: updatedTransfer,
            withdrawStatus: coinSpecific && 'status' in coinSpecific
                ? t.exact(codecs_1.LndCreateWithdrawResponse).encode(coinSpecific)
                : undefined,
        };
    }
    async getPayment(paymentId) {
        const response = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/payment/${paymentId}`, 2))
            .result();
        return (0, sdk_core_1.decodeOrElse)(codecs_1.PaymentInfo.name, codecs_1.PaymentInfo, response, (error) => {
            throw new Error(`Invalid payment response: ${error}`);
        });
    }
    async listPayments(params) {
        const response = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/payment`, 2))
            .query(codecs_1.PaymentQuery.encode(params))
            .result();
        return (0, sdk_core_1.decodeOrElse)(codecs_1.ListPaymentsResponse.name, codecs_1.ListPaymentsResponse, response, (error) => {
            throw new Error(`Invalid payment list response: ${error}`);
        });
    }
    async getTransaction(txId) {
        const response = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/transaction/${txId}`, 2))
            .result();
        return (0, sdk_core_1.decodeOrElse)(codecs_1.Transaction.name, codecs_1.Transaction, response, (error) => {
            throw new Error(`Invalid transaction response: ${error}`);
        });
    }
    async listTransactions(params) {
        const response = await this.wallet.bitgo
            .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/transaction`, 2))
            .query(codecs_1.TransactionQuery.encode(params))
            .result();
        return (0, sdk_core_1.decodeOrElse)(t.array(codecs_1.Transaction).name, t.array(codecs_1.Transaction), response, (error) => {
            throw new Error(`Invalid transaction list response: ${error}`);
        });
    }
}
exports.LightningWallet = LightningWallet;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightning.js","sourceRoot":"","sources":["../../../src/wallet/lightning.ts"],"names":[],"mappings":"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","sourcesContent":["import * as sdkcore from '@bitgo/sdk-core';\nimport {\n  PendingApprovalData,\n  PendingApprovals,\n  RequestTracer,\n  RequestType,\n  TxRequest,\n  commonTssMethods,\n  TxRequestState,\n  decodeOrElse,\n} from '@bitgo/sdk-core';\nimport * as t from 'io-ts';\nimport { createMessageSignature, unwrapLightningCoinSpecific } from '../lightning';\nimport {\n  CreateInvoiceBody,\n  Invoice,\n  InvoiceQuery,\n  LightningAuthKeychain,\n  LightningKeychain,\n  LndCreatePaymentResponse,\n  SubmitPaymentParams,\n  Transaction,\n  TransactionQuery,\n  PaymentInfo,\n  PaymentQuery,\n  LightningOnchainWithdrawParams,\n  LightningOnchainWithdrawResponse,\n  ListInvoicesResponse,\n  ListPaymentsResponse,\n  LndCreateWithdrawResponse,\n} from '../codecs';\nimport { LightningPaymentIntent, LightningPaymentRequest } from '@bitgo/public-types';\n\nexport type PayInvoiceResponse = {\n  /**\n   * Unique identifier for the payment request submitted to BitGo.\n   */\n  txRequestId: string;\n\n  /**\n   * Status of the payment request submission to BitGo.\n   * - `'delivered'`: Successfully received by BitGo, but may or may not have been sent to the Lightning Network yet.\n   * - For the actual payment status, refer to `paymentStatus` and track `transfer`.\n   */\n  txRequestState: TxRequestState;\n\n  /**\n   * Pending approval details, if applicable.\n   * - If present, the payment has not been initiated yet.\n   */\n  pendingApproval?: PendingApprovalData;\n\n  /**\n   * Current snapshot of payment status (if available).\n   * - **`'in_flight'`**: Payment is in progress.\n   * - **`'settled'`**: Payment was successfully completed.\n   * - **`'failed'`**: Payment failed.\n   * This field is absent if approval is required before processing.\n   */\n  paymentStatus?: LndCreatePaymentResponse;\n\n  /**\n   * Latest transfer details for this payment request (if available).\n   * - Provides the current state of the transfer.\n   * - To track the final payment status, monitor `transfer` asynchronously.\n   * This field is absent if approval is required before processing.\n   */\n  transfer?: any;\n};\n\n/**\n * Get the lightning keychain for the given wallet.\n */\nexport async function getLightningKeychain(wallet: sdkcore.IWallet): Promise<LightningKeychain> {\n  const coin = wallet.baseCoin;\n  if (coin.getFamily() !== 'lnbtc') {\n    throw new Error(`Invalid coin to get lightning wallet key: ${coin.getFamily()}`);\n  }\n  const keyIds = wallet.keyIds();\n  if (keyIds.length !== 1) {\n    throw new Error(`Invalid number of key in lightning wallet: ${keyIds.length}`);\n  }\n  const keychain = await coin.keychains().get({ id: keyIds[0] });\n  return sdkcore.decodeOrElse(LightningKeychain.name, LightningKeychain, keychain, (_) => {\n    throw new Error(`Invalid user key`);\n  });\n}\n\n/**\n * Get the lightning auth keychains for the given wallet.\n */\nexport async function getLightningAuthKeychains(wallet: sdkcore.IWallet): Promise<{\n  userAuthKey: LightningAuthKeychain;\n  nodeAuthKey: LightningAuthKeychain;\n}> {\n  const coin = wallet.baseCoin;\n  if (coin.getFamily() !== 'lnbtc') {\n    throw new Error(`Invalid coin to get lightning wallet auth keys: ${coin.getFamily()}`);\n  }\n  const authKeyIds = wallet.coinSpecific()?.keys;\n  if (authKeyIds?.length !== 2) {\n    throw new Error(`Invalid number of auth keys in lightning wallet: ${authKeyIds?.length}`);\n  }\n  const keychains = await Promise.all(authKeyIds.map((id) => coin.keychains().get({ id })));\n  const authKeychains = keychains.map((keychain) => {\n    return sdkcore.decodeOrElse(LightningAuthKeychain.name, LightningAuthKeychain, keychain, (_) => {\n      // DON'T throw errors from decodeOrElse. It could leak sensitive information.\n      throw new Error(`Invalid lightning auth key: ${keychain?.id}`);\n    });\n  });\n  const [userAuthKey, nodeAuthKey] = (['userAuth', 'nodeAuth'] as const).map((purpose) => {\n    const keychain = authKeychains.find(\n      (k) => unwrapLightningCoinSpecific(k.coinSpecific, coin.getChain()).purpose === purpose\n    );\n    if (!keychain) {\n      throw new Error(`Missing ${purpose} key`);\n    }\n    return keychain;\n  });\n\n  return { userAuthKey, nodeAuthKey };\n}\n\nexport interface ILightningWallet {\n  /**\n   * Creates a lightning invoice\n   * @param {object} params Invoice parameters\n   * @param {bigint} params.valueMsat The value of the invoice in millisatoshis\n   * @param {string} [params.memo] A memo or description for the invoice\n   * @param {number} [params.expiry] The expiry time of the invoice in seconds\n   * @returns {Promise<Invoice>} A promise that resolves to the created invoice\n   */\n  createInvoice(params: CreateInvoiceBody): Promise<Invoice>;\n  /**\n   * Get invoice details by payment hash\n   * @param {string} paymentHash - Payment hash to lookup\n   * @returns {Promise<Invoice>} Invoice details\n   * @throws {InvalidPaymentHash} When payment hash is not valid\n   */\n  getInvoice(paymentHash: string): Promise<Invoice>;\n  /**\n   * Lists current lightning invoices\n   * @param {InvoiceQuery} params Query parameters for filtering invoices\n   * @param {string} [params.status] The status of the invoice (open, settled, canceled)\n   * @param {bigint} [params.limit] The maximum number of invoices to return\n   * @param {Date} [params.startDate] The start date for the query\n   * @param {Date} [params.endDate] The end date for the query\n   * @param {string} [params.prevId] Continue iterating (provided by nextBatchPrevId in the previous list)\n   * @returns {Promise<ListInvoicesResponse>} List of invoices and nextBatchPrevId\n   */\n  listInvoices(params: InvoiceQuery): Promise<ListInvoicesResponse>;\n\n  /**\n   * Pay a lightning invoice\n   * @param {SubmitPaymentParams} params - Payment parameters\n   * @param {string} params.invoice - The invoice to pay\n   * @param {string} params.amountMsat - The amount to pay in millisatoshis\n   * @param {string} params.passphrase - The wallet passphrase\n   * @param {string} [params.sequenceId] - Optional sequence ID for the respective payment transfer\n   * @param {string} [params.comment] - Optional comment for the respective payment transfer\n   * @returns {Promise<PayInvoiceResponse>} Payment result containing transaction request details and payment status\n   */\n  payInvoice(params: SubmitPaymentParams): Promise<PayInvoiceResponse>;\n\n  /**\n   * On chain withdrawal\n   * @param {LightningOnchainWithdrawParams} params - Withdraw parameters\n   * @param {LightningOnchainRecipient[]} params.recipients - The recipients to pay\n   * @param {bigint} params.satsPerVbyte - Value for sats per virtual byte\n   * @param {string} params.passphrase - The wallet passphrase\n   * @param {string} [params.sequenceId] - Optional sequence ID for the respective withdraw transfer\n   * @param {string} [params.comment] - Optional comment for the respective withdraw transfer\n   * @returns {Promise<LightningOnchainWithdrawResponse>} Withdraw result containing transaction request details and status\n   */\n  withdrawOnchain(params: LightningOnchainWithdrawParams): Promise<LightningOnchainWithdrawResponse>;\n  /**\n   * Get payment details by payment id\n   * @param {string} paymentId - Payment id to lookup\n   * @returns {Promise<PaymentInfo>} Payment details\n   * @throws {InvalidPaymentId} When payment id is not valid\n   */\n  getPayment(paymentId: string): Promise<PaymentInfo>;\n  /**\n   * List payments for a wallet with optional filtering\n   * @param {PaymentQuery} params Query parameters for filtering payments\n   * @param {string} [params.status] The status of the payment\n   * @param {bigint} [params.limit] The maximum number of payments to return\n   * @param {Date} [params.startDate] The start date for the query\n   * @param {Date} [params.endDate] The end date for the query\n   * @param {string} [params.paymentHash] The payment hash of the payments\n   * @param {string} [params.prevId] Continue iterating (provided by nextBatchPrevId in the previous list)\n   * @returns {Promise<ListPaymentsResponse>} List of payments and nextBatchPrevId\n   */\n  listPayments(params: PaymentQuery): Promise<ListPaymentsResponse>;\n  /**\n   * Get transaction details by ID\n   * @param {string} txId - Transaction ID to lookup\n   * @returns {Promise<Transaction>} Transaction details\n   * @throws {InvalidTxId} When transaction ID is not valid\n   */\n  getTransaction(txId: string): Promise<Transaction>;\n\n  /**\n   * List transactions for a wallet with optional filtering\n   * @param {TransactionQuery} params Query parameters for filtering transactions\n   * @param {bigint} [params.limit] The maximum number of transactions to return\n   * @param {Date} [params.startDate] The start date for the query\n   * @param {Date} [params.endDate] The end date for the query\n   * @returns {Promise<Transaction[]>} List of transactions\n   */\n  listTransactions(params: TransactionQuery): Promise<Transaction[]>;\n}\n\nexport class LightningWallet implements ILightningWallet {\n  public wallet: sdkcore.IWallet;\n\n  constructor(wallet: sdkcore.IWallet) {\n    const coin = wallet.baseCoin;\n    if (coin.getFamily() !== 'lnbtc') {\n      throw new Error(`Invalid coin for lightning wallet: ${coin.getFamily()}`);\n    }\n    this.wallet = wallet;\n  }\n\n  async createInvoice(params: CreateInvoiceBody): Promise<Invoice> {\n    const createInvoiceResponse = await this.wallet.bitgo\n      .post(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice`, 2))\n      .send(t.exact(CreateInvoiceBody).encode(params))\n      .result();\n    return sdkcore.decodeOrElse(Invoice.name, Invoice, createInvoiceResponse, (error) => {\n      // DON'T throw errors from decodeOrElse. It could leak sensitive information.\n      throw new Error(`Invalid create invoice response ${error}`);\n    });\n  }\n\n  async getInvoice(paymentHash: string): Promise<Invoice> {\n    const response = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice/${paymentHash}`, 2))\n      .result();\n    return decodeOrElse(Invoice.name, Invoice, response, (error) => {\n      throw new Error(`Invalid get invoice response ${error}`);\n    });\n  }\n\n  async listInvoices(params: InvoiceQuery): Promise<ListInvoicesResponse> {\n    const returnCodec = ListInvoicesResponse;\n    const createInvoiceResponse = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/invoice`, 2))\n      .query(InvoiceQuery.encode(params))\n      .result();\n    return sdkcore.decodeOrElse(returnCodec.name, returnCodec, createInvoiceResponse, (error) => {\n      throw new Error(`Invalid list invoices response ${error}`);\n    });\n  }\n\n  async payInvoice(params: SubmitPaymentParams): Promise<PayInvoiceResponse> {\n    const reqId = new RequestTracer();\n    this.wallet.bitgo.setRequestTracer(reqId);\n\n    const { userAuthKey } = await getLightningAuthKeychains(this.wallet);\n    const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;\n    if (!userAuthKeyEncryptedPrv) {\n      throw new Error(`user auth key is missing encrypted private key`);\n    }\n    const signature = createMessageSignature(\n      t.exact(LightningPaymentRequest).encode(params),\n      this.wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv })\n    );\n\n    const paymentIntent: { intent: LightningPaymentIntent } = {\n      intent: {\n        comment: params.comment,\n        sequenceId: params.sequenceId,\n        intentType: 'payment',\n        signedRequest: {\n          invoice: params.invoice,\n          amountMsat: params.amountMsat,\n          feeLimitMsat: params.feeLimitMsat,\n          feeLimitRatio: params.feeLimitRatio,\n        },\n        signature,\n      },\n    };\n\n    const transactionRequestCreate = (await this.wallet.bitgo\n      .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(t.type({ intent: LightningPaymentIntent }).encode(paymentIntent))\n      .result()) as TxRequest;\n\n    if (transactionRequestCreate.state === 'pendingApproval') {\n      const pendingApprovals = new PendingApprovals(this.wallet.bitgo, this.wallet.baseCoin);\n      const pendingApproval = await pendingApprovals.get({ id: transactionRequestCreate.pendingApprovalId });\n      return {\n        pendingApproval: pendingApproval.toJSON(),\n        txRequestId: transactionRequestCreate.txRequestId,\n        txRequestState: transactionRequestCreate.state,\n      };\n    }\n\n    const transfer: { id: string } = await this.wallet.bitgo\n      .post(\n        this.wallet.bitgo.url(\n          '/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestCreate.txRequestId + '/transfers',\n          2\n        )\n      )\n      .send()\n      .result();\n\n    const transactionRequestSend = await commonTssMethods.sendTxRequest(\n      this.wallet.bitgo,\n      this.wallet.id(),\n      transactionRequestCreate.txRequestId,\n      RequestType.tx,\n      reqId\n    );\n\n    const coinSpecific = transactionRequestSend.transactions?.[0]?.unsignedTx?.coinSpecific;\n    let updatedTransfer: any = undefined;\n    try {\n      updatedTransfer = await this.wallet.getTransfer({ id: transfer.id });\n    } catch (e) {\n      // If transfer is not found which is possible in cases where the payment has definitely failed\n      // Or even if some unknown error occurs, we will not throw an error here\n      // We still want to return the txRequestId, txRequestState and paymentStatus.\n    }\n\n    return {\n      txRequestId: transactionRequestCreate.txRequestId,\n      txRequestState: transactionRequestSend.state,\n      paymentStatus: coinSpecific\n        ? t.exact(LndCreatePaymentResponse).encode(coinSpecific as LndCreatePaymentResponse)\n        : undefined,\n      transfer: updatedTransfer,\n    };\n  }\n\n  async withdrawOnchain(params: LightningOnchainWithdrawParams): Promise<LightningOnchainWithdrawResponse> {\n    const reqId = new RequestTracer();\n    this.wallet.bitgo.setRequestTracer(reqId);\n\n    const paymentIntent: { intent: LightningPaymentIntent } = {\n      intent: {\n        comment: params.comment,\n        sequenceId: params.sequenceId,\n        onchainRequest: {\n          recipients: params.recipients,\n          satsPerVbyte: params.satsPerVbyte,\n        },\n        intentType: 'payment',\n      },\n    };\n\n    const transactionRequestCreate = (await this.wallet.bitgo\n      .post(this.wallet.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(t.type({ intent: LightningPaymentIntent }).encode(paymentIntent))\n      .result()) as TxRequest;\n\n    if (\n      !transactionRequestCreate.transactions ||\n      transactionRequestCreate.transactions.length === 0 ||\n      !transactionRequestCreate.transactions[0].unsignedTx.serializedTxHex\n    ) {\n      throw new Error(`serialized txHex is missing`);\n    }\n\n    const { userAuthKey } = await getLightningAuthKeychains(this.wallet);\n    const userAuthKeyEncryptedPrv = userAuthKey.encryptedPrv;\n    if (!userAuthKeyEncryptedPrv) {\n      throw new Error(`user auth key is missing encrypted private key`);\n    }\n    const signature = createMessageSignature(\n      transactionRequestCreate.transactions[0].unsignedTx.serializedTxHex,\n      this.wallet.bitgo.decrypt({ password: params.passphrase, input: userAuthKeyEncryptedPrv })\n    );\n\n    const transactionRequestWithSignature = (await this.wallet.bitgo\n      .put(\n        this.wallet.bitgo.url(\n          '/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestCreate.txRequestId + '/coinSpecific',\n          2\n        )\n      )\n      .send({\n        unsignedCoinSpecific: {\n          signature,\n        },\n      })\n      .result()) as TxRequest;\n\n    if (transactionRequestWithSignature.state === 'pendingApproval') {\n      const pendingApprovals = new PendingApprovals(this.wallet.bitgo, this.wallet.baseCoin);\n      const pendingApproval = await pendingApprovals.get({ id: transactionRequestWithSignature.pendingApprovalId });\n      return {\n        pendingApproval: pendingApproval.toJSON(),\n        txRequestId: transactionRequestWithSignature.txRequestId,\n        txRequestState: transactionRequestWithSignature.state,\n      };\n    }\n\n    const transfer: { id: string } = await this.wallet.bitgo\n      .post(\n        this.wallet.bitgo.url(\n          '/wallet/' + this.wallet.id() + '/txrequests/' + transactionRequestWithSignature.txRequestId + '/transfers',\n          2\n        )\n      )\n      .send()\n      .result();\n\n    const transactionRequestSend = await commonTssMethods.sendTxRequest(\n      this.wallet.bitgo,\n      this.wallet.id(),\n      transactionRequestWithSignature.txRequestId,\n      RequestType.tx,\n      reqId\n    );\n\n    const coinSpecific = transactionRequestSend.transactions?.[0]?.unsignedTx?.coinSpecific;\n    let updatedTransfer: any = undefined;\n    try {\n      updatedTransfer = await this.wallet.getTransfer({ id: transfer.id });\n    } catch (e) {\n      // If transfer is not found which is possible in cases where the withdraw has definitely failed\n      // Or even if some unknown error occurs, we will not throw an error here\n      // We still want to return the txRequestId and txRequestState.\n    }\n\n    return {\n      txRequestId: transactionRequestWithSignature.txRequestId,\n      txRequestState: transactionRequestSend.state,\n      transfer: updatedTransfer,\n      withdrawStatus:\n        coinSpecific && 'status' in coinSpecific\n          ? t.exact(LndCreateWithdrawResponse).encode(coinSpecific as LndCreateWithdrawResponse)\n          : undefined,\n    };\n  }\n\n  async getPayment(paymentId: string): Promise<PaymentInfo> {\n    const response = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/payment/${paymentId}`, 2))\n      .result();\n    return decodeOrElse(PaymentInfo.name, PaymentInfo, response, (error) => {\n      throw new Error(`Invalid payment response: ${error}`);\n    });\n  }\n\n  async listPayments(params: PaymentQuery): Promise<ListPaymentsResponse> {\n    const response = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/payment`, 2))\n      .query(PaymentQuery.encode(params))\n      .result();\n    return decodeOrElse(ListPaymentsResponse.name, ListPaymentsResponse, response, (error) => {\n      throw new Error(`Invalid payment list response: ${error}`);\n    });\n  }\n\n  async getTransaction(txId: string): Promise<Transaction> {\n    const response = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/transaction/${txId}`, 2))\n      .result();\n    return decodeOrElse(Transaction.name, Transaction, response, (error) => {\n      throw new Error(`Invalid transaction response: ${error}`);\n    });\n  }\n\n  async listTransactions(params: TransactionQuery): Promise<Transaction[]> {\n    const response = await this.wallet.bitgo\n      .get(this.wallet.bitgo.url(`/wallet/${this.wallet.id()}/lightning/transaction`, 2))\n      .query(TransactionQuery.encode(params))\n      .result();\n    return decodeOrElse(t.array(Transaction).name, t.array(Transaction), response, (error) => {\n      throw new Error(`Invalid transaction list response: ${error}`);\n    });\n  }\n}\n"]}

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


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