/* * GeoTools - The Open Source Java GIS Toolkit * http://geotools.org * * (C) 2004-2008, Open Source Geospatial Foundation (OSGeo) * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. */ package org.geotools.data.ows; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.URL; import java.util.logging.Level; import java.util.logging.Logger; public class LoggingHTTPClient extends DelegateHTTPClient { private String charsetName; private static final int DEFAULT_BUFFER_SIZE = 1024 * 4; private static final Logger LOGGER = Logger.getLogger("org.geotools.data.ows.httpclient"); public LoggingHTTPClient(HTTPClient delegate) { this(delegate, "UTF-8"); } public LoggingHTTPClient(HTTPClient delegate, String charsetName) { super(delegate); this.charsetName = charsetName; } @Override public HTTPResponse post(URL url, InputStream postContent, String postContentType) throws IOException { if (LOGGER.isLoggable(Level.FINEST)) { ByteArrayOutputStream out = new ByteArrayOutputStream(); copy(postContent, out); LOGGER.finest("POST Request URL: " + url); LOGGER.finest("POST Request Body: \n" + out.toString(charsetName)); return new LoggingHTTPResponse(delegate.post(url, new ByteArrayInputStream(out.toByteArray()), postContentType), charsetName); } else { return delegate.post(url, postContent, postContentType); } } @Override public HTTPResponse get(URL url) throws IOException { if (LOGGER.isLoggable(Level.FINEST)) { LOGGER.finest("GET Request URL: " + url); return new LoggingHTTPResponse(delegate.get(url), charsetName); } else { return delegate.get(url); } } public static void copy(InputStream input, OutputStream output) throws IOException { byte[] buffer = new byte[DEFAULT_BUFFER_SIZE]; int n = 0; while (-1 != (n = input.read(buffer))) { output.write(buffer, 0, n); } } class LoggingHTTPResponse extends DelegateHTTPResponse { private InputStream input; public LoggingHTTPResponse(HTTPResponse delegate, String charsetName) throws IOException { super(delegate); ByteArrayOutputStream output = new ByteArrayOutputStream(); LoggingHTTPClient.copy(delegate.getResponseStream(), output); LOGGER.finest("Response: \n" + output.toString(charsetName)); input = new ByteArrayInputStream(output.toByteArray()); } @Override public InputStream getResponseStream() throws IOException { return input; } } }