Skip to content

joelmoses/node-red-contrib-persistent-fsm

 
 

Repository files navigation

node-red-contrib-persistent-fsm

A Node-Red node that wraps around the Javascript State Machine to implement a finite state machine for Node-Red.

Combintation of DeanCording's and lutzer's similar libraries with the following notable changes:

  • State can optionally persist during re-deployment of nodes.
  • Deprecated Node-RED events have been replaced.
  • Invalid transition error includes details of request.
  • Excellent input UI from DeanCording combined with simple graphical rendering from lutzer. Best of both worlds.

Usage

The node is configured with a number of states and triggers that will cause the node to transition from one state to another. At any time, the node can only be in one of the defined states and it will only transition to another state when it receives a trigger defined for the current state. The same trigger can be used to cause transitions from more than one state.

Triggers that are not valid for the current state can either be ignored or cause an error to be throw that can be caught by a Catch node.

The node will always start in the first state on the state list and will emit a message with the initial state if the state output is set to a message property.

Global and flow context properties can be used as trigger inputs but state transitions will only occur when the node receives a message.

The current state can be set to a msg property or stored as a flow or global context property. If the state output is set to a msg property, that property is set in the original message and passed through, otherwise no messages are output.

About

A Node Red node that wraps around Javascript State Machine

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • HTML 58.6%
  • JavaScript 41.4%