OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 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 "android_webview/browser/net/aw_url_request_context_getter.h" | 5 #include "android_webview/browser/net/aw_url_request_context_getter.h" |
6 | 6 |
7 #include <vector> | |
8 | |
7 #include "android_webview/browser/aw_browser_context.h" | 9 #include "android_webview/browser/aw_browser_context.h" |
8 #include "android_webview/browser/aw_request_interceptor.h" | 10 #include "android_webview/browser/aw_request_interceptor.h" |
9 #include "android_webview/browser/net/aw_network_delegate.h" | 11 #include "android_webview/browser/net/aw_network_delegate.h" |
10 #include "android_webview/browser/net/aw_url_request_job_factory.h" | 12 #include "android_webview/browser/net/aw_url_request_job_factory.h" |
11 #include "android_webview/browser/net/init_native_callback.h" | 13 #include "android_webview/browser/net/init_native_callback.h" |
12 #include "content/public/browser/browser_thread.h" | 14 #include "content/public/browser/browser_thread.h" |
13 #include "content/public/browser/content_browser_client.h" | 15 #include "content/public/browser/content_browser_client.h" |
14 #include "content/public/common/content_client.h" | 16 #include "content/public/common/content_client.h" |
15 #include "content/public/common/url_constants.h" | 17 #include "content/public/common/url_constants.h" |
16 #include "net/http/http_cache.h" | 18 #include "net/http/http_cache.h" |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
65 PopulateNetworkSessionParams(&network_session_params); | 67 PopulateNetworkSessionParams(&network_session_params); |
66 net::HttpCache* main_cache = new net::HttpCache( | 68 net::HttpCache* main_cache = new net::HttpCache( |
67 network_session_params, | 69 network_session_params, |
68 new net::HttpCache::DefaultBackend( | 70 new net::HttpCache::DefaultBackend( |
69 net::DISK_CACHE, | 71 net::DISK_CACHE, |
70 browser_context_->GetPath().Append(FILE_PATH_LITERAL("Cache")), | 72 browser_context_->GetPath().Append(FILE_PATH_LITERAL("Cache")), |
71 10 * 1024 * 1024, // 10M | 73 10 * 1024 * 1024, // 10M |
72 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE))); | 74 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::CACHE))); |
73 main_http_factory_.reset(main_cache); | 75 main_http_factory_.reset(main_cache); |
74 url_request_context_->set_http_transaction_factory(main_cache); | 76 url_request_context_->set_http_transaction_factory(main_cache); |
77 | |
78 CreateCookieMonster(url_request_context_.get()); | |
boliu
2013/03/01 18:44:11
This bit is already fixed in https://codereview.ch
mkosiba (inactive)
2013/03/05 16:34:43
Ok, looks like I need to rebase.
| |
75 } | 79 } |
76 | 80 |
77 void AwURLRequestContextGetter::PopulateNetworkSessionParams( | 81 void AwURLRequestContextGetter::PopulateNetworkSessionParams( |
78 net::HttpNetworkSession::Params* params) { | 82 net::HttpNetworkSession::Params* params) { |
79 net::URLRequestContext* context = url_request_context_.get(); | 83 net::URLRequestContext* context = url_request_context_.get(); |
80 params->host_resolver = context->host_resolver(); | 84 params->host_resolver = context->host_resolver(); |
81 params->cert_verifier = context->cert_verifier(); | 85 params->cert_verifier = context->cert_verifier(); |
82 params->server_bound_cert_service = context->server_bound_cert_service(); | 86 params->server_bound_cert_service = context->server_bound_cert_service(); |
83 params->transport_security_state = context->transport_security_state(); | 87 params->transport_security_state = context->transport_security_state(); |
84 params->proxy_service = context->proxy_service(); | 88 params->proxy_service = context->proxy_service(); |
85 params->ssl_config_service = context->ssl_config_service(); | 89 params->ssl_config_service = context->ssl_config_service(); |
86 params->http_auth_handler_factory = context->http_auth_handler_factory(); | 90 params->http_auth_handler_factory = context->http_auth_handler_factory(); |
87 params->network_delegate = context->network_delegate(); | 91 params->network_delegate = context->network_delegate(); |
88 params->http_server_properties = context->http_server_properties(); | 92 params->http_server_properties = context->http_server_properties(); |
89 params->net_log = context->net_log(); | 93 params->net_log = context->net_log(); |
90 } | 94 } |
91 | 95 |
96 namespace { | |
97 | |
98 typedef std::vector<net::URLRequestJobFactory::ProtocolHandler*> | |
99 ProtocolHandlerVector; | |
100 | |
101 scoped_ptr<net::URLRequestJobFactory> WrapFactoryWithProtocolHandlers( | |
102 scoped_ptr<net::URLRequestJobFactory> job_factory, | |
103 const ProtocolHandlerVector& protocol_handlers) { | |
104 // The chain of responsibility is constructed in reverse of the order in | |
105 // which we want the particular protocol handlers invoked. | |
106 for (ProtocolHandlerVector::const_reverse_iterator | |
107 i = protocol_handlers.rbegin(); | |
108 i != protocol_handlers.rend(); | |
109 ++i) { | |
110 job_factory.reset(new net::ProtocolInterceptJobFactory( | |
111 job_factory.Pass(), make_scoped_ptr(*i))); | |
112 } | |
113 return job_factory.Pass(); | |
114 } | |
115 | |
116 } // namespace | |
117 | |
92 net::URLRequestContext* AwURLRequestContextGetter::GetURLRequestContext() { | 118 net::URLRequestContext* AwURLRequestContextGetter::GetURLRequestContext() { |
93 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 119 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
94 if (!job_factory_) { | 120 if (!job_factory_) { |
95 scoped_ptr<AwURLRequestJobFactory> job_factory(new AwURLRequestJobFactory); | 121 scoped_ptr<AwURLRequestJobFactory> job_factory(new AwURLRequestJobFactory); |
96 bool set_protocol = job_factory->SetProtocolHandler( | 122 bool set_protocol = job_factory->SetProtocolHandler( |
97 chrome::kFileScheme, new net::FileProtocolHandler()); | 123 chrome::kFileScheme, new net::FileProtocolHandler()); |
98 DCHECK(set_protocol); | 124 DCHECK(set_protocol); |
99 set_protocol = job_factory->SetProtocolHandler( | 125 set_protocol = job_factory->SetProtocolHandler( |
100 chrome::kDataScheme, new net::DataProtocolHandler()); | 126 chrome::kDataScheme, new net::DataProtocolHandler()); |
101 DCHECK(set_protocol); | 127 DCHECK(set_protocol); |
102 DCHECK(blob_protocol_handler_); | 128 DCHECK(blob_protocol_handler_); |
103 set_protocol = job_factory->SetProtocolHandler( | 129 set_protocol = job_factory->SetProtocolHandler( |
104 chrome::kBlobScheme, blob_protocol_handler_.release()); | 130 chrome::kBlobScheme, blob_protocol_handler_.release()); |
105 DCHECK(set_protocol); | 131 DCHECK(set_protocol); |
106 DCHECK(file_system_protocol_handler_); | 132 DCHECK(file_system_protocol_handler_); |
107 set_protocol = job_factory->SetProtocolHandler( | 133 set_protocol = job_factory->SetProtocolHandler( |
108 chrome::kFileSystemScheme, file_system_protocol_handler_.release()); | 134 chrome::kFileSystemScheme, file_system_protocol_handler_.release()); |
109 DCHECK(set_protocol); | 135 DCHECK(set_protocol); |
110 DCHECK(chrome_protocol_handler_); | 136 DCHECK(chrome_protocol_handler_); |
111 set_protocol = job_factory->SetProtocolHandler( | 137 set_protocol = job_factory->SetProtocolHandler( |
112 chrome::kChromeUIScheme, chrome_protocol_handler_.release()); | 138 chrome::kChromeUIScheme, chrome_protocol_handler_.release()); |
113 DCHECK(set_protocol); | 139 DCHECK(set_protocol); |
114 DCHECK(chrome_devtools_protocol_handler_); | 140 DCHECK(chrome_devtools_protocol_handler_); |
115 set_protocol = job_factory->SetProtocolHandler( | 141 set_protocol = job_factory->SetProtocolHandler( |
116 chrome::kChromeDevToolsScheme, | 142 chrome::kChromeDevToolsScheme, |
117 chrome_devtools_protocol_handler_.release()); | 143 chrome_devtools_protocol_handler_.release()); |
118 DCHECK(set_protocol); | 144 DCHECK(set_protocol); |
119 // Create a chain of URLRequestJobFactories. Keep |job_factory_| pointed | 145 |
120 // at the beginning of the chain. | 146 // Create a chain of URLRequestJobFactories. |
121 job_factory_ = CreateAndroidJobFactoryAndCookieMonster( | 147 ProtocolHandlerVector protocol_handlers; |
122 url_request_context_.get(), job_factory.Pass()); | 148 |
123 job_factory_.reset(new net::ProtocolInterceptJobFactory( | 149 protocol_handlers.push_back( |
124 job_factory_.Pass(), | 150 CreateAndroidContentProtocolHandler().release()); |
125 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler>( | 151 protocol_handlers.push_back( |
126 new AwRequestInterceptor()))); | 152 CreateAndroidAssetFileProtocolHandler().release()); |
127 job_factory_.reset(new net::ProtocolInterceptJobFactory( | 153 protocol_handlers.push_back(developer_protocol_handler_.release()); |
128 job_factory_.Pass(), | 154 // The AwRequestInterceptor must come after the content and asset file job |
129 developer_protocol_handler_.Pass())); | 155 // factories. This for WebViewClassic compatibility where it was not |
156 // possible to intercept resource loads to resolvable content:// and | |
157 // file:// URIs. | |
158 // This is achieved by the Content and AssetFile jobs handling only | |
159 // resolvable URLRequests | |
160 protocol_handlers.push_back(new AwRequestInterceptor()); | |
161 job_factory_ = WrapFactoryWithProtocolHandlers( | |
162 job_factory.PassAs<net::URLRequestJobFactory>(), protocol_handlers); | |
163 | |
164 #if 0 | |
165 // Alternative approach: | |
boliu
2013/03/01 18:44:11
I like this alternative approach better, because i
mnaganov (inactive)
2013/03/04 09:53:44
But on the other hand, it's more consistent with t
boliu
2013/03/04 19:55:46
I don't feel very strongly about this. Seems too m
| |
166 job_factory_ = new net::ProtocolInterceptJobFactory( | |
167 job_factory.Pass(), | |
168 new FallbackProtocolHandler( | |
169 &protocol_handlers, | |
170 make_scoped_ptr(new AwRequestInterceptor())); | |
171 #endif | |
172 | |
130 url_request_context_->set_job_factory(job_factory_.get()); | 173 url_request_context_->set_job_factory(job_factory_.get()); |
131 } | 174 } |
175 | |
132 return url_request_context_.get(); | 176 return url_request_context_.get(); |
133 } | 177 } |
134 | 178 |
135 scoped_refptr<base::SingleThreadTaskRunner> | 179 scoped_refptr<base::SingleThreadTaskRunner> |
136 AwURLRequestContextGetter::GetNetworkTaskRunner() const { | 180 AwURLRequestContextGetter::GetNetworkTaskRunner() const { |
137 return BrowserThread::GetMessageLoopProxyForThread(BrowserThread::IO); | 181 return BrowserThread::GetMessageLoopProxyForThread(BrowserThread::IO); |
138 } | 182 } |
139 | 183 |
140 void AwURLRequestContextGetter::SetProtocolHandlers( | 184 void AwURLRequestContextGetter::SetProtocolHandlers( |
141 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> | 185 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> |
142 blob_protocol_handler, | 186 blob_protocol_handler, |
143 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> | 187 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> |
144 file_system_protocol_handler, | 188 file_system_protocol_handler, |
145 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> | 189 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> |
146 developer_protocol_handler, | 190 developer_protocol_handler, |
147 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> | 191 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> |
148 chrome_protocol_handler, | 192 chrome_protocol_handler, |
149 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> | 193 scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> |
150 chrome_devtools_protocol_handler) { | 194 chrome_devtools_protocol_handler) { |
151 blob_protocol_handler_ = blob_protocol_handler.Pass(); | 195 blob_protocol_handler_ = blob_protocol_handler.Pass(); |
152 file_system_protocol_handler_ = file_system_protocol_handler.Pass(); | 196 file_system_protocol_handler_ = file_system_protocol_handler.Pass(); |
153 developer_protocol_handler_ = developer_protocol_handler.Pass(); | 197 developer_protocol_handler_ = developer_protocol_handler.Pass(); |
154 chrome_protocol_handler_ = chrome_protocol_handler.Pass(); | 198 chrome_protocol_handler_ = chrome_protocol_handler.Pass(); |
155 chrome_devtools_protocol_handler_ = chrome_devtools_protocol_handler.Pass(); | 199 chrome_devtools_protocol_handler_ = chrome_devtools_protocol_handler.Pass(); |
156 } | 200 } |
157 | 201 |
158 } // namespace android_webview | 202 } // namespace android_webview |
OLD | NEW |