summaryrefslogtreecommitdiff
path: root/Source/WebCore/Modules/fetch/FetchResponse.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
commit1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch)
tree46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/Modules/fetch/FetchResponse.h
parent32761a6cee1d0dee366b885b7b9c777e67885688 (diff)
downloadWebKitGtk-tarball-master.tar.gz
Diffstat (limited to 'Source/WebCore/Modules/fetch/FetchResponse.h')
-rw-r--r--Source/WebCore/Modules/fetch/FetchResponse.h133
1 files changed, 133 insertions, 0 deletions
diff --git a/Source/WebCore/Modules/fetch/FetchResponse.h b/Source/WebCore/Modules/fetch/FetchResponse.h
new file mode 100644
index 000000000..b4d84f9e7
--- /dev/null
+++ b/Source/WebCore/Modules/fetch/FetchResponse.h
@@ -0,0 +1,133 @@
+/*
+ * Copyright (C) 2016 Canon Inc.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted, provided that the following conditions
+ * are required to be 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 Canon Inc. 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 CANON INC. 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 CANON INC. AND 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
+
+#if ENABLE(FETCH_API)
+
+#include "FetchBodyOwner.h"
+#include "ResourceResponse.h"
+#include <runtime/TypedArrays.h>
+
+namespace JSC {
+class ExecState;
+class JSValue;
+};
+
+namespace WebCore {
+
+class FetchRequest;
+class ReadableStreamSource;
+
+class FetchResponse final : public FetchBodyOwner {
+public:
+ using Type = ResourceResponse::Type;
+
+ static Ref<FetchResponse> create(ScriptExecutionContext& context) { return adoptRef(*new FetchResponse(context, std::nullopt, FetchHeaders::create(FetchHeaders::Guard::Response), ResourceResponse())); }
+ static Ref<FetchResponse> error(ScriptExecutionContext&);
+ static ExceptionOr<Ref<FetchResponse>> redirect(ScriptExecutionContext&, const String& url, int status);
+
+ using FetchPromise = DOMPromise<IDLInterface<FetchResponse>>;
+ static void fetch(ScriptExecutionContext&, FetchRequest&, FetchPromise&&);
+
+ void consume(unsigned, Ref<DeferredPromise>&&);
+#if ENABLE(READABLE_STREAM_API)
+ void startConsumingStream(unsigned);
+ void consumeChunk(Ref<JSC::Uint8Array>&&);
+ void finishConsumingStream(Ref<DeferredPromise>&&);
+#endif
+
+ ExceptionOr<void> setStatus(int status, const String& statusText);
+ void initializeWith(JSC::ExecState&, JSC::JSValue);
+
+ Type type() const { return m_response.type(); }
+ const String& url() const;
+ bool redirected() const { return m_response.isRedirected(); }
+ int status() const { return m_response.httpStatusCode(); }
+ bool ok() const { return m_response.isSuccessful(); }
+ const String& statusText() const { return m_response.httpStatusText(); }
+
+ FetchHeaders& headers() { return m_headers; }
+ Ref<FetchResponse> cloneForJS();
+
+#if ENABLE(READABLE_STREAM_API)
+ ReadableStreamSource* createReadableStreamSource();
+ void consumeBodyAsStream();
+ void feedStream();
+ void cancel();
+#endif
+
+ bool isLoading() const { return !!m_bodyLoader; }
+
+private:
+ FetchResponse(ScriptExecutionContext&, std::optional<FetchBody>&&, Ref<FetchHeaders>&&, ResourceResponse&&);
+
+ static void startFetching(ScriptExecutionContext&, const FetchRequest&, FetchPromise&&);
+
+ void stop() final;
+ const char* activeDOMObjectName() const final;
+ bool canSuspendForDocumentSuspension() const final;
+
+#if ENABLE(READABLE_STREAM_API)
+ void closeStream();
+#endif
+
+ class BodyLoader final : public FetchLoaderClient {
+ public:
+ BodyLoader(FetchResponse&, FetchPromise&&);
+ ~BodyLoader();
+
+ bool start(ScriptExecutionContext&, const FetchRequest&);
+ void stop();
+
+#if ENABLE(READABLE_STREAM_API)
+ RefPtr<SharedBuffer> startStreaming();
+#endif
+
+ private:
+ // FetchLoaderClient API
+ void didSucceed() final;
+ void didFail() final;
+ void didReceiveResponse(const ResourceResponse&) final;
+ void didReceiveData(const char*, size_t) final;
+
+ FetchResponse& m_response;
+ std::optional<FetchPromise> m_promise;
+ std::unique_ptr<FetchLoader> m_loader;
+ };
+
+ ResourceResponse m_response;
+ std::optional<BodyLoader> m_bodyLoader;
+ mutable String m_responseURL;
+
+ FetchBodyConsumer m_consumer { FetchBodyConsumer::Type::ArrayBuffer };
+};
+
+} // namespace WebCore
+
+#endif // ENABLE(FETCH_API)