lnwallet: add new restoreHtlc method to the updateLog
This commit adds a new method to the updateLog which will be used when restoring the state of a channel from disk after a restart. This new method will add an entry to the updateLog without incrementing either of the counters as the HTLC already comes pre populated with its historical index.
This commit is contained in:
parent
51618f2ae3
commit
4b71e87b77
@ -661,9 +661,9 @@ func newCommitmentChain(initialHeight uint64) *commitmentChain {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// addCommitment extends the commitment chain by a single commitment. This
|
// addCommitment extends the commitment chain by a single commitment. This
|
||||||
// added commitment represents a state update propsed by either party. Once the
|
// added commitment represents a state update proposed by either party. Once
|
||||||
// commitment prior to this commitment is revoked, the commitment becomes the
|
// the commitment prior to this commitment is revoked, the commitment becomes
|
||||||
// new defacto state within the channel.
|
// the new defacto state within the channel.
|
||||||
func (s *commitmentChain) addCommitment(c *commitment) {
|
func (s *commitmentChain) addCommitment(c *commitment) {
|
||||||
s.commitments.PushBack(c)
|
s.commitments.PushBack(c)
|
||||||
}
|
}
|
||||||
@ -697,8 +697,6 @@ func (s *commitmentChain) hasUnackedCommitment() bool {
|
|||||||
// changes are stored before they're committed to the chain. Once an entry has
|
// changes are stored before they're committed to the chain. Once an entry has
|
||||||
// been committed in both the local and remote commitment chain, then it can be
|
// been committed in both the local and remote commitment chain, then it can be
|
||||||
// removed from this log.
|
// removed from this log.
|
||||||
|
|
||||||
// TODO(roasbeef): update with offer vs update distinction
|
|
||||||
//
|
//
|
||||||
// TODO(roasbeef): create lightning package, move commitment and update to
|
// TODO(roasbeef): create lightning package, move commitment and update to
|
||||||
// package?
|
// package?
|
||||||
@ -730,20 +728,33 @@ type updateLog struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// newUpdateLog creates a new updateLog instance.
|
// newUpdateLog creates a new updateLog instance.
|
||||||
func newUpdateLog(logIndex, ackedIndex uint64) *updateLog {
|
func newUpdateLog(logIndex, htlcCounter uint64) *updateLog {
|
||||||
return &updateLog{
|
return &updateLog{
|
||||||
List: list.New(),
|
List: list.New(),
|
||||||
updateIndex: make(map[uint64]*list.Element),
|
updateIndex: make(map[uint64]*list.Element),
|
||||||
htlcIndex: make(map[uint64]*list.Element),
|
htlcIndex: make(map[uint64]*list.Element),
|
||||||
logIndex: logIndex,
|
logIndex: logIndex,
|
||||||
ackedIndex: ackedIndex,
|
htlcCounter: htlcCounter,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// restoreHtlc will "restore" a prior HTLC to the updateLog. We say restore as
|
||||||
|
// this method is intended to be used when re-covering a prior commitment
|
||||||
|
// state. This function differs from appendHtlc in that it won't increment
|
||||||
|
// either of log's counters. If the HTLC is already present, then it is
|
||||||
|
// ignored.
|
||||||
|
func (u *updateLog) restoreHtlc(pd *PaymentDescriptor) {
|
||||||
|
if _, ok := u.htlcIndex[pd.HtlcIndex]; ok {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
u.htlcIndex[pd.HtlcIndex] = u.PushBack(pd)
|
||||||
|
}
|
||||||
|
|
||||||
// appendUpdate appends a new update to the tip of the updateLog. The entry is
|
// appendUpdate appends a new update to the tip of the updateLog. The entry is
|
||||||
// also added to index accordingly.
|
// also added to index accordingly.
|
||||||
func (u *updateLog) appendUpdate(pd *PaymentDescriptor) {
|
func (u *updateLog) appendUpdate(pd *PaymentDescriptor) {
|
||||||
u.updateIndex[pd.Index] = u.PushBack(pd)
|
u.updateIndex[u.logIndex] = u.PushBack(pd)
|
||||||
u.logIndex++
|
u.logIndex++
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -793,9 +804,9 @@ func compactLogs(ourLog, theirLog *updateLog,
|
|||||||
compactLog := func(logA, logB *updateLog) {
|
compactLog := func(logA, logB *updateLog) {
|
||||||
var nextA *list.Element
|
var nextA *list.Element
|
||||||
for e := logA.Front(); e != nil; e = nextA {
|
for e := logA.Front(); e != nil; e = nextA {
|
||||||
// Assign next iteration element at top of loop because we may
|
// Assign next iteration element at top of loop because
|
||||||
// remove the current element from the list, which can change the
|
// we may remove the current element from the list,
|
||||||
// iterated sequence.
|
// which can change the iterated sequence.
|
||||||
nextA = e.Next()
|
nextA = e.Next()
|
||||||
|
|
||||||
htlc := e.Value.(*PaymentDescriptor)
|
htlc := e.Value.(*PaymentDescriptor)
|
||||||
@ -825,7 +836,6 @@ func compactLogs(ourLog, theirLog *updateLog,
|
|||||||
}
|
}
|
||||||
|
|
||||||
compactLog(ourLog, theirLog)
|
compactLog(ourLog, theirLog)
|
||||||
|
|
||||||
compactLog(theirLog, ourLog)
|
compactLog(theirLog, ourLog)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user