| // Copyright (c) 2012 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 CONTENT_BROWSER_SSL_SSL_CERT_ERROR_HANDLER_H_ |
| #define CONTENT_BROWSER_SSL_SSL_CERT_ERROR_HANDLER_H_ |
| |
| #include <string> |
| |
| #include "base/macros.h" |
| #include "base/memory/weak_ptr.h" |
| #include "content/browser/ssl/ssl_error_handler.h" |
| #include "net/ssl/ssl_info.h" |
| |
| namespace content { |
| |
| // A CertError represents an error that occurred with the certificate in an |
| // SSL session. A CertError object exists both on the IO thread and on the UI |
| // thread and allows us to cancel/continue a request it is associated with. |
| class SSLCertErrorHandler : public SSLErrorHandler { |
| public: |
| // Construct on the IO thread. |
| SSLCertErrorHandler(const base::WeakPtr<Delegate>& delegate, |
| ResourceType resource_type, |
| const GURL& url, |
| const net::SSLInfo& ssl_info, |
| bool fatal); |
| |
| SSLCertErrorHandler* AsSSLCertErrorHandler() override; |
| |
| // These accessors are available on either thread |
| const net::SSLInfo& ssl_info() const { return ssl_info_; } |
| int cert_error() const { return cert_error_; } |
| bool fatal() const { return fatal_; } |
| |
| protected: |
| // SSLErrorHandler methods |
| void OnDispatchFailed() override; |
| void OnDispatched() override; |
| |
| private: |
| ~SSLCertErrorHandler() override; |
| |
| // These read-only members may be accessed on any thread. |
| const net::SSLInfo ssl_info_; |
| const int cert_error_; // The error we represent. |
| const bool fatal_; // True if the error is from a host requiring |
| // certificate errors to be fatal. |
| |
| DISALLOW_COPY_AND_ASSIGN(SSLCertErrorHandler); |
| }; |
| |
| } // namespace content |
| |
| #endif // CONTENT_BROWSER_SSL_SSL_CERT_ERROR_HANDLER_H_ |