channeldb/channel: adds RefreshShortChanID

This commit is contained in:
Conner Fromknecht 2018-05-01 16:28:12 -07:00
parent 355355b81e
commit 7ad56943c7
No known key found for this signature in database
GPG Key ID: 39DE78FBE6ACB0EF
2 changed files with 51 additions and 8 deletions

@ -340,10 +340,10 @@ type OpenChannel struct {
// target blockchain as specified by the chain hash parameter. // target blockchain as specified by the chain hash parameter.
FundingOutpoint wire.OutPoint FundingOutpoint wire.OutPoint
// ShortChanID encodes the exact location in the chain in which the // ShortChannelID encodes the exact location in the chain in which the
// channel was initially confirmed. This includes: the block height, // channel was initially confirmed. This includes: the block height,
// transaction index, and the output within the target transaction. // transaction index, and the output within the target transaction.
ShortChanID lnwire.ShortChannelID ShortChannelID lnwire.ShortChannelID
// IsPending indicates whether a channel's funding transaction has been // IsPending indicates whether a channel's funding transaction has been
// confirmed. // confirmed.
@ -460,6 +460,47 @@ func (c *OpenChannel) FullSync() error {
return c.Db.Update(c.fullSync) return c.Db.Update(c.fullSync)
} }
// ShortChanID returns the current ShortChannelID of this channel.
func (c *OpenChannel) ShortChanID() lnwire.ShortChannelID {
c.RLock()
defer c.RUnlock()
return c.ShortChannelID
}
// RefreshShortChanID updates the in-memory short channel ID using the latest
// value observed on disk.
func (c *OpenChannel) RefreshShortChanID() error {
c.Lock()
defer c.Unlock()
var sid lnwire.ShortChannelID
err := c.Db.View(func(tx *bolt.Tx) error {
chanBucket, err := readChanBucket(
tx, c.IdentityPub, &c.FundingOutpoint, c.ChainHash,
)
if err != nil {
return err
}
channel, err := fetchOpenChannel(chanBucket, &c.FundingOutpoint)
if err != nil {
return err
}
sid = channel.ShortChannelID
return nil
})
if err != nil {
return err
}
c.ShortChannelID = sid
return nil
}
// updateChanBucket is a helper function that returns a writable bucket that a // updateChanBucket is a helper function that returns a writable bucket that a
// channel's data resides in given: the public key for the node, the outpoint, // channel's data resides in given: the public key for the node, the outpoint,
// and the chainhash that the channel resides on. // and the chainhash that the channel resides on.
@ -582,7 +623,7 @@ func (c *OpenChannel) MarkAsOpen(openLoc lnwire.ShortChannelID) error {
} }
channel.IsPending = false channel.IsPending = false
channel.ShortChanID = openLoc channel.ShortChannelID = openLoc
return putOpenChannel(chanBucket, channel) return putOpenChannel(chanBucket, channel)
}); err != nil { }); err != nil {
@ -590,7 +631,7 @@ func (c *OpenChannel) MarkAsOpen(openLoc lnwire.ShortChannelID) error {
} }
c.IsPending = false c.IsPending = false
c.ShortChanID = openLoc c.ShortChannelID = openLoc
return nil return nil
} }
@ -692,7 +733,7 @@ func fetchOpenChannel(chanBucket *bolt.Bucket,
return nil, fmt.Errorf("unable to fetch chan revocations: %v", err) return nil, fmt.Errorf("unable to fetch chan revocations: %v", err)
} }
channel.Packager = NewChannelPackager(channel.ShortChanID) channel.Packager = NewChannelPackager(channel.ShortChannelID)
return channel, nil return channel, nil
} }
@ -1977,7 +2018,7 @@ func putChanInfo(chanBucket *bolt.Bucket, channel *OpenChannel) error {
var w bytes.Buffer var w bytes.Buffer
if err := writeElements(&w, if err := writeElements(&w,
channel.ChanType, channel.ChainHash, channel.FundingOutpoint, channel.ChanType, channel.ChainHash, channel.FundingOutpoint,
channel.ShortChanID, channel.IsPending, channel.IsInitiator, channel.ShortChannelID, channel.IsPending, channel.IsInitiator,
channel.ChanStatus, channel.FundingBroadcastHeight, channel.ChanStatus, channel.FundingBroadcastHeight,
channel.NumConfsRequired, channel.ChannelFlags, channel.NumConfsRequired, channel.ChannelFlags,
channel.IdentityPub, channel.Capacity, channel.TotalMSatSent, channel.IdentityPub, channel.Capacity, channel.TotalMSatSent,
@ -2087,7 +2128,7 @@ func fetchChanInfo(chanBucket *bolt.Bucket, channel *OpenChannel) error {
if err := readElements(r, if err := readElements(r,
&channel.ChanType, &channel.ChainHash, &channel.FundingOutpoint, &channel.ChanType, &channel.ChainHash, &channel.FundingOutpoint,
&channel.ShortChanID, &channel.IsPending, &channel.IsInitiator, &channel.ShortChannelID, &channel.IsPending, &channel.IsInitiator,
&channel.ChanStatus, &channel.FundingBroadcastHeight, &channel.ChanStatus, &channel.FundingBroadcastHeight,
&channel.NumConfsRequired, &channel.ChannelFlags, &channel.NumConfsRequired, &channel.ChannelFlags,
&channel.IdentityPub, &channel.Capacity, &channel.TotalMSatSent, &channel.IdentityPub, &channel.Capacity, &channel.TotalMSatSent,
@ -2110,7 +2151,7 @@ func fetchChanInfo(chanBucket *bolt.Bucket, channel *OpenChannel) error {
return err return err
} }
channel.Packager = NewChannelPackager(channel.ShortChanID) channel.Packager = NewChannelPackager(channel.ShortChannelID)
return nil return nil
} }

@ -1702,6 +1702,8 @@ func (s *Switch) Stop() error {
for _, mailBox := range s.mailboxes { for _, mailBox := range s.mailboxes {
mailBox.Stop() mailBox.Stop()
} }
for _, mailBox := range s.pendingMailboxes {
mailBox.Stop()
return nil return nil
} }