JsonToLinq 1.0.0-rc6

This is a prerelease version of JsonToLinq.
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package JsonToLinq --version 1.0.0-rc6
                    
NuGet\Install-Package JsonToLinq -Version 1.0.0-rc6
                    
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="JsonToLinq" Version="1.0.0-rc6" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="JsonToLinq" Version="1.0.0-rc6" />
                    
Directory.Packages.props
<PackageReference Include="JsonToLinq" />
                    
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 JsonToLinq --version 1.0.0-rc6
                    
#r "nuget: JsonToLinq, 1.0.0-rc6"
                    
#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 JsonToLinq@1.0.0-rc6
                    
#: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=JsonToLinq&version=1.0.0-rc6&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=JsonToLinq&version=1.0.0-rc6&prerelease
                    
Install as a Cake Tool

<div align="center"> <img src="Docs/img/title_path.svg"> </div>

JsonToLinq

JsonToLinq - lightweight C# library that converts JSON-based query definitions into LINQ expressions. Ideal for building dynamic filters, predicates, and queries.

๐Ÿ—‚๏ธ Use Cases

JsonToLinq can be applied in various scenarios where dynamic, runtime-defined queries are needed. Examples include:

  • Server-side filtering: Apply JSON-defined filters received from front-end applications to collections or database queries.
  • Dynamic reporting: Build complex filters and predicates for reports without hardcoding logic.
  • Custom dashboards: Let users define queries for dashboards dynamically and translate them to LINQ expressions.
  • EF Core / Entity Framework queries: Map JSON filters directly to LINQ queries executed on the database.
  • Audit & logging filters: Dynamically select subsets of data based on JSON rules for auditing or logging purposes.

๐Ÿ“Œ Default Operator Mapping

JSON LINQ Expression Description
& Expression.And Bitwise AND
&& Expression.AndAlso Logical AND
\| Expression.Or Bitwise OR
\|\| Expression.OrElse Logical OR
= Expression.Equal Equal
!= Expression.NotEqual Not equal
> Expression.GreaterThan Greater than
>= Expression.GreaterThanOrEqual Greater than or equal
< Expression.LessThan Less than
<= Expression.LessThanOrEqual Less than or equal

๐Ÿงช Demos

Filtering Users

// 1. Source data.
var users = new List<User>
{
  new() { Id = 1, Balance = 0, LastVisitAt = null },
  new() { Id = 2, Balance = 0, LastVisitAt = DateTime.UtcNow },
  new() { Id = 3, Balance = 0, LastVisitAt = DateTime.UtcNow.AddYears(-10) },
  new() { Id = 4, Balance = 100, LastVisitAt = null },
  new() { Id = 5, Balance = 100, LastVisitAt = DateTime.UtcNow },
  new() { Id = 6, Balance = 100, LastVisitAt = DateTime.UtcNow.AddYears(-10) },
};

// 2. JSON filter definition (simulates front-end request).
var filterJson = JsonDocument.Parse(
  """
  {
    "Logic": "&&",
    "Rules": [
      {
        "Field": "balance",
        "Operator": "=",
        "Value": 0
      },
      {
        "Logic": "||",
        "Rules": [
          {
            "Field": "lastVisitAt",
            "Operator": "=",
            "Value": null
          },
          {
            "Field": "lastVisitAt",
            "Operator": "<=",
            "Value": "2025-01-01T00:00:00Z"
          }
        ]
      }
    ]
  }
  """);

// 3. Parse JSON to LINQ expression and compile.
var filterExpr = JsonLinq.ParseToFilterExpression<User>(filterJson);
var filterLambda = filterExpr.Compile();

// 4. Apply filter.
var filteredUsers = users.Where(filterLambda);

// 5. Output results.
foreach (var fu in filteredUsers)
{
  Console.WriteLine($"Id: {fu.Id}");
}

// Id: 1
// Id: 3
Product 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 netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.0.0-rc908 19 12/13/2025
1.0.0-rc907 24 12/13/2025
1.0.0-rc906 37 12/12/2025
1.0.0-rc905 254 12/11/2025
1.0.0-rc904 268 12/9/2025
1.0.0-rc903 77 12/6/2025
1.0.0-rc901 81 12/6/2025
1.0.0-rc9 611 12/2/2025
1.0.0-rc8 202 11/30/2025
1.0.0-rc7 198 11/30/2025
1.0.0-rc6 199 11/30/2025
1.0.0-rc5 201 11/30/2025
1.0.0-rc4 156 11/9/2025
1.0.0-rc3 110 11/2/2025
1.0.0-rc2 112 11/2/2025
1.0.0-rc13 123 12/5/2025
1.0.0-rc12 128 12/5/2025
1.0.0-rc11 125 12/5/2025
1.0.0-rc10 126 12/5/2025
1.0.0-rc1 74 11/1/2025