|
|
|
import bitcore from 'bitcore-lib'
|
|
|
|
import find from 'lodash/find'
|
|
|
|
import { listPeers, connectPeer } from './peersController'
|
|
|
|
import pushopenchannel from '../push/openchannel'
|
|
|
|
import pushclosechannel from '../push/closechannel'
|
|
|
|
|
|
|
|
const BufferUtil = bitcore.util.buffer
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to open a singly funded channel specified in the request to a remote peer.
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @param {[type]} event [description]
|
|
|
|
* @param {[type]} payload [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function connectAndOpen(lnd, meta, event, payload) {
|
|
|
|
console.log('payload: ', payload)
|
|
|
|
|
|
|
|
const { pubkey, host, localamt } = payload
|
|
|
|
const channelPayload = {
|
|
|
|
node_pubkey: BufferUtil.hexToBuffer(pubkey),
|
|
|
|
local_funding_amount: Number(localamt)
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
listPeers(lnd, meta)
|
|
|
|
.then(({ peers }) => {
|
|
|
|
console.log('peers: ', peers)
|
|
|
|
|
|
|
|
const peer = find(peers, { pub_key: pubkey })
|
|
|
|
|
|
|
|
if (peer) {
|
|
|
|
console.log('already have the peer. can open the channel now')
|
|
|
|
const call = lnd.openChannel(channelPayload, meta)
|
|
|
|
|
|
|
|
call.on('data', data => event.sender.send('pushchannelupdated', { pubkey, data }))
|
|
|
|
call.on('error', error => event.sender.send('pushchannelerror', { pubkey, error: error.toString() }))
|
|
|
|
} else {
|
|
|
|
console.log('connect to the peer first')
|
|
|
|
connectPeer(lnd, meta, { pubkey, host })
|
|
|
|
.then((data) => {
|
|
|
|
console.log('connectPeer data: ', data)
|
|
|
|
|
|
|
|
const call = lnd.openChannel(channelPayload, meta)
|
|
|
|
|
|
|
|
call.on('data', data => event.sender.send('pushchannelupdated', { pubkey, data }))
|
|
|
|
call.on('error', error => event.sender.send('pushchannelerror', { pubkey, error: error.toString() }))
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
console.log('connect peer err: ', err)
|
|
|
|
event.sender.send('pushchannelerror', { pubkey, error: err.toString() })
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(err => {
|
|
|
|
console.log('list peer err: ', err)
|
|
|
|
event.sender.send('pushchannelerror', { pubkey, error: err.toString() })
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to open a singly funded channel specified in the request to a remote peer.
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @param {[type]} event [description]
|
|
|
|
* @param {[type]} payload [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function openChannel(lnd, meta, event, payload) {
|
|
|
|
console.log('opening the channel')
|
|
|
|
const { pubkey, localamt, pushamt } = payload
|
|
|
|
const res = {
|
|
|
|
node_pubkey: BufferUtil.hexToBuffer(pubkey),
|
|
|
|
local_funding_amount: Number(localamt),
|
|
|
|
push_sat: Number(pushamt)
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) =>
|
|
|
|
pushopenchannel(lnd, meta, event, res)
|
|
|
|
.then(data => resolve(data))
|
|
|
|
.catch(error => reject(error))
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the total funds available across all open channels in satoshis
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function channelBalance(lnd, meta) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
lnd.channelBalance({}, meta, (err, data) => {
|
|
|
|
if (err) { reject(err) }
|
|
|
|
|
|
|
|
resolve(data)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a description of all the open channels that this node is a participant in
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function listChannels(lnd, meta) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
lnd.listChannels({}, meta, (err, data) => {
|
|
|
|
if (err) { reject(err) }
|
|
|
|
|
|
|
|
resolve(data)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to close an active channel identified by its channel outpoint (ChannelPoint)
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @param {[type]} event [description]
|
|
|
|
* @param {[type]} payload [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function closeChannel(lnd, meta, event, payload) {
|
|
|
|
const tx = payload.channel_point.funding_txid.match(/.{2}/g).reverse().join('')
|
|
|
|
const res = {
|
|
|
|
channel_point: {
|
|
|
|
funding_txid: BufferUtil.hexToBuffer(tx),
|
|
|
|
output_index: Number(payload.channel_point.output_index)
|
|
|
|
},
|
|
|
|
force: true
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) =>
|
|
|
|
pushclosechannel(lnd, meta, event, res)
|
|
|
|
.then(data => resolve(data))
|
|
|
|
.catch(error => reject(error))
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of all the channels that are currently considered “pending"
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function pendingChannels(lnd, meta) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
lnd.pendingChannels({}, meta, (err, data) => {
|
|
|
|
if (err) { reject(err) }
|
|
|
|
|
|
|
|
resolve(data)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the latest authenticated network announcement for the given channel
|
|
|
|
* @param {[type]} lnd [description]
|
|
|
|
* @param {[type]} channelId [description]
|
|
|
|
* @return {[type]} [description]
|
|
|
|
*/
|
|
|
|
export function getChanInfo(lnd, meta, { chanId }) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
lnd.getChanInfo({ chan_id: chanId }, meta, (err, data) => {
|
|
|
|
if (err) { reject(err) }
|
|
|
|
|
|
|
|
resolve(data)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|