htlcswitch: update commit tx per downstream msg type
Unroll common code to allow splitting in separate handlers per message type.
This commit is contained in:
parent
b559811bf5
commit
55930df70d
@ -1261,7 +1261,6 @@ func (l *channelLink) randomFeeUpdateTimeout() time.Duration {
|
|||||||
//
|
//
|
||||||
// TODO(roasbeef): add sync ntfn to ensure switch always has consistent view?
|
// TODO(roasbeef): add sync ntfn to ensure switch always has consistent view?
|
||||||
func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
||||||
var isSettle bool
|
|
||||||
switch htlc := pkt.htlc.(type) {
|
switch htlc := pkt.htlc.(type) {
|
||||||
case *lnwire.UpdateAddHTLC:
|
case *lnwire.UpdateAddHTLC:
|
||||||
// If hodl.AddOutgoing mode is active, we exit early to simulate
|
// If hodl.AddOutgoing mode is active, we exit early to simulate
|
||||||
@ -1328,6 +1327,8 @@ func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
|||||||
getEventType(pkt),
|
getEventType(pkt),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
l.tryBatchUpdateCommitTx()
|
||||||
|
|
||||||
case *lnwire.UpdateFulfillHTLC:
|
case *lnwire.UpdateFulfillHTLC:
|
||||||
// If hodl.SettleOutgoing mode is active, we exit early to
|
// If hodl.SettleOutgoing mode is active, we exit early to
|
||||||
// simulate arbitrary delays between the switch adding the
|
// simulate arbitrary delays between the switch adding the
|
||||||
@ -1384,7 +1385,6 @@ func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
|||||||
// Then we send the HTLC settle message to the connected peer
|
// Then we send the HTLC settle message to the connected peer
|
||||||
// so we can continue the propagation of the settle message.
|
// so we can continue the propagation of the settle message.
|
||||||
l.cfg.Peer.SendMessage(false, htlc)
|
l.cfg.Peer.SendMessage(false, htlc)
|
||||||
isSettle = true
|
|
||||||
|
|
||||||
// Send a settle event notification to htlcNotifier.
|
// Send a settle event notification to htlcNotifier.
|
||||||
l.cfg.HtlcNotifier.NotifySettleEvent(
|
l.cfg.HtlcNotifier.NotifySettleEvent(
|
||||||
@ -1392,6 +1392,9 @@ func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
|||||||
getEventType(pkt),
|
getEventType(pkt),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Immediately update the commitment tx to minimize latency.
|
||||||
|
l.updateCommitTxOrFail()
|
||||||
|
|
||||||
case *lnwire.UpdateFailHTLC:
|
case *lnwire.UpdateFailHTLC:
|
||||||
// If hodl.FailOutgoing mode is active, we exit early to
|
// If hodl.FailOutgoing mode is active, we exit early to
|
||||||
// simulate arbitrary delays between the switch adding a FAIL to
|
// simulate arbitrary delays between the switch adding a FAIL to
|
||||||
@ -1448,7 +1451,6 @@ func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
|||||||
// We send the HTLC message to the peer which initially created
|
// We send the HTLC message to the peer which initially created
|
||||||
// the HTLC.
|
// the HTLC.
|
||||||
l.cfg.Peer.SendMessage(false, htlc)
|
l.cfg.Peer.SendMessage(false, htlc)
|
||||||
isSettle = true
|
|
||||||
|
|
||||||
// If the packet does not have a link failure set, it failed
|
// If the packet does not have a link failure set, it failed
|
||||||
// further down the route so we notify a forwarding failure.
|
// further down the route so we notify a forwarding failure.
|
||||||
@ -1467,17 +1469,20 @@ func (l *channelLink) handleDownstreamPkt(pkt *htlcPacket) {
|
|||||||
newHtlcKey(pkt), getEventType(pkt),
|
newHtlcKey(pkt), getEventType(pkt),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Immediately update the commitment tx to minimize latency.
|
||||||
|
l.updateCommitTxOrFail()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If this newly added update exceeds the min batch size for adds, or
|
// tryBatchUpdateCommitTx updates the commitment transaction if the batch is
|
||||||
// this is a settle request, then initiate an update.
|
// full.
|
||||||
if l.channel.PendingLocalUpdateCount() >= uint64(l.cfg.BatchSize) ||
|
func (l *channelLink) tryBatchUpdateCommitTx() {
|
||||||
isSettle {
|
if l.channel.PendingLocalUpdateCount() < uint64(l.cfg.BatchSize) {
|
||||||
|
|
||||||
if !l.updateCommitTxOrFail() {
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
l.updateCommitTxOrFail()
|
||||||
}
|
}
|
||||||
|
|
||||||
// cleanupSpuriousResponse attempts to ack any AddRef or SettleFailRef
|
// cleanupSpuriousResponse attempts to ack any AddRef or SettleFailRef
|
||||||
|
Loading…
Reference in New Issue
Block a user