RuleEval 1.3.0

dotnet add package RuleEval --version 1.3.0
                    
NuGet\Install-Package RuleEval -Version 1.3.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="RuleEval" Version="1.3.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="RuleEval" Version="1.3.0" />
                    
Directory.Packages.props
<PackageReference Include="RuleEval" />
                    
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 RuleEval --version 1.3.0
                    
#r "nuget: RuleEval, 1.3.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 RuleEval@1.3.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=RuleEval&version=1.3.0
                    
Install as a Cake Addin
#tool nuget:?package=RuleEval&version=1.3.0
                    
Install as a Cake Tool

RuleEval

RuleEval.Abstractions RuleEval RuleEval.DependencyInjection RuleEval.Database RuleEval.Database.DependencyInjection License: MIT

📚 Dokumentace: architecture.md · nuget-packages.md · publishing-nuget.md

Moderní open-source rule engine pro .NET 8

Obsah

Rychlý start

dotnet add package RuleEval
using RuleEval.Abstractions;
using RuleEval.Core;

var ruleSet = RuleSetBuilder
    .Create("pricing")
    .AddInput("segment")
    .AddInput("age")
    .AddRule(rule => rule
        .When("segment", ".*Perspektiva.*")
        .When("age", "INTERVAL<15;24>")
        .ThenOutput("formula", "C2/240")
        .WithPrimaryKey("id", 1))
    .Build();

var evaluator = new RuleSetEvaluator();
var result = evaluator.EvaluateFirst(
    ruleSet,
    EvaluationContext.FromPositional("7BN Perspektiva Důchod", 15m),
    new EvaluationOptions(CaptureDiagnostics: true));

Console.WriteLine(result.Status);
Console.WriteLine(result.Match?.Outputs[0].RawValue); // C2/240

Volitelná integrace s Microsoft.Extensions.DependencyInjection

using Microsoft.Extensions.DependencyInjection;
using RuleEval.DependencyInjection;

services.AddRuleEval();

EvaluationContext — pozičně nebo dle názvů

Vstupní hodnoty lze předat dvěma způsoby. Pořadí pozičních hodnot odpovídá sloupci Order definice pravidel.

// Pozičně — hodnoty ve stejném pořadí jako vstupní pole v RuleSet
var result = evaluator.EvaluateFirst(
    ruleSet,
    EvaluationContext.FromPositional("7BN Perspektiva Důchod", 15m));

// Dle názvů — nezávislé na pořadí
var result = evaluator.EvaluateFirst(
    ruleSet,
    EvaluationContext.FromNamed(new Dictionary<string, object?>
    {
        ["segment"] = "7BN Perspektiva Důchod",
        ["age"]     = 15m,
    }));

Console.WriteLine(result.Status);                        // Matched
Console.WriteLine(result.Match?.Outputs[0].RawValue);    // C2/240

Vyhodnocení z databáze

dotnet add package RuleEval.Database
dotnet add package RuleEval.Database.DependencyInjection

DB metadata stored procedure vrací sloupce (Code, ColNr, Order, Type) a datová stored procedure vrací první technický identifikátor řádku (např. TranslatorDataId) a za ním Col01, Col02, …

Metadata sloupec Popis
Code Logický/business název pole (vstup nebo výstup)
ColNr Fyzické číslo sloupce dat (Col01..Col20)
Order Pořadí pro poziční evaluaci (EvaluationContext.FromPositional)
Type 0 = Input, 1 = Output

První datový sloupec (např. TranslatorDataId) je diagnostický identifikátor – automaticky se stane MatchResult.PrimaryKey. Neovlivňuje výsledek evaluace.

Inicializace v Program.cs

using Microsoft.Data.SqlClient;
using RuleEval.Database;
using RuleEval.Database.DependencyInjection;

builder.Services.AddRuleEvalDatabase(
    sp => new SqlServerRuleSetSource(
        new AdoCommandExecutor(cs => new SqlConnection(cs)),
        builder.Configuration.GetConnectionString("RuleEval")!,
        "[dbo].[p_GetSchemaColBySchemaCode]",
        "[dbo].[p_GetDataBySchemaCode]"),
    opt => opt.DefaultCacheTtl = TimeSpan.FromMinutes(30));

Výsledkem je, že IRuleSetRepository je singleton s 30minutovou cache. Každé volání LoadAsync / EvaluateFirstAsync / GetFirstOutputAsync automaticky čte z cache; do DB se jde jen při prvním načtení nebo po invalidaci.

SQL kontrakt – metadata stored procedure

-- Vrací: Code, ColNr, Order, Type
-- Type: 0 = Input, 1 = Output
SELECT Code, ColNr, [Order], [Type]
FROM   SchemaCol
WHERE  SchemaCode = @Code
ORDER  BY [Order];

SQL kontrakt – datová stored procedure

-- První sloupec = diagnostický identifikátor (stane se PrimaryKey)
-- Následují Col01..Col20
SELECT TranslatorDataId,
       Col01, Col02, Col03, ...
FROM   Data
WHERE  SchemaCode = @Code;

Použití v business kódu

