You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Currently there is no out of the box way to construct an Input filter by InputFilterManager by merging multiple Input Filters without having to construct a factory where each of the merged input filters to be requested from IFM first.
So constructing the final IF is now like this:
Fire IFM for each IF which are going to be merged
Merge all IF into final IF
rather I see more appropriate (by example when subclassing InputFilter) to:
construct final IF into IF init, merging here all other IF
Fire just one time the IFM to actually get the instance
We need a mergeByClass functionality to be used on main IF to merge with the rest of IF's and IFM to be fired one time only...
A similar situation is for adding filters, if we are about to set a name to the "sub-inputfilter" we can't unless we provide an instance, not a class as below:
cbichis
changed the title
InputFilterManager and merging multiple input filters
InputFilterManager and merging/adding multiple input filters
Oct 27, 2021
cbichis
changed the title
InputFilterManager and merging/adding multiple input filters
InputFilterManager and merging/adding input filters to a base input filter
Oct 27, 2021
Rather than merging, which requires InputFilter to provide insight into its internals (breaks encapsulation), I'd say that input filters should be chained perhaps?
having to construct a factory where each of the merged input filters to be requested from IFM first.
This seems normal/OK? Not sure why that's a problem...
unless we provide an instance, not a class as below:
I didn't understand the phrasing here.
Of course the below example works, but it's just useless complicating situation as would require addition fire of IFM to build the sub-inputfilter...
The input filter manager is totally optional: I personally assemble input filters manually, without any DIC involved.
Summary
Currently there is no out of the box way to construct an Input filter by InputFilterManager by merging multiple Input Filters without having to construct a factory where each of the merged input filters to be requested from IFM first.
So constructing the final IF is now like this:
Fire IFM for each IF which are going to be merged
Merge all IF into final IF
Eg:
$inputFilter = new StockGetCheckInputFilter();
$inputFilter->merge( $container->get('InputFilterManager')->get(OldEntityCheckInputFilter::class) );
$inputFilter->merge( $container->get('InputFilterManager')->get(SaleInputFilter::class) );
$inputFilter->merge( $container->get('InputFilterManager')->get(InstanceInputFilter::class) );
rather I see more appropriate (by example when subclassing InputFilter) to:
construct final IF into IF init, merging here all other IF
Fire just one time the IFM to actually get the instance
We need a mergeByClass functionality to be used on main IF to merge with the rest of IF's and IFM to be fired one time only...
A similar situation is for adding filters, if we are about to set a name to the "sub-inputfilter" we can't unless we provide an instance, not a class as below:
$this->add([
'type' => InstanceInputFilter::class,
'name' => 'instance'
]);
Of course the below example works, but it's just useless complicating situation as would require addition fire of IFM to build the sub-inputfilter...
$this->add($instanceInputFilter, 'instance');
The text was updated successfully, but these errors were encountered: