org.jumpmind.symmetric.web.compression.CompressionServletResponseWrapper Maven / Gradle / Ivy
/**
* Licensed to JumpMind Inc under one or more contributor
* license agreements. See the NOTICE file distributed
* with this work for additional information regarding
* copyright ownership. JumpMind Inc licenses this file
* to you under the GNU General Public License, version 3.0 (GPLv3)
* (the "License"); you may not use this file except in compliance
* with the License.
*
* You should have received a copy of the GNU General Public License,
* version 3.0 (GPLv3) along with this library; if not, see
* .
*
* 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.jumpmind.symmetric.web.compression;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.util.zip.Deflater;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Implementation of HttpServletResponseWrapper that works with the
* CompressionServletResponseStream implementation..
*
* This package is derived from the Jakarta Tomcat examples compression
* filter and is distributed in SymmetricDS for convenience.
*
* @author Amy Roh
* @author Dmitri Valdin
* @version $Revision: 496190 $, $Date: 2007-01-14 16:21:45 -0700 (Sun, 14 Jan
* 2007) $
*/
public class CompressionServletResponseWrapper extends HttpServletResponseWrapper {
static final Logger log = LoggerFactory.getLogger(CompressionServletResponseWrapper.class);
int compressionLevel = Deflater.DEFAULT_COMPRESSION;
int compressionStrategy = Deflater.DEFAULT_STRATEGY;
/**
* Calls the parent constructor which creates a ServletResponse adaptor
* wrapping the given response object.
*/
public CompressionServletResponseWrapper(HttpServletResponse response, int compressionLevel, int compressionStrategy) {
super(response);
this.compressionLevel = compressionLevel;
this.compressionStrategy = compressionStrategy;
origResponse = response;
log.debug("CompressionServletResponseWrapper constructor gets called");
}
/**
* Original response
*/
protected HttpServletResponse origResponse = null;
/**
* Descriptive information about this Response implementation.
*/
protected static final String info = "CompressionServletResponseWrapper";
/**
* The ServletOutputStream that has been returned by
* getOutputStream()
, if any.
*/
protected ServletOutputStream stream = null;
/**
* The PrintWriter that has been returned by getWriter()
, if
* any.
*/
protected PrintWriter writer = null;
/**
* Content type
*/
protected String contentType = null;
// --------------------------------------------------------- Public Methods
/**
* Set content type
*/
public void setContentType(String contentType) {
log.debug("setContentType to {}", contentType);
this.contentType = contentType;
origResponse.setContentType(contentType);
}
/**
* Create and return a ServletOutputStream to write the content associated
* with this Response.
*
* @exception IOException
* if an input/output error occurs
*/
public ServletOutputStream createOutputStream() throws IOException {
log.debug("createOutputStream gets called");
CompressionResponseStream stream = new CompressionResponseStream(origResponse, compressionLevel,
compressionStrategy);
return stream;
}
/**
* Finish a response.
*/
public void finishResponse() {
try {
if (writer != null) {
writer.close();
} else {
if (stream != null)
stream.close();
}
} catch (IOException e) {
}
}
// ------------------------------------------------ ServletResponse Methods
/**
* Flush the buffer and commit this response.
*
* @exception IOException
* if an input/output error occurs
*/
public void flushBuffer() throws IOException {
log.debug("flush buffer @ CompressionServletResponseWrapper");
((CompressionResponseStream) stream).flush();
}
/**
* Return the servlet output stream associated with this Response.
*
* @exception IllegalStateException
* if getWriter
has already been called for this
* response
* @exception IOException
* if an input/output error occurs
*/
public ServletOutputStream getOutputStream() throws IOException {
if (writer != null)
throw new IllegalStateException("getWriter() has already been called for this response");
if (stream == null)
stream = createOutputStream();
log.debug("stream is set to {} in getOutputStream", stream);
return (stream);
}
/**
* Return the writer associated with this Response.
*
* @exception IllegalStateException
* if getOutputStream
has already been called
* for this response
* @exception IOException
* if an input/output error occurs
*/
public PrintWriter getWriter() throws IOException {
if (writer != null)
return (writer);
if (stream != null)
throw new IllegalStateException("getOutputStream() has already been called for this response");
stream = createOutputStream();
log.debug("stream is set to {} in getWriter", stream);
// String charset = getCharsetFromContentType(contentType);
String charEnc = origResponse.getCharacterEncoding();
log.debug("character encoding is {}", charEnc);
// HttpServletResponse.getCharacterEncoding() shouldn't return null
// according the spec, so feel free to remove that "if"
if (charEnc != null) {
writer = new PrintWriter(new OutputStreamWriter(stream, charEnc));
} else {
writer = new PrintWriter(stream);
}
return (writer);
}
public void setContentLength(int length) {
}
}