OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/net/chrome_network_delegate.h" | 5 #include "chrome/browser/net/chrome_network_delegate.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" | 8 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" |
9 #include "chrome/browser/extensions/extension_event_router_forwarder.h" | 9 #include "chrome/browser/extensions/extension_event_router_forwarder.h" |
10 #include "chrome/browser/extensions/extension_proxy_api.h" | 10 #include "chrome/browser/extensions/extension_proxy_api.h" |
11 #include "chrome/browser/extensions/extension_webrequest_api.h" | 11 #include "chrome/browser/extensions/extension_webrequest_api.h" |
12 #include "chrome/browser/prefs/pref_member.h" | |
13 #include "chrome/common/pref_names.h" | |
12 #include "net/base/net_errors.h" | 14 #include "net/base/net_errors.h" |
13 #include "net/http/http_request_headers.h" | 15 #include "net/http/http_request_headers.h" |
14 #include "net/url_request/url_request.h" | 16 #include "net/url_request/url_request.h" |
15 | 17 |
16 namespace { | 18 namespace { |
17 | 19 |
18 // If the |request| failed due to problems with a proxy, forward the error to | 20 // If the |request| failed due to problems with a proxy, forward the error to |
19 // the proxy extension API. | 21 // the proxy extension API. |
20 void ForwardProxyErrors(net::URLRequest* request, | 22 void ForwardProxyErrors(net::URLRequest* request, |
21 ExtensionEventRouterForwarder* event_router, | 23 ExtensionEventRouterForwarder* event_router, |
22 ProfileId profile_id) { | 24 ProfileId profile_id) { |
23 if (request->status().status() == net::URLRequestStatus::FAILED) { | 25 if (request->status().status() == net::URLRequestStatus::FAILED) { |
24 switch (request->status().os_error()) { | 26 switch (request->status().os_error()) { |
25 case net::ERR_PROXY_AUTH_UNSUPPORTED: | 27 case net::ERR_PROXY_AUTH_UNSUPPORTED: |
26 case net::ERR_PROXY_CONNECTION_FAILED: | 28 case net::ERR_PROXY_CONNECTION_FAILED: |
27 case net::ERR_TUNNEL_CONNECTION_FAILED: | 29 case net::ERR_TUNNEL_CONNECTION_FAILED: |
28 ExtensionProxyEventRouter::GetInstance()->OnProxyError( | 30 ExtensionProxyEventRouter::GetInstance()->OnProxyError( |
29 event_router, profile_id, request->status().os_error()); | 31 event_router, profile_id, request->status().os_error()); |
30 } | 32 } |
31 } | 33 } |
32 } | 34 } |
33 | 35 |
34 } // namespace | 36 } // namespace |
35 | 37 |
36 ChromeNetworkDelegate::ChromeNetworkDelegate( | 38 ChromeNetworkDelegate::ChromeNetworkDelegate( |
37 ExtensionEventRouterForwarder* event_router, | 39 ExtensionEventRouterForwarder* event_router, |
38 ProfileId profile_id, | 40 ProfileId profile_id, |
41 BooleanPrefMember* enable_referrers, | |
39 ProtocolHandlerRegistry* protocol_handler_registry) | 42 ProtocolHandlerRegistry* protocol_handler_registry) |
40 : event_router_(event_router), | 43 : event_router_(event_router), |
41 profile_id_(profile_id), | 44 profile_id_(profile_id), |
45 enable_referrers_(enable_referrers), | |
42 protocol_handler_registry_(protocol_handler_registry) { | 46 protocol_handler_registry_(protocol_handler_registry) { |
43 DCHECK(event_router); | 47 DCHECK(event_router); |
48 DCHECK(enable_referrers); | |
44 } | 49 } |
45 | 50 |
46 ChromeNetworkDelegate::~ChromeNetworkDelegate() {} | 51 ChromeNetworkDelegate::~ChromeNetworkDelegate() {} |
47 | 52 |
53 // static | |
54 void ChromeNetworkDelegate::InitializeReferrersEnabled( | |
55 BooleanPrefMember* enable_referrers, | |
56 PrefService* pref_service) { | |
57 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
willchan no longer on Chromium
2011/04/13 14:59:00
Please include browser_thread.h for this.
Bernhard Bauer
2011/04/13 15:14:50
Done.
| |
58 enable_referrers->Init(prefs::kEnableReferrers, pref_service, NULL); | |
59 enable_referrers->MoveToThread(BrowserThread::IO); | |
60 } | |
61 | |
48 int ChromeNetworkDelegate::OnBeforeURLRequest( | 62 int ChromeNetworkDelegate::OnBeforeURLRequest( |
49 net::URLRequest* request, net::CompletionCallback* callback) { | 63 net::URLRequest* request, net::CompletionCallback* callback) { |
64 if (!enable_referrers_->GetValue()) | |
65 request->set_referrer(std::string()); | |
50 return ExtensionWebRequestEventRouter::GetInstance()->OnBeforeRequest( | 66 return ExtensionWebRequestEventRouter::GetInstance()->OnBeforeRequest( |
51 profile_id_, event_router_.get(), request, callback); | 67 profile_id_, event_router_.get(), request, callback); |
52 } | 68 } |
53 | 69 |
54 int ChromeNetworkDelegate::OnBeforeSendHeaders( | 70 int ChromeNetworkDelegate::OnBeforeSendHeaders( |
55 uint64 request_id, | 71 uint64 request_id, |
56 net::HttpRequestHeaders* headers, | 72 net::HttpRequestHeaders* headers, |
57 net::CompletionCallback* callback) { | 73 net::CompletionCallback* callback) { |
58 return ExtensionWebRequestEventRouter::GetInstance()->OnBeforeSendHeaders( | 74 return ExtensionWebRequestEventRouter::GetInstance()->OnBeforeSendHeaders( |
59 profile_id_, event_router_.get(), request_id, headers, callback); | 75 profile_id_, event_router_.get(), request_id, headers, callback); |
(...skipping 12 matching lines...) Expand all Loading... | |
72 ExtensionWebRequestEventRouter::GetInstance()->OnURLRequestDestroyed( | 88 ExtensionWebRequestEventRouter::GetInstance()->OnURLRequestDestroyed( |
73 profile_id_, request); | 89 profile_id_, request); |
74 } | 90 } |
75 | 91 |
76 net::URLRequestJob* ChromeNetworkDelegate::OnMaybeCreateURLRequestJob( | 92 net::URLRequestJob* ChromeNetworkDelegate::OnMaybeCreateURLRequestJob( |
77 net::URLRequest* request) { | 93 net::URLRequest* request) { |
78 if (!protocol_handler_registry_) | 94 if (!protocol_handler_registry_) |
79 return NULL; | 95 return NULL; |
80 return protocol_handler_registry_->MaybeCreateJob(request); | 96 return protocol_handler_registry_->MaybeCreateJob(request); |
81 } | 97 } |
OLD | NEW |