mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-20 05:38:03 +01:00
ca0e381681
- CefRequestContext instances can be configured using a new CefRequestContextSettings structure passed to CefRequestContext::CreateContext. - Scheme registration is now per-request-context using new CefRequestContext::RegisterSchemeHandlerFactory and ClearSchemeHandlerFactories methods. - Cookie managers are now per-request-context by default and can be retrieved using a new CefRequestContext::GetDefaultCookieManager method. - CefURLRequest::Create now accepts an optional CefRequestContext argument for associating a URL request with a context (browser process only). - The CefRequestContextHandler associated with a CefRequestContext will not be released until all objects related to that context have been destroyed. - When the cache path is empty an in-memory cache ("incognito mode") will be used for storage and no data will be persisted to disk. - Add CefSettings.user_data_path which specifies the location where user data such as spell checking dictionary files will be stored on disk. - Add asynchronous callbacks for all CefCookieManager methods. - Add PK_LOCAL_APP_DATA and PK_USER_DATA path keys for retrieving user directories via CefGetPath. - cefclient: Add "New Window" test that creates a new window unrelated to existing windows. When used in combination with `--request-context-per-browser` the new window will be given a new and isolated request context. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@2040 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
89 lines
3.3 KiB
C++
89 lines
3.3 KiB
C++
// Copyright (c) 2013 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
// can be found in the LICENSE file.
|
|
|
|
#include "libcef/browser/scheme_handler.h"
|
|
|
|
#include <string>
|
|
|
|
#include "libcef/browser/chrome_scheme_handler.h"
|
|
#include "libcef/browser/devtools_scheme_handler.h"
|
|
#include "libcef/common/scheme_registration.h"
|
|
|
|
#include "base/threading/sequenced_worker_pool.h"
|
|
#include "content/public/browser/browser_thread.h"
|
|
#include "content/public/common/url_constants.h"
|
|
#include "net/url_request/data_protocol_handler.h"
|
|
#include "net/url_request/file_protocol_handler.h"
|
|
#include "net/url_request/ftp_protocol_handler.h"
|
|
#include "net/url_request/url_request_job_factory_impl.h"
|
|
#include "url/url_constants.h"
|
|
|
|
namespace scheme {
|
|
|
|
void InstallInternalProtectedHandlers(
|
|
net::URLRequestJobFactoryImpl* job_factory,
|
|
CefURLRequestManager* request_manager,
|
|
content::ProtocolHandlerMap* protocol_handlers,
|
|
net::FtpTransactionFactory* ftp_transaction_factory) {
|
|
protocol_handlers->insert(
|
|
std::make_pair(url::kDataScheme,
|
|
linked_ptr<net::URLRequestJobFactory::ProtocolHandler>(
|
|
new net::DataProtocolHandler)));
|
|
protocol_handlers->insert(
|
|
std::make_pair(url::kFileScheme,
|
|
linked_ptr<net::URLRequestJobFactory::ProtocolHandler>(
|
|
new net::FileProtocolHandler(
|
|
content::BrowserThread::GetBlockingPool()->
|
|
GetTaskRunnerWithShutdownBehavior(
|
|
base::SequencedWorkerPool::SKIP_ON_SHUTDOWN)))));
|
|
#if !defined(DISABLE_FTP_SUPPORT)
|
|
protocol_handlers->insert(
|
|
std::make_pair(url::kFtpScheme,
|
|
linked_ptr<net::URLRequestJobFactory::ProtocolHandler>(
|
|
new net::FtpProtocolHandler(ftp_transaction_factory))));
|
|
#endif
|
|
|
|
for (content::ProtocolHandlerMap::iterator it =
|
|
protocol_handlers->begin();
|
|
it != protocol_handlers->end();
|
|
++it) {
|
|
const std::string& scheme = it->first;
|
|
scoped_ptr<net::URLRequestJobFactory::ProtocolHandler> protocol_handler;
|
|
|
|
if (scheme == content::kChromeDevToolsScheme) {
|
|
// Don't use the default "chrome-devtools" handler.
|
|
continue;
|
|
} else if (scheme == content::kChromeUIScheme) {
|
|
// Filter the URLs that are passed to the default "chrome" handler so as
|
|
// not to interfere with CEF's "chrome" handler.
|
|
protocol_handler.reset(
|
|
scheme::WrapChromeProtocolHandler(
|
|
request_manager,
|
|
make_scoped_ptr(it->second.release())).release());
|
|
} else {
|
|
protocol_handler.reset(it->second.release());
|
|
}
|
|
|
|
// Make sure IsInternalProtectedScheme() stays synchronized with what
|
|
// Chromium is actually giving us.
|
|
DCHECK(IsInternalProtectedScheme(scheme));
|
|
|
|
bool set_protocol = job_factory->SetProtocolHandler(
|
|
scheme, protocol_handler.release());
|
|
DCHECK(set_protocol);
|
|
}
|
|
}
|
|
|
|
void RegisterInternalHandlers(CefURLRequestManager* request_manager) {
|
|
scheme::RegisterChromeHandler(request_manager);
|
|
scheme::RegisterChromeDevToolsHandler(request_manager);
|
|
}
|
|
|
|
void DidFinishLoad(CefRefPtr<CefFrame> frame, const GURL& validated_url) {
|
|
if (validated_url.scheme() == content::kChromeUIScheme)
|
|
scheme::DidFinishChromeLoad(frame, validated_url);
|
|
}
|
|
|
|
} // namespace scheme
|