OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/renderer/net/net_error_helper.h" | 5 #include "chrome/renderer/net/net_error_helper.h" |
6 | 6 |
7 #include "base/values.h" | 7 #include "base/values.h" |
8 #include "chrome/common/localized_error.h" | 8 #include "chrome/common/localized_error.h" |
9 #include "chrome/common/render_messages.h" | 9 #include "chrome/common/render_messages.h" |
10 #include "chrome/common/net/net_error_info.h" | 10 #include "chrome/common/net/net_error_info.h" |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
94 } | 94 } |
95 | 95 |
96 } // namespace | 96 } // namespace |
97 | 97 |
98 NetErrorHelper::NetErrorHelper(RenderView* render_view) | 98 NetErrorHelper::NetErrorHelper(RenderView* render_view) |
99 : RenderViewObserver(render_view), | 99 : RenderViewObserver(render_view), |
100 ALLOW_THIS_IN_INITIALIZER_LIST(tracker_(base::Bind( | 100 ALLOW_THIS_IN_INITIALIZER_LIST(tracker_(base::Bind( |
101 &NetErrorHelper::TrackerCallback, | 101 &NetErrorHelper::TrackerCallback, |
102 base::Unretained(this)))), | 102 base::Unretained(this)))), |
103 dns_error_page_state_(NetErrorTracker::DNS_ERROR_PAGE_NONE), | 103 dns_error_page_state_(NetErrorTracker::DNS_ERROR_PAGE_NONE), |
104 updated_error_page_(false) { | 104 updated_error_page_(false), |
| 105 is_failed_post_(false) { |
105 } | 106 } |
106 | 107 |
107 NetErrorHelper::~NetErrorHelper() { | 108 NetErrorHelper::~NetErrorHelper() { |
108 } | 109 } |
109 | 110 |
110 void NetErrorHelper::DidStartProvisionalLoad(WebKit::WebFrame* frame) { | 111 void NetErrorHelper::DidStartProvisionalLoad(WebKit::WebFrame* frame) { |
111 tracker_.OnStartProvisionalLoad(GetFrameType(frame), GetPageType(frame)); | 112 tracker_.OnStartProvisionalLoad(GetFrameType(frame), GetPageType(frame)); |
112 } | 113 } |
113 | 114 |
114 void NetErrorHelper::DidFailProvisionalLoad(WebKit::WebFrame* frame, | 115 void NetErrorHelper::DidFailProvisionalLoad(WebKit::WebFrame* frame, |
115 const WebKit::WebURLError& error) { | 116 const WebKit::WebURLError& error) { |
| 117 WebKit::WebDataSource* data_source = frame->provisionalDataSource(); |
| 118 const WebKit::WebURLRequest& failed_request = data_source->request(); |
| 119 is_failed_post_ = EqualsASCII(failed_request.httpMethod(), "POST"); |
116 tracker_.OnFailProvisionalLoad(GetFrameType(frame), GetErrorType(error)); | 120 tracker_.OnFailProvisionalLoad(GetFrameType(frame), GetErrorType(error)); |
117 } | 121 } |
118 | 122 |
119 void NetErrorHelper::DidCommitProvisionalLoad(WebKit::WebFrame* frame, | 123 void NetErrorHelper::DidCommitProvisionalLoad(WebKit::WebFrame* frame, |
120 bool is_new_navigation) { | 124 bool is_new_navigation) { |
121 tracker_.OnCommitProvisionalLoad(GetFrameType(frame)); | 125 tracker_.OnCommitProvisionalLoad(GetFrameType(frame)); |
122 } | 126 } |
123 | 127 |
124 void NetErrorHelper::DidFinishLoad(WebKit::WebFrame* frame) { | 128 void NetErrorHelper::DidFinishLoad(WebKit::WebFrame* frame) { |
125 tracker_.OnFinishLoad(GetFrameType(frame)); | 129 tracker_.OnFinishLoad(GetFrameType(frame)); |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
173 DVLOG(1) << "Updating error page with result " << dns_probe_result; | 177 DVLOG(1) << "Updating error page with result " << dns_probe_result; |
174 | 178 |
175 int net_error = DnsProbeResultToNetError(dns_probe_result); | 179 int net_error = DnsProbeResultToNetError(dns_probe_result); |
176 if (net_error == net::OK) | 180 if (net_error == net::OK) |
177 return; | 181 return; |
178 | 182 |
179 DVLOG(1) << "net error code is " << net_error; | 183 DVLOG(1) << "net error code is " << net_error; |
180 | 184 |
181 DictionaryValue error_strings; | 185 DictionaryValue error_strings; |
182 LocalizedError::GetStrings(NetErrorToWebURLError(net_error), | 186 LocalizedError::GetStrings(NetErrorToWebURLError(net_error), |
183 &error_strings, | 187 is_failed_post_, |
184 RenderThread::Get()->GetLocale()); | 188 RenderThread::Get()->GetLocale(), |
| 189 &error_strings); |
185 | 190 |
186 // TODO(ttuttle): Update error page with error_strings. | 191 // TODO(ttuttle): Update error page with error_strings. |
187 } | 192 } |
OLD | NEW |