
* chore: bump chromium in DEPS to 520c02b46668fc608927e0fcd79b6a90885a48bf * chore: bump chromium in DEPS to 90.0.4414.0 * resolve chromium conflicts * resolve v8 conflicts * fix node gn files * 2673502: Remove RenderViewCreated use from ExtensionHost.2673502
* 2676903: [mojo] Remove most legacy Binding classes.2676903
* 2644847: Move self-deleting URLLoaderFactory base into //services/network.2644847
* 2664006: Remove from mojo::DataPipe.2664006
* 2674530: Remove CertVerifierService feature2674530
* 2668748: Move OnSSLCertificateError to a new interface.2668748
* 2672923: Remove RAPPOR reporting infrastructure.2672923
* 2673502: Remove RenderViewCreated use from ExtensionHost.2673502
* 2655126: Convert FrameHostMsg_ContextMenu and FrameMsg_ContextMenuClosed|CustomContextMenuAction to Mojo2655126
* 2628705: Window Placement: Implement screen.isExtended and change event2628705
* 2643161: Refactor storage::kFileSystem*Native*2643161
* fix build * only remove the biggest subdir of //ios * chore: bump chromium in DEPS to 90.0.4415.0 * update patches * update sysroots * 2686147: Remove WebContentsObserver::RenderViewCreated().2686147
* 2596429: Fixing how extension's split and spanning modes affect OriginAccessList.2596429
* 2686026: [mojo] Delete AssociatedInterfacePtr (replaced by AssociatedRemote)2686026
* 2651705: Move ui/base/dragdrop/file_info to ui/base/clipboard2651705
* 358217: drawBitmap is deprecated https://skia-review.googlesource.com/c/skia/+/358217 * fix gn check * 2678098: Use gen/front_end as input to generate_devtools_grd2678098
* 2674530: Remove CertVerifierService feature2674530
* fixup 2664006: Remove from mojo::DataPipe.2664006
* fixup build_add_electron_tracing_category.patch * 2673415: [base] Prepare CrashReporterClient for string16 switch2673415
* 2673413: Add CursorFactoryWin to handle Cursors on Windows2673413
* 2668748: Move OnSSLCertificateError to a new interface.2668748
* fix mas gn check * update patch after merge * Update node for .mjs files * build: load v8_prof_processor dependencies as ESM * chore: add patch to fix linux 32bit Co-authored-by: Jeremy Rose <nornagon@nornagon.net> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: Samuel Attard <samuel.r.attard@gmail.com>
96 lines
3.1 KiB
C++
96 lines
3.1 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.
|
|
|
|
#ifndef SHELL_APP_ELECTRON_CRASH_REPORTER_CLIENT_H_
|
|
#define SHELL_APP_ELECTRON_CRASH_REPORTER_CLIENT_H_
|
|
|
|
#include <map>
|
|
#include <string>
|
|
|
|
#include "base/compiler_specific.h"
|
|
#include "base/macros.h"
|
|
#include "base/no_destructor.h"
|
|
#include "build/build_config.h"
|
|
#include "components/crash/core/app/crash_reporter_client.h"
|
|
|
|
class ElectronCrashReporterClient : public crash_reporter::CrashReporterClient {
|
|
public:
|
|
static void Create();
|
|
|
|
static ElectronCrashReporterClient* Get();
|
|
void SetCollectStatsConsent(bool upload_allowed);
|
|
void SetUploadUrl(const std::string& url);
|
|
void SetShouldRateLimit(bool rate_limit);
|
|
void SetShouldCompressUploads(bool compress_uploads);
|
|
void SetGlobalAnnotations(
|
|
const std::map<std::string, std::string>& annotations);
|
|
|
|
// crash_reporter::CrashReporterClient implementation.
|
|
#if defined(OS_LINUX)
|
|
void SetCrashReporterClientIdFromGUID(
|
|
const std::string& client_guid) override;
|
|
void GetProductNameAndVersion(const char** product_name,
|
|
const char** version) override;
|
|
void GetProductNameAndVersion(std::string* product_name,
|
|
std::string* version,
|
|
std::string* channel) override;
|
|
base::FilePath GetReporterLogFilename() override;
|
|
#endif
|
|
|
|
#if defined(OS_WIN)
|
|
void GetProductNameAndVersion(const std::wstring& exe_path,
|
|
std::wstring* product_name,
|
|
std::wstring* version,
|
|
std::wstring* special_build,
|
|
std::wstring* channel_name) override;
|
|
#endif
|
|
|
|
#if defined(OS_WIN)
|
|
bool GetCrashDumpLocation(std::wstring* crash_dir) override;
|
|
#else
|
|
bool GetCrashDumpLocation(base::FilePath* crash_dir) override;
|
|
#endif
|
|
|
|
#if defined(OS_MAC) || defined(OS_LINUX)
|
|
bool GetCrashMetricsLocation(base::FilePath* metrics_dir) override;
|
|
#endif
|
|
|
|
bool IsRunningUnattended() override;
|
|
|
|
bool GetCollectStatsConsent() override;
|
|
|
|
bool GetShouldRateLimit() override;
|
|
bool GetShouldCompressUploads() override;
|
|
|
|
void GetProcessSimpleAnnotations(
|
|
std::map<std::string, std::string>* annotations) override;
|
|
|
|
#if defined(OS_MAC)
|
|
bool ReportingIsEnforcedByPolicy(bool* breakpad_enabled) override;
|
|
#endif
|
|
|
|
#if defined(OS_MAC) || defined(OS_LINUX)
|
|
bool ShouldMonitorCrashHandlerExpensively() override;
|
|
#endif
|
|
|
|
bool EnableBreakpadForProcess(const std::string& process_type) override;
|
|
|
|
std::string GetUploadUrl() override;
|
|
|
|
private:
|
|
friend class base::NoDestructor<ElectronCrashReporterClient>;
|
|
|
|
std::string upload_url_;
|
|
bool collect_stats_consent_ = false;
|
|
bool rate_limit_ = false;
|
|
bool compress_uploads_ = false;
|
|
std::map<std::string, std::string> global_annotations_;
|
|
|
|
ElectronCrashReporterClient();
|
|
~ElectronCrashReporterClient() override;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(ElectronCrashReporterClient);
|
|
};
|
|
|
|
#endif // SHELL_APP_ELECTRON_CRASH_REPORTER_CLIENT_H_
|