1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
|
// Copyright (c) 2013 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/extensions/suspicious_extension_bubble_delegate.h"
#include "base/lazy_instance.h"
#include "base/metrics/histogram_macros.h"
#include "base/strings/utf_string_conversions.h"
#include "chrome/browser/extensions/extension_service.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/common/url_constants.h"
#include "chrome/grit/chromium_strings.h"
#include "chrome/grit/generated_resources.h"
#include "extensions/browser/extension_prefs.h"
#include "extensions/browser/extension_system.h"
#include "extensions/common/extension.h"
#include "ui/base/l10n/l10n_util.h"
using extensions::ExtensionMessageBubbleController;
namespace {
// Whether the user has been notified about extension being wiped out.
const char kWipeoutAcknowledged[] = "ack_wiped";
} // namespace
namespace extensions {
namespace {
base::LazyInstance<std::set<Profile*>>::Leaky g_suspicious_extension_shown =
LAZY_INSTANCE_INITIALIZER;
} // namespace
SuspiciousExtensionBubbleDelegate::SuspiciousExtensionBubbleDelegate(
Profile* profile)
: extensions::ExtensionMessageBubbleController::Delegate(profile),
profile_(profile) {
set_acknowledged_flag_pref_name(kWipeoutAcknowledged);
}
SuspiciousExtensionBubbleDelegate::~SuspiciousExtensionBubbleDelegate() {
}
bool SuspiciousExtensionBubbleDelegate::ShouldIncludeExtension(
const extensions::Extension* extension) {
extensions::ExtensionPrefs* prefs = extensions::ExtensionPrefs::Get(
profile());
if (!prefs->IsExtensionDisabled(extension->id()))
return false;
int disable_reasons = prefs->GetDisableReasons(extension->id());
if (disable_reasons & extensions::disable_reason::DISABLE_NOT_VERIFIED)
return !HasBubbleInfoBeenAcknowledged(extension->id());
return false;
}
void SuspiciousExtensionBubbleDelegate::AcknowledgeExtension(
const std::string& extension_id,
ExtensionMessageBubbleController::BubbleAction user_action) {
SetBubbleInfoBeenAcknowledged(extension_id, true);
}
void SuspiciousExtensionBubbleDelegate::PerformAction(
const extensions::ExtensionIdList& list) {
// This bubble solicits no action from the user. Or as Nimoy would have it:
// "Well, my work here is done".
}
base::string16 SuspiciousExtensionBubbleDelegate::GetTitle() const {
return l10n_util::GetStringUTF16(IDS_EXTENSIONS_UNSUPPORTED_DISABLED_TITLE);
}
base::string16 SuspiciousExtensionBubbleDelegate::GetMessageBody(
bool anchored_to_browser_action,
int extension_count) const {
int message_id = extension_count == 1 ?
IDS_EXTENSIONS_SINGLE_UNSUPPORTED_DISABLED_BODY :
IDS_EXTENSIONS_MULTIPLE_UNSUPPORTED_DISABLED_BODY;
return l10n_util::GetStringFUTF16(
message_id, l10n_util::GetStringUTF16(IDS_EXTENSION_WEB_STORE_TITLE));
}
base::string16 SuspiciousExtensionBubbleDelegate::GetOverflowText(
const base::string16& overflow_count) const {
return l10n_util::GetStringFUTF16(
IDS_EXTENSIONS_DISABLED_AND_N_MORE,
overflow_count);
}
GURL SuspiciousExtensionBubbleDelegate::GetLearnMoreUrl() const {
return GURL(chrome::kRemoveNonCWSExtensionURL);
}
base::string16
SuspiciousExtensionBubbleDelegate::GetActionButtonLabel() const {
return base::string16();
}
base::string16
SuspiciousExtensionBubbleDelegate::GetDismissButtonLabel() const {
return l10n_util::GetStringUTF16(IDS_EXTENSIONS_UNSUPPORTED_DISABLED_BUTTON);
}
bool SuspiciousExtensionBubbleDelegate::ShouldCloseOnDeactivate() const {
return false;
}
bool SuspiciousExtensionBubbleDelegate::ShouldAcknowledgeOnDeactivate() const {
return false;
}
bool SuspiciousExtensionBubbleDelegate::ShouldShow(
const ExtensionIdList& extensions) const {
DCHECK_LE(1u, extensions.size());
return !g_suspicious_extension_shown.Get().count(profile_);
}
void SuspiciousExtensionBubbleDelegate::OnShown(
const ExtensionIdList& extensions) {
DCHECK_LE(1u, extensions.size());
DCHECK(!g_suspicious_extension_shown.Get().count(profile_));
g_suspicious_extension_shown.Get().insert(profile_);
}
void SuspiciousExtensionBubbleDelegate::OnAction() {
// We clear the profile set because the user chooses to remove or disable the
// extension. Thus if that extension or another takes effect, it is worth
// mentioning to the user (ShouldShow() would return true) because it is
// contrary to the user's choice.
g_suspicious_extension_shown.Get().clear();
}
void SuspiciousExtensionBubbleDelegate::ClearProfileSetForTesting() {
g_suspicious_extension_shown.Get().clear();
}
bool SuspiciousExtensionBubbleDelegate::ShouldShowExtensionList() const {
return true;
}
bool SuspiciousExtensionBubbleDelegate::ShouldHighlightExtensions() const {
return false;
}
bool SuspiciousExtensionBubbleDelegate::ShouldLimitToEnabledExtensions() const {
return false;
}
void SuspiciousExtensionBubbleDelegate::LogExtensionCount(
size_t count) {
UMA_HISTOGRAM_COUNTS_100(
"ExtensionBubble.ExtensionWipeoutCount", count);
}
void SuspiciousExtensionBubbleDelegate::LogAction(
ExtensionMessageBubbleController::BubbleAction action) {
UMA_HISTOGRAM_ENUMERATION(
"ExtensionBubble.WipeoutUserSelection",
action, ExtensionMessageBubbleController::ACTION_BOUNDARY);
}
bool SuspiciousExtensionBubbleDelegate::SupportsPolicyIndicator() {
return false;
}
} // namespace extensions
|