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.
5 #ifndef CONTENT_PUBLIC_BROWSER_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
6 #define CONTENT_PUBLIC_BROWSER_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
10 #include "base/basictypes.h"
11 #include "base/memory/scoped_ptr.h"
12 #include "content/common/content_export.h"
13 #include "webkit/common/resource_type.h"
16 template <class T> class ScopedVector;
19 class AppCacheService;
23 class ResourceContext;
24 class ResourceThrottle;
27 struct ResourceResponse;
35 class AuthChallengeInfo;
41 class ResourceDispatcherHostLoginDelegate;
43 // Interface that the embedder provides to ResourceDispatcherHost to allow
44 // observing and modifying requests.
45 class CONTENT_EXPORT ResourceDispatcherHostDelegate {
47 // Called when a request begins. Return false to abort the request.
48 virtual bool ShouldBeginRequest(
51 const std::string& method,
53 ResourceType::Type resource_type,
54 ResourceContext* resource_context);
56 // Called after ShouldBeginRequest to allow the embedder to add resource
58 virtual void RequestBeginning(
59 net::URLRequest* request,
60 ResourceContext* resource_context,
61 appcache::AppCacheService* appcache_service,
62 ResourceType::Type resource_type,
65 ScopedVector<ResourceThrottle>* throttles);
67 // Allows an embedder to add additional resource handlers for a download.
68 // |must_download| is set if the request must be handled as a download.
69 virtual void DownloadStarting(
70 net::URLRequest* request,
71 ResourceContext* resource_context,
75 bool is_content_initiated,
77 ScopedVector<ResourceThrottle>* throttles);
79 // Creates a ResourceDispatcherHostLoginDelegate that asks the user for a
80 // username and password.
81 virtual ResourceDispatcherHostLoginDelegate* CreateLoginDelegate(
82 net::AuthChallengeInfo* auth_info, net::URLRequest* request);
84 // Launches the url for the given tab. Returns true if an attempt to handle
85 // the url was made, e.g. by launching an app. Note that this does not
86 // guarantee that the app successfully handled it.
87 virtual bool HandleExternalProtocol(const GURL& url,
91 // Returns true if we should force the given resource to be downloaded.
92 // Otherwise, the content layer decides.
93 virtual bool ShouldForceDownloadResource(
94 const GURL& url, const std::string& mime_type);
96 // Returns true and sets |origin| if a Stream should be created for the
98 // If true is returned, a new Stream will be created and OnStreamCreated()
99 // will be called with
100 // - a StreamHandle instance for the Stream. The handle contains the URL for
101 // reading the Stream etc.
102 // The Stream's origin will be set to |origin|.
104 // If the stream will be rendered in a BrowserPlugin, |payload| will contain
105 // the data that should be given to the old ResourceHandler to forward to the
107 virtual bool ShouldInterceptResourceAsStream(
108 net::URLRequest* request,
109 const std::string& mime_type,
111 std::string* payload);
113 // Informs the delegate that a Stream was created. The Stream can be read from
114 // the blob URL of the Stream, but can only be read once.
115 virtual void OnStreamCreated(
116 net::URLRequest* request,
117 scoped_ptr<content::StreamHandle> stream);
119 // Informs the delegate that a response has started.
120 virtual void OnResponseStarted(
121 net::URLRequest* request,
122 ResourceContext* resource_context,
123 ResourceResponse* response,
124 IPC::Sender* sender);
126 // Informs the delegate that a request has been redirected.
127 virtual void OnRequestRedirected(
128 const GURL& redirect_url,
129 net::URLRequest* request,
130 ResourceContext* resource_context,
131 ResourceResponse* response);
133 // Notification that a request has completed.
134 virtual void RequestComplete(net::URLRequest* url_request);
137 ResourceDispatcherHostDelegate();
138 virtual ~ResourceDispatcherHostDelegate();
141 } // namespace content
143 #endif // CONTENT_PUBLIC_BROWSER_RESOURCE_DISPATCHER_HOST_DELEGATE_H_