94e6e95592d3784a18b8063a19f2f03212be3ab8
[WebKit-https.git] / Source / WebKit2 / WebProcess / Network / WebResourceLoader.cpp
1 /*
2  * Copyright (C) 2012 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #include "config.h"
27 #include "WebResourceLoader.h"
28
29 #if ENABLE(NETWORK_PROCESS)
30
31 #include "DataReference.h"
32 #include "Logging.h"
33 #include "NetworkProcessConnection.h"
34 #include "PlatformCertificateInfo.h"
35 #include "WebCoreArgumentCoders.h"
36 #include "WebErrors.h"
37 #include "WebProcess.h"
38 #include <WebCore/ResourceBuffer.h>
39 #include <WebCore/ResourceError.h>
40 #include <WebCore/ResourceLoader.h>
41
42 using namespace WebCore;
43
44 namespace WebKit {
45
46 PassRefPtr<WebResourceLoader> WebResourceLoader::create(PassRefPtr<ResourceLoader> coreLoader)
47 {
48     return adoptRef(new WebResourceLoader(coreLoader));
49 }
50
51 WebResourceLoader::WebResourceLoader(PassRefPtr<WebCore::ResourceLoader> coreLoader)
52     : m_coreLoader(coreLoader)
53 {
54 }
55
56 WebResourceLoader::~WebResourceLoader()
57 {
58 }
59
60 CoreIPC::Connection* WebResourceLoader::connection() const
61 {
62     return WebProcess::shared().networkConnection()->connection();
63 }
64
65 uint64_t WebResourceLoader::destinationID() const
66 {
67     return m_coreLoader->identifier();
68 }
69
70 void WebResourceLoader::cancelResourceLoader()
71 {
72     m_coreLoader->cancel();
73 }
74
75 void WebResourceLoader::willSendRequest(const ResourceRequest& proposedRequest, const ResourceResponse& redirectResponse, ResourceRequest& newRequest)
76 {
77     LOG(Network, "(WebProcess) WebResourceLoader::willSendRequest to '%s'", proposedRequest.url().string().utf8().data());
78     
79     newRequest = proposedRequest;
80     m_coreLoader->willSendRequest(newRequest, redirectResponse);
81 }
82
83 void WebResourceLoader::didReceiveResponseWithCertificateInfo(const ResourceResponse& response, const PlatformCertificateInfo& certificateInfo)
84 {
85     LOG(Network, "(WebProcess) WebResourceLoader::didReceiveResponseWithCertificateInfo for '%s'. Status %d.", m_coreLoader->url().string().utf8().data(), response.httpStatusCode());
86     ResourceResponse responseCopy(response);
87     responseCopy.setCertificateChain(certificateInfo.certificateChain());
88     m_coreLoader->didReceiveResponse(responseCopy);
89 }
90
91 void WebResourceLoader::didReceiveData(const CoreIPC::DataReference& data, int64_t encodedDataLength)
92 {
93     LOG(Network, "(WebProcess) WebResourceLoader::didReceiveData of size %i for '%s'", (int)data.size(), m_coreLoader->url().string().utf8().data());
94     m_coreLoader->didReceiveData(reinterpret_cast<const char*>(data.data()), data.size(), encodedDataLength, DataPayloadBytes);
95 }
96
97 void WebResourceLoader::didFinishResourceLoad(double finishTime)
98 {
99     LOG(Network, "(WebProcess) WebResourceLoader::didFinishResourceLoad for '%s'", m_coreLoader->url().string().utf8().data());
100     m_coreLoader->didFinishLoading(finishTime);
101 }
102
103 void WebResourceLoader::didFailResourceLoad(const ResourceError& error)
104 {
105     LOG(Network, "(WebProcess) WebResourceLoader::didFailResourceLoad for '%s'", m_coreLoader->url().string().utf8().data());
106     
107     m_coreLoader->didFail(error);
108 }
109
110 void WebResourceLoader::didReceiveResource(const ShareableResource::Handle& handle, double finishTime)
111 {
112     LOG(Network, "(WebProcess) WebResourceLoader::didReceiveResource for '%s'", m_coreLoader->url().string().utf8().data());
113
114     RefPtr<SharedBuffer> buffer = handle.tryWrapInSharedBuffer();
115     if (!buffer) {
116         LOG_ERROR("Unable to create buffer from ShareableResource sent from the network process.");
117         m_coreLoader->didFail(internalError(m_coreLoader->request().url()));
118         return;
119     }
120
121     // Only send data to the didReceiveData callback if it exists.
122     if (buffer->size())
123         m_coreLoader->didReceiveBuffer(buffer.get(), buffer->size(), DataPayloadWholeResource);
124
125     m_coreLoader->didFinishLoading(finishTime);
126 }
127
128 void WebResourceLoader::canAuthenticateAgainstProtectionSpace(const ProtectionSpace& protectionSpace, bool& result)
129 {
130     result = m_coreLoader->canAuthenticateAgainstProtectionSpace(protectionSpace);
131 }
132
133 } // namespace WebKit
134
135 #endif // ENABLE(NETWORK_PROCESS)