contractcourt/chain_arbitrator: make breachArbiter handoff a function closure
This commit adds the new function closure option ContractBreach to the ChainArbitrator config, a closure that is again used by the ChainWatcher to reliably handoff a breach event to the breachArbiter.
This commit is contained in:
parent
3fdc04dff0
commit
f06797ab00
@ -81,6 +81,13 @@ type ChainArbitratorConfig struct {
|
|||||||
// TODO(roasbeef): rename, routing based
|
// TODO(roasbeef): rename, routing based
|
||||||
MarkLinkInactive func(wire.OutPoint) error
|
MarkLinkInactive func(wire.OutPoint) error
|
||||||
|
|
||||||
|
// ContractBreach is a function closure that the ChainArbitrator will
|
||||||
|
// use to notify the breachArbiter about a contract breach. It should
|
||||||
|
// only return a non-nil error when the breachArbiter has preserved the
|
||||||
|
// necessary breach info for this channel point, and it is safe to mark
|
||||||
|
// the channel as pending close in the database.
|
||||||
|
ContractBreach func(wire.OutPoint, *lnwallet.BreachRetribution) error
|
||||||
|
|
||||||
// IsOurAddress is a function that returns true if the passed address
|
// IsOurAddress is a function that returns true if the passed address
|
||||||
// is known to the underlying wallet. Otherwise, false should be
|
// is known to the underlying wallet. Otherwise, false should be
|
||||||
// returned.
|
// returned.
|
||||||
@ -337,6 +344,9 @@ func (c *ChainArbitrator) Start() error {
|
|||||||
// TODO(roasbeef): also need to pass in log?
|
// TODO(roasbeef): also need to pass in log?
|
||||||
return c.resolveContract(chanPoint, nil)
|
return c.resolveContract(chanPoint, nil)
|
||||||
},
|
},
|
||||||
|
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
||||||
|
return c.cfg.ContractBreach(chanPoint, retInfo)
|
||||||
|
},
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -345,7 +355,7 @@ func (c *ChainArbitrator) Start() error {
|
|||||||
|
|
||||||
c.activeWatchers[chanPoint] = chainWatcher
|
c.activeWatchers[chanPoint] = chainWatcher
|
||||||
channelArb, err := newActiveChannelArbitrator(
|
channelArb, err := newActiveChannelArbitrator(
|
||||||
channel, c, chainWatcher.SubscribeChannelEvents(false),
|
channel, c, chainWatcher.SubscribeChannelEvents(),
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -669,6 +679,9 @@ func (c *ChainArbitrator) WatchNewChannel(newChan *channeldb.OpenChannel) error
|
|||||||
markChanClosed: func() error {
|
markChanClosed: func() error {
|
||||||
return c.resolveContract(chanPoint, nil)
|
return c.resolveContract(chanPoint, nil)
|
||||||
},
|
},
|
||||||
|
contractBreach: func(retInfo *lnwallet.BreachRetribution) error {
|
||||||
|
return c.cfg.ContractBreach(chanPoint, retInfo)
|
||||||
|
},
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -680,7 +693,7 @@ func (c *ChainArbitrator) WatchNewChannel(newChan *channeldb.OpenChannel) error
|
|||||||
// We'll also create a new channel arbitrator instance using this new
|
// We'll also create a new channel arbitrator instance using this new
|
||||||
// channel, and our internal state.
|
// channel, and our internal state.
|
||||||
channelArb, err := newActiveChannelArbitrator(
|
channelArb, err := newActiveChannelArbitrator(
|
||||||
newChan, c, chainWatcher.SubscribeChannelEvents(false),
|
newChan, c, chainWatcher.SubscribeChannelEvents(),
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -708,7 +721,7 @@ func (c *ChainArbitrator) WatchNewChannel(newChan *channeldb.OpenChannel) error
|
|||||||
// TODO(roasbeef): can be used later to provide RPC hook for all channel
|
// TODO(roasbeef): can be used later to provide RPC hook for all channel
|
||||||
// lifetimes
|
// lifetimes
|
||||||
func (c *ChainArbitrator) SubscribeChannelEvents(
|
func (c *ChainArbitrator) SubscribeChannelEvents(
|
||||||
chanPoint wire.OutPoint, syncDispatch bool) (*ChainEventSubscription, error) {
|
chanPoint wire.OutPoint) (*ChainEventSubscription, error) {
|
||||||
|
|
||||||
// First, we'll attempt to look up the active watcher for this channel.
|
// First, we'll attempt to look up the active watcher for this channel.
|
||||||
// If we can't find it, then we'll return an error back to the caller.
|
// If we can't find it, then we'll return an error back to the caller.
|
||||||
@ -720,7 +733,7 @@ func (c *ChainArbitrator) SubscribeChannelEvents(
|
|||||||
|
|
||||||
// With the watcher located, we'll request for it to create a new chain
|
// With the watcher located, we'll request for it to create a new chain
|
||||||
// event subscription client.
|
// event subscription client.
|
||||||
return watcher.SubscribeChannelEvents(syncDispatch), nil
|
return watcher.SubscribeChannelEvents(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// BeginCoopChanClose allows the initiator or responder to a cooperative
|
// BeginCoopChanClose allows the initiator or responder to a cooperative
|
||||||
|
Loading…
Reference in New Issue
Block a user