• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 //
5 // The intent of this file is to provide a type-neutral abstraction between
6 // Chrome and WebKit for resource loading. This pure-virtual interface is
7 // implemented by the embedder.
8 //
9 // One of these objects will be created by WebKit for each request. WebKit
10 // will own the pointer to the bridge, and will delete it when the request is
11 // no longer needed.
12 //
13 // In turn, the bridge's owner on the WebKit end will implement the Peer
14 // interface, which we will use to communicate notifications back.
15 
16 #ifndef WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
17 #define WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
18 
19 #include <utility>
20 
21 #include "build/build_config.h"
22 #if defined(OS_POSIX)
23 #include "base/file_descriptor_posix.h"
24 #endif
25 #include "base/memory/ref_counted.h"
26 #include "base/platform_file.h"
27 #include "base/values.h"
28 #include "net/base/request_priority.h"
29 #include "third_party/WebKit/public/platform/WebReferrerPolicy.h"
30 #include "third_party/WebKit/public/platform/WebURLRequest.h"
31 #include "url/gurl.h"
32 #include "webkit/child/webkit_child_export.h"
33 #include "webkit/common/resource_response_info.h"
34 #include "webkit/common/resource_type.h"
35 
36 namespace webkit_glue {
37 class ResourceRequestBody;
38 
39 class ResourceLoaderBridge {
40  public:
41   // Structure used when calling
42   // WebKitPlatformSupportImpl::CreateResourceLoader().
43   struct WEBKIT_CHILD_EXPORT RequestInfo {
44     RequestInfo();
45     ~RequestInfo();
46 
47     // HTTP-style method name (e.g., "GET" or "POST").
48     std::string method;
49 
50     // Absolute URL encoded in ASCII per the rules of RFC-2396.
51     GURL url;
52 
53     // URL of the document in the top-level window, which may be checked by the
54     // third-party cookie blocking policy.
55     GURL first_party_for_cookies;
56 
57     // Optional parameter, a URL with similar constraints in how it must be
58     // encoded as the url member.
59     GURL referrer;
60 
61     // The referrer policy that applies to the referrer.
62     blink::WebReferrerPolicy referrer_policy;
63 
64     // For HTTP(S) requests, the headers parameter can be a \r\n-delimited and
65     // \r\n-terminated list of MIME headers.  They should be ASCII-encoded using
66     // the standard MIME header encoding rules.  The headers parameter can also
67     // be null if no extra request headers need to be set.
68     std::string headers;
69 
70     // Composed of the values defined in url_request_load_flags.h.
71     int load_flags;
72 
73     // Process id of the process making the request.
74     int requestor_pid;
75 
76     // Indicates if the current request is the main frame load, a sub-frame
77     // load, or a sub objects load.
78     ResourceType::Type request_type;
79 
80     // Indicates the priority of this request, as determined by WebKit.
81     net::RequestPriority priority;
82 
83     // Used for plugin to browser requests.
84     uint32 request_context;
85 
86     // Identifies what appcache host this request is associated with.
87     int appcache_host_id;
88 
89     // Used to associated the bridge with a frame's network context.
90     int routing_id;
91 
92     // If true, then the response body will be downloaded to a file and the
93     // path to that file will be provided in ResponseInfo::download_file_path.
94     bool download_to_file;
95 
96     // True if the request was user initiated.
97     bool has_user_gesture;
98 
99     // Extra data associated with this request.  We do not own this pointer.
100     blink::WebURLRequest::ExtraData* extra_data;
101 
102    private:
103     DISALLOW_COPY_AND_ASSIGN(RequestInfo);
104   };
105 
106   // See the SyncLoad method declared below.  (The name of this struct is not
107   // suffixed with "Info" because it also contains the response data.)
108   struct SyncLoadResponse : ResourceResponseInfo {
109     WEBKIT_CHILD_EXPORT SyncLoadResponse();
110     WEBKIT_CHILD_EXPORT ~SyncLoadResponse();
111 
112     // The response error code.
113     int error_code;
114 
115     // The final URL of the response.  This may differ from the request URL in
116     // the case of a server redirect.
117     GURL url;
118 
119     // The response data.
120     std::string data;
121   };
122 
123   // Generated by the bridge. This is implemented by our custom resource loader
124   // within webkit. The Peer and it's bridge should have identical lifetimes
125   // as they represent each end of a communication channel.
126   //
127   // These callbacks mirror net::URLRequest::Delegate and the order and
128   // conditions in which they will be called are identical. See url_request.h
129   // for more information.
130   class WEBKIT_CHILD_EXPORT Peer {
131    public:
132     // Called as upload progress is made.
133     // note: only for requests with LOAD_ENABLE_UPLOAD_PROGRESS set
134     virtual void OnUploadProgress(uint64 position, uint64 size) = 0;
135 
136     // Called when a redirect occurs.  The implementation may return false to
137     // suppress the redirect.  The given ResponseInfo provides complete
138     // information about the redirect, and new_url is the URL that will be
139     // loaded if this method returns true.  If this method returns true, the
140     // output parameter *has_new_first_party_for_cookies indicates whether the
141     // output parameter *new_first_party_for_cookies contains the new URL that
142     // should be consulted for the third-party cookie blocking policy.
143     virtual bool OnReceivedRedirect(const GURL& new_url,
144                                     const ResourceResponseInfo& info,
145                                     bool* has_new_first_party_for_cookies,
146                                     GURL* new_first_party_for_cookies) = 0;
147 
148     // Called when response headers are available (after all redirects have
149     // been followed).
150     virtual void OnReceivedResponse(const ResourceResponseInfo& info) = 0;
151 
152     // Called when a chunk of response data is downloaded.  This method may be
153     // called multiple times or not at all if an error occurs.  This method is
154     // only called if RequestInfo::download_to_file was set to true, and in
155     // that case, OnReceivedData will not be called.
156     // The encoded_data_length is the length of the encoded data transferred
157     // over the network, which could be different from data length (e.g. for
158     // gzipped content), or -1 if unknown. It is only valid while devtools are
159     // attached. Otherwise it becomes -1.
160     virtual void OnDownloadedData(int len, int encoded_data_length) = 0;
161 
162     // Called when a chunk of response data is available. This method may
163     // be called multiple times or not at all if an error occurs.
164     // The encoded_data_length is the length of the encoded data transferred
165     // over the network, which could be different from data length (e.g. for
166     // gzipped content), or -1 if unknown. It is only valid while devtools are
167     // attached. Otherwise it becomes -1.
168     virtual void OnReceivedData(const char* data,
169                                 int data_length,
170                                 int encoded_data_length) = 0;
171 
172     // Called when metadata generated by the renderer is retrieved from the
173     // cache. This method may be called zero or one times.
OnReceivedCachedMetadata(const char * data,int len)174     virtual void OnReceivedCachedMetadata(const char* data, int len) { }
175 
176     // Called when the response is complete.  This method signals completion of
177     // the resource load.
178     virtual void OnCompletedRequest(
179         int error_code,
180         bool was_ignored_by_handler,
181         const std::string& security_info,
182         const base::TimeTicks& completion_time) = 0;
183 
184    protected:
~Peer()185     virtual ~Peer() {}
186   };
187 
188   // use WebKitPlatformSupportImpl::CreateResourceLoader() for construction, but
189   // anybody can delete at any time, INCLUDING during processing of callbacks.
190   WEBKIT_CHILD_EXPORT virtual ~ResourceLoaderBridge();
191 
192   // Call this method before calling Start() to set the request body.
193   // May only be used with HTTP(S) POST requests.
194   virtual void SetRequestBody(ResourceRequestBody* request_body) = 0;
195 
196   // Call this method to initiate the request.  If this method succeeds, then
197   // the peer's methods will be called asynchronously to report various events.
198   virtual bool Start(Peer* peer) = 0;
199 
200   // Call this method to cancel a request that is in progress.  This method
201   // causes the request to immediately transition into the 'done' state. The
202   // OnCompletedRequest method will be called asynchronously; this assumes
203   // the peer is still valid.
204   virtual void Cancel() = 0;
205 
206   // Call this method to suspend or resume a load that is in progress.  This
207   // method may only be called after a successful call to the Start method.
208   virtual void SetDefersLoading(bool value) = 0;
209 
210   // Call this method when the priority of the requested resource changes after
211   // Start() has been called.  This method may only be called after a successful
212   // call to the Start method.
213   virtual void DidChangePriority(net::RequestPriority new_priority) = 0;
214 
215   // Call this method to load the resource synchronously (i.e., in one shot).
216   // This is an alternative to the Start method.  Be warned that this method
217   // will block the calling thread until the resource is fully downloaded or an
218   // error occurs.  It could block the calling thread for a long time, so only
219   // use this if you really need it!  There is also no way for the caller to
220   // interrupt this method.  Errors are reported via the status field of the
221   // response parameter.
222   virtual void SyncLoad(SyncLoadResponse* response) = 0;
223 
224  protected:
225   // Construction must go through
226   // WebKitPlatformSupportImpl::CreateResourceLoader()
227   // For HTTP(S) POST requests, the AppendDataToUpload and AppendFileToUpload
228   // methods may be called to construct the body of the request.
229   WEBKIT_CHILD_EXPORT ResourceLoaderBridge();
230 
231  private:
232   DISALLOW_COPY_AND_ASSIGN(ResourceLoaderBridge);
233 };
234 
235 }  // namespace webkit_glue
236 
237 #endif  // WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
238