Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var IntervalSize time.Duration
Functions ¶
This section is empty.
Types ¶
type ConnectEventsConfig ¶ added in v1.2.0
type CtrlDialer ¶
type CtrlDialer func(address transport.Address, bindHandler channel.BindHandler) error
type CtrlEvent ¶ added in v1.3.0
type CtrlEvent struct { Type CtrlEventType Controller NetworkController }
type CtrlEventListener ¶ added in v1.3.0
type CtrlEventListener interface {
NotifyOfCtrlEvent(event CtrlEvent)
}
type CtrlEventListenerFunc ¶ added in v1.3.0
type CtrlEventListenerFunc func(event CtrlEvent)
func (CtrlEventListenerFunc) NotifyOfCtrlEvent ¶ added in v1.3.0
func (self CtrlEventListenerFunc) NotifyOfCtrlEvent(event CtrlEvent)
type CtrlEventType ¶ added in v1.3.0
type CtrlEventType string
const ( ControllerAdded CtrlEventType = "Added" ControllerReconnected CtrlEventType = "Reconnected" ControllerRemoved CtrlEventType = "Removed" )
type HeartbeatOptions ¶
func NewDefaultHeartbeatOptions ¶
func NewDefaultHeartbeatOptions() *HeartbeatOptions
func NewHeartbeatOptions ¶
func NewHeartbeatOptions(options *channel.HeartbeatOptions) (*HeartbeatOptions, error)
type NetworkController ¶
type NetworkController interface { Channel() channel.Channel Address() string Latency() time.Duration HeartbeatCallback() channel.HeartbeatCallback IsUnresponsive() bool GetVersion() *versions.VersionInfo TimeSinceLastContact() time.Duration IsConnected() bool GetLastReportedDataModelIndex() uint64 // contains filtered or unexported methods }
type NetworkControllers ¶
type NetworkControllers interface { UpdateControllerEndpoints(endpoints []string) bool UpdateLeader(leaderId string) GetAll() map[string]NetworkController GetNetworkController(ctrlId string) NetworkController AnyCtrlChannel() channel.Channel GetModelUpdateCtrlChannel() channel.Channel GetIfResponsive(ctrlId string) (channel.Channel, bool) AllResponsiveCtrlChannels() []channel.Channel AnyValidCtrlChannel() channel.Channel GetCtrlChannel(ctrlId string) channel.Channel DefaultRequestTimeout() time.Duration ForEach(f func(ctrlId string, ch channel.Channel)) Close() error Inspect() *inspect.ControllerInspectDetails AddChangeListener(listener CtrlEventListener) NotifyOfReconnect(ctrlId string) }
func NewNetworkControllers ¶
func NewNetworkControllers(defaultRequestTimeout time.Duration, dialer CtrlDialer, heartbeatOptions *HeartbeatOptions) NetworkControllers
type RouterEnv ¶
type RouterEnv interface { GetNetworkControllers() NetworkControllers GetRouterId() *identity.TokenId GetDialerCfg() map[string]xgress.OptionsData GetXlinkDialers() []xlink.Dialer GetXrctrls() []Xrctrl GetTraceHandler() *channel.TraceHandler GetXlinkRegistry() xlink.Registry GetCloseNotify() <-chan struct{} GetMetricsRegistry() metrics.UsageRegistry RenderJsonConfig() (string, error) GetHeartbeatOptions() HeartbeatOptions GetRateLimiterPool() goroutines.Pool GetCtrlRateLimiter() rate.AdaptiveRateLimitTracker GetVersionInfo() versions.VersionProvider GetRouterDataModel() *common.RouterDataModel GetConnectEventsConfig() *ConnectEventsConfig GetRouterDataModelEnabledConfig() *config.Value[bool] }
type Xrctrl ¶
type Xrctrl interface { config.Subconfig channel.BindHandler Enabled() bool Run(env RouterEnv) error NotifyOfReconnect(ch channel.Channel) }
An Xrctrl allows adding handlers to the router <-> controller connection on the router side. This means you can support additional message types/flows to extend the basic fabric functionality.
There is a corresponding Xctrl interface for extending communication on the controller side
Click to show internal directories.
Click to hide internal directories.