@sentry/wizard
Version:
Sentry wizard helping you to configure your project
68 lines (59 loc) • 1.91 kB
text/typescript
// @ts-ignore - clack is ESM and TS complains about that. It works though
import clack, { select } from '@clack/prompts';
import chalk from 'chalk';
import {
abortIfCancelled,
addDotEnvSentryBuildPluginFile,
getPackageDotJson,
hasPackageInstalled,
installPackage,
} from '../../utils/clack-utils';
import {
SourceMapUploadToolConfigurationFunction,
SourceMapUploadToolConfigurationOptions,
} from './types';
const getCodeSnippet = (options: SourceMapUploadToolConfigurationOptions) =>
chalk.gray(`
${chalk.greenBright(
'const { sentryWebpackPlugin } = require("@sentry/webpack-plugin");',
)}
module.exports = {
// ... other config options
${chalk.greenBright(
'devtool: "source-map", // Source map generation must be turned on',
)}
plugins: [
${chalk.greenBright(`sentryWebpackPlugin({
authToken: process.env.SENTRY_AUTH_TOKEN,
org: "${options.orgSlug}",
project: "${options.projectSlug}",${
options.selfHosted ? `\n url: "${options.url}",` : ''
}
})`)},
],
};
`);
export const configureWebPackPlugin: SourceMapUploadToolConfigurationFunction =
async (options) => {
await installPackage({
packageName: '@sentry/webpack-plugin',
alreadyInstalled: hasPackageInstalled(
'@sentry/webpack-plugin',
await getPackageDotJson(),
),
});
clack.log.step(
`Add the following code to your ${chalk.bold('webpack.config.js')} file:`,
);
// Intentially logging directly to console here so that the code can be copied/pasted directly
// eslint-disable-next-line no-console
console.log(getCodeSnippet(options));
await abortIfCancelled(
select({
message: 'Did you copy the snippet above?',
options: [{ label: 'Yes, continue!', value: true }],
initialValue: true,
}),
);
await addDotEnvSentryBuildPluginFile(options.authToken);
};