api

package
v3.1.0+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 17, 2019 License: Apache-2.0 Imports: 6 Imported by: 52

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func DeleteAll

func DeleteAll(txn UpdateOperations, values KeyValuePairs)

DeleteAll is a helper function to prepare Delete for multiple key-value pairs into a single transaction.

func NewAbortEventError

func NewAbortEventError(origErr error) error

NewAbortEventError is the constructor for the AbortEventError.

func NewFatalError

func NewFatalError(origErr error) error

NewFatalError is the constructor for FatalError.

func PutAll

func PutAll(txn ResyncOperations, values KeyValuePairs)

PutAll is a helper function to prepare Put for multiple key-value pairs into a single transaction.

Types

type AbortEventError

type AbortEventError struct {
	// contains filtered or unexported fields
}

AbortEventError tells controller to abort the processing of the event (and for Update/RevertOnFailure to revert the changes). The agent does not have to restart but resync should be performed as soon as possible.

func (*AbortEventError) Error

func (e *AbortEventError) Error() string

Error delegates the call to the underlying error.

func (*AbortEventError) GetOriginalError

func (e *AbortEventError) GetOriginalError() error

GetOriginalError returns the underlying error.

type ConfigRetriever

type ConfigRetriever interface {
	// GetConfig returns value for the given key in the controller's transaction. If data for
	// the key is not part of the transaction stored value from internal config is returned.
	GetConfig(key string) proto.Message
}

ConfigRetriever allows to read configuration in order to adjust a config item by multiple event handlers.

type DBResync

type DBResync struct {
	Local          bool // against local DB?
	KubeState      KubeStateData
	ExternalConfig KeyValuePairs
}

DBResync is a Resync Event that carries snapshot of the database for all watched Kubernetes resources and the external configuration (for vpp-agent).

func NewDBResync

func NewDBResync() *DBResync

NewDBResync is a constructor for DBResync

func (*DBResync) Done

func (ev *DBResync) Done(error)

Done is NOOP.

func (*DBResync) GetName

func (ev *DBResync) GetName() string

GetName returns name of the DBResync event.

func (*DBResync) IsBlocking

func (ev *DBResync) IsBlocking() bool

IsBlocking returns false.

func (*DBResync) Method

func (ev *DBResync) Method() EventMethodType

Method is FullResync.

func (*DBResync) String

func (ev *DBResync) String() string

String describes DBResync event.

type Event

type Event interface {
	// GetName should return a string identifier, unique among the event types,
	// but also somewhat descriptive for humans.
	GetName() string

	// String should return a description of the event.
	String() string

	// Method tells whether the event can be reacted to by an incremental change
	// (Update) or if a full re-synchronization is needed (Resync, i.e. complex
	// change).
	Method() EventMethodType

	// IsBlocking should return true if any producer of this event ever waits
	// for the event result (sent using the method Done()).
	IsBlocking() bool

	// Done is used to mark the event as processed.
	// A specific Event implementation may use this method for example to deliver
	// the return value back to the send of the event.
	Done(error)
}

Event represents something that has happened and may cause some reaction.

type EventHandler

type EventHandler interface {
	// String identifies the handler for the Controller and in the logs.
	// Note: Plugins already implement Stringer.
	String() string

	// HandlesEvent is used by Controller to check if the event is being handled
	// by this handler.
	HandlesEvent(event Event) bool

	// Resync is called by Controller to handle event that requires full
	// re-synchronization.
	// For startup resync, resyncCount is 1. Higher counter values identify
	// run-time resync.
	Resync(event Event, kubeStateData KubeStateData, resyncCount int, txn ResyncOperations) error

	// Update is called by Controller to handle event that can be reacted to by
	// an incremental change.
	// <changeDescription> should be human-readable description of changes that
	// have to be performed (via txn or internally) - can be empty.
	Update(event Event, txn UpdateOperations) (changeDescription string, err error)

	// Revert is called to revert already executed internal changes (in the plugin
	// itself, not in VPP/Linux network stack) for a RevertOnFailure event that
	// has failed in the processing.
	Revert(event Event) error
}

EventHandler declares methods that event handler must implement.

type EventLoop

type EventLoop interface {
	// PushEvent adds the given event into the queue for processing.
	PushEvent(event Event) error
}

EventLoop defines method for accessing the main event loop.

type EventMethodType

type EventMethodType int

EventMethodType is either Resync or Update.

const (
	// FullResync event requires to be reacted to by a full re-synchronization
	// (Contiv -> VPP-agent <-> SB).
	FullResync EventMethodType = iota

	// DownstreamResync triggers re-synchronization between vpp-agent and SB.
	// Event is fully processed by the Controller (not passed to event handlers).
	DownstreamResync

	// UpstreamResync triggers re-synchronization between Contiv and VPP-agent.
	// It can be used whenever it is far easier to re-build the configuration
	// from the scratch as opposed to calculating an incremental change.
	UpstreamResync

	// Update event can be reacted to by an incremental change.
	Update
)

