Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

The following example shows how to create a Message Filter route consuming messages from an endpoint called queue:a, which if the Predicate is true will be dispatched to to queue:b

Using the Fluent Builders

Wiki Markup
{snippet:id=e2|lang=java|url=camel/trunk/camel-core/src/test/java/org/apache/camel/builder/RouteBuilderTest.java}
You can, of course, use many different Predicate languages such as XPath, XQuery, SQL or various Scripting Languages. Here is an XPath example
Wiki Markup
{snippet:id=example|lang=java|url=camel/trunk/camel-core/src/test/java/org/apache/camel/processor/XPathFilterTest.java}
Here is 's another example of using a bean to define the filter behavior:

Code Block
languagejava
from("direct:start")
    .filter().method(MyBean.class, "isGoldCustomer").to("mock:result").end()
    .to("mock:end");

public static class MyBean {
    public boolean isGoldCustomer(@Header("level") String level) { 
        return level.equals("gold"); 
    }
}

Using the Spring XML Extensions

Wiki Markup
{snippet:id=example|lang=xml|url=camel/trunk/components/camel-spring/src/test/resources/org/apache/camel/spring/xml/buildSimpleRouteWithHeaderPredicate.xml}
You can also use a method call expression (to call a method on a bean) in the Message Filter, as shown below:

Code Block
languagexml
<bean id="myBean" class="com.foo.MyBean"/>

...



<camelContext xmlns="http://camel.apache.org/schema/spring">

...

    <route>

...


    <route>
        <from uri="direct:a"/>

...

        <filter>

...


        <filter>
            <method ref="myBean" method="isGoldCustomer"/>

...


            <to uri="direct:b"/>

...

        </filter>
    </route>

...


        </filter>
    </route>
</camelContext>
Info
titlefiltered endpoint required inside Filtered Endpoint Required Inside </filter> tagTag

make sure Ensure you put the endpoint you want to filter (<to uri="seda:b"/>, etc.) before the closing closing </filter> tag or the filter will not be applied (in . From Camel 2.8+, : omitting this will result in an error).

For further examples of this pattern in use you could look at the junit test case

...

Using stop()

Stop is a bit different than a message filter as it will filter out all messages and end the route entirely (filter only applies to its child processor). Stop is convenient to use in a Content Based Router when you for example need to stop further processing in one of the predicates.

In the example below we do not want to route messages any further that has the word Bye in the message body. Notice how we prevent this in the the when() predicate by using the .stop().

Wiki Markup
{snippet:id=e1|lang=java|url=camel/trunk/camel-core/src/test/java/org/apache/camel/processor/RouteStopTest.java}

...

How To Determine If An  Exchange Was Filtered

Available as of Camel 2.5

The Message Filter EIP will add a property on the Exchange that states if it was filtered or not.

The property has the key Exchange.FILTER_MATCHED, which has the String value of CamelFilterMatched. Its value is a boolean indicating true or false. If the value is true then the Exchange was routed in the filter block. This property will be visible within the Message Filter block who's Predicate matches (value set to true), and to the steps immediately following the Message Filter with the value set based on the results of the last Message Filter Predicate evaluated.

...