/*
* Copyright 1999-2004 The Apache Software Foundation.
*
* 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.
*/
/* $Id$ */
package org.apache.fop.servlet;
import java.io.File;
import java.io.InputStream;
import java.io.PrintWriter;
// JAXP
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.sax.SAXResult;
import javax.xml.transform.stream.StreamSource;
// XML
import org.apache.commons.logging.impl.SimpleLog;
import org.apache.commons.logging.Log;
import org.apache.fop.apps.Fop;
import org.xml.sax.InputSource;
//Java
import java.io.File;
import java.io.IOException;
import java.io.OutputStream;
/**
* Example servlet to generate a fop printout from a servlet.
* Printing goes to the default printer on host where the servlet executes.
* Servlet param is:
*
* - fo: the path to a XSL-FO file to render
*
* or
*
* - xml: the path to an XML file to render
* - xslt: the path to an XSLT file that can transform the above XML to XSL-FO
*
*
* Example URL: http://servername/fop/servlet/FopPrintServlet?fo=readme.fo
*
* Example URL: http://servername/fop/servlet/FopPrintServlet?xml=data.xml&xsl=format.xsl
*
* @author Apache XML FOP Development Team
* @version $Id: FopPrintServlet.java,v 1.2 2003/03/07 09:48:05 jeremias Exp $
* (todo) Doesn't work since there's no AWTRenderer at the moment. Revisit when
* available.
* (todo) Ev. add caching mechanism for Templates objects
*/
public class FopPrintServlet extends HttpServlet {
/** Name of the parameter used for the XSL-FO file */
protected static final String FO_REQUEST_PARAM = "fo";
/** Name of the parameter used for the XML file */
protected static final String XML_REQUEST_PARAM = "xml";
/** Name of the parameter used for the XSLT file */
protected static final String XSLT_REQUEST_PARAM = "xslt";
/** Logger to give to FOP */
protected SimpleLog log = null;
/** The TransformerFactory to use to create Transformer instances */
protected TransformerFactory transFactory = null;
/**
* @see javax.servlet.GenericServlet#init()
*/
public void init() throws ServletException {
this.log = new SimpleLog("FOP/Print Servlet");
log.setLevel(SimpleLog.LOG_LEVEL_WARN);
this.transFactory = TransformerFactory.newInstance();
}
/**
* @see javax.servlet.http.HttpServlet#doGet(HttpServletRequest, HttpServletResponse)
*/
public void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException {
if (log == null) {
log = new SimpleLog("FOP/Print Servlet");
log.setLevel(SimpleLog.LOG_LEVEL_WARN);
}
try {
String foParam = request.getParameter(FO_REQUEST_PARAM);
String xmlParam = request.getParameter(XML_REQUEST_PARAM);
String xsltParam = request.getParameter(XSLT_REQUEST_PARAM);
if (foParam != null) {
InputStream file = new java.io.FileInputStream(foParam);
renderFO(file, response);
} else if ((xmlParam != null) && (xsltParam != null)) {
renderXML(new File(xmlParam), new File(xsltParam), response);
} else {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("Error\n"
+ "FopServlet Error
\n"
+ "No 'fo' or 'xml/xsl' "
+ "request param given.
\n");
}
} catch (ServletException ex) {
throw ex;
} catch (Exception ex) {
throw new ServletException(ex);
}
}
/**
* Renders an FO inputsource to the default printer.
* @param foFile The XSL-FO file
* @param response Response to write to
* @throws ServletException In case of a problem
*/
public void renderFO(InputStream foFile,
HttpServletResponse response) throws ServletException {
try {
Fop fop = new Fop(Fop.RENDER_PRINT);
// Setup JAXP
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer(); //identity transformer
// Setup input for XSLT transformation
Source src = new StreamSource(foFile);
// Resulting SAX events (the generated FO) must be piped through to FOP
Result res = new SAXResult(fop.getDefaultHandler());
// Start XSLT transformation and FOP processing
transformer.transform(src, res);
reportOK (response);
} catch (Exception ex) {
throw new ServletException(ex);
}
}
/**
* Renders an FO generated using an XML and a stylesheet to the default printer.
* @param xmlfile XML file object
* @param xsltfile XSLT stylesheet
* @param response HTTP response object
* @throws ServletException In case of a problem
*/
public void renderXML(File xmlfile, File xsltfile,
HttpServletResponse response) throws ServletException {
try {
Fop fop = new Fop(Fop.RENDER_PRINT);
// Setup XSLT
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer(new StreamSource(xsltfile));
// Setup input for XSLT transformation
Source src = new StreamSource(xmlfile);
// Resulting SAX events (the generated FO) must be piped through to FOP
Result res = new SAXResult(fop.getDefaultHandler());
// Start XSLT transformation and FOP processing
transformer.transform(src, res);
reportOK (response);
} catch (Exception ex) {
throw new ServletException(ex);
}
}
// private helper, tell (browser) user that file printed
private void reportOK(HttpServletResponse response)
throws ServletException {
String sMsg = "Success\n"
+ "FopPrintServlet:
"
+ "The requested data was printed
";
response.setContentType("text/html");
response.setContentLength(sMsg.length());
try {
PrintWriter out = response.getWriter();
out.println(sMsg);
out.flush();
} catch (Exception ex) {
throw new ServletException(ex);
}
}
}