Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/DeanCording/node-red-contrib-state-machine
A Node Red node that wraps around Javascript State Machine
https://github.com/DeanCording/node-red-contrib-state-machine
node-red
Last synced: 3 months ago
JSON representation
A Node Red node that wraps around Javascript State Machine
- Host: GitHub
- URL: https://github.com/DeanCording/node-red-contrib-state-machine
- Owner: DeanCording
- License: other
- Created: 2018-01-06T00:18:46.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-01-05T17:22:56.000Z (almost 4 years ago)
- Last Synced: 2024-07-22T05:06:11.212Z (4 months ago)
- Topics: node-red
- Language: HTML
- Size: 11.7 KB
- Stars: 17
- Watchers: 6
- Forks: 14
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-nodered - state-machine - Wraps around the JavaScript State Machine to implement a finite state machine. (Nodes / Utility)
README
# node-red-contrib-state-machine
A Node Red node that wraps around the [Javascript State Machine](https://www.npmjs.com/package/javascript-state-machine) to implement a [finite state machine](https://en.wikipedia.org/wiki/Finite-state_machine) for Node Red.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.