| OLD | NEW |
| (Empty) |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CHROME_BROWSER_SSL_CHROME_SECURITY_STATE_MODEL_CLIENT_H_ | |
| 6 #define CHROME_BROWSER_SSL_CHROME_SECURITY_STATE_MODEL_CLIENT_H_ | |
| 7 | |
| 8 #include <memory> | |
| 9 | |
| 10 #include "base/macros.h" | |
| 11 #include "components/security_state/security_state_model.h" | |
| 12 #include "components/security_state/security_state_model_client.h" | |
| 13 #include "content/public/browser/web_contents_observer.h" | |
| 14 #include "content/public/browser/web_contents_user_data.h" | |
| 15 #include "third_party/WebKit/public/platform/WebSecurityStyle.h" | |
| 16 | |
| 17 namespace content { | |
| 18 struct SecurityStyleExplanations; | |
| 19 class NavigationHandle; | |
| 20 class WebContents; | |
| 21 } // namespace content | |
| 22 | |
| 23 // Uses a WebContents to provide a SecurityStateModel with the | |
| 24 // information that it needs to determine the page's security status. | |
| 25 class ChromeSecurityStateModelClient | |
| 26 : public security_state::SecurityStateModelClient, | |
| 27 public content::WebContentsObserver, | |
| 28 public content::WebContentsUserData<ChromeSecurityStateModelClient> { | |
| 29 public: | |
| 30 ~ChromeSecurityStateModelClient() override; | |
| 31 | |
| 32 void GetSecurityInfo( | |
| 33 security_state::SecurityStateModel::SecurityInfo* result) const; | |
| 34 | |
| 35 // Called when the NavigationEntry's SSLStatus changes. | |
| 36 void VisibleSSLStateChanged(); | |
| 37 | |
| 38 // content::WebContentsObserver: | |
| 39 void DidFinishNavigation( | |
| 40 content::NavigationHandle* navigation_handle) override; | |
| 41 | |
| 42 // Returns the SecurityStyle that should be applied to a WebContents | |
| 43 // with the given |security_info|. Populates | |
| 44 // |security_style_explanations| to explain why the returned | |
| 45 // SecurityStyle was chosen. | |
| 46 static blink::WebSecurityStyle GetSecurityStyle( | |
| 47 const security_state::SecurityStateModel::SecurityInfo& security_info, | |
| 48 content::SecurityStyleExplanations* security_style_explanations); | |
| 49 | |
| 50 // SecurityStateModelClient: | |
| 51 void GetVisibleSecurityState( | |
| 52 security_state::SecurityStateModel::VisibleSecurityState* state) override; | |
| 53 bool UsedPolicyInstalledCertificate() override; | |
| 54 bool IsOriginSecure(const GURL& url) override; | |
| 55 | |
| 56 private: | |
| 57 explicit ChromeSecurityStateModelClient(content::WebContents* web_contents); | |
| 58 friend class content::WebContentsUserData<ChromeSecurityStateModelClient>; | |
| 59 | |
| 60 content::WebContents* web_contents_; | |
| 61 std::unique_ptr<security_state::SecurityStateModel> security_state_model_; | |
| 62 | |
| 63 // True if a console has been logged about an omnibox warning that | |
| 64 // will be shown in future versions of Chrome for insecure HTTP | |
| 65 // pages. This message should only be logged once per main-frame | |
| 66 // navigation. | |
| 67 bool logged_http_warning_on_current_navigation_; | |
| 68 | |
| 69 DISALLOW_COPY_AND_ASSIGN(ChromeSecurityStateModelClient); | |
| 70 }; | |
| 71 | |
| 72 #endif // CHROME_BROWSER_SSL_CHROME_SECURITY_STATE_MODEL_CLIENT_H_ | |
| OLD | NEW |