feat(ffi): add Azure Policy JSON compilation FFI and C# bindings#720
Closed
anakrish wants to merge 1 commit into
Closed
feat(ffi): add Azure Policy JSON compilation FFI and C# bindings#720anakrish wants to merge 1 commit into
anakrish wants to merge 1 commit into
Conversation
There was a problem hiding this comment.
Pull request overview
Note
Copilot was unable to run its full agentic suite in this review.
This PR adds Azure Policy JSON compilation and evaluation support through the Rust FFI layer and exposes it via new C# bindings, enabling callers to compile/evaluate Azure Policy rules/definitions without translating to Rego.
Changes:
- Added new FFI entry points to compile Azure Policy JSON (
regorus_compile_azure_policy_rule,regorus_compile_azure_policy_definition) and to set VM context (regorus_rvm_set_context). - Added C# bindings (
AzurePolicyCompiler,Rvm.SetContextJson) plus example usage and tests. - Bumped FFI/C# package versions to 0.10.1.
Reviewed changes
Copilot reviewed 12 out of 13 changed files in this pull request and generated 5 comments.
Show a summary per file
| File | Description |
|---|---|
| bindings/ffi/src/rvm.rs | Adds regorus_rvm_set_context for supplying ambient context JSON to the RVM. |
| bindings/ffi/src/compile.rs | Adds Azure Policy JSON compile entry points plus Rust-side tests. |
| bindings/ffi/src/alias_registry.rs | Exposes alias maps to the compiler via new wrapper methods. |
| bindings/ffi/Cargo.toml | Bumps regorus-ffi version to 0.10.1. |
| bindings/csharp/TargetExampleApp/Program.cs | Adds an Azure Policy JSON compilation demo. |
| bindings/csharp/Regorus/Rvm.cs | Adds SetContextJson wrapper over the new FFI entry point. |
| bindings/csharp/Regorus/Program.cs | Makes Program constructor internal for internal factory usage. |
| bindings/csharp/Regorus/NativeMethods.cs | Adds new P/Invoke signatures for Azure Policy compile + context APIs. |
| bindings/csharp/Regorus/AzurePolicyCompiler.cs | Adds a C# helper to compile JSON policy rules/definitions into RVM programs. |
| bindings/csharp/Regorus.Tests/AzurePolicyCompilerTests.cs | Adds MSTest coverage for compilation + evaluation + context behavior. |
| bindings/csharp/README.md | Documents Azure Policy JSON evaluation workflow in C#. |
| bindings/csharp/Directory.Packages.props | Bumps C# package version to 0.10.1. |
Comment on lines
+186
to
+187
| [DllImport(LibraryName, EntryPoint = "regorus_rvm_set_context", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||
| internal static extern RegorusResult regorus_rvm_set_context(RegorusRvm* vm, byte* context_json); |
Comment on lines
+501
to
+514
| /// <summary> | ||
| /// Compile an Azure Policy JSON policy rule into an RVM program. | ||
| /// </summary> | ||
| [DllImport(LibraryName, EntryPoint = "regorus_compile_azure_policy_rule", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||
| internal static extern RegorusResult regorus_compile_azure_policy_rule( | ||
| RegorusAliasRegistry* registry, byte* policy_rule_json); | ||
|
|
||
| /// <summary> | ||
| /// Compile a full Azure Policy definition JSON into an RVM program. | ||
| /// </summary> | ||
| [DllImport(LibraryName, EntryPoint = "regorus_compile_azure_policy_definition", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||
| internal static extern RegorusResult regorus_compile_azure_policy_definition( | ||
| RegorusAliasRegistry* registry, byte* policy_definition_json); | ||
|
|
Comment on lines
+509
to
+513
| /// Compile a full Azure Policy definition JSON into an RVM program. | ||
| /// </summary> | ||
| [DllImport(LibraryName, EntryPoint = "regorus_compile_azure_policy_definition", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||
| internal static extern RegorusResult regorus_compile_azure_policy_definition( | ||
| RegorusAliasRegistry* registry, byte* policy_definition_json); |
| .map_err(|e| (RegorusStatus::Error, format!("VM lock failed: {e}")))?; | ||
| let context_value = Value::from_json_str(&from_c_str(context_json).map_err(|e| { | ||
| ( | ||
| RegorusStatus::InvalidDataFormat, |
Comment on lines
+27
to
+38
| pub(crate) fn alias_map( | ||
| &self, | ||
| ) -> alloc::collections::BTreeMap<alloc::string::String, alloc::string::String> { | ||
| self.registry.alias_map() | ||
| } | ||
|
|
||
| /// Return a clone of the alias-to-modifiable map for use by the compiler. | ||
| pub(crate) fn alias_modifiable_map( | ||
| &self, | ||
| ) -> alloc::collections::BTreeMap<alloc::string::String, bool> { | ||
| self.registry.alias_modifiable_map() | ||
| } |
51b5b1b to
427ce6c
Compare
Collaborator
Author
|
@copilot Use the deep-review skill to review this PR. |
95b61cf to
b164a3c
Compare
Add two new FFI functions for compiling Azure Policy JSON directly: - regorus_compile_azure_policy_rule: compiles a policyRule JSON object - regorus_compile_azure_policy_definition: compiles a full policy definition Add regorus_rvm_set_context for setting VM context (subscription, resourceGroup, etc.) needed by context-dependent policies. C# bindings: - AzurePolicyCompiler static class with CompilePolicyRule/CompilePolicyDefinition - Rvm.SetContextJson method with persistence and validation docs - Comprehensive test suite (16 tests) - README documentation with usage examples Key design decisions: - Non-object context values rejected with InvalidDataFormat error - Context persists across executions (same pattern as set_input) - Null alias registry documented as caller responsibility - Rc::try_unwrap optimization avoids unnecessary Program clone - Feature-gated with #[cfg(feature = "azure_policy")] Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
b164a3c to
f43788b
Compare
Collaborator
Author
|
Superseded by new PR with cleaned up API surface (removed CompilePolicyRule, only CompilePolicyDefinition exposed). |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR exposes Azure Policy JSON compilation through the FFI layer and C# bindings, enabling callers to compile and evaluate Azure Policy definitions natively without translating to Rego first.
What's new
Three new FFI entry points:
regorus_compile_azure_policy_ruleandregorus_compile_azure_policy_definitionparse and compile JSON policy rules/definitions into RVM programs, with optional alias resolution via the existingRegorusAliasRegistry.regorus_rvm_set_contextlets callers supply ambient host data (subscription(),resourceGroup(), etc.) that context-dependent policies need at evaluation time.On the C# side, there's a new
AzurePolicyCompilerhelper class and aRvm.SetContextJsonmethod, along with tests and README docs.Notable choices
set_contextvalidates that the JSON is an object (returnsInvalidDataFormatotherwise) and persists across executions, matching the existingset_inputbehavior.Rc::try_unwrapto avoid cloning the compiled program when the refcount is 1 (the common case).#[cfg(feature = "azure_policy")].