-
Notifications
You must be signed in to change notification settings - Fork 2.4k
Filters
Filters must extend ZuulFilter and implement the following methods:
String filterType();
int filterOrder();
boolean shouldFilter();
Object run();The method shouldFilter() returns a boolean indicating if the Filter should run or not.
The method [filterOrder()](http://netflix.github.io/zuul/javadoc/zuul-core/com/netflix/zuul/ZuulFilter.html#filterOrder() returns an int describing the order that the Filter should run in relative to others.
A Filter's type is a String which can be any value that you desire. There are 2 uses for this:
-
Zuul's primary request lifecycle consists of "pre", "routing", and "post" phases, in that order. All filters with these types are run for every request.
-
Filters of any type can be explicitly run using the method GroovyProcessor.runFilters(String type).
Filters have no direct way of accessing each other. They can share state using RequestContext which is a Map-like structure with some explicit accessor methods for data considered primitive to Zuul.
A Netflix Original Production
Tech Blog | Twitter @NetflixOSS | Jobs
-
Zuul 3.x
-
Zuul 2.x
-
Zuul 1.x