-
Notifications
You must be signed in to change notification settings - Fork 217
Allow just registerPredicate for the polling to be overridden/configured for PerResourcePollingDependentResources #2783
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
Comments
Hi @Inkromind , Thank you for the issue, absolutely makes sense.
This is an interesting idea might worth to further discuss it, maybe support it with a feature flag eventually (cc @xstefank @metacosm ), also note that you can override the Lines 82 to 102 in e775349
Regarding supporting the preidicate with a method what you mentioned: @Override
protected Predicate<MyResource> pollingRegisterPredicate() {
return resource -> "someType".equals(resource.getSpec().type());
} I'm fine with this approach, do you plan to create a PR for this? |
Note that we could probably use an annotation approach to configure things, using an approach similar to what's done for |
That is an other option for sure. Note that this DR atm does not even implements (I personally have a bit issue passing such implementations via annotations, in this case a predicate, since an additional class needs to be created, but since we do it already, I'm fine with it) |
@metacosm we don't have this annotation based configuration extension documented atm, will create an issue for that, since that is probably extremely hard to discover. |
Is your feature request related to a problem? Please describe.
When using the
PerResourcePollingDependentResource
and you do not want polling (yet) for certain resources, it is hard to discover and cumbersome that you need to override thecreateEventSource
method (which happens to be the only implemented method of that class) just to add the single linewithRegisterPredicate(mypredicate::test)
to the PerResourcePollingConfigurationBuilder-builder (which also happens to be the only configuration property that is not already out-of-the-box overridable when using PerResourcePollingDependentResource).This has the additional downside that if the code for PerResourcePollingDependentResource.createEventSource is improved, we'd have to update our overridden method accordingly because we want the same behaviour, just only with the registerPredicate.
Describe the solution you'd like
A
pollingRegisterPredicate
method onPerResourcePollingDependentResource
that could be overridden and by default returns null. EgPerResourcePollingDependentResource
could then use this method to configure the registerPredicate when setting op the polling event source.Additionally, documenting the fact that by default polling is started for every resource (even if the depending reconciler has informer filters) and how this could be adjusted would greatly help new consumers.
Alternatively, an annotation
@PollingRegisterPredicate
could be added to your class that would then get picked up byPerResourcePollingDependentResource
.Describe alternatives you've considered
For our case (see below), it would also work if the polling picks up on the genericFilter/onAddFilter in the
@ControllerConfiguration/@Informer
annotations on the depending reconciler, so that the polling does not start if no event is processed by the reconciler.We recognize that his may be too specific to our use case which may not apply to other people and is also more complex than exposing the existing registerPredicate a bit more which would also be more generic.
Additional context
Our use case is that we have a reconciler with a PerResourcePollingDependentResource which polls an external system. Our reconciler should only reconcile specific resources within a kind (eg based on a static type field). We achieve this by adding a genericFilter to the
@ControllerConfiguration/@Informer
annotation:We noticed that, even for resources not being handled by the reconciler, polling was being started and the external system was being queried. This puts load on the operator and the external system for resource we know will never need something to happen in the external system.
This behaviour is not (clearly) documented and required some digging around to discover that
PerResourcePollingConfigurationBuilder
has the methodwithRegisterPredicate
which to control this behaviour, but this method is not used by thePerResourcePollingDependentResource
.To use this register predicate, it's therefor required to override the
createEventSource
method ofPerResourcePollingDependentResource
, just to add the register predicate:The text was updated successfully, but these errors were encountered: