Chromium Code Reviews| Index: chrome/browser/ssl/ssl_tab_helper.cc |
| diff --git a/chrome/browser/ssl/ssl_tab_helper.cc b/chrome/browser/ssl/ssl_tab_helper.cc |
| index 063548ad4c9a16cae81722654c4d849ed96ad8af..be90e46b4aa06f967f97d774e3b77d5f2e3c073a 100644 |
| --- a/chrome/browser/ssl/ssl_tab_helper.cc |
| +++ b/chrome/browser/ssl/ssl_tab_helper.cc |
| @@ -4,189 +4,13 @@ |
| #include "chrome/browser/ssl/ssl_tab_helper.h" |
| -#include <string> |
| -#include <vector> |
| - |
| -#include "base/basictypes.h" |
| -#include "base/command_line.h" |
| -#include "base/strings/string_number_conversions.h" |
| -#include "base/strings/utf_string_conversions.h" |
| -#include "base/values.h" |
| -#include "chrome/browser/certificate_viewer.h" |
| -#include "chrome/browser/chrome_notification_types.h" |
| -#include "chrome/browser/content_settings/host_content_settings_map.h" |
| -#include "chrome/browser/infobars/infobar_service.h" |
| -#include "chrome/browser/profiles/profile.h" |
| -#include "chrome/browser/ssl/ssl_add_cert_handler.h" |
| -#include "chrome/browser/ssl/ssl_client_certificate_selector.h" |
| #include "chrome/browser/ui/browser_finder.h" |
| -#include "chrome/common/chrome_switches.h" |
| -#include "components/infobars/core/confirm_infobar_delegate.h" |
| -#include "components/infobars/core/infobar.h" |
| -#include "components/infobars/core/infobar_manager.h" |
| #include "content/public/browser/web_contents.h" |
| -#include "grit/generated_resources.h" |
| -#include "grit/theme_resources.h" |
| -#include "net/base/net_errors.h" |
| -#include "net/cert/x509_certificate.h" |
| -#include "ui/base/l10n/l10n_util.h" |
| - |
| - |
| -// SSLCertResultInfoBarDelegate ----------------------------------------------- |
| - |
| -namespace { |
| - |
| -class SSLCertResultInfoBarDelegate : public ConfirmInfoBarDelegate { |
| - public: |
| - // Creates an SSL cert result infobar and delegate. If |previous_infobar| is |
| - // NULL, adds the infobar to |infobar_service|; otherwise, replaces |
| - // |previous_infobar|. Returns the new infobar if it was successfully added. |
| - // |cert| is valid iff cert addition was successful. |
| - static infobars::InfoBar* Create(InfoBarService* infobar_service, |
| - infobars::InfoBar* previous_infobar, |
| - const base::string16& message, |
| - net::X509Certificate* cert); |
| - |
| - private: |
| - SSLCertResultInfoBarDelegate(const base::string16& message, |
| - net::X509Certificate* cert); |
| - virtual ~SSLCertResultInfoBarDelegate(); |
| - |
| - // ConfirmInfoBarDelegate: |
| - virtual int GetIconID() const OVERRIDE; |
| - virtual Type GetInfoBarType() const OVERRIDE; |
| - virtual base::string16 GetMessageText() const OVERRIDE; |
| - virtual int GetButtons() const OVERRIDE; |
| - virtual base::string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; |
| - virtual bool Accept() OVERRIDE; |
| - |
| - base::string16 message_; |
| - scoped_refptr<net::X509Certificate> cert_; // The cert we added, if any. |
| - |
| - DISALLOW_COPY_AND_ASSIGN(SSLCertResultInfoBarDelegate); |
| -}; |
| - |
| -// static |
| -infobars::InfoBar* SSLCertResultInfoBarDelegate::Create( |
| - InfoBarService* infobar_service, |
| - infobars::InfoBar* previous_infobar, |
| - const base::string16& message, |
| - net::X509Certificate* cert) { |
| - scoped_ptr<infobars::InfoBar> infobar( |
| - ConfirmInfoBarDelegate::CreateInfoBar(scoped_ptr<ConfirmInfoBarDelegate>( |
| - new SSLCertResultInfoBarDelegate(message, cert)))); |
| - return previous_infobar ? |
| - infobar_service->ReplaceInfoBar(previous_infobar, infobar.Pass()) : |
| - infobar_service->AddInfoBar(infobar.Pass()); |
| -} |
| - |
| -SSLCertResultInfoBarDelegate::SSLCertResultInfoBarDelegate( |
| - const base::string16& message, |
| - net::X509Certificate* cert) |
| - : ConfirmInfoBarDelegate(), |
| - message_(message), |
| - cert_(cert) { |
| -} |
| - |
| -SSLCertResultInfoBarDelegate::~SSLCertResultInfoBarDelegate() { |
| -} |
| - |
| -int SSLCertResultInfoBarDelegate::GetIconID() const { |
| - // TODO(davidben): use a more appropriate icon. |
| - return IDR_INFOBAR_SAVE_PASSWORD; |
| -} |
| - |
| -infobars::InfoBarDelegate::Type SSLCertResultInfoBarDelegate::GetInfoBarType() |
| - const { |
| - return cert_.get() ? PAGE_ACTION_TYPE : WARNING_TYPE; |
| -} |
| - |
| -base::string16 SSLCertResultInfoBarDelegate::GetMessageText() const { |
| - return message_; |
| -} |
| - |
| -int SSLCertResultInfoBarDelegate::GetButtons() const { |
| - return cert_.get() ? BUTTON_OK : BUTTON_NONE; |
| -} |
| - |
| -base::string16 SSLCertResultInfoBarDelegate::GetButtonLabel( |
| - InfoBarButton button) const { |
| - DCHECK_EQ(BUTTON_OK, button); |
| - return l10n_util::GetStringUTF16(IDS_ADD_CERT_SUCCESS_INFOBAR_BUTTON); |
| -} |
| - |
| -bool SSLCertResultInfoBarDelegate::Accept() { |
| - content::WebContents* web_contents = |
| - InfoBarService::WebContentsFromInfoBar(infobar()); |
| - ShowCertificateViewer(web_contents, |
| - web_contents->GetTopLevelNativeWindow(), |
| - cert_.get()); |
| - return false; // Hiding the infobar just as the dialog opens looks weird. |
| -} |
| - |
| -} // namespace |
| - |
| - |
| -// SSLTabHelper::SSLAddCertData ------------------------------------------------ |
| - |
| -class SSLTabHelper::SSLAddCertData : public infobars::InfoBarManager::Observer { |
| - public: |
| - explicit SSLAddCertData(InfoBarService* infobar_service); |
| - virtual ~SSLAddCertData(); |
| - |
| - // Displays an infobar, replacing |infobar_| if it exists. |
| - void ShowInfoBar(const base::string16& message, net::X509Certificate* cert); |
| - |
| - private: |
| - // infobars::InfoBarManager::Observer: |
| - virtual void OnInfoBarRemoved(infobars::InfoBar* infobar, |
| - bool animate) OVERRIDE; |
| - virtual void OnInfoBarReplaced(infobars::InfoBar* old_infobar, |
| - infobars::InfoBar* new_infobar) OVERRIDE; |
| - |
| - InfoBarService* infobar_service_; |
| - infobars::InfoBar* infobar_; |
| - |
| - DISALLOW_COPY_AND_ASSIGN(SSLAddCertData); |
| -}; |
| - |
| -SSLTabHelper::SSLAddCertData::SSLAddCertData(InfoBarService* infobar_service) |
| - : infobar_service_(infobar_service), |
| - infobar_(NULL) { |
| - infobar_service_->AddObserver(this); |
| -} |
| - |
| -SSLTabHelper::SSLAddCertData::~SSLAddCertData() { |
| - infobar_service_->RemoveObserver(this); |
| -} |
| - |
| -void SSLTabHelper::SSLAddCertData::ShowInfoBar(const base::string16& message, |
| - net::X509Certificate* cert) { |
| - infobar_ = SSLCertResultInfoBarDelegate::Create(infobar_service_, infobar_, |
| - message, cert); |
| -} |
| - |
| -void SSLTabHelper::SSLAddCertData::OnInfoBarRemoved(infobars::InfoBar* infobar, |
| - bool animate) { |
| - if (infobar_ == infobar) |
| - infobar_ = NULL; |
| -} |
| - |
| -void SSLTabHelper::SSLAddCertData::OnInfoBarReplaced( |
| - infobars::InfoBar* old_infobar, |
| - infobars::InfoBar* new_infobar) { |
| - if (infobar_ == old_infobar) |
| - infobar_ = NULL; |
| -} |
| - |
| - |
| -// SSLTabHelper ---------------------------------------------------------------- |
| DEFINE_WEB_CONTENTS_USER_DATA_KEY(SSLTabHelper); |
| SSLTabHelper::SSLTabHelper(content::WebContents* contents) |
| - : WebContentsObserver(contents), |
| - web_contents_(contents) { |
| + : WebContentsObserver(contents) { |
| } |
| SSLTabHelper::~SSLTabHelper() { |
| @@ -194,75 +18,8 @@ SSLTabHelper::~SSLTabHelper() { |
| void SSLTabHelper::DidChangeVisibleSSLState() { |
| #if !defined(OS_ANDROID) |
| - Browser* browser = chrome::FindBrowserWithWebContents(web_contents_); |
| + Browser* browser = chrome::FindBrowserWithWebContents(web_contents()); |
| if (browser) |
| - browser->VisibleSSLStateChanged(web_contents_); |
| + browser->VisibleSSLStateChanged(web_contents()); |
|
davidben
2014/05/27 21:07:12
Given that SSLTabHelper's only purpose in life at
|
| #endif // !defined(OS_ANDROID) |
| } |
| - |
| -void SSLTabHelper::ShowClientCertificateRequestDialog( |
| - const net::HttpNetworkSession* network_session, |
| - net::SSLCertRequestInfo* cert_request_info, |
| - const base::Callback<void(net::X509Certificate*)>& callback) { |
| - chrome::ShowSSLClientCertificateSelector(web_contents_, network_session, |
| - cert_request_info, callback); |
| -} |
| - |
| -void SSLTabHelper::OnVerifyClientCertificateError( |
| - scoped_refptr<SSLAddCertHandler> handler, int error_code) { |
| - // Display an infobar with the error message. |
| - // TODO(davidben): Display a more user-friendly error string. |
| - GetAddCertData(handler.get())->ShowInfoBar( |
| - l10n_util::GetStringFUTF16(IDS_ADD_CERT_ERR_INVALID_CERT, |
| - base::IntToString16(-error_code), |
| - base::ASCIIToUTF16( |
| - net::ErrorToString(error_code))), |
| - NULL); |
| -} |
| - |
| -void SSLTabHelper::AskToAddClientCertificate( |
| - scoped_refptr<SSLAddCertHandler> handler) { |
| - NOTREACHED(); // Not implemented yet. |
| -} |
| - |
| -void SSLTabHelper::OnAddClientCertificateSuccess( |
| - scoped_refptr<SSLAddCertHandler> handler) { |
| - net::X509Certificate* cert = handler->cert(); |
| - // TODO(evanm): GetDisplayName should return UTF-16. |
| - GetAddCertData(handler.get())->ShowInfoBar( |
| - l10n_util::GetStringFUTF16(IDS_ADD_CERT_SUCCESS_INFOBAR_LABEL, |
| - base::UTF8ToUTF16( |
| - cert->issuer().GetDisplayName())), |
| - cert); |
| -} |
| - |
| -void SSLTabHelper::OnAddClientCertificateError( |
| - scoped_refptr<SSLAddCertHandler> handler, |
| - int error_code) { |
| - // TODO(davidben): Display a more user-friendly error string. |
| - GetAddCertData(handler.get())->ShowInfoBar( |
| - l10n_util::GetStringFUTF16(IDS_ADD_CERT_ERR_FAILED, |
| - base::IntToString16(-error_code), |
| - base::ASCIIToUTF16( |
| - net::ErrorToString(error_code))), |
| - NULL); |
| -} |
| - |
| -void SSLTabHelper::OnAddClientCertificateFinished( |
| - scoped_refptr<SSLAddCertHandler> handler) { |
| - // Clean up. |
| - request_id_to_add_cert_data_.erase(handler->network_request_id()); |
| -} |
| - |
| -SSLTabHelper::SSLAddCertData* |
| - SSLTabHelper::GetAddCertData(SSLAddCertHandler* handler) { |
| - // Find/create the slot. |
| - linked_ptr<SSLAddCertData>& ptr_ref = |
| - request_id_to_add_cert_data_[handler->network_request_id()]; |
| - // Fill it if necessary. |
| - if (!ptr_ref.get()) { |
| - ptr_ref.reset( |
| - new SSLAddCertData(InfoBarService::FromWebContents(web_contents_))); |
| - } |
| - return ptr_ref.get(); |
| -} |