code cleanup

This commit is contained in:
deepak1556 2017-02-27 20:31:54 +05:30
parent b1b6573bcd
commit b28e686228
3 changed files with 113 additions and 95 deletions

View file

@ -58,16 +58,17 @@ void PopulateStreamInfo(base::DictionaryValue* stream_info,
} // namespace } // namespace
PdfViewerHandler::PdfViewerHandler(const std::string& src) PdfViewerHandler::PdfViewerHandler(const std::string& src)
: stream_(nullptr), original_url_(src), initialized_(false) {} : stream_(nullptr), original_url_(src), initialized_(true) {}
PdfViewerHandler::~PdfViewerHandler() {} PdfViewerHandler::~PdfViewerHandler() {}
void PdfViewerHandler::SetPdfResourceStream(content::StreamInfo* stream) { void PdfViewerHandler::SetPdfResourceStream(content::StreamInfo* stream) {
stream_ = stream; stream_ = stream;
if (initialized_) { if (!initialized_) {
auto list = base::MakeUnique<base::ListValue>(); auto list = base::MakeUnique<base::ListValue>();
list->Set(0, std::move(initialize_callback_id_)); list->Set(0, std::move(initialize_callback_id_));
Initialize(list.get()); Initialize(list.get());
initialized_ = true;
} }
} }
@ -106,8 +107,6 @@ void PdfViewerHandler::Initialize(const base::ListValue* args) {
CHECK(args->Get(0, &callback_id)); CHECK(args->Get(0, &callback_id));
if (stream_) { if (stream_) {
initialized_ = false;
AllowJavascript(); AllowJavascript();
std::unique_ptr<base::DictionaryValue> stream_info( std::unique_ptr<base::DictionaryValue> stream_info(
@ -116,7 +115,7 @@ void PdfViewerHandler::Initialize(const base::ListValue* args) {
ResolveJavascriptCallback(*callback_id, *stream_info); ResolveJavascriptCallback(*callback_id, *stream_info);
} else { } else {
initialize_callback_id_ = callback_id->CreateDeepCopy(); initialize_callback_id_ = callback_id->CreateDeepCopy();
initialized_ = true; initialized_ = false;
} }
} }

View file

@ -7,8 +7,10 @@
#include <map> #include <map>
#include "atom/browser/atom_browser_context.h" #include "atom/browser/atom_browser_context.h"
#include "atom/browser/loader/layered_resource_handler.h"
#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 "base/sequenced_task_runner_helpers.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_dispatcher_host_impl.h"
#include "content/browser/loader/resource_request_info_impl.h" #include "content/browser/loader/resource_request_info_impl.h"
@ -98,15 +100,29 @@ class BundledDataSource : public content::URLDataSource {
DISALLOW_COPY_AND_ASSIGN(BundledDataSource); DISALLOW_COPY_AND_ASSIGN(BundledDataSource);
}; };
void RequestPdfResource( // Helper to convert from OnceCallback to Callback.
const GURL& url, template <typename T>
void CallMigrationCallback(T callback,
std::unique_ptr<content::StreamInfo> stream_info) {
std::move(callback).Run(std::move(stream_info));
}
} // namespace
class PdfViewerUI::ResourceRequester
: public base::RefCountedThreadSafe<ResourceRequester,
BrowserThread::DeleteOnIOThread>,
public atom::LayeredResourceHandler::Delegate {
public:
ResourceRequester(StreamResponseCallback cb)
: stream_response_cb_(std::move(cb)) {}
void StartRequest(const GURL& url,
const GURL& origin, const GURL& origin,
int render_process_id, int render_process_id,
int render_view_id, int render_view_id,
int render_frame_id, int render_frame_id,
content::ResourceContext* resource_context, content::ResourceContext* resource_context) {
base::Callback<void(std::unique_ptr<content::StreamInfo>)> callback,
atom::LayeredResourceHandler::Delegate* delegate) {
DCHECK_CURRENTLY_ON(BrowserThread::IO); DCHECK_CURRENTLY_ON(BrowserThread::IO);
const net::URLRequestContext* request_context = const net::URLRequestContext* request_context =
@ -129,16 +145,16 @@ void RequestPdfResource(
new content::StreamResourceHandler(request.get(), new content::StreamResourceHandler(request.get(),
stream_context->registry(), origin)); stream_context->registry(), origin));
info->set_is_stream(true); info->set_is_stream(true);
std::unique_ptr<content::StreamInfo> stream_info(new content::StreamInfo); stream_info_.reset(new content::StreamInfo);
stream_info->handle = stream_info_->handle =
static_cast<content::StreamResourceHandler*>(handler.get()) static_cast<content::StreamResourceHandler*>(handler.get())
->stream() ->stream()
->CreateHandle(); ->CreateHandle();
stream_info->original_url = request->url(); stream_info_->original_url = request->url();
// Helper to fill stream response details. // Helper to fill stream response details.
handler.reset(new atom::LayeredResourceHandler(request.get(), handler.reset(new atom::LayeredResourceHandler(request.get(),
std::move(handler), delegate)); std::move(handler), this));
content::ResourceDispatcherHostImpl::Get()->BeginURLRequest( content::ResourceDispatcherHostImpl::Get()->BeginURLRequest(
std::move(request), std::move(handler), std::move(request), std::move(handler),
@ -146,11 +162,39 @@ void RequestPdfResource(
false, // content_initiated (download specific) false, // content_initiated (download specific)
false, // do_not_prompt_for_login (download specific) false, // do_not_prompt_for_login (download specific)
resource_context); resource_context);
}
callback.Run(std::move(stream_info)); protected:
} // atom::LayeredResourceHandler::Delegate:
void OnResponseStarted(content::ResourceResponse* response) override {
DCHECK_CURRENTLY_ON(BrowserThread::IO);
} // namespace auto resource_response_head = response->head;
auto headers = resource_response_head.headers;
auto mime_type = resource_response_head.mime_type;
if (headers.get())
stream_info_->response_headers =
new net::HttpResponseHeaders(headers->raw_headers());
stream_info_->mime_type = mime_type;
BrowserThread::PostTask(
BrowserThread::UI, FROM_HERE,
base::Bind(&CallMigrationCallback<StreamResponseCallback>,
base::Passed(&stream_response_cb_),
base::Passed(&stream_info_)));
}
private:
friend class base::RefCountedThreadSafe<ResourceRequester>;
friend struct BrowserThread::DeleteOnThread<BrowserThread::IO>;
friend class base::DeleteHelper<ResourceRequester>;
~ResourceRequester() override {}
StreamResponseCallback stream_response_cb_;
std::unique_ptr<content::StreamInfo> stream_info_;
DISALLOW_COPY_AND_ASSIGN(ResourceRequester);
};
PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context, PdfViewerUI::PdfViewerUI(content::BrowserContext* browser_context,
content::WebUI* web_ui, content::WebUI* web_ui,
@ -176,30 +220,11 @@ 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( void PdfViewerUI::OnPdfStreamCreated(
std::unique_ptr<content::StreamInfo> stream) { std::unique_ptr<content::StreamInfo> stream) {
stream_ = std::move(stream); stream_ = std::move(stream);
pdf_handler_->SetPdfResourceStream(stream_.get());
resource_requester_ = nullptr;
} }
void PdfViewerUI::RenderFrameCreated(content::RenderFrameHost* rfh) { void PdfViewerUI::RenderFrameCreated(content::RenderFrameHost* rfh) {
@ -208,13 +233,14 @@ void PdfViewerUI::RenderFrameCreated(content::RenderFrameHost* rfh) {
int render_view_id = rfh->GetRenderViewHost()->GetRoutingID(); int render_view_id = rfh->GetRenderViewHost()->GetRoutingID();
auto resource_context = auto resource_context =
web_contents()->GetBrowserContext()->GetResourceContext(); web_contents()->GetBrowserContext()->GetResourceContext();
auto callback =
base::BindOnce(&PdfViewerUI::OnPdfStreamCreated, base::Unretained(this));
resource_requester_ = new ResourceRequester(std::move(callback));
BrowserThread::PostTask( BrowserThread::PostTask(
BrowserThread::IO, FROM_HERE, BrowserThread::IO, FROM_HERE,
base::Bind( base::Bind(&ResourceRequester::StartRequest, resource_requester_,
&RequestPdfResource, GURL(src_), GURL(kPdfViewerUIOrigin), GURL(src_), GURL(kPdfViewerUIOrigin), render_process_id,
render_process_id, render_view_id, render_frame_id, resource_context, 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,

View file

@ -7,7 +7,6 @@
#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"
@ -15,21 +14,15 @@
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 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,
@ -41,14 +34,12 @@ class PdfViewerUI : public content::WebUIController,
content::RenderFrameHost* render_frame_host) override; content::RenderFrameHost* render_frame_host) override;
void RenderFrameCreated(content::RenderFrameHost* rfh) override; void RenderFrameCreated(content::RenderFrameHost* rfh) override;
// LayeredResourceHandler:
void OnResponseStarted(content::ResourceResponse* response) override;
private: private:
using StreamResponseCallback =
base::OnceCallback<void(std::unique_ptr<content::StreamInfo>)>;
class ResourceRequester;
void OnPdfStreamCreated(std::unique_ptr<content::StreamInfo> stream_info); 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.
@ -56,6 +47,8 @@ class PdfViewerUI : public content::WebUIController,
PdfViewerHandler* pdf_handler_; PdfViewerHandler* pdf_handler_;
scoped_refptr<ResourceRequester> resource_requester_;
// Pdf Resource stream. // Pdf Resource stream.
std::unique_ptr<content::StreamInfo> stream_; std::unique_ptr<content::StreamInfo> stream_;