Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "jingle/notifier/base/proxy_resolving_client_socket.h" | 5 #include "jingle/notifier/base/proxy_resolving_client_socket.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/bind_helpers.h" | 9 #include "base/bind_helpers.h" |
| 10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
| (...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 165 CloseTransportSocket(); | 165 CloseTransportSocket(); |
| 166 RunUserConnectCallback(status); | 166 RunUserConnectCallback(status); |
| 167 return; | 167 return; |
| 168 } | 168 } |
| 169 } | 169 } |
| 170 | 170 |
| 171 transport_.reset(new net::ClientSocketHandle); | 171 transport_.reset(new net::ClientSocketHandle); |
| 172 // Now that we have resolved the proxy, we need to connect. | 172 // Now that we have resolved the proxy, we need to connect. |
| 173 status = net::InitSocketHandleForRawConnect( | 173 status = net::InitSocketHandleForRawConnect( |
| 174 dest_host_port_pair_, network_session_.get(), proxy_info_, ssl_config_, | 174 dest_host_port_pair_, network_session_.get(), proxy_info_, ssl_config_, |
| 175 ssl_config_, bound_net_log_, transport_.get(), connect_callback_); | 175 ssl_config_, bound_net_log_, transport_.get(), connect_callback_, |
| 176 base::Bind(&ProxyResolvingClientSocket::OnNeedsProxyTunnelAuthCallback, | |
| 177 base::Unretained(this))); | |
|
akalin
2012/01/19 21:20:40
is it really safe to use Unretained here? If so i
| |
| 176 if (status != net::ERR_IO_PENDING) { | 178 if (status != net::ERR_IO_PENDING) { |
| 177 // Since this method is always called asynchronously. it is OK to call | 179 // Since this method is always called asynchronously. it is OK to call |
| 178 // ProcessConnectDone synchronously. | 180 // ProcessConnectDone synchronously. |
| 179 ProcessConnectDone(status); | 181 ProcessConnectDone(status); |
| 180 } | 182 } |
| 181 } | 183 } |
| 182 | 184 |
| 185 void ProxyResolvingClientSocket::OnNeedsProxyTunnelAuthCallback( | |
| 186 const net::HttpResponseInfo& response_info, | |
| 187 net::HttpAuthController* auth_controller, | |
| 188 net::CompletionCallback callback) { | |
| 189 // Since have not way to respond, simply invoke the callback and the | |
| 190 // request will fail. | |
| 191 callback.Run(net::OK); | |
| 192 } | |
| 193 | |
| 183 void ProxyResolvingClientSocket::ProcessConnectDone(int status) { | 194 void ProxyResolvingClientSocket::ProcessConnectDone(int status) { |
| 184 if (status != net::OK) { | 195 if (status != net::OK) { |
| 185 // If the connection fails, try another proxy. | 196 // If the connection fails, try another proxy. |
| 186 status = ReconsiderProxyAfterError(status); | 197 status = ReconsiderProxyAfterError(status); |
| 187 // ReconsiderProxyAfterError either returns an error (in which case it is | 198 // ReconsiderProxyAfterError either returns an error (in which case it is |
| 188 // not reconsidering a proxy) or returns ERR_IO_PENDING if it is considering | 199 // not reconsidering a proxy) or returns ERR_IO_PENDING if it is considering |
| 189 // another proxy. | 200 // another proxy. |
| 190 DCHECK_NE(status, net::OK); | 201 DCHECK_NE(status, net::OK); |
| 191 if (status == net::ERR_IO_PENDING) | 202 if (status == net::ERR_IO_PENDING) |
| 192 // Proxy reconsideration pending. Return. | 203 // Proxy reconsideration pending. Return. |
| (...skipping 173 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 366 return base::TimeDelta::FromMicroseconds(-1); | 377 return base::TimeDelta::FromMicroseconds(-1); |
| 367 } | 378 } |
| 368 | 379 |
| 369 void ProxyResolvingClientSocket::CloseTransportSocket() { | 380 void ProxyResolvingClientSocket::CloseTransportSocket() { |
| 370 if (transport_.get() && transport_->socket()) | 381 if (transport_.get() && transport_->socket()) |
| 371 transport_->socket()->Disconnect(); | 382 transport_->socket()->Disconnect(); |
| 372 transport_.reset(); | 383 transport_.reset(); |
| 373 } | 384 } |
| 374 | 385 |
| 375 } // namespace notifier | 386 } // namespace notifier |
| OLD | NEW |