request for pdf resource from the webui
This commit is contained in:
parent
210f40dd53
commit
c982af991d
10 changed files with 260 additions and 65 deletions
|
@ -4,9 +4,7 @@
|
||||||
|
|
||||||
#include "atom/browser/atom_resource_dispatcher_host_delegate.h"
|
#include "atom/browser/atom_resource_dispatcher_host_delegate.h"
|
||||||
|
|
||||||
#include "atom/browser/atom_browser_context.h"
|
|
||||||
#include "atom/browser/login_handler.h"
|
#include "atom/browser/login_handler.h"
|
||||||
#include "atom/browser/stream_manager.h"
|
|
||||||
#include "atom/browser/web_contents_permission_helper.h"
|
#include "atom/browser/web_contents_permission_helper.h"
|
||||||
#include "atom/common/atom_constants.h"
|
#include "atom/common/atom_constants.h"
|
||||||
#include "atom/common/platform_util.h"
|
#include "atom/common/platform_util.h"
|
||||||
|
@ -14,6 +12,7 @@
|
||||||
#include "base/strings/stringprintf.h"
|
#include "base/strings/stringprintf.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
|
#include "content/public/browser/stream_info.h"
|
||||||
#include "net/base/escape.h"
|
#include "net/base/escape.h"
|
||||||
#include "net/ssl/client_cert_store.h"
|
#include "net/ssl/client_cert_store.h"
|
||||||
#include "net/url_request/url_request.h"
|
#include "net/url_request/url_request.h"
|
||||||
|
@ -63,30 +62,20 @@ void HandleExternalProtocolInUI(
|
||||||
permission_helper->RequestOpenExternalPermission(callback, has_user_gesture);
|
permission_helper->RequestOpenExternalPermission(callback, has_user_gesture);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OnPdfStreamCreated(
|
void OnPdfStreamCreated(const GURL& original_url,
|
||||||
std::unique_ptr<content::StreamInfo> stream,
|
const content::ResourceRequestInfo::WebContentsGetter&
|
||||||
const std::string& stream_id,
|
web_contents_getter) {
|
||||||
const content::ResourceRequestInfo::WebContentsGetter& web_contents_getter,
|
|
||||||
int render_process_id,
|
|
||||||
int render_frame_id) {
|
|
||||||
content::WebContents* web_contents = web_contents_getter.Run();
|
content::WebContents* web_contents = web_contents_getter.Run();
|
||||||
if (!web_contents)
|
if (!web_contents)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto browser_context =
|
// The URL passes the original pdf resource url, that will be requested
|
||||||
static_cast<AtomBrowserContext*>(web_contents->GetBrowserContext());
|
// by the webui page.
|
||||||
auto stream_manager = browser_context->stream_manager();
|
// chrome://pdf-viewer/index.html?src=https://somepage/123.pdf
|
||||||
GURL original_url = stream->original_url;
|
content::NavigationController::LoadURLParams params(
|
||||||
stream_manager->AddStream(std::move(stream), stream_id, render_process_id,
|
GURL(base::StringPrintf("%sindex.html?%s=%s", kPdfViewerUIOrigin,
|
||||||
render_frame_id);
|
kPdfPluginSrc, original_url.spec().c_str())));
|
||||||
// The URL passes the stream ID to PDF webui that uses it to extract the
|
params.can_load_local_resources = true;
|
||||||
// stream from the StreamManager and also passes the URL that the PDF
|
|
||||||
// originates from, which is used whenever no stream is available from the
|
|
||||||
// content layer (this will happen when the webui page is reloaded).
|
|
||||||
// chrome://pdf-viewer/index.html?streamId=abcd&src=https://somepage/123.pdf
|
|
||||||
content::NavigationController::LoadURLParams params(GURL(base::StringPrintf(
|
|
||||||
"%sindex.html?%s=%s&%s=%s", kPdfViewerUIOrigin, kPdfViewerUIStreamId,
|
|
||||||
stream_id.c_str(), kPdfPluginSrc, original_url.spec().c_str())));
|
|
||||||
web_contents->GetController().LoadURLWithParams(params);
|
web_contents->GetController().LoadURLWithParams(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +125,6 @@ bool AtomResourceDispatcherHostDelegate::ShouldInterceptResourceAsStream(
|
||||||
std::string* payload) {
|
std::string* payload) {
|
||||||
if (mime_type == "application/pdf") {
|
if (mime_type == "application/pdf") {
|
||||||
*origin = GURL(kPdfViewerUIOrigin);
|
*origin = GURL(kPdfViewerUIOrigin);
|
||||||
stream_info_[request] = base::GenerateGUID();
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -145,17 +133,12 @@ bool AtomResourceDispatcherHostDelegate::ShouldInterceptResourceAsStream(
|
||||||
void AtomResourceDispatcherHostDelegate::OnStreamCreated(
|
void AtomResourceDispatcherHostDelegate::OnStreamCreated(
|
||||||
net::URLRequest* request,
|
net::URLRequest* request,
|
||||||
std::unique_ptr<content::StreamInfo> stream) {
|
std::unique_ptr<content::StreamInfo> stream) {
|
||||||
auto it = stream_info_.find(request);
|
|
||||||
if (it == stream_info_.end())
|
|
||||||
return;
|
|
||||||
const content::ResourceRequestInfo* info =
|
const content::ResourceRequestInfo* info =
|
||||||
content::ResourceRequestInfo::ForRequest(request);
|
content::ResourceRequestInfo::ForRequest(request);
|
||||||
content::BrowserThread::PostTask(
|
content::BrowserThread::PostTask(
|
||||||
BrowserThread::UI, FROM_HERE,
|
BrowserThread::UI, FROM_HERE,
|
||||||
base::Bind(&OnPdfStreamCreated, base::Passed(&stream), it->second,
|
base::Bind(&OnPdfStreamCreated, stream->original_url,
|
||||||
info->GetWebContentsGetterForRequest(), info->GetChildID(),
|
info->GetWebContentsGetterForRequest()));
|
||||||
info->GetRenderFrameID()));
|
|
||||||
stream_info_.erase(it);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
#ifndef ATOM_BROWSER_ATOM_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
|
#ifndef ATOM_BROWSER_ATOM_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
|
||||||
#define ATOM_BROWSER_ATOM_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
|
#define ATOM_BROWSER_ATOM_RESOURCE_DISPATCHER_HOST_DELEGATE_H_
|
||||||
|
|
||||||
#include <map>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "content/public/browser/resource_dispatcher_host_delegate.h"
|
#include "content/public/browser/resource_dispatcher_host_delegate.h"
|
||||||
|
@ -34,9 +33,6 @@ class AtomResourceDispatcherHostDelegate
|
||||||
std::unique_ptr<content::StreamInfo> stream) override;
|
std::unique_ptr<content::StreamInfo> stream) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Map between intercepted request and its generated stream id.
|
|
||||||
std::map<net::URLRequest*, std::string> stream_info_;
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(AtomResourceDispatcherHostDelegate);
|
DISALLOW_COPY_AND_ASSIGN(AtomResourceDispatcherHostDelegate);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -53,14 +53,12 @@ AtomWebUIControllerFactory::CreateWebUIControllerForURL(content::WebUI* web_ui,
|
||||||
base::SplitStringIntoKeyValuePairs(url.query(), '=', '&', &toplevel_params);
|
base::SplitStringIntoKeyValuePairs(url.query(), '=', '&', &toplevel_params);
|
||||||
std::string stream_id, src;
|
std::string stream_id, src;
|
||||||
for (const auto& param : toplevel_params) {
|
for (const auto& param : toplevel_params) {
|
||||||
if (param.first == kPdfViewerUIStreamId) {
|
if (param.first == kPdfPluginSrc) {
|
||||||
stream_id = param.second;
|
|
||||||
} else if (param.first == kPdfPluginSrc) {
|
|
||||||
src = param.second;
|
src = param.second;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
auto browser_context = web_ui->GetWebContents()->GetBrowserContext();
|
auto browser_context = web_ui->GetWebContents()->GetBrowserContext();
|
||||||
return new PdfViewerUI(browser_context, web_ui, stream_id, src);
|
return new PdfViewerUI(browser_context, web_ui, src);
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
26
atom/browser/loader/layered_resource_handler.cc
Normal file
26
atom/browser/loader/layered_resource_handler.cc
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
// Copyright (c) 2017 GitHub, Inc.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "atom/browser/loader/layered_resource_handler.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
LayeredResourceHandler::LayeredResourceHandler(
|
||||||
|
net::URLRequest* request,
|
||||||
|
std::unique_ptr<content::ResourceHandler> next_handler,
|
||||||
|
Delegate* delegate)
|
||||||
|
: content::LayeredResourceHandler(request, std::move(next_handler)),
|
||||||
|
delegate_(delegate) {}
|
||||||
|
|
||||||
|
LayeredResourceHandler::~LayeredResourceHandler() {}
|
||||||
|
|
||||||
|
bool LayeredResourceHandler::OnResponseStarted(
|
||||||
|
content::ResourceResponse* response,
|
||||||
|
bool* defer) {
|
||||||
|
if (delegate_)
|
||||||
|
delegate_->OnResponseStarted(response);
|
||||||
|
return next_handler_->OnResponseStarted(response, defer);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace atom
|
40
atom/browser/loader/layered_resource_handler.h
Normal file
40
atom/browser/loader/layered_resource_handler.h
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
// Copyright (c) 2017 GitHub, Inc.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#ifndef ATOM_BROWSER_LOADER_LAYERED_RESOURCE_HANDLER_H_
|
||||||
|
#define ATOM_BROWSER_LOADER_LAYERED_RESOURCE_HANDLER_H_
|
||||||
|
|
||||||
|
#include "content/browser/loader/layered_resource_handler.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
// Resource handler that notifies on various stages of a resource request.
|
||||||
|
class LayeredResourceHandler : public content::LayeredResourceHandler {
|
||||||
|
public:
|
||||||
|
class Delegate {
|
||||||
|
public:
|
||||||
|
Delegate() {}
|
||||||
|
virtual ~Delegate() {}
|
||||||
|
|
||||||
|
virtual void OnResponseStarted(content::ResourceResponse* response) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
LayeredResourceHandler(net::URLRequest* request,
|
||||||
|
std::unique_ptr<content::ResourceHandler> next_handler,
|
||||||
|
Delegate* delegate);
|
||||||
|
~LayeredResourceHandler() override;
|
||||||
|
|
||||||
|
// content::LayeredResourceHandler:
|
||||||
|
bool OnResponseStarted(content::ResourceResponse* response,
|
||||||
|
bool* defer) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Delegate* delegate_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(LayeredResourceHandler);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
#endif // ATOM_BROWSER_LOADER_LAYERED_RESOURCE_HANDLER_H_
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
#include "atom/common/atom_constants.h"
|
#include "atom/common/atom_constants.h"
|
||||||
#include "base/bind.h"
|
#include "base/bind.h"
|
||||||
|
#include "base/memory/ptr_util.h"
|
||||||
#include "base/values.h"
|
#include "base/values.h"
|
||||||
#include "content/public/browser/stream_handle.h"
|
#include "content/public/browser/stream_handle.h"
|
||||||
#include "content/public/browser/stream_info.h"
|
#include "content/public/browser/stream_info.h"
|
||||||
|
@ -41,14 +42,35 @@ void CreateResponseHeadersDictionary(const net::HttpResponseHeaders* headers,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PopulateStreamInfo(base::DictionaryValue* stream_info,
|
||||||
|
content::StreamInfo* stream,
|
||||||
|
const std::string& original_url) {
|
||||||
|
std::unique_ptr<base::DictionaryValue> headers_dict(
|
||||||
|
new base::DictionaryValue);
|
||||||
|
auto stream_url = stream->handle->GetURL().spec();
|
||||||
|
CreateResponseHeadersDictionary(stream->response_headers.get(),
|
||||||
|
headers_dict.get());
|
||||||
|
stream_info->SetString("streamURL", stream_url);
|
||||||
|
stream_info->SetString("originalURL", original_url);
|
||||||
|
stream_info->Set("responseHeaders", std::move(headers_dict));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
PdfViewerHandler::PdfViewerHandler(const content::StreamInfo* stream,
|
PdfViewerHandler::PdfViewerHandler(const std::string& src)
|
||||||
const std::string& src)
|
: stream_(nullptr), original_url_(src), initialized_(false) {}
|
||||||
: stream_(stream), original_url_(src) {}
|
|
||||||
|
|
||||||
PdfViewerHandler::~PdfViewerHandler() {}
|
PdfViewerHandler::~PdfViewerHandler() {}
|
||||||
|
|
||||||
|
void PdfViewerHandler::SetPdfResourceStream(content::StreamInfo* stream) {
|
||||||
|
stream_ = stream;
|
||||||
|
if (initialized_) {
|
||||||
|
auto list = base::MakeUnique<base::ListValue>();
|
||||||
|
list->Set(0, std::move(initialize_callback_id_));
|
||||||
|
Initialize(list.get());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void PdfViewerHandler::RegisterMessages() {
|
void PdfViewerHandler::RegisterMessages() {
|
||||||
web_ui()->RegisterMessageCallback(
|
web_ui()->RegisterMessageCallback(
|
||||||
"initialize",
|
"initialize",
|
||||||
|
@ -79,24 +101,23 @@ void PdfViewerHandler::OnJavascriptDisallowed() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void PdfViewerHandler::Initialize(const base::ListValue* args) {
|
void PdfViewerHandler::Initialize(const base::ListValue* args) {
|
||||||
AllowJavascript();
|
|
||||||
|
|
||||||
CHECK_EQ(1U, args->GetSize());
|
CHECK_EQ(1U, args->GetSize());
|
||||||
const base::Value* callback_id;
|
const base::Value* callback_id;
|
||||||
CHECK(args->Get(0, &callback_id));
|
CHECK(args->Get(0, &callback_id));
|
||||||
std::unique_ptr<base::DictionaryValue> stream_info(new base::DictionaryValue);
|
|
||||||
std::unique_ptr<base::DictionaryValue> headers_dict(
|
|
||||||
new base::DictionaryValue);
|
|
||||||
std::string stream_url = original_url_;
|
|
||||||
if (stream_) {
|
if (stream_) {
|
||||||
stream_url = stream_->handle->GetURL().spec();
|
initialized_ = false;
|
||||||
CreateResponseHeadersDictionary(stream_->response_headers.get(),
|
|
||||||
headers_dict.get());
|
AllowJavascript();
|
||||||
|
|
||||||
|
std::unique_ptr<base::DictionaryValue> stream_info(
|
||||||
|
new base::DictionaryValue);
|
||||||
|
PopulateStreamInfo(stream_info.get(), stream_, original_url_);
|
||||||
|
ResolveJavascriptCallback(*callback_id, *stream_info);
|
||||||
|
} else {
|
||||||
|
initialize_callback_id_ = callback_id->CreateDeepCopy();
|
||||||
|
initialized_ = true;
|
||||||
}
|
}
|
||||||
stream_info->SetString("streamURL", stream_url);
|
|
||||||
stream_info->SetString("originalURL", original_url_);
|
|
||||||
stream_info->Set("responseHeaders", std::move(headers_dict));
|
|
||||||
ResolveJavascriptCallback(*callback_id, *stream_info);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PdfViewerHandler::GetDefaultZoom(const base::ListValue* args) {
|
void PdfViewerHandler::GetDefaultZoom(const base::ListValue* args) {
|
||||||
|
|
|
@ -23,10 +23,12 @@ namespace atom {
|
||||||
|
|
||||||
class PdfViewerHandler : public content::WebUIMessageHandler {
|
class PdfViewerHandler : public content::WebUIMessageHandler {
|
||||||
public:
|
public:
|
||||||
PdfViewerHandler(const content::StreamInfo* stream,
|
explicit PdfViewerHandler(const std::string& original_url);
|
||||||
const std::string& original_url);
|
|
||||||
~PdfViewerHandler() override;
|
~PdfViewerHandler() override;
|
||||||
|
|
||||||
|
void SetPdfResourceStream(content::StreamInfo* stream);
|
||||||
|
|
||||||
|
protected:
|
||||||
// WebUIMessageHandler implementation.
|
// WebUIMessageHandler implementation.
|
||||||
void RegisterMessages() override;
|
void RegisterMessages() override;
|
||||||
void OnJavascriptAllowed() override;
|
void OnJavascriptAllowed() override;
|
||||||
|
@ -43,8 +45,10 @@ class PdfViewerHandler : public content::WebUIMessageHandler {
|
||||||
// Keeps track of events related to zooming.
|
// Keeps track of events related to zooming.
|
||||||
std::unique_ptr<content::HostZoomMap::Subscription>
|
std::unique_ptr<content::HostZoomMap::Subscription>
|
||||||
host_zoom_map_subscription_;
|
host_zoom_map_subscription_;
|
||||||
const content::StreamInfo* stream_;
|
std::unique_ptr<base::Value> initialize_callback_id_;
|
||||||
|
content::StreamInfo* stream_;
|
||||||
std::string original_url_;
|
std::string original_url_;
|
||||||
|
bool initialized_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerHandler);
|
DISALLOW_COPY_AND_ASSIGN(PdfViewerHandler);
|
||||||
};
|
};
|
||||||
|
|
|
@ -11,14 +11,29 @@
|
||||||
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
||||||
#include "atom/common/atom_constants.h"
|
#include "atom/common/atom_constants.h"
|
||||||
#include "components/pdf/common/pdf_messages.h"
|
#include "components/pdf/common/pdf_messages.h"
|
||||||
|
#include "content/browser/loader/resource_dispatcher_host_impl.h"
|
||||||
|
#include "content/browser/loader/resource_request_info_impl.h"
|
||||||
|
#include "content/browser/loader/stream_resource_handler.h"
|
||||||
|
#include "content/browser/resource_context_impl.h"
|
||||||
|
#include "content/browser/streams/stream.h"
|
||||||
|
#include "content/browser/streams/stream_context.h"
|
||||||
|
#include "content/public/browser/browser_thread.h"
|
||||||
|
#include "content/public/browser/render_frame_host.h"
|
||||||
|
#include "content/public/browser/render_process_host.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/render_view_host.h"
|
||||||
|
#include "content/public/browser/resource_context.h"
|
||||||
|
#include "content/public/browser/stream_handle.h"
|
||||||
#include "content/public/browser/url_data_source.h"
|
#include "content/public/browser/url_data_source.h"
|
||||||
#include "content/public/browser/web_contents.h"
|
#include "content/public/browser/web_contents.h"
|
||||||
#include "content/public/common/bindings_policy.h"
|
|
||||||
#include "grit/pdf_viewer_resources_map.h"
|
#include "grit/pdf_viewer_resources_map.h"
|
||||||
|
#include "net/base/load_flags.h"
|
||||||
#include "net/base/mime_util.h"
|
#include "net/base/mime_util.h"
|
||||||
|
#include "net/url_request/url_request.h"
|
||||||
|
#include "net/url_request/url_request_context.h"
|
||||||
#include "ui/base/resource/resource_bundle.h"
|
#include "ui/base/resource/resource_bundle.h"
|
||||||
|
|
||||||
|
using content::BrowserThread;
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -83,19 +98,68 @@ class BundledDataSource : public content::URLDataSource {
|
||||||
DISALLOW_COPY_AND_ASSIGN(BundledDataSource);
|
DISALLOW_COPY_AND_ASSIGN(BundledDataSource);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void RequestPdfResource(
|
||||||
|
const GURL& url,
|
||||||
|
const GURL& origin,
|
||||||
|
int render_process_id,
|
||||||
|
int render_view_id,
|
||||||
|
int render_frame_id,
|
||||||
|
content::ResourceContext* resource_context,
|
||||||
|
base::Callback<void(std::unique_ptr<content::StreamInfo>)> callback,
|
||||||
|
atom::LayeredResourceHandler::Delegate* delegate) {
|
||||||
|
DCHECK_CURRENTLY_ON(BrowserThread::IO);
|
||||||
|
|
||||||
|
const net::URLRequestContext* request_context =
|
||||||
|
resource_context->GetRequestContext();
|
||||||
|
std::unique_ptr<net::URLRequest> request(
|
||||||
|
request_context->CreateRequest(url, net::DEFAULT_PRIORITY, nullptr));
|
||||||
|
request->set_method("GET");
|
||||||
|
|
||||||
|
content::ResourceDispatcherHostImpl::Get()->InitializeURLRequest(
|
||||||
|
request.get(), content::Referrer(url, blink::WebReferrerPolicyDefault),
|
||||||
|
false, // download.
|
||||||
|
render_process_id, render_view_id, render_frame_id, resource_context);
|
||||||
|
|
||||||
|
content::ResourceRequestInfoImpl* info =
|
||||||
|
content::ResourceRequestInfoImpl::ForRequest(request.get());
|
||||||
|
content::StreamContext* stream_context =
|
||||||
|
content::GetStreamContextForResourceContext(resource_context);
|
||||||
|
|
||||||
|
std::unique_ptr<content::ResourceHandler> handler(
|
||||||
|
new content::StreamResourceHandler(request.get(),
|
||||||
|
stream_context->registry(), origin));
|
||||||
|
info->set_is_stream(true);
|
||||||
|
std::unique_ptr<content::StreamInfo> stream_info(new content::StreamInfo);
|
||||||
|
stream_info->handle =
|
||||||
|
static_cast<content::StreamResourceHandler*>(handler.get())
|
||||||
|
->stream()
|
||||||
|
->CreateHandle();
|
||||||
|
stream_info->original_url = request->url();
|
||||||
|
|
||||||
|
// Helper to fill stream response details.
|
||||||
|
handler.reset(new atom::LayeredResourceHandler(request.get(),
|
||||||
|
std::move(handler), delegate));
|
||||||
|
|
||||||
|
content::ResourceDispatcherHostImpl::Get()->BeginURLRequest(
|
||||||
|
std::move(request), std::move(handler),
|
||||||
|
false, // download
|
||||||
|
false, // content_initiated (download specific)
|
||||||
|
false, // do_not_prompt_for_login (download specific)
|
||||||
|
resource_context);
|
||||||
|
|
||||||
|
callback.Run(std::move(stream_info));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context,
|
PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context,
|
||||||
content::WebUI* web_ui,
|
content::WebUI* web_ui,
|
||||||
const std::string& stream_id,
|
|
||||||
const std::string& src)
|
const std::string& src)
|
||||||
: content::WebUIController(web_ui),
|
: content::WebUIController(web_ui),
|
||||||
content::WebContentsObserver(web_ui->GetWebContents()),
|
content::WebContentsObserver(web_ui->GetWebContents()),
|
||||||
src_(src) {
|
src_(src) {
|
||||||
auto context = static_cast<AtomBrowserContext*>(browser_context);
|
pdf_handler_ = new PdfViewerHandler(src);
|
||||||
auto stream_manager = context->stream_manager();
|
web_ui->AddMessageHandler(pdf_handler_);
|
||||||
stream_ = stream_manager->ReleaseStream(stream_id);
|
|
||||||
web_ui->AddMessageHandler(new PdfViewerHandler(stream_.get(), src));
|
|
||||||
content::URLDataSource::Add(browser_context, new BundledDataSource);
|
content::URLDataSource::Add(browser_context, new BundledDataSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,6 +176,47 @@ bool PdfViewerUI::OnMessageReceived(
|
||||||
return handled;
|
return handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PdfViewerUI::OnPdfStreamResponseStarted(
|
||||||
|
scoped_refptr<net::HttpResponseHeaders> headers,
|
||||||
|
const std::string& mime_type) {
|
||||||
|
if (headers.get())
|
||||||
|
stream_->response_headers =
|
||||||
|
new net::HttpResponseHeaders(headers->raw_headers());
|
||||||
|
stream_->mime_type = mime_type;
|
||||||
|
pdf_handler_->SetPdfResourceStream(stream_.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
void PdfViewerUI::OnResponseStarted(content::ResourceResponse* response) {
|
||||||
|
DCHECK_CURRENTLY_ON(BrowserThread::IO);
|
||||||
|
|
||||||
|
auto resource_response_head = response->head;
|
||||||
|
BrowserThread::PostTask(
|
||||||
|
BrowserThread::UI, FROM_HERE,
|
||||||
|
base::Bind(&PdfViewerUI::OnPdfStreamResponseStarted,
|
||||||
|
base::Unretained(this), resource_response_head.headers,
|
||||||
|
resource_response_head.mime_type));
|
||||||
|
}
|
||||||
|
|
||||||
|
void PdfViewerUI::OnPdfStreamCreated(
|
||||||
|
std::unique_ptr<content::StreamInfo> stream) {
|
||||||
|
stream_ = std::move(stream);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PdfViewerUI::RenderFrameCreated(content::RenderFrameHost* rfh) {
|
||||||
|
int render_process_id = rfh->GetProcess()->GetID();
|
||||||
|
int render_frame_id = rfh->GetRoutingID();
|
||||||
|
int render_view_id = rfh->GetRenderViewHost()->GetRoutingID();
|
||||||
|
auto resource_context =
|
||||||
|
web_contents()->GetBrowserContext()->GetResourceContext();
|
||||||
|
BrowserThread::PostTask(
|
||||||
|
BrowserThread::IO, FROM_HERE,
|
||||||
|
base::Bind(
|
||||||
|
&RequestPdfResource, GURL(src_), GURL(kPdfViewerUIOrigin),
|
||||||
|
render_process_id, render_view_id, render_frame_id, resource_context,
|
||||||
|
base::Bind(&PdfViewerUI::OnPdfStreamCreated, base::Unretained(this)),
|
||||||
|
this));
|
||||||
|
}
|
||||||
|
|
||||||
void PdfViewerUI::OnSaveURLAs(const GURL& url,
|
void PdfViewerUI::OnSaveURLAs(const GURL& url,
|
||||||
const content::Referrer& referrer) {
|
const content::Referrer& referrer) {
|
||||||
web_contents()->SaveFrame(url, referrer);
|
web_contents()->SaveFrame(url, referrer);
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#include "atom/browser/loader/layered_resource_handler.h"
|
||||||
#include "base/macros.h"
|
#include "base/macros.h"
|
||||||
#include "content/public/browser/web_contents_observer.h"
|
#include "content/public/browser/web_contents_observer.h"
|
||||||
#include "content/public/browser/web_ui_controller.h"
|
#include "content/public/browser/web_ui_controller.h"
|
||||||
|
@ -14,29 +15,48 @@
|
||||||
|
|
||||||
namespace content {
|
namespace content {
|
||||||
class BrowserContext;
|
class BrowserContext;
|
||||||
|
class ResourceContext;
|
||||||
struct StreamInfo;
|
struct StreamInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace net {
|
||||||
|
class HttpResponseHeaders;
|
||||||
|
}
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
|
class PdfViewerHandler;
|
||||||
|
|
||||||
class PdfViewerUI : public content::WebUIController,
|
class PdfViewerUI : public content::WebUIController,
|
||||||
public content::WebContentsObserver {
|
public content::WebContentsObserver,
|
||||||
|
public LayeredResourceHandler::Delegate {
|
||||||
public:
|
public:
|
||||||
PdfViewerUI(content::BrowserContext* browser_context,
|
PdfViewerUI(content::BrowserContext* browser_context,
|
||||||
content::WebUI* web_ui,
|
content::WebUI* web_ui,
|
||||||
const std::string& stream_id,
|
|
||||||
const std::string& src);
|
const std::string& src);
|
||||||
~PdfViewerUI() override;
|
~PdfViewerUI() override;
|
||||||
|
|
||||||
// content::WebContentsObserver:
|
// content::WebContentsObserver:
|
||||||
bool OnMessageReceived(const IPC::Message& message,
|
bool OnMessageReceived(const IPC::Message& message,
|
||||||
content::RenderFrameHost* render_frame_host) override;
|
content::RenderFrameHost* render_frame_host) override;
|
||||||
|
void RenderFrameCreated(content::RenderFrameHost* rfh) override;
|
||||||
|
|
||||||
|
// LayeredResourceHandler:
|
||||||
|
void OnResponseStarted(content::ResourceResponse* response) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void OnPdfStreamCreated(std::unique_ptr<content::StreamInfo> stream_info);
|
||||||
|
void OnPdfStreamResponseStarted(
|
||||||
|
scoped_refptr<net::HttpResponseHeaders> headers,
|
||||||
|
const std::string& mime_type);
|
||||||
void OnSaveURLAs(const GURL& url, const content::Referrer& referrer);
|
void OnSaveURLAs(const GURL& url, const content::Referrer& referrer);
|
||||||
|
|
||||||
// Source URL from where the PDF originates.
|
// Source URL from where the PDF originates.
|
||||||
std::string src_;
|
std::string src_;
|
||||||
|
|
||||||
|
PdfViewerHandler* pdf_handler_;
|
||||||
|
|
||||||
|
// Pdf Resource stream.
|
||||||
std::unique_ptr<content::StreamInfo> stream_;
|
std::unique_ptr<content::StreamInfo> stream_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerUI);
|
DISALLOW_COPY_AND_ASSIGN(PdfViewerUI);
|
||||||
|
|
|
@ -213,6 +213,8 @@
|
||||||
'atom/browser/javascript_environment.h',
|
'atom/browser/javascript_environment.h',
|
||||||
'atom/browser/lib/bluetooth_chooser.cc',
|
'atom/browser/lib/bluetooth_chooser.cc',
|
||||||
'atom/browser/lib/bluetooth_chooser.h',
|
'atom/browser/lib/bluetooth_chooser.h',
|
||||||
|
'atom/browser/loader/layered_resource_handler.cc',
|
||||||
|
'atom/browser/loader/layered_resource_handler.h',
|
||||||
'atom/browser/login_handler.cc',
|
'atom/browser/login_handler.cc',
|
||||||
'atom/browser/login_handler.h',
|
'atom/browser/login_handler.h',
|
||||||
'atom/browser/mac/atom_application.h',
|
'atom/browser/mac/atom_application.h',
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue