Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(67)

Unified Diff: chrome/browser/safe_browsing/srt_global_error.cc

Issue 599653002: SRT Bubble (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: CR Comments. Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/safe_browsing/srt_global_error.cc
diff --git a/chrome/browser/safe_browsing/srt_global_error.cc b/chrome/browser/safe_browsing/srt_global_error.cc
new file mode 100644
index 0000000000000000000000000000000000000000..32fc411101d0fd260b7d5b7e334ef313c7b45869
--- /dev/null
+++ b/chrome/browser/safe_browsing/srt_global_error.cc
@@ -0,0 +1,122 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/safe_browsing/srt_global_error.h"
+
+#include "base/callback.h"
+#include "base/metrics/histogram.h"
+#include "chrome/app/chrome_command_ids.h"
+#include "chrome/browser/ui/browser.h"
+#include "chrome/browser/ui/global_error/global_error_service.h"
+#include "grit/chromium_strings.h"
+#include "grit/generated_resources.h"
+#include "grit/google_chrome_strings.h"
+#include "ui/base/l10n/l10n_util.h"
+
+namespace {
+// The download link of the Software Removal Tool.
+const char kSRTDownloadURL[] = "https://www.google.com/chrome/srt/";
robertshield 2014/09/24 13:02:12 should some of this file be #if defined(GOOGLE_CHR
MAD 2014/09/24 20:40:35 Hum, but then, which value do we put here? Actuall
+
+// Enum values for the SRTPrompt histogram. Don't change order, always add
+// to the end, and adjust SRT_PROMPT_MAX.
+enum SRTPromptHistogramValue {
+ SRT_PROMPT_SHOWN = 0,
+ SRT_PROMPT_ACCEPTED = 1,
+ SRT_PROMPT_DENIED = 2,
+ SRT_PROMPT_MAX = 3,
gab 2014/09/24 16:22:37 Do not explicitly label SRT_PROMPT_MAX (let it be
MAD 2014/09/24 20:40:35 Done.
+};
+
+void RecordSRTPromptHistogram(SRTPromptHistogramValue value) {
+ UMA_HISTOGRAM_ENUMERATION("SRTPrompt", value, SRT_PROMPT_MAX);
+}
+
+} // namespace
+
+// SRTGlobalError ------------------------------------------------------------
+
+SRTGlobalError::SRTGlobalError(GlobalErrorService* global_error_service)
+ : global_error_service_(global_error_service) {
+ DCHECK(global_error_service_);
+}
+
+SRTGlobalError::~SRTGlobalError() {
+}
+
+// static
+bool SRTGlobalError::IsSupportedOnPlatform() {
gab 2014/09/24 16:22:37 Are there any callers of this method? Shouldn't th
MAD 2014/09/24 20:40:36 Good point, this was a leftover from the profile r
+// The Software Removal Tool only runs on windows.
+#if defined(OS_WIN)
+ return true;
+#else
+ return false;
+#endif
+}
+
+bool SRTGlobalError::HasMenuItem() {
+ return true;
+}
+
+int SRTGlobalError::MenuItemCommandID() {
+ return IDC_SHOW_SRT_BUBBLE;
+}
+
+base::string16 SRTGlobalError::MenuItemLabel() {
+ return l10n_util::GetStringUTF16(IDS_SRT_MENU_ITEM);
+}
+
+void SRTGlobalError::ExecuteMenuItem(Browser* browser) {
+ ShowBubbleView(browser);
engedy 2014/09/24 13:37:15 Showing more than one instance of the bubble is un
MAD 2014/09/24 20:40:36 Since the bubble is closed when it loses focus, th
+}
+
+void SRTGlobalError::ShowBubbleView(Browser* browser) {
+ RecordSRTPromptHistogram(SRT_PROMPT_SHOWN);
+ GlobalErrorWithStandardBubble::ShowBubbleView(browser);
+}
+
+base::string16 SRTGlobalError::GetBubbleViewTitle() {
+ return l10n_util::GetStringUTF16(IDS_SRT_BUBBLE_TITLE);
+}
+
+std::vector<base::string16> SRTGlobalError::GetBubbleViewMessages() {
+ std::vector<base::string16> messages;
+ messages.push_back(l10n_util::GetStringUTF16(IDS_SRT_BUBBLE_TEXT));
+ return messages;
+}
+
+base::string16 SRTGlobalError::GetBubbleViewAcceptButtonLabel() {
+ return l10n_util::GetStringUTF16(IDS_SRT_BUBBLE_DOWNLOAD_BUTTON_TEXT);
+}
+
+base::string16 SRTGlobalError::GetBubbleViewCancelButtonLabel() {
+ return l10n_util::GetStringUTF16(IDS_NO_THANKS);
+}
+
+void SRTGlobalError::OnBubbleViewDidClose(Browser* browser) {
+}
+
+void SRTGlobalError::BubbleViewAcceptButtonPressed(Browser* browser) {
+ RecordSRTPromptHistogram(SRT_PROMPT_ACCEPTED);
+ browser->OpenURL(content::OpenURLParams(GURL(kSRTDownloadURL),
+ content::Referrer(),
+ NEW_FOREGROUND_TAB,
+ ui::PAGE_TRANSITION_LINK,
+ false));
+ DismissGlobalError();
+}
+
+void SRTGlobalError::BubbleViewCancelButtonPressed(Browser* browser) {
+ RecordSRTPromptHistogram(SRT_PROMPT_DENIED);
+ DismissGlobalError();
+}
+
+void SRTGlobalError::DismissGlobalError() {
+ global_error_service_->RemoveGlobalError(this);
+
+ // Even though OnBubbleViewDidClose will be called asynchronously when the
+ // bubble actually gets closed by RemoveGlobalError, we can safely suicide
robertshield 2014/09/24 13:02:12 totally ignorable grammar nit: s/suicide/commit su
MAD 2014/09/24 20:40:35 Done.
+ // here since the bubble holds on a weak pointer of the global error. This
+ // way, if the destruction of the bubble UI ever gets changed to be
+ // synchronous, we'll still be OK.
gab 2014/09/24 16:22:36 This comment should not be necessary. All your cod
MAD 2014/09/24 20:40:35 Actually, this comment was added to explain the st
+ delete this;
+}

Powered by Google App Engine
This is Rietveld 408576698