PHP WebShell
Текущая директория: /opt/BitGoJS/modules/express/dist/lightning
Просмотр файла: lndSignerClient.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.LndSignerClient = void 0;
const https = require("https");
const superagent = require("superagent");
const sdk_core_1 = require("@bitgo/sdk-core");
const retryPromise_1 = require("../retryPromise");
const codecs_1 = require("./codecs");
const lightningUtils_1 = require("./lightningUtils");
/**
* Client for interacting with the LND signer.
*/
class LndSignerClient {
constructor(config) {
this.url = config.url;
this.httpsAgent = new https.Agent({
ca: Buffer.from(config.tlsCert, 'base64').toString('utf-8'),
});
}
/**
* Create a new LndSignerClient.
*/
static async create(walletId, config) {
const lightningSignerConfig = await (0, lightningUtils_1.getLightningSignerConfig)(walletId, config);
return new LndSignerClient(lightningSignerConfig);
}
/**
* Get the current state of the wallet from remote signer LND.
*/
async getWalletState() {
const res = await (0, retryPromise_1.retryPromise)(() => superagent.get(`${this.url}/v1/state`).agent(this.httpsAgent).send(), (err, tryCount) => {
console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);
});
if (res.status !== 200) {
throw new Error(`Failed to get wallet state with status: ${res.text}`);
}
return (0, sdk_core_1.decodeOrElse)(codecs_1.GetWalletStateResponse.name, codecs_1.GetWalletStateResponse, res.body, (errors) => {
throw new Error(`Get wallet state failed: ${errors}`);
});
}
/**
* Initialize the remote signer LND wallet with the given data.
*/
async initWallet(data) {
const res = await (0, retryPromise_1.retryPromise)(() => superagent
.post(`${this.url}/v1/initwallet`)
.agent(this.httpsAgent)
.type('json')
.send({ ...data, stateless_init: true }), (err, tryCount) => {
console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);
});
if (res.status !== 200) {
throw new Error(`Failed to initialize wallet with status: ${res.status}`);
}
return (0, sdk_core_1.decodeOrElse)(codecs_1.InitWalletResponse.name, codecs_1.InitWalletResponse, res.body, (_) => {
throw new Error(`Init wallet failed.`);
});
}
/**
* Bake a macaroon with the given permissions from remote signer LND.
*/
async bakeMacaroon(data, header) {
const res = await (0, retryPromise_1.retryPromise)(() => superagent
.post(`${this.url}/v1/macaroon`)
.agent(this.httpsAgent)
.set('Grpc-Metadata-macaroon', header.adminMacaroonHex)
.type('json')
.send(data), (err, tryCount) => {
console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);
});
if (res.status !== 200) {
throw new Error(`Failed to bake macaroon with status: ${res.text}`);
}
return (0, sdk_core_1.decodeOrElse)(codecs_1.BakeMacaroonResponse.name, codecs_1.BakeMacaroonResponse, res.body, (errors) => {
throw new Error(`Bake macaroon failed: ${errors}`);
});
}
/**
* Unlock the wallet with the given wallet password.
*/
async unlockWallet(data) {
const res = await (0, retryPromise_1.retryPromise)(() => superagent
.post(`${this.url}/v1/unlockwallet`)
.agent(this.httpsAgent)
.type('json')
.send({ ...data, stateless_init: true }), (err, tryCount) => {
console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);
});
if (res.status !== 200) {
throw new Error(`Failed to unlock wallet: ${res.text}`);
}
}
}
exports.LndSignerClient = LndSignerClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lndSignerClient.js","sourceRoot":"","sources":["../../src/lightning/lndSignerClient.ts"],"names":[],"mappings":"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","sourcesContent":["import * as https from 'https';\nimport * as superagent from 'superagent';\nimport { decodeOrElse } from '@bitgo/sdk-core';\nimport { retryPromise } from '../retryPromise';\nimport { BakeMacaroonResponse, GetWalletStateResponse, InitWalletResponse, LightningSignerConfig } from './codecs';\nimport { getLightningSignerConfig } from './lightningUtils';\n\n/**\n * Client for interacting with the LND signer.\n */\nexport class LndSignerClient {\n  public readonly url: string;\n  public readonly httpsAgent: https.Agent;\n\n  private constructor(config: LightningSignerConfig) {\n    this.url = config.url;\n    this.httpsAgent = new https.Agent({\n      ca: Buffer.from(config.tlsCert, 'base64').toString('utf-8'),\n    });\n  }\n\n  /**\n   * Create a new LndSignerClient.\n   */\n  public static async create(\n    walletId: string,\n    config: { lightningSignerFileSystemPath?: string }\n  ): Promise<LndSignerClient> {\n    const lightningSignerConfig = await getLightningSignerConfig(walletId, config);\n    return new LndSignerClient(lightningSignerConfig);\n  }\n\n  /**\n   * Get the current state of the wallet from remote signer LND.\n   */\n  async getWalletState(): Promise<GetWalletStateResponse> {\n    const res = await retryPromise(\n      () => superagent.get(`${this.url}/v1/state`).agent(this.httpsAgent).send(),\n      (err, tryCount) => {\n        console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);\n      }\n    );\n\n    if (res.status !== 200) {\n      throw new Error(`Failed to get wallet state with status: ${res.text}`);\n    }\n\n    return decodeOrElse(GetWalletStateResponse.name, GetWalletStateResponse, res.body, (errors) => {\n      throw new Error(`Get wallet state failed: ${errors}`);\n    });\n  }\n\n  /**\n   * Initialize the remote signer LND wallet with the given data.\n   */\n  async initWallet(data: {\n    wallet_password: string;\n    extended_master_key: string;\n    macaroon_root_key: string;\n  }): Promise<InitWalletResponse> {\n    const res = await retryPromise(\n      () =>\n        superagent\n          .post(`${this.url}/v1/initwallet`)\n          .agent(this.httpsAgent)\n          .type('json')\n          .send({ ...data, stateless_init: true }),\n      (err, tryCount) => {\n        console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);\n      }\n    );\n\n    if (res.status !== 200) {\n      throw new Error(`Failed to initialize wallet with status: ${res.status}`);\n    }\n\n    return decodeOrElse(InitWalletResponse.name, InitWalletResponse, res.body, (_) => {\n      throw new Error(`Init wallet failed.`);\n    });\n  }\n\n  /**\n   * Bake a macaroon with the given permissions from remote signer LND.\n   */\n  async bakeMacaroon(\n    data: {\n      permissions: {\n        entity: string;\n        action: string;\n      }[];\n    },\n    header: { adminMacaroonHex: string }\n  ): Promise<BakeMacaroonResponse> {\n    const res = await retryPromise(\n      () =>\n        superagent\n          .post(`${this.url}/v1/macaroon`)\n          .agent(this.httpsAgent)\n          .set('Grpc-Metadata-macaroon', header.adminMacaroonHex)\n          .type('json')\n          .send(data),\n      (err, tryCount) => {\n        console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);\n      }\n    );\n\n    if (res.status !== 200) {\n      throw new Error(`Failed to bake macaroon with status: ${res.text}`);\n    }\n\n    return decodeOrElse(BakeMacaroonResponse.name, BakeMacaroonResponse, res.body, (errors) => {\n      throw new Error(`Bake macaroon failed: ${errors}`);\n    });\n  }\n\n  /**\n   * Unlock the wallet with the given wallet password.\n   */\n  async unlockWallet(data: { wallet_password: string }): Promise<void> {\n    const res = await retryPromise(\n      () =>\n        superagent\n          .post(`${this.url}/v1/unlockwallet`)\n          .agent(this.httpsAgent)\n          .type('json')\n          .send({ ...data, stateless_init: true }),\n      (err, tryCount) => {\n        console.log(`failed to connect to lightning signer (attempt ${tryCount}, error: ${err.message})`);\n      }\n    );\n\n    if (res.status !== 200) {\n      throw new Error(`Failed to unlock wallet: ${res.text}`);\n    }\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!