Documentation ¶
Index ¶
- Constants
- func ErrAssertMachineCtx(err error) error
- func ErrInititalizeK8sMachine(err error) error
- func ErrInvalidTransition(from, to StateType) error
- func ErrInvalidTransitionEvent(from StateType, event EventType) error
- func ErrInvalidType(err error) error
- type Action
- type ConnectionToStateMachineInstanceTracker
- type DefaultConnectAction
- func (da *DefaultConnectAction) Execute(ctx context.Context, machineCtx interface{}, data interface{}) (EventType, *events.Event, error)
- func (da *DefaultConnectAction) ExecuteOnEntry(ctx context.Context, machineCtx interface{}, data interface{}) (EventType, *events.Event, error)
- func (da *DefaultConnectAction) ExecuteOnExit(ctx context.Context, machineCtx interface{}, data interface{}) (EventType, *events.Event, error)
- type EventType
- type Events
- type Payload
- type State
- type StateMachine
- func (sm *StateMachine) AssignProvider(provider models.Provider) *StateMachine
- func (sm *StateMachine) ResetState()
- func (sm *StateMachine) SendEvent(ctx context.Context, eventType EventType, payload interface{}) (*events.Event, error)
- func (sm *StateMachine) Start(ctx context.Context, machinectx interface{}, log logger.Handler, ...) (*events.Event, error)
- type StateType
- type States
Constants ¶
View Source
const ( ErrInvalidTransitionCode = "1541" ErrInvalidTransitionEventCode = "1542" ErrInititalizeK8sMachineCode = "1543" ErrAssetMachineCtxCode = "1544" ErrInvalidTypeCode = "1551" )
View Source
const ( Discovery EventType = "discovery" Register EventType = "register" Connect EventType = "connect" Disconnect EventType = "disconnect" Ignore EventType = "ignore" NotFound EventType = "not found" Delete EventType = "delete" NoOp EventType = "noop" Exit EventType = "exit" DISCOVERED StateType = "discovered" REGISTERED StateType = "registered" CONNECTED StateType = "connected" IGNORED StateType = "ignored" MAINTENANCE StateType = "maintenance" DISCONNECTED StateType = "disconnected" DELETED StateType = "deleted" NOTFOUND StateType = "not found" Init EventType = "initialize" )
Variables ¶
This section is empty.
Functions ¶
func ErrAssertMachineCtx ¶
func ErrInvalidTransition ¶
func ErrInvalidType ¶
Types ¶
type Action ¶
type Action interface { // Used as guards/prerequisites checks and actions to be performed when the machine enters a given state. ExecuteOnEntry(context context.Context, machinectx interface{}, data interface{}) (EventType, *events.Event, error) Execute(context context.Context, machinectx interface{}, data interface{}) (EventType, *events.Event, error) // Used for cleanup actions to perform when the machine exits a given state ExecuteOnExit(context context.Context, machinectx interface{}, data interface{}) (EventType, *events.Event, error) }
Action to be executed in a given state.
type ConnectionToStateMachineInstanceTracker ¶
type ConnectionToStateMachineInstanceTracker struct { ConnectToInstanceMap map[uuid.UUID]*StateMachine // contains filtered or unexported fields }
func (*ConnectionToStateMachineInstanceTracker) Add ¶
func (smt *ConnectionToStateMachineInstanceTracker) Add(id uuid.UUID, inst *StateMachine)
func (*ConnectionToStateMachineInstanceTracker) Get ¶
func (smt *ConnectionToStateMachineInstanceTracker) Get(id uuid.UUID) (*StateMachine, bool)
func (*ConnectionToStateMachineInstanceTracker) Remove ¶
func (smt *ConnectionToStateMachineInstanceTracker) Remove(id uuid.UUID)
type DefaultConnectAction ¶
type DefaultConnectAction struct{}
func (*DefaultConnectAction) ExecuteOnEntry ¶
func (*DefaultConnectAction) ExecuteOnExit ¶
type Payload ¶
type Payload struct { Connection connections.Connection Credential models.Credential }
type State ¶
func Disconnected ¶
func Disconnected() State
func Discovered ¶
func Discovered() State
func Registered ¶
func Registered() State
func (*State) RegisterAction ¶
type StateMachine ¶
type StateMachine struct { // ID to trace the events originated from the machine, also used in logs ID uuid.UUID UserID uuid.UUID // Given name for the machine, used in logs to track issues Name string // Configuration of states managed by the machine States States // Represent the previous state of the machine PreviousState StateType // The current state of the machine CurrentState StateType // The initial state at which machine gets initialized InitialState StateType // Machine specific parameters/context. // Provided at initialization of the machine. Context interface{} Log logger.Handler Provider models.Provider // contains filtered or unexported fields }
func (*StateMachine) AssignProvider ¶
func (sm *StateMachine) AssignProvider(provider models.Provider) *StateMachine
func (*StateMachine) ResetState ¶
func (sm *StateMachine) ResetState()
func (*StateMachine) SendEvent ¶
func (sm *StateMachine) SendEvent(ctx context.Context, eventType EventType, payload interface{}) (*events.Event, error)
Returns events.Event and error. The func invoking the SendEvent should handle the error and publish the event. wherever possible use the userID and systemID from context as the events can be created from other comps or actors and not only user actors. In cases when the event is received as part of some other event and not explicitly created by an actor, use the useID and systemID of the actor who initially invoked the machine.
Source Files ¶
Click to show internal directories.
Click to hide internal directories.