SubresourceLoader.h [plain text]
#pragma once
#include "FrameLoaderTypes.h"
#include "ResourceLoader.h"
#include <wtf/text/WTFString.h>
namespace WebCore {
class CachedResource;
class CachedResourceLoader;
class NetworkLoadMetrics;
class ResourceRequest;
class SecurityOrigin;
class SubresourceLoader final : public ResourceLoader {
public:
WEBCORE_EXPORT static void create(Frame&, CachedResource&, ResourceRequest&&, const ResourceLoaderOptions&, CompletionHandler<void(RefPtr<SubresourceLoader>&&)>&&);
virtual ~SubresourceLoader();
void cancelIfNotFinishing();
bool isSubresourceLoader() override;
CachedResource* cachedResource();
SecurityOrigin* origin() { return m_origin.get(); }
#if PLATFORM(IOS)
void startLoading() override;
const ResourceRequest& iOSOriginalRequest() const override { return m_iOSOriginalRequest; }
#endif
unsigned redirectCount() const { return m_redirectCount; }
private:
SubresourceLoader(Frame&, CachedResource&, const ResourceLoaderOptions&);
void init(ResourceRequest&&, CompletionHandler<void(bool)>&&) override;
void willSendRequestInternal(ResourceRequest&&, const ResourceResponse& redirectResponse, CompletionHandler<void(ResourceRequest&&)>&&) override;
void didSendData(unsigned long long bytesSent, unsigned long long totalBytesToBeSent) override;
void didReceiveResponse(const ResourceResponse&) override;
void didReceiveData(const char*, unsigned, long long encodedDataLength, DataPayloadType) override;
void didReceiveBuffer(Ref<SharedBuffer>&&, long long encodedDataLength, DataPayloadType) override;
void didFinishLoading(const NetworkLoadMetrics&) override;
void didFail(const ResourceError&) override;
void willCancel(const ResourceError&) override;
void didCancel(const ResourceError&) override;
void didRetrieveDerivedDataFromCache(const String& type, SharedBuffer&) override;
#if PLATFORM(COCOA)
NSCachedURLResponse *willCacheResponse(ResourceHandle*, NSCachedURLResponse*) override;
#endif
void releaseResources() override;
bool checkForHTTPStatusCodeError();
bool checkResponseCrossOriginAccessControl(const ResourceResponse&, String&);
bool checkRedirectionCrossOriginAccessControl(const ResourceRequest& previousRequest, const ResourceResponse&, ResourceRequest& newRequest, String&);
void didReceiveDataOrBuffer(const char*, int, RefPtr<SharedBuffer>&&, long long encodedDataLength, DataPayloadType);
void notifyDone();
void reportResourceTiming(const NetworkLoadMetrics&);
#if USE(QUICK_LOOK)
bool shouldCreatePreviewLoaderForResponse(const ResourceResponse&) const;
#endif
enum SubresourceLoaderState {
Uninitialized,
Initialized,
Finishing,
#if PLATFORM(IOS)
CancelledWhileInitializing
#endif
};
class RequestCountTracker {
#if !COMPILER(MSVC)
WTF_MAKE_FAST_ALLOCATED;
#endif
public:
RequestCountTracker(CachedResourceLoader&, const CachedResource&);
~RequestCountTracker();
private:
CachedResourceLoader& m_cachedResourceLoader;
const CachedResource& m_resource;
};
#if PLATFORM(IOS)
ResourceRequest m_iOSOriginalRequest;
#endif
CachedResource* m_resource;
SubresourceLoaderState m_state;
std::optional<RequestCountTracker> m_requestCountTracker;
RefPtr<SecurityOrigin> m_origin;
unsigned m_redirectCount { 0 };
bool m_loadingMultipartContent { false };
};
}