Skip to content

Commit

Permalink
Address review comments
Browse files Browse the repository at this point in the history
* Don't pass log through - get it from the context
* Use ContextEval - need to set a timeout on the context that's passed

Signed-off-by: Kevin McDermott <bigkevmcd@gmail.com>
  • Loading branch information
bigkevmcd committed Dec 12, 2024
1 parent 5bb30d0 commit bda3f0a
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 13 deletions.
4 changes: 2 additions & 2 deletions docs/spec/v1/receivers.md
Original file line number Diff line number Diff line change
Expand Up @@ -757,15 +757,15 @@ If the body of the incoming hook looks like this:

This simple example would match `ImageRepositories` containing the name `hello-world`.

If you want do do more complex processing:
If you want to do more complex processing:

```yaml
resourceFilter: has(resource.metadata.annotations) && request.body.tag.split('/').last().split(":").first() == resource.metadata.annotations['update-image']
```

This would look for an annotation "update-image" on the resource, and match it to the `hello-world` part of the tag name.

**NOTE**: Currently the `resource` value in the CEL expression only provides the object metadata, this means you can access things like `resource.metadata.labels` and `resource.metadata.annotations` and `resource.metadata.name`.
**Note:** Currently the `resource` value in the CEL expression only provides the object metadata, this means you can access things like `resource.metadata.labels` and `resource.metadata.annotations` and `resource.metadata.name`.

There are a number of functions available to the CEL expressions beyond the basic CEL functionality.

Expand Down
9 changes: 5 additions & 4 deletions internal/controller/receiver_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@ import (
helper "github.com/fluxcd/pkg/runtime/controller"
"github.com/fluxcd/pkg/runtime/patch"
"github.com/fluxcd/pkg/runtime/predicates"
"github.com/go-logr/logr"

apiv1 "github.com/fluxcd/notification-controller/api/v1"
"github.com/fluxcd/notification-controller/internal/server"
Expand Down Expand Up @@ -151,12 +150,14 @@ func (r *ReceiverReconciler) Reconcile(ctx context.Context, req ctrl.Request) (r
return ctrl.Result{}, nil
}

return r.reconcile(ctx, obj, log)
return r.reconcile(ctx, obj)
}

// reconcile steps through the actual reconciliation tasks for the object, it returns early on the first step that
// produces an error.
func (r *ReceiverReconciler) reconcile(ctx context.Context, obj *apiv1.Receiver, logger logr.Logger) (ctrl.Result, error) {
func (r *ReceiverReconciler) reconcile(ctx context.Context, obj *apiv1.Receiver) (ctrl.Result, error) {
log := ctrl.LoggerFrom(ctx)

// Mark the resource as under reconciliation.
conditions.MarkReconciling(obj, meta.ProgressingReason, "Reconciliation in progress")

Expand All @@ -172,7 +173,7 @@ func (r *ReceiverReconciler) reconcile(ctx context.Context, obj *apiv1.Receiver,
if err != nil {
conditions.MarkFalse(obj, meta.ReadyCondition, apiv1.InvalidCELExpressionReason, "%s", err)
obj.Status.WebhookPath = ""
logger.Error(err, "parsing CEL resource filter expression")
log.Error(err, "parsing CEL resource filter expression")
return ctrl.Result{}, nil
}
}
Expand Down
7 changes: 4 additions & 3 deletions internal/server/cel.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ limitations under the License.
package server

import (
"context"
"encoding/json"
"fmt"
"mime"
Expand Down Expand Up @@ -54,7 +55,7 @@ func newCELProgram(expr string) (cel.Program, error) {
return nil, fmt.Errorf("expression %v check failed: %w", expr, issues.Err())
}

prg, err := env.Program(checked, cel.EvalOptions(cel.OptOptimize))
prg, err := env.Program(checked, cel.EvalOptions(cel.OptOptimize), cel.InterruptCheckFrequency(100))
if err != nil {
return nil, fmt.Errorf("expression %v failed to create a Program: %w", expr, err)
}
Expand All @@ -77,13 +78,13 @@ func newCELEvaluator(expr string, req *http.Request) (resourcePredicate, error)
}
}

return func(obj client.Object) (*bool, error) {
return func(ctx context.Context, obj client.Object) (*bool, error) {
data, err := clientObjectToMap(obj)
if err != nil {
return nil, err
}

out, _, err := prg.Eval(map[string]any{
out, _, err := prg.ContextEval(ctx, map[string]any{
"resource": data,
"request": map[string]any{
"body": body,
Expand Down
8 changes: 4 additions & 4 deletions internal/server/receiver_handlers.go
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ func (s *ReceiverServer) handlePayload(w http.ResponseWriter, r *http.Request) {
return
}

var evaluator func(client.Object) (*bool, error)
var evaluator func(context.Context, client.Object) (*bool, error)
if receiver.Spec.ResourceFilter != "" {
evaluator, err = newCELEvaluator(receiver.Spec.ResourceFilter, r)
if err != nil {
Expand Down Expand Up @@ -150,12 +150,12 @@ func (s *ReceiverServer) notifySingleResource(ctx context.Context, logger logr.L

func (s *ReceiverServer) notifyResource(ctx context.Context, logger logr.Logger, resource *metav1.PartialObjectMetadata, predicate resourcePredicate) error {
if predicate != nil {
accept, err := predicate(resource)
accept, err := predicate(ctx, resource)
if err != nil {
return err
}
if !*accept {
logger.Info(fmt.Sprintf("resource '%s/%s.%s' NOT annotated because CEL expression returned false", resource.Kind, resource.Name, resource.Namespace))
logger.V(1).Info(fmt.Sprintf("resource '%s/%s.%s' NOT annotated because CEL expression returned false", resource.Kind, resource.Name, resource.Namespace))
return nil
}
}
Expand Down Expand Up @@ -514,7 +514,7 @@ func (s *ReceiverServer) token(ctx context.Context, receiver apiv1.Receiver) (st
return token, nil
}

type resourcePredicate func(client.Object) (*bool, error)
type resourcePredicate func(context.Context, client.Object) (*bool, error)

// requestReconciliation requests reconciliation of all the resources matching the given CrossNamespaceObjectReference by annotating them accordingly.
func (s *ReceiverServer) requestReconciliation(ctx context.Context, logger logr.Logger, resource apiv1.CrossNamespaceObjectReference, defaultNamespace string, resourcePredicate resourcePredicate) error {
Expand Down

0 comments on commit bda3f0a

Please sign in to comment.