This project is open-sourced under MIT license.
This REST API service provides for awards, points, redemptions, badges....
This service is designed to support generic workflows for awards, badges and multiple gamification scenarios. Following is a brief overview of the internals of the service.
Service contains 3 main areas.
- Schema Engine - A generic workflow engine
- Domain specific facts data handler
- Exernal event handling module - currently listening on webhook to defined types of events.
The schema engine is the most generic module in the service and can be re-used as a module in multiple scenarios.
- Client admins/moderators can define the workflow to mimic the logic of gamification.
- Each workflow is represented by workflow schema.
- Each schema can be constructed as series of nodes connected by paths. Each node represents a state/step in the workflow.
- A node can be of type 'Execution node' or 'Rule Node'.
- A 'Execution node' contains an action which represents some action to be performed as a step in the workflow. After execution of the action, the control moves to the next node in the schema.
- A 'Rule node' contains a rule to be executed and results in the passing or failing status. Based on the rule execution status, the workflow can change the paths in the workflow.
- Each rule contains a tree structure of conditions to be evaluated against the set of facts.
- These facts could be -- input parameters fed to the schema at the start or -- can be result/output of the execution of the action of the 'execution node'.
- The conditions which are part of the rule can have following types of the operators - -- composite (e.g. AND, OR, XOR) -- logical (e.g. EQUALS, NOT_EQUALS, GREATER_THAN,....and many more)
- The schema is instanced for a given context. For example, in case of the awards or gamifications, the context can be a participant or a participant group.
- Based on the use-cases, the schema instances can be of 2 types. -- Long running schema instance : This schema instance can wait on a current node for certain types of events or rule to be satisfied before proceeding ahead. An example of this could be an emergency healthcare protocol or certain award point schema which is dependent on multiple events. -- Event based schema instance : For every type of the supported event, a new instance of the schema is generated and executed by the engine. An example of this could be consistency badge awards schema.
This module basically pulls in the facts from the event as well as facts database and feeds them into schema instance. The interfaces are quite generic but the implementation of this is governed by the entities defined in the facts database. The facts database is generally populated and maintained by the client app/service.
This is a typical webhook which listens to the predefined events (which can be of custom types and created by the schema content moderators). The supported event will trigger execution of the schema instance for the given context. So each event payload must contain context identifier (which is generally called as 'reference id') apart from other event specific parameters. This reference id could be an 'id' of the participant in the exernal client system.
Please have a look at the following schematic depicting the internals of the awards service.
The following are workflow schema examples.
A schema containing only execution nodes.
A blood pressure management schema containing both rule and execution nodes.
Following schematic depicts the relation between a rule and children conditions.
We encourage forking and welcome contributions to this code base.