Skip to content
Snippets Groups Projects
Select Git revision
  • efafcd7b8effe1e1e3a6d2efe7c5734f3f2a87af
  • develop default protected
  • congestioncontrol
  • merge-v-data-collection-spammer-0.8.2
  • WIP-merge-v-data-collection-spammer-0.8.2
  • merge-v-data-collection-spammer-0.7.7
  • tmp
  • test-masterpow-fixing
  • test-masterpow
  • test-echo
  • v-data-collection
  • v-data-collection-spammer
  • tmp-dump-spam-info
  • dump-msg-info-0.3.1
  • test-dump-message-info
  • spammer-exprandom
  • extra/tutorial
  • without_tipselection
  • hacking-docker-network
  • hacking-docker-network-0.2.3
  • master
  • v0.2.3
22 results

Makefile

Blame
  • plugin.go 2.07 KiB
    package autopeering
    
    import (
    	"time"
    
    	"github.com/iotaledger/goshimmer/packages/shutdown"
    	"github.com/iotaledger/hive.go/autopeering/discover"
    	"github.com/iotaledger/hive.go/autopeering/selection"
    	"github.com/iotaledger/hive.go/daemon"
    	"github.com/iotaledger/hive.go/events"
    	"github.com/iotaledger/hive.go/logger"
    	"github.com/iotaledger/hive.go/node"
    )
    
    // PluginName is the name of the autopeering plugin.
    const PluginName = "Autopeering"
    
    var (
    	// Plugin is the plugin instance of the autopeering plugin.
    	Plugin = node.NewPlugin(PluginName, node.Enabled, configure, run)
    
    	log *logger.Logger
    )
    
    func configure(*node.Plugin) {
    	log = logger.NewLogger(PluginName)
    
    	configureEvents()
    }
    
    func run(*node.Plugin) {
    	if err := daemon.BackgroundWorker(PluginName, start, shutdown.PriorityAutopeering); err != nil {
    		log.Panicf("Failed to start as daemon: %s", err)
    	}
    }
    
    func configureEvents() {
    	// assure that the autopeering is instantiated
    	peerDisc := Discovery()
    	peerSel := Selection()
    
    	// log the peer discovery events
    	peerDisc.Events().PeerDiscovered.Attach(events.NewClosure(func(ev *discover.DiscoveredEvent) {
    		log.Infof("Discovered: %s / %s", ev.Peer.Address(), ev.Peer.ID())
    	}))
    	peerDisc.Events().PeerDeleted.Attach(events.NewClosure(func(ev *discover.DeletedEvent) {
    		log.Infof("Removed offline: %s / %s", ev.Peer.Address(), ev.Peer.ID())
    	}))
    
    	// log the peer selection events
    	peerSel.Events().SaltUpdated.Attach(events.NewClosure(func(ev *selection.SaltUpdatedEvent) {
    		log.Infof("Salt updated; expires=%s", ev.Public.GetExpiration().Format(time.RFC822))
    	}))
    	peerSel.Events().OutgoingPeering.Attach(events.NewClosure(func(ev *selection.PeeringEvent) {
    		if ev.Status {
    			log.Infof("Peering chosen: %s / %s", ev.Peer.Address(), ev.Peer.ID())
    		}
    	}))
    	peerSel.Events().IncomingPeering.Attach(events.NewClosure(func(ev *selection.PeeringEvent) {
    		if ev.Status {
    			log.Infof("Peering accepted: %s / %s", ev.Peer.Address(), ev.Peer.ID())
    		}
    	}))
    	peerSel.Events().Dropped.Attach(events.NewClosure(func(ev *selection.DroppedEvent) {
    		log.Infof("Peering dropped: %s", ev.DroppedID)
    	}))
    }