| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/ui/android/website_settings_popup_android.h" | 5 #include "chrome/browser/ui/android/website_settings_popup_legacy_android.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/jni_array.h" | 8 #include "base/android/jni_array.h" |
| 9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
| 10 #include "chrome/browser/android/resource_mapper.h" | 10 #include "chrome/browser/android/resource_mapper.h" |
| 11 #include "chrome/browser/infobars/infobar_service.h" | 11 #include "chrome/browser/infobars/infobar_service.h" |
| 12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
| 13 #include "chrome/browser/ui/website_settings/website_settings.h" | 13 #include "chrome/browser/ui/website_settings/website_settings.h" |
| 14 #include "chrome/grit/generated_resources.h" | 14 #include "chrome/grit/generated_resources.h" |
| 15 #include "content/public/browser/browser_context.h" | 15 #include "content/public/browser/browser_context.h" |
| 16 #include "content/public/browser/cert_store.h" | 16 #include "content/public/browser/cert_store.h" |
| 17 #include "content/public/browser/navigation_controller.h" | 17 #include "content/public/browser/navigation_controller.h" |
| 18 #include "content/public/browser/navigation_entry.h" | 18 #include "content/public/browser/navigation_entry.h" |
| 19 #include "content/public/browser/web_contents.h" | 19 #include "content/public/browser/web_contents.h" |
| 20 #include "content/public/common/ssl_status.h" | 20 #include "content/public/common/ssl_status.h" |
| 21 #include "jni/WebsiteSettingsPopup_jni.h" | 21 #include "jni/WebsiteSettingsPopupLegacy_jni.h" |
| 22 #include "net/cert/x509_certificate.h" | 22 #include "net/cert/x509_certificate.h" |
| 23 #include "ui/base/l10n/l10n_util.h" | 23 #include "ui/base/l10n/l10n_util.h" |
| 24 | 24 |
| 25 using base::android::CheckException; | 25 using base::android::CheckException; |
| 26 using base::android::ConvertUTF8ToJavaString; | 26 using base::android::ConvertUTF8ToJavaString; |
| 27 using base::android::ConvertUTF16ToJavaString; | 27 using base::android::ConvertUTF16ToJavaString; |
| 28 using base::android::GetClass; | 28 using base::android::GetClass; |
| 29 using base::android::ScopedJavaLocalRef; | 29 using base::android::ScopedJavaLocalRef; |
| 30 using content::CertStore; | 30 using content::CertStore; |
| 31 using content::WebContents; | 31 using content::WebContents; |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 68 | 68 |
| 69 // static | 69 // static |
| 70 static jlong Init(JNIEnv* env, | 70 static jlong Init(JNIEnv* env, |
| 71 jclass clazz, | 71 jclass clazz, |
| 72 jobject obj, | 72 jobject obj, |
| 73 jobject java_web_contents) { | 73 jobject java_web_contents) { |
| 74 content::WebContents* web_contents = | 74 content::WebContents* web_contents = |
| 75 content::WebContents::FromJavaWebContents(java_web_contents); | 75 content::WebContents::FromJavaWebContents(java_web_contents); |
| 76 | 76 |
| 77 return reinterpret_cast<intptr_t>( | 77 return reinterpret_cast<intptr_t>( |
| 78 new WebsiteSettingsPopupAndroid(env, obj, web_contents)); | 78 new WebsiteSettingsPopupLegacyAndroid(env, obj, web_contents)); |
| 79 } | 79 } |
| 80 | 80 |
| 81 WebsiteSettingsPopupAndroid::WebsiteSettingsPopupAndroid( | 81 WebsiteSettingsPopupLegacyAndroid::WebsiteSettingsPopupLegacyAndroid( |
| 82 JNIEnv* env, | 82 JNIEnv* env, |
| 83 jobject java_website_settings_pop, | 83 jobject java_website_settings_pop, |
| 84 WebContents* web_contents) { | 84 WebContents* web_contents) { |
| 85 // Important to use GetVisibleEntry to match what's showing in the omnibox. | 85 // Important to use GetVisibleEntry to match what's showing in the omnibox. |
| 86 content::NavigationEntry* nav_entry = | 86 content::NavigationEntry* nav_entry = |
| 87 web_contents->GetController().GetVisibleEntry(); | 87 web_contents->GetController().GetVisibleEntry(); |
| 88 if (nav_entry == NULL) | 88 if (nav_entry == NULL) |
| 89 return; | 89 return; |
| 90 | 90 |
| 91 popup_jobject_.Reset(env, java_website_settings_pop); | 91 popup_jobject_.Reset(env, java_website_settings_pop); |
| 92 | 92 |
| 93 presenter_.reset(new WebsiteSettings( | 93 presenter_.reset(new WebsiteSettings( |
| 94 this, | 94 this, |
| 95 Profile::FromBrowserContext(web_contents->GetBrowserContext()), | 95 Profile::FromBrowserContext(web_contents->GetBrowserContext()), |
| 96 TabSpecificContentSettings::FromWebContents(web_contents), | 96 TabSpecificContentSettings::FromWebContents(web_contents), |
| 97 InfoBarService::FromWebContents(web_contents), | 97 InfoBarService::FromWebContents(web_contents), |
| 98 nav_entry->GetURL(), | 98 nav_entry->GetURL(), |
| 99 nav_entry->GetSSL(), | 99 nav_entry->GetSSL(), |
| 100 content::CertStore::GetInstance())); | 100 content::CertStore::GetInstance())); |
| 101 } | 101 } |
| 102 | 102 |
| 103 WebsiteSettingsPopupAndroid::~WebsiteSettingsPopupAndroid() {} | 103 WebsiteSettingsPopupLegacyAndroid::~WebsiteSettingsPopupLegacyAndroid() {} |
| 104 | 104 |
| 105 void WebsiteSettingsPopupAndroid::Destroy(JNIEnv* env, jobject obj) { | 105 void WebsiteSettingsPopupLegacyAndroid::Destroy(JNIEnv* env, jobject obj) { |
| 106 delete this; | 106 delete this; |
| 107 } | 107 } |
| 108 | 108 |
| 109 void WebsiteSettingsPopupAndroid::ResetCertDecisions( | 109 void WebsiteSettingsPopupLegacyAndroid::ResetCertDecisions( |
| 110 JNIEnv* env, | 110 JNIEnv* env, |
| 111 jobject obj, | 111 jobject obj, |
| 112 jobject java_web_contents) { | 112 jobject java_web_contents) { |
| 113 presenter_->OnRevokeSSLErrorBypassButtonPressed(); | 113 presenter_->OnRevokeSSLErrorBypassButtonPressed(); |
| 114 } | 114 } |
| 115 | 115 |
| 116 void WebsiteSettingsPopupAndroid::SetIdentityInfo( | 116 void WebsiteSettingsPopupLegacyAndroid::SetIdentityInfo( |
| 117 const IdentityInfo& identity_info) { | 117 const IdentityInfo& identity_info) { |
| 118 JNIEnv* env = base::android::AttachCurrentThread(); | 118 JNIEnv* env = base::android::AttachCurrentThread(); |
| 119 | 119 |
| 120 { | 120 { |
| 121 int icon_id = ResourceMapper::MapFromChromiumId( | 121 int icon_id = ResourceMapper::MapFromChromiumId( |
| 122 WebsiteSettingsUI::GetIdentityIconID(identity_info.identity_status)); | 122 WebsiteSettingsUI::GetIdentityIconID(identity_info.identity_status)); |
| 123 | 123 |
| 124 // The headline and the certificate dialog link of the site's identity | 124 // The headline and the certificate dialog link of the site's identity |
| 125 // section is only displayed if the site's identity was verified. If the | 125 // section is only displayed if the site's identity was verified. If the |
| 126 // site's identity was verified, then the headline contains the organization | 126 // site's identity was verified, then the headline contains the organization |
| 127 // name from the provided certificate. If the organization name is not | 127 // name from the provided certificate. If the organization name is not |
| 128 // available than the hostname of the site is used instead. | 128 // available than the hostname of the site is used instead. |
| 129 std::string headline; | 129 std::string headline; |
| 130 if (identity_info.cert_id) { | 130 if (identity_info.cert_id) { |
| 131 headline = identity_info.site_identity; | 131 headline = identity_info.site_identity; |
| 132 } | 132 } |
| 133 | 133 |
| 134 ScopedJavaLocalRef<jstring> description = ConvertUTF8ToJavaString( | 134 ScopedJavaLocalRef<jstring> description = ConvertUTF8ToJavaString( |
| 135 env, identity_info.identity_status_description); | 135 env, identity_info.identity_status_description); |
| 136 base::string16 certificate_label = | 136 base::string16 certificate_label = |
| 137 l10n_util::GetStringUTF16(IDS_PAGEINFO_CERT_INFO_BUTTON); | 137 l10n_util::GetStringUTF16(IDS_PAGEINFO_CERT_INFO_BUTTON); |
| 138 Java_WebsiteSettingsPopup_addCertificateSection( | 138 Java_WebsiteSettingsPopupLegacy_addCertificateSection( |
| 139 env, | 139 env, |
| 140 popup_jobject_.obj(), | 140 popup_jobject_.obj(), |
| 141 icon_id, | 141 icon_id, |
| 142 ConvertUTF8ToJavaString(env, headline).obj(), | 142 ConvertUTF8ToJavaString(env, headline).obj(), |
| 143 description.obj(), | 143 description.obj(), |
| 144 ConvertUTF16ToJavaString(env, certificate_label).obj()); | 144 ConvertUTF16ToJavaString(env, certificate_label).obj()); |
| 145 | 145 |
| 146 if (identity_info.show_ssl_decision_revoke_button) { | 146 if (identity_info.show_ssl_decision_revoke_button) { |
| 147 base::string16 reset_button_label = l10n_util::GetStringUTF16( | 147 base::string16 reset_button_label = l10n_util::GetStringUTF16( |
| 148 IDS_PAGEINFO_RESET_INVALID_CERTIFICATE_DECISIONS_BUTTON); | 148 IDS_PAGEINFO_RESET_INVALID_CERTIFICATE_DECISIONS_BUTTON); |
| 149 Java_WebsiteSettingsPopup_addResetCertDecisionsButton( | 149 Java_WebsiteSettingsPopupLegacy_addResetCertDecisionsButton( |
| 150 env, | 150 env, |
| 151 popup_jobject_.obj(), | 151 popup_jobject_.obj(), |
| 152 ConvertUTF16ToJavaString(env, reset_button_label).obj()); | 152 ConvertUTF16ToJavaString(env, reset_button_label).obj()); |
| 153 } | 153 } |
| 154 } | 154 } |
| 155 | 155 |
| 156 { | 156 { |
| 157 int icon_id = ResourceMapper::MapFromChromiumId( | 157 int icon_id = ResourceMapper::MapFromChromiumId( |
| 158 WebsiteSettingsUI::GetConnectionIconID( | 158 WebsiteSettingsUI::GetConnectionIconID( |
| 159 identity_info.connection_status)); | 159 identity_info.connection_status)); |
| 160 | 160 |
| 161 ScopedJavaLocalRef<jstring> description = ConvertUTF8ToJavaString( | 161 ScopedJavaLocalRef<jstring> description = ConvertUTF8ToJavaString( |
| 162 env, identity_info.connection_status_description); | 162 env, identity_info.connection_status_description); |
| 163 Java_WebsiteSettingsPopup_addDescriptionSection( | 163 Java_WebsiteSettingsPopupLegacy_addDescriptionSection( |
| 164 env, popup_jobject_.obj(), icon_id, NULL, description.obj()); | 164 env, popup_jobject_.obj(), icon_id, NULL, description.obj()); |
| 165 } | 165 } |
| 166 | 166 |
| 167 Java_WebsiteSettingsPopup_addMoreInfoLink(env, popup_jobject_.obj(), | 167 Java_WebsiteSettingsPopupLegacy_addMoreInfoLink(env, popup_jobject_.obj(), |
| 168 ConvertUTF8ToJavaString( | 168 ConvertUTF8ToJavaString( |
| 169 env, l10n_util::GetStringUTF8(IDS_PAGE_INFO_HELP_CENTER_LINK)).obj()); | 169 env, l10n_util::GetStringUTF8(IDS_PAGE_INFO_HELP_CENTER_LINK)).obj()); |
| 170 Java_WebsiteSettingsPopup_showDialog(env, popup_jobject_.obj()); | 170 Java_WebsiteSettingsPopupLegacy_showDialog(env, popup_jobject_.obj()); |
| 171 } | 171 } |
| 172 | 172 |
| 173 void WebsiteSettingsPopupAndroid::SetCookieInfo( | 173 void WebsiteSettingsPopupLegacyAndroid::SetCookieInfo( |
| 174 const CookieInfoList& cookie_info_list) { | 174 const CookieInfoList& cookie_info_list) { |
| 175 NOTIMPLEMENTED(); | 175 NOTIMPLEMENTED(); |
| 176 } | 176 } |
| 177 | 177 |
| 178 void WebsiteSettingsPopupAndroid::SetPermissionInfo( | 178 void WebsiteSettingsPopupLegacyAndroid::SetPermissionInfo( |
| 179 const PermissionInfoList& permission_info_list) { | 179 const PermissionInfoList& permission_info_list) { |
| 180 NOTIMPLEMENTED(); | 180 NOTIMPLEMENTED(); |
| 181 } | 181 } |
| 182 | 182 |
| 183 void WebsiteSettingsPopupAndroid::SetSelectedTab( | 183 void WebsiteSettingsPopupLegacyAndroid::SetSelectedTab( |
| 184 WebsiteSettingsUI::TabId tab_id) { | 184 WebsiteSettingsUI::TabId tab_id) { |
| 185 // There's no tab UI on Android - only connection info is shown. | 185 // There's no tab UI on Android - only connection info is shown. |
| 186 NOTIMPLEMENTED(); | 186 NOTIMPLEMENTED(); |
| 187 } | 187 } |
| 188 | 188 |
| 189 void WebsiteSettingsPopupAndroid::SetFirstVisit( | 189 void WebsiteSettingsPopupLegacyAndroid::SetFirstVisit( |
| 190 const base::string16& first_visit) { | 190 const base::string16& first_visit) { |
| 191 NOTIMPLEMENTED(); | 191 NOTIMPLEMENTED(); |
| 192 } | 192 } |
| 193 | 193 |
| 194 // static | 194 // static |
| 195 bool WebsiteSettingsPopupAndroid::RegisterWebsiteSettingsPopupAndroid( | 195 bool |
| 196 WebsiteSettingsPopupLegacyAndroid::RegisterWebsiteSettingsPopupLegacyAndroid( |
| 196 JNIEnv* env) { | 197 JNIEnv* env) { |
| 197 return RegisterNativesImpl(env); | 198 return RegisterNativesImpl(env); |
| 198 } | 199 } |
| OLD | NEW |