Do třídy stačí injektovat jen IRuleSetRepository — o připojení k DB, cache i TTL se stará DI konfigurace z Program.cs.

public class PricingService(IRuleSetRepository rules)
{
    // Vrátí hodnotu prvního výstupního sloupce — název sloupce nás nezajímá
    public Task<string?> GetFormulaAsync(string segment, decimal age) =>
        rules.GetFirstOutputAsync("Pricing",
            EvaluationContext.FromPositional(segment, age));

    // Vrátí hodnotu konkrétního výstupního sloupce dle názvu
    public Task<string?> GetFormulaByNameAsync(string segment, decimal age) =>
        rules.GetFirstOutputAsync("Pricing",
            EvaluationContext.FromPositional(segment, age),
            outputName: "Formula");
}

Invalidace cache

// Vyhodí konkrétní pravidlo z cache — příští volání načte z DB a uloží znovu
await repository.InvalidateCacheAsync("Pricing");

Přehled metod IRuleSetRepository

// Načte RuleSet (z cache nebo DB)
RuleSet ruleSet = await repository.LoadAsync(key);

// Výsledek evaluace
EvaluationResult result = await repository.EvaluateFirstAsync(key, context);

// Hodí výjimku při NoMatch / AmbiguousMatch / InvalidInput
EvaluationResult result = await repository.EvaluateFirstOrThrowAsync(key, context);

// Hodnota prvního výstupního sloupce (název nás nezajímá), nebo null
string? value = await repository.GetFirstOutputAsync(key, context);

// Totéž, hodí výjimku pokud pravidlo neodpovídá nebo nemá výstupy
string value = await repository.GetFirstOutputOrThrowAsync(key, context);

// Hodnota konkrétního výstupního sloupce dle názvu, nebo null
string? value = await repository.GetFirstOutputAsync(key, context, outputName: "Formula");

// Totéž, hodí výjimku pokud výstup chybí
string value = await repository.GetFirstOutputOrThrowAsync(key, context, outputName: "Formula");

// Invalidace cache pro konkrétní pravidlo
await repository.InvalidateCacheAsync(key);

NuGet balíčky

Projekt NuGet Popis
RuleEval.Abstractions 📦 Contracts a immutable doménový model; referujte, pokud píšete knihovny integrující se s RuleEval
RuleEval 📦 Evaluační engine, built-in matchery (regex, INTERVAL, equality)
RuleEval.Caching Interní projekt bez vlastního NuGet; zkompilován do RuleEval.DependencyInjection a RuleEval.Database. Obsahuje IRuleSetCache, MemoryRuleSetCache, NoCacheRuleSetCache
RuleEval.Diagnostics Interní projekt bez vlastního NuGet. Obsahuje IRuleEvaluationObserver, observer pattern pro výsledky evaluace
RuleEval.DependencyInjection 📦 AddRuleEval() registrace core služeb do IServiceCollection
RuleEval.Database.Abstractions Interní projekt bez vlastního NuGet; zkompilován do RuleEval.Database. Obsahuje IRuleSetSource, IRuleSetRepository — provider-neutral DB contracts
RuleEval.Database 📦 DbRuleSetMapper, RuleSetRepository, PostgreSqlRuleSetSource, SqlServerRuleSetSource
RuleEval.Database.DependencyInjection 📦 AddRuleEvalDatabase() registrace DB služeb do IServiceCollection

Dokumentace

Dokument Obsah
docs/architecture.md Architektura, design rozhodnutí, závislosti mezi vrstvami, evaluační flow
docs/observability.md Technická observability: ILogger, ActivitySource (OpenTelemetry), Meter (metriky)
docs/nuget-packages.md Přehled balíčků, typické instalační scénáře, dependency graph
docs/publishing-nuget.md Jak verzovat, zabalit a publikovat NuGet balíčky
samples/RuleEval.Samples Kompletní ukázky použití včetně DI, cache a DB vrstvy
benchmarks/RuleEval.Benchmarks BenchmarkDotNet výkonnostní testy

Build a test

dotnet restore RuleEval.sln
dotnet build RuleEval.sln -c Release
dotnet test RuleEval.sln -c Release --collect:"XPlat Code Coverage"

Licence

MIT. Viz LICENSE.

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 (2)

Showing the top 2 NuGet packages that depend on RuleEval:

Package Downloads
RuleEval.Database

Database-backed rule set loading for RuleEval. Includes DbRuleSetMapper, RuleSetRepository, and a PostgreSQL source (PostgreSqlRuleSetSource) via Npgsql. SQL Server support (SqlServerRuleSetSource) is provider-neutral and works with any ADO.NET DbConnection.

RuleEval.DependencyInjection

Optional Microsoft.Extensions.DependencyInjection integration for RuleEval core runtime. Does not pull in any database dependencies.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.3.0 141 3/25/2026
1.2.0 123 3/25/2026
1.1.3 129 3/24/2026
1.1.2 130 3/24/2026
1.1.1 125 3/24/2026
1.1.0 128 3/24/2026
1.0.1 127 3/24/2026
1.0.0 134 3/20/2026