feat: Implement CEL runtime cost budget for expression evaluation #442
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.
PR Description
Fixes #191
Feature Description
This PR implements cost budgeting for CEL expression evaluation to prevent resource exhaustion from complex expressions. The controller now enforces both per-call limits for individual expressions and a total runtime budget for the entire reconciliation cycle.
Key features implemented:
Implementation Details
pkg/cel/cost.go
ResourceGraphDefinitionRuntime
Testing
pkg/cel
Testspkg/graph
Testspkg/runtime
TestsAll tests
Example Error
When the CEL budget is exceeded, the controller will report an error and the instance status will reflect:
This prevents potential DoS attacks from overly complex expressions and ensures the controller remains responsive.
cc: @a-hilaly