-
Notifications
You must be signed in to change notification settings - Fork 207
Home
Jesus Ruiz edited this page Jan 19, 2014
·
9 revisions
Durable Rules provides real-time, consistent and scalable coordination of events. With Durable Rules you can track and analyze information about things that happen (events) by combining data from multiple sources to infer more complicated circumstances.
A forward chaining algorithm (A.K.A. Rete) is used to evaluate massive streams of data. A simple, yet powerful meta-liguistic abstraction lets define simple and complex rulesets. Below is an example on how easy it is to define a couple of rules that act on incoming web messages.
var d = require('durable');
d.run({
approve: {
r1: {
when: { $lt: { amount: 1000 } },
run: function(s) { s.status = 'pending' }
},
r2: {
whenAll: {
$m: { subject: 'approved' },
$s: { status: 'pending' }
},
run: function(s) { console.log('approved'); }
}
}
});
Durable Rules relies on state of the art technologies:
- Node.js is used as the host. This allows leveraging the vast amount of available libraries.
- Inference state is cached using Redis, which lets scaling out without giving up performance.
- A web client based on D3.js provides powerful data visualization and test tools.
To learn more:
- [Setup] (http://www.github.com/jruizgit/rules/wiki/setup)
- [Tutorial] (http://www.github.com/jruizgit/rules/wiki/tutorial)
- [Concepts] (http://www.github.com/jruizgit/rules/wiki/concepts)