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 17 matching lines...) Expand all Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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 Loading... |
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) |
OLD | NEW |