| 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 "extensions/shell/browser/shell_network_delegate.h" | 5 #include "extensions/shell/browser/shell_network_delegate.h" |
| 6 | 6 |
| 7 #include "content/public/browser/render_frame_host.h" | 7 #include "content/public/browser/render_frame_host.h" |
| 8 #include "content/public/browser/resource_request_info.h" | 8 #include "content/public/browser/resource_request_info.h" |
| 9 #include "extensions/browser/api/web_request/web_request_api.h" | 9 #include "extensions/browser/api/web_request/web_request_api.h" |
| 10 #include "extensions/browser/extension_system.h" | 10 #include "extensions/browser/extension_system.h" |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 69 allowed_unsafe_redirect_url); | 69 allowed_unsafe_redirect_url); |
| 70 } | 70 } |
| 71 | 71 |
| 72 void ShellNetworkDelegate::OnBeforeRedirect( | 72 void ShellNetworkDelegate::OnBeforeRedirect( |
| 73 net::URLRequest* request, | 73 net::URLRequest* request, |
| 74 const GURL& new_location) { | 74 const GURL& new_location) { |
| 75 ExtensionWebRequestEventRouter::GetInstance()->OnBeforeRedirect( | 75 ExtensionWebRequestEventRouter::GetInstance()->OnBeforeRedirect( |
| 76 browser_context_, extension_info_map_.get(), request, new_location); | 76 browser_context_, extension_info_map_.get(), request, new_location); |
| 77 } | 77 } |
| 78 | 78 |
| 79 | 79 void ShellNetworkDelegate::OnResponseStarted(net::URLRequest* request, |
| 80 void ShellNetworkDelegate::OnResponseStarted( | 80 int net_error) { |
| 81 net::URLRequest* request) { | |
| 82 ExtensionWebRequestEventRouter::GetInstance()->OnResponseStarted( | 81 ExtensionWebRequestEventRouter::GetInstance()->OnResponseStarted( |
| 83 browser_context_, extension_info_map_.get(), request); | 82 browser_context_, extension_info_map_.get(), request, net_error); |
| 84 } | 83 } |
| 85 | 84 |
| 86 void ShellNetworkDelegate::OnCompleted( | 85 void ShellNetworkDelegate::OnCompleted(net::URLRequest* request, |
| 87 net::URLRequest* request, | 86 bool started, |
| 88 bool started) { | 87 int net_error) { |
| 89 if (request->status().status() == net::URLRequestStatus::SUCCESS) { | 88 DCHECK_NE(net::ERR_IO_PENDING, net_error); |
| 89 |
| 90 if (net_error == net::OK) { |
| 90 bool is_redirect = request->response_headers() && | 91 bool is_redirect = request->response_headers() && |
| 91 net::HttpResponseHeaders::IsRedirectResponseCode( | 92 net::HttpResponseHeaders::IsRedirectResponseCode( |
| 92 request->response_headers()->response_code()); | 93 request->response_headers()->response_code()); |
| 93 if (!is_redirect) { | 94 if (!is_redirect) { |
| 94 ExtensionWebRequestEventRouter::GetInstance()->OnCompleted( | 95 ExtensionWebRequestEventRouter::GetInstance()->OnCompleted( |
| 95 browser_context_, extension_info_map_.get(), request); | 96 browser_context_, extension_info_map_.get(), request, net_error); |
| 96 } | 97 } |
| 97 return; | 98 } else { |
| 99 ExtensionWebRequestEventRouter::GetInstance()->OnErrorOccurred( |
| 100 browser_context_, extension_info_map_.get(), request, started, |
| 101 net_error); |
| 98 } | 102 } |
| 99 | |
| 100 if (request->status().status() == net::URLRequestStatus::FAILED || | |
| 101 request->status().status() == net::URLRequestStatus::CANCELED) { | |
| 102 ExtensionWebRequestEventRouter::GetInstance()->OnErrorOccurred( | |
| 103 browser_context_, extension_info_map_.get(), request, started); | |
| 104 return; | |
| 105 } | |
| 106 | |
| 107 NOTREACHED(); | |
| 108 } | 103 } |
| 109 | 104 |
| 110 void ShellNetworkDelegate::OnURLRequestDestroyed( | 105 void ShellNetworkDelegate::OnURLRequestDestroyed( |
| 111 net::URLRequest* request) { | 106 net::URLRequest* request) { |
| 112 ExtensionWebRequestEventRouter::GetInstance()->OnURLRequestDestroyed( | 107 ExtensionWebRequestEventRouter::GetInstance()->OnURLRequestDestroyed( |
| 113 browser_context_, request); | 108 browser_context_, request); |
| 114 } | 109 } |
| 115 | 110 |
| 116 void ShellNetworkDelegate::OnPACScriptError( | 111 void ShellNetworkDelegate::OnPACScriptError( |
| 117 int line_number, | 112 int line_number, |
| 118 const base::string16& error) { | 113 const base::string16& error) { |
| 119 } | 114 } |
| 120 | 115 |
| 121 net::NetworkDelegate::AuthRequiredResponse | 116 net::NetworkDelegate::AuthRequiredResponse |
| 122 ShellNetworkDelegate::OnAuthRequired( | 117 ShellNetworkDelegate::OnAuthRequired( |
| 123 net::URLRequest* request, | 118 net::URLRequest* request, |
| 124 const net::AuthChallengeInfo& auth_info, | 119 const net::AuthChallengeInfo& auth_info, |
| 125 const AuthCallback& callback, | 120 const AuthCallback& callback, |
| 126 net::AuthCredentials* credentials) { | 121 net::AuthCredentials* credentials) { |
| 127 return ExtensionWebRequestEventRouter::GetInstance()->OnAuthRequired( | 122 return ExtensionWebRequestEventRouter::GetInstance()->OnAuthRequired( |
| 128 browser_context_, extension_info_map_.get(), request, auth_info, callback, | 123 browser_context_, extension_info_map_.get(), request, auth_info, callback, |
| 129 credentials); | 124 credentials); |
| 130 } | 125 } |
| 131 | 126 |
| 132 } // namespace extensions | 127 } // namespace extensions |
| OLD | NEW |