Chromium Code Reviews| 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/ui/views/download/download_item_view.h" | 5 #include "chrome/browser/ui/views/download/download_item_view.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/files/file_path.h" | 12 #include "base/files/file_path.h" |
| 13 #include "base/i18n/break_iterator.h" | 13 #include "base/i18n/break_iterator.h" |
| 14 #include "base/i18n/rtl.h" | 14 #include "base/i18n/rtl.h" |
| 15 #include "base/metrics/histogram.h" | 15 #include "base/metrics/histogram.h" |
| 16 #include "base/strings/string_util.h" | 16 #include "base/strings/string_util.h" |
| 17 #include "base/strings/stringprintf.h" | 17 #include "base/strings/stringprintf.h" |
| 18 #include "base/strings/sys_string_conversions.h" | 18 #include "base/strings/sys_string_conversions.h" |
| 19 #include "base/strings/utf_string_conversions.h" | 19 #include "base/strings/utf_string_conversions.h" |
| 20 #include "chrome/browser/browser_process.h" | 20 #include "chrome/browser/browser_process.h" |
| 21 #include "chrome/browser/download/chrome_download_manager_delegate.h" | 21 #include "chrome/browser/download/chrome_download_manager_delegate.h" |
| 22 #include "chrome/browser/download/download_item_model.h" | 22 #include "chrome/browser/download/download_item_model.h" |
| 23 #include "chrome/browser/download/download_stats.h" | 23 #include "chrome/browser/download/download_stats.h" |
| 24 #include "chrome/browser/download/drag_download_item.h" | 24 #include "chrome/browser/download/drag_download_item.h" |
| 25 #include "chrome/browser/prefs/pref_service_syncable.h" | |
| 25 #include "chrome/browser/safe_browsing/download_feedback_service.h" | 26 #include "chrome/browser/safe_browsing/download_feedback_service.h" |
| 26 #include "chrome/browser/safe_browsing/download_protection_service.h" | 27 #include "chrome/browser/safe_browsing/download_protection_service.h" |
| 27 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 28 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 28 #include "chrome/browser/themes/theme_properties.h" | 29 #include "chrome/browser/themes/theme_properties.h" |
| 30 #include "chrome/browser/ui/views/download/download_feedback_dialog_view.h" | |
| 29 #include "chrome/browser/ui/views/download/download_shelf_context_menu_view.h" | 31 #include "chrome/browser/ui/views/download/download_shelf_context_menu_view.h" |
| 30 #include "chrome/browser/ui/views/download/download_shelf_view.h" | 32 #include "chrome/browser/ui/views/download/download_shelf_view.h" |
| 31 #include "content/public/browser/download_danger_type.h" | 33 #include "content/public/browser/download_danger_type.h" |
| 32 #include "grit/generated_resources.h" | 34 #include "grit/generated_resources.h" |
| 33 #include "grit/theme_resources.h" | 35 #include "grit/theme_resources.h" |
| 34 #include "third_party/icu/source/common/unicode/uchar.h" | 36 #include "third_party/icu/source/common/unicode/uchar.h" |
| 35 #include "ui/base/accessibility/accessible_view_state.h" | 37 #include "ui/base/accessibility/accessible_view_state.h" |
| 36 #include "ui/base/l10n/l10n_util.h" | 38 #include "ui/base/l10n/l10n_util.h" |
| 37 #include "ui/base/resource/resource_bundle.h" | 39 #include "ui/base/resource/resource_bundle.h" |
| 38 #include "ui/base/theme_provider.h" | 40 #include "ui/base/theme_provider.h" |
| (...skipping 504 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 543 return; | 545 return; |
| 544 } | 546 } |
| 545 | 547 |
| 546 // WARNING: all end states after this point delete |this|. | 548 // WARNING: all end states after this point delete |this|. |
| 547 DCHECK_EQ(discard_button_, sender); | 549 DCHECK_EQ(discard_button_, sender); |
| 548 if (model_.IsMalicious()) { | 550 if (model_.IsMalicious()) { |
| 549 UMA_HISTOGRAM_LONG_TIMES("clickjacking.dismiss_download", warning_duration); | 551 UMA_HISTOGRAM_LONG_TIMES("clickjacking.dismiss_download", warning_duration); |
| 550 shelf_->RemoveDownloadView(this); | 552 shelf_->RemoveDownloadView(this); |
| 551 return; | 553 return; |
| 552 } | 554 } |
| 553 if (model_.ShouldAllowDownloadFeedback() && BeginDownloadFeedback()) | 555 UMA_HISTOGRAM_LONG_TIMES("clickjacking.discard_download", warning_duration); |
| 556 if (model_.ShouldAllowDownloadFeedback()) { | |
| 557 const int pref_value = shelf_->browser()->profile()->GetPrefs()->GetInteger( | |
| 558 prefs::kSafeBrowsingDownloadReportingEnabled); | |
| 559 switch (static_cast<DownloadFeedbackDialogView::Response>(pref_value)) { | |
| 560 case DownloadFeedbackDialogView::kNeverShown: { | |
|
Peter Kasting
2014/02/04 21:56:33
Nit: {} not necessary on any of these cases.
felt
2014/02/04 23:37:22
Done, but doesn't the style guide say either with
Peter Kasting
2014/02/05 00:07:36
Yes, either way is acceptable by the style guide.
| |
| 561 DownloadFeedbackDialogView::Show( | |
| 562 shelf_->GetParentWindowView()->GetNativeWindow(), | |
| 563 shelf_->browser()->profile(), | |
| 564 base::Bind(&DownloadItemView::BeginDownloadFeedbackWrapper, | |
| 565 weak_ptr_factory_.GetWeakPtr())); | |
| 566 break; | |
| 567 } | |
| 568 case DownloadFeedbackDialogView::kUserEnabled: { | |
| 569 BeginDownloadFeedbackWrapper(true); | |
| 570 break; | |
| 571 } | |
| 572 case DownloadFeedbackDialogView::kUserDisabled: { | |
| 573 BeginDownloadFeedbackWrapper(false); | |
| 574 break; | |
| 575 } | |
| 576 case DownloadFeedbackDialogView::kMaxValue: | |
|
Peter Kasting
2014/02/04 21:56:33
Having this value buys you nothing over just havin
felt
2014/02/04 23:37:22
Switching to just "default", but I need kMaxValue
Peter Kasting
2014/02/05 00:07:36
In that case, I would eliminate "default" and only
felt
2014/02/05 02:08:53
Done.
| |
| 577 default: { | |
| 578 NOTREACHED(); | |
| 579 } | |
| 580 } | |
| 554 return; | 581 return; |
| 555 UMA_HISTOGRAM_LONG_TIMES("clickjacking.discard_download", warning_duration); | 582 } |
| 556 download()->Remove(); | 583 download()->Remove(); |
| 557 } | 584 } |
| 558 | 585 |
| 559 void DownloadItemView::AnimationProgressed(const gfx::Animation* animation) { | 586 void DownloadItemView::AnimationProgressed(const gfx::Animation* animation) { |
| 560 // We don't care if what animation (body button/drop button/complete), | 587 // We don't care if what animation (body button/drop button/complete), |
| 561 // is calling back, as they all have to go through the same paint call. | 588 // is calling back, as they all have to go through the same paint call. |
| 562 SchedulePaint(); | 589 SchedulePaint(); |
| 563 } | 590 } |
| 564 | 591 |
| 565 void DownloadItemView::OnPaint(gfx::Canvas* canvas) { | 592 void DownloadItemView::OnPaint(gfx::Canvas* canvas) { |
| (...skipping 317 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 883 void DownloadItemView::OpenDownload() { | 910 void DownloadItemView::OpenDownload() { |
| 884 DCHECK(!IsShowingWarningDialog()); | 911 DCHECK(!IsShowingWarningDialog()); |
| 885 // We're interested in how long it takes users to open downloads. If they | 912 // We're interested in how long it takes users to open downloads. If they |
| 886 // open downloads super quickly, we should be concerned about clickjacking. | 913 // open downloads super quickly, we should be concerned about clickjacking. |
| 887 UMA_HISTOGRAM_LONG_TIMES("clickjacking.open_download", | 914 UMA_HISTOGRAM_LONG_TIMES("clickjacking.open_download", |
| 888 base::Time::Now() - creation_time_); | 915 base::Time::Now() - creation_time_); |
| 889 download()->OpenDownload(); | 916 download()->OpenDownload(); |
| 890 UpdateAccessibleName(); | 917 UpdateAccessibleName(); |
| 891 } | 918 } |
| 892 | 919 |
| 920 void DownloadItemView::BeginDownloadFeedbackWrapper(bool user_enabled) { | |
|
Peter Kasting
2014/02/04 21:56:33
Nit: If you make the argument to this be the enum
felt
2014/02/05 02:08:53
Done.
| |
| 921 if (user_enabled && BeginDownloadFeedback()) | |
| 922 return; | |
| 923 download()->Remove(); | |
| 924 // WARNING: 'this' is deleted at this point. Don't access 'this'. | |
|
Peter Kasting
2014/02/04 21:56:33
Nit: Shorter:
if (!user_enabled || !BeginDownlo
felt
2014/02/04 23:37:22
Done.
| |
| 925 } | |
| 926 | |
| 893 bool DownloadItemView::BeginDownloadFeedback() { | 927 bool DownloadItemView::BeginDownloadFeedback() { |
| 894 #if defined(FULL_SAFE_BROWSING) | 928 #if defined(FULL_SAFE_BROWSING) |
| 895 SafeBrowsingService* sb_service = g_browser_process->safe_browsing_service(); | 929 SafeBrowsingService* sb_service = g_browser_process->safe_browsing_service(); |
| 896 if (!sb_service) | 930 if (!sb_service) |
| 897 return false; | 931 return false; |
| 898 safe_browsing::DownloadProtectionService* download_protection_service = | 932 safe_browsing::DownloadProtectionService* download_protection_service = |
| 899 sb_service->download_protection_service(); | 933 sb_service->download_protection_service(); |
| 900 if (!download_protection_service) | 934 if (!download_protection_service) |
| 901 return false; | 935 return false; |
| 902 base::TimeDelta warning_duration = base::TimeDelta(); | |
| 903 if (!time_download_warning_shown_.is_null()) | |
| 904 warning_duration = base::Time::Now() - time_download_warning_shown_; | |
| 905 UMA_HISTOGRAM_LONG_TIMES("clickjacking.report_and_discard_download", | |
| 906 warning_duration); | |
| 907 download_protection_service->feedback_service()->BeginFeedbackForDownload( | 936 download_protection_service->feedback_service()->BeginFeedbackForDownload( |
| 908 download()); | 937 download()); |
| 909 // WARNING: we are deleted at this point. Don't access 'this'. | 938 // WARNING: we are deleted at this point. Don't access 'this'. |
| 910 return true; | 939 return true; |
| 911 #else | 940 #else |
| 912 NOTREACHED(); | 941 NOTREACHED(); |
| 913 return false; | 942 return false; |
| 914 #endif | 943 #endif |
| 915 } | 944 } |
| 916 | 945 |
| (...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1134 body_state_ = NORMAL; | 1163 body_state_ = NORMAL; |
| 1135 drop_down_state_ = NORMAL; | 1164 drop_down_state_ = NORMAL; |
| 1136 if (mode_ == DANGEROUS_MODE) { | 1165 if (mode_ == DANGEROUS_MODE) { |
| 1137 save_button_ = new views::LabelButton( | 1166 save_button_ = new views::LabelButton( |
| 1138 this, model_.GetWarningConfirmButtonText()); | 1167 this, model_.GetWarningConfirmButtonText()); |
| 1139 save_button_->SetStyle(views::Button::STYLE_BUTTON); | 1168 save_button_->SetStyle(views::Button::STYLE_BUTTON); |
| 1140 AddChildView(save_button_); | 1169 AddChildView(save_button_); |
| 1141 } | 1170 } |
| 1142 int discard_button_message = model_.IsMalicious() ? | 1171 int discard_button_message = model_.IsMalicious() ? |
| 1143 IDS_DISMISS_DOWNLOAD : IDS_DISCARD_DOWNLOAD; | 1172 IDS_DISMISS_DOWNLOAD : IDS_DISCARD_DOWNLOAD; |
| 1144 if (!model_.IsMalicious() && model_.ShouldAllowDownloadFeedback()) | |
| 1145 discard_button_message = IDS_REPORT_AND_DISCARD_DOWNLOAD; | |
| 1146 discard_button_ = new views::LabelButton( | 1173 discard_button_ = new views::LabelButton( |
| 1147 this, l10n_util::GetStringUTF16(discard_button_message)); | 1174 this, l10n_util::GetStringUTF16(discard_button_message)); |
| 1148 discard_button_->SetStyle(views::Button::STYLE_BUTTON); | 1175 discard_button_->SetStyle(views::Button::STYLE_BUTTON); |
| 1149 AddChildView(discard_button_); | 1176 AddChildView(discard_button_); |
| 1150 | 1177 |
| 1151 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 1178 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| 1152 switch (danger_type) { | 1179 switch (danger_type) { |
| 1153 case content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL: | 1180 case content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL: |
| 1154 case content::DOWNLOAD_DANGER_TYPE_DANGEROUS_CONTENT: | 1181 case content::DOWNLOAD_DANGER_TYPE_DANGEROUS_CONTENT: |
| 1155 case content::DOWNLOAD_DANGER_TYPE_UNCOMMON_CONTENT: | 1182 case content::DOWNLOAD_DANGER_TYPE_UNCOMMON_CONTENT: |
| (...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1319 void DownloadItemView::AnimateStateTransition(State from, State to, | 1346 void DownloadItemView::AnimateStateTransition(State from, State to, |
| 1320 gfx::SlideAnimation* animation) { | 1347 gfx::SlideAnimation* animation) { |
| 1321 if (from == NORMAL && to == HOT) { | 1348 if (from == NORMAL && to == HOT) { |
| 1322 animation->Show(); | 1349 animation->Show(); |
| 1323 } else if (from == HOT && to == NORMAL) { | 1350 } else if (from == HOT && to == NORMAL) { |
| 1324 animation->Hide(); | 1351 animation->Hide(); |
| 1325 } else if (from != to) { | 1352 } else if (from != to) { |
| 1326 animation->Reset((to == HOT) ? 1.0 : 0.0); | 1353 animation->Reset((to == HOT) ? 1.0 : 0.0); |
| 1327 } | 1354 } |
| 1328 } | 1355 } |
| OLD | NEW |