chainntnfs/bitcoindnotify: remove old spend notification handling logic
In this commit, we remove the old spend notification logic within the BitcoindNotifier as it's been phased out by the TxNotifier.
This commit is contained in:
parent
180dffd154
commit
0927f35dc1
@ -68,8 +68,6 @@ type BitcoindNotifier struct {
|
|||||||
notificationCancels chan interface{}
|
notificationCancels chan interface{}
|
||||||
notificationRegistry chan interface{}
|
notificationRegistry chan interface{}
|
||||||
|
|
||||||
spendNotifications map[wire.OutPoint]map[uint64]*spendNotification
|
|
||||||
|
|
||||||
txNotifier *chainntnfs.TxNotifier
|
txNotifier *chainntnfs.TxNotifier
|
||||||
|
|
||||||
blockEpochClients map[uint64]*blockEpochRegistration
|
blockEpochClients map[uint64]*blockEpochRegistration
|
||||||
@ -106,8 +104,6 @@ func New(chainConn *chain.BitcoindConn, spendHintCache chainntnfs.SpendHintCache
|
|||||||
|
|
||||||
blockEpochClients: make(map[uint64]*blockEpochRegistration),
|
blockEpochClients: make(map[uint64]*blockEpochRegistration),
|
||||||
|
|
||||||
spendNotifications: make(map[wire.OutPoint]map[uint64]*spendNotification),
|
|
||||||
|
|
||||||
spendHintCache: spendHintCache,
|
spendHintCache: spendHintCache,
|
||||||
confirmHintCache: confirmHintCache,
|
confirmHintCache: confirmHintCache,
|
||||||
|
|
||||||
@ -173,11 +169,6 @@ func (b *BitcoindNotifier) Stop() error {
|
|||||||
|
|
||||||
// Notify all pending clients of our shutdown by closing the related
|
// Notify all pending clients of our shutdown by closing the related
|
||||||
// notification channels.
|
// notification channels.
|
||||||
for _, spendClients := range b.spendNotifications {
|
|
||||||
for _, spendClient := range spendClients {
|
|
||||||
close(spendClient.spendChan)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for _, epochClient := range b.blockEpochClients {
|
for _, epochClient := range b.blockEpochClients {
|
||||||
close(epochClient.cancelChan)
|
close(epochClient.cancelChan)
|
||||||
epochClient.wg.Wait()
|
epochClient.wg.Wait()
|
||||||
@ -204,19 +195,6 @@ out:
|
|||||||
select {
|
select {
|
||||||
case cancelMsg := <-b.notificationCancels:
|
case cancelMsg := <-b.notificationCancels:
|
||||||
switch msg := cancelMsg.(type) {
|
switch msg := cancelMsg.(type) {
|
||||||
case *spendCancel:
|
|
||||||
chainntnfs.Log.Infof("Cancelling spend "+
|
|
||||||
"notification for out_point=%v, "+
|
|
||||||
"spend_id=%v", msg.op, msg.spendID)
|
|
||||||
|
|
||||||
// Before we attempt to close the spendChan,
|
|
||||||
// ensure that the notification hasn't already
|
|
||||||
// yet been dispatched.
|
|
||||||
if outPointClients, ok := b.spendNotifications[msg.op]; ok {
|
|
||||||
close(outPointClients[msg.spendID].spendChan)
|
|
||||||
delete(b.spendNotifications[msg.op], msg.spendID)
|
|
||||||
}
|
|
||||||
|
|
||||||
case *epochCancel:
|
case *epochCancel:
|
||||||
chainntnfs.Log.Infof("Cancelling epoch "+
|
chainntnfs.Log.Infof("Cancelling epoch "+
|
||||||
"notification, epoch_id=%v", msg.epochID)
|
"notification, epoch_id=%v", msg.epochID)
|
||||||
@ -244,16 +222,6 @@ out:
|
|||||||
}
|
}
|
||||||
case registerMsg := <-b.notificationRegistry:
|
case registerMsg := <-b.notificationRegistry:
|
||||||
switch msg := registerMsg.(type) {
|
switch msg := registerMsg.(type) {
|
||||||
case *spendNotification:
|
|
||||||
chainntnfs.Log.Infof("New spend subscription: "+
|
|
||||||
"utxo=%v", msg.targetOutpoint)
|
|
||||||
op := *msg.targetOutpoint
|
|
||||||
|
|
||||||
if _, ok := b.spendNotifications[op]; !ok {
|
|
||||||
b.spendNotifications[op] = make(map[uint64]*spendNotification)
|
|
||||||
}
|
|
||||||
b.spendNotifications[op][msg.spendID] = msg
|
|
||||||
|
|
||||||
case *chainntnfs.HistoricalConfDispatch:
|
case *chainntnfs.HistoricalConfDispatch:
|
||||||
// Look up whether the transaction is already
|
// Look up whether the transaction is already
|
||||||
// included in the active chain. We'll do this
|
// included in the active chain. We'll do this
|
||||||
@ -326,9 +294,6 @@ out:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
msg.errorChan <- nil
|
msg.errorChan <- nil
|
||||||
|
|
||||||
case chain.RelevantTx:
|
|
||||||
b.handleRelevantTx(msg, b.bestBlock.Height)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
case ntfn := <-b.chainConn.Notifications():
|
case ntfn := <-b.chainConn.Notifications():
|
||||||
@ -618,27 +583,6 @@ func (b *BitcoindNotifier) handleBlockConnected(block chainntnfs.BlockEpoch) err
|
|||||||
chainntnfs.Log.Infof("New block: height=%v, sha=%v", block.Height,
|
chainntnfs.Log.Infof("New block: height=%v, sha=%v", block.Height,
|
||||||
block.Hash)
|
block.Hash)
|
||||||
|
|
||||||
// Finally, we'll update the spend height hint for all of our watched
|
|
||||||
// outpoints that have not been spent yet. This is safe to do as we do
|
|
||||||
// not watch already spent outpoints for spend notifications.
|
|
||||||
ops := make([]wire.OutPoint, 0, len(b.spendNotifications))
|
|
||||||
for op := range b.spendNotifications {
|
|
||||||
ops = append(ops, op)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(ops) > 0 {
|
|
||||||
err := b.spendHintCache.CommitSpendHint(
|
|
||||||
uint32(block.Height), ops...,
|
|
||||||
)
|
|
||||||
if err != nil {
|
|
||||||
// The error is not fatal since we are connecting a
|
|
||||||
// block, and advancing the spend hint is an optimistic
|
|
||||||
// optimization.
|
|
||||||
chainntnfs.Log.Errorf("Unable to update spend hint to "+
|
|
||||||
"%d for %v: %v", block.Height, ops, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// We want to set the best block before dispatching notifications so
|
// We want to set the best block before dispatching notifications so
|
||||||
// if any subscribers make queries based on their received block epoch,
|
// if any subscribers make queries based on their received block epoch,
|
||||||
// our state is fully updated in time.
|
// our state is fully updated in time.
|
||||||
@ -675,28 +619,6 @@ func (b *BitcoindNotifier) notifyBlockEpochClient(epochClient *blockEpochRegistr
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// spendNotification couples a target outpoint along with the channel used for
|
|
||||||
// notifications once a spend of the outpoint has been detected.
|
|
||||||
type spendNotification struct {
|
|
||||||
targetOutpoint *wire.OutPoint
|
|
||||||
|
|
||||||
spendChan chan *chainntnfs.SpendDetail
|
|
||||||
|
|
||||||
spendID uint64
|
|
||||||
|
|
||||||
heightHint uint32
|
|
||||||
}
|
|
||||||
|
|
||||||
// spendCancel is a message sent to the BitcoindNotifier when a client wishes
|
|
||||||
// to cancel an outstanding spend notification that has yet to be dispatched.
|
|
||||||
type spendCancel struct {
|
|
||||||
// op is the target outpoint of the notification to be cancelled.
|
|
||||||
op wire.OutPoint
|
|
||||||
|
|
||||||
// spendID the ID of the notification to cancel.
|
|
||||||
spendID uint64
|
|
||||||
}
|
|
||||||
|
|
||||||
// RegisterSpendNtfn registers an intent to be notified once the target
|
// RegisterSpendNtfn registers an intent to be notified once the target
|
||||||
// outpoint has been spent by a transaction on-chain. Once a spend of the target
|
// outpoint has been spent by a transaction on-chain. Once a spend of the target
|
||||||
// outpoint has been detected, the details of the spending event will be sent
|
// outpoint has been detected, the details of the spending event will be sent
|
||||||
|
Loading…
Reference in New Issue
Block a user