/*
 * Copyright (c) 2008, Oracle and its affiliates. All rights reserved.
 * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */

/*
 * $Id$
 */

package @package@;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.ServletResponse;
import java.util.logging.Logger;
import java.util.logging.Level;

public class EJBLiteServlet2Filter extends Client implements Filter {
    private static Logger logger = Logger.getLogger(EJBLiteServlet2Filter.class.getName());
    private FilterConfig filterConfig;

    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain)
            throws IOException, ServletException {
	response.setContentType("text/plain");
        setInjectionSupported(true);
        String tn = request.getParameter("testName");
        if(logger.isLoggable(Level.FINE)) {
            logger.fine("doFilter testName=" + tn);
        }
        setTestName(tn);
	setModuleName( ((HttpServletRequest) request).getContextPath() );
        String sta = getStatus();  //to trigger the test run
        PrintWriter pw = response.getWriter();
        pw.println(sta + " " + getReason());
        cleanup();  //need to reset all fields since filter instances are shared
        //skip the rest of the chain
    }

    public void destroy() {
    }

    public void init(FilterConfig filterConfig) {
        this.filterConfig = filterConfig;
    }
}
