@ -11,6 +11,7 @@ import { mainLog } from '../utils/log'
import subscribeToTransactions from './subscribe/transactions'
import subscribeToTransactions from './subscribe/transactions'
import subscribeToInvoices from './subscribe/invoices'
import subscribeToInvoices from './subscribe/invoices'
import subscribeToChannelGraph from './subscribe/channelgraph'
import subscribeToChannelGraph from './subscribe/channelgraph'
import { getInfo } from './methods/networkController'
// Type definition for subscriptions property.
// Type definition for subscriptions property.
type LightningSubscriptionsType = {
type LightningSubscriptionsType = {
@ -65,43 +66,48 @@ class Lightning {
const { rpcProtoPath , host , cert , macaroon } = this . lndConfig
const { rpcProtoPath , host , cert , macaroon } = this . lndConfig
// Verify that the host is valid before creating a gRPC client that is connected to it.
// Verify that the host is valid before creating a gRPC client that is connected to it.
return await validateHost ( host ) . then ( async ( ) => {
return validateHost ( host )
// Load the gRPC proto file.
. then ( async ( ) => {
// The following options object closely approximates the existing behavior of grpc.load.
// Load the gRPC proto file.
// See https://github.com/grpc/grpc-node/blob/master/packages/grpc-protobufjs/README.md
// The following options object closely approximates the existing behavior of grpc.load.
const options = {
// See https://github.com/grpc/grpc-node/blob/master/packages/grpc-protobufjs/README.md
keepCase : true ,
const options = {
longs : Number ,
keepCase : true ,
enums : String ,
longs : Number ,
defaults : true ,
enums : String ,
oneofs : true
defaults : true ,
}
oneofs : true
const packageDefinition = loadSync ( rpcProtoPath , options )
}
const packageDefinition = loadSync ( rpcProtoPath , options )
// Load gRPC package definition as a gRPC object hierarchy.
const rpc = grpc . loadPackageDefinition ( packageDefinition )
// Load gRPC package definition as a gRPC object hierarchy.
const rpc = grpc . loadPackageDefinition ( packageDefinition )
// Create ssl and macaroon credentials to use with the gRPC client.
const [ sslCreds , macaroonCreds ] = await Promise . all ( [
// Create ssl and macaroon credentials to use with the gRPC client.
createSslCreds ( cert ) ,
const [ sslCreds , macaroonCreds ] = await Promise . all ( [
createMacaroonCreds ( macaroon )
createSslCreds ( cert ) ,
] )
createMacaroonCreds ( macaroon )
const credentials = grpc . credentials . combineChannelCredentials ( sslCreds , macaroonCreds )
] )
const credentials = grpc . credentials . combineChannelCredentials ( sslCreds , macaroonCreds )
// Create a new gRPC client instance.
this . service = new rpc . lnrpc . Lightning ( host , credentials )
// Create a new gRPC client instance.
this . service = new rpc . lnrpc . Lightning ( host , credentials )
// Wait for the gRPC connection to be established.
return new Promise ( ( resolve , reject ) => {
// Wait for the gRPC connection to be established.
this . service . waitForReady ( getDeadline ( 2 ) , err => {
return new Promise ( ( resolve , reject ) => {
if ( err ) {
this . service . waitForReady ( getDeadline ( 5 ) , err => {
this . service . close ( )
if ( err ) {
return reject ( err )
return reject ( err )
}
}
return resolve ( )
return resolve ( )
} )
} )
} )
} )
} )
} )
. then ( ( ) => getInfo ( this . service ) )
. catch ( err => {
this . service . close ( )
throw err
} )
}
}
/ * *
/ * *