autopilot: use subtractFees when funding channel

To make the autopilot able to account for fees, we let it use the
subtractFees option when opening channels.

This makes sure that each channel we attempt to open will eat at most
Amt out of our budget. Previously fees would eat into our funds in
addition, causing us to deplete our funds more than expected on each
channel opening.
This commit is contained in:
Johan T. Halseth 2019-07-11 13:14:38 +02:00
parent 0405703019
commit bf7f392c11
No known key found for this signature in database
GPG Key ID: 15BAADA29DA20D26
3 changed files with 7 additions and 4 deletions

@ -584,6 +584,7 @@ func (a *Agent) openChans(availableFunds btcutil.Amount, numChans uint32,
// Use the heuristic to calculate a score for each node in the // Use the heuristic to calculate a score for each node in the
// graph. // graph.
log.Debugf("Scoring %d nodes for chan_size=%v", len(nodes), chanSize)
scores, err := a.cfg.Heuristic.NodeScores( scores, err := a.cfg.Heuristic.NodeScores(
a.cfg.Graph, totalChans, chanSize, nodes, a.cfg.Graph, totalChans, chanSize, nodes,
) )

@ -188,10 +188,11 @@ func init() {
// open a channel within the graph to a target peer, close targeted channels, // open a channel within the graph to a target peer, close targeted channels,
// or add/remove funds from existing channels via a splice in/out mechanisms. // or add/remove funds from existing channels via a splice in/out mechanisms.
type ChannelController interface { type ChannelController interface {
// OpenChannel opens a channel to a target peer, with a capacity of the // OpenChannel opens a channel to a target peer, using at most amt
// specified amount. This function should un-block immediately after // funds. This means that the resulting channel capacity might be
// the funding transaction that marks the channel open has been // slightly less to account for fees. This function should un-block
// broadcast. // immediately after the funding transaction that marks the channel
// open has been broadcast.
OpenChannel(target *btcec.PublicKey, amt btcutil.Amount) error OpenChannel(target *btcec.PublicKey, amt btcutil.Amount) error
// CloseChannel attempts to close out the target channel. // CloseChannel attempts to close out the target channel.

@ -100,6 +100,7 @@ func (c *chanController) OpenChannel(target *btcec.PublicKey,
req := &openChanReq{ req := &openChanReq{
targetPubkey: target, targetPubkey: target,
chainHash: *activeNetParams.GenesisHash, chainHash: *activeNetParams.GenesisHash,
subtractFees: true,
localFundingAmt: amt, localFundingAmt: amt,
pushAmt: 0, pushAmt: 0,
minHtlc: minHtlc, minHtlc: minHtlc,