mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-08-29 15:11:09 +02:00
discovery: pass context through to bootstrapper SampleNodeAddrs
Since the ChannelGraphBootstrapper implementation makes a call to the graph DB.
This commit is contained in:
@@ -2,6 +2,7 @@ package discovery
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"context"
|
||||
"crypto/rand"
|
||||
"crypto/sha256"
|
||||
"errors"
|
||||
@@ -36,8 +37,9 @@ type NetworkPeerBootstrapper interface {
|
||||
// denotes how many valid peer addresses to return. The passed set of
|
||||
// node nodes allows the caller to ignore a set of nodes perhaps
|
||||
// because they already have connections established.
|
||||
SampleNodeAddrs(numAddrs uint32,
|
||||
ignore map[autopilot.NodeID]struct{}) ([]*lnwire.NetAddress, error)
|
||||
SampleNodeAddrs(ctx context.Context, numAddrs uint32,
|
||||
ignore map[autopilot.NodeID]struct{}) ([]*lnwire.NetAddress,
|
||||
error)
|
||||
|
||||
// Name returns a human readable string which names the concrete
|
||||
// implementation of the NetworkPeerBootstrapper.
|
||||
@@ -50,7 +52,8 @@ type NetworkPeerBootstrapper interface {
|
||||
// bootstrapper will be queried successively until the target amount is met. If
|
||||
// the ignore map is populated, then the bootstrappers will be instructed to
|
||||
// skip those nodes.
|
||||
func MultiSourceBootstrap(ignore map[autopilot.NodeID]struct{}, numAddrs uint32,
|
||||
func MultiSourceBootstrap(ctx context.Context,
|
||||
ignore map[autopilot.NodeID]struct{}, numAddrs uint32,
|
||||
bootstrappers ...NetworkPeerBootstrapper) ([]*lnwire.NetAddress, error) {
|
||||
|
||||
// We'll randomly shuffle our bootstrappers before querying them in
|
||||
@@ -73,7 +76,9 @@ func MultiSourceBootstrap(ignore map[autopilot.NodeID]struct{}, numAddrs uint32,
|
||||
// the number of address remaining that we need to fetch.
|
||||
numAddrsLeft := numAddrs - uint32(len(addrs))
|
||||
log.Tracef("Querying for %v addresses", numAddrsLeft)
|
||||
netAddrs, err := bootstrapper.SampleNodeAddrs(numAddrsLeft, ignore)
|
||||
netAddrs, err := bootstrapper.SampleNodeAddrs(
|
||||
ctx, numAddrsLeft, ignore,
|
||||
)
|
||||
if err != nil {
|
||||
// If we encounter an error with a bootstrapper, then
|
||||
// we'll continue on to the next available
|
||||
@@ -152,7 +157,8 @@ func NewGraphBootstrapper(cg autopilot.ChannelGraph) (NetworkPeerBootstrapper, e
|
||||
// many valid peer addresses to return.
|
||||
//
|
||||
// NOTE: Part of the NetworkPeerBootstrapper interface.
|
||||
func (c *ChannelGraphBootstrapper) SampleNodeAddrs(numAddrs uint32,
|
||||
func (c *ChannelGraphBootstrapper) SampleNodeAddrs(_ context.Context,
|
||||
numAddrs uint32,
|
||||
ignore map[autopilot.NodeID]struct{}) ([]*lnwire.NetAddress, error) {
|
||||
|
||||
// We'll merge the ignore map with our currently selected map in order
|
||||
@@ -382,7 +388,8 @@ func (d *DNSSeedBootstrapper) fallBackSRVLookup(soaShim string,
|
||||
// network peer bootstrapper source. The num addrs field passed in denotes how
|
||||
// many valid peer addresses to return. The set of DNS seeds are used
|
||||
// successively to retrieve eligible target nodes.
|
||||
func (d *DNSSeedBootstrapper) SampleNodeAddrs(numAddrs uint32,
|
||||
func (d *DNSSeedBootstrapper) SampleNodeAddrs(_ context.Context,
|
||||
numAddrs uint32,
|
||||
ignore map[autopilot.NodeID]struct{}) ([]*lnwire.NetAddress, error) {
|
||||
|
||||
var netAddrs []*lnwire.NetAddress
|
||||
|
Reference in New Issue
Block a user