mirror of
https://github.com/balena-io/balena-cli.git
synced 2025-01-02 03:56:39 +00:00
Support BALENARC_NO_SENTRY env var to disable Sentry.io error reporting
Change-type: minor
This commit is contained in:
parent
8f0f3bda29
commit
cf376316bc
@ -229,7 +229,12 @@ export function setMaxListeners(maxListeners: number) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export async function globalInit() {
|
export async function globalInit() {
|
||||||
await setupSentry();
|
(await import('./utils/bootstrap')).normalizeEnvVar('BALENARC_NO_SENTRY');
|
||||||
|
if (process.env.BALENARC_NO_SENTRY) {
|
||||||
|
console.error(`WARN: disabling Sentry.io error reporting`);
|
||||||
|
} else {
|
||||||
|
await setupSentry();
|
||||||
|
}
|
||||||
checkNodeVersion();
|
checkNodeVersion();
|
||||||
|
|
||||||
const settings = new CliSettings();
|
const settings = new CliSettings();
|
||||||
|
@ -23,12 +23,7 @@ export async function run(
|
|||||||
cliArgs = process.argv,
|
cliArgs = process.argv,
|
||||||
options: import('./preparser').AppOptions = {},
|
options: import('./preparser').AppOptions = {},
|
||||||
) {
|
) {
|
||||||
// DEBUG set to falsy for negative values else is truthy
|
(await import('./utils/bootstrap')).normalizeEnvVar('DEBUG');
|
||||||
process.env.DEBUG = ['0', 'no', 'false', '', undefined].includes(
|
|
||||||
process.env.DEBUG?.toLowerCase(),
|
|
||||||
)
|
|
||||||
? ''
|
|
||||||
: '1';
|
|
||||||
|
|
||||||
// The 'pkgExec' special/internal command provides a Node.js interpreter
|
// The 'pkgExec' special/internal command provides a Node.js interpreter
|
||||||
// for use of the standalone zip package. See pkgExec function.
|
// for use of the standalone zip package. See pkgExec function.
|
||||||
|
@ -162,6 +162,18 @@ export const getSentry = async function () {
|
|||||||
return await import('@sentry/node');
|
return await import('@sentry/node');
|
||||||
};
|
};
|
||||||
|
|
||||||
|
async function sentryCaptureException(error: Error) {
|
||||||
|
const Sentry = await getSentry();
|
||||||
|
Sentry.captureException(error);
|
||||||
|
try {
|
||||||
|
await Sentry.close(1000);
|
||||||
|
} catch (e) {
|
||||||
|
if (process.env.DEBUG) {
|
||||||
|
console.error('Timeout reporting error to sentry.io');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export async function handleError(error: Error) {
|
export async function handleError(error: Error) {
|
||||||
// Set appropriate exitCode
|
// Set appropriate exitCode
|
||||||
process.exitCode =
|
process.exitCode =
|
||||||
@ -189,15 +201,10 @@ export async function handleError(error: Error) {
|
|||||||
printErrorMessage(message.join('\n'));
|
printErrorMessage(message.join('\n'));
|
||||||
|
|
||||||
// Report "unexpected" errors via Sentry.io
|
// Report "unexpected" errors via Sentry.io
|
||||||
const Sentry = await getSentry();
|
if (!process.env.BALENARC_NO_SENTRY) {
|
||||||
Sentry.captureException(error);
|
await sentryCaptureException(error);
|
||||||
try {
|
|
||||||
await Sentry.close(1000);
|
|
||||||
} catch (e) {
|
|
||||||
if (process.env.DEBUG) {
|
|
||||||
console.error('Timeout reporting error to sentry.io');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unhandled/unexpected error: ensure that the process terminates.
|
// Unhandled/unexpected error: ensure that the process terminates.
|
||||||
// The exit error code was set above through `process.exitCode`.
|
// The exit error code was set above through `process.exitCode`.
|
||||||
process.exit();
|
process.exit();
|
||||||
|
@ -49,10 +49,13 @@ interface CachedUsername {
|
|||||||
*/
|
*/
|
||||||
export async function trackCommand(commandSignature: string) {
|
export async function trackCommand(commandSignature: string) {
|
||||||
try {
|
try {
|
||||||
const Sentry = await import('@sentry/node');
|
let Sentry: typeof import('@sentry/node');
|
||||||
Sentry.configureScope((scope) => {
|
if (!process.env.BALENARC_NO_SENTRY) {
|
||||||
scope.setExtra('command', commandSignature);
|
Sentry = await import('@sentry/node');
|
||||||
});
|
Sentry.configureScope((scope) => {
|
||||||
|
scope.setExtra('command', commandSignature);
|
||||||
|
});
|
||||||
|
}
|
||||||
const settings = await import('balena-settings-client');
|
const settings = await import('balena-settings-client');
|
||||||
const balenaUrl = settings.get('balenaUrl') as string;
|
const balenaUrl = settings.get('balenaUrl') as string;
|
||||||
|
|
||||||
@ -90,12 +93,14 @@ export async function trackCommand(commandSignature: string) {
|
|||||||
|
|
||||||
const mixpanel = getMixpanel(balenaUrl);
|
const mixpanel = getMixpanel(balenaUrl);
|
||||||
|
|
||||||
Sentry.configureScope((scope) => {
|
if (!process.env.BALENARC_NO_SENTRY) {
|
||||||
scope.setUser({
|
Sentry!.configureScope((scope) => {
|
||||||
id: username,
|
scope.setUser({
|
||||||
username,
|
id: username,
|
||||||
|
username,
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
}
|
||||||
// Don't actually call mixpanel.track() while running test cases
|
// Don't actually call mixpanel.track() while running test cases
|
||||||
if (!process.env.BALENA_CLI_TEST_TYPE) {
|
if (!process.env.BALENA_CLI_TEST_TYPE) {
|
||||||
await mixpanel.track(`[CLI] ${commandSignature}`, {
|
await mixpanel.track(`[CLI] ${commandSignature}`, {
|
||||||
|
33
lib/utils/bootstrap.ts
Normal file
33
lib/utils/bootstrap.ts
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/**
|
||||||
|
* @license
|
||||||
|
* Copyright 2020 Balena Ltd.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* THIS MODULE SHOULD NOT IMPORT / REQUIRE ANYTHING AT THE GLOBAL LEVEL.
|
||||||
|
* It is meant to contain elementary helper functions or classes that
|
||||||
|
* can be used very early on during CLI startup, before anything else
|
||||||
|
* like Sentry error reporting, preparser, oclif parser and the like.
|
||||||
|
*/
|
||||||
|
|
||||||
|
export function parseBoolEnvVar(varName: string): boolean {
|
||||||
|
return !['0', 'no', 'false', '', undefined].includes(
|
||||||
|
process.env[varName]?.toLowerCase(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function normalizeEnvVar(varName: string) {
|
||||||
|
process.env[varName] = parseBoolEnvVar(varName) ? '1' : '';
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user