| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chrome/browser/ssl/ssl_tab_helper.h" | 5 #include "chrome/browser/ssl/ssl_tab_helper.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 24 matching lines...) Expand all Loading... |
| 35 #include "net/cert/x509_certificate.h" | 35 #include "net/cert/x509_certificate.h" |
| 36 #include "ui/base/l10n/l10n_util.h" | 36 #include "ui/base/l10n/l10n_util.h" |
| 37 | 37 |
| 38 | 38 |
| 39 // SSLCertResultInfoBarDelegate ----------------------------------------------- | 39 // SSLCertResultInfoBarDelegate ----------------------------------------------- |
| 40 | 40 |
| 41 namespace { | 41 namespace { |
| 42 | 42 |
| 43 class SSLCertResultInfoBarDelegate : public ConfirmInfoBarDelegate { | 43 class SSLCertResultInfoBarDelegate : public ConfirmInfoBarDelegate { |
| 44 public: | 44 public: |
| 45 // Creates an SSL cert result infobar and delegate. If |previous_infobar| is | 45 // Creates an SSL cert result infobar delegate. If |previous_infobar| is |
| 46 // NULL, adds the infobar to |infobar_service|; otherwise, replaces | 46 // NULL, adds the infobar to |infobar_service|; otherwise, replaces |
| 47 // |previous_infobar|. Returns the new infobar if it was successfully added. | 47 // |previous_infobar|. Returns the new infobar if it was successfully added. |
| 48 // |cert| is valid iff cert addition was successful. | 48 // |cert| is valid iff cert addition was successful. |
| 49 static InfoBar* Create(InfoBarService* infobar_service, | 49 static InfoBarDelegate* Create(InfoBarService* infobar_service, |
| 50 InfoBar* previous_infobar, | 50 InfoBarDelegate* previous_infobar, |
| 51 const string16& message, | 51 const string16& message, |
| 52 net::X509Certificate* cert); | 52 net::X509Certificate* cert); |
| 53 | 53 |
| 54 private: | 54 private: |
| 55 SSLCertResultInfoBarDelegate(const string16& message, | 55 SSLCertResultInfoBarDelegate(InfoBarService* infobar_service, |
| 56 const string16& message, |
| 56 net::X509Certificate* cert); | 57 net::X509Certificate* cert); |
| 57 virtual ~SSLCertResultInfoBarDelegate(); | 58 virtual ~SSLCertResultInfoBarDelegate(); |
| 58 | 59 |
| 59 // ConfirmInfoBarDelegate: | 60 // ConfirmInfoBarDelegate: |
| 60 virtual int GetIconID() const OVERRIDE; | 61 virtual int GetIconID() const OVERRIDE; |
| 61 virtual Type GetInfoBarType() const OVERRIDE; | 62 virtual Type GetInfoBarType() const OVERRIDE; |
| 62 virtual string16 GetMessageText() const OVERRIDE; | 63 virtual string16 GetMessageText() const OVERRIDE; |
| 63 virtual int GetButtons() const OVERRIDE; | 64 virtual int GetButtons() const OVERRIDE; |
| 64 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; | 65 virtual string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; |
| 65 virtual bool Accept() OVERRIDE; | 66 virtual bool Accept() OVERRIDE; |
| 66 | 67 |
| 67 string16 message_; | 68 string16 message_; |
| 68 scoped_refptr<net::X509Certificate> cert_; // The cert we added, if any. | 69 scoped_refptr<net::X509Certificate> cert_; // The cert we added, if any. |
| 69 | 70 |
| 70 DISALLOW_COPY_AND_ASSIGN(SSLCertResultInfoBarDelegate); | 71 DISALLOW_COPY_AND_ASSIGN(SSLCertResultInfoBarDelegate); |
| 71 }; | 72 }; |
| 72 | 73 |
| 73 // static | 74 // static |
| 74 InfoBar* SSLCertResultInfoBarDelegate::Create(InfoBarService* infobar_service, | 75 InfoBarDelegate* SSLCertResultInfoBarDelegate::Create( |
| 75 InfoBar* previous_infobar, | 76 InfoBarService* infobar_service, |
| 76 const string16& message, | 77 InfoBarDelegate* previous_infobar, |
| 77 net::X509Certificate* cert) { | 78 const string16& message, |
| 78 scoped_ptr<InfoBar> infobar(ConfirmInfoBarDelegate::CreateInfoBar( | 79 net::X509Certificate* cert) { |
| 79 scoped_ptr<ConfirmInfoBarDelegate>( | 80 scoped_ptr<InfoBarDelegate> infobar( |
| 80 new SSLCertResultInfoBarDelegate(message, cert)))); | 81 new SSLCertResultInfoBarDelegate(infobar_service, message, cert)); |
| 81 return previous_infobar ? | 82 return previous_infobar ? |
| 82 infobar_service->ReplaceInfoBar(previous_infobar, infobar.Pass()) : | 83 infobar_service->ReplaceInfoBar(previous_infobar, infobar.Pass()) : |
| 83 infobar_service->AddInfoBar(infobar.Pass()); | 84 infobar_service->AddInfoBar(infobar.Pass()); |
| 84 } | 85 } |
| 85 | 86 |
| 86 SSLCertResultInfoBarDelegate::SSLCertResultInfoBarDelegate( | 87 SSLCertResultInfoBarDelegate::SSLCertResultInfoBarDelegate( |
| 88 InfoBarService* infobar_service, |
| 87 const string16& message, | 89 const string16& message, |
| 88 net::X509Certificate* cert) | 90 net::X509Certificate* cert) |
| 89 : ConfirmInfoBarDelegate(), | 91 : ConfirmInfoBarDelegate(infobar_service), |
| 90 message_(message), | 92 message_(message), |
| 91 cert_(cert) { | 93 cert_(cert) { |
| 92 } | 94 } |
| 93 | 95 |
| 94 SSLCertResultInfoBarDelegate::~SSLCertResultInfoBarDelegate() { | 96 SSLCertResultInfoBarDelegate::~SSLCertResultInfoBarDelegate() { |
| 95 } | 97 } |
| 96 | 98 |
| 97 int SSLCertResultInfoBarDelegate::GetIconID() const { | 99 int SSLCertResultInfoBarDelegate::GetIconID() const { |
| 98 // TODO(davidben): use a more appropriate icon. | 100 // TODO(davidben): use a more appropriate icon. |
| 99 return IDR_INFOBAR_SAVE_PASSWORD; | 101 return IDR_INFOBAR_SAVE_PASSWORD; |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 138 // Displays an infobar, replacing |infobar_| if it exists. | 140 // Displays an infobar, replacing |infobar_| if it exists. |
| 139 void ShowInfoBar(const string16& message, net::X509Certificate* cert); | 141 void ShowInfoBar(const string16& message, net::X509Certificate* cert); |
| 140 | 142 |
| 141 private: | 143 private: |
| 142 // content::NotificationObserver: | 144 // content::NotificationObserver: |
| 143 virtual void Observe(int type, | 145 virtual void Observe(int type, |
| 144 const content::NotificationSource& source, | 146 const content::NotificationSource& source, |
| 145 const content::NotificationDetails& details) OVERRIDE; | 147 const content::NotificationDetails& details) OVERRIDE; |
| 146 | 148 |
| 147 InfoBarService* infobar_service_; | 149 InfoBarService* infobar_service_; |
| 148 InfoBar* infobar_; | 150 InfoBarDelegate* infobar_; |
| 149 content::NotificationRegistrar registrar_; | 151 content::NotificationRegistrar registrar_; |
| 150 | 152 |
| 151 DISALLOW_COPY_AND_ASSIGN(SSLAddCertData); | 153 DISALLOW_COPY_AND_ASSIGN(SSLAddCertData); |
| 152 }; | 154 }; |
| 153 | 155 |
| 154 SSLTabHelper::SSLAddCertData::SSLAddCertData(InfoBarService* infobar_service) | 156 SSLTabHelper::SSLAddCertData::SSLAddCertData(InfoBarService* infobar_service) |
| 155 : infobar_service_(infobar_service), | 157 : infobar_service_(infobar_service), |
| 156 infobar_(NULL) { | 158 infobar_(NULL) { |
| 157 content::Source<InfoBarService> source(infobar_service_); | 159 content::Source<InfoBarService> source(infobar_service_); |
| 158 registrar_.Add(this, chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_REMOVED, | 160 registrar_.Add(this, chrome::NOTIFICATION_TAB_CONTENTS_INFOBAR_REMOVED, |
| (...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 260 // Find/create the slot. | 262 // Find/create the slot. |
| 261 linked_ptr<SSLAddCertData>& ptr_ref = | 263 linked_ptr<SSLAddCertData>& ptr_ref = |
| 262 request_id_to_add_cert_data_[handler->network_request_id()]; | 264 request_id_to_add_cert_data_[handler->network_request_id()]; |
| 263 // Fill it if necessary. | 265 // Fill it if necessary. |
| 264 if (!ptr_ref.get()) { | 266 if (!ptr_ref.get()) { |
| 265 ptr_ref.reset( | 267 ptr_ref.reset( |
| 266 new SSLAddCertData(InfoBarService::FromWebContents(web_contents_))); | 268 new SSLAddCertData(InfoBarService::FromWebContents(web_contents_))); |
| 267 } | 269 } |
| 268 return ptr_ref.get(); | 270 return ptr_ref.get(); |
| 269 } | 271 } |
| OLD | NEW |