package dms3p2p import ( "context" "time" "gitlab.dms3.io/p2p/go-p2p-core/host" "gitlab.dms3.io/p2p/go-p2p-core/peer" "gitlab.dms3.io/p2p/go-p2p/p2p/discovery" "go.uber.org/fx" "gitlab.dms3.io/dms3/go-dms3/core/node/helpers" ) const discoveryConnTimeout = time.Second * 30 type discoveryHandler struct { ctx context.Context host host.Host } func (dh *discoveryHandler) HandlePeerFound(p peer.AddrInfo) { log.Info("connecting to discovered peer: ", p) ctx, cancel := context.WithTimeout(dh.ctx, discoveryConnTimeout) defer cancel() if err := dh.host.Connect(ctx, p); err != nil { log.Warnf("failed to connect to peer %s found by discovery: %s", p.ID, err) } } func DiscoveryHandler(mctx helpers.MetricsCtx, lc fx.Lifecycle, host host.Host) *discoveryHandler { return &discoveryHandler{ ctx: helpers.LifecycleCtx(mctx, lc), host: host, } } func SetupDiscovery(mdns bool, mdnsInterval int) func(helpers.MetricsCtx, fx.Lifecycle, host.Host, *discoveryHandler) error { return func(mctx helpers.MetricsCtx, lc fx.Lifecycle, host host.Host, handler *discoveryHandler) error { if mdns { if mdnsInterval == 0 { mdnsInterval = 5 } service, err := discovery.NewMdnsService(helpers.LifecycleCtx(mctx, lc), host, time.Duration(mdnsInterval)*time.Second, discovery.ServiceTag) if err != nil { log.Error("mdns error: ", err) return nil } service.RegisterNotifee(handler) } return nil } }