Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(215)

Side by Side Diff: chrome/browser/net/chrome_url_request_context.cc

Issue 11669012: Convert ProtocolHandlerRegistry::Interceptor to a net::URLRequestJobFactory. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Address jhawkins' comments Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 "chrome/browser/net/chrome_url_request_context.h" 5 #include "chrome/browser/net/chrome_url_request_context.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/message_loop.h" 9 #include "base/message_loop.h"
10 #include "base/message_loop_proxy.h" 10 #include "base/message_loop_proxy.h"
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
61 return profile_io_data_->GetExtensionsRequestContext(); 61 return profile_io_data_->GetExtensionsRequestContext();
62 } 62 }
63 63
64 private: 64 private:
65 const ProfileIOData* const profile_io_data_; 65 const ProfileIOData* const profile_io_data_;
66 }; 66 };
67 67
68 // Factory that creates the ChromeURLRequestContext for a given isolated app. 68 // Factory that creates the ChromeURLRequestContext for a given isolated app.
69 class FactoryForIsolatedApp : public ChromeURLRequestContextFactory { 69 class FactoryForIsolatedApp : public ChromeURLRequestContextFactory {
70 public: 70 public:
71 FactoryForIsolatedApp(const ProfileIOData* profile_io_data, 71 FactoryForIsolatedApp(
72 const StoragePartitionDescriptor& partition_descriptor, 72 const ProfileIOData* profile_io_data,
73 ChromeURLRequestContextGetter* main_context, 73 const StoragePartitionDescriptor& partition_descriptor,
74 scoped_ptr<net::URLRequestJobFactory::Interceptor> 74 ChromeURLRequestContextGetter* main_context,
75 protocol_handler_interceptor) 75 scoped_ptr<ProtocolHandlerRegistry::JobInterceptorFactory>
76 protocol_handler_interceptor)
76 : profile_io_data_(profile_io_data), 77 : profile_io_data_(profile_io_data),
77 partition_descriptor_(partition_descriptor), 78 partition_descriptor_(partition_descriptor),
78 main_request_context_getter_(main_context), 79 main_request_context_getter_(main_context),
79 protocol_handler_interceptor_(protocol_handler_interceptor.Pass()) {} 80 protocol_handler_interceptor_(protocol_handler_interceptor.Pass()) {}
80 81
81 virtual ChromeURLRequestContext* Create() OVERRIDE { 82 virtual ChromeURLRequestContext* Create() OVERRIDE {
82 // We will copy most of the state from the main request context. 83 // We will copy most of the state from the main request context.
83 // 84 //
84 // Note that this factory is one-shot. After Create() is called once, the 85 // Note that this factory is one-shot. After Create() is called once, the
85 // factory is actually destroyed. Thus it is safe to destructively pass 86 // factory is actually destroyed. Thus it is safe to destructively pass
86 // state onwards. 87 // state onwards.
87 return profile_io_data_->GetIsolatedAppRequestContext( 88 return profile_io_data_->GetIsolatedAppRequestContext(
88 main_request_context_getter_->GetIOContext(), partition_descriptor_, 89 main_request_context_getter_->GetIOContext(), partition_descriptor_,
89 protocol_handler_interceptor_.Pass()); 90 protocol_handler_interceptor_.Pass());
90 } 91 }
91 92
92 private: 93 private:
93 const ProfileIOData* const profile_io_data_; 94 const ProfileIOData* const profile_io_data_;
94 const StoragePartitionDescriptor partition_descriptor_; 95 const StoragePartitionDescriptor partition_descriptor_;
95 scoped_refptr<ChromeURLRequestContextGetter> 96 scoped_refptr<ChromeURLRequestContextGetter>
96 main_request_context_getter_; 97 main_request_context_getter_;
97 scoped_ptr<net::URLRequestJobFactory::Interceptor> 98 scoped_ptr<ProtocolHandlerRegistry::JobInterceptorFactory>
98 protocol_handler_interceptor_; 99 protocol_handler_interceptor_;
99 }; 100 };
100 101
101 // Factory that creates the media ChromeURLRequestContext for a given isolated 102 // Factory that creates the media ChromeURLRequestContext for a given isolated
102 // app. The media context is based on the corresponding isolated app's context. 103 // app. The media context is based on the corresponding isolated app's context.
103 class FactoryForIsolatedMedia : public ChromeURLRequestContextFactory { 104 class FactoryForIsolatedMedia : public ChromeURLRequestContextFactory {
104 public: 105 public:
105 FactoryForIsolatedMedia( 106 FactoryForIsolatedMedia(
106 const ProfileIOData* profile_io_data, 107 const ProfileIOData* profile_io_data,
107 const StoragePartitionDescriptor& partition_descriptor, 108 const StoragePartitionDescriptor& partition_descriptor,
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after
204 return new ChromeURLRequestContextGetter( 205 return new ChromeURLRequestContextGetter(
205 new FactoryForExtensions(profile_io_data)); 206 new FactoryForExtensions(profile_io_data));
206 } 207 }
207 208
208 // static 209 // static
209 ChromeURLRequestContextGetter* 210 ChromeURLRequestContextGetter*
210 ChromeURLRequestContextGetter::CreateOriginalForIsolatedApp( 211 ChromeURLRequestContextGetter::CreateOriginalForIsolatedApp(
211 Profile* profile, 212 Profile* profile,
212 const ProfileIOData* profile_io_data, 213 const ProfileIOData* profile_io_data,
213 const StoragePartitionDescriptor& partition_descriptor, 214 const StoragePartitionDescriptor& partition_descriptor,
214 scoped_ptr<net::URLRequestJobFactory::Interceptor> 215 scoped_ptr<ProtocolHandlerRegistry::JobInterceptorFactory>
215 protocol_handler_interceptor) { 216 protocol_handler_interceptor) {
216 DCHECK(!profile->IsOffTheRecord()); 217 DCHECK(!profile->IsOffTheRecord());
217 ChromeURLRequestContextGetter* main_context = 218 ChromeURLRequestContextGetter* main_context =
218 static_cast<ChromeURLRequestContextGetter*>(profile->GetRequestContext()); 219 static_cast<ChromeURLRequestContextGetter*>(profile->GetRequestContext());
219 return new ChromeURLRequestContextGetter( 220 return new ChromeURLRequestContextGetter(
220 new FactoryForIsolatedApp(profile_io_data, partition_descriptor, 221 new FactoryForIsolatedApp(profile_io_data, partition_descriptor,
221 main_context, protocol_handler_interceptor.Pass())); 222 main_context, protocol_handler_interceptor.Pass()));
222 } 223 }
223 224
224 // static 225 // static
(...skipping 26 matching lines...) Expand all
251 return new ChromeURLRequestContextGetter( 252 return new ChromeURLRequestContextGetter(
252 new FactoryForExtensions(profile_io_data)); 253 new FactoryForExtensions(profile_io_data));
253 } 254 }
254 255
255 // static 256 // static
256 ChromeURLRequestContextGetter* 257 ChromeURLRequestContextGetter*
257 ChromeURLRequestContextGetter::CreateOffTheRecordForIsolatedApp( 258 ChromeURLRequestContextGetter::CreateOffTheRecordForIsolatedApp(
258 Profile* profile, 259 Profile* profile,
259 const ProfileIOData* profile_io_data, 260 const ProfileIOData* profile_io_data,
260 const StoragePartitionDescriptor& partition_descriptor, 261 const StoragePartitionDescriptor& partition_descriptor,
261 scoped_ptr<net::URLRequestJobFactory::Interceptor> 262 scoped_ptr<ProtocolHandlerRegistry::JobInterceptorFactory>
262 protocol_handler_interceptor) { 263 protocol_handler_interceptor) {
263 DCHECK(profile->IsOffTheRecord()); 264 DCHECK(profile->IsOffTheRecord());
264 ChromeURLRequestContextGetter* main_context = 265 ChromeURLRequestContextGetter* main_context =
265 static_cast<ChromeURLRequestContextGetter*>(profile->GetRequestContext()); 266 static_cast<ChromeURLRequestContextGetter*>(profile->GetRequestContext());
266 return new ChromeURLRequestContextGetter( 267 return new ChromeURLRequestContextGetter(
267 new FactoryForIsolatedApp(profile_io_data, partition_descriptor, 268 new FactoryForIsolatedApp(profile_io_data, partition_descriptor,
268 main_context, protocol_handler_interceptor.Pass())); 269 main_context, protocol_handler_interceptor.Pass()));
269 } 270 }
270 271
271 // ---------------------------------------------------------------------------- 272 // ----------------------------------------------------------------------------
(...skipping 29 matching lines...) Expand all
301 ChromeURLDataManagerBackend* 302 ChromeURLDataManagerBackend*
302 ChromeURLRequestContext::chrome_url_data_manager_backend() const { 303 ChromeURLRequestContext::chrome_url_data_manager_backend() const {
303 return chrome_url_data_manager_backend_; 304 return chrome_url_data_manager_backend_;
304 } 305 }
305 306
306 void ChromeURLRequestContext::set_chrome_url_data_manager_backend( 307 void ChromeURLRequestContext::set_chrome_url_data_manager_backend(
307 ChromeURLDataManagerBackend* backend) { 308 ChromeURLDataManagerBackend* backend) {
308 DCHECK(backend); 309 DCHECK(backend);
309 chrome_url_data_manager_backend_ = backend; 310 chrome_url_data_manager_backend_ = backend;
310 } 311 }
OLDNEW
« no previous file with comments | « chrome/browser/net/chrome_url_request_context.h ('k') | chrome/browser/profiles/off_the_record_profile_io_data.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698