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 RefPtr<SubresourceLoader> create(Frame&, CachedResource&, const ResourceRequest&, const ResourceLoaderOptions&);
virtual ~SubresourceLoader();
void cancelIfNotFinishing();
bool isSubresourceLoader() override;
CachedResource* cachedResource();
SecurityOrigin* origin() { return m_origin.get(); }
#if PLATFORM(IOS)
bool startLoading() override;
const ResourceRequest& iOSOriginalRequest() const override { return m_iOSOriginalRequest; }
#endif
unsigned redirectCount() const { return m_redirectCount; }
private:
SubresourceLoader(Frame&, CachedResource&, const ResourceLoaderOptions&);
bool init(const ResourceRequest&) override;
void willSendRequestInternal(ResourceRequest&, const ResourceResponse& redirectResponse) 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) && !USE(CFURLCONNECTION)
NSCachedURLResponse *willCacheResponse(ResourceHandle*, NSCachedURLResponse*) override;
#endif
#if PLATFORM(COCOA) && USE(CFURLCONNECTION)
CFCachedURLResponseRef willCacheResponse(ResourceHandle*, CFCachedURLResponseRef) override;
#endif
void releaseResources() override;
#if USE(SOUP)
char* getOrCreateReadBuffer(size_t requestedSize, size_t& actualSize) override;
#endif
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();
#if ENABLE(WEB_TIMING)
void reportResourceTiming(const NetworkLoadMetrics&);
#endif
#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 };
};
}