1069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/*
2069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $HeadURL: http://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk/module-client/src/main/java/org/apache/http/impl/conn/DefaultClientConnection.java $
3069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Revision: 673450 $
4069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Date: 2008-07-02 10:35:05 -0700 (Wed, 02 Jul 2008) $
5069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
6069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ====================================================================
7069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Licensed to the Apache Software Foundation (ASF) under one
8069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * or more contributor license agreements.  See the NOTICE file
9069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * distributed with this work for additional information
10069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * regarding copyright ownership.  The ASF licenses this file
11069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * to you under the Apache License, Version 2.0 (the
12069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * "License"); you may not use this file except in compliance
13069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * with the License.  You may obtain a copy of the License at
14069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
15069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *   http://www.apache.org/licenses/LICENSE-2.0
16069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
17069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Unless required by applicable law or agreed to in writing,
18069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * software distributed under the License is distributed on an
19069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
20069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * KIND, either express or implied.  See the License for the
21069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * specific language governing permissions and limitations
22069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * under the License.
23069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ====================================================================
24069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
25069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * This software consists of voluntary contributions made by many
26069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * individuals on behalf of the Apache Software Foundation.  For more
27069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * information on the Apache Software Foundation, please see
28069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <http://www.apache.org/>.
29069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
30069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project */
31069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
32069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpackage org.apache.http.impl.conn;
33069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
34069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
35069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport java.io.IOException;
36069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport java.net.Socket;
37069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
38069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.commons.logging.Log;
39069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.commons.logging.LogFactory;
40069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.Header;
41069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.HttpException;
42069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.HttpHost;
43069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.HttpRequest;
44069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.HttpResponse;
45069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.HttpResponseFactory;
46069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.params.HttpParams;
47069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.impl.SocketHttpClientConnection;
48069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.io.HttpMessageParser;
49069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.io.SessionInputBuffer;
50069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.io.SessionOutputBuffer;
51069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
52069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectimport org.apache.http.conn.OperatedClientConnection;
53069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
54069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
55069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/**
56069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Default implementation of an operated client connection.
57069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
58069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * @author <a href="mailto:rolandw at apache.org">Roland Weber</a>
59069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
60069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
61069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <!-- empty lines to avoid svn diff problems -->
62069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * @version   $Revision: 673450 $ $Date: 2008-07-02 10:35:05 -0700 (Wed, 02 Jul 2008) $
63069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
64069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * @since 4.0
65d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *
66d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * @deprecated Please use {@link java.net.URL#openConnection} instead.
67d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *     Please visit <a href="http://android-developers.blogspot.com/2011/09/androids-http-clients.html">this webpage</a>
68d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *     for further details.
69069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project */
70d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath@Deprecated
71069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpublic class DefaultClientConnection extends SocketHttpClientConnection
72069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    implements OperatedClientConnection {
73069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
74069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private final Log log = LogFactory.getLog(getClass());
75069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private final Log headerLog = LogFactory.getLog("org.apache.http.headers");
76069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private final Log wireLog = LogFactory.getLog("org.apache.http.wire");
77069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
78069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /** The unconnected socket */
79069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private volatile Socket socket;
80069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
81069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /** The target host of this connection. */
82069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private HttpHost targetHost;
83069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
84069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /** Whether this connection is secure. */
85069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private boolean connSecure;
86069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
87069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /** True if this connection was shutdown. */
88069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    private volatile boolean shutdown;
89069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
90069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public DefaultClientConnection() {
91069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        super();
92069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
93069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
94069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
95069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    // non-javadoc, see interface OperatedClientConnection
96069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public final HttpHost getTargetHost() {
97069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return this.targetHost;
98069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
99069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
100069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
101069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    // non-javadoc, see interface OperatedClientConnection
102069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public final boolean isSecure() {
103069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return this.connSecure;
104069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
105069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
106069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
107069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
108069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public final Socket getSocket() {
109069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return this.socket;
110069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
111069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
112069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
113069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void opening(Socket sock, HttpHost target) throws IOException {
114069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        assertNotOpen();
115069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        this.socket = sock;
116069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        this.targetHost = target;
117069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
118069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        // Check for shutdown after assigning socket, so that
119069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (this.shutdown) {
120069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            sock.close(); // allow this to throw...
121069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            // ...but if it doesn't, explicitly throw one ourselves.
122069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            throw new IOException("Connection already shutdown");
123069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
124069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
125069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
126069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
127069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void openCompleted(boolean secure, HttpParams params) throws IOException {
128069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        assertNotOpen();
129069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (params == null) {
130069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            throw new IllegalArgumentException
131069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                ("Parameters must not be null.");
132069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
133069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        this.connSecure = secure;
134069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        bind(this.socket, params);
135069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
136069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
137069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /**
138069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * Force-closes this connection.
139069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * If the connection is still in the process of being open (the method
140069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * {@link #opening opening} was already called but
141069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * {@link #openCompleted openCompleted} was not), the associated
142069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * socket that is being connected to a remote address will be closed.
143069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * That will interrupt a thread that is blocked on connecting
144069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * the socket.
145069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * If the connection is not yet open, this will prevent the connection
146069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * from being opened.
147069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     *
148069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @throws IOException      in case of a problem
149069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     */
150069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
151069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void shutdown() throws IOException {
152069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        log.debug("Connection shut down");
153069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        shutdown = true;
154069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
155069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        super.shutdown();
156069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        Socket sock = this.socket; // copy volatile attribute
157069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (sock != null)
158069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            sock.close();
159069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
160069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    } // shutdown
161069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
162069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
163069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
164069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void close() throws IOException {
165069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        log.debug("Connection closed");
166069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        super.close();
167069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
168069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
169069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
170069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
171069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    protected SessionInputBuffer createSessionInputBuffer(
172069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final Socket socket,
173069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            int buffersize,
174069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final HttpParams params) throws IOException {
175069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        SessionInputBuffer inbuffer = super.createSessionInputBuffer(
176069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                socket,
177069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                buffersize,
178069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                params);
179069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (wireLog.isDebugEnabled()) {
180069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            inbuffer = new LoggingSessionInputBuffer(inbuffer, new Wire(wireLog));
181069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
182069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return inbuffer;
183069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
184069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
185069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
186069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
187069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    protected SessionOutputBuffer createSessionOutputBuffer(
188069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final Socket socket,
189069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            int buffersize,
190069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final HttpParams params) throws IOException {
191069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        SessionOutputBuffer outbuffer = super.createSessionOutputBuffer(
192069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                socket,
193069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                buffersize,
194069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                params);
195069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (wireLog.isDebugEnabled()) {
196069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            outbuffer = new LoggingSessionOutputBuffer(outbuffer, new Wire(wireLog));
197069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
198069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return outbuffer;
199069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
200069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
201069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
202069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
203069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    protected HttpMessageParser createResponseParser(
204069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final SessionInputBuffer buffer,
205069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final HttpResponseFactory responseFactory,
206069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            final HttpParams params) {
207069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        // override in derived class to specify a line parser
208069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return new DefaultResponseParser
209069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            (buffer, null, responseFactory, params);
210069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
211069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
212069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
213069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    // non-javadoc, see interface OperatedClientConnection
214069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void update(Socket sock, HttpHost target,
215069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                       boolean secure, HttpParams params)
216069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        throws IOException {
217069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
218069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        assertOpen();
219069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (target == null) {
220069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            throw new IllegalArgumentException
221069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                ("Target host must not be null.");
222069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
223069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (params == null) {
224069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            throw new IllegalArgumentException
225069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                ("Parameters must not be null.");
226069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
227069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
228069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (sock != null) {
229069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            this.socket = sock;
230069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            bind(sock, params);
231069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
232069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        targetHost = target;
233069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        connSecure = secure;
234069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
235069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    } // update
236069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
237069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
238069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
239069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public HttpResponse receiveResponseHeader() throws HttpException, IOException {
240069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        HttpResponse response = super.receiveResponseHeader();
241069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (headerLog.isDebugEnabled()) {
242069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            headerLog.debug("<< " + response.getStatusLine().toString());
243069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            Header[] headers = response.getAllHeaders();
244069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            for (Header header : headers) {
245069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                headerLog.debug("<< " + header.toString());
246069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            }
247069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
248069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        return response;
249069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
250069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
251069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
252069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    @Override
253069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    public void sendRequestHeader(HttpRequest request) throws HttpException, IOException {
254069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        super.sendRequestHeader(request);
255069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        if (headerLog.isDebugEnabled()) {
256069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            headerLog.debug(">> " + request.getRequestLine().toString());
257069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            Header[] headers = request.getAllHeaders();
258069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            for (Header header : headers) {
259069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project                headerLog.debug(">> " + header.toString());
260069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            }
261069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project        }
262069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    }
263069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
264069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project} // class DefaultClientConnection
265