Skip to content
Snippets Groups Projects
Select Git revision
  • 2db9a4ddf69fad9e45f3dc1d2c46a055172a430c
  • release default protected
  • 11-22-implement-kv-interface-defined-in-collectiveversionedkvgo
  • hotfix/TestHostPool_UpdateNdf_AddFilter
  • XX-4719/announcementChannels
  • xx-4717/logLevel
  • jonah/noob-channel
  • master protected
  • XX-4707/tagDiskJson
  • xx-4698/notification-retry
  • hotfix/notifylockup
  • syncNodes
  • hotfix/localCB
  • XX-4677/NewChanManagerMobile
  • XX-4689/DmSync
  • duplicatePrefix
  • XX-4601/HavenInvites
  • finalizedUICallbacks
  • XX-4673/AdminKeySync
  • debugNotifID
  • anne/test
  • v4.7.5
  • v4.7.4
  • v4.7.3
  • v4.7.2
  • v4.7.1
  • v4.6.3
  • v4.6.1
  • v4.5.0
  • v4.4.4
  • v4.3.11
  • v4.3.8
  • v4.3.7
  • v4.3.6
  • v4.3.5
  • v4.2.0
  • v4.3.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
41 results

ndf.go

Blame
  • roundEvents.go 1.74 KiB
    ///////////////////////////////////////////////////////////////////////////////
    // Copyright © 2020 xx network SEZC                                          //
    //                                                                           //
    // Use of this source code is governed by a license that can be found in the //
    // LICENSE file                                                              //
    ///////////////////////////////////////////////////////////////////////////////
    
    package interfaces
    
    import (
    	ds "gitlab.com/elixxir/comms/network/dataStructures"
    	"gitlab.com/elixxir/primitives/states"
    	"gitlab.com/xx_network/primitives/id"
    	"time"
    )
    
    // The round events interface allows the registration of an event which triggers
    // when a round reaches one or more states
    
    type RoundEvents interface {
    	// designates a callback to call on the specified event
    	// rid is the id of the round the event occurs on
    	// callback is the callback the event is triggered on
    	// timeout is the amount of time before an error event is returned
    	// valid states are the states which the event should trigger on
    	AddRoundEvent(rid id.Round, callback ds.RoundEventCallback,
    		timeout time.Duration, validStates ...states.Round) *ds.EventCallback
    
    	// designates a go channel to signal the specified event
    	// rid is the id of the round the event occurs on
    	// eventChan is the channel the event is triggered on
    	// timeout is the amount of time before an error event is returned
    	// valid states are the states which the event should trigger on
    	AddRoundEventChan(rid id.Round, eventChan chan ds.EventReturn,
    		timeout time.Duration, validStates ...states.Round) *ds.EventCallback
    
    	//Allows the un-registration of a round event before it triggers
    	Remove(rid id.Round, e *ds.EventCallback)
    }