feaf18e371
* chore: bump chromium in DEPS to 112.0.5576.0 * 4211172: Use the Mac ImageTransportSurface on iOS. https://chromium-review.googlesource.com/c/chromium/src/+/4211172 * 4191759: Reuse PrintBackend process from query for printing https://chromium-review.googlesource.com/c/chromium/src/+/4191759 * 4189718: Revert "[code health] Remove NotificationService use by SpellcheckService" https://chromium-review.googlesource.com/c/chromium/src/+/4189718 * 4216074: web_contents_delegate: remove content:: https://chromium-review.googlesource.com/c/chromium/src/+/4216074 * 4192284: ios: Add feature flag for PartitionAlloc. https://chromium-review.googlesource.com/c/chromium/src/+/4192284 * chore: bump chromium in DEPS to 112.0.5578.0 * 4211172: Use the Mac ImageTransportSurface on iOS. https://chromium-review.googlesource.com/c/chromium/src/+/4211172 * 4067682: Define ThirdPartyCookiesUserBypass runtime feature and plumb it through to URLRequest.cookie_setting_overrides. https://chromium-review.googlesource.com/c/chromium/src/+/4067682 * chore: fixup patch indices * 4218354: Disable the use of preserve_most on arm64 Windows https://chromium-review.googlesource.com/c/v8/v8/+/4218354 * chore: fixup patch indices * chore: bump chromium in DEPS to 112.0.5579.0 * chore: update patches * chore: bump chromium in DEPS to 112.0.5581.0 * chore: update patches * refactor: use modern base values in tracing Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4210912 * refactor: remove GetFontLookupTableCacheDir Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4191820 * refactor: base value type DICTIONARY replaced with DICT Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4198081 * chore: add stub impls for WCO routing Refs: https://chromium-review.googlesource.com/c/chromium/src/+/4182690 * refactor: rename latency metrics Refs: https://chromium-review.googlesource.com/c/chromium/src/+/4048262 * refactor: add sanitized context to clipboard write Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4178264 * refactor: s/Rect/WindowFeatures Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4167001 * refacotr: switch mojom::NetworkHintsHandler to use SchemeHostPair instead of URL Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4185417 * chore: remove dead DecodeToken code * refactor: refactoring geolocation manager Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4161603 * chore: iwyu net/cert/cert_verify_result.h * build: use xcode 14 * chore: bump chromium in DEPS to 112.0.5583.0 * chore: update patches * chore: fixup mas patches * refactor: base::span explicit conversion checks Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4219636 * chore: bump chromium in DEPS to 112.0.5591.0 * chore: bump chromium in DEPS to 112.0.5593.0 * chore: bump chromium in DEPS to 112.0.5594.3 * chore: bump chromium in DEPS to 112.0.5597.0 * chore: update chromium patches * 4242507: Move most of GetChromeKeySystems() into components/cdm Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4242507 It seems as though the bug this patch was trying to resolve is now fixed. * chore: update v8 patches * 4240798: Get rid of ShowInvalidPrinterSettingsError() in PrintManagerHost. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4240798 * 4247938: Bump min required GTK version to 3.20 Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4247938 * 4173660: Remove unused argument in BeforeUnloadCompleted Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4173660 * 4226656: Add response url to SimpleURLLoader::OnRedirectCallback Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4226656 * fixup!: 4240798: Get rid of ShowInvalidPrinterSettingsError() in PrintManager Host. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4240798 * chore: bump chromium in DEPS to 112.0.5599.0 * chore: update patches * 4251237: [StorageKey Cleanup] (2) Rename CreateFirstParty constructors Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4251237 * 4256866: [Extensions] Replace GetHooksForAPI with a RegisterHooksDelegate Ref: https://chromium-review.googlesource.com/c/chromium/src/+/4256866 * chore: bump chromium in DEPS to 112.0.5601.0 * chore: update patches * chore: bump chromium in DEPS to 112.0.5603.0 * chore: bump chromium in DEPS to 112.0.5605.0 * chore: bump chromium in DEPS to 112.0.5607.0 * update patches * fix mas patch * chore: bump chromium in DEPS to 112.0.5609.0 * chore: update patches * build: update appveyor image 4072083: New toolchain for Windows 11 10.0.22621.755 SDK | https://chromium-review.googlesource.com/c/chromium/src/+/4072083 * chore: bump chromium in DEPS to 112.0.5611.0 * fix patches * chore: update patches * 4261434: Remove browser_watcher (1/3): Move ExitCodeWatcher to chrome/app https://chromium-review.googlesource.com/c/chromium/src/+/4261434 * 4258446: Move network::mojom::ClearDataFilter to its own mojom file https://chromium-review.googlesource.com/c/chromium/src/+/4258446 * 4128591: Enable large pdbs by default https://chromium-review.googlesource.com/c/chromium/src/+/4128591 * move dbgcore/dbghelp to extensions_to_skip * chore: bump chromium in DEPS to 113.0.5624.0 * chore: bump chromium in DEPS to 113.0.5626.0 * chore: bump chromium in DEPS to 113.0.5628.2 * chore: bump chromium in DEPS to 113.0.5630.0 * chore: bump chromium in DEPS to 113.0.5632.0 * chore: bump chromium in DEPS to 113.0.5634.0 * chore: bump chromium in DEPS to 113.0.5636.0 * 4255184: Permit popups from fullscreen-within-tab openers https://chromium-review.googlesource.com/c/chromium/src/+/4255184 * 4297715: [mac] Introduce BluetoothLowEnergyAdapterApple to reuse CoreBluetooth https://chromium-review.googlesource.com/c/chromium/src/+/4297715 * 4301154: Remove GLContextCGL and cleanup relevant code https://chromium-review.googlesource.com/c/chromium/src/+/4301154 * 4278389: CDP: fix Page.addScriptToEvaluateOnNewDocument in iframes https://chromium-review.googlesource.com/c/chromium/src/+/4278389 * 4240798: Get rid of ShowInvalidPrinterSettingsError() in PrintManagerHost. https://chromium-review.googlesource.com/c/chromium/src/+/4240798 * 4291989: Refactor logic determining untrusted mojo invitation flag. https://chromium-review.googlesource.com/c/chromium/src/+/4291989 * 4110189: Add Select option to content touch selection menu. https://chromium-review.googlesource.com/c/chromium/src/+/4110189 * 4309923: [Extensions] Add a unit test for API permissions having features https://chromium-review.googlesource.com/c/chromium/src/+/4309923 * 4282657: Revert "[headless] Route stdio to parent console on Windows." https://chromium-review.googlesource.com/c/chromium/src/+/4282657 * 4306685: [v8] Improve V8 flag configuration to avoid errors https://chromium-review.googlesource.com/c/chromium/src/+/4306685 * 4295455: Add fallback Linux UI for when GTK 3.20 isn't available https://chromium-review.googlesource.com/c/chromium/src/+/4295455 * 4289774: Remove feature for shared sandbox policies https://chromium-review.googlesource.com/c/chromium/src/+/4289774 * 4292705: Rename WebSwapCGLLayer to ANGLESwapCGLLayer outside WebKit. https://chromium-review.googlesource.com/c/angle/angle/+/4292705 * chore: fixup patch indices * fixup! 4297715: [mac] Introduce BluetoothLowEnergyAdapterApple to reuse CoreBluetooth * 4289789: Remove base::JSONReader::ReadDeprecated https://chromium-review.googlesource.com/c/chromium/src/+/4289789 * 4281521: Remove `base::Value::FindKey()` https://chromium-review.googlesource.com/c/chromium/src/+/4281521 * 4276761: Update NAK constructor and GetIsCrossSite https://chromium-review.googlesource.com/c/chromium/src/+/4276761 * 4288119: Let GetUpload work with UploadInfo pointers https://chromium-review.googlesource.com/c/chromium/src/+/4288119 * 4285322: content: Move WebExposedIsolationLevel to its own public header https://chromium-review.googlesource.com/c/chromium/src/+/4285322 * 4251818: [Extensions] Make ExtensionSet moveable. https://chromium-review.googlesource.com/c/chromium/src/+/4251818 * 4299554: [json-schema-compiler] Refactor to Params::Create (14/74) https://chromium-review.googlesource.com/c/chromium/src/+/4299554 * chore: update printing patch indices * chore: update chromium/add_maximized_parameter_to_linuxui_getwindowframeprovider.patch Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4295455 Our patch changes the signature of `LinuxUiTheme::GetWindowFrameProvider()`. Upstream 4295455 added a new subclass (FallbackLinuxUi) so sync its version of GetWindowFrameProvider() to match our changes. * chore: disable node test parallel/test-intl Disabling the test because upstream is still working on this feature. Xref: https://chromium-review.googlesource.com/c/v8/v8/+/4237675 Xref: https://bugs.chromium.org/p/chromium/issues/detail?id=1414292 When upstream churn is done we should re-enable this test and update it as necessary. * win7dep: Remove ResolveCoreWinRTStringDelayload Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4277708 Upstream has removed this since Win7 support is deprecated. This updates our `language_util_win.cc` file using the same approach that 4277708 uses for `base/win/win_util.cc`. * fix: remove use of ResolveCoreWinRTDelayload() Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4297979 A followup to prev commit, which removed ResolveCoreWinRTStringDelayload(). This PR follows the 4297979 approach of simply removing the calls, e.g. https://chromium-review.googlesource.com/c/chromium/src/+/4297979/4/chrome/browser/device_reauth/win/authenticator_win.cc * fix: add d3dcompiler_47 to the zip manifest Xref: https://chromium-review.googlesource.com/c/angle/angle/+/4285717 Xref (24-x-y):0fb1def32b
* This clang roll breaks Linux arm 32-bit Xref (24-x-y):1229114494
Xref (chromium): https://crbug.com/1410101 * fix: WebUSB on ARM64 macs (#37441) * chore: update patches * chore: fix macOS CI build. Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4278307 That whole dir was previously being removed to save space since we don't use it. We still don't use anything in the file, but gn needs it to exist. * fixup! chore: fix macOS CI build. chore: mkdir --parents does not exist on BSD; use mkdir -p * chore: update chromium/mas_disable_remote_accessibility.patch Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4273450 Upstream added a new block of code using NSAccessibilityRemoteUIElement, so stub it out with `#if !IS_MAS_BUILD()` same as we do everwhere else. * chore: address code review nit :) --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <marshallofsound@electronjs.org> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org>
283 lines
9.5 KiB
C++
283 lines
9.5 KiB
C++
// Copyright (c) 2013 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/api/electron_api_crash_reporter.h"
|
|
|
|
#include <limits>
|
|
#include <map>
|
|
#include <string>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
#include "base/command_line.h"
|
|
#include "base/functional/bind.h"
|
|
#include "base/no_destructor.h"
|
|
#include "base/path_service.h"
|
|
#include "base/strings/utf_string_conversions.h"
|
|
#include "base/trace_event/trace_event.h"
|
|
#include "chrome/common/chrome_paths.h"
|
|
#include "components/upload_list/crash_upload_list.h"
|
|
#include "components/upload_list/text_log_upload_list.h"
|
|
#include "content/public/common/content_switches.h"
|
|
#include "gin/arguments.h"
|
|
#include "gin/data_object_builder.h"
|
|
#include "shell/common/electron_paths.h"
|
|
#include "shell/common/gin_converters/callback_converter.h"
|
|
#include "shell/common/gin_converters/file_path_converter.h"
|
|
#include "shell/common/gin_converters/time_converter.h"
|
|
#include "shell/common/gin_helper/dictionary.h"
|
|
#include "shell/common/node_includes.h"
|
|
#include "shell/common/thread_restrictions.h"
|
|
|
|
#if !IS_MAS_BUILD()
|
|
#include "components/crash/core/app/crashpad.h" // nogncheck
|
|
#include "components/crash/core/browser/crash_upload_list_crashpad.h" // nogncheck
|
|
#include "components/crash/core/common/crash_key.h"
|
|
#include "shell/app/electron_crash_reporter_client.h"
|
|
#include "shell/common/crash_keys.h"
|
|
#include "third_party/crashpad/crashpad/client/crashpad_info.h" // nogncheck
|
|
#endif
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
#include "base/containers/span.h"
|
|
#include "base/files/file_util.h"
|
|
#include "base/guid.h"
|
|
#include "components/crash/core/common/crash_keys.h"
|
|
#include "components/upload_list/combining_upload_list.h"
|
|
#include "v8/include/v8-wasm-trap-handler-posix.h"
|
|
#include "v8/include/v8.h"
|
|
#endif
|
|
|
|
namespace {
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
std::map<std::string, std::string>& GetGlobalCrashKeysMutable() {
|
|
static base::NoDestructor<std::map<std::string, std::string>>
|
|
global_crash_keys;
|
|
return *global_crash_keys;
|
|
}
|
|
#endif // BUILDFLAG(IS_LINUX)
|
|
|
|
bool g_crash_reporter_initialized = false;
|
|
|
|
} // namespace
|
|
|
|
namespace electron::api::crash_reporter {
|
|
|
|
#if IS_MAS_BUILD()
|
|
namespace {
|
|
|
|
void NoOp() {}
|
|
|
|
} // namespace
|
|
#endif
|
|
|
|
bool IsCrashReporterEnabled() {
|
|
return g_crash_reporter_initialized;
|
|
}
|
|
|
|
#if BUILDFLAG(IS_LINUX)
|
|
const std::map<std::string, std::string>& GetGlobalCrashKeys() {
|
|
return GetGlobalCrashKeysMutable();
|
|
}
|
|
|
|
bool GetClientIdPath(base::FilePath* path) {
|
|
if (base::PathService::Get(electron::DIR_CRASH_DUMPS, path)) {
|
|
*path = path->Append("client_id");
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
std::string ReadClientId() {
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
std::string client_id;
|
|
// "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".length == 36
|
|
base::FilePath client_id_path;
|
|
if (GetClientIdPath(&client_id_path) &&
|
|
(!base::ReadFileToStringWithMaxSize(client_id_path, &client_id, 36) ||
|
|
client_id.size() != 36))
|
|
return std::string();
|
|
return client_id;
|
|
}
|
|
|
|
void WriteClientId(const std::string& client_id) {
|
|
DCHECK_EQ(client_id.size(), 36u);
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
base::FilePath client_id_path;
|
|
if (GetClientIdPath(&client_id_path))
|
|
base::WriteFile(client_id_path, client_id);
|
|
}
|
|
|
|
std::string GetClientId() {
|
|
static base::NoDestructor<std::string> client_id;
|
|
if (!client_id->empty())
|
|
return *client_id;
|
|
*client_id = ReadClientId();
|
|
if (client_id->empty()) {
|
|
*client_id = base::GenerateGUID();
|
|
WriteClientId(*client_id);
|
|
}
|
|
return *client_id;
|
|
}
|
|
#endif
|
|
|
|
void Start(const std::string& submit_url,
|
|
bool upload_to_server,
|
|
bool ignore_system_crash_handler,
|
|
bool rate_limit,
|
|
bool compress,
|
|
const std::map<std::string, std::string>& global_extra,
|
|
const std::map<std::string, std::string>& extra,
|
|
bool is_node_process) {
|
|
TRACE_EVENT0("electron", "crash_reporter::Start");
|
|
#if !IS_MAS_BUILD()
|
|
if (g_crash_reporter_initialized)
|
|
return;
|
|
g_crash_reporter_initialized = true;
|
|
ElectronCrashReporterClient::Create();
|
|
ElectronCrashReporterClient::Get()->SetUploadUrl(submit_url);
|
|
ElectronCrashReporterClient::Get()->SetCollectStatsConsent(upload_to_server);
|
|
ElectronCrashReporterClient::Get()->SetShouldRateLimit(rate_limit);
|
|
ElectronCrashReporterClient::Get()->SetShouldCompressUploads(compress);
|
|
ElectronCrashReporterClient::Get()->SetGlobalAnnotations(global_extra);
|
|
auto* command_line = base::CommandLine::ForCurrentProcess();
|
|
std::string process_type =
|
|
is_node_process
|
|
? "node"
|
|
: command_line->GetSwitchValueASCII(::switches::kProcessType);
|
|
#if BUILDFLAG(IS_LINUX)
|
|
for (const auto& pair : extra)
|
|
electron::crash_keys::SetCrashKey(pair.first, pair.second);
|
|
{
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
::crash_reporter::InitializeCrashpad(process_type.empty(), process_type);
|
|
}
|
|
if (ignore_system_crash_handler) {
|
|
crashpad::CrashpadInfo::GetCrashpadInfo()
|
|
->set_system_crash_reporter_forwarding(crashpad::TriState::kDisabled);
|
|
}
|
|
#elif BUILDFLAG(IS_MAC)
|
|
for (const auto& pair : extra)
|
|
electron::crash_keys::SetCrashKey(pair.first, pair.second);
|
|
::crash_reporter::InitializeCrashpad(process_type.empty(), process_type);
|
|
if (ignore_system_crash_handler) {
|
|
crashpad::CrashpadInfo::GetCrashpadInfo()
|
|
->set_system_crash_reporter_forwarding(crashpad::TriState::kDisabled);
|
|
}
|
|
#elif BUILDFLAG(IS_WIN)
|
|
for (const auto& pair : extra)
|
|
electron::crash_keys::SetCrashKey(pair.first, pair.second);
|
|
base::FilePath user_data_dir;
|
|
base::PathService::Get(chrome::DIR_USER_DATA, &user_data_dir);
|
|
::crash_reporter::InitializeCrashpadWithEmbeddedHandler(
|
|
process_type.empty(), process_type,
|
|
base::WideToUTF8(user_data_dir.value()), base::FilePath());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
} // namespace electron::api::crash_reporter
|
|
|
|
namespace {
|
|
|
|
#if IS_MAS_BUILD()
|
|
void GetUploadedReports(
|
|
v8::Isolate* isolate,
|
|
base::OnceCallback<void(v8::Local<v8::Value>)> callback) {
|
|
std::move(callback).Run(v8::Array::New(isolate));
|
|
}
|
|
#else
|
|
scoped_refptr<UploadList> CreateCrashUploadList() {
|
|
#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN)
|
|
return base::MakeRefCounted<CrashUploadListCrashpad>();
|
|
#else
|
|
base::FilePath crash_dir_path;
|
|
base::PathService::Get(electron::DIR_CRASH_DUMPS, &crash_dir_path);
|
|
base::FilePath upload_log_path =
|
|
crash_dir_path.AppendASCII(CrashUploadList::kReporterLogFilename);
|
|
scoped_refptr<UploadList> result =
|
|
base::MakeRefCounted<TextLogUploadList>(upload_log_path);
|
|
// Crashpad keeps the records of C++ crashes (segfaults, etc) in its
|
|
// internal database. The JavaScript error reporter writes JS error upload
|
|
// records to the older text format. Combine the two to present a complete
|
|
// list to the user.
|
|
// TODO(nornagon): what is "The JavaScript error reporter", and do we care
|
|
// about it?
|
|
std::vector<scoped_refptr<UploadList>> uploaders = {
|
|
base::MakeRefCounted<CrashUploadListCrashpad>(), std::move(result)};
|
|
result = base::MakeRefCounted<CombiningUploadList>(std::move(uploaders));
|
|
return result;
|
|
#endif // BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN)
|
|
}
|
|
|
|
v8::Local<v8::Value> GetUploadedReports(v8::Isolate* isolate) {
|
|
auto list = CreateCrashUploadList();
|
|
// TODO(nornagon): switch to using Load() instead of LoadSync() once the
|
|
// synchronous version of getUploadedReports is deprecated so we can remove
|
|
// our patch.
|
|
{
|
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
|
list->LoadSync();
|
|
}
|
|
|
|
constexpr size_t kMaxUploadReportsToList = std::numeric_limits<size_t>::max();
|
|
const std::vector<const UploadList::UploadInfo*> uploads =
|
|
list->GetUploads(kMaxUploadReportsToList);
|
|
std::vector<v8::Local<v8::Object>> result;
|
|
for (auto* const upload : uploads) {
|
|
result.push_back(gin::DataObjectBuilder(isolate)
|
|
.Set("date", upload->upload_time)
|
|
.Set("id", upload->upload_id)
|
|
.Build());
|
|
}
|
|
v8::Local<v8::Value> v8_result = gin::ConvertToV8(isolate, result);
|
|
return v8_result;
|
|
}
|
|
#endif
|
|
|
|
void SetUploadToServer(bool upload) {
|
|
#if !IS_MAS_BUILD()
|
|
ElectronCrashReporterClient::Get()->SetCollectStatsConsent(upload);
|
|
#endif
|
|
}
|
|
|
|
bool GetUploadToServer() {
|
|
#if IS_MAS_BUILD()
|
|
return false;
|
|
#else
|
|
return ElectronCrashReporterClient::Get()->GetCollectStatsConsent();
|
|
#endif
|
|
}
|
|
|
|
v8::Local<v8::Value> GetParameters(v8::Isolate* isolate) {
|
|
std::map<std::string, std::string> keys;
|
|
#if !IS_MAS_BUILD()
|
|
electron::crash_keys::GetCrashKeys(&keys);
|
|
#endif
|
|
return gin::ConvertToV8(isolate, keys);
|
|
}
|
|
|
|
void Initialize(v8::Local<v8::Object> exports,
|
|
v8::Local<v8::Value> unused,
|
|
v8::Local<v8::Context> context,
|
|
void* priv) {
|
|
gin_helper::Dictionary dict(context->GetIsolate(), exports);
|
|
dict.SetMethod("start", &electron::api::crash_reporter::Start);
|
|
#if IS_MAS_BUILD()
|
|
dict.SetMethod("addExtraParameter", &electron::api::crash_reporter::NoOp);
|
|
dict.SetMethod("removeExtraParameter", &electron::api::crash_reporter::NoOp);
|
|
#else
|
|
dict.SetMethod("addExtraParameter", &electron::crash_keys::SetCrashKey);
|
|
dict.SetMethod("removeExtraParameter", &electron::crash_keys::ClearCrashKey);
|
|
#endif
|
|
dict.SetMethod("getParameters", &GetParameters);
|
|
dict.SetMethod("getUploadedReports", &GetUploadedReports);
|
|
dict.SetMethod("setUploadToServer", &SetUploadToServer);
|
|
dict.SetMethod("getUploadToServer", &GetUploadToServer);
|
|
}
|
|
|
|
} // namespace
|
|
|
|
NODE_LINKED_BINDING_CONTEXT_AWARE(electron_browser_crash_reporter, Initialize)
|