routing/pathfind: consolidate final vs non-final hop processing
This commit is contained in:
parent
495ae8ca42
commit
b97adf79a4
@ -141,18 +141,34 @@ func newRoute(sourceVertex route.Vertex,
|
|||||||
// payload for the hop this edge is leading to.
|
// payload for the hop this edge is leading to.
|
||||||
edge := pathEdges[i]
|
edge := pathEdges[i]
|
||||||
|
|
||||||
// If this is the last hop, then the hop payload will contain
|
// We'll calculate the amounts, timelocks, and fees for each hop
|
||||||
// the exact amount. In BOLT #4: Onion Routing
|
// in the route. The base case is the final hop which includes
|
||||||
// Protocol / "Payload for the Last Node", this is detailed.
|
// their amount and timelocks. These values will accumulate
|
||||||
amtToForward := finalHop.amt
|
// contributions from the preceding hops back to the sender as
|
||||||
|
// we compute the route in reverse.
|
||||||
|
var (
|
||||||
|
amtToForward lnwire.MilliSatoshi
|
||||||
|
fee lnwire.MilliSatoshi
|
||||||
|
outgoingTimeLock uint32
|
||||||
|
)
|
||||||
|
if i == len(pathEdges)-1 {
|
||||||
|
// If this is the last hop, then the hop payload will
|
||||||
|
// contain the exact amount. In BOLT #4: Onion Routing
|
||||||
|
// Protocol / "Payload for the Last Node", this is
|
||||||
|
// detailed.
|
||||||
|
amtToForward = finalHop.amt
|
||||||
|
|
||||||
// Fee is not part of the hop payload, but only used for
|
// Fee is not part of the hop payload, but only used for
|
||||||
// reporting through RPC. Set to zero for the final hop.
|
// reporting through RPC. Set to zero for the final hop.
|
||||||
fee := lnwire.MilliSatoshi(0)
|
fee = lnwire.MilliSatoshi(0)
|
||||||
|
|
||||||
// If the current hop isn't the last hop, then add enough funds
|
// As this is the last hop, we'll use the specified
|
||||||
// to pay for transit over the next link.
|
// final CLTV delta value instead of the value from the
|
||||||
if i != len(pathEdges)-1 {
|
// last link in the route.
|
||||||
|
totalTimeLock += uint32(finalHop.cltvDelta)
|
||||||
|
|
||||||
|
outgoingTimeLock = currentHeight + uint32(finalHop.cltvDelta)
|
||||||
|
} else {
|
||||||
// The amount that the current hop needs to forward is
|
// The amount that the current hop needs to forward is
|
||||||
// equal to the incoming amount of the next hop.
|
// equal to the incoming amount of the next hop.
|
||||||
amtToForward = nextIncomingAmount
|
amtToForward = nextIncomingAmount
|
||||||
@ -163,20 +179,7 @@ func newRoute(sourceVertex route.Vertex,
|
|||||||
// is stored as part of the incoming channel of
|
// is stored as part of the incoming channel of
|
||||||
// the next hop.
|
// the next hop.
|
||||||
fee = pathEdges[i+1].ComputeFee(amtToForward)
|
fee = pathEdges[i+1].ComputeFee(amtToForward)
|
||||||
}
|
|
||||||
|
|
||||||
// If this is the last hop, then for verification purposes, the
|
|
||||||
// value of the outgoing time-lock should be _exactly_ the
|
|
||||||
// absolute time out they'd expect in the HTLC.
|
|
||||||
var outgoingTimeLock uint32
|
|
||||||
if i == len(pathEdges)-1 {
|
|
||||||
// As this is the last hop, we'll use the specified
|
|
||||||
// final CLTV delta value instead of the value from the
|
|
||||||
// last link in the route.
|
|
||||||
totalTimeLock += uint32(finalHop.cltvDelta)
|
|
||||||
|
|
||||||
outgoingTimeLock = currentHeight + uint32(finalHop.cltvDelta)
|
|
||||||
} else {
|
|
||||||
// Next, increment the total timelock of the entire
|
// Next, increment the total timelock of the entire
|
||||||
// route such that each hops time lock increases as we
|
// route such that each hops time lock increases as we
|
||||||
// walk backwards in the route, using the delta of the
|
// walk backwards in the route, using the delta of the
|
||||||
|
Loading…
Reference in New Issue
Block a user