Give user a chance to create custom URLRequestJobFactory.
This commit is contained in:
parent
d01aa51686
commit
2d03c983e4
4 changed files with 34 additions and 0 deletions
|
@ -20,6 +20,7 @@
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "content/public/browser/resource_context.h"
|
#include "content/public/browser/resource_context.h"
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
|
#include "net/url_request/url_request_job_factory_impl.h"
|
||||||
|
|
||||||
#if defined(OS_LINUX)
|
#if defined(OS_LINUX)
|
||||||
#include "base/nix/xdg_util.h"
|
#include "base/nix/xdg_util.h"
|
||||||
|
@ -109,6 +110,7 @@ net::URLRequestContextGetter* BrowserContext::CreateRequestContext(
|
||||||
BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::IO),
|
BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::IO),
|
||||||
BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::FILE),
|
BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::FILE),
|
||||||
base::Bind(&BrowserContext::CreateNetworkDelegate, base::Unretained(this)),
|
base::Bind(&BrowserContext::CreateNetworkDelegate, base::Unretained(this)),
|
||||||
|
base::Bind(&BrowserContext::CreateURLRequestJobFactory, base::Unretained(this)),
|
||||||
protocol_handlers,
|
protocol_handlers,
|
||||||
protocol_interceptors.Pass());
|
protocol_interceptors.Pass());
|
||||||
resource_context_->set_url_request_context_getter(url_request_getter_.get());
|
resource_context_->set_url_request_context_getter(url_request_getter_.get());
|
||||||
|
@ -119,6 +121,12 @@ scoped_ptr<NetworkDelegate> BrowserContext::CreateNetworkDelegate() {
|
||||||
return make_scoped_ptr(new NetworkDelegate).Pass();
|
return make_scoped_ptr(new NetworkDelegate).Pass();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scoped_ptr<net::URLRequestJobFactory> BrowserContext::CreateURLRequestJobFactory(
|
||||||
|
const content::ProtocolHandlerMap& protocol_handlers,
|
||||||
|
const content::ProtocolHandlerScopedVector& protocol_interceptors) {
|
||||||
|
return scoped_ptr<net::URLRequestJobFactory>();
|
||||||
|
}
|
||||||
|
|
||||||
base::FilePath BrowserContext::GetPath() const {
|
base::FilePath BrowserContext::GetPath() const {
|
||||||
return path_;
|
return path_;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,10 @@
|
||||||
class PrefRegistrySimple;
|
class PrefRegistrySimple;
|
||||||
class PrefService;
|
class PrefService;
|
||||||
|
|
||||||
|
namespace browser_context {
|
||||||
|
class URLRequestJobFactory;
|
||||||
|
}
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
||||||
class DownloadManagerDelegate;
|
class DownloadManagerDelegate;
|
||||||
|
@ -38,6 +42,12 @@ class BrowserContext : public content::BrowserContext {
|
||||||
// implementation.
|
// implementation.
|
||||||
virtual scoped_ptr<NetworkDelegate> CreateNetworkDelegate();
|
virtual scoped_ptr<NetworkDelegate> CreateNetworkDelegate();
|
||||||
|
|
||||||
|
// Subclasses should override this to provide a custom URLRequestJobFactory
|
||||||
|
// implementation.
|
||||||
|
virtual scoped_ptr<net::URLRequestJobFactory> CreateURLRequestJobFactory(
|
||||||
|
const content::ProtocolHandlerMap& protocol_handlers,
|
||||||
|
const content::ProtocolHandlerScopedVector& protocol_interceptors);
|
||||||
|
|
||||||
virtual base::FilePath GetPath() const OVERRIDE;
|
virtual base::FilePath GetPath() const OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -45,12 +45,14 @@ URLRequestContextGetter::URLRequestContextGetter(
|
||||||
base::MessageLoop* io_loop,
|
base::MessageLoop* io_loop,
|
||||||
base::MessageLoop* file_loop,
|
base::MessageLoop* file_loop,
|
||||||
base::Callback<scoped_ptr<NetworkDelegate>(void)> network_delegate_factory,
|
base::Callback<scoped_ptr<NetworkDelegate>(void)> network_delegate_factory,
|
||||||
|
URLRequestJobFactoryFactory job_factory_factory,
|
||||||
content::ProtocolHandlerMap* protocol_handlers,
|
content::ProtocolHandlerMap* protocol_handlers,
|
||||||
content::ProtocolHandlerScopedVector protocol_interceptors)
|
content::ProtocolHandlerScopedVector protocol_interceptors)
|
||||||
: base_path_(base_path),
|
: base_path_(base_path),
|
||||||
io_loop_(io_loop),
|
io_loop_(io_loop),
|
||||||
file_loop_(file_loop),
|
file_loop_(file_loop),
|
||||||
network_delegate_factory_(network_delegate_factory),
|
network_delegate_factory_(network_delegate_factory),
|
||||||
|
job_factory_factory_(job_factory_factory),
|
||||||
protocol_interceptors_(protocol_interceptors.Pass()) {
|
protocol_interceptors_(protocol_interceptors.Pass()) {
|
||||||
// Must first be created on the UI thread.
|
// Must first be created on the UI thread.
|
||||||
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
|
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
|
||||||
|
@ -149,6 +151,14 @@ net::URLRequestContext* URLRequestContextGetter::GetURLRequestContext() {
|
||||||
network_session_params, main_backend);
|
network_session_params, main_backend);
|
||||||
storage_->set_http_transaction_factory(main_cache);
|
storage_->set_http_transaction_factory(main_cache);
|
||||||
|
|
||||||
|
// Give user a chance to create their own job factory.
|
||||||
|
scoped_ptr<net::URLRequestJobFactory> user_job_factory(
|
||||||
|
job_factory_factory_.Run(protocol_handlers_, protocol_interceptors_));
|
||||||
|
if (user_job_factory) {
|
||||||
|
storage_->set_job_factory(user_job_factory.release());
|
||||||
|
return url_request_context_.get();
|
||||||
|
}
|
||||||
|
|
||||||
scoped_ptr<net::URLRequestJobFactoryImpl> job_factory(
|
scoped_ptr<net::URLRequestJobFactoryImpl> job_factory(
|
||||||
new net::URLRequestJobFactoryImpl());
|
new net::URLRequestJobFactoryImpl());
|
||||||
for (auto it = protocol_handlers_.begin(),
|
for (auto it = protocol_handlers_.begin(),
|
||||||
|
|
|
@ -25,6 +25,10 @@ namespace brightray {
|
||||||
|
|
||||||
class NetworkDelegate;
|
class NetworkDelegate;
|
||||||
|
|
||||||
|
typedef base::Callback<scoped_ptr<net::URLRequestJobFactory>(
|
||||||
|
const content::ProtocolHandlerMap& protocol_handlers,
|
||||||
|
const content::ProtocolHandlerScopedVector& protocol_interceptors)> URLRequestJobFactoryFactory;
|
||||||
|
|
||||||
class URLRequestContextGetter : public net::URLRequestContextGetter {
|
class URLRequestContextGetter : public net::URLRequestContextGetter {
|
||||||
public:
|
public:
|
||||||
URLRequestContextGetter(
|
URLRequestContextGetter(
|
||||||
|
@ -32,6 +36,7 @@ class URLRequestContextGetter : public net::URLRequestContextGetter {
|
||||||
base::MessageLoop* io_loop,
|
base::MessageLoop* io_loop,
|
||||||
base::MessageLoop* file_loop,
|
base::MessageLoop* file_loop,
|
||||||
base::Callback<scoped_ptr<NetworkDelegate>(void)>,
|
base::Callback<scoped_ptr<NetworkDelegate>(void)>,
|
||||||
|
URLRequestJobFactoryFactory job_factory_factory,
|
||||||
content::ProtocolHandlerMap* protocol_handlers,
|
content::ProtocolHandlerMap* protocol_handlers,
|
||||||
content::ProtocolHandlerScopedVector protocol_interceptors);
|
content::ProtocolHandlerScopedVector protocol_interceptors);
|
||||||
virtual ~URLRequestContextGetter();
|
virtual ~URLRequestContextGetter();
|
||||||
|
@ -48,6 +53,7 @@ class URLRequestContextGetter : public net::URLRequestContextGetter {
|
||||||
base::MessageLoop* file_loop_;
|
base::MessageLoop* file_loop_;
|
||||||
|
|
||||||
base::Callback<scoped_ptr<NetworkDelegate>(void)> network_delegate_factory_;
|
base::Callback<scoped_ptr<NetworkDelegate>(void)> network_delegate_factory_;
|
||||||
|
URLRequestJobFactoryFactory job_factory_factory_;
|
||||||
|
|
||||||
scoped_ptr<net::ProxyConfigService> proxy_config_service_;
|
scoped_ptr<net::ProxyConfigService> proxy_config_service_;
|
||||||
scoped_ptr<NetworkDelegate> network_delegate_;
|
scoped_ptr<NetworkDelegate> network_delegate_;
|
||||||
|
|
Loading…
Reference in a new issue