Roll ANGLE e754fb8..6ffeb74
[chromium-blink-merge.git] / content / browser / appcache / appcache_url_request_job.h
blobbe30a5fa3c3c49c3be1ee63cd657ed42d7bb4cff
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_BROWSER_APPCACHE_APPCACHE_URL_REQUEST_JOB_H_
6 #define CONTENT_BROWSER_APPCACHE_APPCACHE_URL_REQUEST_JOB_H_
8 #include <string>
10 #include "base/memory/weak_ptr.h"
11 #include "content/browser/appcache/appcache_entry.h"
12 #include "content/browser/appcache/appcache_executable_handler.h"
13 #include "content/browser/appcache/appcache_response.h"
14 #include "content/browser/appcache/appcache_storage.h"
15 #include "content/common/content_export.h"
16 #include "net/http/http_byte_range.h"
17 #include "net/url_request/url_request_job.h"
19 namespace net {
20 class GrowableIOBuffer;
23 namespace content {
24 class AppCacheHost;
25 class AppCacheRequestHandlerTest;
26 class AppCacheURLRequestJobTest;
28 // A net::URLRequestJob derivative that knows how to return a response stored
29 // in the appcache.
30 class CONTENT_EXPORT AppCacheURLRequestJob
31 : public net::URLRequestJob,
32 public AppCacheStorage::Delegate {
33 public:
34 AppCacheURLRequestJob(net::URLRequest* request,
35 net::NetworkDelegate* network_delegate,
36 AppCacheStorage* storage,
37 AppCacheHost* host,
38 bool is_main_resource);
40 // Informs the job of what response it should deliver. Only one of these
41 // methods should be called, and only once per job. A job will sit idle and
42 // wait indefinitely until one of the deliver methods is called.
43 void DeliverAppCachedResponse(const GURL& manifest_url, int64 group_id,
44 int64 cache_id, const AppCacheEntry& entry,
45 bool is_fallback);
46 void DeliverNetworkResponse();
47 void DeliverErrorResponse();
49 bool is_waiting() const {
50 return delivery_type_ == AWAITING_DELIVERY_ORDERS;
53 bool is_delivering_appcache_response() const {
54 return delivery_type_ == APPCACHED_DELIVERY;
57 bool is_delivering_network_response() const {
58 return delivery_type_ == NETWORK_DELIVERY;
61 bool is_delivering_error_response() const {
62 return delivery_type_ == ERROR_DELIVERY;
65 // Accessors for the info about the appcached response, if any,
66 // that this job has been instructed to deliver. These are only
67 // valid to call if is_delivering_appcache_response.
68 const GURL& manifest_url() const { return manifest_url_; }
69 int64 group_id() const { return group_id_; }
70 int64 cache_id() const { return cache_id_; }
71 const AppCacheEntry& entry() const { return entry_; }
73 // net::URLRequestJob's Kill method is made public so the users of this
74 // class in the appcache namespace can call it.
75 void Kill() override;
77 // Returns true if the job has been started by the net library.
78 bool has_been_started() const {
79 return has_been_started_;
82 // Returns true if the job has been killed.
83 bool has_been_killed() const {
84 return has_been_killed_;
87 // Returns true if the cache entry was not found in the disk cache.
88 bool cache_entry_not_found() const {
89 return cache_entry_not_found_;
92 protected:
93 ~AppCacheURLRequestJob() override;
95 private:
96 friend class content::AppCacheRequestHandlerTest;
97 friend class content::AppCacheURLRequestJobTest;
99 enum DeliveryType {
100 AWAITING_DELIVERY_ORDERS,
101 APPCACHED_DELIVERY,
102 NETWORK_DELIVERY,
103 ERROR_DELIVERY
106 // Returns true if one of the Deliver methods has been called.
107 bool has_delivery_orders() const {
108 return !is_waiting();
111 void MaybeBeginDelivery();
112 void BeginDelivery();
114 // For executable response handling.
115 void BeginExecutableHandlerDelivery();
116 void OnExecutableSourceLoaded(int result);
117 void InvokeExecutableHandler(AppCacheExecutableHandler* handler);
118 void OnExecutableResponseCallback(
119 const AppCacheExecutableHandler::Response& response);
120 void BeginErrorDelivery(const char* message);
122 // AppCacheStorage::Delegate methods
123 void OnResponseInfoLoaded(AppCacheResponseInfo* response_info,
124 int64 response_id) override;
125 void OnCacheLoaded(AppCache* cache, int64 cache_id) override;
127 const net::HttpResponseInfo* http_info() const;
128 bool is_range_request() const { return range_requested_.IsValid(); }
129 void SetupRangeResponse();
131 // AppCacheResponseReader completion callback
132 void OnReadComplete(int result);
134 // net::URLRequestJob methods, see url_request_job.h for doc comments
135 void Start() override;
136 net::LoadState GetLoadState() const override;
137 bool GetCharset(std::string* charset) override;
138 void GetResponseInfo(net::HttpResponseInfo* info) override;
139 bool ReadRawData(net::IOBuffer* buf, int buf_size, int* bytes_read) override;
141 // Sets extra request headers for Job types that support request headers.
142 // This is how we get informed of range-requests.
143 void SetExtraRequestHeaders(const net::HttpRequestHeaders& headers) override;
145 // FilterContext methods
146 bool GetMimeType(std::string* mime_type) const override;
147 int GetResponseCode() const override;
149 AppCacheHost* host_;
150 AppCacheStorage* storage_;
151 base::TimeTicks start_time_tick_;
152 bool has_been_started_;
153 bool has_been_killed_;
154 DeliveryType delivery_type_;
155 GURL manifest_url_;
156 int64 group_id_;
157 int64 cache_id_;
158 AppCacheEntry entry_;
159 bool is_fallback_;
160 bool is_main_resource_; // Used for histogram logging.
161 bool cache_entry_not_found_;
162 scoped_refptr<AppCacheResponseInfo> info_;
163 scoped_refptr<net::GrowableIOBuffer> handler_source_buffer_;
164 scoped_ptr<AppCacheResponseReader> handler_source_reader_;
165 net::HttpByteRange range_requested_;
166 scoped_ptr<net::HttpResponseInfo> range_response_info_;
167 scoped_ptr<AppCacheResponseReader> reader_;
168 scoped_refptr<AppCache> cache_;
169 scoped_refptr<AppCacheGroup> group_;
170 base::WeakPtrFactory<AppCacheURLRequestJob> weak_factory_;
173 } // namespace content
175 #endif // CONTENT_BROWSER_APPCACHE_APPCACHE_URL_REQUEST_JOB_H_