diff options
author | Pierre Rossi <pierre.rossi@digia.com> | 2013-06-10 19:33:44 +0200 |
---|---|---|
committer | Pierre Rossi <pierre.rossi@digia.com> | 2013-06-10 19:33:44 +0200 |
commit | 6555874455eb23722974b06b388c3cbde0a24f95 (patch) | |
tree | a8d3a3de82ba8c151e8667bec426cc6d21004554 /lib/url_request_context_getter_qt.cpp | |
parent | d50a091095f49032587fef97034ba1210a1a8f0f (diff) |
And shell is out !
Introduce a few more bits of our own very basic implementations
(URLRequestContextGetter and NetworkDelegate subclasses).
Still need to figure out the appropriate dependancies in blinq.gypi
Diffstat (limited to 'lib/url_request_context_getter_qt.cpp')
-rw-r--r-- | lib/url_request_context_getter_qt.cpp | 156 |
1 files changed, 156 insertions, 0 deletions
diff --git a/lib/url_request_context_getter_qt.cpp b/lib/url_request_context_getter_qt.cpp new file mode 100644 index 000000000..1b523697d --- /dev/null +++ b/lib/url_request_context_getter_qt.cpp @@ -0,0 +1,156 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the QtWebEngine module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include "url_request_context_getter_qt.h" + +#include "base/string_util.h" +#include "base/threading/worker_pool.h" +#include "content/public/browser/browser_thread.h" +#include "net/base/cache_type.h" +#include "net/cert/cert_verifier.h" +#include "net/cookies/cookie_monster.h" +#include "net/dns/host_resolver.h" +#include "net/dns/mapped_host_resolver.h" +#include "net/http/http_auth_handler_factory.h" +#include "net/http/http_cache.h" +#include "net/http/http_network_session.h" +#include "net/http/http_server_properties_impl.h" +#include "net/proxy/proxy_service.h" +#include "net/ssl/default_server_bound_cert_store.h" +#include "net/ssl/server_bound_cert_service.h" +#include "net/ssl/ssl_config_service_defaults.h" +#include "net/url_request/static_http_user_agent_settings.h" +#include "net/url_request/url_request_context.h" + +#include "network_delegate_qt.h" + +using content::BrowserThread; + +URLRequestContextGetterQt::URLRequestContextGetterQt(const base::FilePath &basePath) + : m_ignoreCertificateErrors(false) + , m_basePath(basePath) +{ + + // We must create the proxy config service on the UI loop on Linux because it + // must synchronously run on the glib message loop. This will be passed to + // the URLRequestContextStorage on the IO thread in GetURLRequestContext(). +//#ifdef Q_OS_LINUX + m_proxyConfigService.reset(net::ProxyService::CreateSystemProxyConfigService(BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::IO)->message_loop_proxy() + , BrowserThread::UnsafeGetMessageLoopForThread(BrowserThread::FILE))); +//#endif +} + +net::URLRequestContext *URLRequestContextGetterQt::GetURLRequestContext() +{ + if (!m_urlRequestContext) { + + m_urlRequestContext.reset(new net::URLRequestContext()); + m_networkDelegate.reset(new NetworkDelegateQt); + + m_urlRequestContext->set_network_delegate(m_networkDelegate.get()); + m_storage.reset(new net::URLRequestContextStorage(m_urlRequestContext.get())); + m_storage->set_cookie_store(new net::CookieMonster(NULL, NULL)); + m_storage->set_server_bound_cert_service(new net::ServerBoundCertService( + new net::DefaultServerBoundCertStore(NULL), + base::WorkerPool::GetTaskRunner(true))); + m_storage->set_http_user_agent_settings( + new net::StaticHttpUserAgentSettings("en-us,en", EmptyString())); + + scoped_ptr<net::HostResolver> host_resolver( + net::HostResolver::CreateDefaultResolver(NULL)); + + m_storage->set_cert_verifier(net::CertVerifier::CreateDefault()); + + m_storage->set_proxy_service(net::ProxyService::CreateUsingSystemProxyResolver(m_proxyConfigService.release(), 0, NULL)); + + m_storage->set_ssl_config_service(new net::SSLConfigServiceDefaults); + m_storage->set_http_auth_handler_factory( + net::HttpAuthHandlerFactory::CreateDefault(host_resolver.get())); + m_storage->set_http_server_properties(new net::HttpServerPropertiesImpl); + + base::FilePath cache_path = m_basePath.Append(FILE_PATH_LITERAL("Cache")); + net::HttpCache::DefaultBackend* main_backend = + new net::HttpCache::DefaultBackend( + net::DISK_CACHE, + net::CACHE_BACKEND_DEFAULT, + cache_path, + 0, + BrowserThread::GetMessageLoopProxyForThread( + BrowserThread::CACHE)); + + net::HttpNetworkSession::Params network_session_params; + network_session_params.cert_verifier = + m_urlRequestContext->cert_verifier(); + network_session_params.server_bound_cert_service = + m_urlRequestContext->server_bound_cert_service(); + network_session_params.proxy_service = + m_urlRequestContext->proxy_service(); + network_session_params.ssl_config_service = + m_urlRequestContext->ssl_config_service(); + network_session_params.http_auth_handler_factory = + m_urlRequestContext->http_auth_handler_factory(); + network_session_params.network_delegate = + m_networkDelegate.get(); + network_session_params.http_server_properties = + m_urlRequestContext->http_server_properties(); + network_session_params.ignore_certificate_errors = + m_ignoreCertificateErrors; + + // Give |m_storage| ownership at the end in case it's |mapped_host_resolver|. + m_storage->set_host_resolver(host_resolver.Pass()); + network_session_params.host_resolver = + m_urlRequestContext->host_resolver(); + + net::HttpCache* main_cache = new net::HttpCache( + network_session_params, main_backend); + m_storage->set_http_transaction_factory(main_cache); + + // FIXME: add protocol handling + } + + return m_urlRequestContext.get(); +} + + +scoped_refptr<base::SingleThreadTaskRunner> URLRequestContextGetterQt::GetNetworkTaskRunner() const +{ + return content::BrowserThread::GetMessageLoopProxyForThread(content::BrowserThread::IO); +} |