WorkflowForge.Extensions.DependencyInjection
2.0.0
See the version list below for details.
dotnet add package WorkflowForge.Extensions.DependencyInjection --version 2.0.0
NuGet\Install-Package WorkflowForge.Extensions.DependencyInjection -Version 2.0.0
<PackageReference Include="WorkflowForge.Extensions.DependencyInjection" Version="2.0.0" />
<PackageVersion Include="WorkflowForge.Extensions.DependencyInjection" Version="2.0.0" />
<PackageReference Include="WorkflowForge.Extensions.DependencyInjection" />
paket add WorkflowForge.Extensions.DependencyInjection --version 2.0.0
#r "nuget: WorkflowForge.Extensions.DependencyInjection, 2.0.0"
#:package WorkflowForge.Extensions.DependencyInjection@2.0.0
#addin nuget:?package=WorkflowForge.Extensions.DependencyInjection&version=2.0.0
#tool nuget:?package=WorkflowForge.Extensions.DependencyInjection&version=2.0.0
WorkflowForge.Extensions.DependencyInjection
Microsoft.Extensions.DependencyInjection integration for WorkflowForge
This extension provides seamless integration with Microsoft's dependency injection container, enabling:
- IOptions<T> pattern support
- Automatic configuration validation on startup
- ASP.NET Core integration
- Configuration binding from appsettings.json
📦 Installation
dotnet add package WorkflowForge.Extensions.DependencyInjection
Note: This package is optional. WorkflowForge core has zero dependencies and can be used standalone.
🚀 Quick Start
ASP.NET Core
// Program.cs or Startup.cs
public void ConfigureServices(IServiceCollection services)
{
// Register logger (choose your implementation)
services.AddSingleton<IWorkflowForgeLogger>(sp =>
SerilogExtensions.CreateWorkflowForgeLogger());
// Register WorkflowForge with configuration binding
services.AddWorkflowForge(Configuration);
// Register WorkflowSmith
services.AddWorkflowSmith();
}
appsettings.json
{
"WorkflowForge": {
"MaxConcurrentWorkflows": 2,
"ContinueOnError": false,
"FailFastCompensation": false,
"ThrowOnCompensationError": false,
"EnableOutputChaining": true,
"Middleware": {
"Timing": {
"Enabled": true,
"IncludeDetailedTimings": false
},
"Logging": {
"Enabled": true,
"MinimumLevel": "Information",
"LogDataPayloads": false
},
"ErrorHandling": {
"Enabled": true,
"RethrowExceptions": true,
"IncludeStackTraces": true
}
}
}
}
Usage in Controllers/Services
public class WorkflowService
{
private readonly IWorkflowSmith _smith;
private readonly IOptions<TimingMiddlewareOptions> _timingOptions;
public WorkflowService(
IWorkflowSmith smith,
IOptions<TimingMiddlewareOptions> timingOptions)
{
_smith = smith;
_timingOptions = timingOptions;
}
public async Task ExecuteWorkflow()
{
var workflow = new MyWorkflow();
await _smith.ForgeAsync(workflow);
}
}
🔧 Manual Configuration
If you don't use appsettings.json, you can configure options manually:
services.AddWorkflowForge(
core =>
{
core.MaxConcurrentWorkflows = 2;
core.ContinueOnError = false;
core.EnableOutputChaining = true;
},
timing => timing.Enabled = false,
logging => logging.MinimumLevel = "Warning",
errorHandling => errorHandling.IncludeStackTraces = false
);
✅ Automatic Validation
This extension validates configuration on startup using the Validate() methods from options classes
and registers IValidateOptions<WorkflowForgeOptions> for startup-time checks:
// This will throw on startup if configuration is invalid
services.AddWorkflowForge(configuration);
// Invalid configuration example:
{
"WorkflowForge": {
"MaxConcurrentWorkflows": -5, // ❌ Throws: Must be between 0 and 10000
"Middleware": {
"Logging": {
"MinimumLevel": "Verbose" // ❌ Throws: Must be Trace/Debug/Information/Warning/Error/Critical
}
}
}
}
Validation errors are caught at startup, not at runtime!
📚 API Reference
AddWorkflowForge(IConfiguration)
Binds configuration from appsettings.json and validates.
services.AddWorkflowForge(Configuration);
AddWorkflowForge(Actions)
Manually configure options.
services.AddWorkflowForge(
core => { /* ... */ },
timing => { /* ... */ },
logging => { /* ... */ },
errorHandling => { /* ... */ }
);
AddWorkflowSmith()
Registers IWorkflowSmith as a singleton.
Requirements:
IWorkflowForgeLoggermust be registeredAddWorkflowForge()must be called first
services.AddSingleton<IWorkflowForgeLogger>(/* ... */);
services.AddWorkflowForge(Configuration);
services.AddWorkflowSmith(); // ✅ Now WorkflowSmith is available
🎯 Configuration Sections
| Section | Options Class | Validated |
|---|---|---|
WorkflowForge |
WorkflowForgeOptions |
✅ Yes |
WorkflowForge:Middleware:Timing |
TimingMiddlewareOptions |
❌ No |
WorkflowForge:Middleware:Logging |
LoggingMiddlewareOptions |
✅ Yes |
WorkflowForge:Middleware:ErrorHandling |
ErrorHandlingMiddlewareOptions |
❌ No |
🔍 Why This Extension Exists
WorkflowForge core has ZERO dependencies to avoid version conflicts when using extensions.
This extension provides optional DI integration for users who want:
- IOptions<T> pattern
- Configuration validation on startup
- ASP.NET Core integration
- appsettings.json binding
If you don't need these features, use WorkflowForge core directly!
📖 Related Packages
- WorkflowForge - Core workflow engine (zero dependencies)
- WorkflowForge.Extensions.Logging.Serilog - Serilog integration
- WorkflowForge.Extensions.Resilience.Polly - Polly resilience patterns
- WorkflowForge.Extensions.Observability.Performance - Performance metrics
📄 License
MIT License - Copyright © 2025-2026 AnimatLabs
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Options (>= 10.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.2)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.2)
- WorkflowForge (>= 2.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.