Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "config.h" | 5 #include "config.h" |
| 6 #include "modules/serviceworkers/RespondWithObserver.h" | 6 #include "modules/serviceworkers/RespondWithObserver.h" |
| 7 | 7 |
| 8 #include "bindings/core/v8/ScriptFunction.h" | 8 #include "bindings/core/v8/ScriptFunction.h" |
| 9 #include "bindings/core/v8/ScriptPromise.h" | 9 #include "bindings/core/v8/ScriptPromise.h" |
| 10 #include "bindings/core/v8/ScriptValue.h" | 10 #include "bindings/core/v8/ScriptValue.h" |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 54 case WebServiceWorkerResponseErrorUnknown: | 54 case WebServiceWorkerResponseErrorUnknown: |
| 55 default: | 55 default: |
| 56 errorMessage = errorMessage + "an unexpected error occurred."; | 56 errorMessage = errorMessage + "an unexpected error occurred."; |
| 57 break; | 57 break; |
| 58 } | 58 } |
| 59 return errorMessage; | 59 return errorMessage; |
| 60 } | 60 } |
| 61 | 61 |
| 62 } // namespace | 62 } // namespace |
| 63 | 63 |
| 64 namespace { | |
|
hiroshige
2015/07/24 12:47:03
nit: can we merge two anonymous namespaces (i.e. r
yhirano
2015/07/29 08:45:02
Done.
| |
| 65 | |
| 66 class LoaderClient final : public GarbageCollectedFinalized<LoaderClient>, publi c FetchDataLoader::Client { | |
|
hiroshige
2015/07/24 12:47:03
nit optional: how about a name like NoopLoaderClie
yhirano
2015/07/29 08:45:02
Done.
| |
| 67 WTF_MAKE_NONCOPYABLE(LoaderClient); | |
| 68 USING_GARBAGE_COLLECTED_MIXIN(LoaderClient); | |
| 69 public: | |
| 70 LoaderClient() = default; | |
| 71 void didFetchDataLoadedStream() override {} | |
| 72 void didFetchDataLoadFailed() override {} | |
| 73 DEFINE_INLINE_TRACE() { FetchDataLoader::Client::trace(visitor); } | |
| 74 }; | |
| 75 | |
| 76 } // namespace | |
| 77 | |
| 64 class RespondWithObserver::ThenFunction final : public ScriptFunction { | 78 class RespondWithObserver::ThenFunction final : public ScriptFunction { |
| 65 public: | 79 public: |
| 66 enum ResolveType { | 80 enum ResolveType { |
| 67 Fulfilled, | 81 Fulfilled, |
| 68 Rejected, | 82 Rejected, |
| 69 }; | 83 }; |
| 70 | 84 |
| 71 static v8::Local<v8::Function> createFunction(ScriptState* scriptState, Resp ondWithObserver* observer, ResolveType type) | 85 static v8::Local<v8::Function> createFunction(ScriptState* scriptState, Resp ondWithObserver* observer, ResolveType type) |
| 72 { | 86 { |
| 73 ThenFunction* self = new ThenFunction(scriptState, observer, type); | 87 ThenFunction* self = new ThenFunction(scriptState, observer, type); |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 182 } | 196 } |
| 183 if (m_frameType != WebURLRequest::FrameTypeNone && responseType != FetchResp onseData::BasicType && responseType != FetchResponseData::DefaultType) { | 197 if (m_frameType != WebURLRequest::FrameTypeNone && responseType != FetchResp onseData::BasicType && responseType != FetchResponseData::DefaultType) { |
| 184 responseWasRejected(WebServiceWorkerResponseErrorResponseTypeNotBasicOrD efault); | 198 responseWasRejected(WebServiceWorkerResponseErrorResponseTypeNotBasicOrD efault); |
| 185 return; | 199 return; |
| 186 } | 200 } |
| 187 if (response->bodyUsed()) { | 201 if (response->bodyUsed()) { |
| 188 responseWasRejected(WebServiceWorkerResponseErrorBodyUsed); | 202 responseWasRejected(WebServiceWorkerResponseErrorBodyUsed); |
| 189 return; | 203 return; |
| 190 } | 204 } |
| 191 | 205 |
| 192 response->lockBody(Body::PassBody); | 206 response->setBodyPassed(); |
| 193 if (OwnPtr<DrainingBodyStreamBuffer> buffer = response->createInternalDraini ngStream()) { | |
| 194 WebServiceWorkerResponse webResponse; | |
| 195 response->populateWebServiceWorkerResponse(webResponse); | |
| 196 if (RefPtr<BlobDataHandle> blobDataHandle = buffer->drainAsBlobDataHandl e(FetchDataConsumerHandle::Reader::AllowBlobWithInvalidSize)) { | |
| 197 webResponse.setBlobDataHandle(blobDataHandle); | |
| 198 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleF etchEvent(m_eventID, webResponse); | |
| 199 m_state = Done; | |
| 200 return; | |
| 201 } | |
| 202 Stream* outStream = Stream::create(executionContext(), ""); | |
| 203 webResponse.setStreamURL(outStream->url()); | |
| 204 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetch Event(m_eventID, webResponse); | |
| 205 FetchDataLoader* loader = FetchDataLoader::createLoaderAsStream(outStrea m); | |
| 206 buffer->startLoading(loader, nullptr); | |
| 207 m_state = Done; | |
| 208 return; | |
| 209 } | |
| 210 WebServiceWorkerResponse webResponse; | 207 WebServiceWorkerResponse webResponse; |
| 211 response->populateWebServiceWorkerResponse(webResponse); | 208 response->populateWebServiceWorkerResponse(webResponse); |
| 209 BodyStreamBuffer* buffer = response->internalBodyBuffer(); | |
| 210 if (buffer->hasBody()) { | |
| 211 RefPtr<BlobDataHandle> blobDataHandle = buffer->drainAsBlobDataHandle(Fe tchDataConsumerHandle::Reader::AllowBlobWithInvalidSize); | |
| 212 if (blobDataHandle) { | |
| 213 webResponse.setBlobDataHandle(blobDataHandle); | |
| 214 } else { | |
| 215 Stream* outStream = Stream::create(executionContext(), ""); | |
| 216 webResponse.setStreamURL(outStream->url()); | |
| 217 buffer->startLoading(executionContext(), FetchDataLoader::createLoad erAsStream(outStream), new LoaderClient); | |
| 218 } | |
| 219 } | |
| 212 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetchEven t(m_eventID, webResponse); | 220 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetchEven t(m_eventID, webResponse); |
| 213 m_state = Done; | 221 m_state = Done; |
| 214 } | 222 } |
| 215 | 223 |
| 216 RespondWithObserver::RespondWithObserver(ExecutionContext* context, int eventID, const KURL& requestURL, WebURLRequest::FetchRequestMode requestMode, WebURLRequ est::FrameType frameType) | 224 RespondWithObserver::RespondWithObserver(ExecutionContext* context, int eventID, const KURL& requestURL, WebURLRequest::FetchRequestMode requestMode, WebURLRequ est::FrameType frameType) |
| 217 : ContextLifecycleObserver(context) | 225 : ContextLifecycleObserver(context) |
| 218 , m_eventID(eventID) | 226 , m_eventID(eventID) |
| 219 , m_requestURL(requestURL) | 227 , m_requestURL(requestURL) |
| 220 , m_requestMode(requestMode) | 228 , m_requestMode(requestMode) |
| 221 , m_frameType(frameType) | 229 , m_frameType(frameType) |
| 222 , m_state(Initial) | 230 , m_state(Initial) |
| 223 { | 231 { |
| 224 } | 232 } |
| 225 | 233 |
| 226 DEFINE_TRACE(RespondWithObserver) | 234 DEFINE_TRACE(RespondWithObserver) |
| 227 { | 235 { |
| 228 ContextLifecycleObserver::trace(visitor); | 236 ContextLifecycleObserver::trace(visitor); |
| 229 } | 237 } |
| 230 | 238 |
| 231 } // namespace blink | 239 } // namespace blink |
| OLD | NEW |