/**
* Copyright OPS4J
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.ops4j.pax.wicket.internal.filter;
import java.io.IOException;
import java.util.List;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.Servlet;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* The {@link org.ops4j.pax.wicket.internal.filter.PAXWicketFilterChain} is responsible for dispatching registered filters if applicable and finally to the
* {@link javax.servlet.Servlet} if all filters are respected
*
* @author nmw
* @version $Id: $Id
*/
public class PAXWicketFilterChain implements FilterChain {
private static final Logger LOGGER = LoggerFactory.getLogger(PAXWicketFilterChain.class);
private int filterIndex = 0;
private final List<Filter> filters;
private final Servlet delegateServlet;
/**
* <p>Constructor for PAXWicketFilterChain.</p>
*
* @param filter a {@link java.util.List} object.
* @param delegateServlet a {@link javax.servlet.Servlet} object.
*/
public PAXWicketFilterChain(List<Filter> filter, Servlet delegateServlet) {
filters = filter;
this.delegateServlet = delegateServlet;
}
/** {@inheritDoc} */
public void doFilter(ServletRequest request, ServletResponse response) throws IOException, ServletException {
int size = filters.size();
if (filterIndex < size) {
Filter filter = filters.get(filterIndex);
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("call filter {}/{} of type {} ", new Object[]{ (filterIndex + 1), size,
filter.getClass().getName() });
}
filterIndex++;
filter.doFilter(request, response, this);
} else {
LOGGER.debug("No more filters in chain, delegate to servlet");
delegateServlet.service(request, response);
}
}
}