a006cf681b
* chore: bump chromium in DEPS to 91.0.4435.3 * build: add 'use_rts' definition Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2694187 * chore: update patches * chore: media_internal_resources becomes resources Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2699022 * chore: update patches * refactor: extensions::ViewType moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2710351 * chore: might_have_observers has been removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2667839 * refactor: CertVerifier is not in the network namespace anymore Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2689805 * refactor: ExtensionUserScriptManager is now UserScriptManager Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2657617 * refactor: content::SiteInstance::GetSiteForURL was removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2680274 * refactor: MenuItemType was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2071443 * refactor: extensions::ViewType was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2710351 * refacotr: grit::ResourceMap replaced with webui::ResourcePath Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2685601 * refactor: blink::MenuItem::Type was moved to mojom Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2071443 * refactor: CreateDataPipe deprecated form was removed Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2698090 * refactor: DesktopMediaList::Type replaces content::DesktopMediaType_* Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2700637 * chore: wire up activation_time in OSR Refs: https://chromium-review.googlesource.com/c/chromium/src/+/2638372 * chore: remove deleted file from chromium_src list * chore: fix lint * update patches * chore: bump chromium in DEPS to 91.0.4438.0 * chore: bump chromium in DEPS to 91.0.4439.0 * chore: bump chromium in DEPS to 91.0.4440.0 * chore: bump chromium in DEPS to 91.0.4441.0 * chore: bump chromium in DEPS to 91.0.4442.0 * chore: bump chromium in DEPS to 91.0.4443.0 * chore: bump chromium in DEPS to 91.0.4445.0 * chore: bump chromium in DEPS to 91.0.4446.0 * chore: update patches * fixup gn check * Merge branch 'master' into roller/chromium/master * update to xcode 12.4.0 Needed because of8008deb41c
* 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 * 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 * 2752932: Associate each AwProxyingURLLoaderFactory with a frame tree node id. https://chromium-review.googlesource.com/c/chromium/src/+/2752932 * 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer. https://chromium-review.googlesource.com/c/chromium/src/+/2651385 * 2734095: Introduce StoragePartitionId type to wrap current string representation. https://chromium-review.googlesource.com/c/chromium/src/+/2734095 * chore: bump chromium in DEPS to 91.0.4448.0 * Update patches * 2743594: Remove WebSize from blink. https://chromium-review.googlesource.com/c/chromium/src/+/2743594 * 2725403: Add URLLoaderClient::OnReceiveEarlyHints() https://chromium-review.googlesource.com/c/chromium/src/+/2725403 * 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer. https://chromium-review.googlesource.com/c/chromium/src/+/2651385 * 2721718: Move HostID to extensions::mojom::HostID https://chromium-review.googlesource.com/c/chromium/src/+/2721718 * 2733070: Rename observer to URLLoaderNetworkServiceObserver https://chromium-review.googlesource.com/c/chromium/src/+/2733070 * Use nogncheck for content/browser/site_instance_impl.h This is needed because //content/browser:browser is not a visible target * 2648046: Introduce alert notification helper .app https://chromium-review.googlesource.com/c/chromium/src/+/2648046 * 2752406: [LSC] Replace base::string16 with std::u16string in //ui https://chromium-review.googlesource.com/c/chromium/src/+/2752406 * only include mac notifications on mac * add additional skipping of atk toolchain check * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 * 2720306: [api] Remove deprecated [Shared]ArrayBuffer API https://chromium-review.googlesource.com/c/v8/v8/+/2720306 * Fixup 2721718: Move HostID to extensions::mojom::HostID * fixup 2651385: Moving Profile::shared_cors_origin_access_list_ into //content layer * Fixup 2752406: [LSC] Replace base::string16 with std::u16string in //ui * Fixup 2725403: Add URLLoaderClient::OnReceiveEarlyHints() * update node headers * chore: bump chromium in DEPS to 91.0.4449.0 * Revert "chore: bump chromium in DEPS to 91.0.4449.0" This reverts commitbccafa0289
. * 2693008: Fix loading non-system cursors on Windows on browser_tests https://chromium-review.googlesource.com/c/chromium/src/+/2693008 * 2757472: Reland "Reland "[LSC] Remove base::string16 alias"" https://chromium-review.googlesource.com/c/chromium/src/+/2757472 * undo changes to WebContentsPreferences::GetPreloadPath to fix mac build * fix StrCat issue * incantations for WebContentsPreferences::GetPreloadPath wide strings * bump nan * fix GetAsString maybe? * windows build fixes * more windows build fix * SetAppUserModelID -> wstring * upgrade nan dep in tests * lint * wstrings are cross-platform * linter * only bind setAppUserModelId on windows * fix a messed up merge * well that was an odyssey * backport fcdf35e from v8 to fix nan crash * disable typedarrays-test.js * don't defer in NSWindow creation https://chromium-review.googlesource.com/c/chromium/src/+/2707696 * use PartitionAllocator for ArrayBuffers in the main process * fix patches * chore: omit some unnecessary conversions * refactor: make LoginItemSettings::path a wstring * refactor: make ShowTaskDialog take a wstr * Revert "refactor: make LoginItemSettings::path a wstring" This reverts commit9127cff58b
. Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: John Kleinschmidt <jkleinsc@github.com> Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: Charles Kerr <charles@charleskerr.com>
219 lines
6.4 KiB
C++
219 lines
6.4 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 "base/threading/thread_restrictions.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"
|
|
|
|
#if defined(OS_POSIX) && !defined(OS_MAC)
|
|
#include "components/version_info/version_info_values.h"
|
|
#endif
|
|
|
|
#if defined(OS_POSIX)
|
|
#include "base/debug/dump_without_crashing.h"
|
|
#endif
|
|
|
|
#if defined(OS_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.
|
|
std::unique_ptr<base::Environment> 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()) {
|
|
base::ThreadRestrictions::ScopedAllowIO allow_io;
|
|
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() {}
|
|
|
|
ElectronCrashReporterClient::~ElectronCrashReporterClient() {}
|
|
|
|
#if defined(OS_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 defined(OS_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 defined(OS_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);
|
|
{
|
|
base::ThreadRestrictions::ScopedAllowIO allow_io;
|
|
if (result && !base::PathExists(*crash_dir)) {
|
|
return base::CreateDirectory(*crash_dir);
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
#endif
|
|
|
|
#if defined(OS_MAC) || defined(OS_LINUX)
|
|
bool ElectronCrashReporterClient::GetCrashMetricsLocation(
|
|
base::FilePath* metrics_dir) {
|
|
return base::PathService::Get(electron::DIR_USER_DATA, metrics_dir);
|
|
}
|
|
#endif // OS_MAC || OS_LINUX
|
|
|
|
bool ElectronCrashReporterClient::IsRunningUnattended() {
|
|
return !collect_stats_consent_;
|
|
}
|
|
|
|
bool ElectronCrashReporterClient::GetCollectStatsConsent() {
|
|
return collect_stats_consent_;
|
|
}
|
|
|
|
#if defined(OS_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) {
|
|
*annotations = global_annotations_;
|
|
(*annotations)["prod"] = ELECTRON_PRODUCT_NAME;
|
|
(*annotations)["ver"] = ELECTRON_VERSION_STRING;
|
|
}
|
|
|
|
#if defined(OS_LINUX) || defined(OS_MAC)
|
|
bool ElectronCrashReporterClient::ShouldMonitorCrashHandlerExpensively() {
|
|
return false;
|
|
}
|
|
#endif // OS_LINUX
|
|
|
|
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";
|
|
}
|