mirror of
https://github.com/electron/electron.git
synced 2026-04-10 03:01:51 -04:00
* chore: bump chromium to 100.0.4857.0 (main) (#32419) * chore: bump chromium in DEPS to 99.0.4819.0 * chore: update patches * chore: bump chromium in DEPS to 99.0.4824.0 * chore: update patches * chore: bump chromium in DEPS to 99.0.4827.0 * chore: update patches * 3352511: PiP: Add inkdrop and pointer cursor to PiP window buttons https://chromium-review.googlesource.com/c/chromium/src/+/3352511 * 3309164: webhid: Show FIDO devices in the chooser if allowed https://chromium-review.googlesource.com/c/chromium/src/+/3309164 * 3297868: hid: Add experimental HIDDevice.forget() https://chromium-review.googlesource.com/c/chromium/src/+/3297868 * 3362491: [Extensions] Move i18n API to //extensions https://chromium-review.googlesource.com/c/chromium/src/+/3362491 * MCC Refactor step0: Allow embedders to register associated_interface binders with RenderFrameHostImpl::associated_registry_. https://chromium-review.googlesource.com/c/chromium/src/+/3281481 * 3352616: [Gtk] Remove libgtk from the link-line https://chromium-review.googlesource.com/c/chromium/src/+/3352616 * 3249211: Clear-Site-Data support for partitioned cookies https://chromium-review.googlesource.com/c/chromium/src/+/3249211 * [Extensions][COIL] Use [allow|block]list in //extensions/common https://chromium-review.googlesource.com/c/chromium/src/+/3372668 * Begin ScopedUserPrefUpdate migration to modern base::Value https://chromium-review.googlesource.com/c/chromium/src/+/3376154 * [Code Health] Refactor PrefService GetDict + GetList to use base::Value https://chromium-review.googlesource.com/c/chromium/src/+/3343526 * 3354997: [CodeHealth] Remove deprecated SetDictionary method https://chromium-review.googlesource.com/c/chromium/src/+/3354997 * 3287323: Add LacrosPrefStore for lacros settings https://chromium-review.googlesource.com/c/chromium/src/+/3287323 * 3365916: [PA] Clean up remaining lazy commit code https://chromium-review.googlesource.com/c/chromium/src/+/3365916 * [MPArch] Target the external protocol error at the responsible frame. https://chromium-review.googlesource.com/c/chromium/src/+/3011560 * Pass origin to RegisterNonNetworkSubresourceURLLoaderFactories https://chromium-review.googlesource.com/c/chromium/src/+/3350608 * Linux: Send OSCrypt raw encryption key to the Network Service https://chromium-review.googlesource.com/c/chromium/src/+/3320484 * [PlzServiceWorker] Remove remaining references to PlzServiceWorker. https://chromium-review.googlesource.com/c/chromium/src/+/3359441 * chore: fixup for lint * 3327621: Fix tablet mode detection for Win 11. https://chromium-review.googlesource.com/c/chromium/src/+/3327621 * 3342428: ax_mac: move AXTextMarker conversion utils under ui umbrella https://chromium-review.googlesource.com/c/chromium/src/+/3342428 * 3353974: Mac: Use base::Feature for overlay features https://chromium-review.googlesource.com/c/chromium/src/+/3353974 * chore: bump chromium in DEPS to 99.0.4828.0 * chore: update patches * chore: bump chromium in DEPS to 99.0.4837.0 * chore: update patches * chore: update patches * 3379142: Drop FALLTHROUGH macro Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3379142 * 3381749: C++17: Allow use of std::map::try_emplace and std::map::insert_or_assign Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3381749 * chore: bump chromium in DEPS to 99.0.4839.0 * chore: update patches * chore: bump chromium in DEPS to 99.0.4840.0 * chore: bump chromium in DEPS to 99.0.4844.0 * 3395881: [api] Deprecate Local<v8::Context> v8::Object::CreationContext() Ref: https://chromium-review.googlesource.com/c/v8/v8/+/3395881 * chore: update patches * chore: bump chromium in DEPS to 100.0.4845.0 * chore: update patches * chore: bump chromium in DEPS to 100.0.4847.0 * chore: update patches * chore: bump chromium in DEPS to 100.0.4849.0 * chore: update patches * chore: bump chromium in DEPS to 100.0.4851.0 * chore: bump chromium in DEPS to 100.0.4853.0 * update patches * chore: update patches * update patches * 3383599: Fonts Access: Remove prototype that uses a font picker. https://chromium-review.googlesource.com/c/chromium/src/+/3383599 * 3404768: Remove ALLOW_UNUSED macros https://chromium-review.googlesource.com/c/chromium/src/+/3404768 * 3374762: Remove ignore_result.h https://chromium-review.googlesource.com/c/chromium/src/+/3374762 * 3399305: [unseasoned-pdf] Apply proper frame offsets for touch selections https://chromium-review.googlesource.com/c/chromium/src/+/3399305 * 3402210: [Extensions] Don't trigger unload event for already unloaded extension https://chromium-review.googlesource.com/c/chromium/src/+/3402210 * 3410912: Combine URLLoaderClient OnReceiveResponse and OnStartLoadingResponseBody. https://chromium-review.googlesource.com/c/chromium/src/+/3410912 * 3370428: Make the AuthSchemes policy support dynamic refresh https://chromium-review.googlesource.com/c/chromium/src/+/3370428 * 3407603: Finish ScopedUserPrefUpdate migration to modern base::Value https://chromium-review.googlesource.com/c/chromium/src/+/3407603 * 3378352: ozone/x11: move code from //ui/p/x11 to //ui/ozone/p/x11 https://chromium-review.googlesource.com/c/chromium/src/+/3378352 * 3370810: Delete chrome/service, AKA the Cloud Print service process. https://chromium-review.googlesource.com/c/chromium/src/+/3370810 * chore: bump chromium in DEPS to 100.0.4855.0 * chore: update patches * fixup! 3370810: Delete chrome/service, AKA the Cloud Print service process. * revert 3348007 to fix windows build * 3318572: [Code health] Fix gn check errors in //extensions/browser:* https://chromium-review.googlesource.com/c/chromium/src/+/3318572 * fix printing.patch * fix iwyu issue * 3408515: win: Make ShorcutOperation an enum class and modernize names https://chromium-review.googlesource.com/c/chromium/src/+/3408515 * 3388333: [UIA] Remove dead code accessibility_misc_utils.h/cc https://chromium-review.googlesource.com/c/chromium/src/+/3388333 * fix windows build? i hope * patch gn visibility of //ui/ozone/platform/x11 * missing include base/logging.h * use BUILDFLAG for USE_NSS_CERTS https://chromium-review.googlesource.com/c/chromium/src/+/3379123 * defined(OS_*) ==> BUILDFLAG(IS_*) https://bugs.chromium.org/p/chromium/issues/detail?id=1234043 * fixup! 3404768: Remove ALLOW_UNUSED macros * another attempt to fix windows build * temporarily disable the custom scheme service worker test https://github.com/electron/electron/issues/32664 * fix loading mv3 extensions not sure what cl broke this unfort. * fixup! 3404768: Remove ALLOW_UNUSED macros * patch nan https://chromium-review.googlesource.com/c/v8/v8/+/3395880 * fix node test * fix nullptr in FindPdfFrame * patch perfetto to fix build issue on win-ia32bc44c3c753* fix build for linux-x64-testing-no-run-as-node * fix patch * skip <webview>.capturePage() test https://github.com/electron/electron/issues/32705 * test: fix failing tests of focus/blur events of WebContents (#32711) * inherit stdio from app module test child processes this prevents them from timing out due to full stdout buffers * test to see if we can get better logs on windows ci * try again for appveyor log things * skip contentTracing tests on ia32 * ci: disable gpu compositing * drop applied patch * fix merge fail * Revert "ci: disable gpu compositing" This reverts commit0344129fcb. Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: VerteDinde <khammond@slack-corp.com> Co-authored-by: VerteDinde <vertedinde@electronjs.org> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: Cheng Zhao <zcbenz@gmail.com> Co-authored-by: deepak1556 <hop2deep@gmail.com> (cherry picked from commit28ada6ea8b) * chore: bump chromium to 100.0.4894.0 (main) (#32852) * chore: bump chromium in DEPS to 100.0.4880.0 * resolve conflicts * chore: update patches * fix patch * PIP20: add a new DocumentOverlayWindowViews subtype https://chromium-review.googlesource.com/c/chromium/src/+/3252789 * Clean up PictureInPictureWindowManager::EnterPictureInPicture() https://chromium-review.googlesource.com/c/chromium/src/+/3424145 * Remove StoragePartitionId. https://chromium-review.googlesource.com/c/chromium/src/+/2811120 * Remove FLoC code https://chromium-review.googlesource.com/c/chromium/src/+/3424359 * media: Make AddSupportedKeySystems() Async https://chromium-review.googlesource.com/c/chromium/src/+/3430502 * [Extensions] Move some l10n file util methods to //extensions/browser https://chromium-review.googlesource.com/c/chromium/src/+/3408192 * chore: IWYU * Reland "webhid: Grant permissions for policy-allowed devices" https://chromium-review.googlesource.com/c/chromium/src/+/3444147 * Migrate base::Value::GetList() to base::Value::GetListDeprecated(): 2/N. https://chromium-review.googlesource.com/c/chromium/src/+/3435727 https://chromium-review.googlesource.com/c/chromium/src/+/3440910 https://chromium-review.googlesource.com/c/chromium/src/+/3440088 * [text blink period] Cache blink period instead of fetching from defaults https://chromium-review.googlesource.com/c/chromium/src/+/3419059 * chore: update picture-in-picture.patch https://chromium-review.googlesource.com/c/chromium/src/+/3252789 * ci: update to Xcode 13.2.1 https://chromium-review.googlesource.com/c/chromium/src/+/3437552 * chore: bump chromium in DEPS to 100.0.4882.1 * chore: update patches * chore: bump chromium in DEPS to 100.0.4884.0 * chore: update patches * chore: bump chromium in DEPS to 100.0.4886.0 * chore: update patches * Refactor DownloadManager to use StoragePartitionConfig https://chromium-review.googlesource.com/c/chromium/src/+/3222011 * Remove ToWebInputElement() in favor of new WebNode::DynamicTo<> helpers. https://chromium-review.googlesource.com/c/chromium/src/+/3433852 * refactor: autofill to use the color pipeline https://bugs.chromium.org/p/chromium/issues/detail?id=1249558 https://bugs.chromium.org/p/chromium/issues/detail?id=1003612 * [ProcessSingleton] Add many more trace events to cover all scenarios https://chromium-review.googlesource.com/c/chromium/src/+/3429325 * fixup! PIP20: add a new DocumentOverlayWindowViews subtype * chore: bump chromium in DEPS to 100.0.4888.0 * chore: update patches * chore: update picture-in-picture.patch * fixup! refactor: autofill to use the color pipeline * ci: fixup fix sync (cherry picked from commit c1e3e395465739bce5ca8e1c5ec1f5bd72b99ebd) * chore: bump chromium in DEPS to 100.0.4889.0 * chore: update patches * chore: fix feat_add_data_transfer_to_requestsingleinstancelock.patch * fixup! PIP20: add a new DocumentOverlayWindowViews subtype * Remove remaining NativeTheme::GetSystemColor() machinery. https://chromium-review.googlesource.com/c/chromium/src/+/3421719 * ci: fetch proper esbuild for macos * ci: fixup fetch proper esbuild for macos * fix: failing Node.js test on outdated CurrentValueSerializerFormatVersion * chore: bump chromium in DEPS to 100.0.4892.0 * 3460365: Set V8 fatal error callbacks during Isolate initialization https://chromium-review.googlesource.com/c/chromium/src/+/3460365 * 3454343: PIP20: use permanent top controls https://chromium-review.googlesource.com/c/chromium/src/+/3454343 * 3465574: Move most of GTK color mixers to ui/color/. https://chromium-review.googlesource.com/c/chromium/src/+/3465574 * chore: fixup patch indices * 3445327: [locales] Remove locales reference https://chromium-review.googlesource.com/c/chromium/src/+/3445327 * 3456548: [DBB][#7] Blue border falls back to all tab if cropped-to zero pixels https://chromium-review.googlesource.com/c/chromium/src/+/3456548 * 3441196: Convert GuestView's remaining legacy IPC messages to Mojo https://chromium-review.googlesource.com/c/chromium/src/+/3441196 * 3455491: Don't include run_loop.h in thread_task_runner_handle.h https://chromium-review.googlesource.com/c/chromium/src/+/3455491 * fixup! 3454343: PIP20: use permanent top controls * 3442501: Add missing includes of //base/observer_list.h https://chromium-review.googlesource.com/c/chromium/src/+/3442501 * 3437552: mac: Deploy a new hermetic build of Xcode 13.2.1 13C100 https://chromium-review.googlesource.com/c/chromium/src/+/3437552 * chore: bump chromium in DEPS to 100.0.4894.0 * fixup! 3460365: Set V8 fatal error callbacks during Isolate initialization * chore: update patches * 3425231: Use DnsOverHttpsConfig where appropriate https://chromium-review.googlesource.com/c/chromium/src/+/3425231 * test: disable test-heapsnapshot-near-heap-limit-worker.js As a result of CLs linked in https://bugs.chromium.org/p/v8/issues/detail?id=12503, heap snapshotting near the heap limit DCHECKS in Node.js specs. This will likely require a larger refactor in Node.js so i've disabled the test for now and opened an upstream issue on node-v8 issue at https://github.com/nodejs/node-v8/issues/218. * Port all usage of NativeTheme color IDs to color pipeline https://bugs.chromium.org/p/chromium/issues/detail?id=1249558 * chore: update patches after rebase * ci: use gen2 machine for more disk space * ci: don't try to make root volume writeable * ci: use older xcode/macos for tests * fix: html fullscreen transitions stacking (cherry picked from commit 5e10965cdd7b2a024def5fc568912cefd0f05b44) * ci: speed up woa testing (cherry picked from commit 75c33c48b032137794f5734348a9ee3daa60d9de) (cherry picked from commite819962340) * ci: disable flaky tests on WOA * ci: run remote tests separately to isolate issue there * tests: disable node test parallel/test-worker-debug for now * revert: fix: html fullscreen transitions stacking * tests: disable flaky test on macOS arm64 * fixup circleci config so build tools can find xcode version * make sure the workspace is clean before job runs (cherry picked from commit75f713c974) * tests: disable flaky test on Linux * ci: debug why windows i32 is crashing * Revert "ci: debug why windows i32 is crashing" This reverts commit4c4bba87ea. Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: deepak1556 <hop2deep@gmail.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> (cherry picked from commit3da598015b) Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
256 lines
9.2 KiB
C++
256 lines
9.2 KiB
C++
// Copyright (c) 2015 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/electron_download_manager_delegate.h"
|
|
|
|
#include <string>
|
|
#include <tuple>
|
|
#include <utility>
|
|
|
|
#include "base/bind.h"
|
|
#include "base/files/file_util.h"
|
|
#include "base/task/post_task.h"
|
|
#include "base/task/thread_pool.h"
|
|
#include "base/threading/thread_restrictions.h"
|
|
#include "chrome/common/pref_names.h"
|
|
#include "components/download/public/common/download_danger_type.h"
|
|
#include "components/prefs/pref_service.h"
|
|
#include "content/public/browser/browser_context.h"
|
|
#include "content/public/browser/browser_thread.h"
|
|
#include "content/public/browser/download_item_utils.h"
|
|
#include "content/public/browser/download_manager.h"
|
|
#include "net/base/filename_util.h"
|
|
#include "shell/browser/api/electron_api_download_item.h"
|
|
#include "shell/browser/electron_browser_context.h"
|
|
#include "shell/browser/javascript_environment.h"
|
|
#include "shell/browser/native_window.h"
|
|
#include "shell/browser/ui/file_dialog.h"
|
|
#include "shell/browser/web_contents_preferences.h"
|
|
#include "shell/common/gin_converters/callback_converter.h"
|
|
#include "shell/common/gin_converters/file_path_converter.h"
|
|
#include "shell/common/options_switches.h"
|
|
|
|
namespace electron {
|
|
|
|
namespace {
|
|
|
|
// Generate default file path to save the download.
|
|
base::FilePath CreateDownloadPath(const GURL& url,
|
|
const std::string& content_disposition,
|
|
const std::string& suggested_filename,
|
|
const std::string& mime_type,
|
|
const base::FilePath& last_saved_directory,
|
|
const base::FilePath& default_download_path) {
|
|
auto generated_name =
|
|
net::GenerateFileName(url, content_disposition, std::string(),
|
|
suggested_filename, mime_type, "download");
|
|
|
|
base::FilePath download_path;
|
|
|
|
// If the last saved directory is a non-empty existent path, use it as the
|
|
// default.
|
|
if (last_saved_directory.empty() || !base::PathExists(last_saved_directory)) {
|
|
download_path = default_download_path;
|
|
|
|
if (!base::PathExists(download_path))
|
|
base::CreateDirectory(download_path);
|
|
} else {
|
|
// Otherwise use the global default.
|
|
download_path = last_saved_directory;
|
|
}
|
|
|
|
return download_path.Append(generated_name);
|
|
}
|
|
|
|
} // namespace
|
|
|
|
ElectronDownloadManagerDelegate::ElectronDownloadManagerDelegate(
|
|
content::DownloadManager* manager)
|
|
: download_manager_(manager) {}
|
|
|
|
ElectronDownloadManagerDelegate::~ElectronDownloadManagerDelegate() {
|
|
if (download_manager_) {
|
|
DCHECK_EQ(static_cast<content::DownloadManagerDelegate*>(this),
|
|
download_manager_->GetDelegate());
|
|
download_manager_->SetDelegate(nullptr);
|
|
download_manager_ = nullptr;
|
|
}
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::GetItemSavePath(
|
|
download::DownloadItem* item,
|
|
base::FilePath* path) {
|
|
api::DownloadItem* download = api::DownloadItem::FromDownloadItem(item);
|
|
if (download)
|
|
*path = download->GetSavePath();
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::GetItemSaveDialogOptions(
|
|
download::DownloadItem* item,
|
|
file_dialog::DialogSettings* options) {
|
|
api::DownloadItem* download = api::DownloadItem::FromDownloadItem(item);
|
|
if (download)
|
|
*options = download->GetSaveDialogOptions();
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::OnDownloadPathGenerated(
|
|
uint32_t download_id,
|
|
content::DownloadTargetCallback callback,
|
|
const base::FilePath& default_path) {
|
|
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
|
base::ThreadRestrictions::ScopedAllowIO allow_io;
|
|
|
|
auto* item = download_manager_->GetDownload(download_id);
|
|
if (!item)
|
|
return;
|
|
|
|
NativeWindow* window = nullptr;
|
|
content::WebContents* web_contents =
|
|
content::DownloadItemUtils::GetWebContents(item);
|
|
auto* relay =
|
|
web_contents ? NativeWindowRelay::FromWebContents(web_contents) : nullptr;
|
|
if (relay)
|
|
window = relay->GetNativeWindow();
|
|
|
|
// Show save dialog if save path was not set already on item
|
|
base::FilePath path;
|
|
GetItemSavePath(item, &path);
|
|
if (path.empty()) {
|
|
file_dialog::DialogSettings settings;
|
|
GetItemSaveDialogOptions(item, &settings);
|
|
|
|
if (!settings.parent_window)
|
|
settings.parent_window = window;
|
|
if (settings.title.empty())
|
|
settings.title = item->GetURL().spec();
|
|
if (settings.default_path.empty())
|
|
settings.default_path = default_path;
|
|
|
|
auto* web_preferences = WebContentsPreferences::From(web_contents);
|
|
const bool offscreen = !web_preferences || web_preferences->IsOffscreen();
|
|
settings.force_detached = offscreen;
|
|
|
|
v8::Isolate* isolate = JavascriptEnvironment::GetIsolate();
|
|
v8::HandleScope scope(isolate);
|
|
gin_helper::Promise<gin_helper::Dictionary> dialog_promise(isolate);
|
|
auto dialog_callback = base::BindOnce(
|
|
&ElectronDownloadManagerDelegate::OnDownloadSaveDialogDone,
|
|
base::Unretained(this), download_id, std::move(callback));
|
|
|
|
std::ignore = dialog_promise.Then(std::move(dialog_callback));
|
|
file_dialog::ShowSaveDialog(settings, std::move(dialog_promise));
|
|
} else {
|
|
std::move(callback).Run(path,
|
|
download::DownloadItem::TARGET_DISPOSITION_PROMPT,
|
|
download::DOWNLOAD_DANGER_TYPE_NOT_DANGEROUS,
|
|
item->GetMixedContentStatus(), path, absl::nullopt,
|
|
download::DOWNLOAD_INTERRUPT_REASON_NONE);
|
|
}
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::OnDownloadSaveDialogDone(
|
|
uint32_t download_id,
|
|
content::DownloadTargetCallback download_callback,
|
|
gin_helper::Dictionary result) {
|
|
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
|
|
|
auto* item = download_manager_->GetDownload(download_id);
|
|
if (!item)
|
|
return;
|
|
|
|
bool canceled = true;
|
|
result.Get("canceled", &canceled);
|
|
|
|
base::FilePath path;
|
|
|
|
if (!canceled) {
|
|
if (result.Get("filePath", &path)) {
|
|
// Remember the last selected download directory.
|
|
last_saved_directory_ = path.DirName();
|
|
|
|
api::DownloadItem* download = api::DownloadItem::FromDownloadItem(item);
|
|
if (download)
|
|
download->SetSavePath(path);
|
|
}
|
|
}
|
|
|
|
// Running the DownloadTargetCallback with an empty FilePath signals that the
|
|
// download should be cancelled. If user cancels the file save dialog, run
|
|
// the callback with empty FilePath.
|
|
const auto interrupt_reason =
|
|
path.empty() ? download::DOWNLOAD_INTERRUPT_REASON_USER_CANCELED
|
|
: download::DOWNLOAD_INTERRUPT_REASON_NONE;
|
|
std::move(download_callback)
|
|
.Run(path, download::DownloadItem::TARGET_DISPOSITION_PROMPT,
|
|
download::DOWNLOAD_DANGER_TYPE_NOT_DANGEROUS,
|
|
item->GetMixedContentStatus(), path, absl::nullopt,
|
|
interrupt_reason);
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::Shutdown() {
|
|
weak_ptr_factory_.InvalidateWeakPtrs();
|
|
download_manager_ = nullptr;
|
|
}
|
|
|
|
bool ElectronDownloadManagerDelegate::DetermineDownloadTarget(
|
|
download::DownloadItem* download,
|
|
content::DownloadTargetCallback* callback) {
|
|
DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
|
|
|
|
if (!download->GetForcedFilePath().empty()) {
|
|
std::move(*callback).Run(
|
|
download->GetForcedFilePath(),
|
|
download::DownloadItem::TARGET_DISPOSITION_OVERWRITE,
|
|
download::DOWNLOAD_DANGER_TYPE_NOT_DANGEROUS,
|
|
download::DownloadItem::MixedContentStatus::UNKNOWN,
|
|
download->GetForcedFilePath(), absl::nullopt,
|
|
download::DOWNLOAD_INTERRUPT_REASON_NONE);
|
|
return true;
|
|
}
|
|
|
|
// Try to get the save path from JS wrapper.
|
|
base::FilePath save_path;
|
|
GetItemSavePath(download, &save_path);
|
|
if (!save_path.empty()) {
|
|
std::move(*callback).Run(
|
|
save_path, download::DownloadItem::TARGET_DISPOSITION_OVERWRITE,
|
|
download::DOWNLOAD_DANGER_TYPE_NOT_DANGEROUS,
|
|
download::DownloadItem::MixedContentStatus::UNKNOWN, save_path,
|
|
absl::nullopt, download::DOWNLOAD_INTERRUPT_REASON_NONE);
|
|
return true;
|
|
}
|
|
|
|
auto* browser_context = static_cast<ElectronBrowserContext*>(
|
|
download_manager_->GetBrowserContext());
|
|
base::FilePath default_download_path =
|
|
browser_context->prefs()->GetFilePath(prefs::kDownloadDefaultDirectory);
|
|
|
|
base::ThreadPool::PostTaskAndReplyWithResult(
|
|
FROM_HERE,
|
|
{base::MayBlock(), base::TaskPriority::BEST_EFFORT,
|
|
base::TaskShutdownBehavior::SKIP_ON_SHUTDOWN},
|
|
base::BindOnce(&CreateDownloadPath, download->GetURL(),
|
|
download->GetContentDisposition(),
|
|
download->GetSuggestedFilename(), download->GetMimeType(),
|
|
last_saved_directory_, default_download_path),
|
|
base::BindOnce(&ElectronDownloadManagerDelegate::OnDownloadPathGenerated,
|
|
weak_ptr_factory_.GetWeakPtr(), download->GetId(),
|
|
std::move(*callback)));
|
|
return true;
|
|
}
|
|
|
|
bool ElectronDownloadManagerDelegate::ShouldOpenDownload(
|
|
download::DownloadItem* download,
|
|
content::DownloadOpenDelayedCallback callback) {
|
|
return true;
|
|
}
|
|
|
|
void ElectronDownloadManagerDelegate::GetNextId(
|
|
content::DownloadIdCallback callback) {
|
|
static uint32_t next_id = download::DownloadItem::kInvalidId + 1;
|
|
std::move(callback).Run(next_id++);
|
|
}
|
|
|
|
} // namespace electron
|