| 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/chrome_content_browser_client.h" | 5 #include "chrome/browser/chrome_content_browser_client.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <set> | 8 #include <set> |
| 9 #include <utility> | 9 #include <utility> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 #include "base/threading/thread_task_runner_handle.h" | 30 #include "base/threading/thread_task_runner_handle.h" |
| 31 #include "build/build_config.h" | 31 #include "build/build_config.h" |
| 32 #include "chrome/browser/after_startup_task_utils.h" | 32 #include "chrome/browser/after_startup_task_utils.h" |
| 33 #include "chrome/browser/apps/app_url_redirector.h" | 33 #include "chrome/browser/apps/app_url_redirector.h" |
| 34 #include "chrome/browser/browser_about_handler.h" | 34 #include "chrome/browser/browser_about_handler.h" |
| 35 #include "chrome/browser/browser_process.h" | 35 #include "chrome/browser/browser_process.h" |
| 36 #include "chrome/browser/browser_shutdown.h" | 36 #include "chrome/browser/browser_shutdown.h" |
| 37 #include "chrome/browser/browsing_data/browsing_data_helper.h" | 37 #include "chrome/browser/browsing_data/browsing_data_helper.h" |
| 38 #include "chrome/browser/browsing_data/browsing_data_remover.h" | 38 #include "chrome/browser/browsing_data/browsing_data_remover.h" |
| 39 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h" | 39 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h" |
| 40 #include "chrome/browser/browsing_data/chrome_browsing_data_types.h" |
| 40 #include "chrome/browser/budget_service/budget_service_impl.h" | 41 #include "chrome/browser/budget_service/budget_service_impl.h" |
| 41 #include "chrome/browser/chrome_content_browser_client_parts.h" | 42 #include "chrome/browser/chrome_content_browser_client_parts.h" |
| 42 #include "chrome/browser/chrome_quota_permission_context.h" | 43 #include "chrome/browser/chrome_quota_permission_context.h" |
| 43 #include "chrome/browser/content_settings/cookie_settings_factory.h" | 44 #include "chrome/browser/content_settings/cookie_settings_factory.h" |
| 44 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 45 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| 45 #include "chrome/browser/content_settings/tab_specific_content_settings.h" | 46 #include "chrome/browser/content_settings/tab_specific_content_settings.h" |
| 46 #include "chrome/browser/defaults.h" | 47 #include "chrome/browser/defaults.h" |
| 47 #include "chrome/browser/download/download_prefs.h" | 48 #include "chrome/browser/download/download_prefs.h" |
| 48 #include "chrome/browser/field_trial_recorder.h" | 49 #include "chrome/browser/field_trial_recorder.h" |
| 49 #include "chrome/browser/font_family_cache.h" | 50 #include "chrome/browser/font_family_cache.h" |
| (...skipping 2656 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2706 | 2707 |
| 2707 // chrome: & friends. | 2708 // chrome: & friends. |
| 2708 handler->AddHandlerPair(&HandleWebUI, &HandleWebUIReverse); | 2709 handler->AddHandlerPair(&HandleWebUI, &HandleWebUIReverse); |
| 2709 } | 2710 } |
| 2710 | 2711 |
| 2711 void ChromeContentBrowserClient::ClearCache(RenderFrameHost* rfh) { | 2712 void ChromeContentBrowserClient::ClearCache(RenderFrameHost* rfh) { |
| 2712 Profile* profile = Profile::FromBrowserContext( | 2713 Profile* profile = Profile::FromBrowserContext( |
| 2713 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext()); | 2714 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext()); |
| 2714 BrowsingDataRemover* remover = | 2715 BrowsingDataRemover* remover = |
| 2715 BrowsingDataRemoverFactory::GetForBrowserContext(profile); | 2716 BrowsingDataRemoverFactory::GetForBrowserContext(profile); |
| 2716 remover->Remove(base::Time(), base::Time::Max(), | 2717 remover->Remove(base::Time(), base::Time::Max(), {&kBrowsingDataTypeCache}, |
| 2717 BrowsingDataRemover::REMOVE_CACHE, | |
| 2718 BrowsingDataHelper::UNPROTECTED_WEB); | 2718 BrowsingDataHelper::UNPROTECTED_WEB); |
| 2719 } | 2719 } |
| 2720 | 2720 |
| 2721 void ChromeContentBrowserClient::ClearCookies(RenderFrameHost* rfh) { | 2721 void ChromeContentBrowserClient::ClearCookies(RenderFrameHost* rfh) { |
| 2722 Profile* profile = Profile::FromBrowserContext( | 2722 Profile* profile = Profile::FromBrowserContext( |
| 2723 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext()); | 2723 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext()); |
| 2724 BrowsingDataRemover* remover = | 2724 BrowsingDataRemover* remover = |
| 2725 BrowsingDataRemoverFactory::GetForBrowserContext(profile); | 2725 BrowsingDataRemoverFactory::GetForBrowserContext(profile); |
| 2726 int remove_mask = BrowsingDataRemover::REMOVE_SITE_DATA; | 2726 remover->Remove(base::Time(), base::Time::Max(), |
| 2727 remover->Remove(base::Time(), base::Time::Max(), remove_mask, | 2727 BrowsingDataTypeSetSiteData(), |
| 2728 BrowsingDataHelper::UNPROTECTED_WEB); | 2728 BrowsingDataHelper::UNPROTECTED_WEB); |
| 2729 } | 2729 } |
| 2730 | 2730 |
| 2731 void ChromeContentBrowserClient::ClearSiteData( | 2731 void ChromeContentBrowserClient::ClearSiteData( |
| 2732 content::BrowserContext* browser_context, | 2732 content::BrowserContext* browser_context, |
| 2733 const url::Origin& origin, | 2733 const url::Origin& origin, |
| 2734 bool remove_cookies, | 2734 bool remove_cookies, |
| 2735 bool remove_storage, | 2735 bool remove_storage, |
| 2736 bool remove_cache, | 2736 bool remove_cache, |
| 2737 const base::Closure& callback) { | 2737 const base::Closure& callback) { |
| (...skipping 16 matching lines...) Expand all Loading... |
| 2754 net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES); | 2754 net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES); |
| 2755 | 2755 |
| 2756 if (domain.empty()) | 2756 if (domain.empty()) |
| 2757 domain = origin.host(); // IP address or internal hostname. | 2757 domain = origin.host(); // IP address or internal hostname. |
| 2758 | 2758 |
| 2759 std::unique_ptr<BrowsingDataFilterBuilder> domain_filter_builder( | 2759 std::unique_ptr<BrowsingDataFilterBuilder> domain_filter_builder( |
| 2760 BrowsingDataFilterBuilder::Create( | 2760 BrowsingDataFilterBuilder::Create( |
| 2761 BrowsingDataFilterBuilder::WHITELIST)); | 2761 BrowsingDataFilterBuilder::WHITELIST)); |
| 2762 domain_filter_builder->AddRegisterableDomain(domain); | 2762 domain_filter_builder->AddRegisterableDomain(domain); |
| 2763 | 2763 |
| 2764 std::set<const content::BrowsingDataType*> remove_mask; |
| 2765 remove_mask.insert(&kBrowsingDataTypeCookies); |
| 2766 remove_mask.insert(&kBrowsingDataTypeChannelIDs); |
| 2767 remove_mask.insert(&kBrowsingDataTypePluginData); |
| 2764 remover->RemoveWithFilterAndReply( | 2768 remover->RemoveWithFilterAndReply( |
| 2765 base::Time(), base::Time::Max(), | 2769 base::Time(), base::Time::Max(), remove_mask, BrowsingDataHelper::ALL, |
| 2766 BrowsingDataRemover::REMOVE_COOKIES | | 2770 std::move(domain_filter_builder), observer); |
| 2767 BrowsingDataRemover::REMOVE_CHANNEL_IDS | | |
| 2768 BrowsingDataRemover::REMOVE_PLUGIN_DATA, | |
| 2769 BrowsingDataHelper::ALL, std::move(domain_filter_builder), observer); | |
| 2770 } else { | 2771 } else { |
| 2771 // The first removal task is a no-op. | 2772 // The first removal task is a no-op. |
| 2772 observer->OnBrowsingDataRemoverDone(); | 2773 observer->OnBrowsingDataRemoverDone(); |
| 2773 } | 2774 } |
| 2774 | 2775 |
| 2775 // Delete origin-scoped data. | 2776 // Delete origin-scoped data. |
| 2776 int remove_mask = 0; | 2777 std::set<const content::BrowsingDataType*> remove_mask; |
| 2777 if (remove_storage) { | 2778 if (remove_storage) { |
| 2778 remove_mask |= BrowsingDataRemover::REMOVE_SITE_DATA & | 2779 remove_mask = BrowsingDataTypeSetSiteData(); |
| 2779 ~BrowsingDataRemover::REMOVE_COOKIES & | 2780 remove_mask.erase(&kBrowsingDataTypeCookies); |
| 2780 ~BrowsingDataRemover::REMOVE_CHANNEL_IDS & | 2781 remove_mask.erase(&kBrowsingDataTypeChannelIDs); |
| 2781 ~BrowsingDataRemover::REMOVE_PLUGIN_DATA; | 2782 remove_mask.erase(&kBrowsingDataTypePluginData); |
| 2782 } | 2783 } |
| 2783 if (remove_cache) | 2784 if (remove_cache) |
| 2784 remove_mask |= BrowsingDataRemover::REMOVE_CACHE; | 2785 remove_mask.insert(&kBrowsingDataTypeCache); |
| 2785 | 2786 |
| 2786 if (remove_mask) { | 2787 if (!remove_mask.empty()) { |
| 2787 std::unique_ptr<BrowsingDataFilterBuilder> origin_filter_builder( | 2788 std::unique_ptr<BrowsingDataFilterBuilder> origin_filter_builder( |
| 2788 BrowsingDataFilterBuilder::Create( | 2789 BrowsingDataFilterBuilder::Create( |
| 2789 BrowsingDataFilterBuilder::WHITELIST)); | 2790 BrowsingDataFilterBuilder::WHITELIST)); |
| 2790 origin_filter_builder->AddOrigin(origin); | 2791 origin_filter_builder->AddOrigin(origin); |
| 2791 | 2792 |
| 2792 remover->RemoveWithFilterAndReply( | 2793 remover->RemoveWithFilterAndReply( |
| 2793 base::Time(), base::Time::Max(), | 2794 base::Time(), base::Time::Max(), |
| 2794 remove_mask, BrowsingDataHelper::ALL, std::move(origin_filter_builder), | 2795 remove_mask, BrowsingDataHelper::ALL, std::move(origin_filter_builder), |
| 2795 observer); | 2796 observer); |
| 2796 } else { | 2797 } else { |
| (...skipping 744 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3541 RedirectNonUINonIOBrowserThreadsToTaskScheduler() { | 3542 RedirectNonUINonIOBrowserThreadsToTaskScheduler() { |
| 3542 return variations::GetVariationParamValue( | 3543 return variations::GetVariationParamValue( |
| 3543 "BrowserScheduler", "RedirectNonUINonIOBrowserThreads") == "true"; | 3544 "BrowserScheduler", "RedirectNonUINonIOBrowserThreads") == "true"; |
| 3544 } | 3545 } |
| 3545 | 3546 |
| 3546 // static | 3547 // static |
| 3547 void ChromeContentBrowserClient::SetDefaultQuotaSettingsForTesting( | 3548 void ChromeContentBrowserClient::SetDefaultQuotaSettingsForTesting( |
| 3548 const storage::QuotaSettings* settings) { | 3549 const storage::QuotaSettings* settings) { |
| 3549 g_default_quota_settings = settings; | 3550 g_default_quota_settings = settings; |
| 3550 } | 3551 } |
| OLD | NEW |