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
179 lines
4.9 KiB
C++
179 lines
4.9 KiB
C++
// Copyright (c) 2012 The Chromium Embedded Framework Authors.
|
|
// Portions copyright (c) 2012 The Chromium 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/internal_scheme_handler.h"
|
|
#include <string>
|
|
#include "libcef/common/content_client.h"
|
|
#include "base/strings/string_util.h"
|
|
#include "ui/base/resource/resource_bundle.h"
|
|
|
|
namespace scheme {
|
|
|
|
namespace {
|
|
|
|
static std::string GetMimeType(const std::string& filename) {
|
|
if (EndsWith(filename, ".html", false)) {
|
|
return "text/html";
|
|
} else if (EndsWith(filename, ".css", false)) {
|
|
return "text/css";
|
|
} else if (EndsWith(filename, ".jpg", false)) {
|
|
return "image/jpeg";
|
|
} else if (EndsWith(filename, ".js", false)) {
|
|
return "application/javascript";
|
|
} else if (EndsWith(filename, ".png", false)) {
|
|
return "image/png";
|
|
} else if (EndsWith(filename, ".gif", false)) {
|
|
return "image/gif";
|
|
}
|
|
NOTREACHED() << "No known mime type for file: " << filename.c_str();
|
|
return "text/plain";
|
|
}
|
|
|
|
class RedirectHandler : public CefResourceHandler {
|
|
public:
|
|
explicit RedirectHandler(const GURL& url)
|
|
: url_(url) {
|
|
}
|
|
|
|
bool ProcessRequest(CefRefPtr<CefRequest> request,
|
|
CefRefPtr<CefCallback> callback) override {
|
|
callback->Continue();
|
|
return true;
|
|
}
|
|
|
|
void GetResponseHeaders(CefRefPtr<CefResponse> response,
|
|
int64& response_length,
|
|
CefString& redirectUrl) override {
|
|
response_length = 0;
|
|
redirectUrl = url_.spec();
|
|
}
|
|
|
|
bool ReadResponse(void* data_out,
|
|
int bytes_to_read,
|
|
int& bytes_read,
|
|
CefRefPtr<CefCallback> callback) override {
|
|
return false;
|
|
}
|
|
|
|
void Cancel() override {
|
|
}
|
|
|
|
private:
|
|
GURL url_;
|
|
|
|
IMPLEMENT_REFCOUNTING(RedirectHandler);
|
|
};
|
|
|
|
class InternalHandler : public CefResourceHandler {
|
|
public:
|
|
InternalHandler(const std::string& mime_type,
|
|
CefRefPtr<CefStreamReader> reader,
|
|
int size)
|
|
: mime_type_(mime_type),
|
|
reader_(reader),
|
|
size_(size) {
|
|
}
|
|
|
|
bool ProcessRequest(CefRefPtr<CefRequest> request,
|
|
CefRefPtr<CefCallback> callback) override {
|
|
callback->Continue();
|
|
return true;
|
|
}
|
|
|
|
void GetResponseHeaders(CefRefPtr<CefResponse> response,
|
|
int64& response_length,
|
|
CefString& redirectUrl) override {
|
|
response_length = size_;
|
|
|
|
response->SetMimeType(mime_type_);
|
|
response->SetStatus(200);
|
|
}
|
|
|
|
bool ReadResponse(void* data_out,
|
|
int bytes_to_read,
|
|
int& bytes_read,
|
|
CefRefPtr<CefCallback> callback) override {
|
|
bytes_read = reader_->Read(data_out, 1, bytes_to_read);
|
|
return (bytes_read > 0);
|
|
}
|
|
|
|
void Cancel() override {
|
|
}
|
|
|
|
private:
|
|
std::string mime_type_;
|
|
CefRefPtr<CefStreamReader> reader_;
|
|
int size_;
|
|
|
|
IMPLEMENT_REFCOUNTING(InternalHandler);
|
|
};
|
|
|
|
class InternalHandlerFactory : public CefSchemeHandlerFactory {
|
|
public:
|
|
explicit InternalHandlerFactory(
|
|
scoped_ptr<InternalHandlerDelegate> delegate)
|
|
: delegate_(delegate.Pass()) {
|
|
}
|
|
|
|
CefRefPtr<CefResourceHandler> Create(
|
|
CefRefPtr<CefBrowser> browser,
|
|
CefRefPtr<CefFrame> frame,
|
|
const CefString& scheme_name,
|
|
CefRefPtr<CefRequest> request) override {
|
|
GURL url = GURL(request->GetURL().ToString());
|
|
|
|
InternalHandlerDelegate::Action action;
|
|
if (delegate_->OnRequest(browser, request, &action)) {
|
|
if (!action.redirect_url.is_empty() && action.redirect_url.is_valid())
|
|
return new RedirectHandler(action.redirect_url);
|
|
|
|
if (action.mime_type.empty())
|
|
action.mime_type = GetMimeType(url.path());
|
|
|
|
if (action.resource_id >= 0) {
|
|
base::StringPiece piece = CefContentClient::Get()->GetDataResource(
|
|
action.resource_id, ui::SCALE_FACTOR_NONE);
|
|
if (!piece.empty()) {
|
|
action.stream =
|
|
CefStreamReader::CreateForData(const_cast<char*>(piece.data()),
|
|
piece.size());
|
|
action.stream_size = piece.size();
|
|
} else {
|
|
NOTREACHED() << "Failed to load internal resource for id: " <<
|
|
action.resource_id << " URL: " << url.spec().c_str();
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
if (action.stream.get()) {
|
|
return new InternalHandler(action.mime_type, action.stream,
|
|
action.stream_size);
|
|
}
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
private:
|
|
scoped_ptr<InternalHandlerDelegate> delegate_;
|
|
|
|
IMPLEMENT_REFCOUNTING(InternalHandlerFactory);
|
|
};
|
|
|
|
} // namespace
|
|
|
|
InternalHandlerDelegate::Action::Action()
|
|
: stream_size(-1),
|
|
resource_id(-1) {
|
|
}
|
|
|
|
CefRefPtr<CefSchemeHandlerFactory> CreateInternalHandlerFactory(
|
|
scoped_ptr<InternalHandlerDelegate> delegate) {
|
|
DCHECK(delegate.get());
|
|
return new InternalHandlerFactory(delegate.Pass());
|
|
}
|
|
|
|
} // namespace scheme
|