package org.toobsframework.servlet.filters.export;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.toobsframework.servlet.filters.compression.FilterResponseWrapper;
import org.toobsframework.util.Configuration;
public class XLSExportFilter extends BaseExportFilter implements Filter {
// TODO: generate a serialVersionUID
/** The logger instance */
private static Log log = LogFactory.getLog(XLSExportFilter.class);
/** The Filter config */
private FilterConfig config = null;
public void init(FilterConfig config)
throws ServletException
{
this.config = config;
this.config.getServletContext().log("XLSFilter - init()");
}
public void destroy() {
this.config.getServletContext().log("XLSFilter - destroy()");
this.config = null;
}
/**
* Pipe the fetched *.xls <fo> xml output from the ComponentLayoutManager through the FO transformer
* in order to get a viable pdf file. Set the response headers, response stream, and the browser
* should pick the pdf up and handle it properly.
*/
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException
{
this.config.getServletContext().log("XLSFilter - doFilter(...)");
log.debug("ENTER doFilter(...)");
HttpServletResponse httpResponse = (HttpServletResponse) response;
HttpServletRequest httpRequest = (HttpServletRequest) request;
// set headers so browser knows it's looking at a pdf
//httpResponse.setHeader("Content-Disposition", "attachment");
//first chain the filters... ie do everything else first... this filter
//will work on the data that comes back after the transform has already been run
FilterResponseWrapper wrapper = new FilterResponseWrapper(httpResponse);
chain.doFilter(request, wrapper);
String fileName;
String exportMode = httpRequest.getParameter("exportMode");
if ("table".equals(exportMode)) {
fileName = httpRequest.getParameter("component") + ".xls";
} else {
fileName = httpRequest.getRequestURI().substring(Configuration.getInstance().getMainContext().length() + 1).replace("xxls", "xls");
}
// set headers so browser knows it's looking at a pdf
httpResponse.setContentType("application/vnd.ms-excel");
httpResponse.setHeader("Pragma", "public");
httpResponse.setDateHeader("Expires", 0);
httpResponse.setHeader("Cache-Control","must-revalidate, post-check=0, pre-check=0");
httpResponse.setHeader("Cache-Control","public");
httpResponse.setHeader("Content-Description","File Transfer");
httpResponse.setHeader("Content-Disposition","attachment; filename=\"" + fileName + "\"");
//now fetch the output stream and response data
ServletOutputStream httpOutputStream = httpResponse.getOutputStream();
byte[] responseData = wrapper.getData();
httpOutputStream.write(responseData);
if (log.isDebugEnabled()) {
log.debug("EXIT doFilter(...)");
}
}
}