| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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 #ifndef CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ | 5 #ifndef CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ |
| 6 #define CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ | 6 #define CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
| (...skipping 12 matching lines...) Expand all Loading... |
| 24 // Ensure that the specified message is displayed to the user. This will | 24 // Ensure that the specified message is displayed to the user. This will |
| 25 // display an InfoBar at the top of the associated tab. | 25 // display an InfoBar at the top of the associated tab. |
| 26 void ShowMessage(const std::wstring& msg); | 26 void ShowMessage(const std::wstring& msg); |
| 27 | 27 |
| 28 // Same as ShowMessage but also contains a link that when clicked run the | 28 // Same as ShowMessage but also contains a link that when clicked run the |
| 29 // specified task. The SSL Manager becomes the owner of the task. | 29 // specified task. The SSL Manager becomes the owner of the task. |
| 30 void ShowMessageWithLink(const std::wstring& msg, | 30 void ShowMessageWithLink(const std::wstring& msg, |
| 31 const std::wstring& link_text, | 31 const std::wstring& link_text, |
| 32 Task* task); | 32 Task* task); |
| 33 | 33 |
| 34 // Records that a host has run insecure content. | 34 // Records that a host is "broken," that is, the origin for that host has been |
| 35 void HostRanInsecureContent(const std::string& host, int pid); | 35 // contaminated with insecure content, either via HTTP or via HTTPS with a |
| 36 // bad certificate. |
| 37 void MarkHostAsBroken(const std::string& host, int pid); |
| 36 | 38 |
| 37 // Returns whether the specified host ran insecure content. | 39 // Returns whether the specified host was marked as broken. |
| 38 bool DidHostRunInsecureContent(const std::string& host, int pid) const; | 40 bool DidMarkHostAsBroken(const std::string& host, int pid) const; |
| 39 | 41 |
| 40 // Records that |cert| is permitted to be used for |host| in the future. | 42 // Records that |cert| is permitted to be used for |host| in the future. |
| 41 void DenyCertForHost(net::X509Certificate* cert, const std::string& host); | 43 void DenyCertForHost(net::X509Certificate* cert, const std::string& host); |
| 42 | 44 |
| 43 // Records that |cert| is not permitted to be used for |host| in the future. | 45 // Records that |cert| is not permitted to be used for |host| in the future. |
| 44 void AllowCertForHost(net::X509Certificate* cert, const std::string& host); | 46 void AllowCertForHost(net::X509Certificate* cert, const std::string& host); |
| 45 | 47 |
| 46 // Queries whether |cert| is allowed or denied for |host|. | 48 // Queries whether |cert| is allowed or denied for |host|. |
| 47 net::X509Certificate::Policy::Judgment QueryPolicy( | 49 net::X509Certificate::Policy::Judgment QueryPolicy( |
| 48 net::X509Certificate* cert, const std::string& host); | 50 net::X509Certificate* cert, const std::string& host); |
| (...skipping 22 matching lines...) Expand all Loading... |
| 71 bool operator==(const std::wstring& other_message) const { | 73 bool operator==(const std::wstring& other_message) const { |
| 72 // We are uniquing SSLMessageInfo by their message only. | 74 // We are uniquing SSLMessageInfo by their message only. |
| 73 return message == other_message; | 75 return message == other_message; |
| 74 } | 76 } |
| 75 | 77 |
| 76 std::wstring message; | 78 std::wstring message; |
| 77 std::wstring link_text; | 79 std::wstring link_text; |
| 78 Task* action; | 80 Task* action; |
| 79 }; | 81 }; |
| 80 | 82 |
| 83 // Dispatch NotificationType::SSL_INTERNAL_STATE_CHANGED notification. |
| 84 void DispatchSSLInternalStateChanged(); |
| 85 |
| 81 // The NavigationController that owns this SSLManager. We are responsible | 86 // The NavigationController that owns this SSLManager. We are responsible |
| 82 // for the security UI of this tab. | 87 // for the security UI of this tab. |
| 83 NavigationController* controller_; | 88 NavigationController* controller_; |
| 84 | 89 |
| 85 // SSL state specific for each host. | 90 // SSL state specific for each host. |
| 86 SSLHostState* ssl_host_state_; | 91 SSLHostState* ssl_host_state_; |
| 87 | 92 |
| 88 // The list of messages that should be displayed (in info bars) when the page | 93 // The list of messages that should be displayed (in info bars) when the page |
| 89 // currently loading had loaded. | 94 // currently loading had loaded. |
| 90 std::vector<SSLMessageInfo> pending_messages_; | 95 std::vector<SSLMessageInfo> pending_messages_; |
| 91 | 96 |
| 92 DISALLOW_COPY_AND_ASSIGN(SSLPolicyBackend); | 97 DISALLOW_COPY_AND_ASSIGN(SSLPolicyBackend); |
| 93 }; | 98 }; |
| 94 | 99 |
| 95 #endif // CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ | 100 #endif // CHROME_BROWSER_SSL_SSL_POLICY_BACKEND_H_ |
| OLD | NEW |