FlowForge 1.0.0

dotnet add package FlowForge --version 1.0.0
                    
NuGet\Install-Package FlowForge -Version 1.0.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FlowForge" Version="1.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="FlowForge" Version="1.0.0" />
                    
Directory.Packages.props
<PackageReference Include="FlowForge" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add FlowForge --version 1.0.0
                    
#r "nuget: FlowForge, 1.0.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package FlowForge@1.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=FlowForge&version=1.0.0
                    
Install as a Cake Addin
#tool nuget:?package=FlowForge&version=1.0.0
                    
Install as a Cake Tool

FlowForge

FlowForge is a dynamic and extensible workflow engine designed to simplify and automate complex processes. Built with flexibility and scalability in mind, FlowForge allows developers to define, manage, and execute workflows seamlessly. Whether you're orchestrating business logic, automating processes, or handling asynchronous events, FlowForge provides the tools you need to forge workflows into efficient, reliable systems.


Features

  • Dynamic Workflow Definitions
    Define workflows using JSON, YAML, or a fluent API builder, giving you flexibility in how you model your processes.

  • Parallel and Sequential Execution
    Supports sequential steps, parallel execution, and synchronization of tasks.

  • Event-Driven Architecture
    Trigger workflows and transitions based on custom events, ensuring responsiveness to external inputs.

  • OnEnter and OnExit Actions
    Execute customizable actions on entering or exiting a state, including:

    • Webhook calls
    • Timer-based delays
    • Custom behaviors
  • Pluggable Components
    Integrates easily with your infrastructure:

    • Databases: Supports PostgreSQL, MongoDB, SQL Server, etc.
    • Queues: RabbitMQ, Kafka, or custom implementations.
  • Built-in Scheduler
    Add delays or schedule transitions at specific times.

  • State Management
    Track workflow progress and transitions with detailed event logs for auditing and debugging.

  • Assignment Rules
    Assign users or groups to states, ensuring only authorized actors can trigger transitions.

  • Extensible Action System
    Register custom actions for bespoke behavior, allowing seamless integration with your existing systems.

  • Visualization Tools
    Generate Mermaid diagrams directly from workflow definitions for easy visualization and debugging.


Installation

Install the core FlowForge package via NuGet:

dotnet add package FlowForge

To integrate specific modules (e.g. PostgreSQL or RabbitMQ):

dotnet add package FlowForge.PostgreSQL
dotnet add package FlowForge.RabbitMQ

Getting Started

1. Define a Workflow

You can define workflows using JSON or the provided fluent builder.

Using the Fluent Builder:

var workflow = new WorkflowDefinitionBuilder("Sample Workflow")
    .Start(s => s
        .OnEnter(new WebhookAction("http://example.com/start"))
    )
    .Delay(TimeSpan.FromMinutes(5))
    .ActionableStep("Approval", s => s
        .AssignGroup("managers")
        .OnEnter(new WebhookAction("http://example.com/approval"))
        .Transition("event == \"Approved\"")
        .Transition("event == \"Declined\"", "Start")
    )
    .End();

2. Register the Workflow

await workflowEngine.RegisterWorkflowAsync(workflow);

3. Start a Workflow instance

var instanceId = await workflowEngine.StartWorkflowAsync(workflowId, new Dictionary<string, object>
{
    { "initialData", "example" }
});

4. Trigger Events

await workflowEngine.TriggerEventAsync(instanceId, "Approved", new Dictionary<string, object>
{
    { "reviewer", "admin" }
});

5. Visualize the Workflow

Use the Mermaid Diagram Generator to create visual representations of your workflows:

var diagram = workflowEngine.GenerateMermaidDiagram(workflowDefinition);
Console.WriteLine(diagram);

Modules

FlowForge is modula, allowing you to select the components that best fit your infrastructure:

Database Modules
  • PostgreSQL: FlowForge.PostgreSQL
  • MongoDB: FlowForge.MongoDB (coming soon)
Event Queue Modules
  • RabbitMQ: FlowForge.RabbitMQ
  • Kafka: FlowForge.Kafka (coming soon)

Example Configuration

In your Program.cs:

builder.Services.AddWorkflowEngine(options =>
{
    options.EnableDetailedLogging = true;
})
.UsePostgresql("Host=localhost;Database=workflow;Username=postgres;Password=password")
.UseRabbitMQ("localhost", "workflow-queue");

Why Choose FlowForge?

  1. Flexibility: Support for a variety of databases, event queues, and custom actions.
  2. Extensibility: Easily add new modules or integrations.
  3. User-Friendly: Fluent APIs, YAML support, and visualization tools make workflows easy to define and manage.
  4. Performance: Designed to handle high-throughput and complex workflows with ease.

Contributing

We welcome contributions to FlowForge! If you'd like to contribute, please follow these steps:

  1. Fork the repository.
  2. Create a feature branch: git checkout -b feature-name.
  3. Commit your changes: git commit -m 'Add feature'.
  4. Push to the branch: git push origin feature-name.
  5. Submit a pull request.

License

FlowForge is licensed under the MIT License.


Feedback and Support

If you encounter issues or have feature requests, please open an issue in the Github repository. For questions or feedback, feel free to contact me directly at justinlovelessx@gmail.com.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on FlowForge:

Package Downloads
FlowForge.Mermaid

Enable generating mermaid diagrams from FlowForge workflows

FlowForge.Postgresql

Package Description

FlowForge.RabbitMQ

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.0 197 1/1/2025
0.1.0-alpha-gbbe6a38e20 136 1/1/2025
0.1.0-alpha-ga7e146e2d3 142 1/1/2025
0.1.0-alpha-g8585bcceea 135 1/1/2025
0.1.0-alpha-g24c32358cc 139 1/1/2025
0.1.0-alpha-g207bb190a1 128 1/1/2025
0.0.1 176 1/1/2025
0.0.1-gf09ab8942f 170 1/1/2025
0.0.1-gdce4eca7c3 170 1/1/2025
0.0.1-g9647f888ee 174 1/1/2025