type ExternalConfigChange

type ExternalConfigChange struct {
	Source     string
	UpdatedKVs KeyValuePairs
	// contains filtered or unexported fields
}

ExternalConfigChange is an Update event that represents change for one or more keys from the external configuration (for vpp-agent).

func NewExternalConfigChange

func NewExternalConfigChange(source string, blocking bool) *ExternalConfigChange

NewExternalConfigChange is a constructor for ExternalConfigChange.

func (*ExternalConfigChange) Direction

func (ev *ExternalConfigChange) Direction() UpdateDirectionType

Direction is Forward.

func (*ExternalConfigChange) Done

func (ev *ExternalConfigChange) Done(err error)

Done propagates error to the event producer.

func (*ExternalConfigChange) GetName

func (ev *ExternalConfigChange) GetName() string

GetName returns name of the ExternalConfigChange event.

func (*ExternalConfigChange) IsBlocking

func (ev *ExternalConfigChange) IsBlocking() bool

IsBlocking returns what is configured in the constructor.

func (*ExternalConfigChange) Method

Method is Update.

func (*ExternalConfigChange) String

func (ev *ExternalConfigChange) String() string

String describes ExternalConfigChange event.

func (*ExternalConfigChange) TransactionType

func (ev *ExternalConfigChange) TransactionType() UpdateTransactionType

TransactionType is BestEffort.

func (*ExternalConfigChange) Wait

func (ev *ExternalConfigChange) Wait() error

Wait waits for the result of the ExternalConfigChange event.

type ExternalConfigResync

type ExternalConfigResync struct {
	Source         string
	ExternalConfig KeyValuePairs
	// contains filtered or unexported fields
}

ExternalConfigResync is a Resync event triggered by external config source. Note: External config from Remote DB uses DBResync instead.

func NewExternalConfigResync

func NewExternalConfigResync(source string, blocking bool) *ExternalConfigResync

NewExternalConfigResync is a constructor for ExternalConfigResync.

func (*ExternalConfigResync) Done

func (ev *ExternalConfigResync) Done(err error)

Done propagates error to the event producer.

func (*ExternalConfigResync) GetName

func (ev *ExternalConfigResync) GetName() string

GetName returns name of the ExternalConfigResync event.

func (*ExternalConfigResync) IsBlocking

func (ev *ExternalConfigResync) IsBlocking() bool

IsBlocking returns what is configured in the constructor.

func (*ExternalConfigResync) Method

Method is Update.

func (*ExternalConfigResync) String

func (ev *ExternalConfigResync) String() string

String describes ExternalConfigResync event.

func (*ExternalConfigResync) Wait

func (ev *ExternalConfigResync) Wait() error

Wait waits for the result of the ExternalConfigResync event.

type FatalError

type FatalError struct {
	// contains filtered or unexported fields
}

FatalError tells Controller to abort the event loop and stop the agent as soon as possible.

func (*FatalError) Error

func (e *FatalError) Error() string

Error delegates the call to the underlying error.

func (*FatalError) GetOriginalError

func (e *FatalError) GetOriginalError() error

GetOriginalError returns the underlying error.

type HealingResync

type HealingResync struct {
	Type  HealingResyncType
	Error error // non-nil if the resync is of type AfterError
}

HealingResync is supposed to "heal" the contiv-vswitch. It is run either after an error occurred or periodically.

func (*HealingResync) Done

func (ev *HealingResync) Done(error)

Done is NOOP.

func (*HealingResync) GetName

func (ev *HealingResync) GetName() string

GetName returns name of the HealingResync event.

func (*HealingResync) IsBlocking

func (ev *HealingResync) IsBlocking() bool

IsBlocking returns false.

func (*HealingResync) Method

func (ev *HealingResync) Method() EventMethodType

Method is DownstreamResync for periodic healing, otherwise FullResync is used to heal after an error.

func (*HealingResync) String

func (ev *HealingResync) String() string

String describes HealingResync event.

type HealingResyncType

type HealingResyncType int

HealingResyncType is either Periodic or AfterError.

const (
	// Periodic healing resync, when enabled in the configuration, is run periodically
	// to trigger the Downstream resync (sync between vpp-agent and VPP/Linux).
	Periodic HealingResyncType = iota

	// AfterError healing resync is triggered after an event processing ended with error.
	AfterError
)

type KeyValuePairs

type KeyValuePairs map[string]proto.Message

KeyValuePairs is a set of key-value pairs.

type KubeStateChange

type KubeStateChange struct {
	Key       string
	Resource  string
	PrevValue proto.Message // nil if newly added
	NewValue  proto.Message // nil if deleted
}

KubeStateChange is an Update event that represents change for one key from Kubernetes state data.

