• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2014 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
14 // RequestPeer interface, which we will use to communicate notifications
15 // back.
16 
17 #ifndef WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
18 #define WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
19 
20 #include "base/macros.h"
21 #include "net/base/request_priority.h"
22 #include "webkit/child/webkit_child_export.h"
23 
24 namespace blink {
25 class WebThreadedDataReceiver;
26 }
27 
28 // TODO(pilgrim) remove this once resource loader is moved to content
29 // http://crbug.com/338338
30 namespace content {
31 class RequestPeer;
32 class ResourceRequestBody;
33 struct SyncLoadResponse;
34 }
35 
36 namespace webkit_glue {
37 
38 class ResourceLoaderBridge {
39  public:
40   // use WebKitPlatformSupportImpl::CreateResourceLoader() for construction, but
41   // anybody can delete at any time, INCLUDING during processing of callbacks.
42   WEBKIT_CHILD_EXPORT virtual ~ResourceLoaderBridge();
43 
44   // Call this method before calling Start() to set the request body.
45   // May only be used with HTTP(S) POST requests.
46   virtual void SetRequestBody(content::ResourceRequestBody* request_body) = 0;
47 
48   // Call this method to initiate the request.  If this method succeeds, then
49   // the peer's methods will be called asynchronously to report various events.
50   virtual bool Start(content::RequestPeer* peer) = 0;
51 
52   // Call this method to cancel a request that is in progress.  This method
53   // causes the request to immediately transition into the 'done' state. The
54   // OnCompletedRequest method will be called asynchronously; this assumes
55   // the peer is still valid.
56   virtual void Cancel() = 0;
57 
58   // Call this method to suspend or resume a load that is in progress.  This
59   // method may only be called after a successful call to the Start method.
60   virtual void SetDefersLoading(bool value) = 0;
61 
62   // Call this method when the priority of the requested resource changes after
63   // Start() has been called.  This method may only be called after a successful
64   // call to the Start method.
65   virtual void DidChangePriority(net::RequestPriority new_priority,
66                                  int intra_priority_value) = 0;
67 
68   // Call this method to attach a data receiver which will receive resource data
69   // on its own thread.
70   virtual bool AttachThreadedDataReceiver(
71       blink::WebThreadedDataReceiver* threaded_data_receiver) = 0;
72 
73   // Call this method to load the resource synchronously (i.e., in one shot).
74   // This is an alternative to the Start method.  Be warned that this method
75   // will block the calling thread until the resource is fully downloaded or an
76   // error occurs.  It could block the calling thread for a long time, so only
77   // use this if you really need it!  There is also no way for the caller to
78   // interrupt this method.  Errors are reported via the status field of the
79   // response parameter.
80   virtual void SyncLoad(content::SyncLoadResponse* response) = 0;
81 
82  protected:
83   // Construction must go through
84   // WebKitPlatformSupportImpl::CreateResourceLoader()
85   // For HTTP(S) POST requests, the AppendDataToUpload and AppendFileToUpload
86   // methods may be called to construct the body of the request.
87   WEBKIT_CHILD_EXPORT ResourceLoaderBridge();
88 
89  private:
90   DISALLOW_COPY_AND_ASSIGN(ResourceLoaderBridge);
91 };
92 
93 }  // namespace webkit_glue
94 
95 #endif  // WEBKIT_CHILD_RESOURCE_LOADER_BRIDGE_H_
96