01: /*
02: * $HeadURL$
03: * $Revision$
04: * $Date$
05: *
06: * ====================================================================
07: * Licensed to the Apache Software Foundation (ASF) under one
08: * or more contributor license agreements. See the NOTICE file
09: * distributed with this work for additional information
10: * regarding copyright ownership. The ASF licenses this file
11: * to you under the Apache License, Version 2.0 (the
12: * "License"); you may not use this file except in compliance
13: * with the License. You may obtain a copy of the License at
14: *
15: * http://www.apache.org/licenses/LICENSE-2.0
16: *
17: * Unless required by applicable law or agreed to in writing,
18: * software distributed under the License is distributed on an
19: * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
20: * KIND, either express or implied. See the License for the
21: * specific language governing permissions and limitations
22: * under the License.
23: * ====================================================================
24: *
25: * This software consists of voluntary contributions made by many
26: * individuals on behalf of the Apache Software Foundation. For more
27: * information on the Apache Software Foundation, please see
28: * <http://www.apache.org/>.
29: *
30: */
31:
32: package org.apache.axis2.transport.nhttp;
33:
34: import java.io.IOException;
35:
36: import org.apache.commons.logging.Log;
37: import org.apache.commons.logging.LogFactory;
38: import org.apache.http.Header;
39: import org.apache.http.HttpException;
40: import org.apache.http.HttpRequestFactory;
41: import org.apache.http.HttpResponse;
42: import org.apache.http.impl.nio.DefaultNHttpServerConnection;
43: import org.apache.http.nio.reactor.IOSession;
44: import org.apache.http.nio.util.ByteBufferAllocator;
45: import org.apache.http.params.HttpParams;
46:
47: public class LoggingNHttpServerConnection extends
48: DefaultNHttpServerConnection {
49:
50: private final Log log;
51: private final Log headerlog;
52:
53: public LoggingNHttpServerConnection(final IOSession session,
54: final HttpRequestFactory requestFactory,
55: final ByteBufferAllocator allocator, final HttpParams params) {
56: super (session, requestFactory, allocator, params);
57: this .log = LogFactory
58: .getLog(DefaultNHttpServerConnection.class);
59: this .headerlog = LogFactory
60: .getLog("org.apache.axis2.transport.nhttp.headers");
61: }
62:
63: public void submitResponse(final HttpResponse response)
64: throws IOException, HttpException {
65: if (this .log.isDebugEnabled()) {
66: this .log.debug("HTTP connection " + this + ": "
67: + response.getStatusLine().toString());
68: }
69: super .submitResponse(response);
70: if (this .headerlog.isDebugEnabled()) {
71: this .headerlog.debug("<< "
72: + response.getStatusLine().toString());
73: Header[] headers = response.getAllHeaders();
74: for (int i = 0; i < headers.length; i++) {
75: this .headerlog.debug("<< " + headers[i].toString());
76: }
77: }
78: }
79:
80: }
|