Bart Thierens created JCRVLT-827:
------------------------------------

             Summary: Determination of ImportMode dependent on order of filters 
in filter.xml
                 Key: JCRVLT-827
                 URL: https://issues.apache.org/jira/browse/JCRVLT-827
             Project: Jackrabbit FileVault
          Issue Type: Bug
          Components: vlt
    Affects Versions: 3.8.4
            Reporter: Bart Thierens


I noticed weird behaviour in the processing of the filters in filter.xml that 
does not seem to be documented explicitly in the [FileVault filter 
documentation|https://jackrabbit.apache.org/filevault/filter.html].

Consider this scenario:
{code:xml}
<filter root="/apps/my-app" mode="update_properties"/>
<filter root="/apps/my-app/components"/>
{code}

After renaming a node a few levels under /apps/my-app/components in my IDE 
(=making a change in the .content.xml) and installing the package, the new node 
(with the new name) appears, but the old one is *not deleted*. 
This seems weird because the most specific filter has the _implicit_ replace 
import mode.

When swapping the order of the filters it works correctly.
{code:xml}
<filter root="/apps/my-app/components"/>
<filter root="/apps/my-app" mode="update_properties"/>
{code}
This leads me to believe that the first match in the filter.xml is taken, ands 
not the most specific one. 
This also seems rather unfortunate in case someone would add a filter at the 
start of the filter.xml
{code:xml}
<filter root="/apps" mode="update_properties"/>
{code}
then ALL nodes under /apps will be update_properties regardless of any 
subsequent filters.

We have this scenario to guarantee certain parent folders are created with a 
certain node type instead of nt:folder. This is not guaranteed when switching 
the order of the filter statements.

I logged this as a bug but I'm more looking for info on the details of the 
workings of these filters.  Is this the expected behaviour? How should this 
problem be tackled then?



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to