@clipboard-health/rules-engine
A pure functional rules engine to keep logic-dense code simple, reliable, understandable, and explainable.
The engine uses static rules created in code instead of dynamic rules serialized to a database since we haven't needed the latter yet.
Table of contents
Install
npm install @clipboard-health/rules-engine
Usage
import {
all,
appendOutput,
firstMatch,
type Rule,
type RuleContext,
} from "@clipboard-health/rules-engine";
interface Input {
number1: number;
number2: number;
}
interface Output {
result: number;
}
const exampleContext: RuleContext<Input, Output> = {
input: {
number1: 2,
number2: 5,
},
output: [],
};
const addNumbersIfPositiveRule: Rule<Input, Output> = {
runIf: (input) => input.number1 > 0 && input.number2 > 0,
run: (context) => {
const { number1, number2 } = context.input;
const sum = number1 + number2;
return appendOutput(context, { result: sum });
},
};
const multiplyNumbersIfPositiveRule: Rule<Input, Output> = {
runIf: (input) => input.number1 > 0 && input.number2 > 0,
run: (context) => {
const { number1, number2 } = context.input;
const sum = number1 * number2;
return appendOutput(context, { result: sum });
},
};
const divideNumbersIfNegative: Rule<Input, Output> = {
runIf: (input) => input.number1 < 0 && input.number2 < 0,
run: (context) => {
const { number1, number2 } = context.input;
const sum = number1 * number2;
return appendOutput(context, { result: sum });
},
};
const allResult = all(
addNumbersIfPositiveRule,
divideNumbersIfNegative,
multiplyNumbersIfPositiveRule,
).run(exampleContext);
console.log(allResult.output);
const firstMatchResult = firstMatch(
divideNumbersIfNegative,
addNumbersIfPositiveRule,
multiplyNumbersIfPositiveRule,
).run(exampleContext);
console.log(firstMatchResult.output);
Local development commands
See package.json
scripts
for a list of commands.