Documentation ¶
Index ¶
- Constants
- Variables
- func GenerateURL(subPath string, m *Machine) (URL *url.URL, err error)
- type BackendChan
- type BackendData
- type BackendInChan
- type BackendOutChan
- type BasicMessage
- type Email
- type Event
- func (e Event) Answers(status *agency.Question) bool
- func (e Event) ExecLua(content string, a ...string) (out string, ok bool)
- func (e Event) String() string
- func (e Event) Triggers(status *agency.ProtocolStatus) bool
- func (e Event) TriggersByBackendData(data *BackendData) bool
- func (e Event) TriggersByHook() bool
- type EventData
- type Hook
- type Issuing
- type Machine
- func (m *Machine) Answers(q *agency.Question) *Transition
- func (m *Machine) CurrentState() *State
- func (m *Machine) InitLua()
- func (m *Machine) Initialize() (err error)
- func (m *Machine) Start(termChan TerminateOutChan) []*Event
- func (m *Machine) Step(t *Transition)
- func (m *Machine) String() string
- func (m *Machine) Triggers(status *agency.ProtocolStatus) *Transition
- func (m *Machine) TriggersByBackendData(data *BackendData) *Transition
- func (m *Machine) TriggersByHook() *Transition
- type MachineData
- type MachineType
- type NotificationType
- type Proof
- type ProofAttr
- type State
- type TerminateChan
- type TerminateInChan
- type TerminateOutChan
- type Transition
- func (t *Transition) BuildSendAnswers(status *agency.AgentStatus) []*Event
- func (t *Transition) BuildSendEvents(status *agency.ProtocolStatus) []*Event
- func (t *Transition) BuildSendEventsFromBackendData(data *BackendData) []*Event
- func (t *Transition) BuildSendEventsFromHook(hookData map[string]string) []*Event
- func (t *Transition) FmtFromMem(send *Event) string
- func (t *Transition) GenPIN(_ *Event)
Constants ¶
const ( // Executes Lua script that can access to machines memory and which must // return true/false if trigger can be executed. TriggerTypeLua = "LUA" // monitors how our proof/issue protocol goes TriggerTypeOurMessage = "OUR_STATUS" // used just for echo/forward TriggerTypeUseInput = "INPUT" // saves input data to event that we can use it, data tells the name of // memory slot TriggerTypeUseInputSave = "INPUT_SAVE" // formates input data with then format string which is in send data TriggerTypeFormat = "FORMAT" // formates send event where data is themplate and every memory map value // are available. See exmaples for more information. TriggerTypeFormatFromMem = "FORMAT_MEM" // helps to generate a PIN code to send e.g. email (endpoint not yet // supported). TriggerTypePIN = "GEN_PIN" // quides to use send events `data` as is. TriggerTypeData = "" // these three validate 'operations' compare input data to send data TriggerTypeValidateInputEqual = "INPUT_VALIDATE_EQUAL" TriggerTypeValidateInputNotEqual = "INPUT_VALIDATE_NOT_EQUAL" TriggerTypeInputEqual = "INPUT_EQUAL" // these two need other states to help them (in production). The previous // states decide to which of these the FSM transits. // accept and stores present proof values and stores them to FSM memory map TriggerTypeAcceptAndInputValues = "ACCEPT_AND_INPUT_VALUES" // not accept present proof protocol TriggerTypeNotAcceptValues = "NOT_ACCEPT_VALUES" )
We cannot (atleast yet) to use JSON enum type like MachineType, because we have used different naming like snake_case, etc. maybe refactor later, or migrate old FSM files?
const ( // these are Aries DIDComm protocols MessageNone = "" MessageBasicMessage = "basic_message" MessageIssueCred = "issue_cred" MessageTrustPing = "trust_ping" MessagePresentProof = "present_proof" MessageConnection = "connection" MessageAnswer = "answer" MessageEmail = "email" // not supported yet MessageHook = "hook" // internal program call back // these are internal messages send between Backend (service) FSM and // conversation (pairwise connection) FSM MessageBackend = "backend" )
const ( EmailProtocol = 100 QAProtocol = 101 HookProtocol = 102 BackendProtocol = 103 // see MessageBackend )
const ( // register names for communication thru machine's memory map. LUA_INPUT = "INPUT" // current incoming data like basic_message.content LUA_OUTPUT = "OUTPUT" // lua scripts output register name LUA_OK = "OK" // lua scripts OK return value LUA_ALL_OK = "" // lua scripts return values are OK LUA_ERROR = "ERR" // lua scripts key for error message )
const ( REG_MEMORY = "MEM" REG_DB = "DB" REG_PROCESS = "PROC" )
------ lua stuff ------
const ( MachineTypeNone = 0 MachineTypeConversation = 1 + iota MachineTypeBackend )
Variables ¶
var ProtocolType = map[string]agency.Protocol_Type{ MessageNone: agency.Protocol_NONE, MessageConnection: agency.Protocol_DIDEXCHANGE, MessageIssueCred: agency.Protocol_ISSUE_CREDENTIAL, MessagePresentProof: agency.Protocol_PRESENT_PROOF, MessageTrustPing: agency.Protocol_TRUST_PING, MessageBasicMessage: agency.Protocol_BASIC_MESSAGE, MessageEmail: EmailProtocol, MessageAnswer: QAProtocol, MessageHook: HookProtocol, MessageBackend: BackendProtocol, }
var QuestionTypeID = map[string]agency.Question_Type{ "ANSWER_NEEDED_PING": agency.Question_PING_WAITS, "ANSWER_NEEDED_ISSUE_PROPOSE": agency.Question_ISSUE_PROPOSE_WAITS, "ANSWER_NEEDED_PROOF_PROPOSE": agency.Question_PROOF_PROPOSE_WAITS, "ANSWER_NEEDED_PROOF_VERIFY": agency.Question_PROOF_VERIFY_WAITS, }
Functions ¶
Types ¶
type BackendChan ¶ added in v0.2.19
type BackendChan = chan *BackendData
type BackendData ¶ added in v0.2.19
type BackendData struct { // these two are the header part ToConnID string // backend/service FSM, should it have a UUID? maybe? Protocol string FromConnID string // this is something that might not be exist // for the start we have only string content, but maybe later.. // see the EventData Subject string // this could be used for the chat room, // todo: but who should know it, i.e. keep track of the room Content string }
type BackendInChan ¶ added in v0.2.19
type BackendInChan = <-chan *BackendData
type BackendOutChan ¶ added in v0.2.19
type BackendOutChan = chan<- *BackendData
type BasicMessage ¶
type BasicMessage struct {
Content string
}
type Event ¶
type Event struct { // These both are string versions to make writing the yaml fsm easier. // There parser methdod, Initialize() that must be call to make the machine // to work. It also make other syntax checks. // NOTE. Don't use this here at code level, use ProtocolType! Protocol string `json:"protocol"` // Note! See ProtocolType below TypeID string `json:"type_id"` // Note! See NotificationType below Rule string `json:"rule"` Data string `json:"data,omitempty"` // Deprecated: replaced by WantStatus, left to keep file format NoStatus bool `json:"no_status,omitempty"` // Tells that we want status updates about our sending, this is calculated // automatically WantStatus bool `json:"want_status,omitempty"` *EventData `json:"event_data,omitempty"` ProtocolType agency.Protocol_Type `json:"-"` NotificationType NotificationType `json:"-"` *agency.ProtocolStatus `json:"-"` *Transition `json:"-"` *BackendData `json:"-"` }
func (Event) TriggersByBackendData ¶ added in v0.2.19
func (e Event) TriggersByBackendData(data *BackendData) bool
func (Event) TriggersByHook ¶
type EventData ¶
type EventData struct { BasicMessage *BasicMessage `json:"basic_message,omitempty"` Issuing *Issuing `json:"issuing,omitempty"` Email *Email `json:"email,omitempty"` Proof *Proof `json:"proof,omitempty"` Hook *Hook `json:"hook,omitempty"` Backend *BackendData `json:"backend,omitempty"` }
type Machine ¶
type Machine struct { // Tells do we have a Backend (Service) bot or a connection lvl bot Type MachineType `json:"type,omitempty"` Name string `json:"name,omitempty"` KeepMemory bool `json:"keep_memory,omitempty"` // marks the start state: there can be only one for the Machine, but there // can be 0..n termination states. See State.Terminate field. Initial *Transition `json:"initial"` States map[string]*State `json:"states"` Current string `json:"-"` Initialized bool `json:"-"` Memory map[string]string `json:"-"` // contains filtered or unexported fields }
func NewMachine ¶
func NewMachine(data MachineData) *Machine
func (*Machine) CurrentState ¶
func (*Machine) Initialize ¶
Initialize initializes and optimizes the state machine because the JSON is meant for humans to write and machines to read. Initialize also moves machine to the initial state. It returns error if machine has them.
func (*Machine) Start ¶
func (m *Machine) Start(termChan TerminateOutChan) []*Event
Start starts the FSM. It takes termination channel as an argument to be able to signaling outside when machine is stoped. It accept nil as a channel value when signaling isn't done.
func (*Machine) Step ¶
func (m *Machine) Step(t *Transition)
func (*Machine) Triggers ¶
func (m *Machine) Triggers(status *agency.ProtocolStatus) *Transition
Triggers returns a transition if machine has it in its current state. If not it returns nil.
func (*Machine) TriggersByBackendData ¶ added in v0.2.19
func (m *Machine) TriggersByBackendData(data *BackendData) *Transition
func (*Machine) TriggersByHook ¶
func (m *Machine) TriggersByHook() *Transition
TriggersByHook returns a transition if machine has it in its current state. If not it returns nil.
type MachineData ¶
func (*MachineData) IsValid ¶ added in v0.2.20
func (md *MachineData) IsValid() bool
type MachineType ¶ added in v0.2.19
type MachineType int
func ParseMachineType ¶ added in v0.2.19
func ParseMachineType(s string) (mt MachineType, err error)
func (*MachineType) MarshalJSON ¶ added in v0.2.19
func (mt *MachineType) MarshalJSON() ([]byte, error)
func (MachineType) String ¶ added in v0.2.19
func (mt MachineType) String() string
func (*MachineType) UnmarshalJSON ¶ added in v0.2.19
func (mt *MachineType) UnmarshalJSON(data []byte) (err error)
type NotificationType ¶
type NotificationType int32
func NotificationTypeID ¶
func NotificationTypeID(typeName string) NotificationType
type State ¶
type State struct { Transitions []*Transition `json:"transitions"` Terminate bool `json:"terminate,omitempty"` }
type TerminateChan ¶ added in v0.2.5
type TerminateChan = chan bool
type TerminateInChan ¶ added in v0.2.5
type TerminateInChan = <-chan bool
type TerminateOutChan ¶ added in v0.2.5
type TerminateOutChan = chan<- bool
type Transition ¶
type Transition struct { Trigger *Event `json:"trigger,omitempty"` Sends []*Event `json:"sends,omitempty"` Target string `json:"target"` Machine *Machine `json:"-"` }
func (*Transition) BuildSendAnswers ¶
func (t *Transition) BuildSendAnswers(status *agency.AgentStatus) []*Event
func (*Transition) BuildSendEvents ¶
func (t *Transition) BuildSendEvents(status *agency.ProtocolStatus) []*Event
func (*Transition) BuildSendEventsFromBackendData ¶ added in v0.2.19
func (t *Transition) BuildSendEventsFromBackendData(data *BackendData) []*Event
func (*Transition) BuildSendEventsFromHook ¶
func (t *Transition) BuildSendEventsFromHook(hookData map[string]string) []*Event
func (*Transition) FmtFromMem ¶
func (t *Transition) FmtFromMem(send *Event) string
func (*Transition) GenPIN ¶
func (t *Transition) GenPIN(_ *Event)