routing: fall back to edge MaxHTLC within findPath instead of Capacity
In this commit, we make our findPath function use an edge's MaxHTLC as its available bandwidth instead of its Capacity. We do this as it's possible for the capacity of an edge to not exist when operating as a light client. For channels that do not support the MaxHTLC optional field, we'll fall back to using the edge's Capacity.
This commit is contained in:
parent
0b0a9f4172
commit
998680ad59
@ -693,12 +693,17 @@ func findPath(g *graphParams, r *RestrictParams, source, target Vertex,
|
|||||||
edgeBandwidth, ok := g.bandwidthHints[edgeInfo.ChannelID]
|
edgeBandwidth, ok := g.bandwidthHints[edgeInfo.ChannelID]
|
||||||
if !ok {
|
if !ok {
|
||||||
// If we don't have a hint for this edge, then
|
// If we don't have a hint for this edge, then
|
||||||
// we'll just use the known Capacity as the
|
// we'll just use the known Capacity/MaxHTLC as
|
||||||
// available bandwidth.
|
// the available bandwidth. It's possible for
|
||||||
|
// the capacity to be unknown when operating
|
||||||
|
// under a light client.
|
||||||
|
edgeBandwidth = inEdge.MaxHTLC
|
||||||
|
if edgeBandwidth == 0 {
|
||||||
edgeBandwidth = lnwire.NewMSatFromSatoshis(
|
edgeBandwidth = lnwire.NewMSatFromSatoshis(
|
||||||
edgeInfo.Capacity,
|
edgeInfo.Capacity,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Before we can process the edge, we'll need to fetch
|
// Before we can process the edge, we'll need to fetch
|
||||||
// the node on the _other_ end of this channel as we
|
// the node on the _other_ end of this channel as we
|
||||||
|
Loading…
Reference in New Issue
Block a user