| 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/fetch/FetchManager.h" | 6 #include "modules/fetch/FetchManager.h" |
| 7 | 7 |
| 8 #include "bindings/core/v8/ExceptionState.h" | 8 #include "bindings/core/v8/ExceptionState.h" |
| 9 #include "bindings/core/v8/ScriptPromiseResolver.h" | 9 #include "bindings/core/v8/ScriptPromiseResolver.h" |
| 10 #include "bindings/core/v8/ScriptState.h" | 10 #include "bindings/core/v8/ScriptState.h" |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 42 void trace(Visitor*) override; | 42 void trace(Visitor*) override; |
| 43 | 43 |
| 44 void didReceiveResponse(unsigned long, const ResourceResponse&, PassOwnPtr<W
ebDataConsumerHandle>) override; | 44 void didReceiveResponse(unsigned long, const ResourceResponse&, PassOwnPtr<W
ebDataConsumerHandle>) override; |
| 45 void didReceiveData(const char*, unsigned) override; | 45 void didReceiveData(const char*, unsigned) override; |
| 46 void didFinishLoading(unsigned long, double) override; | 46 void didFinishLoading(unsigned long, double) override; |
| 47 void didFail(const ResourceError&) override; | 47 void didFail(const ResourceError&) override; |
| 48 void didFailAccessControlCheck(const ResourceError&) override; | 48 void didFailAccessControlCheck(const ResourceError&) override; |
| 49 void didFailRedirectCheck() override; | 49 void didFailRedirectCheck() override; |
| 50 | 50 |
| 51 void start(); | 51 void start(); |
| 52 void cleanup(); | 52 void dispose(); |
| 53 | 53 |
| 54 private: | 54 private: |
| 55 Loader(ExecutionContext*, FetchManager*, PassRefPtrWillBeRawPtr<ScriptPromis
eResolver>, const FetchRequestData*); | 55 Loader(ExecutionContext*, FetchManager*, PassRefPtrWillBeRawPtr<ScriptPromis
eResolver>, const FetchRequestData*); |
| 56 | 56 |
| 57 void performBasicFetch(); | 57 void performBasicFetch(); |
| 58 void performNetworkError(const String& message); | 58 void performNetworkError(const String& message); |
| 59 void performHTTPFetch(bool corsFlag, bool corsPreflightFlag); | 59 void performHTTPFetch(bool corsFlag, bool corsPreflightFlag); |
| 60 void failed(const String& message); | 60 void failed(const String& message); |
| 61 void notifyFinished(); | 61 void notifyFinished(); |
| 62 | 62 |
| 63 RawPtrWillBeMember<FetchManager> m_fetchManager; | 63 RawPtrWillBeMember<FetchManager> m_fetchManager; |
| 64 RefPtrWillBeMember<ScriptPromiseResolver> m_resolver; | 64 RefPtrWillBeMember<ScriptPromiseResolver> m_resolver; |
| 65 PersistentWillBeMember<FetchRequestData> m_request; | 65 PersistentWillBeMember<FetchRequestData> m_request; |
| 66 PersistentWillBeMember<BodyStreamBuffer> m_responseBuffer; | 66 PersistentWillBeMember<BodyStreamBuffer> m_responseBuffer; |
| 67 RefPtr<ThreadableLoader> m_loader; | 67 RefPtr<ThreadableLoader> m_loader; |
| 68 bool m_failed; | 68 bool m_failed; |
| 69 }; | 69 }; |
| 70 | 70 |
| 71 FetchManager::Loader::Loader(ExecutionContext* executionContext, FetchManager* f
etchManager, PassRefPtrWillBeRawPtr<ScriptPromiseResolver> resolver, const Fetch
RequestData* request) | 71 FetchManager::Loader::Loader(ExecutionContext* executionContext, FetchManager* f
etchManager, PassRefPtrWillBeRawPtr<ScriptPromiseResolver> resolver, const Fetch
RequestData* request) |
| 72 : ContextLifecycleObserver(executionContext) | 72 : ContextLifecycleObserver(executionContext) |
| 73 , m_fetchManager(fetchManager) | 73 , m_fetchManager(fetchManager) |
| 74 , m_resolver(resolver) | 74 , m_resolver(resolver) |
| 75 , m_request(request->createCopy()) | 75 , m_request(request->createCopy()) |
| 76 , m_failed(false) | 76 , m_failed(false) |
| 77 { | 77 { |
| 78 } | 78 } |
| 79 | 79 |
| 80 FetchManager::Loader::~Loader() | 80 FetchManager::Loader::~Loader() |
| 81 { | 81 { |
| 82 if (m_loader) | 82 ASSERT(!m_loader); |
| 83 m_loader->cancel(); | |
| 84 } | 83 } |
| 85 | 84 |
| 86 void FetchManager::Loader::trace(Visitor* visitor) | 85 void FetchManager::Loader::trace(Visitor* visitor) |
| 87 { | 86 { |
| 88 visitor->trace(m_fetchManager); | 87 visitor->trace(m_fetchManager); |
| 89 visitor->trace(m_resolver); | 88 visitor->trace(m_resolver); |
| 90 visitor->trace(m_request); | 89 visitor->trace(m_request); |
| 91 visitor->trace(m_responseBuffer); | 90 visitor->trace(m_responseBuffer); |
| 92 ContextLifecycleObserver::trace(visitor); | 91 ContextLifecycleObserver::trace(visitor); |
| 93 } | 92 } |
| (...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 249 } | 248 } |
| 250 | 249 |
| 251 // "- Otherwise | 250 // "- Otherwise |
| 252 // Set |request|'s response tainting to |CORS|." | 251 // Set |request|'s response tainting to |CORS|." |
| 253 m_request->setResponseTainting(FetchRequestData::CORSTainting); | 252 m_request->setResponseTainting(FetchRequestData::CORSTainting); |
| 254 // "The result of performing an HTTP fetch using |request| with the | 253 // "The result of performing an HTTP fetch using |request| with the |
| 255 // |CORS flag| set." | 254 // |CORS flag| set." |
| 256 performHTTPFetch(true, false); | 255 performHTTPFetch(true, false); |
| 257 } | 256 } |
| 258 | 257 |
| 259 void FetchManager::Loader::cleanup() | 258 void FetchManager::Loader::dispose() |
| 260 { | 259 { |
| 261 // Prevent notification | 260 // Prevent notification |
| 262 m_fetchManager = 0; | 261 m_fetchManager = nullptr; |
| 263 | |
| 264 if (m_loader) { | 262 if (m_loader) { |
| 265 m_loader->cancel(); | 263 m_loader->cancel(); |
| 266 m_loader.clear(); | 264 m_loader.clear(); |
| 267 } | 265 } |
| 268 } | 266 } |
| 269 | 267 |
| 270 void FetchManager::Loader::performBasicFetch() | 268 void FetchManager::Loader::performBasicFetch() |
| 271 { | 269 { |
| 272 // "To perform a basic fetch using |request|, switch on |request|'s url's | 270 // "To perform a basic fetch using |request|, switch on |request|'s url's |
| 273 // scheme, and run the associated steps:" | 271 // scheme, and run the associated steps:" |
| (...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 407 OwnPtrWillBeRawPtr<Loader> ownLoader = Loader::create(m_executionContext, th
is, resolver.release(), request); | 405 OwnPtrWillBeRawPtr<Loader> ownLoader = Loader::create(m_executionContext, th
is, resolver.release(), request); |
| 408 Loader* loader = m_loaders.add(ownLoader.release()).storedValue->get(); | 406 Loader* loader = m_loaders.add(ownLoader.release()).storedValue->get(); |
| 409 loader->start(); | 407 loader->start(); |
| 410 return promise; | 408 return promise; |
| 411 } | 409 } |
| 412 | 410 |
| 413 void FetchManager::stop() | 411 void FetchManager::stop() |
| 414 { | 412 { |
| 415 ASSERT(!m_isStopped); | 413 ASSERT(!m_isStopped); |
| 416 m_isStopped = true; | 414 m_isStopped = true; |
| 417 for (auto& loader : m_loaders) { | 415 for (auto& loader : m_loaders) |
| 418 loader->cleanup(); | 416 loader->dispose(); |
| 419 } | |
| 420 } | 417 } |
| 421 | 418 |
| 422 void FetchManager::onLoaderFinished(Loader* loader) | 419 void FetchManager::onLoaderFinished(Loader* loader) |
| 423 { | 420 { |
| 424 // We don't use remove here, because it may cause recursive deletion. | 421 // We don't use remove here, because it may cause recursive deletion. |
| 425 OwnPtrWillBeRawPtr<Loader> p = m_loaders.take(loader); | 422 OwnPtrWillBeRawPtr<Loader> p = m_loaders.take(loader); |
| 426 ALLOW_UNUSED_LOCAL(p); | 423 ASSERT(p); |
| 424 p->dispose(); |
| 427 } | 425 } |
| 428 | 426 |
| 429 void FetchManager::trace(Visitor* visitor) | 427 void FetchManager::trace(Visitor* visitor) |
| 430 { | 428 { |
| 431 #if ENABLE(OILPAN) | 429 #if ENABLE(OILPAN) |
| 432 visitor->trace(m_executionContext); | 430 visitor->trace(m_executionContext); |
| 433 visitor->trace(m_loaders); | 431 visitor->trace(m_loaders); |
| 434 #endif | 432 #endif |
| 435 } | 433 } |
| 436 | 434 |
| 437 } // namespace blink | 435 } // namespace blink |
| OLD | NEW |