Chromium Code Reviews| 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/renderer_host/chrome_render_message_filter.h" | 5 #include "chrome/browser/renderer_host/chrome_render_message_filter.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <string> | 9 #include <string> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/bind_helpers.h" | 12 #include "base/bind_helpers.h" |
| 13 #include "base/feature_list.h" | |
|
nhiroki
2016/07/25 06:15:13
Are this and other header inclusions added by this
horo
2016/07/25 08:24:26
Done.
nhiroki
2016/07/25 09:26:45
How about storage_partition.h and content_features
| |
| 13 #include "base/logging.h" | 14 #include "base/logging.h" |
| 14 #include "base/macros.h" | 15 #include "base/macros.h" |
| 15 #include "base/metrics/field_trial.h" | 16 #include "base/metrics/field_trial.h" |
| 16 #include "chrome/browser/browser_process.h" | 17 #include "chrome/browser/browser_process.h" |
| 17 #include "chrome/browser/chrome_notification_types.h" | 18 #include "chrome/browser/chrome_notification_types.h" |
| 18 #include "chrome/browser/content_settings/cookie_settings_factory.h" | 19 #include "chrome/browser/content_settings/cookie_settings_factory.h" |
| 19 #include "chrome/browser/content_settings/tab_specific_content_settings.h" | 20 #include "chrome/browser/content_settings/tab_specific_content_settings.h" |
| 20 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 21 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
| 21 #include "chrome/browser/net/predictor.h" | 22 #include "chrome/browser/net/predictor.h" |
| 22 #include "chrome/browser/profiles/profile.h" | 23 #include "chrome/browser/profiles/profile.h" |
| 23 #include "chrome/browser/profiles/profile_manager.h" | 24 #include "chrome/browser/profiles/profile_manager.h" |
| 24 #include "chrome/common/render_messages.h" | 25 #include "chrome/common/render_messages.h" |
| 25 #include "components/content_settings/content/common/content_settings_messages.h " | 26 #include "components/content_settings/content/common/content_settings_messages.h " |
| 26 #include "components/content_settings/core/browser/cookie_settings.h" | 27 #include "components/content_settings/core/browser/cookie_settings.h" |
| 27 #include "components/network_hints/common/network_hints_common.h" | 28 #include "components/network_hints/common/network_hints_common.h" |
| 28 #include "components/network_hints/common/network_hints_messages.h" | 29 #include "components/network_hints/common/network_hints_messages.h" |
| 29 #include "components/rappor/rappor_service.h" | 30 #include "components/rappor/rappor_service.h" |
| 30 #include "components/rappor/rappor_utils.h" | 31 #include "components/rappor/rappor_utils.h" |
| 31 #include "components/web_cache/browser/web_cache_manager.h" | 32 #include "components/web_cache/browser/web_cache_manager.h" |
| 32 #include "content/public/browser/notification_service.h" | 33 #include "content/public/browser/notification_service.h" |
| 33 #include "content/public/browser/render_process_host.h" | 34 #include "content/public/browser/render_process_host.h" |
|
nhiroki
2016/07/25 06:15:13
#include "content/public/browser/service_worker_co
horo
2016/07/25 08:24:26
Done.
| |
| 35 #include "content/public/browser/storage_partition.h" | |
| 36 #include "content/public/common/content_features.h" | |
| 34 | 37 |
| 35 #if defined(ENABLE_EXTENSIONS) | 38 #if defined(ENABLE_EXTENSIONS) |
| 36 #include "extensions/browser/guest_view/web_view/web_view_permission_helper.h" | 39 #include "extensions/browser/guest_view/web_view/web_view_permission_helper.h" |
| 37 #include "extensions/browser/guest_view/web_view/web_view_renderer_state.h" | 40 #include "extensions/browser/guest_view/web_view/web_view_renderer_state.h" |
| 38 #include "extensions/common/manifest_handlers/default_locale_handler.h" | 41 #include "extensions/common/manifest_handlers/default_locale_handler.h" |
| 39 #endif | 42 #endif |
| 40 | 43 |
| 41 using content::BrowserThread; | 44 using content::BrowserThread; |
| 42 | 45 |
| 43 namespace { | 46 namespace { |
| 44 | 47 |
| 45 const uint32_t kFilteredMessageClasses[] = { | 48 const uint32_t kFilteredMessageClasses[] = { |
| 46 ChromeMsgStart, ContentSettingsMsgStart, NetworkHintsMsgStart, | 49 ChromeMsgStart, ContentSettingsMsgStart, NetworkHintsMsgStart, |
| 47 }; | 50 }; |
| 48 | 51 |
| 52 void DidStartServiceWorkerForNavigationHint(bool success) { | |
| 53 DCHECK_CURRENTLY_ON(BrowserThread::UI); | |
| 54 } | |
| 55 | |
| 49 } // namespace | 56 } // namespace |
| 50 | 57 |
| 51 ChromeRenderMessageFilter::ChromeRenderMessageFilter(int render_process_id, | 58 ChromeRenderMessageFilter::ChromeRenderMessageFilter( |
| 52 Profile* profile) | 59 int render_process_id, |
| 60 Profile* profile, | |
| 61 content::ServiceWorkerContext* service_worker_context) | |
| 53 : BrowserMessageFilter(kFilteredMessageClasses, | 62 : BrowserMessageFilter(kFilteredMessageClasses, |
| 54 arraysize(kFilteredMessageClasses)), | 63 arraysize(kFilteredMessageClasses)), |
| 55 render_process_id_(render_process_id), | 64 render_process_id_(render_process_id), |
| 56 profile_(profile), | 65 profile_(profile), |
| 57 predictor_(profile_->GetNetworkPredictor()), | 66 predictor_(profile_->GetNetworkPredictor()), |
| 58 cookie_settings_(CookieSettingsFactory::GetForProfile(profile)) { | 67 cookie_settings_(CookieSettingsFactory::GetForProfile(profile)), |
| 59 } | 68 service_worker_context_(service_worker_context) {} |
| 60 | 69 |
| 61 ChromeRenderMessageFilter::~ChromeRenderMessageFilter() { | 70 ChromeRenderMessageFilter::~ChromeRenderMessageFilter() { |
| 62 } | 71 } |
| 63 | 72 |
| 64 bool ChromeRenderMessageFilter::OnMessageReceived(const IPC::Message& message) { | 73 bool ChromeRenderMessageFilter::OnMessageReceived(const IPC::Message& message) { |
| 65 bool handled = true; | 74 bool handled = true; |
| 66 IPC_BEGIN_MESSAGE_MAP(ChromeRenderMessageFilter, message) | 75 IPC_BEGIN_MESSAGE_MAP(ChromeRenderMessageFilter, message) |
| 67 IPC_MESSAGE_HANDLER(NetworkHintsMsg_DNSPrefetch, OnDnsPrefetch) | 76 IPC_MESSAGE_HANDLER(NetworkHintsMsg_DNSPrefetch, OnDnsPrefetch) |
| 68 IPC_MESSAGE_HANDLER(NetworkHintsMsg_Preconnect, OnPreconnect) | 77 IPC_MESSAGE_HANDLER(NetworkHintsMsg_Preconnect, OnPreconnect) |
| 69 IPC_MESSAGE_HANDLER(NetworkHintsMsg_NavigationHint, OnNavigationHint) | 78 IPC_MESSAGE_HANDLER(NetworkHintsMsg_NavigationHint, OnNavigationHint) |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 87 IPC_MESSAGE_HANDLER(ChromeViewHostMsg_RecordRapporURL, OnRecordRapporURL) | 96 IPC_MESSAGE_HANDLER(ChromeViewHostMsg_RecordRapporURL, OnRecordRapporURL) |
| 88 IPC_MESSAGE_UNHANDLED(handled = false) | 97 IPC_MESSAGE_UNHANDLED(handled = false) |
| 89 IPC_END_MESSAGE_MAP() | 98 IPC_END_MESSAGE_MAP() |
| 90 | 99 |
| 91 return handled; | 100 return handled; |
| 92 } | 101 } |
| 93 | 102 |
| 94 void ChromeRenderMessageFilter::OverrideThreadForMessage( | 103 void ChromeRenderMessageFilter::OverrideThreadForMessage( |
| 95 const IPC::Message& message, BrowserThread::ID* thread) { | 104 const IPC::Message& message, BrowserThread::ID* thread) { |
| 96 switch (message.type()) { | 105 switch (message.type()) { |
| 106 case NetworkHintsMsg_NavigationHint::ID: | |
| 97 #if defined(ENABLE_PLUGINS) | 107 #if defined(ENABLE_PLUGINS) |
| 98 case ChromeViewHostMsg_IsCrashReportingEnabled::ID: | 108 case ChromeViewHostMsg_IsCrashReportingEnabled::ID: |
| 99 #endif | 109 #endif |
| 100 case ChromeViewHostMsg_UpdatedCacheStats::ID: | 110 case ChromeViewHostMsg_UpdatedCacheStats::ID: |
| 101 case ChromeViewHostMsg_RecordRappor::ID: | 111 case ChromeViewHostMsg_RecordRappor::ID: |
| 102 case ChromeViewHostMsg_RecordRapporURL::ID: | 112 case ChromeViewHostMsg_RecordRapporURL::ID: |
| 103 *thread = BrowserThread::UI; | 113 *thread = BrowserThread::UI; |
| 104 break; | 114 break; |
| 105 default: | 115 default: |
| 106 break; | 116 break; |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 127 chrome_browser_net::UrlInfo::EARLY_LOAD_MOTIVATED, | 137 chrome_browser_net::UrlInfo::EARLY_LOAD_MOTIVATED, |
| 128 allow_credentials, count); | 138 allow_credentials, count); |
| 129 } | 139 } |
| 130 } | 140 } |
| 131 | 141 |
| 132 void ChromeRenderMessageFilter::OnNavigationHint( | 142 void ChromeRenderMessageFilter::OnNavigationHint( |
| 133 const GURL& url, | 143 const GURL& url, |
| 134 blink::WebNavigationHintType type) { | 144 blink::WebNavigationHintType type) { |
| 135 // TODO(horo): We don't need to have this method in //chrome. Move it to | 145 // TODO(horo): We don't need to have this method in //chrome. Move it to |
| 136 // //content while mojoifing network_hints. (crbug.com/610750) | 146 // //content while mojoifing network_hints. (crbug.com/610750) |
| 137 // TODO(horo): Implement this. | 147 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 148 service_worker_context_->StartServiceWorkerForNavigationHint( | |
| 149 url, type, render_process_id_, | |
| 150 base::Bind(&DidStartServiceWorkerForNavigationHint)); | |
| 138 } | 151 } |
| 139 | 152 |
| 140 void ChromeRenderMessageFilter::OnUpdatedCacheStats( | 153 void ChromeRenderMessageFilter::OnUpdatedCacheStats( |
| 141 uint64_t min_dead_capacity, | 154 uint64_t min_dead_capacity, |
| 142 uint64_t max_dead_capacity, | 155 uint64_t max_dead_capacity, |
| 143 uint64_t capacity, | 156 uint64_t capacity, |
| 144 uint64_t live_size, | 157 uint64_t live_size, |
| 145 uint64_t dead_size) { | 158 uint64_t dead_size) { |
| 146 web_cache::WebCacheManager::GetInstance()->ObserveStats( | 159 web_cache::WebCacheManager::GetInstance()->ObserveStats( |
| 147 render_process_id_, min_dead_capacity, max_dead_capacity, capacity, | 160 render_process_id_, min_dead_capacity, max_dead_capacity, capacity, |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 360 rappor::SampleString(g_browser_process->rappor_service(), metric, | 373 rappor::SampleString(g_browser_process->rappor_service(), metric, |
| 361 rappor::ETLD_PLUS_ONE_RAPPOR_TYPE, sample); | 374 rappor::ETLD_PLUS_ONE_RAPPOR_TYPE, sample); |
| 362 } | 375 } |
| 363 | 376 |
| 364 void ChromeRenderMessageFilter::OnRecordRapporURL(const std::string& metric, | 377 void ChromeRenderMessageFilter::OnRecordRapporURL(const std::string& metric, |
| 365 const GURL& sample) { | 378 const GURL& sample) { |
| 366 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 379 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 367 rappor::SampleDomainAndRegistryFromGURL(g_browser_process->rappor_service(), | 380 rappor::SampleDomainAndRegistryFromGURL(g_browser_process->rappor_service(), |
| 368 metric, sample); | 381 metric, sample); |
| 369 } | 382 } |
| OLD | NEW |