fix crash when pdf viewer is reloaded
This commit is contained in:
parent
ddc2e0df71
commit
c15f6af892
6 changed files with 42 additions and 28 deletions
|
@ -77,11 +77,12 @@ void OnPdfStreamCreated(
|
||||||
static_cast<AtomBrowserContext*>(web_contents->GetBrowserContext());
|
static_cast<AtomBrowserContext*>(web_contents->GetBrowserContext());
|
||||||
auto stream_manager = browser_context->stream_manager();
|
auto stream_manager = browser_context->stream_manager();
|
||||||
std::string view_id = base::GenerateGUID();
|
std::string view_id = base::GenerateGUID();
|
||||||
|
GURL original_url = stream->original_url;
|
||||||
stream_manager->AddStream(std::move(stream), view_id, render_process_id,
|
stream_manager->AddStream(std::move(stream), view_id, render_process_id,
|
||||||
render_frame_id);
|
render_frame_id);
|
||||||
content::NavigationController::LoadURLParams params(
|
content::NavigationController::LoadURLParams params(GURL(base::StringPrintf(
|
||||||
GURL(base::StringPrintf("%sindex.html?%s=%s", PdfViewerUI::kOrigin,
|
"%sindex.html?%s=%s&%s=%s", PdfViewerUI::kOrigin, PdfViewerUI::kId,
|
||||||
PdfViewerUI::kId, view_id.c_str())));
|
view_id.c_str(), PdfViewerUI::kSrc, original_url.spec().c_str())));
|
||||||
web_contents->GetController().LoadURLWithParams(params);
|
web_contents->GetController().LoadURLWithParams(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -50,15 +50,16 @@ AtomWebUIControllerFactory::CreateWebUIControllerForURL(content::WebUI* web_ui,
|
||||||
if (url.host() == PdfViewerUI::kHost) {
|
if (url.host() == PdfViewerUI::kHost) {
|
||||||
base::StringPairs toplevel_params;
|
base::StringPairs toplevel_params;
|
||||||
base::SplitStringIntoKeyValuePairs(url.query(), '=', '&', &toplevel_params);
|
base::SplitStringIntoKeyValuePairs(url.query(), '=', '&', &toplevel_params);
|
||||||
std::string view_id;
|
std::string view_id, src;
|
||||||
for (const auto& param : toplevel_params) {
|
for (const auto& param : toplevel_params) {
|
||||||
if (param.first == PdfViewerUI::kId) {
|
if (param.first == PdfViewerUI::kId) {
|
||||||
view_id = param.second;
|
view_id = param.second;
|
||||||
break;
|
} else if (param.first == PdfViewerUI::kSrc) {
|
||||||
|
src = param.second;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
auto browser_context = web_ui->GetWebContents()->GetBrowserContext();
|
auto browser_context = web_ui->GetWebContents()->GetBrowserContext();
|
||||||
return new PdfViewerUI(browser_context, web_ui, view_id);
|
return new PdfViewerUI(browser_context, web_ui, view_id, src);
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,8 +4,7 @@
|
||||||
|
|
||||||
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
||||||
|
|
||||||
#include "atom/browser/atom_browser_context.h"
|
#include "base/bind.h"
|
||||||
#include "atom/browser/stream_manager.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"
|
||||||
|
@ -42,17 +41,13 @@ void CreateResponseHeadersDictionary(const net::HttpResponseHeaders* headers,
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
PdfViewerHandler::PdfViewerHandler(const std::string& view_id)
|
PdfViewerHandler::PdfViewerHandler(const content::StreamInfo* stream,
|
||||||
: view_id_(view_id) {}
|
const std::string& src)
|
||||||
|
: stream_(stream), original_url_(src) {}
|
||||||
|
|
||||||
PdfViewerHandler::~PdfViewerHandler() {}
|
PdfViewerHandler::~PdfViewerHandler() {}
|
||||||
|
|
||||||
void PdfViewerHandler::RegisterMessages() {
|
void PdfViewerHandler::RegisterMessages() {
|
||||||
auto browser_context = static_cast<AtomBrowserContext*>(
|
|
||||||
web_ui()->GetWebContents()->GetBrowserContext());
|
|
||||||
auto stream_manager = browser_context->stream_manager();
|
|
||||||
stream_ = stream_manager->ReleaseStream(view_id_);
|
|
||||||
|
|
||||||
web_ui()->RegisterMessageCallback(
|
web_ui()->RegisterMessageCallback(
|
||||||
"initialize",
|
"initialize",
|
||||||
base::Bind(&PdfViewerHandler::Initialize, base::Unretained(this)));
|
base::Bind(&PdfViewerHandler::Initialize, base::Unretained(this)));
|
||||||
|
@ -86,14 +81,16 @@ void PdfViewerHandler::Initialize(const base::ListValue* args) {
|
||||||
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> stream_info(new base::DictionaryValue);
|
||||||
auto stream_url = stream_->handle->GetURL().spec();
|
|
||||||
auto original_url = stream_->original_url.spec();
|
|
||||||
stream_info->SetString("streamURL", stream_url);
|
|
||||||
stream_info->SetString("originalURL", original_url);
|
|
||||||
std::unique_ptr<base::DictionaryValue> headers_dict(
|
std::unique_ptr<base::DictionaryValue> headers_dict(
|
||||||
new base::DictionaryValue);
|
new base::DictionaryValue);
|
||||||
CreateResponseHeadersDictionary(stream_->response_headers.get(),
|
std::string stream_url = original_url_;
|
||||||
headers_dict.get());
|
if (stream_) {
|
||||||
|
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));
|
stream_info->Set("responseHeaders", std::move(headers_dict));
|
||||||
ResolveJavascriptCallback(*callback_id, *stream_info);
|
ResolveJavascriptCallback(*callback_id, *stream_info);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,8 @@ namespace atom {
|
||||||
|
|
||||||
class PdfViewerHandler : public content::WebUIMessageHandler {
|
class PdfViewerHandler : public content::WebUIMessageHandler {
|
||||||
public:
|
public:
|
||||||
explicit PdfViewerHandler(const std::string& view_id);
|
PdfViewerHandler(const content::StreamInfo* stream,
|
||||||
|
const std::string& original_url);
|
||||||
~PdfViewerHandler() override;
|
~PdfViewerHandler() override;
|
||||||
|
|
||||||
// WebUIMessageHandler implementation.
|
// WebUIMessageHandler implementation.
|
||||||
|
@ -41,8 +42,8 @@ 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_;
|
||||||
std::unique_ptr<content::StreamInfo> stream_;
|
const content::StreamInfo* stream_;
|
||||||
std::string view_id_;
|
std::string original_url_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerHandler);
|
DISALLOW_COPY_AND_ASSIGN(PdfViewerHandler);
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
|
#include "atom/browser/atom_browser_context.h"
|
||||||
|
#include "atom/browser/stream_manager.h"
|
||||||
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
#include "atom/browser/ui/webui/pdf_viewer_handler.h"
|
||||||
#include "components/pdf/common/pdf_messages.h"
|
#include "components/pdf/common/pdf_messages.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/render_view_host.h"
|
||||||
|
@ -82,13 +84,19 @@ class BundledDataSource : public content::URLDataSource {
|
||||||
const char PdfViewerUI::kOrigin[] = "chrome://pdf-viewer/";
|
const char PdfViewerUI::kOrigin[] = "chrome://pdf-viewer/";
|
||||||
const char PdfViewerUI::kHost[] = "pdf-viewer";
|
const char PdfViewerUI::kHost[] = "pdf-viewer";
|
||||||
const char PdfViewerUI::kId[] = "viewId";
|
const char PdfViewerUI::kId[] = "viewId";
|
||||||
|
const char PdfViewerUI::kSrc[] = "src";
|
||||||
|
|
||||||
PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context,
|
PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context,
|
||||||
content::WebUI* web_ui,
|
content::WebUI* web_ui,
|
||||||
const std::string& view_id)
|
const std::string& view_id,
|
||||||
: content::WebUIController(web_ui),
|
const std::string& src)
|
||||||
|
: src_(src),
|
||||||
|
content::WebUIController(web_ui),
|
||||||
content::WebContentsObserver(web_ui->GetWebContents()) {
|
content::WebContentsObserver(web_ui->GetWebContents()) {
|
||||||
web_ui->AddMessageHandler(new PdfViewerHandler(view_id));
|
auto context = static_cast<AtomBrowserContext*>(browser_context);
|
||||||
|
auto stream_manager = context->stream_manager();
|
||||||
|
stream_ = stream_manager->ReleaseStream(view_id);
|
||||||
|
web_ui->AddMessageHandler(new PdfViewerHandler(stream_.get(), src));
|
||||||
content::URLDataSource::Add(browser_context, new BundledDataSource);
|
content::URLDataSource::Add(browser_context, new BundledDataSource);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
namespace content {
|
namespace content {
|
||||||
class BrowserContext;
|
class BrowserContext;
|
||||||
|
class StreamInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
@ -24,10 +25,12 @@ class PdfViewerUI : public content::WebUIController,
|
||||||
static const char kOrigin[];
|
static const char kOrigin[];
|
||||||
static const char kHost[];
|
static const char kHost[];
|
||||||
static const char kId[];
|
static const char kId[];
|
||||||
|
static const char kSrc[];
|
||||||
|
|
||||||
PdfViewerUI(content::BrowserContext* browser_context,
|
PdfViewerUI(content::BrowserContext* browser_context,
|
||||||
content::WebUI* web_ui,
|
content::WebUI* web_ui,
|
||||||
const std::string& view_id);
|
const std::string& view_id,
|
||||||
|
const std::string& src);
|
||||||
~PdfViewerUI() override;
|
~PdfViewerUI() override;
|
||||||
|
|
||||||
// content::WebUIController implementation.
|
// content::WebUIController implementation.
|
||||||
|
@ -40,6 +43,9 @@ class PdfViewerUI : public content::WebUIController,
|
||||||
private:
|
private:
|
||||||
void OnSaveURLAs(const GURL& url, const content::Referrer& referrer);
|
void OnSaveURLAs(const GURL& url, const content::Referrer& referrer);
|
||||||
|
|
||||||
|
std::string src_;
|
||||||
|
std::unique_ptr<content::StreamInfo> stream_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(PdfViewerUI);
|
DISALLOW_COPY_AND_ASSIGN(PdfViewerUI);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue