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

Side by Side Diff: chrome/browser/chrome_content_browser_client.cc

Issue 2025683003: First experimental implementation of the Clear-Site-Data header (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: REMOVE_PLUGIN_DATA for eTLD+1 Created 4 years, 4 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 unified diff | Download patch
OLDNEW
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 17 matching lines...) Expand all
28 #include "base/threading/thread_task_runner_handle.h" 28 #include "base/threading/thread_task_runner_handle.h"
29 #include "build/build_config.h" 29 #include "build/build_config.h"
30 #include "chrome/browser/after_startup_task_utils.h" 30 #include "chrome/browser/after_startup_task_utils.h"
31 #include "chrome/browser/apps/app_url_redirector.h" 31 #include "chrome/browser/apps/app_url_redirector.h"
32 #include "chrome/browser/browser_about_handler.h" 32 #include "chrome/browser/browser_about_handler.h"
33 #include "chrome/browser/browser_process.h" 33 #include "chrome/browser/browser_process.h"
34 #include "chrome/browser/browser_shutdown.h" 34 #include "chrome/browser/browser_shutdown.h"
35 #include "chrome/browser/browsing_data/browsing_data_helper.h" 35 #include "chrome/browser/browsing_data/browsing_data_helper.h"
36 #include "chrome/browser/browsing_data/browsing_data_remover.h" 36 #include "chrome/browser/browsing_data/browsing_data_remover.h"
37 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h" 37 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h"
38 #include "chrome/browser/browsing_data/origin_filter_builder.h"
39 #include "chrome/browser/browsing_data/registrable_domain_filter_builder.h"
38 #include "chrome/browser/character_encoding.h" 40 #include "chrome/browser/character_encoding.h"
39 #include "chrome/browser/chrome_content_browser_client_parts.h" 41 #include "chrome/browser/chrome_content_browser_client_parts.h"
40 #include "chrome/browser/chrome_net_benchmarking_message_filter.h" 42 #include "chrome/browser/chrome_net_benchmarking_message_filter.h"
41 #include "chrome/browser/chrome_quota_permission_context.h" 43 #include "chrome/browser/chrome_quota_permission_context.h"
42 #include "chrome/browser/content_settings/cookie_settings_factory.h" 44 #include "chrome/browser/content_settings/cookie_settings_factory.h"
43 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" 45 #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
44 #include "chrome/browser/content_settings/tab_specific_content_settings.h" 46 #include "chrome/browser/content_settings/tab_specific_content_settings.h"
45 #include "chrome/browser/defaults.h" 47 #include "chrome/browser/defaults.h"
46 #include "chrome/browser/devtools/chrome_devtools_manager_delegate.h" 48 #include "chrome/browser/devtools/chrome_devtools_manager_delegate.h"
47 #include "chrome/browser/download/download_prefs.h" 49 #include "chrome/browser/download/download_prefs.h"
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
162 #include "content/public/common/content_features.h" 164 #include "content/public/common/content_features.h"
163 #include "content/public/common/content_switches.h" 165 #include "content/public/common/content_switches.h"
164 #include "content/public/common/mojo_shell_connection.h" 166 #include "content/public/common/mojo_shell_connection.h"
165 #include "content/public/common/sandbox_type.h" 167 #include "content/public/common/sandbox_type.h"
166 #include "content/public/common/url_utils.h" 168 #include "content/public/common/url_utils.h"
167 #include "content/public/common/web_preferences.h" 169 #include "content/public/common/web_preferences.h"
168 #include "device/usb/public/interfaces/chooser_service.mojom.h" 170 #include "device/usb/public/interfaces/chooser_service.mojom.h"
169 #include "device/usb/public/interfaces/device_manager.mojom.h" 171 #include "device/usb/public/interfaces/device_manager.mojom.h"
170 #include "gin/v8_initializer.h" 172 #include "gin/v8_initializer.h"
171 #include "net/base/mime_util.h" 173 #include "net/base/mime_util.h"
174 #include "net/base/registry_controlled_domains/registry_controlled_domain.h"
172 #include "net/cookies/canonical_cookie.h" 175 #include "net/cookies/canonical_cookie.h"
173 #include "net/cookies/cookie_options.h" 176 #include "net/cookies/cookie_options.h"
174 #include "net/ssl/ssl_cert_request_info.h" 177 #include "net/ssl/ssl_cert_request_info.h"
175 #include "ppapi/host/ppapi_host.h" 178 #include "ppapi/host/ppapi_host.h"
176 #include "services/shell/public/cpp/service.h" 179 #include "services/shell/public/cpp/service.h"
177 #include "storage/browser/fileapi/external_mount_points.h" 180 #include "storage/browser/fileapi/external_mount_points.h"
178 #include "ui/base/l10n/l10n_util.h" 181 #include "ui/base/l10n/l10n_util.h"
179 #include "ui/base/resource/resource_bundle.h" 182 #include "ui/base/resource/resource_bundle.h"
180 #include "ui/resources/grit/ui_resources.h" 183 #include "ui/resources/grit/ui_resources.h"
181 #include "url/gurl.h" 184 #include "url/gurl.h"
(...skipping 550 matching lines...) Expand 10 before | Expand all | Expand 10 after
732 } 735 }
733 736
734 bool GetDataSaverEnabledPref(const PrefService* prefs) { 737 bool GetDataSaverEnabledPref(const PrefService* prefs) {
735 // Enable data saver only when data saver pref is enabled and not part of 738 // Enable data saver only when data saver pref is enabled and not part of
736 // "Disabled" group of "SaveDataHeader" experiment. 739 // "Disabled" group of "SaveDataHeader" experiment.
737 return prefs->GetBoolean(prefs::kDataSaverEnabled) && 740 return prefs->GetBoolean(prefs::kDataSaverEnabled) &&
738 base::FieldTrialList::FindFullName("SaveDataHeader") 741 base::FieldTrialList::FindFullName("SaveDataHeader")
739 .compare("Disabled"); 742 .compare("Disabled");
740 } 743 }
741 744
745 // A BrowsingDataRemover::Observer that waits for |count|
746 // OnBrowsingDataRemoverDone() callbacks, translates them into
747 // one base::Closure, and then destroys itself.
748 class ClearSiteDataObserver : public BrowsingDataRemover::Observer {
749 public:
750 explicit ClearSiteDataObserver(BrowsingDataRemover* remover,
751 const base::Closure& callback,
752 int count)
753 : remover_(remover), callback_(callback), count_(count) {
754 remover_->AddObserver(this);
755 }
756
757 ~ClearSiteDataObserver() override { remover_->RemoveObserver(this); }
758
759 // BrowsingDataRemover::Observer.
760 void OnBrowsingDataRemoverDone() override {
761 DCHECK(count_);
762 if (--count_)
763 return;
764
765 callback_.Run();
766 delete this;
767 }
768
769 private:
770 BrowsingDataRemover* remover_;
771 base::Closure callback_;
772 int count_;
773 };
774
742 } // namespace 775 } // namespace
743 776
744 ChromeContentBrowserClient::ChromeContentBrowserClient() 777 ChromeContentBrowserClient::ChromeContentBrowserClient()
745 : weak_factory_(this) { 778 : weak_factory_(this) {
746 #if defined(ENABLE_PLUGINS) 779 #if defined(ENABLE_PLUGINS)
747 for (size_t i = 0; i < arraysize(kPredefinedAllowedDevChannelOrigins); ++i) 780 for (size_t i = 0; i < arraysize(kPredefinedAllowedDevChannelOrigins); ++i)
748 allowed_dev_channel_origins_.insert(kPredefinedAllowedDevChannelOrigins[i]); 781 allowed_dev_channel_origins_.insert(kPredefinedAllowedDevChannelOrigins[i]);
749 for (size_t i = 0; i < arraysize(kPredefinedAllowedFileHandleOrigins); ++i) 782 for (size_t i = 0; i < arraysize(kPredefinedAllowedFileHandleOrigins); ++i)
750 allowed_file_handle_origins_.insert(kPredefinedAllowedFileHandleOrigins[i]); 783 allowed_file_handle_origins_.insert(kPredefinedAllowedFileHandleOrigins[i]);
751 for (size_t i = 0; i < arraysize(kPredefinedAllowedSocketOrigins); ++i) 784 for (size_t i = 0; i < arraysize(kPredefinedAllowedSocketOrigins); ++i)
(...skipping 1703 matching lines...) Expand 10 before | Expand all | Expand 10 after
2455 void ChromeContentBrowserClient::ClearCookies(RenderFrameHost* rfh) { 2488 void ChromeContentBrowserClient::ClearCookies(RenderFrameHost* rfh) {
2456 Profile* profile = Profile::FromBrowserContext( 2489 Profile* profile = Profile::FromBrowserContext(
2457 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext()); 2490 rfh->GetSiteInstance()->GetProcess()->GetBrowserContext());
2458 BrowsingDataRemover* remover = 2491 BrowsingDataRemover* remover =
2459 BrowsingDataRemoverFactory::GetForBrowserContext(profile); 2492 BrowsingDataRemoverFactory::GetForBrowserContext(profile);
2460 int remove_mask = BrowsingDataRemover::REMOVE_SITE_DATA; 2493 int remove_mask = BrowsingDataRemover::REMOVE_SITE_DATA;
2461 remover->Remove(BrowsingDataRemover::Unbounded(), remove_mask, 2494 remover->Remove(BrowsingDataRemover::Unbounded(), remove_mask,
2462 BrowsingDataHelper::UNPROTECTED_WEB); 2495 BrowsingDataHelper::UNPROTECTED_WEB);
2463 } 2496 }
2464 2497
2498 void ChromeContentBrowserClient::ClearSiteData(
2499 content::BrowserContext* browser_context,
2500 const url::Origin& origin,
2501 bool remove_cookies,
2502 bool remove_storage,
2503 bool remove_cache,
2504 const base::Closure& callback) {
2505 BrowsingDataRemover* remover =
2506 BrowsingDataRemoverFactory::GetForBrowserContext(browser_context);
2507
2508 // ClearSiteDataObserver deletes itself when callbacks from both removal
2509 // tasks are received.
2510 ClearSiteDataObserver* observer =
2511 new ClearSiteDataObserver(remover, callback, 2 /* number of tasks */);
2512
2513 // Cookies and channel IDs are scoped to
2514 // a) eTLD+1 of |origin|'s host if |origin|'s host is a registrable domain
2515 // or a subdomain thereof
2516 // b) |origin|'s host exactly if it is an IP address or an internal hostname
2517 // (e.g. "localhost" or "fileserver").
2518 if (remove_cookies) {
2519 std::string domain = GetDomainAndRegistry(
2520 origin.host(),
2521 net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES);
2522
2523 if (domain.empty())
2524 domain = origin.host(); // IP address or internal hostname.
2525
2526 std::unique_ptr<RegistrableDomainFilterBuilder> domain_filter_builder(
2527 new RegistrableDomainFilterBuilder(
2528 BrowsingDataFilterBuilder::WHITELIST));
2529 domain_filter_builder->AddRegisterableDomain(domain);
2530
2531 remover->RemoveWithFilterAndReply(
2532 BrowsingDataRemover::Period(browsing_data::TimePeriod::ALL_TIME),
2533 BrowsingDataRemover::REMOVE_COOKIES |
2534 BrowsingDataRemover::REMOVE_CHANNEL_IDS |
2535 BrowsingDataRemover::REMOVE_PLUGIN_DATA,
2536 BrowsingDataHelper::ALL, std::move(domain_filter_builder), observer);
2537 } else {
2538 // The first removal task is a no-op.
2539 observer->OnBrowsingDataRemoverDone();
2540 }
2541
2542 // Delete origin-scoped data.
2543 int remove_mask = 0;
2544 if (remove_storage) {
2545 remove_mask |= BrowsingDataRemover::REMOVE_SITE_DATA &
2546 ~BrowsingDataRemover::REMOVE_COOKIES &
2547 ~BrowsingDataRemover::REMOVE_CHANNEL_IDS &
2548 ~BrowsingDataRemover::REMOVE_PLUGIN_DATA;
2549 }
2550 if (remove_cache)
2551 remove_mask |= BrowsingDataRemover::REMOVE_CACHE;
2552
2553 if (remove_mask) {
2554 std::unique_ptr<OriginFilterBuilder> origin_filter_builder(
2555 new OriginFilterBuilder(BrowsingDataFilterBuilder::WHITELIST));
2556 origin_filter_builder->AddOrigin(origin);
2557
2558 remover->RemoveWithFilterAndReply(
2559 BrowsingDataRemover::Period(browsing_data::TimePeriod::ALL_TIME),
2560 remove_mask, BrowsingDataHelper::ALL, std::move(origin_filter_builder),
2561 observer);
2562 } else {
2563 // The second removal task is a no-op.
2564 observer->OnBrowsingDataRemoverDone();
2565 }
2566 }
2567
2465 base::FilePath ChromeContentBrowserClient::GetDefaultDownloadDirectory() { 2568 base::FilePath ChromeContentBrowserClient::GetDefaultDownloadDirectory() {
2466 return DownloadPrefs::GetDefaultDownloadDirectory(); 2569 return DownloadPrefs::GetDefaultDownloadDirectory();
2467 } 2570 }
2468 2571
2469 std::string ChromeContentBrowserClient::GetDefaultDownloadName() { 2572 std::string ChromeContentBrowserClient::GetDefaultDownloadName() {
2470 return l10n_util::GetStringUTF8(IDS_DEFAULT_DOWNLOAD_FILENAME); 2573 return l10n_util::GetStringUTF8(IDS_DEFAULT_DOWNLOAD_FILENAME);
2471 } 2574 }
2472 2575
2473 base::FilePath ChromeContentBrowserClient::GetShaderDiskCacheDirectory() { 2576 base::FilePath ChromeContentBrowserClient::GetShaderDiskCacheDirectory() {
2474 base::FilePath user_data_dir; 2577 base::FilePath user_data_dir;
(...skipping 579 matching lines...) Expand 10 before | Expand all | Expand 10 after
3054 if (channel <= kMaxDisableEncryptionChannel) { 3157 if (channel <= kMaxDisableEncryptionChannel) {
3055 static const char* const kWebRtcDevSwitchNames[] = { 3158 static const char* const kWebRtcDevSwitchNames[] = {
3056 switches::kDisableWebRtcEncryption, 3159 switches::kDisableWebRtcEncryption,
3057 }; 3160 };
3058 to_command_line->CopySwitchesFrom(from_command_line, 3161 to_command_line->CopySwitchesFrom(from_command_line,
3059 kWebRtcDevSwitchNames, 3162 kWebRtcDevSwitchNames,
3060 arraysize(kWebRtcDevSwitchNames)); 3163 arraysize(kWebRtcDevSwitchNames));
3061 } 3164 }
3062 } 3165 }
3063 #endif // defined(ENABLE_WEBRTC) 3166 #endif // defined(ENABLE_WEBRTC)
OLDNEW
« no previous file with comments | « chrome/browser/chrome_content_browser_client.h ('k') | chrome/browser/chrome_content_browser_client_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698