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_LOADER_ASYNC_RESOURCE_HANDLER_H_
6 #define CONTENT_BROWSER_LOADER_ASYNC_RESOURCE_HANDLER_H_
10 #include "base/memory/ref_counted.h"
11 #include "base/time/time.h"
12 #include "content/browser/loader/resource_handler.h"
13 #include "content/browser/loader/resource_message_delegate.h"
22 class ResourceContext
;
23 class ResourceDispatcherHostImpl
;
24 class ResourceMessageFilter
;
27 // Used to complete an asynchronous resource request in response to resource
28 // load events from the resource dispatcher host.
29 class AsyncResourceHandler
: public ResourceHandler
,
30 public ResourceMessageDelegate
{
32 AsyncResourceHandler(net::URLRequest
* request
,
33 ResourceDispatcherHostImpl
* rdh
);
34 ~AsyncResourceHandler() override
;
36 bool OnMessageReceived(const IPC::Message
& message
) override
;
38 // ResourceHandler implementation:
39 bool OnUploadProgress(uint64 position
, uint64 size
) override
;
40 bool OnRequestRedirected(const net::RedirectInfo
& redirect_info
,
41 ResourceResponse
* response
,
42 bool* defer
) override
;
43 bool OnResponseStarted(ResourceResponse
* response
, bool* defer
) override
;
44 bool OnWillStart(const GURL
& url
, bool* defer
) override
;
45 bool OnBeforeNetworkStart(const GURL
& url
, bool* defer
) override
;
46 bool OnWillRead(scoped_refptr
<net::IOBuffer
>* buf
,
48 int min_size
) override
;
49 bool OnReadCompleted(int bytes_read
, bool* defer
) override
;
50 void OnResponseCompleted(const net::URLRequestStatus
& status
,
51 const std::string
& security_info
,
52 bool* defer
) override
;
53 void OnDataDownloaded(int bytes_downloaded
) override
;
56 // IPC message handlers:
57 void OnFollowRedirect(int request_id
);
58 void OnDataReceivedACK(int request_id
);
60 bool EnsureResourceBufferIsInitialized();
61 void ResumeIfDeferred();
64 scoped_refptr
<ResourceBuffer
> buffer_
;
65 ResourceDispatcherHostImpl
* rdh_
;
67 // Number of messages we've sent to the renderer that we haven't gotten an
68 // ACK for. This allows us to avoid having too many messages in flight.
69 int pending_data_count_
;
75 bool has_checked_for_sufficient_resources_
;
76 bool sent_received_response_msg_
;
77 bool sent_first_data_msg_
;
79 int64_t reported_transfer_size_
;
81 base::TimeTicks redirect_start_time_
;
83 DISALLOW_COPY_AND_ASSIGN(AsyncResourceHandler
);
86 } // namespace content
88 #endif // CONTENT_BROWSER_LOADER_ASYNC_RESOURCE_HANDLER_H_