diff options
author | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-06-01 13:40:02 +0000 |
---|---|---|
committer | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-06-01 13:40:02 +0000 |
commit | be4d55fe8d843628223a7b40162007ab734d1402 (patch) | |
tree | d8ecca580b0561fab811d41447339cfd473ae229 /net/base | |
parent | 221e544540fc33994373a8e88ba68300f840da75 (diff) | |
download | chromium_src-be4d55fe8d843628223a7b40162007ab734d1402.zip chromium_src-be4d55fe8d843628223a7b40162007ab734d1402.tar.gz chromium_src-be4d55fe8d843628223a7b40162007ab734d1402.tar.bz2 |
Move net::HTTPSProber from net_base to net
net::HTTPSProber belongs into the net library, where also it's only user
net::URLRequest is living. This fixes undefined references in net_base caused
by net::HTTPSProber when not linking against net.
BUG=45493
TEST=Building hresolv with the plain ld linker in shared library configuration should not generate undefined references.
Review URL: http://codereview.chromium.org/2441001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@48632 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/base')
-rw-r--r-- | net/base/https_prober.cc | 80 | ||||
-rw-r--r-- | net/base/https_prober.h | 73 |
2 files changed, 0 insertions, 153 deletions
diff --git a/net/base/https_prober.cc b/net/base/https_prober.cc deleted file mode 100644 index c37f17d..0000000 --- a/net/base/https_prober.cc +++ /dev/null @@ -1,80 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "net/base/https_prober.h" - -#include "net/url_request/url_request.h" -#include "net/url_request/url_request_context.h" - -namespace net { - -bool HTTPSProber::HaveProbed(const std::string& host) const { - return probed_.find(host) != probed_.end(); -} - -bool HTTPSProber::InFlight(const std::string& host) const { - return inflight_probes_.find(host) != inflight_probes_.end(); -} - -bool HTTPSProber::ProbeHost(const std::string& host, URLRequestContext* ctx, - HTTPSProberDelegate* delegate) { - if (HaveProbed(host) || InFlight(host)) { - return false; - } - - inflight_probes_[host] = delegate; - - GURL url("https://" + host); - DCHECK_EQ(url.host(), host); - - URLRequest* req = new URLRequest(url, this); - req->set_context(ctx); - req->Start(); - return true; -} - -void HTTPSProber::Success(URLRequest* request) { - DoCallback(request, true); -} - -void HTTPSProber::Failure(URLRequest* request) { - DoCallback(request, false); -} - -void HTTPSProber::DoCallback(URLRequest* request, bool result) { - std::map<std::string, HTTPSProberDelegate*>::iterator i = - inflight_probes_.find(request->original_url().host()); - DCHECK(i != inflight_probes_.end()); - - HTTPSProberDelegate* delegate = i->second; - inflight_probes_.erase(i); - probed_.insert(request->original_url().host()); - delete request; - delegate->ProbeComplete(result); -} - -void HTTPSProber::OnAuthRequired(URLRequest* request, - net::AuthChallengeInfo* auth_info) { - Success(request); -} - -void HTTPSProber::OnSSLCertificateError(URLRequest* request, - int cert_error, - net::X509Certificate* cert) { - request->ContinueDespiteLastError(); -} - -void HTTPSProber::OnResponseStarted(URLRequest* request) { - if (request->status().status() == URLRequestStatus::SUCCESS) { - Success(request); - } else { - Failure(request); - } -} - -void HTTPSProber::OnReadCompleted(URLRequest* request, int bytes_read) { - NOTREACHED(); -} - -} // namespace net diff --git a/net/base/https_prober.h b/net/base/https_prober.h deleted file mode 100644 index 327fc16..0000000 --- a/net/base/https_prober.h +++ /dev/null @@ -1,73 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef NET_BASE_HTTPS_PROBER_H_ -#define NET_BASE_HTTPS_PROBER_H_ - -#include <map> -#include <set> -#include <string> - -#include "base/singleton.h" -#include "base/task.h" -#include "net/url_request/url_request.h" - -class URLRequestContext; - -namespace net { - -// This should be scoped inside HTTPSProber, but VC cannot compile -// HTTPProber::Delegate when HTTPSProber also inherits from -// URLRequest::Delegate. -class HTTPSProberDelegate { - public: - virtual void ProbeComplete(bool result) = 0; -}; - -// HTTPSProber is a singleton object that manages HTTPS probes. A HTTPS probe -// determines if we can connect to a given host over HTTPS. It's used when -// transparently upgrading from HTTP to HTTPS (for example, for SPDY). -class HTTPSProber : public URLRequest::Delegate { - public: - HTTPSProber() { } - - // HaveProbed returns true if the given host is known to have been probed - // since the browser was last started. - bool HaveProbed(const std::string& host) const; - - // InFlight returns true iff a probe for the given host is currently active. - bool InFlight(const std::string& host) const; - - // ProbeHost starts a new probe for the given host. If the host is known to - // have been probed since the browser was started, false is returned and no - // other action is taken. If a probe to the given host in currently inflight, - // false will be returned, and no other action is taken. Otherwise, a new - // probe is started, true is returned and the Delegate will be called with the - // results (true means a successful handshake). - bool ProbeHost(const std::string& host, URLRequestContext* ctx, - HTTPSProberDelegate* delegate); - - // Implementation of URLRequest::Delegate - void OnAuthRequired(URLRequest* request, - net::AuthChallengeInfo* auth_info); - void OnSSLCertificateError(URLRequest* request, - int cert_error, - net::X509Certificate* cert); - void OnResponseStarted(URLRequest* request); - void OnReadCompleted(URLRequest* request, int bytes_read); - - private: - void Success(URLRequest* request); - void Failure(URLRequest* request); - void DoCallback(URLRequest* request, bool result); - - std::map<std::string, HTTPSProberDelegate*> inflight_probes_; - std::set<std::string> probed_; - - friend struct DefaultSingletonTraits<HTTPSProber>; - DISALLOW_EVIL_CONSTRUCTORS(HTTPSProber); -}; - -} // namespace net -#endif |