OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/devtools/devtools_network_transaction.h" | 5 #include "chrome/browser/devtools/devtools_network_transaction.h" |
6 | 6 |
7 #include "chrome/browser/devtools/devtools_network_controller.h" | 7 #include "chrome/browser/devtools/devtools_network_controller.h" |
8 #include "net/base/net_errors.h" | 8 #include "net/base/net_errors.h" |
9 #include "net/base/upload_progress.h" | 9 #include "net/base/upload_progress.h" |
10 #include "net/http/http_network_transaction.h" | 10 #include "net/http/http_network_transaction.h" |
11 #include "net/http/http_request_info.h" | 11 #include "net/http/http_request_info.h" |
12 | 12 |
13 DevToolsNetworkTransaction::DevToolsNetworkTransaction( | 13 DevToolsNetworkTransaction::DevToolsNetworkTransaction( |
14 DevToolsNetworkController* controller, | 14 DevToolsNetworkController* controller, |
15 scoped_ptr<net::HttpTransaction> network_transaction) | 15 scoped_ptr<net::HttpTransaction> network_transaction) |
16 : controller_(controller), | 16 : controller_(controller), |
17 network_transaction_(network_transaction.Pass()), | 17 network_transaction_(network_transaction.Pass()), |
18 request_(NULL), | 18 request_(NULL), |
19 failed_(false), | 19 failed_(false), |
20 throttled_byte_count_(0), | |
21 callback_type_(NONE), | |
20 proxy_callback_(base::Bind(&DevToolsNetworkTransaction::OnCallback, | 22 proxy_callback_(base::Bind(&DevToolsNetworkTransaction::OnCallback, |
21 base::Unretained(this))) { | 23 base::Unretained(this))) { |
22 DCHECK(controller); | 24 DCHECK(controller); |
23 controller->AddTransaction(this); | 25 controller->AddTransaction(this); |
24 } | 26 } |
25 | 27 |
26 DevToolsNetworkTransaction::~DevToolsNetworkTransaction() { | 28 DevToolsNetworkTransaction::~DevToolsNetworkTransaction() { |
27 controller_->RemoveTransaction(this); | 29 controller_->RemoveTransaction(this); |
28 } | 30 } |
29 | 31 |
32 void DevToolsNetworkTransaction::Throttle(int result) { | |
33 throttled_result_ = result; | |
34 | |
35 if (callback_type_ == START) | |
36 throttled_byte_count_ += network_transaction_->GetTotalReceivedBytes(); | |
37 if (result > 0) | |
38 throttled_byte_count_ += result; | |
39 | |
40 controller_->ThrottleTransaction(this); | |
41 } | |
42 | |
30 void DevToolsNetworkTransaction::OnCallback(int rv) { | 43 void DevToolsNetworkTransaction::OnCallback(int rv) { |
31 if (failed_) | 44 if (failed_) |
32 return; | 45 return; |
33 DCHECK(!callback_.is_null()); | 46 DCHECK(!callback_.is_null()); |
47 if (callback_type_ == START || callback_type_ == READ) { | |
48 if (controller_->ShouldThrottle(request_)) { | |
49 Throttle(rv); | |
50 return; | |
51 } | |
52 } | |
34 net::CompletionCallback callback = callback_; | 53 net::CompletionCallback callback = callback_; |
35 callback_.Reset(); | 54 callback_.Reset(); |
55 callback_type_ = NONE; | |
36 callback.Run(rv); | 56 callback.Run(rv); |
37 } | 57 } |
38 | 58 |
59 int DevToolsNetworkTransaction::SetupCallback( | |
60 net::CompletionCallback callback, | |
61 int result, | |
62 CallbackType callback_type) { | |
63 DCHECK(callback_type_ == NONE); | |
64 | |
65 if (result == net::ERR_IO_PENDING) { | |
66 callback_type_ = callback_type; | |
67 callback_ = callback; | |
68 return result; | |
69 } | |
70 | |
71 if (!controller_->ShouldThrottle(request_)) | |
72 return result; | |
73 | |
74 // Only START and READ operation throttling is supported. | |
75 if (callback_type != START && callback_type != READ) | |
76 return result; | |
77 | |
78 // In case of error |throttled_byte_count_| is unknown. | |
79 if (result < 0) | |
80 return result; | |
81 | |
82 // URLRequestJob relies on synchronous end-of-stream notification. | |
83 if (callback_type == READ && result == 0) | |
84 return result; | |
85 | |
86 callback_type_ = callback_type; | |
87 callback_ = callback; | |
88 Throttle(result); | |
89 return net::ERR_IO_PENDING; | |
90 } | |
91 | |
39 void DevToolsNetworkTransaction::Fail() { | 92 void DevToolsNetworkTransaction::Fail() { |
40 DCHECK(request_); | 93 DCHECK(request_); |
41 DCHECK(!failed_); | 94 DCHECK(!failed_); |
42 failed_ = true; | 95 failed_ = true; |
43 network_transaction_->SetBeforeNetworkStartCallback( | 96 network_transaction_->SetBeforeNetworkStartCallback( |
44 BeforeNetworkStartCallback()); | 97 BeforeNetworkStartCallback()); |
45 if (callback_.is_null()) | 98 if (callback_.is_null()) |
46 return; | 99 return; |
47 net::CompletionCallback callback = callback_; | 100 net::CompletionCallback callback = callback_; |
48 callback_.Reset(); | 101 callback_.Reset(); |
102 callback_type_ = NONE; | |
49 callback.Run(net::ERR_INTERNET_DISCONNECTED); | 103 callback.Run(net::ERR_INTERNET_DISCONNECTED); |
50 } | 104 } |
51 | 105 |
52 int DevToolsNetworkTransaction::Start( | 106 int DevToolsNetworkTransaction::Start( |
53 const net::HttpRequestInfo* request, | 107 const net::HttpRequestInfo* request, |
54 const net::CompletionCallback& callback, | 108 const net::CompletionCallback& callback, |
55 const net::BoundNetLog& net_log) { | 109 const net::BoundNetLog& net_log) { |
56 DCHECK(request); | 110 DCHECK(request); |
57 request_ = request; | 111 request_ = request; |
58 | 112 |
59 if (controller_->ShouldFail(request_)) { | 113 if (controller_->ShouldFail(request_)) { |
60 failed_ = true; | 114 failed_ = true; |
61 network_transaction_->SetBeforeNetworkStartCallback( | 115 network_transaction_->SetBeforeNetworkStartCallback( |
62 BeforeNetworkStartCallback()); | 116 BeforeNetworkStartCallback()); |
63 return net::ERR_INTERNET_DISCONNECTED; | 117 return net::ERR_INTERNET_DISCONNECTED; |
64 } | 118 } |
65 int rv = network_transaction_->Start(request, proxy_callback_, net_log); | 119 int rv = network_transaction_->Start(request, proxy_callback_, net_log); |
66 if (rv == net::ERR_IO_PENDING) | 120 return SetupCallback(callback, rv, START); |
67 callback_ = callback; | |
68 return rv; | |
69 } | 121 } |
70 | 122 |
71 int DevToolsNetworkTransaction::RestartIgnoringLastError( | 123 int DevToolsNetworkTransaction::RestartIgnoringLastError( |
72 const net::CompletionCallback& callback) { | 124 const net::CompletionCallback& callback) { |
73 if (failed_) | 125 if (failed_) |
74 return net::ERR_INTERNET_DISCONNECTED; | 126 return net::ERR_INTERNET_DISCONNECTED; |
75 int rv = network_transaction_->RestartIgnoringLastError(proxy_callback_); | 127 int rv = network_transaction_->RestartIgnoringLastError(proxy_callback_); |
76 if (rv == net::ERR_IO_PENDING) | 128 return SetupCallback(callback, rv, RESTART_IGNORING_LAST_ERROR); |
77 callback_ = callback; | |
78 return rv; | |
79 } | 129 } |
80 | 130 |
81 int DevToolsNetworkTransaction::RestartWithCertificate( | 131 int DevToolsNetworkTransaction::RestartWithCertificate( |
82 net::X509Certificate* client_cert, | 132 net::X509Certificate* client_cert, |
83 const net::CompletionCallback& callback) { | 133 const net::CompletionCallback& callback) { |
84 if (failed_) | 134 if (failed_) |
85 return net::ERR_INTERNET_DISCONNECTED; | 135 return net::ERR_INTERNET_DISCONNECTED; |
86 int rv = network_transaction_->RestartWithCertificate( | 136 int rv = network_transaction_->RestartWithCertificate( |
87 client_cert, proxy_callback_); | 137 client_cert, proxy_callback_); |
88 if (rv == net::ERR_IO_PENDING) | 138 return SetupCallback(callback, rv, RESTART_WITH_CERTIFICATE); |
89 callback_ = callback; | |
90 return rv; | |
91 } | 139 } |
92 | 140 |
93 int DevToolsNetworkTransaction::RestartWithAuth( | 141 int DevToolsNetworkTransaction::RestartWithAuth( |
94 const net::AuthCredentials& credentials, | 142 const net::AuthCredentials& credentials, |
95 const net::CompletionCallback& callback) { | 143 const net::CompletionCallback& callback) { |
96 if (failed_) | 144 if (failed_) |
97 return net::ERR_INTERNET_DISCONNECTED; | 145 return net::ERR_INTERNET_DISCONNECTED; |
98 int rv = network_transaction_->RestartWithAuth(credentials, proxy_callback_); | 146 int rv = network_transaction_->RestartWithAuth(credentials, proxy_callback_); |
99 if (rv == net::ERR_IO_PENDING) | 147 return SetupCallback(callback, rv, RESTART_WITH_AUTH); |
100 callback_ = callback; | |
101 return rv; | |
102 } | 148 } |
103 | 149 |
104 bool DevToolsNetworkTransaction::IsReadyToRestartForAuth() { | 150 bool DevToolsNetworkTransaction::IsReadyToRestartForAuth() { |
105 return network_transaction_->IsReadyToRestartForAuth(); | 151 return network_transaction_->IsReadyToRestartForAuth(); |
106 } | 152 } |
107 | 153 |
108 int DevToolsNetworkTransaction::Read( | 154 int DevToolsNetworkTransaction::Read( |
109 net::IOBuffer* buf, | 155 net::IOBuffer* buf, |
110 int buf_len, | 156 int buf_len, |
111 const net::CompletionCallback& callback) { | 157 const net::CompletionCallback& callback) { |
112 if (failed_) | 158 if (failed_) |
113 return net::ERR_INTERNET_DISCONNECTED; | 159 return net::ERR_INTERNET_DISCONNECTED; |
114 int rv = network_transaction_->Read(buf, buf_len, proxy_callback_); | 160 int rv = network_transaction_->Read(buf, buf_len, proxy_callback_); |
115 if (rv == net::ERR_IO_PENDING) | 161 return SetupCallback(callback, rv, READ); |
116 callback_ = callback; | |
117 return rv; | |
118 } | 162 } |
119 | 163 |
120 void DevToolsNetworkTransaction::StopCaching() { | 164 void DevToolsNetworkTransaction::StopCaching() { |
121 network_transaction_->StopCaching(); | 165 network_transaction_->StopCaching(); |
122 } | 166 } |
123 | 167 |
124 bool DevToolsNetworkTransaction::GetFullRequestHeaders( | 168 bool DevToolsNetworkTransaction::GetFullRequestHeaders( |
125 net::HttpRequestHeaders* headers) const { | 169 net::HttpRequestHeaders* headers) const { |
126 return network_transaction_->GetFullRequestHeaders(headers); | 170 return network_transaction_->GetFullRequestHeaders(headers); |
127 } | 171 } |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
169 void DevToolsNetworkTransaction::SetBeforeNetworkStartCallback( | 213 void DevToolsNetworkTransaction::SetBeforeNetworkStartCallback( |
170 const BeforeNetworkStartCallback& callback) { | 214 const BeforeNetworkStartCallback& callback) { |
171 network_transaction_->SetBeforeNetworkStartCallback(callback); | 215 network_transaction_->SetBeforeNetworkStartCallback(callback); |
172 } | 216 } |
173 | 217 |
174 int DevToolsNetworkTransaction::ResumeNetworkStart() { | 218 int DevToolsNetworkTransaction::ResumeNetworkStart() { |
175 if (failed_) | 219 if (failed_) |
176 return net::ERR_INTERNET_DISCONNECTED; | 220 return net::ERR_INTERNET_DISCONNECTED; |
177 return network_transaction_->ResumeNetworkStart(); | 221 return network_transaction_->ResumeNetworkStart(); |
178 } | 222 } |
223 | |
224 void DevToolsNetworkTransaction::DecreaseThrottledByteCount(int64_t delta) { | |
225 throttled_byte_count_ -= delta; | |
vsevik
2014/06/11 14:29:39
nit: inline
eustas
2014/06/11 14:42:47
Done.
| |
226 } | |
227 | |
228 void DevToolsNetworkTransaction::FireThrottledCallback() { | |
229 DCHECK(!callback_.is_null()); | |
230 DCHECK(callback_type_ == READ || callback_type_ == START); | |
231 net::CompletionCallback callback = callback_; | |
232 callback_.Reset(); | |
233 callback_type_ = NONE; | |
234 callback.Run(throttled_result_); | |
235 } | |
OLD | NEW |