1 unstable release
new 0.0.1 | Apr 4, 2025 |
---|
#5 in #phlow
Used in phlow-runtime
110KB
2.5K
SLoC
Phlow - A Dynamic Rule-Based Workflow Engine
Phlow
is a flexible and extensible rule-based workflow engine written in Rust.
It allows users to define and execute dynamic decision trees and conditional workflows
using JSON-based configurations and embedded scripting via Rhai
.
Features
- Dynamic workflows with JSON-defined rules
- Embedded scripting with Rhai for advanced expressions
- Conditional branching with custom operators (
starts_with
,ends_with
,search
) - Step-based execution with context-aware evaluation
- Extensible engine with pluggable functions
Example: Decision Tree for Club Membership Approval
This example demonstrates a decision tree to determine if a person can become a club member.
use phlow::phlow;
use phlow::Engine;
use valu3::json;
use phlow::context::Context;
fn main() {
let decision_tree = json!({
"steps": [
{
"condition": {
"left": "params.age",
"right": 18,
"operator": "greater_than_or_equal"
},
"then": {
"steps": [
{
"condition": {
"left": "params.income",
"right": 5000.0,
"operator": "greater_than_or_equal"
},
"then": {
"return": "Approved"
},
"else": {
"return": "Rejected - Insufficient income"
}
}
]
},
"else": {
"return": "Rejected - Underage"
}
}
]
});
let engine = Engine::new();
let phlow = phlow::try_from_value(&engine, &decision_tree, None, None).unwrap();
let mut context = Context::new(Some(json!({ "age": 20, "income": 6000.0 })));
let result = phlow.execute_context(&mut context).unwrap();
println!("Decision: {:?}", result);
}
Modules
phlow
- Main structure containing pipelines and execution logic.context
- Manages execution state and variable storage.pipeline
- Defines sequential execution of processing steps.step_worker
- Handles conditional logic and step execution.script
- Integrates Rhai scripting for dynamic evaluation.engine
- Configures and extends the scripting engine.condition
- Defines logical operators and conditions.collector
- Logs execution steps and tracks workflow state.
Architecture Overview
The phlow
engine processes a workflow pipeline composed of steps. Each step can:
- Evaluate conditions (e.g., comparisons, regex matching)
- Execute scripts for computations
- Branch execution based on conditions
- Store and reference previous step outputs
Execution Flow
- The engine receives an input JSON workflow definition.
- The
phlow
instance parses and validates the workflow. - The workflow executes step-by-step, evaluating conditions and executing actions.
- The final result is returned to the caller.
Advanced Usage
Adding Custom Plugins
Users can extend phlow by adding custom functions to the execution engine:
use phlow::engine::{build_engine, Plugins, PluginFunction};
use valu3::value::Value;
use std::collections::HashMap;
use std::sync::Arc;
fn main() {
let mut plugins = HashMap::new();
let custom_function: PluginFunction = Arc::new(|value: Value| {
Value::from(format!("Processed: {}", value.to_string()))
});
plugins.insert("custom_process".to_string(), custom_function);
let engine = build_engine(Some(Plugins { plugins }));
let result: Value = engine.eval("custom_process(\"Hello\")").unwrap();
println!("Result: {:?}", result);
}
Handling Execution Errors
Errors during workflow execution are returned as Result<T, PhlowError>
:
match phlow.execute_context(&mut context) {
Ok(result) => println!("Execution succeeded: {:?}", result),
Err(err) => eprintln!("Execution failed: {:?}", err),
}
License
This project is licensed under the MIT License.
Dependencies
~25–36MB
~558K SLoC