htlcswitch/link: only resovle+gc fwdpkgs for live channels
This commit is contained in:
parent
e5a61183b5
commit
211a0299e9
@ -847,7 +847,11 @@ func (l *channelLink) htlcManager() {
|
||||
|
||||
// After cleaning up any memory pertaining to incoming packets, we now
|
||||
// replay our forwarding packages to handle any htlcs that can be
|
||||
// processed locally, or need to be forwarded out to the switch.
|
||||
// processed locally, or need to be forwarded out to the switch. We will
|
||||
// only attempt to resolve packages if our short chan id indicates that
|
||||
// the channel is not pending, otherwise we should have no htlcs to
|
||||
// reforward.
|
||||
if l.ShortChanID() != sourceHop {
|
||||
if err := l.resolveFwdPkgs(); err != nil {
|
||||
l.fail(LinkFailureError{code: ErrInternalError},
|
||||
"unable to resolve fwd pkgs: %v", err)
|
||||
@ -859,6 +863,7 @@ func (l *channelLink) htlcManager() {
|
||||
// completed forwarding packages.
|
||||
l.wg.Add(1)
|
||||
go l.fwdPkgGarbager()
|
||||
}
|
||||
|
||||
out:
|
||||
for {
|
||||
@ -1670,6 +1675,11 @@ func (l *channelLink) UpdateShortChanID() (lnwire.ShortChannelID, error) {
|
||||
}
|
||||
}()
|
||||
|
||||
// Now that the short channel ID has been properly updated, we can begin
|
||||
// garbage collecting any forwarding packages we create.
|
||||
l.wg.Add(1)
|
||||
go l.fwdPkgGarbager()
|
||||
|
||||
return sid, nil
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user