channeldb/channel: make putChanStatus take optional extra closures

This commit is contained in:
Johan T. Halseth 2019-09-06 13:14:39 +02:00
parent 1974bfa4cf
commit a810092e53
No known key found for this signature in database
GPG Key ID: 15BAADA29DA20D26

@ -726,44 +726,16 @@ func (c *OpenChannel) MarkDataLoss(commitPoint *btcec.PublicKey) error {
c.Lock() c.Lock()
defer c.Unlock() defer c.Unlock()
var status ChannelStatus
if err := c.Db.Update(func(tx *bbolt.Tx) error {
chanBucket, err := fetchChanBucket(
tx, c.IdentityPub, &c.FundingOutpoint, c.ChainHash,
)
if err != nil {
return err
}
channel, err := fetchOpenChannel(chanBucket, &c.FundingOutpoint)
if err != nil {
return err
}
// Add status LocalDataLoss to the existing bitvector found in
// the DB.
status = channel.chanStatus | ChanStatusLocalDataLoss
channel.chanStatus = status
var b bytes.Buffer var b bytes.Buffer
if err := WriteElement(&b, commitPoint); err != nil { if err := WriteElement(&b, commitPoint); err != nil {
return err return err
} }
err = chanBucket.Put(dataLossCommitPointKey, b.Bytes()) putCommitPoint := func(chanBucket *bbolt.Bucket) error {
if err != nil { return chanBucket.Put(dataLossCommitPointKey, b.Bytes())
return err
} }
return putOpenChannel(chanBucket, channel) return c.putChanStatus(ChanStatusLocalDataLoss, putCommitPoint)
}); err != nil {
return err
}
// Update the in-memory representation to keep it in sync with the DB.
c.chanStatus = status
return nil
} }
// DataLossCommitPoint retrieves the stored commit point set during // DataLossCommitPoint retrieves the stored commit point set during
@ -914,7 +886,12 @@ func (c *OpenChannel) MarkCommitmentBroadcasted() error {
return c.putChanStatus(ChanStatusCommitBroadcasted) return c.putChanStatus(ChanStatusCommitBroadcasted)
} }
func (c *OpenChannel) putChanStatus(status ChannelStatus) error { // putChanStatus appends the given status to the channel. fs is an optional
// list of closures that are given the chanBucket in order to atomically add
// extra information together with the new status.
func (c *OpenChannel) putChanStatus(status ChannelStatus,
fs ...func(*bbolt.Bucket) error) error {
if err := c.Db.Update(func(tx *bbolt.Tx) error { if err := c.Db.Update(func(tx *bbolt.Tx) error {
chanBucket, err := fetchChanBucket( chanBucket, err := fetchChanBucket(
tx, c.IdentityPub, &c.FundingOutpoint, c.ChainHash, tx, c.IdentityPub, &c.FundingOutpoint, c.ChainHash,
@ -932,7 +909,17 @@ func (c *OpenChannel) putChanStatus(status ChannelStatus) error {
status = channel.chanStatus | status status = channel.chanStatus | status
channel.chanStatus = status channel.chanStatus = status
return putOpenChannel(chanBucket, channel) if err := putOpenChannel(chanBucket, channel); err != nil {
return err
}
for _, f := range fs {
if err := f(chanBucket); err != nil {
return err
}
}
return nil
}); err != nil { }); err != nil {
return err return err
} }