UserDefinedExpressions 1.0.1
dotnet add package UserDefinedExpressions --version 1.0.1
NuGet\Install-Package UserDefinedExpressions -Version 1.0.1
<PackageReference Include="UserDefinedExpressions" Version="1.0.1" />
paket add UserDefinedExpressions --version 1.0.1
#r "nuget: UserDefinedExpressions, 1.0.1"
// Install UserDefinedExpressions as a Cake Addin #addin nuget:?package=UserDefinedExpressions&version=1.0.1 // Install UserDefinedExpressions as a Cake Tool #tool nuget:?package=UserDefinedExpressions&version=1.0.1
UserDefinedExpressions
UserDefinedExpressions is a .NET library to safely invoke (evaluate) User Defined Expressions (Formulas) using Roslyn Scripting Engine
One of the most common tasks in business applications is to allow end-users to configure business rules on their own. This library allows dynamic evaluation of C# expressions (which can be written by end-users as if they were writing Excel formulas) but it's safe against malicious code.
Installation
Just install nuget package UserDefinedExpressions,
add using UserDefinedExpressions
and start using (see examples below).
See documentation below, or more examples in unit tests.
Documentation
Sample usage:
public class SalesOrderHeader
{
public decimal TotalDue { get; set; }
public decimal Freight { get; set; }
}
var isHeavyOrExpensiveFormula = UserDefinedExpression<SalesOrderHeader, bool>
.Create("TotalDue > 1000 || Freight > 1000");
var order = new SalesOrderHeader() { TotalDue = 1200, Freight = 700 };
bool isHeavyOrExpensive = isHeavyOrExpensiveFormula.Invoke(order);
Unsafe expressions are blocked:
If you use an unsafe expression, you'll get an UnsafeExpressionException
exception:
var unsafeFormula = UserDefinedExpression<SalesOrderHeader, bool>
.Create("System.IO.File.Create(\"dummy\")");
var order = new SalesOrderHeader() { TotalDue = 1200, Freight = 700 };
try
{
bool isHeavyOrExpensive = unsafeFormula.Invoke(order);
}
catch(UnsafeExpressionException ex)
{
//ex.Message: 'ForbiddenCall: Cannot use System.IO.File (location : (0,0)-(0,30)): System.IO.File.Create("dummy")'
}
Passing Complex Models as Expressions Input:
var creditInfo = new CreditInfo()
{
HardInquiries = new List<DateTime>()
{
new DateTime(2020, 12, 12),
new DateTime(2019, 05, 06),
new DateTime(2017, 03, 03)
},
Accounts = new List<CreditAccount>()
{
new CreditAccount() { TotalCredit = 10000, UsedCredit = 3000 },
new CreditAccount() { TotalCredit = 5000, UsedCredit = 300 }
}
};
// The input model (CreditInfo) is automatically added to white-list,
// but other non-primitive types should be explicitly added
SafetyValidators.TypesValidator.Defaults.AddAllowedType(typeof(CreditAccount));
// Past 2 years
var recentHardInquiriesFormula = UserDefinedExpression<CreditInfo, int>
.Create("HardInquiries.Count(h => h.Date > DateTime.Today.AddYears(-2))");
var creditUsageFormula = UserDefinedExpression<CreditInfo, decimal>
.Create("Accounts.Sum(a => a.UsedCredit) / Accounts.Sum(a => a.TotalCredit)");
var recentHardInquiries = recentHardInquiriesFormula.Invoke(creditInfo); // 2
var creditUsage = creditUsageFormula.Invoke(creditInfo); // 0.22
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. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
.NET Framework | net472 is compatible. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.7.2
- Microsoft.CodeAnalysis.CSharp.Scripting (>= 3.8.0)
- Microsoft.CodeAnalysis.Scripting.Common (>= 3.8.0)
-
.NETStandard 2.1
- Microsoft.CodeAnalysis.CSharp.Scripting (>= 3.8.0)
- Microsoft.CodeAnalysis.Scripting.Common (>= 3.8.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.