2022-10-23 13:13:43 +00:00
|
|
|
package peer_exchange
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p/core/host"
|
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
2023-08-10 12:58:22 +00:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/peermanager"
|
2022-11-09 19:53:01 +00:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
2022-10-23 13:13:43 +00:00
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
|
|
|
type PeerExchangeParameters struct {
|
|
|
|
host host.Host
|
|
|
|
selectedPeer peer.ID
|
2023-08-10 12:58:22 +00:00
|
|
|
pm *peermanager.PeerManager
|
2022-10-23 13:13:43 +00:00
|
|
|
log *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
type PeerExchangeOption func(*PeerExchangeParameters)
|
|
|
|
|
|
|
|
// WithPeer is an option used to specify the peerID to push a waku message to
|
|
|
|
func WithPeer(p peer.ID) PeerExchangeOption {
|
|
|
|
return func(params *PeerExchangeParameters) {
|
|
|
|
params.selectedPeer = p
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithAutomaticPeerSelection is an option used to randomly select a peer from the peer store
|
2022-11-24 21:50:43 +00:00
|
|
|
// to obtains peers from. If a list of specific peers is passed, the peer will be chosen
|
|
|
|
// from that list assuming it supports the chosen protocol, otherwise it will chose a peer
|
|
|
|
// from the node peerstore
|
|
|
|
func WithAutomaticPeerSelection(fromThesePeers ...peer.ID) PeerExchangeOption {
|
2022-10-23 13:13:43 +00:00
|
|
|
return func(params *PeerExchangeParameters) {
|
2023-08-10 12:58:22 +00:00
|
|
|
var p peer.ID
|
|
|
|
var err error
|
|
|
|
if params.pm == nil {
|
|
|
|
p, err = utils.SelectPeer(params.host, PeerExchangeID_v20alpha1, fromThesePeers, params.log)
|
|
|
|
} else {
|
2023-09-11 14:24:05 +00:00
|
|
|
p, err = params.pm.SelectPeer(PeerExchangeID_v20alpha1, fromThesePeers)
|
2023-08-10 12:58:22 +00:00
|
|
|
}
|
2022-10-23 13:13:43 +00:00
|
|
|
if err == nil {
|
2023-01-08 18:33:30 +00:00
|
|
|
params.selectedPeer = p
|
2022-10-23 13:13:43 +00:00
|
|
|
} else {
|
|
|
|
params.log.Info("selecting peer", zap.Error(err))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithFastestPeerSelection is an option used to select a peer from the peer store
|
2022-11-24 21:50:43 +00:00
|
|
|
// with the lowest ping. If a list of specific peers is passed, the peer will be chosen
|
|
|
|
// from that list assuming it supports the chosen protocol, otherwise it will chose a peer
|
|
|
|
// from the node peerstore
|
|
|
|
func WithFastestPeerSelection(ctx context.Context, fromThesePeers ...peer.ID) PeerExchangeOption {
|
2022-10-23 13:13:43 +00:00
|
|
|
return func(params *PeerExchangeParameters) {
|
2023-02-16 16:17:52 +00:00
|
|
|
p, err := utils.SelectPeerWithLowestRTT(ctx, params.host, PeerExchangeID_v20alpha1, fromThesePeers, params.log)
|
2022-10-23 13:13:43 +00:00
|
|
|
if err == nil {
|
2023-01-08 18:33:30 +00:00
|
|
|
params.selectedPeer = p
|
2022-10-23 13:13:43 +00:00
|
|
|
} else {
|
|
|
|
params.log.Info("selecting peer", zap.Error(err))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultOptions are the default options to be used when using the lightpush protocol
|
|
|
|
func DefaultOptions(host host.Host) []PeerExchangeOption {
|
|
|
|
return []PeerExchangeOption{
|
|
|
|
WithAutomaticPeerSelection(),
|
|
|
|
}
|
|
|
|
}
|