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/notifications/message_center_settings_controller.h" | 5 #include "chrome/browser/notifications/message_center_settings_controller.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/i18n/string_compare.h" | 10 #include "base/i18n/string_compare.h" |
(...skipping 296 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
307 // WEB_PAGE notifier cannot handle in DesktopNotificationService | 307 // WEB_PAGE notifier cannot handle in DesktopNotificationService |
308 // since it has the exact URL pattern. | 308 // since it has the exact URL pattern. |
309 // TODO(mukai): fix this. | 309 // TODO(mukai): fix this. |
310 ContentSetting default_setting = | 310 ContentSetting default_setting = |
311 profile->GetHostContentSettingsMap()->GetDefaultContentSetting( | 311 profile->GetHostContentSettingsMap()->GetDefaultContentSetting( |
312 CONTENT_SETTINGS_TYPE_NOTIFICATIONS, NULL); | 312 CONTENT_SETTINGS_TYPE_NOTIFICATIONS, NULL); |
313 | 313 |
314 DCHECK(default_setting == CONTENT_SETTING_ALLOW || | 314 DCHECK(default_setting == CONTENT_SETTING_ALLOW || |
315 default_setting == CONTENT_SETTING_BLOCK || | 315 default_setting == CONTENT_SETTING_BLOCK || |
316 default_setting == CONTENT_SETTING_ASK); | 316 default_setting == CONTENT_SETTING_ASK); |
317 if ((enabled && default_setting != CONTENT_SETTING_ALLOW) || | 317 |
318 (!enabled && default_setting == CONTENT_SETTING_ALLOW)) { | 318 bool derive_from_default_value = |
dewittj
2015/04/27 16:48:51
nit: derive isn't completely clear here.. Possibl
Peter Beverloo
2015/04/28 12:14:44
Done.
| |
319 (default_setting != CONTENT_SETTING_ALLOW && enabled) || | |
320 (default_setting == CONTENT_SETTING_ALLOW && !enabled); | |
321 | |
322 if (derive_from_default_value) { | |
319 if (notifier.notifier_id.url.is_valid()) { | 323 if (notifier.notifier_id.url.is_valid()) { |
320 if (enabled) | 324 if (enabled) |
dewittj
2015/04/27 16:48:51
nit: please add braces to this if/else since they
Peter Beverloo
2015/04/28 12:14:45
Done.
| |
321 DesktopNotificationProfileUtil::GrantPermission( | 325 DesktopNotificationProfileUtil::GrantPermission( |
322 profile, notifier.notifier_id.url); | 326 profile, notifier.notifier_id.url); |
323 else | 327 else |
324 DesktopNotificationProfileUtil::DenyPermission( | 328 DesktopNotificationProfileUtil::DenyPermission( |
325 profile, notifier.notifier_id.url); | 329 profile, notifier.notifier_id.url); |
326 } else { | 330 } else { |
327 LOG(ERROR) << "Invalid url pattern: " | 331 LOG(ERROR) << "Invalid url pattern: " |
328 << notifier.notifier_id.url.spec(); | 332 << notifier.notifier_id.url.spec(); |
329 } | 333 } |
330 } else { | 334 } else { |
331 std::map<base::string16, ContentSettingsPattern>::const_iterator iter = | 335 ContentSettingsPattern pattern; |
332 patterns_.find(notifier.name); | 336 |
337 const auto& iter = patterns_.find(notifier.name); | |
333 if (iter != patterns_.end()) { | 338 if (iter != patterns_.end()) { |
334 DesktopNotificationProfileUtil::ClearSetting(profile, iter->second); | 339 pattern = iter->second; |
340 } else if (notifier.notifier_id.url.is_valid()) { | |
341 pattern = | |
342 ContentSettingsPattern::FromURLNoWildcard(notifier.notifier_id.url); | |
335 } else { | 343 } else { |
336 LOG(ERROR) << "Invalid url pattern: " | 344 LOG(ERROR) << "Invalid url pattern: " |
337 << notifier.notifier_id.url.spec(); | 345 << notifier.notifier_id.url.spec(); |
338 } | 346 } |
347 | |
348 if (pattern.IsValid()) | |
349 DesktopNotificationProfileUtil::ClearSetting(profile, pattern); | |
339 } | 350 } |
340 } else { | 351 } else { |
341 notification_service->SetNotifierEnabled(notifier.notifier_id, enabled); | 352 notification_service->SetNotifierEnabled(notifier.notifier_id, enabled); |
342 } | 353 } |
343 FOR_EACH_OBSERVER(message_center::NotifierSettingsObserver, | 354 FOR_EACH_OBSERVER(message_center::NotifierSettingsObserver, |
344 observers_, | 355 observers_, |
345 NotifierEnabledChanged(notifier.notifier_id, enabled)); | 356 NotifierEnabledChanged(notifier.notifier_id, enabled)); |
346 } | 357 } |
347 | 358 |
348 void MessageCenterSettingsController::OnNotifierSettingsClosing() { | 359 void MessageCenterSettingsController::OnNotifierSettingsClosing() { |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
533 weak_factory_.GetWeakPtr())); | 544 weak_factory_.GetWeakPtr())); |
534 } | 545 } |
535 #endif | 546 #endif |
536 | 547 |
537 if (notify) { | 548 if (notify) { |
538 FOR_EACH_OBSERVER(message_center::NotifierSettingsObserver, | 549 FOR_EACH_OBSERVER(message_center::NotifierSettingsObserver, |
539 observers_, | 550 observers_, |
540 NotifierGroupChanged()); | 551 NotifierGroupChanged()); |
541 } | 552 } |
542 } | 553 } |
OLD | NEW |