-
Notifications
You must be signed in to change notification settings - Fork 137
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Initial version of CEL resource expressions. #928
Conversation
@@ -63,10 +63,24 @@ type ReceiverSpec struct { | |||
// +optional | |||
Events []string `json:"events,omitempty"` | |||
|
|||
// TODO: Validate one or other (or both?) | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will need to be addressed, because you could have .spec.resourceExpressions
or .spec.resources
(or both).
786ff7e
to
5da3f91
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the work here @bigkevmcd, but I think we need to create an RFC or at least an issue to discuss this feature.
// Only decodes the body for the expression if the body is JSON. | ||
// Technically you could generate several resources without any body. | ||
if isJSONContent(r) { | ||
if err := json.NewDecoder(r.Body).Decode(&body); err != nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This needs to be reworked, the request body was already received at this point, in the line if err := s.validate(ctx, receiver, r); err != nil {
from (s *ReceiverServer) handlePayload()
. Reading it again won't be possible. To fix this you will need something like a https://pkg.go.dev/io#TeeReader with a https://pkg.go.dev/bytes#Buffer.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I missed this in the code above, I'll fix this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another option is simply reading the body into a bytes.Buffer
and passing it to all the parts of the code that need to consume it.
Looking again at the original issue, maybe we could use that issue to discuss this feature, it looks like in this PR you're specifically trying to address this part:
|
b6d22ba
to
8cfcfb6
Compare
To fix the e2e GitHub Action failing you can run |
de123a3
to
4e2654f
Compare
Now there's a diff on |
That's ok, it was a quick branch to explore what's possible, there's no compelling need to land this, and, it's taking on support for CEL, which is not "free". Worst case, it gets closed as "won't fix" 😄 and informs a different solution, fine by me.
Yes, this is basically a way to dynamically generate the set of resources to notify in a receiver. The new field |
1d7d611
to
e25d8f3
Compare
This solution sounds very elegant to me @bigkevmcd, I'd love to see it in. It would be nice if you could attend some of our dev meetings to discuss this feature, they are public and can be found here: https://fluxcd.io/community/#meetings (The |
I'll see what I can do to be there, time permitting. You'll see that the specific request in here #491 (comment) is tested in the code. |
e25d8f3
to
1d7d611
Compare
This adds support for dynamic generation of resources for receivers using CEL and parsing the body in the content request. Signed-off-by: Kevin McDermott <bigkevmcd@gmail.com>
Signed-off-by: Kevin McDermott <bigkevmcd@gmail.com>
Signed-off-by: Kevin McDermott <bigkevmcd@gmail.com>
904f97b
to
be66d3c
Compare
This is currently failing because of this bug: kubernetes-sigs/controller-runtime#2949 Signed-off-by: Kevin McDermott <bigkevmcd@gmail.com>
29ce325
to
b1c68b3
Compare
// e.g. {"name": "test-resource-1", "kind": "Receiver", "apiVersion": | ||
// "notification.toolkit.fluxcd.io/v1"}. | ||
// +optional | ||
ResourceExpressions []string `json:"resourceExpressions,omitempty"` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this should be named ResourceFilters
and act on the given list of Resources
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@stefanprodan The last test is borked because of a bug in controller-runtime which I've fixed, but is yet to be released
If I understand what you're saying here, you would have Resources
and the user would declare all the possible resources, and the ResourceFilters
would filter these to only a subset based on the request?
This wouldn't be dynamic tho', it's not clear how it would solve the problem outlined in #491?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If I understand what you're saying here, you would have Resources and the user would declare all the possible resources, and the ResourceFilters would filter these to only a subset based on the request?
Precisely, that's exactly what we discussed in the dev meeting today!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This wouldn't be dynamic tho', it's not clear how it would solve the problem outlined in #491?
Our reasoning is security, this style forces a more secure stance, the user always have to the declare which resources can be reconciled by the Receiver. They may end up with a long list of resources but at least it will always be clear from the Receiver object which Flux objects can be reconciled from that Receiver.
This is a very rough cut (needs additional error checking).
But the basic implementation works.
This is the code I referenced here #491 (comment)
I will harden it up, checking that it's receiving a
json
body and improve the error handling, this was a quick bit of code to see if it was possible.