#pragma once
#if ENABLE(FETCH_API)
#include "ActiveDOMObject.h"
#include "FetchBody.h"
#include "FetchHeaders.h"
#include "FetchLoaderClient.h"
#include "FetchResponseSource.h"
namespace WebCore {
class FetchLoader;
class FetchBodyOwner : public RefCounted<FetchBodyOwner>, public ActiveDOMObject {
public:
FetchBodyOwner(ScriptExecutionContext&, std::optional<FetchBody>&&, Ref<FetchHeaders>&&);
bool isDisturbed() const { return m_isDisturbed; };
void arrayBuffer(Ref<DeferredPromise>&&);
void blob(Ref<DeferredPromise>&&);
void formData(Ref<DeferredPromise>&&);
void json(Ref<DeferredPromise>&&);
void text(Ref<DeferredPromise>&&);
bool isDisturbedOrLocked() const;
void loadBlob(const Blob&, FetchBodyConsumer*);
bool isActive() const { return !!m_blobLoader; }
protected:
const FetchBody& body() const { return *m_body; }
FetchBody& body() { return *m_body; }
bool isBodyNull() const { return !m_body; }
void cloneBody(const FetchBodyOwner&);
void extractBody(ScriptExecutionContext&, JSC::ExecState&, JSC::JSValue);
void updateContentType();
void consumeOnceLoadingFinished(FetchBodyConsumer::Type, Ref<DeferredPromise>&&);
void stop() override;
void setDisturbed() { m_isDisturbed = true; }
private:
void blobChunk(const char*, size_t);
void blobLoadingSucceeded();
void blobLoadingFailed();
void finishBlobLoading();
struct BlobLoader final : FetchLoaderClient {
BlobLoader(FetchBodyOwner&);
void didReceiveResponse(const ResourceResponse&) final;
void didReceiveData(const char* data, size_t size) final { owner.blobChunk(data, size); }
void didFail() final;
void didSucceed() final { owner.blobLoadingSucceeded(); }
FetchBodyOwner& owner;
std::unique_ptr<FetchLoader> loader;
};
protected:
std::optional<FetchBody> m_body;
String m_contentType;
bool m_isDisturbed { false };
#if ENABLE(READABLE_STREAM_API)
RefPtr<FetchResponseSource> m_readableStreamSource;
#endif
Ref<FetchHeaders> m_headers;
private:
std::optional<BlobLoader> m_blobLoader;
};
}
#endif // ENABLE(FETCH_API)