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