/* * Copyright (C) 2005-2017 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of Apple Inc. ("Apple") nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #pragma once #include "LoadTiming.h" #include "ResourceHandleClient.h" #include "ResourceLoaderOptions.h" #include "ResourceLoaderTypes.h" #include "ResourceRequest.h" #include "ResourceResponse.h" #include #if ENABLE(CONTENT_EXTENSIONS) #include "ResourceLoadInfo.h" #endif namespace WTF { class SchedulePair; } namespace WebCore { class AuthenticationChallenge; class DocumentLoader; class Frame; class FrameLoader; class QuickLookHandle; class URL; class ResourceLoader : public RefCounted, protected ResourceHandleClient { public: virtual ~ResourceLoader() = 0; WEBCORE_EXPORT void cancel(); virtual bool init(const ResourceRequest&); void deliverResponseAndData(const ResourceResponse&, RefPtr&&); #if PLATFORM(IOS) virtual bool startLoading() { start(); return true; } virtual const ResourceRequest& iOSOriginalRequest() const { return request(); } #endif WEBCORE_EXPORT FrameLoader* frameLoader() const; DocumentLoader* documentLoader() const { return m_documentLoader.get(); } const ResourceRequest& originalRequest() const { return m_originalRequest; } WEBCORE_EXPORT void start(); WEBCORE_EXPORT void cancel(const ResourceError&); WEBCORE_EXPORT ResourceError cancelledError(); ResourceError blockedError(); ResourceError blockedByContentBlockerError(); ResourceError cannotShowURLError(); virtual void setDefersLoading(bool); bool defersLoading() const { return m_defersLoading; } unsigned long identifier() const { return m_identifier; } virtual void releaseResources(); const ResourceResponse& response() const { return m_response; } SharedBuffer* resourceData() const { return m_resourceData.get(); } void clearResourceData(); virtual bool isSubresourceLoader(); virtual void willSendRequest(ResourceRequest&&, const ResourceResponse& redirectResponse, std::function&& callback); virtual void didSendData(unsigned long long bytesSent, unsigned long long totalBytesToBeSent); virtual void didReceiveResponse(const ResourceResponse&); virtual void didReceiveData(const char*, unsigned, long long encodedDataLength, DataPayloadType); virtual void didReceiveBuffer(Ref&&, long long encodedDataLength, DataPayloadType); virtual void didFinishLoading(double finishTime); virtual void didFail(const ResourceError&); #if USE(NETWORK_CFDATA_ARRAY_CALLBACK) virtual void didReceiveDataArray(CFArrayRef dataArray); #endif virtual void didRetrieveDerivedDataFromCache(const String& type, SharedBuffer&); virtual bool shouldUseCredentialStorage(); virtual void didReceiveAuthenticationChallenge(const AuthenticationChallenge&); #if USE(PROTECTION_SPACE_AUTH_CALLBACK) virtual bool canAuthenticateAgainstProtectionSpace(const ProtectionSpace&); #endif virtual void receivedCancellation(const AuthenticationChallenge&); #if USE(QUICK_LOOK) bool isQuickLookResource() const; #endif const URL& url() const { return m_request.url(); } ResourceHandle* handle() const { return m_handle.get(); } bool shouldSendResourceLoadCallbacks() const { return m_options.sendLoadCallbacks == SendCallbacks; } void setSendCallbackPolicy(SendCallbackPolicy sendLoadCallbacks) { m_options.sendLoadCallbacks = sendLoadCallbacks; } bool shouldSniffContent() const { return m_options.sniffContent == SniffContent; } WEBCORE_EXPORT bool isAllowedToAskUserForCredentials() const; bool shouldIncludeCertificateInfo() const { return m_options.certificateInfoPolicy == IncludeCertificateInfo; } bool reachedTerminalState() const { return m_reachedTerminalState; } const ResourceRequest& request() const { return m_request; } void setDataBufferingPolicy(DataBufferingPolicy); void willSwitchToSubstituteResource(); const LoadTiming& loadTiming() { return m_loadTiming; } #if PLATFORM(COCOA) && !USE(CFURLCONNECTION) void schedule(WTF::SchedulePair&); void unschedule(WTF::SchedulePair&); #endif const Frame* frame() const { return m_frame.get(); } WEBCORE_EXPORT bool isAlwaysOnLoggingAllowed() const; const ResourceLoaderOptions& options() const { return m_options; } protected: ResourceLoader(Frame&, ResourceLoaderOptions); void didFinishLoadingOnePart(double finishTime); void cleanupForError(const ResourceError&); bool wasCancelled() const { return m_cancellationStatus >= Cancelled; } void didReceiveDataOrBuffer(const char*, unsigned, RefPtr&&, long long encodedDataLength, DataPayloadType); #if PLATFORM(COCOA) && !USE(CFURLCONNECTION) NSCachedURLResponse* willCacheResponse(ResourceHandle*, NSCachedURLResponse*) override; #endif #if PLATFORM(COCOA) && USE(CFURLCONNECTION) CFCachedURLResponseRef willCacheResponse(ResourceHandle*, CFCachedURLResponseRef) override; #endif virtual void willSendRequestInternal(ResourceRequest&, const ResourceResponse& redirectResponse); RefPtr m_handle; RefPtr m_frame; RefPtr m_documentLoader; ResourceResponse m_response; LoadTiming m_loadTiming; #if USE(QUICK_LOOK) std::unique_ptr m_quickLookHandle; #endif private: virtual void willCancel(const ResourceError&) = 0; virtual void didCancel(const ResourceError&) = 0; void addDataOrBuffer(const char*, unsigned, SharedBuffer*, DataPayloadType); void loadDataURL(); void finishNetworkLoad(); // ResourceHandleClient ResourceRequest willSendRequest(ResourceHandle*, ResourceRequest&&, ResourceResponse&& redirectResponse) override; void didSendData(ResourceHandle*, unsigned long long bytesSent, unsigned long long totalBytesToBeSent) override; void didReceiveResponse(ResourceHandle*, ResourceResponse&&) override; void didReceiveData(ResourceHandle*, const char*, unsigned, int encodedDataLength) override; void didReceiveBuffer(ResourceHandle*, Ref&&, int encodedDataLength) override; void didFinishLoading(ResourceHandle*, double finishTime) override; void didFail(ResourceHandle*, const ResourceError&) override; void wasBlocked(ResourceHandle*) override; void cannotShowURL(ResourceHandle*) override; #if USE(NETWORK_CFDATA_ARRAY_CALLBACK) void didReceiveDataArray(ResourceHandle*, CFArrayRef dataArray) override; #endif bool shouldUseCredentialStorage(ResourceHandle*) override { return shouldUseCredentialStorage(); } void didReceiveAuthenticationChallenge(ResourceHandle*, const AuthenticationChallenge& challenge) override { didReceiveAuthenticationChallenge(challenge); } #if USE(PROTECTION_SPACE_AUTH_CALLBACK) bool canAuthenticateAgainstProtectionSpace(ResourceHandle*, const ProtectionSpace& protectionSpace) override { return canAuthenticateAgainstProtectionSpace(protectionSpace); } #endif void receivedCancellation(ResourceHandle*, const AuthenticationChallenge& challenge) override { receivedCancellation(challenge); } #if PLATFORM(IOS) RetainPtr connectionProperties(ResourceHandle*) override; #endif #if PLATFORM(WIN) && USE(CFURLCONNECTION) // FIXME: Windows should use willCacheResponse - . bool shouldCacheResponse(ResourceHandle*, CFCachedURLResponseRef) override; #endif ResourceRequest m_request; ResourceRequest m_originalRequest; // Before redirects. RefPtr m_resourceData; unsigned long m_identifier { 0 }; bool m_reachedTerminalState { false }; bool m_notifiedLoadComplete { false }; enum CancellationStatus { NotCancelled, CalledWillCancel, Cancelled, FinishedCancel }; CancellationStatus m_cancellationStatus { NotCancelled }; bool m_defersLoading; ResourceRequest m_deferredRequest; ResourceLoaderOptions m_options; #if ENABLE(CONTENT_EXTENSIONS) protected: ResourceType m_resourceType { ResourceType::Invalid }; #endif }; } // namespace WebCore