LayoutTests/imported/w3c:
[WebKit-https.git] / Source / WebCore / Modules / fetch / FetchLoader.cpp
1 /*
2  * Copyright (C) 2016 Canon Inc.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted, provided that the following conditions
6  * are required to be met:
7  *
8  * 1.  Redistributions of source code must retain the above copyright
9  *     notice, this list of conditions and the following disclaimer.
10  * 2.  Redistributions in binary form must reproduce the above copyright
11  *     notice, this list of conditions and the following disclaimer in the
12  *     documentation and/or other materials provided with the distribution.
13  * 3.  Neither the name of Canon Inc. nor the names of
14  *     its contributors may be used to endorse or promote products derived
15  *     from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY CANON INC. AND ITS CONTRIBUTORS "AS IS" AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL CANON INC. AND ITS CONTRIBUTORS BE LIABLE FOR
21  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
23  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
24  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28
29 #include "config.h"
30 #include "FetchLoader.h"
31
32 #if ENABLE(FETCH_API)
33
34 #include "BlobURL.h"
35 #include "FetchBody.h"
36 #include "FetchLoaderClient.h"
37 #include "FetchRequest.h"
38 #include "ResourceRequest.h"
39 #include "ScriptExecutionContext.h"
40 #include "SecurityOrigin.h"
41 #include "SharedBuffer.h"
42 #include "TextResourceDecoder.h"
43 #include "ThreadableBlobRegistry.h"
44 #include "ThreadableLoader.h"
45
46 namespace WebCore {
47
48 void FetchLoader::start(ScriptExecutionContext& context, Blob& blob)
49 {
50     auto urlForReading = BlobURL::createPublicURL(context.securityOrigin());
51     if (urlForReading.isEmpty()) {
52         m_client.didFail();
53         return;
54     }
55
56     ThreadableBlobRegistry::registerBlobURL(context.securityOrigin(), urlForReading, blob.url());
57
58     ResourceRequest request(urlForReading);
59     request.setHTTPMethod("GET");
60
61     ThreadableLoaderOptions options;
62     options.setSendLoadCallbacks(SendCallbacks);
63     options.setSniffContent(DoNotSniffContent);
64     options.setDataBufferingPolicy(DoNotBufferData);
65     options.preflightPolicy = ConsiderPreflight;
66     options.setAllowCredentials(AllowStoredCredentials);
67     options.crossOriginRequestPolicy = DenyCrossOriginRequests;
68     options.contentSecurityPolicyEnforcement = ContentSecurityPolicyEnforcement::DoNotEnforce;
69
70     m_loader = ThreadableLoader::create(&context, this, request, options);
71     m_isStarted = true;
72 }
73
74 void FetchLoader::start(ScriptExecutionContext& context, const FetchRequest& request)
75 {
76     // FIXME: Compute loading options according fetch options.
77     ThreadableLoaderOptions options;
78     options.setSendLoadCallbacks(SendCallbacks);
79     options.setSniffContent(DoNotSniffContent);
80     options.setDataBufferingPolicy(DoNotBufferData);
81     options.preflightPolicy = ConsiderPreflight;
82     options.setAllowCredentials(AllowStoredCredentials);
83     options.crossOriginRequestPolicy = DenyCrossOriginRequests;
84     options.contentSecurityPolicyEnforcement = ContentSecurityPolicyEnforcement::DoNotEnforce;
85
86     m_loader = ThreadableLoader::create(&context, this, request.internalRequest(), options);
87     m_isStarted = true;
88 }
89
90 FetchLoader::FetchLoader(Type type, FetchLoaderClient& client)
91     : m_type(type)
92     , m_client(client)
93 {
94 }
95
96 void FetchLoader::stop()
97 {
98     m_data = nullptr;
99     if (m_loader) {
100         RefPtr<ThreadableLoader> loader = WTFMove(m_loader);
101         loader->cancel();
102     }
103 }
104
105 RefPtr<SharedBuffer> FetchLoader::startStreaming()
106 {
107     ASSERT(m_type == Type::ArrayBuffer);
108     m_type = Type::Stream;
109     return WTFMove(m_data);
110 }
111
112 void FetchLoader::didReceiveResponse(unsigned long, const ResourceResponse& response)
113 {
114     m_client.didReceiveResponse(response);
115 }
116
117 // FIXME: We should make text and blob creation more efficient.
118 // We might also want to merge this class with FileReaderLoader.
119 void FetchLoader::didReceiveData(const char* value, int size)
120 {
121     if (m_type == Type::Stream) {
122         m_client.didReceiveData(value, size);
123         return;
124     }
125     if (!m_data) {
126         m_data = SharedBuffer::create(value, size);
127         return;
128     }
129     m_data->append(value, size);
130 }
131
132 void FetchLoader::didFinishLoading(unsigned long, double)
133 {
134     if (m_type == Type::ArrayBuffer)
135         m_client.didFinishLoadingAsArrayBuffer(m_data ? m_data->createArrayBuffer() : ArrayBuffer::tryCreate(nullptr, 0));
136     else if (m_type == Type::Text)
137         m_client.didFinishLoadingAsText(m_data ? TextResourceDecoder::create(ASCIILiteral("text/plain"), "UTF-8")->decodeAndFlush(m_data->data(), m_data->size()): String());
138     m_data = nullptr;
139
140     m_client.didSucceed();
141 }
142
143 void FetchLoader::didFail(const ResourceError&)
144 {
145     m_client.didFail();
146 }
147
148 void FetchLoader::didFailRedirectCheck()
149 {
150     m_client.didFail();
151 }
152
153 } // namespace WebCore
154
155 #endif // ENABLE(FETCH_API)