69f1731bbb
* chore: bump chromium in DEPS to cbdeef954dfc34e94c8ca9cf72ad326b4a121158 * chore: bump chromium in DEPS to 29723f905baeab1d4228eef2c31cdb341ebeffe0 * chore: bump chromium in DEPS to 44d6d78e852137fff58c14ed26ab1e803e5bf822 * update patches * chore: bump chromium in DEPS to 8a3a0fccb39d6b8334c9a0496c0d5056e50cdb3f * chore: update patches * refactor: fix PrintBackend::CreateInstance() calls Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2354541 * chore: bump chromium in DEPS to b9ebec3bcb1cabdd1426f367636f54cc98e0500e * chore: remove patches to code that was deleted upstream CL: https://chromium-review.googlesource.com/c/chromium/src/+/2360314 * Remove uses of kCGColorSpaceITUR_2020_PQ_EOTF/HLG CL: https://chromium-review.googlesource.com/c/chromium/src/+/2363950 just garden variety code shear * chore: update patch indices * Move ColorModel to //printing/mojom/print.mojom https://chromium-review.googlesource.com/c/chromium/src/+/2355083 sync with printing ColorModel changes: moved to mojo, different naming scheme * chore: bump chromium in DEPS to 56c4b4d2ce5ba941acd2e0fdb5100e8a48847134 * chore: bump chromium in DEPS to 130501f220b684a79dc82c17e236e63ac1f2a093 * Convert PrintHostMsg_DidGetPrintedPagesCount to Mojo https://chromium-review.googlesource.com/c/chromium/src/+/2326857 Update argument list to Print() * chore: update patch indices * DumpAccTree: convert utf16 to utf8 in PropertyFilter https://chromium-review.googlesource.com/c/chromium/src/+/2360218 * chore: bump chromium in DEPS to 3058368c6646e0dc8be6f8ea838b0343428b7998 * chore: bump chromium in DEPS to f51b4e6555364363c61438dac7afd988c8347bfc * chore: bump chromium in DEPS to 2dcc6f8fc23ac41b2499eb69dee0b4017e9d1046 * update patches * chore: bump chromium in DEPS to 2d8e98ecedc7e4905540b053bc1c87e964715be5 * update patches * 2345900: Move content::RecordContentToVisibleTimeRequest struct to mojo https://chromium-review.googlesource.com/c/chromium/src/+/2345900 * update patches * 2345900: Move content::RecordContentToVisibleTimeRequest struct to mojo https://chromium-review.googlesource.com/c/chromium/src/+/2345900 * 2367394: Remove net::LOAD_DO_NOT_SEND_COOKIES and net::LOAD_DO_NOT_SEND_AUTH_DATA. https://chromium-review.googlesource.com/c/chromium/src/+/2367394 * 2373227: [XProto] Consolidate all <X11/*> includes to //ui/gfx/x/x11.h https://chromium-review.googlesource.com/c/chromium/src/+/2373227 * fixup! 2373227: [XProto] Consolidate all <X11/*> includes to //ui/gfx/x/x11.h * chore: bump chromium in DEPS to c090e3f960520cbd2328608b97f87238c76d6143 * update patches * chore: bump chromium in DEPS to 13a25e0a755de9a14271022c595f3d2e29829e1a * chore: bump chromium in DEPS to 6adbb767b012c41efaeab0d1bdbb3eefed0977bc * chore: bump chromium in DEPS to 339ec5455c5932ef1322ea9953a6349b0732199e * chore: bump chromium in DEPS to 20291807c33f7ef4ef4f57d62075e099b027bfe6 * chore: bump chromium in DEPS to 226fbd1b8b17d4ac84fdb9548ef3a1c646878d47 * update patches * fixup disable_color_correct_rendering patch * chore: bump chromium in DEPS to 577c45979cad4359f2e206d68efd9317d3d79315 * update patches * viz: Rename RenderPass to CompositorRenderPass (and related types). https://chromium-review.googlesource.com/c/chromium/src/+/2380730 * chore: bump chromium in DEPS to 37e2ad5303f2c03a1b5d8eda65341bf2561196cd * update patches * add kOmitCookies_Electron * update patch * chore: bump chromium in DEPS to 256e42409ea63a7e71016de07818a983a97db463 * update patches * fix worker script ready hook https://chromium-review.googlesource.com/c/chromium/src/+/2335713 * Fixup printing page ranges patch * [printing] Move PrintMsg_PrintPages_Params to print.mojom https://chromium-review.googlesource.com/c/chromium/src/+/2340854 * Add MIME sniffer overloads that take base::StringPieces https://chromium-review.googlesource.com/c/chromium/src/+/2382896 * [printing] Move PrintHostMsg_PreviewIds to print.mojom https://chromium-review.googlesource.com/c/chromium/src/+/2379455 * fixup test due to new DCHECK https://chromium-review.googlesource.com/c/chromium/src/+/2333750 * stop sending cookies when useSessionCookies is false * chore: bump chromium in DEPS to dd429dbc556449951ee8160d8a4d61fd95a139d5 * update patches * chore: bump chromium in DEPS to 5202bde3f9f44c2065f5dacf27e7000dd19e4e4d * chore: bump chromium in DEPS to 099e8e07b89da65932431bb0fd51b6f7f5344c19 * chore: bump chromium in DEPS to 104e5da2a43b759732d5b94bfc750b3a9a639653 * chore: bump chromium in DEPS to a4519ce657af25834e355315fd7fefa77b13426a * update patches * Make FileURLLoaderFactory always owned by its |receivers_|. https://chromium-review.googlesource.com/c/chromium/src/+/2337411 * Make FileURLLoaderFactory always owned by its |receivers_|. https://chromium-review.googlesource.com/c/chromium/src/+/2337411 * chore: bump chromium in DEPS to 1b62e9e8c8eaf6b8e3a9c77ee67a4c1bfa6a4d6b * chore: update patches * fixup! Make FileURLLoaderFactory always owned by its |receivers_|. * chore: update patches - mac: Disable CoreServices _CSCheckFix. https://chromium-review.googlesource.com/c/chromium/src/+/2401334 - [XProto] Remove bad DCHECK in x11_error_tracker.cc https://chromium-review.googlesource.com/c/chromium/src/+/2402304 - Move content/browser/frame_host/* over to content/browser/renderer_host/ https://chromium-review.googlesource.com/c/chromium/src/+/2401303 * Refactor WebContentSettingsClient to dedupe AllowXYZ methods https://chromium-review.googlesource.com/c/chromium/src/+/2353552 * Introduce NonNetworkURLLoaderFactoryBase class. https://chromium-review.googlesource.com/c/chromium/src/+/2357559 * [XProto] Remove usage of all Xlib headers https://chromium-review.googlesource.com/c/chromium/src/+/2392140 * fixup! chore: update patches * chore: bump chromium in DEPS to c1df55fbeb8207d036a604f59e4ea4e8ee79930a * chore: update patches * Move content::WebPreferences struct to Blink https://chromium-review.googlesource.com/c/chromium/src/+/2397670 * chore: bump chromium in DEPS to 57a23ec4884fff6c2f8d9b8536131cdc9b551ec2 * Set appid on Pip windows. https://chromium-review.googlesource.com/c/chromium/src/+/2388274 * fixup! Set appid on Pip windows. * fix: add a patch to remove deprecated factory * chore: bump chromium in DEPS to 1a9ddb7ea43955877823d5c4dcbf241b64228635 * fix compilation on windows * chore: bump chromium in DEPS to 234e6c6a77f61ffad9335099d9b13892cf88fd44 * chore: update patches * chore: bump chromium in DEPS to 7631eb0a9f57a8a47d3c28e1d265961b3a4d6b2b * chore: update patches * chore: bump chromium in DEPS to f9c34cd485845b95c2d17a7f55fdf92cda9a1b3a * chore: update patches * chore: implement GetSurveyAPIKey Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2362182 * chore: replace CreateWebUIURLLoader with CreateWebUIURLLoaderFactory Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2358309 * chore: bump chromium in DEPS to 5bdbd2373da884adf41c087be1465fcc344d168c * chore: update node patches for common.gypi * chore: update patches * chore: non_network_url_loader_factory_base was moved Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2357431 * 2415752: Reland "Reland "OOR-CORS: Remove BlinkCORS supporting code outside Blink"" Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2415752 * chore: bump chromium in DEPS to b943d006a33ec5bc1743792d64724693eb357083 * fix: replace x11::None with x11::Window::None * chore: update patches * chore: update patches * fix: cast x11::Window to int * 2402123: Use end date when deleting http auth cache Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2402123 * 2320268: Migrate DragHostMsg_StartDragging to Mojo Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2320268 * 2401303: Move content/browser/frame_host/* over to content/browser/renderer_host/ https://chromium-review.googlesource.com/c/chromium/src/+/2401303 * chore: fix lint * chore: fix build * Update config.yml Co-authored-by: Electron Bot <anonymous@electronjs.org> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: deepak1556 <hop2deep@gmail.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: Samuel Attard <sattard@slack-corp.com>
284 lines
9.8 KiB
C++
284 lines
9.8 KiB
C++
// Copyright (c) 2018 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/printing/print_preview_message_handler.h"
|
|
|
|
#include <memory>
|
|
#include <utility>
|
|
|
|
#include "base/bind.h"
|
|
#include "base/memory/read_only_shared_memory_region.h"
|
|
#include "base/memory/ref_counted.h"
|
|
#include "base/memory/ref_counted_memory.h"
|
|
#include "base/task/post_task.h"
|
|
#include "chrome/browser/browser_process.h"
|
|
#include "chrome/browser/printing/print_job_manager.h"
|
|
#include "chrome/browser/printing/printer_query.h"
|
|
#include "components/printing/browser/print_composite_client.h"
|
|
#include "components/printing/browser/print_manager_utils.h"
|
|
#include "components/printing/common/print_messages.h"
|
|
#include "components/services/print_compositor/public/cpp/print_service_mojo_types.h"
|
|
#include "content/public/browser/browser_task_traits.h"
|
|
#include "content/public/browser/browser_thread.h"
|
|
#include "content/public/browser/render_frame_host.h"
|
|
#include "content/public/browser/web_contents.h"
|
|
#include "mojo/public/cpp/bindings/callback_helpers.h"
|
|
#include "shell/common/gin_helper/locker.h"
|
|
#include "third_party/blink/public/common/associated_interfaces/associated_interface_provider.h"
|
|
|
|
#include "shell/common/node_includes.h"
|
|
|
|
using content::BrowserThread;
|
|
|
|
namespace electron {
|
|
|
|
namespace {
|
|
|
|
void StopWorker(int document_cookie) {
|
|
if (document_cookie <= 0)
|
|
return;
|
|
scoped_refptr<printing::PrintQueriesQueue> queue =
|
|
g_browser_process->print_job_manager()->queue();
|
|
std::unique_ptr<printing::PrinterQuery> printer_query =
|
|
queue->PopPrinterQuery(document_cookie);
|
|
if (printer_query.get()) {
|
|
base::PostTask(FROM_HERE, {BrowserThread::IO},
|
|
base::BindOnce(&printing::PrinterQuery::StopWorker,
|
|
std::move(printer_query)));
|
|
}
|
|
}
|
|
|
|
} // namespace
|
|
|
|
PrintPreviewMessageHandler::PrintPreviewMessageHandler(
|
|
content::WebContents* web_contents)
|
|
: content::WebContentsObserver(web_contents), weak_ptr_factory_(this) {
|
|
DCHECK(web_contents);
|
|
}
|
|
|
|
PrintPreviewMessageHandler::~PrintPreviewMessageHandler() = default;
|
|
|
|
bool PrintPreviewMessageHandler::OnMessageReceived(
|
|
const IPC::Message& message,
|
|
content::RenderFrameHost* render_frame_host) {
|
|
bool handled = true;
|
|
IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(PrintPreviewMessageHandler, message,
|
|
render_frame_host)
|
|
IPC_MESSAGE_HANDLER(PrintHostMsg_MetafileReadyForPrinting,
|
|
OnMetafileReadyForPrinting)
|
|
IPC_MESSAGE_HANDLER(PrintHostMsg_DidPreviewPage, OnDidPreviewPage)
|
|
IPC_MESSAGE_HANDLER(PrintHostMsg_DidPrepareDocumentForPreview,
|
|
OnDidPrepareForDocumentToPdf)
|
|
IPC_MESSAGE_UNHANDLED(handled = false)
|
|
IPC_END_MESSAGE_MAP()
|
|
return handled;
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnMetafileReadyForPrinting(
|
|
content::RenderFrameHost* render_frame_host,
|
|
const printing::mojom::DidPreviewDocumentParams& params,
|
|
const printing::mojom::PreviewIds& ids) {
|
|
// Always try to stop the worker.
|
|
StopWorker(params.document_cookie);
|
|
|
|
if (params.expected_pages_count == 0) {
|
|
RejectPromise(ids.request_id);
|
|
return;
|
|
}
|
|
|
|
const base::ReadOnlySharedMemoryRegion& metafile =
|
|
params.content->metafile_data_region;
|
|
|
|
if (printing::IsOopifEnabled()) {
|
|
auto* client =
|
|
printing::PrintCompositeClient::FromWebContents(web_contents());
|
|
DCHECK(client);
|
|
|
|
auto callback = base::BindOnce(
|
|
&PrintPreviewMessageHandler::OnCompositeDocumentToPdfDone,
|
|
weak_ptr_factory_.GetWeakPtr(), ids);
|
|
|
|
client->DoCompleteDocumentToPdf(
|
|
params.document_cookie, params.expected_pages_count,
|
|
mojo::WrapCallbackWithDefaultInvokeIfNotRun(
|
|
std::move(callback),
|
|
printing::mojom::PrintCompositor::Status::kCompositingFailure,
|
|
base::ReadOnlySharedMemoryRegion()));
|
|
} else {
|
|
ResolvePromise(
|
|
ids.request_id,
|
|
base::RefCountedSharedMemoryMapping::CreateFromWholeRegion(metafile));
|
|
}
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnPrepareForDocumentToPdfDone(
|
|
const printing::mojom::PreviewIds& ids,
|
|
printing::mojom::PrintCompositor::Status status) {
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
|
if (status != printing::mojom::PrintCompositor::Status::kSuccess) {
|
|
LOG(ERROR) << "Preparing document for pdf failed with error " << status;
|
|
}
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnDidPrepareForDocumentToPdf(
|
|
content::RenderFrameHost* render_frame_host,
|
|
int document_cookie,
|
|
const printing::mojom::PreviewIds& ids) {
|
|
if (printing::IsOopifEnabled()) {
|
|
auto* client =
|
|
printing::PrintCompositeClient::FromWebContents(web_contents());
|
|
DCHECK(client);
|
|
|
|
if (client->GetIsDocumentConcurrentlyComposited(document_cookie))
|
|
return;
|
|
|
|
client->DoPrepareForDocumentToPdf(
|
|
document_cookie, render_frame_host,
|
|
mojo::WrapCallbackWithDefaultInvokeIfNotRun(
|
|
base::BindOnce(
|
|
&PrintPreviewMessageHandler::OnPrepareForDocumentToPdfDone,
|
|
weak_ptr_factory_.GetWeakPtr(), ids),
|
|
printing::mojom::PrintCompositor::Status::kCompositingFailure));
|
|
}
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnCompositeDocumentToPdfDone(
|
|
const printing::mojom::PreviewIds& ids,
|
|
printing::mojom::PrintCompositor::Status status,
|
|
base::ReadOnlySharedMemoryRegion region) {
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
|
|
|
if (status != printing::mojom::PrintCompositor::Status::kSuccess) {
|
|
LOG(ERROR) << "Compositing pdf failed with error " << status;
|
|
RejectPromise(ids.request_id);
|
|
return;
|
|
}
|
|
|
|
ResolvePromise(
|
|
ids.request_id,
|
|
base::RefCountedSharedMemoryMapping::CreateFromWholeRegion(region));
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnCompositePdfPageDone(
|
|
int page_number,
|
|
int document_cookie,
|
|
const printing::mojom::PreviewIds& ids,
|
|
printing::mojom::PrintCompositor::Status status,
|
|
base::ReadOnlySharedMemoryRegion region) {
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
|
if (status != printing::mojom::PrintCompositor::Status::kSuccess) {
|
|
LOG(ERROR) << "Compositing pdf failed on page: " << page_number
|
|
<< " with error: " << status;
|
|
}
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::OnDidPreviewPage(
|
|
content::RenderFrameHost* render_frame_host,
|
|
const printing::mojom::DidPreviewPageParams& params,
|
|
const printing::mojom::PreviewIds& ids) {
|
|
int page_number = params.page_number;
|
|
const printing::mojom::DidPrintContentParams& content = *params.content;
|
|
|
|
if (page_number < printing::FIRST_PAGE_INDEX ||
|
|
!content.metafile_data_region.IsValid()) {
|
|
RejectPromise(ids.request_id);
|
|
return;
|
|
}
|
|
|
|
if (printing::IsOopifEnabled()) {
|
|
auto* client =
|
|
printing::PrintCompositeClient::FromWebContents(web_contents());
|
|
DCHECK(client);
|
|
|
|
// Use utility process to convert skia metafile to pdf.
|
|
client->DoCompositePageToPdf(
|
|
params.document_cookie, render_frame_host, content,
|
|
mojo::WrapCallbackWithDefaultInvokeIfNotRun(
|
|
base::BindOnce(&PrintPreviewMessageHandler::OnCompositePdfPageDone,
|
|
weak_ptr_factory_.GetWeakPtr(), page_number,
|
|
params.document_cookie, ids),
|
|
printing::mojom::PrintCompositor::Status::kCompositingFailure,
|
|
base::ReadOnlySharedMemoryRegion()));
|
|
}
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::PrintPreviewFailed(int32_t document_cookie,
|
|
int32_t request_id) {
|
|
StopWorker(document_cookie);
|
|
|
|
RejectPromise(request_id);
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::PrintPreviewCancelled(int32_t document_cookie,
|
|
int32_t request_id) {
|
|
StopWorker(document_cookie);
|
|
|
|
RejectPromise(request_id);
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::PrintToPDF(
|
|
base::DictionaryValue options,
|
|
gin_helper::Promise<v8::Local<v8::Value>> promise) {
|
|
int request_id;
|
|
options.GetInteger(printing::kPreviewRequestID, &request_id);
|
|
promise_map_.emplace(request_id, std::move(promise));
|
|
|
|
auto* focused_frame = web_contents()->GetFocusedFrame();
|
|
auto* rfh = focused_frame && focused_frame->HasSelection()
|
|
? focused_frame
|
|
: web_contents()->GetMainFrame();
|
|
|
|
if (!print_render_frame_.is_bound()) {
|
|
rfh->GetRemoteAssociatedInterfaces()->GetInterface(&print_render_frame_);
|
|
}
|
|
if (!receiver_.is_bound()) {
|
|
print_render_frame_->SetPrintPreviewUI(
|
|
receiver_.BindNewEndpointAndPassRemote());
|
|
}
|
|
print_render_frame_->PrintPreview(options.Clone());
|
|
}
|
|
|
|
gin_helper::Promise<v8::Local<v8::Value>>
|
|
PrintPreviewMessageHandler::GetPromise(int request_id) {
|
|
auto it = promise_map_.find(request_id);
|
|
DCHECK(it != promise_map_.end());
|
|
|
|
gin_helper::Promise<v8::Local<v8::Value>> promise = std::move(it->second);
|
|
promise_map_.erase(it);
|
|
|
|
return promise;
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::ResolvePromise(
|
|
int request_id,
|
|
scoped_refptr<base::RefCountedMemory> data_bytes) {
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
|
|
|
gin_helper::Promise<v8::Local<v8::Value>> promise = GetPromise(request_id);
|
|
|
|
v8::Isolate* isolate = promise.isolate();
|
|
gin_helper::Locker locker(isolate);
|
|
v8::HandleScope handle_scope(isolate);
|
|
v8::Context::Scope context_scope(
|
|
v8::Local<v8::Context>::New(isolate, promise.GetContext()));
|
|
|
|
v8::Local<v8::Value> buffer =
|
|
node::Buffer::Copy(isolate,
|
|
reinterpret_cast<const char*>(data_bytes->front()),
|
|
data_bytes->size())
|
|
.ToLocalChecked();
|
|
|
|
promise.Resolve(buffer);
|
|
}
|
|
|
|
void PrintPreviewMessageHandler::RejectPromise(int request_id) {
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
|
|
|
gin_helper::Promise<v8::Local<v8::Value>> promise = GetPromise(request_id);
|
|
promise.RejectWithErrorMessage("Failed to generate PDF");
|
|
}
|
|
|
|
WEB_CONTENTS_USER_DATA_KEY_IMPL(PrintPreviewMessageHandler)
|
|
|
|
} // namespace electron
|