Search in sources :

Example 6 with RouteMatch

use of spark.routematch.RouteMatch in project spark by perwendel.

the class AfterAfterFilters method execute.

static void execute(RouteContext context) throws Exception {
    Object content = context.body().get();
    List<RouteMatch> matchSet = context.routeMatcher().findMultiple(HttpMethod.afterafter, context.uri(), context.acceptType());
    for (RouteMatch filterMatch : matchSet) {
        Object filterTarget = filterMatch.getTarget();
        if (filterTarget instanceof FilterImpl) {
            if (context.requestWrapper().getDelegate() == null) {
                Request request = RequestResponseFactory.create(filterMatch, context.httpRequest());
                context.requestWrapper().setDelegate(request);
            } else {
                context.requestWrapper().changeMatch(filterMatch);
            }
            context.responseWrapper().setDelegate(context.response());
            FilterImpl filter = (FilterImpl) filterTarget;
            filter.handle(context.requestWrapper(), context.responseWrapper());
            String bodyAfterFilter = context.response().body();
            if (bodyAfterFilter != null) {
                content = bodyAfterFilter;
            }
        }
    }
    context.body().set(content);
}
Also used : FilterImpl(spark.FilterImpl) Request(spark.Request) RouteMatch(spark.routematch.RouteMatch)

Aggregations

RouteMatch (spark.routematch.RouteMatch)6 Request (spark.Request)4 FilterImpl (spark.FilterImpl)3 ArrayList (java.util.ArrayList)1 RouteImpl (spark.RouteImpl)1