Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 17287a9ba3 | |||
| 11921a2864 | |||
| 9035fafdc2 | |||
| 773ae00517 | |||
| e67fbfebf6 | |||
| b2478d79f2 | |||
| 917e630554 | |||
| b3b02fee70 | |||
| 8c257bc0fd | |||
| a4ff5c26e2 |
2
package-lock.json
generated
2
package-lock.json
generated
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@pushrocks/smartrule",
|
||||
"version": "1.0.4",
|
||||
"version": "1.0.9",
|
||||
"lockfileVersion": 1,
|
||||
"requires": true,
|
||||
"dependencies": {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@pushrocks/smartrule",
|
||||
"version": "1.0.4",
|
||||
"version": "1.0.9",
|
||||
"private": false,
|
||||
"description": "a smart rule library for handling decision trees.",
|
||||
"main": "dist/index.js",
|
||||
|
||||
@@ -11,7 +11,7 @@ let testSmartruleInstance: smartrule.SmartRule<ITestMessage>;
|
||||
tap.test('first test', async () => {
|
||||
testSmartruleInstance = new smartrule.SmartRule<ITestMessage>();
|
||||
testSmartruleInstance.createRule(
|
||||
0,
|
||||
2,
|
||||
async messageArg => {
|
||||
if (messageArg.body.startsWith('hello')) {
|
||||
return 'apply-stop';
|
||||
|
||||
@@ -26,34 +26,41 @@ export class SmartRule<T> {
|
||||
};
|
||||
|
||||
// lets run the checks
|
||||
const runNextBatch = async (startPriority: number) => {
|
||||
const nextBatch = getNextParallelBatch(0);
|
||||
const runNextBatch = async (startPriority: number, runRulesAmount: number): Promise<void> => {
|
||||
const nextBatch = getNextParallelBatch(startPriority);
|
||||
runRulesAmount = runRulesAmount + nextBatch.length;
|
||||
const outcomes: TTreeActionResult[] = [];
|
||||
for (const rule of nextBatch) {
|
||||
const checkResult = await rule.checkFunction(objectArg);
|
||||
checkResult ? null : console.log('WARNING!!! Please make sure your rule always returns a statement of how to continue!');
|
||||
|
||||
if (checkResult.startsWith("apply")) {
|
||||
await rule.actionFunction(objectArg);
|
||||
await rule.actionFunction(objectArg); // here the action function is run
|
||||
}
|
||||
outcomes.push(checkResult);
|
||||
};
|
||||
|
||||
const finalOutcome: TTreeActionResult = outcomes.reduce((previous, current, index, array) => {
|
||||
if (current.includes('continue') || previous.includes('continue')) {
|
||||
return 'continue';
|
||||
} else {
|
||||
return 'stop';
|
||||
}
|
||||
});
|
||||
if (finalOutcome === 'stop') {
|
||||
return;
|
||||
}
|
||||
|
||||
if (startPriority < this.rules[this.rules.length-1].priority) {
|
||||
runNextBatch(startPriority++);
|
||||
if (outcomes.length > 0) {
|
||||
const finalOutcomeOfBatch: TTreeActionResult = outcomes.reduce((previous, current, index, array) => {
|
||||
if (current.includes('continue') || previous.includes('continue')) {
|
||||
return 'continue';
|
||||
} else {
|
||||
return 'stop';
|
||||
}
|
||||
});
|
||||
if (finalOutcomeOfBatch === 'stop') {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (runRulesAmount < this.rules.length) {
|
||||
await runNextBatch((startPriority + 1), runRulesAmount);
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
};
|
||||
|
||||
await runNextBatch(0);
|
||||
await runNextBatch(0,0);
|
||||
}
|
||||
|
||||
public createRule(priorityArg: number, checkFunctionArg: TCheckFunc<T>, actionFunctionArg: TActionFunc) {
|
||||
|
||||
Reference in New Issue
Block a user