| 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 |