OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/service_worker/service_worker_dispatcher_host.h" | 5 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
9 #include "content/browser/message_port_message_filter.h" | 9 #include "content/browser/message_port_message_filter.h" |
10 #include "content/browser/message_port_service.h" | 10 #include "content/browser/message_port_service.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 #include "url/gurl.h" | 21 #include "url/gurl.h" |
22 | 22 |
23 using blink::WebServiceWorkerError; | 23 using blink::WebServiceWorkerError; |
24 | 24 |
25 namespace content { | 25 namespace content { |
26 | 26 |
27 namespace { | 27 namespace { |
28 | 28 |
29 const char kShutdownErrorMessage[] = | 29 const char kShutdownErrorMessage[] = |
30 "The Service Worker system has shutdown."; | 30 "The Service Worker system has shutdown."; |
31 const char kDomainMismatchErrorMessage[] = | |
32 "Scope and scripts do not have the same origin"; | |
33 | 31 |
34 const uint32 kFilteredMessageClasses[] = { | 32 const uint32 kFilteredMessageClasses[] = { |
35 ServiceWorkerMsgStart, | 33 ServiceWorkerMsgStart, |
36 EmbeddedWorkerMsgStart, | 34 EmbeddedWorkerMsgStart, |
37 }; | 35 }; |
38 | 36 |
| 37 // TODO(dominicc): When crbug.com/362214 is fixed, make |
| 38 // Can(R|Unr)egisterServiceWorker also check that these are secure |
| 39 // origins to defend against compromised renderers. |
39 bool CanRegisterServiceWorker(const GURL& document_url, | 40 bool CanRegisterServiceWorker(const GURL& document_url, |
40 const GURL& pattern, | 41 const GURL& pattern, |
41 const GURL& script_url) { | 42 const GURL& script_url) { |
42 // TODO: Respect Chrome's content settings, if we add a setting for | 43 // TODO: Respect Chrome's content settings, if we add a setting for |
43 // controlling whether Service Worker is allowed. | 44 // controlling whether Service Worker is allowed. |
44 return document_url.GetOrigin() == pattern.GetOrigin() && | 45 return document_url.GetOrigin() == pattern.GetOrigin() && |
45 document_url.GetOrigin() == script_url.GetOrigin(); | 46 document_url.GetOrigin() == script_url.GetOrigin(); |
46 } | 47 } |
47 | 48 |
48 bool CanUnregisterServiceWorker(const GURL& document_url, | 49 bool CanUnregisterServiceWorker(const GURL& document_url, |
(...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
189 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( | 190 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( |
190 thread_id, | 191 thread_id, |
191 request_id, | 192 request_id, |
192 WebServiceWorkerError::ErrorTypeAbort, | 193 WebServiceWorkerError::ErrorTypeAbort, |
193 base::ASCIIToUTF16(kShutdownErrorMessage))); | 194 base::ASCIIToUTF16(kShutdownErrorMessage))); |
194 return; | 195 return; |
195 } | 196 } |
196 | 197 |
197 if (!CanRegisterServiceWorker( | 198 if (!CanRegisterServiceWorker( |
198 provider_host->document_url(), pattern, script_url)) { | 199 provider_host->document_url(), pattern, script_url)) { |
199 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( | 200 BadMessageReceived(); |
200 thread_id, | |
201 request_id, | |
202 WebServiceWorkerError::ErrorTypeSecurity, | |
203 base::ASCIIToUTF16(kDomainMismatchErrorMessage))); | |
204 return; | 201 return; |
205 } | 202 } |
206 GetContext()->RegisterServiceWorker( | 203 GetContext()->RegisterServiceWorker( |
207 pattern, | 204 pattern, |
208 script_url, | 205 script_url, |
209 render_process_id_, | 206 render_process_id_, |
210 provider_host, | 207 provider_host, |
211 base::Bind(&ServiceWorkerDispatcherHost::RegistrationComplete, | 208 base::Bind(&ServiceWorkerDispatcherHost::RegistrationComplete, |
212 this, | 209 this, |
213 thread_id, | 210 thread_id, |
(...skipping 23 matching lines...) Expand all Loading... |
237 if (!provider_host->IsContextAlive()) { | 234 if (!provider_host->IsContextAlive()) { |
238 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( | 235 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( |
239 thread_id, | 236 thread_id, |
240 request_id, | 237 request_id, |
241 blink::WebServiceWorkerError::ErrorTypeAbort, | 238 blink::WebServiceWorkerError::ErrorTypeAbort, |
242 base::ASCIIToUTF16(kShutdownErrorMessage))); | 239 base::ASCIIToUTF16(kShutdownErrorMessage))); |
243 return; | 240 return; |
244 } | 241 } |
245 | 242 |
246 if (!CanUnregisterServiceWorker(provider_host->document_url(), pattern)) { | 243 if (!CanUnregisterServiceWorker(provider_host->document_url(), pattern)) { |
247 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( | 244 BadMessageReceived(); |
248 thread_id, | |
249 request_id, | |
250 WebServiceWorkerError::ErrorTypeSecurity, | |
251 base::ASCIIToUTF16(kDomainMismatchErrorMessage))); | |
252 return; | 245 return; |
253 } | 246 } |
254 | 247 |
255 GetContext()->UnregisterServiceWorker( | 248 GetContext()->UnregisterServiceWorker( |
256 pattern, | 249 pattern, |
257 base::Bind(&ServiceWorkerDispatcherHost::UnregistrationComplete, | 250 base::Bind(&ServiceWorkerDispatcherHost::UnregistrationComplete, |
258 this, | 251 this, |
259 thread_id, | 252 thread_id, |
260 request_id)); | 253 request_id)); |
261 } | 254 } |
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
471 status, &error_type, &error_message); | 464 status, &error_type, &error_message); |
472 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( | 465 Send(new ServiceWorkerMsg_ServiceWorkerRegistrationError( |
473 thread_id, request_id, error_type, error_message)); | 466 thread_id, request_id, error_type, error_message)); |
474 } | 467 } |
475 | 468 |
476 ServiceWorkerContextCore* ServiceWorkerDispatcherHost::GetContext() { | 469 ServiceWorkerContextCore* ServiceWorkerDispatcherHost::GetContext() { |
477 return context_wrapper_->context(); | 470 return context_wrapper_->context(); |
478 } | 471 } |
479 | 472 |
480 } // namespace content | 473 } // namespace content |
OLD | NEW |