OpaDotNet.Wasm 1.1.0-preview0076

This is a prerelease version of OpaDotNet.Wasm.
There is a newer version of this package available.
See the version list below for details.
dotnet add package OpaDotNet.Wasm --version 1.1.0-preview0076                
NuGet\Install-Package OpaDotNet.Wasm -Version 1.1.0-preview0076                
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="OpaDotNet.Wasm" Version="1.1.0-preview0076" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add OpaDotNet.Wasm --version 1.1.0-preview0076                
#r "nuget: OpaDotNet.Wasm, 1.1.0-preview0076"                
#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.
// Install OpaDotNet.Wasm as a Cake Addin
#addin nuget:?package=OpaDotNet.Wasm&version=1.1.0-preview0076&prerelease

// Install OpaDotNet.Wasm as a Cake Tool
#tool nuget:?package=OpaDotNet.Wasm&version=1.1.0-preview0076&prerelease                

CI NuGet Coverage Status

Open Policy Agent (OPA) WebAssembly dotnet core SDK

This is SDK for using WebAssembly (wasm) compiled Open Policy Agent Rego policies with dotnet core.

Initial implementation was based on Open Policy Agent WebAssemby NPM Module

For more information check out the guide.

Supported ABI

Version Status
1.0 ✔️
1.2 ✔️
1.3 ✔️

Getting Started

Install nuget package

dotnet add package OpaDotNet.Wasm

Usage

To evaluate OPA policy you need to:

Load compiled policy

using using OpaDotNet.Wasm;

var factory = new OpaEvaluatorFactory();

const string data = "{ \"world\": \"world\" }";

using var engine = factory.CreateFromWasm(
    File.OpenRead("policy.wasm")
    );

engine.SetDataFromRawJson(data);

Evaluate policy

IOpaEvaluator has several APIs for policy evaluation:

  • EvaluatePredicate - Evaluates named policy with specified input. Response interpreted as simple true/false result.
  • Evaluate - Evaluates named policy with specified input.
  • EvaluateRaw - Evaluates named policy with specified raw JSON input.
var policyResult = engine.EvaluatePredicate(inp);

Check result

if (policyResult)
{
    // We"ve been authorized.
}
else
{
    // Can"t do that.
}

Writing policy

See writing policy

Compiling policy

You have several options to compile rego policy into wasm module:

package example

default hello = false

hello {
    x := input.message
    x == data.world
}

Manually

Either use the Compile REST API or opa build CLI tool.

For example, with OPA v0.20.5+:

opa build -t wasm -e example/hello example.rego

Which is compiling the example.rego policy file. The result will be an OPA bundle with the policy.wasm binary included. See ./samples for a more comprehensive example.

See opa build --help for more details.

With OpaDotNet.Wasm.Compilation

You can use SDK to do compilation for you.

Important. You will need opa cli tool to be in your PATH or provide full path in RegoCliCompilerOptions.

using OpaDotNet.Wasm;
using OpaDotNet.Wasm.Compilation;

var options = new OptionsWrapper<RegoCliCompilerOptions>(new RegoCliCompilerOptions());
var compiler = new RegoCliCompiler(options);
var policyStream = await compiler.CompileFile("example.rego", new[] { "example/hello" });

// Use compiled policy.
var factory = new OpaEvaluatorFactory();

using var engine = factory.CreateFromBundle(policyStream);

3rd Party Libraries and Contributions

  • OPA - An open source, general-purpose policy engine that unifies policy enforcement across the stack.
  • Moq - The most popular and friendly mocking library for .NET.
  • xUnit.net - Free, open source, community-focused unit testing tool for the .NET Framework.
  • wasmtime-dotnet - .NET embedding of Wasmtime.
  • IPNetwork2 - Utility classes take care of complex network, IPv4, IPv6, CIDR calculation for .NET developers.
  • BenchmarkDotNet - Powerful .NET library for benchmarking.
Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on OpaDotNet.Wasm:

Package Downloads
OpaDotNet.Extensions.AspNetCore

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.0-preview-0004 90 11/10/2024
3.0.0-preview-0001 89 10/25/2024
3.0.0-preview-0000 75 10/25/2024
2.5.1 146 11/8/2024
2.5.0 849 2/12/2024
2.4.1 154 1/26/2024
2.4.1-pre0004 103 1/23/2024
2.4.0 185 1/10/2024
2.3.0 240 11/21/2023
2.2.0 202 10/11/2023
2.2.0-preview0010 154 10/9/2023
2.2.0-preview0008 153 10/3/2023
2.1.1 166 9/29/2023
2.1.0 176 9/28/2023
2.0.0 296 8/18/2023
2.0.0-preview0012 131 8/18/2023
2.0.0-preview 129 8/17/2023
1.4.0 224 8/15/2023
1.3.0 166 8/9/2023
1.3.0-preview0010 144 8/7/2023
1.2.1 203 7/27/2023
1.2.0 210 7/26/2023
1.2.0-preview0033 149 7/25/2023
1.2.0-preview0028 137 7/24/2023
1.2.0-preview0012 158 7/20/2023
1.2.0-preview0009 140 7/19/2023
1.2.0-preview0007 143 7/19/2023
1.1.0 184 7/13/2023
1.1.0-preview0078 158 7/13/2023
1.1.0-preview0076 120 7/13/2023
1.1.0-preview0073 127 7/13/2023
1.1.0-preview0068 147 7/12/2023
1.1.0-preview0067 169 7/12/2023
1.1.0-preview0065 163 7/12/2023
1.1.0-preview0063 149 7/12/2023
1.1.0-preview0061 167 7/11/2023
1.1.0-preview0057 135 7/11/2023
1.1.0-preview0053 133 7/11/2023
1.1.0-preview0049 113 7/10/2023
1.1.0-preview0047 125 7/10/2023
1.1.0-preview0018 152 7/6/2023
1.1.0-preview0015 134 7/6/2023
1.1.0-preview0012 140 7/6/2023
1.1.0-preview0011 142 7/5/2023
1.1.0-preview0010 148 7/5/2023
1.1.0-preview0009 130 7/5/2023
1.1.0-preview0007 130 7/3/2023
1.0.0 169 6/27/2023
1.0.0-preview0059 150 6/27/2023
1.0.0-preview0058 135 6/27/2023
1.0.0-preview0056 132 6/27/2023
1.0.0-preview0049 127 6/23/2023
1.0.0-preview0048 132 6/23/2023
1.0.0-preview0047 119 6/23/2023
1.0.0-preview0045 142 6/23/2023
1.0.0-preview0043 128 6/23/2023
1.0.0-preview0041 95 6/22/2023
1.0.0-preview0040 140 6/22/2023
1.0.0-preview0037 114 6/22/2023
1.0.0-preview0036 132 6/22/2023
1.0.0-preview0032 138 6/22/2023
1.0.0-preview0031 137 6/22/2023
1.0.0-preview0029 122 6/21/2023
1.0.0-preview0027 137 6/21/2023
1.0.0-preview0025 132 6/21/2023
1.0.0-preview0023 146 6/21/2023
1.0.0-preview0021 111 6/20/2023
1.0.0-preview0012 117 6/20/2023
1.0.0-preview0011 143 6/20/2023