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

Side by Side Diff: chrome/browser/renderer_host/chrome_render_message_filter.cc

Issue 2052613003: Speculatively launch Service Workers on mouse/touch events. [3/5] (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: use OverrideThreadForMessage to call StartServiceWorkerForNavigationHinton UI thread Created 4 years, 5 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/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
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
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
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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698