87c183df6a
* chore: bump chromium in DEPS to 109.0.5386.0 * chore: bump chromium in DEPS to 109.0.5388.0 * chore: bump chromium in DEPS to 109.0.5390.0 * chore: bump chromium in DEPS to 109.0.5392.0 * chore: bump chromium in DEPS to 109.0.5394.0 * chore: bump chromium in DEPS to 109.0.5396.0 * chore: bump chromium in DEPS to 109.0.5398.0 * chore: bump chromium in DEPS to 109.0.5400.0 * chore: update galactus * chore: bump chromium in DEPS to 109.0.5402.0 * chore: bump chromium in DEPS to 109.0.5403.0 * chore: bump chromium in DEPS to 109.0.5406.0 * chore: update patches * 4004247: Delete unused DocumentWebContentsDelegate Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4004247 * chore: bump chromium in DEPS to 109.0.5408.1 * chore: update patches * 3949284: Support pkey debug mode without pkey 0 access Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3949284 * chore: bump chromium in DEPS to 109.0.5410.0 * chore: update patches * 4000944: [Extensions] Create an API directory in //chrome/renderer/extensions Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4000944 * 3988524: Remove DocumentOverlayWindowViews | https://chromium-review.googlesource.com/c/chromium/src/+/3988524 Co-authored-by: George Xu <33054982+georgexu99@users.noreply.github.com> * chore: bump chromium in DEPS to 109.0.5412.0 * chore: update patches * 3984022: Add AddChildWindowToBrowser to DisplayClient mojo interface Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3984022 * 3957079: Delete the CryptoToken component extension and internal API Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3957079 * 4004421: Migreate ScopedAllowIO to ScopedAllowBlocking Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4004421 Co-authored-by: George Xu <georgexu99@users.noreply.github.com> * chore: bump chromium in DEPS to 109.0.5414.0 * chore: update patches * 4016180: Split PPAPI Mojo interfaces out of RenderFrameHostImpl. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4016180 * 3970838: [MPArch] Convert HostZoomMap and ZoomController off of RenderViewHost ids Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3970838 * 3997795: Don't add Chromium as a login item Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3997795 * 3993482: Remove RefCountedString::TakeString Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3993482 * 3990749: Allow forward-declared sources in base::ScopedObservation<> Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3990749 * fixup! 3957079: Delete the CryptoToken component extension and internal API * chore: bump chromium in DEPS to 110.0.5415.0 * 3883790: Move devtools_frame_token to the RenderFrameHost, to preserve RFH identity across MPArch activations. https://chromium-review.googlesource.com/c/chromium/src/+/3883790 * 4022205: Move license tooling into //tools/licenses https://chromium-review.googlesource.com/c/chromium/src/+/4022205 * chore: fixup patch indices * fixup! 3957079: Delete the CryptoToken component extension and internal API * 4008687: Finish ScopedAllowIO migration https://chromium-review.googlesource.com/c/chromium/src/+/4008687 * 3991548: Move WindowButtonOrderObserver and WindowFrameAction to LinuxUi https://chromium-review.googlesource.com/c/chromium/src/+/3991548 * fixup! 3984022: Add AddChildWindowToBrowser to DisplayClient mojo interface * 4016595: Migrate non-default ScopedObservation<> instantiations to ScopedObservationTraits<> in chrome/browser/ https://chromium-review.googlesource.com/c/chromium/src/+/4016595 * 4000481: Rename :chromedriver to :chromedriver_server Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4000481 * 4008687: Finish ScopedAllowIO migration https://chromium-review.googlesource.com/c/chromium/src/+/4008687 * 3988524: Remove DocumentOverlayWindowViews https://chromium-review.googlesource.com/c/chromium/src/+/3988524 * fixup! 3997795: Don't add Chromium as a login item * chore: fixup patches * 3996872: Plumb input event task runner to EventFactoryEvdev https://chromium-review.googlesource.com/c/chromium/src/+/3996872 * 4014994: Enable SiteIsolationForGuests by default. https://chromium-review.googlesource.com/c/chromium/src/+/4014994 * chore: adopt new thread restrictions api for //electron (#36357) chore: add thread blocking api * fixup! 4014994: Enable SiteIsolationForGuests by default. * pull parent HWND for dialogs on ui thread * chore: set parent_window in MessageBoxSettings * chore: remove redundant patch * chore: revert accidental deletion * chore: update patches Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <sattard@salesforce.com> Co-authored-by: Keeley Hammond <khammond@slack-corp.com> Co-authored-by: VerteDinde <vertedinde@electronjs.org> Co-authored-by: George Xu <33054982+georgexu99@users.noreply.github.com> Co-authored-by: George Xu <georgexu99@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: Robo <hop2deep@gmail.com> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
217 lines
6.3 KiB
C++
217 lines
6.3 KiB
C++
// Copyright 2013 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/app/electron_crash_reporter_client.h"
|
|
|
|
#include <map>
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "base/command_line.h"
|
|
#include "base/environment.h"
|
|
#include "base/files/file_path.h"
|
|
#include "base/files/file_util.h"
|
|
#include "base/logging.h"
|
|
#include "base/path_service.h"
|
|
#include "base/strings/string_split.h"
|
|
#include "base/strings/utf_string_conversions.h"
|
|
#include "build/build_config.h"
|
|
#include "chrome/common/chrome_paths.h"
|
|
#include "components/crash/core/common/crash_keys.h"
|
|
#include "components/upload_list/crash_upload_list.h"
|
|
#include "content/public/common/content_switches.h"
|
|
#include "electron/electron_version.h"
|
|
#include "shell/common/electron_paths.h"
|
|
#include "shell/common/thread_restrictions.h"
|
|
|
|
#if BUILDFLAG(IS_POSIX) && !BUILDFLAG(IS_MAC)
|
|
#include "components/version_info/version_info_values.h"
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_POSIX)
|
|
#include "base/debug/dump_without_crashing.h"
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
#include "base/strings/string_util_win.h"
|
|
#endif
|
|
|
|
namespace {
|
|
|
|
ElectronCrashReporterClient* Instance() {
|
|
static base::NoDestructor<ElectronCrashReporterClient> crash_client;
|
|
return crash_client.get();
|
|
}
|
|
|
|
} // namespace
|
|
|
|
// static
|
|
void ElectronCrashReporterClient::Create() {
|
|
crash_reporter::SetCrashReporterClient(Instance());
|
|
|
|
// By setting the BREAKPAD_DUMP_LOCATION environment variable, an alternate
|
|
// location to write crash dumps can be set.
|
|
auto env = base::Environment::Create();
|
|
std::string alternate_crash_dump_location;
|
|
base::FilePath crash_dumps_dir_path;
|
|
if (env->GetVar("BREAKPAD_DUMP_LOCATION", &alternate_crash_dump_location)) {
|
|
crash_dumps_dir_path =
|
|
base::FilePath::FromUTF8Unsafe(alternate_crash_dump_location);
|
|
}
|
|
if (!crash_dumps_dir_path.empty()) {
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
base::PathService::Override(electron::DIR_CRASH_DUMPS,
|
|
crash_dumps_dir_path);
|
|
}
|
|
}
|
|
|
|
// static
|
|
ElectronCrashReporterClient* ElectronCrashReporterClient::Get() {
|
|
return Instance();
|
|
}
|
|
|
|
void ElectronCrashReporterClient::SetCollectStatsConsent(bool upload_allowed) {
|
|
collect_stats_consent_ = upload_allowed;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::SetUploadUrl(const std::string& url) {
|
|
upload_url_ = url;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::SetShouldRateLimit(bool rate_limit) {
|
|
rate_limit_ = rate_limit;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::SetShouldCompressUploads(bool compress) {
|
|
compress_uploads_ = compress;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::SetGlobalAnnotations(
|
|
const std::map<std::string, std::string>& annotations) {
|
|
global_annotations_ = annotations;
|
|
}
|
|
|
|
ElectronCrashReporterClient::ElectronCrashReporterClient() = default;
|
|
|
|
ElectronCrashReporterClient::~ElectronCrashReporterClient() = default;
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
void ElectronCrashReporterClient::SetCrashReporterClientIdFromGUID(
|
|
const std::string& client_guid) {
|
|
crash_keys::SetMetricsClientIdFromGUID(client_guid);
|
|
}
|
|
void ElectronCrashReporterClient::GetProductNameAndVersion(
|
|
const char** product_name,
|
|
const char** version) {
|
|
DCHECK(product_name);
|
|
DCHECK(version);
|
|
*product_name = ELECTRON_PRODUCT_NAME;
|
|
*version = ELECTRON_VERSION_STRING;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::GetProductNameAndVersion(
|
|
std::string* product_name,
|
|
std::string* version,
|
|
std::string* channel) {
|
|
const char* c_product_name;
|
|
const char* c_version;
|
|
GetProductNameAndVersion(&c_product_name, &c_version);
|
|
*product_name = c_product_name;
|
|
*version = c_version;
|
|
*channel = "";
|
|
}
|
|
|
|
base::FilePath ElectronCrashReporterClient::GetReporterLogFilename() {
|
|
return base::FilePath(CrashUploadList::kReporterLogFilename);
|
|
}
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
void ElectronCrashReporterClient::GetProductNameAndVersion(
|
|
const std::wstring& exe_path,
|
|
std::wstring* product_name,
|
|
std::wstring* version,
|
|
std::wstring* special_build,
|
|
std::wstring* channel_name) {
|
|
*product_name = base::UTF8ToWide(ELECTRON_PRODUCT_NAME);
|
|
*version = base::UTF8ToWide(ELECTRON_VERSION_STRING);
|
|
}
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
bool ElectronCrashReporterClient::GetCrashDumpLocation(
|
|
std::wstring* crash_dir_str) {
|
|
base::FilePath crash_dir;
|
|
if (!base::PathService::Get(electron::DIR_CRASH_DUMPS, &crash_dir))
|
|
return false;
|
|
*crash_dir_str = crash_dir.value();
|
|
return true;
|
|
}
|
|
#else
|
|
bool ElectronCrashReporterClient::GetCrashDumpLocation(
|
|
base::FilePath* crash_dir) {
|
|
bool result = base::PathService::Get(electron::DIR_CRASH_DUMPS, crash_dir);
|
|
{
|
|
// If the DIR_CRASH_DUMPS path is overridden with
|
|
// app.setPath('crashDumps', ...) then the directory might not have been
|
|
// created.
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
if (result && !base::PathExists(*crash_dir)) {
|
|
return base::CreateDirectory(*crash_dir);
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
bool ElectronCrashReporterClient::IsRunningUnattended() {
|
|
return !collect_stats_consent_;
|
|
}
|
|
|
|
bool ElectronCrashReporterClient::GetCollectStatsConsent() {
|
|
return collect_stats_consent_;
|
|
}
|
|
|
|
#if BUILDFLAG(IS_MAC)
|
|
bool ElectronCrashReporterClient::ReportingIsEnforcedByPolicy(
|
|
bool* breakpad_enabled) {
|
|
return false;
|
|
}
|
|
#endif
|
|
|
|
bool ElectronCrashReporterClient::GetShouldRateLimit() {
|
|
return rate_limit_;
|
|
}
|
|
|
|
bool ElectronCrashReporterClient::GetShouldCompressUploads() {
|
|
return compress_uploads_;
|
|
}
|
|
|
|
void ElectronCrashReporterClient::GetProcessSimpleAnnotations(
|
|
std::map<std::string, std::string>* annotations) {
|
|
for (auto&& pair : global_annotations_) {
|
|
(*annotations)[pair.first] = pair.second;
|
|
}
|
|
(*annotations)["prod"] = ELECTRON_PRODUCT_NAME;
|
|
(*annotations)["ver"] = ELECTRON_VERSION_STRING;
|
|
}
|
|
|
|
#if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_MAC)
|
|
bool ElectronCrashReporterClient::ShouldMonitorCrashHandlerExpensively() {
|
|
return false;
|
|
}
|
|
#endif
|
|
|
|
std::string ElectronCrashReporterClient::GetUploadUrl() {
|
|
return upload_url_;
|
|
}
|
|
|
|
bool ElectronCrashReporterClient::EnableBreakpadForProcess(
|
|
const std::string& process_type) {
|
|
return process_type == switches::kRendererProcess ||
|
|
process_type == switches::kPpapiPluginProcess ||
|
|
process_type == switches::kZygoteProcess ||
|
|
process_type == switches::kGpuProcess ||
|
|
process_type == switches::kUtilityProcess || process_type == "node";
|
|
}
|