OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 12 matching lines...) Expand all Loading... |
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
30 | 30 |
31 #include "web/ServiceWorkerGlobalScopeProxy.h" | 31 #include "web/ServiceWorkerGlobalScopeProxy.h" |
32 | 32 |
| 33 #include "base/time/time.h" |
33 #include "bindings/core/v8/SourceLocation.h" | 34 #include "bindings/core/v8/SourceLocation.h" |
34 #include "bindings/core/v8/WorkerOrWorkletScriptController.h" | 35 #include "bindings/core/v8/WorkerOrWorkletScriptController.h" |
35 #include "core/dom/Document.h" | 36 #include "core/dom/Document.h" |
36 #include "core/dom/ExecutionContext.h" | 37 #include "core/dom/ExecutionContext.h" |
37 #include "core/dom/ExecutionContextTask.h" | 38 #include "core/dom/ExecutionContextTask.h" |
38 #include "core/dom/MessagePort.h" | 39 #include "core/dom/MessagePort.h" |
39 #include "core/inspector/ConsoleMessage.h" | 40 #include "core/inspector/ConsoleMessage.h" |
| 41 #include "core/inspector/InspectorInstrumentation.h" |
40 #include "core/origin_trials/OriginTrials.h" | 42 #include "core/origin_trials/OriginTrials.h" |
41 #include "core/workers/ParentFrameTaskRunners.h" | 43 #include "core/workers/ParentFrameTaskRunners.h" |
42 #include "core/workers/WorkerGlobalScope.h" | 44 #include "core/workers/WorkerGlobalScope.h" |
43 #include "core/workers/WorkerThread.h" | 45 #include "core/workers/WorkerThread.h" |
44 #include "modules/background_sync/SyncEvent.h" | 46 #include "modules/background_sync/SyncEvent.h" |
45 #include "modules/fetch/Headers.h" | 47 #include "modules/fetch/Headers.h" |
46 #include "modules/notifications/Notification.h" | 48 #include "modules/notifications/Notification.h" |
47 #include "modules/notifications/NotificationEvent.h" | 49 #include "modules/notifications/NotificationEvent.h" |
48 #include "modules/notifications/NotificationEventInit.h" | 50 #include "modules/notifications/NotificationEventInit.h" |
49 #include "modules/payments/PaymentAppRequestData.h" | 51 #include "modules/payments/PaymentAppRequestData.h" |
(...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
190 waitUntilObserver->willDispatchEvent(); | 192 waitUntilObserver->willDispatchEvent(); |
191 respondWithObserver->willDispatchEvent(); | 193 respondWithObserver->willDispatchEvent(); |
192 DispatchEventResult dispatchResult = | 194 DispatchEventResult dispatchResult = |
193 workerGlobalScope()->dispatchEvent(fetchEvent); | 195 workerGlobalScope()->dispatchEvent(fetchEvent); |
194 respondWithObserver->didDispatchEvent(dispatchResult); | 196 respondWithObserver->didDispatchEvent(dispatchResult); |
195 // false is okay because waitUntil for fetch event doesn't care about the | 197 // false is okay because waitUntil for fetch event doesn't care about the |
196 // promise rejection or an uncaught runtime script error. | 198 // promise rejection or an uncaught runtime script error. |
197 waitUntilObserver->didDispatchEvent(false /* errorOccurred */); | 199 waitUntilObserver->didDispatchEvent(false /* errorOccurred */); |
198 } | 200 } |
199 | 201 |
| 202 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadSent( |
| 203 int fetchEventID, |
| 204 const WebURL& url, |
| 205 base::TimeTicks sentTimestamp, |
| 206 base::Time sentWallTime) { |
| 207 InspectorInstrumentation::didSendNavigationPreload( |
| 208 workerGlobalScope(), fetchEventID, url, |
| 209 sentTimestamp.ToInternalValue() / |
| 210 static_cast<double>(base::Time::kMicrosecondsPerSecond), |
| 211 sentWallTime.ToDoubleT()); |
| 212 } |
| 213 |
200 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadResponse( | 214 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadResponse( |
201 int fetchEventID, | 215 int fetchEventID, |
202 std::unique_ptr<WebURLResponse> response, | 216 std::unique_ptr<WebURLResponse> response, |
203 std::unique_ptr<WebDataConsumerHandle> dataConsumeHandle) { | 217 std::unique_ptr<WebDataConsumerHandle> dataConsumeHandle) { |
| 218 InspectorInstrumentation::didReceiveNavigationPreloadResponse( |
| 219 workerGlobalScope(), fetchEventID, response->toResourceResponse()); |
204 FetchEvent* fetchEvent = m_pendingPreloadFetchEvents.take(fetchEventID); | 220 FetchEvent* fetchEvent = m_pendingPreloadFetchEvents.take(fetchEventID); |
205 DCHECK(fetchEvent); | 221 DCHECK(fetchEvent); |
206 fetchEvent->onNavigationPreloadResponse( | 222 fetchEvent->onNavigationPreloadResponse( |
207 workerGlobalScope()->scriptController()->getScriptState(), | 223 workerGlobalScope()->scriptController()->getScriptState(), |
208 std::move(response), std::move(dataConsumeHandle)); | 224 std::move(response), std::move(dataConsumeHandle)); |
209 } | 225 } |
210 | 226 |
211 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadError( | 227 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadError( |
212 int fetchEventID, | 228 int fetchEventID, |
213 std::unique_ptr<WebServiceWorkerError> error) { | 229 std::unique_ptr<WebServiceWorkerError> error) { |
| 230 InspectorInstrumentation::didReceiveNavigationPreloadError( |
| 231 workerGlobalScope(), fetchEventID, error->message); |
214 FetchEvent* fetchEvent = m_pendingPreloadFetchEvents.take(fetchEventID); | 232 FetchEvent* fetchEvent = m_pendingPreloadFetchEvents.take(fetchEventID); |
215 // This method may be called after onNavigationPreloadResponse() was called. | 233 // This method may be called after onNavigationPreloadResponse() was called. |
216 if (!fetchEvent) | 234 if (!fetchEvent) |
217 return; | 235 return; |
218 fetchEvent->onNavigationPreloadError( | 236 fetchEvent->onNavigationPreloadError( |
219 workerGlobalScope()->scriptController()->getScriptState(), | 237 workerGlobalScope()->scriptController()->getScriptState(), |
220 std::move(error)); | 238 std::move(error)); |
221 } | 239 } |
222 | 240 |
| 241 void ServiceWorkerGlobalScopeProxy::onNavigationPreloadCompleted( |
| 242 int fetchEventID) { |
| 243 InspectorInstrumentation::didCompleteNavigationPreload(workerGlobalScope(), |
| 244 fetchEventID); |
| 245 } |
| 246 |
223 void ServiceWorkerGlobalScopeProxy::dispatchForeignFetchEvent( | 247 void ServiceWorkerGlobalScopeProxy::dispatchForeignFetchEvent( |
224 int fetchEventID, | 248 int fetchEventID, |
225 const WebServiceWorkerRequest& webRequest) { | 249 const WebServiceWorkerRequest& webRequest) { |
226 if (!OriginTrials::foreignFetchEnabled(workerGlobalScope())) { | 250 if (!OriginTrials::foreignFetchEnabled(workerGlobalScope())) { |
227 // If origin trial tokens have expired, or are otherwise no longer valid | 251 // If origin trial tokens have expired, or are otherwise no longer valid |
228 // no events should be dispatched. | 252 // no events should be dispatched. |
229 // TODO(mek): Ideally the browser wouldn't even start the service worker | 253 // TODO(mek): Ideally the browser wouldn't even start the service worker |
230 // if its tokens have expired. | 254 // if its tokens have expired. |
231 ServiceWorkerGlobalScopeClient::from(workerGlobalScope()) | 255 ServiceWorkerGlobalScopeClient::from(workerGlobalScope()) |
232 ->respondToFetchEvent(fetchEventID, WTF::currentTime()); | 256 ->respondToFetchEvent(fetchEventID, WTF::currentTime()); |
(...skipping 255 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
488 return *m_document; | 512 return *m_document; |
489 } | 513 } |
490 | 514 |
491 ServiceWorkerGlobalScope* ServiceWorkerGlobalScopeProxy::workerGlobalScope() | 515 ServiceWorkerGlobalScope* ServiceWorkerGlobalScopeProxy::workerGlobalScope() |
492 const { | 516 const { |
493 DCHECK(m_workerGlobalScope); | 517 DCHECK(m_workerGlobalScope); |
494 return m_workerGlobalScope; | 518 return m_workerGlobalScope; |
495 } | 519 } |
496 | 520 |
497 } // namespace blink | 521 } // namespace blink |
OLD | NEW |