func (*KubeStateChange) Direction

func (ev *KubeStateChange) Direction() UpdateDirectionType

Direction is forward.

func (*KubeStateChange) Done

func (ev *KubeStateChange) Done(error)

Done is NOOP.

func (*KubeStateChange) GetName

func (ev *KubeStateChange) GetName() string

GetName returns name of the KubeStateChange event.

func (*KubeStateChange) IsBlocking

func (ev *KubeStateChange) IsBlocking() bool

IsBlocking returns false.

func (*KubeStateChange) Method

func (ev *KubeStateChange) Method() EventMethodType

Method is Update.

func (*KubeStateChange) String

func (ev *KubeStateChange) String() string

String describes KubeStateChange event.

func (*KubeStateChange) TransactionType

func (ev *KubeStateChange) TransactionType() UpdateTransactionType

TransactionType is BestEffort.

type KubeStateData

type KubeStateData map[string]KeyValuePairs // resource name -> {(key, value)}

KubeStateData contains Kubernetes state data organized as key-value pairs sorted by the resource type.

func NewKubeStateData

func NewKubeStateData() KubeStateData

NewKubeStateData is a constructor for KubeStateData.

type ResyncOperations

type ResyncOperations interface {
	// Put add request to the transaction to add or modify a value.
	// <value> cannot be nil.
	Put(key string, value proto.Message)

	// Get is used to obtain value already prepared to be applied by this transaction.
	// Until the transaction is committed, provided values can still be changed.
	// Returns nil if the value is set to be deleted, or has not been set at all.
	Get(key string) proto.Message
}

ResyncOperations lists operations needed to build transaction for Resync-type events.

type Shutdown

type Shutdown struct {
	// contains filtered or unexported fields
}

Shutdown event is triggered when the agent is being closed.

func NewShutdownEvent

func NewShutdownEvent() *Shutdown

NewShutdownEvent is constructor for Shutdown event.

func (*Shutdown) Direction

func (ev *Shutdown) Direction() UpdateDirectionType

Direction is forward.

func (*Shutdown) Done

func (ev *Shutdown) Done(err error)

Done propagates result to the event producer.

func (*Shutdown) GetName

func (ev *Shutdown) GetName() string

GetName returns name of the Shutdown event.

func (*Shutdown) IsBlocking

func (ev *Shutdown) IsBlocking() bool

IsBlocking returns true.

func (*Shutdown) Method

func (ev *Shutdown) Method() EventMethodType

Method is Update.

func (*Shutdown) String

func (ev *Shutdown) String() string

String describes Shutdown event.

func (*Shutdown) TransactionType

func (ev *Shutdown) TransactionType() UpdateTransactionType

TransactionType is BestEffort.

func (*Shutdown) Wait

func (ev *Shutdown) Wait() error

Wait waits for the result of the shutdown event.

type Transaction

type Transaction interface {
	UpdateOperations

	// Commit applies the requested transaction changes.
	Commit(ctx context.Context) (seqNum uint64, err error)
}

Transaction defines operations needed to build and commit a transaction.

type UpdateDirectionType

type UpdateDirectionType int

UpdateDirectionType is either Forward or Reverse.

const (
	// Forward event is processed by handlers in the exact same order as passed
	// to the Controller - ensuring for every handler that its dependencies
	// have already reacted to the event.
	Forward UpdateDirectionType = iota

	// Reverse event is processed by handlers in the backward order, ensuring
	// for every handler that its dependencies are still in the pre-event state.
	Reverse
)

type UpdateEvent

type UpdateEvent interface {
	// TransactionType defines how to treat already executed changes of a failed
	// event processing - whether to keep them (and be as close to the desired
	// state as it was possible) or to revert them (a proper transaction).
	TransactionType() UpdateTransactionType

	// Direction determines the direction in which the event should flow through
	// the event handlers.
	Direction() UpdateDirectionType
}

UpdateEvent can be reacted to by an incremental change, as opposed to the full re-synchronization.

type UpdateOperations

type UpdateOperations interface {
	ResyncOperations

	// Delete adds request to the transaction to delete an existing value.
	Delete(key string)
}

UpdateOperations lists operations needed to build transaction for Update-type events.

type UpdateTransactionType

type UpdateTransactionType int

UpdateTransactionType is either BestEffort or RevertOnFailure.

const (
	// BestEffort transaction continues even if non-fatal, non-abort error
	// is returned (to get as close to the desired state as it is possible).
	// After an errored BestEffort transaction, a healing resync is triggered.
	BestEffort UpdateTransactionType = iota

	// BestEffortIgnoreErrors is the same as BestEffort, but healing resync
	// is NOT triggered in case of errors.
	BestEffortIgnoreErrors

	// RevertOnFailure tells the Controller to stop event processing when any error
	// is returned and to revert already executed changes.
	RevertOnFailure
)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL