routing: fix path finding, bug use the proper policy during path finding
This commit fixes an lingering bug within the path finding logic of the router. Previously we used the edge policy directly attached to the outgoing channel of the node we were traversing to calculate the fees and time lock information. This is incorrect, as we instead should be using the policy of the *connecting* node as we’ll need to pay for transit as they dictate. To remedy this, we now grab the incoming+outgoing edges and use those accordingly when building the initial path.
This commit is contained in:
parent
6467fdd829
commit
5301da790c
@ -394,9 +394,11 @@ func findPath(graph *channeldb.ChannelGraph, sourceNode *channeldb.LightningNode
|
|||||||
pivot := newVertex(bestNode.PubKey)
|
pivot := newVertex(bestNode.PubKey)
|
||||||
err := bestNode.ForEachChannel(nil, func(tx *bolt.Tx,
|
err := bestNode.ForEachChannel(nil, func(tx *bolt.Tx,
|
||||||
edgeInfo *channeldb.ChannelEdgeInfo,
|
edgeInfo *channeldb.ChannelEdgeInfo,
|
||||||
edge *channeldb.ChannelEdgePolicy) error {
|
outEdge, inEdge *channeldb.ChannelEdgePolicy) error {
|
||||||
|
|
||||||
v := newVertex(edge.Node.PubKey)
|
v := newVertex(outEdge.Node.PubKey)
|
||||||
|
|
||||||
|
// TODO(roasbeef): skip if disabled
|
||||||
|
|
||||||
// If this vertex or edge has been black listed, then
|
// If this vertex or edge has been black listed, then
|
||||||
// we'll skip exploring this edge during this
|
// we'll skip exploring this edge during this
|
||||||
@ -404,14 +406,14 @@ func findPath(graph *channeldb.ChannelGraph, sourceNode *channeldb.LightningNode
|
|||||||
if _, ok := ignoredNodes[v]; ok {
|
if _, ok := ignoredNodes[v]; ok {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if _, ok := ignoredEdges[edge.ChannelID]; ok {
|
if _, ok := ignoredEdges[outEdge.ChannelID]; ok {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compute the tentative distance to this new
|
// Compute the tentative distance to this new
|
||||||
// channel/edge which is the distance to our current
|
// channel/edge which is the distance to our current
|
||||||
// pivot node plus the weight of this edge.
|
// pivot node plus the weight of this edge.
|
||||||
tempDist := distance[pivot].dist + edgeWeight(edge)
|
tempDist := distance[pivot].dist + edgeWeight(inEdge)
|
||||||
|
|
||||||
// If this new tentative distance is better than the
|
// If this new tentative distance is better than the
|
||||||
// current best known distance to this node, then we
|
// current best known distance to this node, then we
|
||||||
@ -427,16 +429,28 @@ func findPath(graph *channeldb.ChannelGraph, sourceNode *channeldb.LightningNode
|
|||||||
|
|
||||||
distance[v] = nodeWithDist{
|
distance[v] = nodeWithDist{
|
||||||
dist: tempDist,
|
dist: tempDist,
|
||||||
node: edge.Node,
|
node: outEdge.Node,
|
||||||
}
|
}
|
||||||
prev[v] = edgeWithPrev{
|
prev[v] = edgeWithPrev{
|
||||||
|
// We'll use the *incoming* edge here
|
||||||
|
// as we need to use the routing policy
|
||||||
|
// specified by the node this channel
|
||||||
|
// connects to.
|
||||||
edge: &ChannelHop{
|
edge: &ChannelHop{
|
||||||
ChannelEdgePolicy: edge,
|
ChannelEdgePolicy: inEdge,
|
||||||
Capacity: edgeInfo.Capacity,
|
Capacity: edgeInfo.Capacity,
|
||||||
},
|
},
|
||||||
prevNode: bestNode.PubKey,
|
prevNode: bestNode.PubKey,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// In order for the path unwinding to work
|
||||||
|
// properly, we'll ensure that this edge
|
||||||
|
// properly points to the outgoing node.
|
||||||
|
//
|
||||||
|
// TODO(roasbeef): revisit, possibly switch db
|
||||||
|
// format?
|
||||||
|
prev[v].edge.Node = outEdge.Node
|
||||||
|
|
||||||
// Add this new node to our heap as we'd like
|
// Add this new node to our heap as we'd like
|
||||||
// to further explore down this edge.
|
// to further explore down this edge.
|
||||||
heap.Push(&nodeHeap, distance[v])
|
heap.Push(&nodeHeap, distance[v])
|
||||||
|
Loading…
Reference in New Issue
Block a user