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 15 matching lines...) Expand all Loading... |
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 #include "config.h" | 30 #include "config.h" |
31 #include "ServiceWorkerGlobalScope.h" | 31 #include "ServiceWorkerGlobalScope.h" |
32 | 32 |
33 #include "bindings/core/v8/ScriptPromise.h" | 33 #include "bindings/core/v8/ScriptPromise.h" |
34 #include "bindings/core/v8/ScriptState.h" | 34 #include "bindings/core/v8/ScriptState.h" |
35 #include "bindings/core/v8/V8ThrowException.h" | 35 #include "bindings/core/v8/V8ThrowException.h" |
| 36 #include "core/fetch/ResourceLoaderOptions.h" |
36 #include "core/inspector/ScriptCallStack.h" | 37 #include "core/inspector/ScriptCallStack.h" |
| 38 #include "core/loader/ThreadableLoader.h" |
37 #include "core/workers/WorkerClients.h" | 39 #include "core/workers/WorkerClients.h" |
38 #include "core/workers/WorkerThreadStartupData.h" | 40 #include "core/workers/WorkerThreadStartupData.h" |
39 #include "modules/CachePolyfill.h" | 41 #include "modules/CachePolyfill.h" |
40 #include "modules/CacheStoragePolyfill.h" | 42 #include "modules/CacheStoragePolyfill.h" |
41 #include "modules/EventTargetModules.h" | 43 #include "modules/EventTargetModules.h" |
42 #include "modules/FetchPolyfill.h" | 44 #include "modules/FetchPolyfill.h" |
43 #include "modules/serviceworkers/FetchManager.h" | 45 #include "modules/serviceworkers/FetchManager.h" |
44 #include "modules/serviceworkers/Request.h" | 46 #include "modules/serviceworkers/Request.h" |
45 #include "modules/serviceworkers/ServiceWorkerClients.h" | 47 #include "modules/serviceworkers/ServiceWorkerClients.h" |
46 #include "modules/serviceworkers/ServiceWorkerGlobalScopeClient.h" | 48 #include "modules/serviceworkers/ServiceWorkerGlobalScopeClient.h" |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 m_fetchManager.clear(); | 83 m_fetchManager.clear(); |
82 } | 84 } |
83 | 85 |
84 String ServiceWorkerGlobalScope::scope(ExecutionContext* context) | 86 String ServiceWorkerGlobalScope::scope(ExecutionContext* context) |
85 { | 87 { |
86 return ServiceWorkerGlobalScopeClient::from(context)->scope().string(); | 88 return ServiceWorkerGlobalScopeClient::from(context)->scope().string(); |
87 } | 89 } |
88 | 90 |
89 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, Request*
request) | 91 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, Request*
request) |
90 { | 92 { |
91 OwnPtr<ResourceRequest> resourceRequest(request->createResourceRequest()); | 93 TrackExceptionState exceptionState; |
92 return m_fetchManager->fetch(scriptState, resourceRequest.release()); | 94 // Let r be the associated request of the result of invoking the initial |
| 95 // value of Request as constructor with input and init as arguments. If this |
| 96 // throws an exception, reject p with it. |
| 97 RefPtr<Request> r = Request::create(this, request, exceptionState); |
| 98 if (exceptionState.hadException()) |
| 99 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr
ror(exceptionState.message(), scriptState->isolate())); |
| 100 return m_fetchManager->fetch(scriptState, r->request()); |
| 101 } |
| 102 |
| 103 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, Request*
request, const Dictionary& requestInit) |
| 104 { |
| 105 TrackExceptionState exceptionState; |
| 106 // Let r be the associated request of the result of invoking the initial |
| 107 // value of Request as constructor with input and init as arguments. If this |
| 108 // throws an exception, reject p with it. |
| 109 RefPtr<Request> r = Request::create(this, request, requestInit, exceptionSta
te); |
| 110 if (exceptionState.hadException()) |
| 111 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr
ror(exceptionState.message(), scriptState->isolate())); |
| 112 return m_fetchManager->fetch(scriptState, r->request()); |
93 } | 113 } |
94 | 114 |
95 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, const St
ring& urlstring) | 115 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, const St
ring& urlstring) |
96 { | 116 { |
97 KURL url = completeURL(urlstring); | 117 TrackExceptionState exceptionState; |
98 if (!url.isValid()) | 118 // Let r be the associated request of the result of invoking the initial |
99 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr
ror("Invalid URL", scriptState->isolate())); | 119 // value of Request as constructor with input and init as arguments. If this |
100 OwnPtr<ResourceRequest> resourceRequest = adoptPtr(new ResourceRequest(url))
; | 120 // throws an exception, reject p with it. |
101 resourceRequest->setHTTPMethod("GET"); | 121 RefPtr<Request> r = Request::create(this, urlstring, exceptionState); |
102 return m_fetchManager->fetch(scriptState, resourceRequest.release()); | 122 if (exceptionState.hadException()) |
| 123 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr
ror(exceptionState.message(), scriptState->isolate())); |
| 124 return m_fetchManager->fetch(scriptState, r->request()); |
| 125 } |
| 126 |
| 127 ScriptPromise ServiceWorkerGlobalScope::fetch(ScriptState* scriptState, const St
ring& urlstring, const Dictionary& requestInit) |
| 128 { |
| 129 TrackExceptionState exceptionState; |
| 130 // Let r be the associated request of the result of invoking the initial |
| 131 // value of Request as constructor with input and init as arguments. If this |
| 132 // throws an exception, reject p with it. |
| 133 RefPtr<Request> r = Request::create(this, urlstring, requestInit, exceptionS
tate); |
| 134 if (exceptionState.hadException()) |
| 135 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr
ror(exceptionState.message(), scriptState->isolate())); |
| 136 return m_fetchManager->fetch(scriptState, r->request()); |
103 } | 137 } |
104 | 138 |
105 PassRefPtr<ServiceWorkerClients> ServiceWorkerGlobalScope::clients() | 139 PassRefPtr<ServiceWorkerClients> ServiceWorkerGlobalScope::clients() |
106 { | 140 { |
107 if (!m_clients) | 141 if (!m_clients) |
108 m_clients = ServiceWorkerClients::create(); | 142 m_clients = ServiceWorkerClients::create(); |
109 return m_clients; | 143 return m_clients; |
110 } | 144 } |
111 | 145 |
112 const AtomicString& ServiceWorkerGlobalScope::interfaceName() const | 146 const AtomicString& ServiceWorkerGlobalScope::interfaceName() const |
113 { | 147 { |
114 return EventTargetNames::ServiceWorkerGlobalScope; | 148 return EventTargetNames::ServiceWorkerGlobalScope; |
115 } | 149 } |
116 | 150 |
117 void ServiceWorkerGlobalScope::trace(Visitor* visitor) | 151 void ServiceWorkerGlobalScope::trace(Visitor* visitor) |
118 { | 152 { |
119 WorkerGlobalScope::trace(visitor); | 153 WorkerGlobalScope::trace(visitor); |
120 } | 154 } |
121 | 155 |
122 void ServiceWorkerGlobalScope::logExceptionToConsole(const String& errorMessage,
const String& sourceURL, int lineNumber, int columnNumber, PassRefPtrWillBeRawP
tr<ScriptCallStack> callStack) | 156 void ServiceWorkerGlobalScope::logExceptionToConsole(const String& errorMessage,
const String& sourceURL, int lineNumber, int columnNumber, PassRefPtrWillBeRawP
tr<ScriptCallStack> callStack) |
123 { | 157 { |
124 WorkerGlobalScope::logExceptionToConsole(errorMessage, sourceURL, lineNumber
, columnNumber, callStack); | 158 WorkerGlobalScope::logExceptionToConsole(errorMessage, sourceURL, lineNumber
, columnNumber, callStack); |
125 addMessageToWorkerConsole(JSMessageSource, ErrorMessageLevel, errorMessage,
sourceURL, lineNumber, callStack, 0); | 159 addMessageToWorkerConsole(JSMessageSource, ErrorMessageLevel, errorMessage,
sourceURL, lineNumber, callStack, 0); |
126 } | 160 } |
127 | 161 |
128 } // namespace WebCore | 162 } // namespace WebCore |
OLD | NEW |