@sentry/wizard 3.42.1 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.node-cache/node-v22.14.0-darwin-arm64 +0 -0
- package/.node-cache/node-v22.14.0-darwin-x64 +0 -0
- package/.node-cache/node-v22.14.0-linux-arm64 +0 -0
- package/.node-cache/node-v22.14.0-linux-x64 +0 -0
- package/.node-cache/node-v22.14.0-win-x64.exe +0 -0
- package/CHANGELOG.md +26 -0
- package/COPYING +3575 -0
- package/bin.ts +85 -80
- package/dist/bin.js +44 -35
- package/dist/bin.js.map +1 -1
- package/dist/e2e-tests/jest.config.js +1 -1
- package/dist/e2e-tests/jest.config.js.map +1 -1
- package/dist/e2e-tests/tests/flutter.test.js +62 -147
- package/dist/e2e-tests/tests/flutter.test.js.map +1 -1
- package/dist/e2e-tests/tests/nextjs.test.js +77 -175
- package/dist/e2e-tests/tests/nextjs.test.js.map +1 -1
- package/dist/e2e-tests/tests/nuxt-3.test.js +61 -162
- package/dist/e2e-tests/tests/nuxt-3.test.js.map +1 -1
- package/dist/e2e-tests/tests/nuxt-4.test.js +62 -163
- package/dist/e2e-tests/tests/nuxt-4.test.js.map +1 -1
- package/dist/e2e-tests/tests/remix.test.js +147 -189
- package/dist/e2e-tests/tests/remix.test.js.map +1 -1
- package/dist/e2e-tests/tests/sveltekit.test.js +133 -187
- package/dist/e2e-tests/tests/sveltekit.test.js.map +1 -1
- package/dist/e2e-tests/utils/index.d.ts +1 -1
- package/dist/e2e-tests/utils/index.js +113 -195
- package/dist/e2e-tests/utils/index.js.map +1 -1
- package/dist/lib/Constants.js +5 -5
- package/dist/lib/Constants.js.map +1 -1
- package/dist/lib/Helper/BottomBar.d.ts +1 -1
- package/dist/lib/Helper/BottomBar.js +14 -15
- package/dist/lib/Helper/BottomBar.js.map +1 -1
- package/dist/lib/Helper/Env.js +5 -2
- package/dist/lib/Helper/Env.js.map +1 -1
- package/dist/lib/Helper/File.js +14 -27
- package/dist/lib/Helper/File.js.map +1 -1
- package/dist/lib/Helper/Git.js +24 -59
- package/dist/lib/Helper/Git.js.map +1 -1
- package/dist/lib/Helper/Logging.js +2 -2
- package/dist/lib/Helper/Logging.js.map +1 -1
- package/dist/lib/Helper/MergeConfig.js +4 -4
- package/dist/lib/Helper/MergeConfig.js.map +1 -1
- package/dist/lib/Helper/Package.d.ts +4 -1
- package/dist/lib/Helper/Package.js +12 -38
- package/dist/lib/Helper/Package.js.map +1 -1
- package/dist/lib/Helper/SentryCli.js +77 -149
- package/dist/lib/Helper/SentryCli.js.map +1 -1
- package/dist/lib/Helper/Wizard.js +29 -124
- package/dist/lib/Helper/Wizard.js.map +1 -1
- package/dist/lib/Helper/__tests__/File.js +4 -4
- package/dist/lib/Helper/__tests__/File.js.map +1 -1
- package/dist/lib/Helper/__tests__/MergeConfig.js +24 -24
- package/dist/lib/Helper/__tests__/MergeConfig.js.map +1 -1
- package/dist/lib/Helper/__tests__/SentryCli.js +33 -23
- package/dist/lib/Helper/__tests__/SentryCli.js.map +1 -1
- package/dist/lib/Setup.js +23 -85
- package/dist/lib/Setup.js.map +1 -1
- package/dist/lib/Steps/BaseStep.js +8 -8
- package/dist/lib/Steps/BaseStep.js.map +1 -1
- package/dist/lib/Steps/ChooseIntegration.js +80 -125
- package/dist/lib/Steps/ChooseIntegration.js.map +1 -1
- package/dist/lib/Steps/ConfigureProject.js +6 -66
- package/dist/lib/Steps/ConfigureProject.js.map +1 -1
- package/dist/lib/Steps/Initial.js +16 -104
- package/dist/lib/Steps/Initial.js.map +1 -1
- package/dist/lib/Steps/Integrations/BaseIntegration.js +24 -118
- package/dist/lib/Steps/Integrations/BaseIntegration.js.map +1 -1
- package/dist/lib/Steps/Integrations/Cordova.js +95 -183
- package/dist/lib/Steps/Integrations/Cordova.js.map +1 -1
- package/dist/lib/Steps/Integrations/Electron.js +87 -145
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/dist/lib/Steps/Integrations/MobileProject.js +40 -148
- package/dist/lib/Steps/Integrations/MobileProject.js.map +1 -1
- package/dist/lib/Steps/OpenSentry.js +63 -126
- package/dist/lib/Steps/OpenSentry.js.map +1 -1
- package/dist/lib/Steps/PromptForParameters.js +110 -206
- package/dist/lib/Steps/PromptForParameters.js.map +1 -1
- package/dist/lib/Steps/Result.js +19 -79
- package/dist/lib/Steps/Result.js.map +1 -1
- package/dist/lib/Steps/SentryProjectSelector.js +57 -148
- package/dist/lib/Steps/SentryProjectSelector.js.map +1 -1
- package/dist/lib/Steps/ShouldConfigure.js +6 -66
- package/dist/lib/Steps/ShouldConfigure.js.map +1 -1
- package/dist/lib/Steps/WaitForSentry.js +43 -120
- package/dist/lib/Steps/WaitForSentry.js.map +1 -1
- package/dist/lib/Steps/Welcome.js +17 -76
- package/dist/lib/Steps/Welcome.js.map +1 -1
- package/dist/lib/__tests__/Env.js +3 -3
- package/dist/lib/__tests__/Env.js.map +1 -1
- package/dist/src/android/android-wizard.js +100 -176
- package/dist/src/android/android-wizard.js.map +1 -1
- package/dist/src/android/code-tools.js +24 -33
- package/dist/src/android/code-tools.js.map +1 -1
- package/dist/src/android/gradle.js +106 -165
- package/dist/src/android/gradle.js.map +1 -1
- package/dist/src/android/manifest.js +26 -27
- package/dist/src/android/manifest.js.map +1 -1
- package/dist/src/android/templates.js +76 -23
- package/dist/src/android/templates.js.map +1 -1
- package/dist/src/apple/apple-wizard.js +129 -225
- package/dist/src/apple/apple-wizard.js.map +1 -1
- package/dist/src/apple/cocoapod.js +47 -109
- package/dist/src/apple/cocoapod.js.map +1 -1
- package/dist/src/apple/code-tools.js +32 -35
- package/dist/src/apple/code-tools.js.map +1 -1
- package/dist/src/apple/fastlane.js +51 -97
- package/dist/src/apple/fastlane.js.map +1 -1
- package/dist/src/apple/templates.js +41 -5
- package/dist/src/apple/templates.js.map +1 -1
- package/dist/src/apple/xcode-manager.d.ts +2 -2
- package/dist/src/apple/xcode-manager.js +93 -108
- package/dist/src/apple/xcode-manager.js.map +1 -1
- package/dist/src/flutter/code-tools.js +79 -127
- package/dist/src/flutter/code-tools.js.map +1 -1
- package/dist/src/flutter/flutter-wizard.js +75 -136
- package/dist/src/flutter/flutter-wizard.js.map +1 -1
- package/dist/src/flutter/templates.js +48 -12
- package/dist/src/flutter/templates.js.map +1 -1
- package/dist/src/nextjs/nextjs-wizard.js +527 -805
- package/dist/src/nextjs/nextjs-wizard.js.map +1 -1
- package/dist/src/nextjs/templates.js +380 -40
- package/dist/src/nextjs/templates.js.map +1 -1
- package/dist/src/nextjs/utils.js +5 -5
- package/dist/src/nextjs/utils.js.map +1 -1
- package/dist/src/nuxt/nuxt-wizard.js +91 -188
- package/dist/src/nuxt/nuxt-wizard.js.map +1 -1
- package/dist/src/nuxt/sdk-example.js +68 -137
- package/dist/src/nuxt/sdk-example.js.map +1 -1
- package/dist/src/nuxt/sdk-setup.d.ts +4 -4
- package/dist/src/nuxt/sdk-setup.js +180 -336
- package/dist/src/nuxt/sdk-setup.js.map +1 -1
- package/dist/src/nuxt/templates.js +195 -18
- package/dist/src/nuxt/templates.js.map +1 -1
- package/dist/src/nuxt/utils.js +29 -76
- package/dist/src/nuxt/utils.js.map +1 -1
- package/dist/src/react-native/expo-env-file.js +41 -94
- package/dist/src/react-native/expo-env-file.js.map +1 -1
- package/dist/src/react-native/expo-metro.d.ts +1 -1
- package/dist/src/react-native/expo-metro.js +75 -130
- package/dist/src/react-native/expo-metro.js.map +1 -1
- package/dist/src/react-native/expo.js +61 -114
- package/dist/src/react-native/expo.js.map +1 -1
- package/dist/src/react-native/git.js +23 -56
- package/dist/src/react-native/git.js.map +1 -1
- package/dist/src/react-native/glob.js +3 -3
- package/dist/src/react-native/glob.js.map +1 -1
- package/dist/src/react-native/gradle.js +4 -4
- package/dist/src/react-native/gradle.js.map +1 -1
- package/dist/src/react-native/javascript.js +51 -95
- package/dist/src/react-native/javascript.js.map +1 -1
- package/dist/src/react-native/metro.js +176 -296
- package/dist/src/react-native/metro.js.map +1 -1
- package/dist/src/react-native/react-native-wizard.js +267 -418
- package/dist/src/react-native/react-native-wizard.js.map +1 -1
- package/dist/src/react-native/uninstall.js +37 -80
- package/dist/src/react-native/uninstall.js.map +1 -1
- package/dist/src/react-native/xcode.js +57 -55
- package/dist/src/react-native/xcode.js.map +1 -1
- package/dist/src/remix/codemods/express-server.js +27 -82
- package/dist/src/remix/codemods/express-server.js.map +1 -1
- package/dist/src/remix/codemods/handle-error.js +28 -31
- package/dist/src/remix/codemods/handle-error.js.map +1 -1
- package/dist/src/remix/codemods/root-common.js +11 -11
- package/dist/src/remix/codemods/root-common.js.map +1 -1
- package/dist/src/remix/codemods/root-v1.js +17 -67
- package/dist/src/remix/codemods/root-v1.js.map +1 -1
- package/dist/src/remix/codemods/root-v2.js +89 -140
- package/dist/src/remix/codemods/root-v2.js.map +1 -1
- package/dist/src/remix/remix-wizard.js +181 -343
- package/dist/src/remix/remix-wizard.js.map +1 -1
- package/dist/src/remix/sdk-example.js +84 -66
- package/dist/src/remix/sdk-example.js.map +1 -1
- package/dist/src/remix/sdk-setup.js +161 -293
- package/dist/src/remix/sdk-setup.js.map +1 -1
- package/dist/src/remix/templates.js +10 -2
- package/dist/src/remix/templates.js.map +1 -1
- package/dist/src/remix/utils.js +13 -14
- package/dist/src/remix/utils.js.map +1 -1
- package/dist/src/run.js +106 -178
- package/dist/src/run.js.map +1 -1
- package/dist/src/sourcemaps/sourcemaps-wizard.js +248 -372
- package/dist/src/sourcemaps/sourcemaps-wizard.js.map +1 -1
- package/dist/src/sourcemaps/tools/angular.js +32 -66
- package/dist/src/sourcemaps/tools/angular.js.map +1 -1
- package/dist/src/sourcemaps/tools/create-react-app.js +14 -59
- package/dist/src/sourcemaps/tools/create-react-app.js.map +1 -1
- package/dist/src/sourcemaps/tools/esbuild.js +34 -77
- package/dist/src/sourcemaps/tools/esbuild.js.map +1 -1
- package/dist/src/sourcemaps/tools/nextjs.d.ts +2 -2
- package/dist/src/sourcemaps/tools/nextjs.js +75 -102
- package/dist/src/sourcemaps/tools/nextjs.js.map +1 -1
- package/dist/src/sourcemaps/tools/remix.js +53 -93
- package/dist/src/sourcemaps/tools/remix.js.map +1 -1
- package/dist/src/sourcemaps/tools/rollup.js +35 -76
- package/dist/src/sourcemaps/tools/rollup.js.map +1 -1
- package/dist/src/sourcemaps/tools/sentry-cli.js +157 -289
- package/dist/src/sourcemaps/tools/sentry-cli.js.map +1 -1
- package/dist/src/sourcemaps/tools/tsc.js +68 -134
- package/dist/src/sourcemaps/tools/tsc.js.map +1 -1
- package/dist/src/sourcemaps/tools/vite.js +111 -196
- package/dist/src/sourcemaps/tools/vite.js.map +1 -1
- package/dist/src/sourcemaps/tools/webpack.d.ts +1 -1
- package/dist/src/sourcemaps/tools/webpack.js +158 -260
- package/dist/src/sourcemaps/tools/webpack.js.map +1 -1
- package/dist/src/sourcemaps/utils/detect-tool.js +9 -54
- package/dist/src/sourcemaps/utils/detect-tool.js.map +1 -1
- package/dist/src/sourcemaps/utils/other-wizards.js +77 -144
- package/dist/src/sourcemaps/utils/other-wizards.js.map +1 -1
- package/dist/src/sourcemaps/utils/sdk-version.js +112 -191
- package/dist/src/sourcemaps/utils/sdk-version.js.map +1 -1
- package/dist/src/sveltekit/sdk-example.js +20 -70
- package/dist/src/sveltekit/sdk-example.js.map +1 -1
- package/dist/src/sveltekit/sdk-setup.js +250 -411
- package/dist/src/sveltekit/sdk-setup.js.map +1 -1
- package/dist/src/sveltekit/sveltekit-wizard.js +107 -191
- package/dist/src/sveltekit/sveltekit-wizard.js.map +1 -1
- package/dist/src/sveltekit/templates.js +147 -13
- package/dist/src/sveltekit/templates.js.map +1 -1
- package/dist/src/sveltekit/utils.js +3 -3
- package/dist/src/sveltekit/utils.js.map +1 -1
- package/dist/src/telemetry.d.ts +2 -2
- package/dist/src/telemetry.js +58 -108
- package/dist/src/telemetry.js.map +1 -1
- package/dist/src/utils/ast-utils.js +39 -54
- package/dist/src/utils/ast-utils.js.map +1 -1
- package/dist/src/utils/bash.js +28 -75
- package/dist/src/utils/bash.js.map +1 -1
- package/dist/src/utils/clack-utils.d.ts +3 -7
- package/dist/src/utils/clack-utils.js +688 -1083
- package/dist/src/utils/clack-utils.js.map +1 -1
- package/dist/src/utils/debug.js +6 -10
- package/dist/src/utils/debug.js.map +1 -1
- package/dist/src/utils/package-json.js +5 -6
- package/dist/src/utils/package-json.js.map +1 -1
- package/dist/src/utils/package-manager.js +65 -139
- package/dist/src/utils/package-manager.js.map +1 -1
- package/dist/src/utils/release-registry.js +12 -59
- package/dist/src/utils/release-registry.js.map +1 -1
- package/dist/src/utils/semver.js +3 -4
- package/dist/src/utils/semver.js.map +1 -1
- package/dist/src/utils/sentrycli-utils.js +4 -4
- package/dist/src/utils/sentrycli-utils.js.map +1 -1
- package/dist/src/utils/url.js +5 -6
- package/dist/src/utils/url.js.map +1 -1
- package/dist/test/android/code-tools.test.js +18 -18
- package/dist/test/android/code-tools.test.js.map +1 -1
- package/dist/test/apple/cocoapod.test.js +154 -299
- package/dist/test/apple/cocoapod.test.js.map +1 -1
- package/dist/test/apple/code-tools.test.js +375 -263
- package/dist/test/apple/code-tools.test.js.map +1 -1
- package/dist/test/apple/fastfile.test.js +319 -271
- package/dist/test/apple/fastfile.test.js.map +1 -1
- package/dist/test/apple/templates.test.js +114 -30
- package/dist/test/apple/templates.test.js.map +1 -1
- package/dist/test/apple/xcode-manager.test.js +230 -234
- package/dist/test/apple/xcode-manager.test.js.map +1 -1
- package/dist/test/flutter/code-tools.test.js +119 -48
- package/dist/test/flutter/code-tools.test.js.map +1 -1
- package/dist/test/flutter/templates.test.js +63 -20
- package/dist/test/flutter/templates.test.js.map +1 -1
- package/dist/test/nextjs/templates.test.js +332 -43
- package/dist/test/nextjs/templates.test.js.map +1 -1
- package/dist/test/nuxt/templates.test.js +161 -33
- package/dist/test/nuxt/templates.test.js.map +1 -1
- package/dist/test/react-native/expo-metro.test.js +61 -15
- package/dist/test/react-native/expo-metro.test.js.map +1 -1
- package/dist/test/react-native/expo.test.js +37 -17
- package/dist/test/react-native/expo.test.js.map +1 -1
- package/dist/test/react-native/gradle.test.js +260 -28
- package/dist/test/react-native/gradle.test.js.map +1 -1
- package/dist/test/react-native/javascript.test.js +85 -19
- package/dist/test/react-native/javascript.test.js.map +1 -1
- package/dist/test/react-native/metro.test.js +261 -187
- package/dist/test/react-native/metro.test.js.map +1 -1
- package/dist/test/react-native/xcode.test.js +243 -62
- package/dist/test/react-native/xcode.test.js.map +1 -1
- package/dist/test/remix/client-entry.test.js +81 -21
- package/dist/test/remix/client-entry.test.js.map +1 -1
- package/dist/test/remix/server-instrumentation.test.js +21 -8
- package/dist/test/remix/server-instrumentation.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/sentry-cli.test.js +20 -72
- package/dist/test/sourcemaps/tools/sentry-cli.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/tsc.test.js +142 -68
- package/dist/test/sourcemaps/tools/tsc.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/vite.test.js +106 -75
- package/dist/test/sourcemaps/tools/vite.test.js.map +1 -1
- package/dist/test/sourcemaps/tools/webpack.test.js +226 -102
- package/dist/test/sourcemaps/tools/webpack.test.js.map +1 -1
- package/dist/test/sveltekit/templates.test.js +117 -18
- package/dist/test/sveltekit/templates.test.js.map +1 -1
- package/dist/test/utils/ast-utils.test.js +99 -58
- package/dist/test/utils/ast-utils.test.js.map +1 -1
- package/dist/test/utils/clack-utils.test.js +142 -247
- package/dist/test/utils/clack-utils.test.js.map +1 -1
- package/e2e-tests/package.json +1 -1
- package/e2e-tests/tests/flutter.test.ts +20 -20
- package/e2e-tests/tests/nextjs.test.ts +2 -2
- package/e2e-tests/tests/nuxt-3.test.ts +4 -4
- package/e2e-tests/tests/nuxt-4.test.ts +3 -3
- package/e2e-tests/tests/remix.test.ts +3 -3
- package/e2e-tests/tests/sveltekit.test.ts +3 -3
- package/e2e-tests/utils/index.ts +33 -15
- package/lib/Helper/BottomBar.ts +1 -1
- package/lib/Helper/Env.ts +1 -1
- package/lib/Helper/Package.ts +12 -10
- package/lib/Helper/SentryCli.ts +18 -27
- package/lib/Helper/Wizard.ts +1 -2
- package/lib/Setup.ts +4 -5
- package/lib/Steps/ChooseIntegration.ts +40 -8
- package/lib/Steps/Initial.ts +17 -26
- package/lib/Steps/Integrations/BaseIntegration.ts +2 -8
- package/lib/Steps/Integrations/Cordova.ts +9 -15
- package/lib/Steps/Integrations/Electron.ts +23 -20
- package/lib/Steps/Integrations/MobileProject.ts +18 -15
- package/lib/Steps/OpenSentry.ts +12 -7
- package/lib/Steps/PromptForParameters.ts +12 -19
- package/lib/Steps/SentryProjectSelector.ts +30 -29
- package/lib/Steps/WaitForSentry.ts +29 -23
- package/package.json +12 -8
- package/src/apple/xcode-manager.ts +10 -10
- package/src/nextjs/templates.ts +2 -3
- package/src/nuxt/sdk-setup.ts +21 -18
- package/src/react-native/expo-metro.ts +2 -2
- package/src/react-native/react-native-wizard.ts +1 -2
- package/src/react-native/uninstall.ts +1 -2
- package/src/react-native/xcode.ts +1 -1
- package/src/run.ts +12 -5
- package/src/sourcemaps/tools/nextjs.ts +2 -2
- package/src/sourcemaps/tools/webpack.ts +3 -3
- package/src/telemetry.ts +27 -7
- package/src/utils/clack-utils.ts +50 -47
- package/test/apple/cocoapod.test.ts +4 -0
- package/test/apple/fastfile.test.ts +12 -7
- package/test/apple/xcode-manager.test.ts +13 -11
- package/test/utils/clack-utils.test.ts +40 -50
- package/types/read-env.d.ts +3 -0
- package/types/xcode.d.ts +1 -0
- package/dist/package.json +0 -128
|
@@ -1,15 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __assign = (this && this.__assign) || function () {
|
|
3
|
-
__assign = Object.assign || function(t) {
|
|
4
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
-
s = arguments[i];
|
|
6
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
14
3
|
if (k2 === undefined) k2 = k;
|
|
15
4
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
@@ -33,382 +22,269 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
33
22
|
__setModuleDefault(result, mod);
|
|
34
23
|
return result;
|
|
35
24
|
};
|
|
36
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
37
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
38
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
39
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
40
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
41
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
42
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
43
|
-
});
|
|
44
|
-
};
|
|
45
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
46
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
47
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
48
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
49
|
-
function step(op) {
|
|
50
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
51
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
52
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
53
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
54
|
-
switch (op[0]) {
|
|
55
|
-
case 0: case 1: t = op; break;
|
|
56
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
57
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
58
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
59
|
-
default:
|
|
60
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
61
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
62
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
63
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
64
|
-
if (t[2]) _.ops.pop();
|
|
65
|
-
_.trys.pop(); continue;
|
|
66
|
-
}
|
|
67
|
-
op = body.call(thisArg, _);
|
|
68
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
69
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
73
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
74
27
|
};
|
|
75
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
76
29
|
exports.configureCI = exports.runSourcemapsWizard = void 0;
|
|
77
30
|
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
function runSourcemapsWizard(options) {
|
|
100
|
-
return
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
wizardOptions: options,
|
|
106
|
-
}, function () { return runSourcemapsWizardWithTelemetry(options); })];
|
|
107
|
-
});
|
|
108
|
-
});
|
|
31
|
+
const prompts_1 = __importDefault(require("@clack/prompts"));
|
|
32
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
33
|
+
const Sentry = __importStar(require("@sentry/node"));
|
|
34
|
+
const clack_utils_1 = require("../utils/clack-utils");
|
|
35
|
+
const is_unicorn_supported_1 = require("../utils/vendor/is-unicorn-supported");
|
|
36
|
+
const vite_1 = require("./tools/vite");
|
|
37
|
+
const sentry_cli_1 = require("./tools/sentry-cli");
|
|
38
|
+
const webpack_1 = require("./tools/webpack");
|
|
39
|
+
const tsc_1 = require("./tools/tsc");
|
|
40
|
+
const rollup_1 = require("./tools/rollup");
|
|
41
|
+
const esbuild_1 = require("./tools/esbuild");
|
|
42
|
+
const create_react_app_1 = require("./tools/create-react-app");
|
|
43
|
+
const sdk_version_1 = require("./utils/sdk-version");
|
|
44
|
+
const telemetry_1 = require("../telemetry");
|
|
45
|
+
const other_wizards_1 = require("./utils/other-wizards");
|
|
46
|
+
const angular_1 = require("./tools/angular");
|
|
47
|
+
const detect_tool_1 = require("./utils/detect-tool");
|
|
48
|
+
const nextjs_1 = require("./tools/nextjs");
|
|
49
|
+
const remix_1 = require("./tools/remix");
|
|
50
|
+
const package_manager_1 = require("../utils/package-manager");
|
|
51
|
+
const url_1 = require("../utils/url");
|
|
52
|
+
async function runSourcemapsWizard(options) {
|
|
53
|
+
return (0, telemetry_1.withTelemetry)({
|
|
54
|
+
enabled: options.telemetryEnabled,
|
|
55
|
+
integration: 'sourcemaps',
|
|
56
|
+
wizardOptions: options,
|
|
57
|
+
}, () => runSourcemapsWizardWithTelemetry(options));
|
|
109
58
|
}
|
|
110
59
|
exports.runSourcemapsWizard = runSourcemapsWizard;
|
|
111
|
-
function runSourcemapsWizardWithTelemetry(options) {
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
promoCode: options.promoCode,
|
|
123
|
-
});
|
|
124
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('check-framework-wizard', other_wizards_1.checkIfMoreSuitableWizardExistsAndAskForRedirect)];
|
|
125
|
-
case 1:
|
|
126
|
-
moreSuitableWizard = _b.sent();
|
|
127
|
-
if (!moreSuitableWizard) return [3 /*break*/, 3];
|
|
128
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('run-framework-wizard', function () { return moreSuitableWizard(options); })];
|
|
129
|
-
case 2:
|
|
130
|
-
_b.sent();
|
|
131
|
-
return [2 /*return*/];
|
|
132
|
-
case 3: return [4 /*yield*/, (0, clack_utils_1.confirmContinueIfNoOrDirtyGitRepo)()];
|
|
133
|
-
case 4:
|
|
134
|
-
_b.sent();
|
|
135
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('check-sdk-version', sdk_version_1.ensureMinimumSdkVersionIsInstalled)];
|
|
136
|
-
case 5:
|
|
137
|
-
_b.sent();
|
|
138
|
-
return [4 /*yield*/, (0, clack_utils_1.getOrAskForProjectData)(options)];
|
|
139
|
-
case 6:
|
|
140
|
-
_a = _b.sent(), selfHosted = _a.selfHosted, selectedProject = _a.selectedProject, sentryUrl = _a.sentryUrl, authToken = _a.authToken;
|
|
141
|
-
wizardOptionsWithPreSelectedProject = __assign(__assign({}, options), { preSelectedProject: {
|
|
142
|
-
project: selectedProject,
|
|
143
|
-
authToken: authToken,
|
|
144
|
-
selfHosted: selfHosted,
|
|
145
|
-
} });
|
|
146
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('select-tool', askForUsedBundlerTool)];
|
|
147
|
-
case 7:
|
|
148
|
-
selectedTool = _b.sent();
|
|
149
|
-
Sentry.setTag('selected-tool', selectedTool);
|
|
150
|
-
if (!(selectedTool === 'no-tool')) return [3 /*break*/, 9];
|
|
151
|
-
prompts_1.default.log.info("No Problem! But in this case, there's nothing to configure :)");
|
|
152
|
-
return [4 /*yield*/, (0, clack_utils_1.abort)('Exiting, have a great day!', 0)];
|
|
153
|
-
case 8:
|
|
154
|
-
_b.sent();
|
|
155
|
-
return [2 /*return*/];
|
|
156
|
-
case 9: return [4 /*yield*/, (0, telemetry_1.traceStep)('tool-setup', function () {
|
|
157
|
-
return startToolSetupFlow(selectedTool, {
|
|
158
|
-
orgSlug: selectedProject.organization.slug,
|
|
159
|
-
projectSlug: selectedProject.slug,
|
|
160
|
-
selfHosted: selfHosted,
|
|
161
|
-
url: sentryUrl,
|
|
162
|
-
authToken: authToken,
|
|
163
|
-
}, wizardOptionsWithPreSelectedProject);
|
|
164
|
-
})];
|
|
165
|
-
case 10:
|
|
166
|
-
_b.sent();
|
|
167
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('ci-setup', function () { return configureCI(selectedTool, authToken); })];
|
|
168
|
-
case 11:
|
|
169
|
-
_b.sent();
|
|
170
|
-
(0, telemetry_1.traceStep)('outro', function () {
|
|
171
|
-
return printOutro(sentryUrl, selectedProject.organization.slug, selectedProject.id);
|
|
172
|
-
});
|
|
173
|
-
return [2 /*return*/];
|
|
174
|
-
}
|
|
175
|
-
});
|
|
60
|
+
async function runSourcemapsWizardWithTelemetry(options) {
|
|
61
|
+
(0, clack_utils_1.printWelcome)({
|
|
62
|
+
wizardName: 'Sentry Source Maps Upload Configuration Wizard',
|
|
63
|
+
message: `This wizard will help you upload source maps to Sentry as part of your build.
|
|
64
|
+
Thank you for using Sentry :)${options.telemetryEnabled
|
|
65
|
+
? `
|
|
66
|
+
|
|
67
|
+
(This setup wizard sends telemetry data and crash reports to Sentry.
|
|
68
|
+
You can turn this off by running the wizard with the '--disable-telemetry' flag.)`
|
|
69
|
+
: ''}`,
|
|
70
|
+
promoCode: options.promoCode,
|
|
176
71
|
});
|
|
72
|
+
const moreSuitableWizard = await (0, telemetry_1.traceStep)('check-framework-wizard', other_wizards_1.checkIfMoreSuitableWizardExistsAndAskForRedirect);
|
|
73
|
+
if (moreSuitableWizard) {
|
|
74
|
+
await (0, telemetry_1.traceStep)('run-framework-wizard', () => moreSuitableWizard(options));
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
await (0, clack_utils_1.confirmContinueIfNoOrDirtyGitRepo)();
|
|
78
|
+
await (0, telemetry_1.traceStep)('check-sdk-version', sdk_version_1.ensureMinimumSdkVersionIsInstalled);
|
|
79
|
+
const { selfHosted, selectedProject, sentryUrl, authToken } = await (0, clack_utils_1.getOrAskForProjectData)(options);
|
|
80
|
+
const wizardOptionsWithPreSelectedProject = {
|
|
81
|
+
...options,
|
|
82
|
+
preSelectedProject: {
|
|
83
|
+
project: selectedProject,
|
|
84
|
+
authToken,
|
|
85
|
+
selfHosted,
|
|
86
|
+
},
|
|
87
|
+
};
|
|
88
|
+
const selectedTool = await (0, telemetry_1.traceStep)('select-tool', askForUsedBundlerTool);
|
|
89
|
+
Sentry.setTag('selected-tool', selectedTool);
|
|
90
|
+
if (selectedTool === 'no-tool') {
|
|
91
|
+
prompts_1.default.log.info("No Problem! But in this case, there's nothing to configure :)");
|
|
92
|
+
await (0, clack_utils_1.abort)('Exiting, have a great day!', 0);
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
await (0, telemetry_1.traceStep)('tool-setup', () => startToolSetupFlow(selectedTool, {
|
|
96
|
+
orgSlug: selectedProject.organization.slug,
|
|
97
|
+
projectSlug: selectedProject.slug,
|
|
98
|
+
selfHosted,
|
|
99
|
+
url: sentryUrl,
|
|
100
|
+
authToken,
|
|
101
|
+
}, wizardOptionsWithPreSelectedProject));
|
|
102
|
+
await (0, telemetry_1.traceStep)('ci-setup', () => configureCI(selectedTool, authToken));
|
|
103
|
+
(0, telemetry_1.traceStep)('outro', () => printOutro(sentryUrl, selectedProject.organization.slug, selectedProject.id));
|
|
177
104
|
}
|
|
178
|
-
function askForUsedBundlerTool() {
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
label: "I don't minify, transpile or bundle my code",
|
|
242
|
-
value: 'no-tool',
|
|
243
|
-
hint: 'This will exit the wizard',
|
|
244
|
-
},
|
|
245
|
-
]
|
|
246
|
-
};
|
|
247
|
-
return [4 /*yield*/, (0, detect_tool_1.detectUsedTool)()];
|
|
248
|
-
case 1: return [4 /*yield*/, _a.apply(void 0, [_c.apply(_b, [(_d.initialValue = _e.sent(),
|
|
249
|
-
_d)])])];
|
|
250
|
-
case 2:
|
|
251
|
-
selectedTool = _e.sent();
|
|
252
|
-
return [2 /*return*/, selectedTool];
|
|
253
|
-
}
|
|
254
|
-
});
|
|
255
|
-
});
|
|
105
|
+
async function askForUsedBundlerTool() {
|
|
106
|
+
const selectedTool = await (0, clack_utils_1.abortIfCancelled)(prompts_1.default.select({
|
|
107
|
+
message: 'Which framework, bundler or build tool are you using?',
|
|
108
|
+
options: [
|
|
109
|
+
{
|
|
110
|
+
label: 'Angular',
|
|
111
|
+
value: 'angular',
|
|
112
|
+
hint: 'Select this option if you are using Angular.',
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
label: 'Create React App',
|
|
116
|
+
value: 'create-react-app',
|
|
117
|
+
hint: 'Select this option if you set up your app with Create React App.',
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
label: 'Next.js',
|
|
121
|
+
value: 'nextjs',
|
|
122
|
+
hint: 'Select this option if you want to set up source maps in a Next.js project.',
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
label: 'Remix',
|
|
126
|
+
value: 'remix',
|
|
127
|
+
hint: 'Select this option if you want to set up source maps in a Remix project.',
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
label: 'Webpack',
|
|
131
|
+
value: 'webpack',
|
|
132
|
+
hint: 'Select this if you are using Webpack and you have access to your Webpack config.',
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
label: 'Vite',
|
|
136
|
+
value: 'vite',
|
|
137
|
+
hint: 'Select this if you are using Vite and you have access to your Vite config.',
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
label: 'esbuild',
|
|
141
|
+
value: 'esbuild',
|
|
142
|
+
hint: 'Select this if you are using esbuild and you have access to your esbuild config.',
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
label: 'Rollup',
|
|
146
|
+
value: 'rollup',
|
|
147
|
+
hint: 'Select this if you are using Rollup and you have access to your Rollup config.',
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
label: 'tsc',
|
|
151
|
+
value: 'tsc',
|
|
152
|
+
hint: 'Configure source maps when using tsc as build tool',
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
label: 'I use another tool',
|
|
156
|
+
value: 'sentry-cli',
|
|
157
|
+
hint: 'This will configure source maps upload for you using sentry-cli',
|
|
158
|
+
},
|
|
159
|
+
{
|
|
160
|
+
label: "I don't minify, transpile or bundle my code",
|
|
161
|
+
value: 'no-tool',
|
|
162
|
+
hint: 'This will exit the wizard',
|
|
163
|
+
},
|
|
164
|
+
],
|
|
165
|
+
initialValue: await (0, detect_tool_1.detectUsedTool)(),
|
|
166
|
+
}));
|
|
167
|
+
return selectedTool;
|
|
256
168
|
}
|
|
257
|
-
function startToolSetupFlow(selctedTool, options, wizardOptions) {
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
_b.sent();
|
|
291
|
-
return [3 /*break*/, 21];
|
|
292
|
-
case 9: return [4 /*yield*/, (0, sentry_cli_1.configureSentryCLI)(options, tsc_1.configureTscSourcemapGenerationFlow)];
|
|
293
|
-
case 10:
|
|
294
|
-
_b.sent();
|
|
295
|
-
return [3 /*break*/, 21];
|
|
296
|
-
case 11: return [4 /*yield*/, (0, sentry_cli_1.configureSentryCLI)(options, create_react_app_1.configureCRASourcemapGenerationFlow)];
|
|
297
|
-
case 12:
|
|
298
|
-
_b.sent();
|
|
299
|
-
return [3 /*break*/, 21];
|
|
300
|
-
case 13: return [4 /*yield*/, (0, sentry_cli_1.configureSentryCLI)(options, angular_1.configureAngularSourcemapGenerationFlow)];
|
|
301
|
-
case 14:
|
|
302
|
-
_b.sent();
|
|
303
|
-
return [3 /*break*/, 21];
|
|
304
|
-
case 15: return [4 /*yield*/, (0, nextjs_1.configureNextJsSourceMapsUpload)(options, wizardOptions)];
|
|
305
|
-
case 16:
|
|
306
|
-
_b.sent();
|
|
307
|
-
return [3 /*break*/, 21];
|
|
308
|
-
case 17: return [4 /*yield*/, (0, remix_1.configureRemixSourceMapsUpload)(options, wizardOptions)];
|
|
309
|
-
case 18:
|
|
310
|
-
_b.sent();
|
|
311
|
-
return [3 /*break*/, 21];
|
|
312
|
-
case 19: return [4 /*yield*/, (0, sentry_cli_1.configureSentryCLI)(options)];
|
|
313
|
-
case 20:
|
|
314
|
-
_b.sent();
|
|
315
|
-
return [3 /*break*/, 21];
|
|
316
|
-
case 21: return [2 /*return*/];
|
|
317
|
-
}
|
|
318
|
-
});
|
|
319
|
-
});
|
|
169
|
+
async function startToolSetupFlow(selctedTool, options, wizardOptions) {
|
|
170
|
+
switch (selctedTool) {
|
|
171
|
+
case 'webpack':
|
|
172
|
+
await (0, webpack_1.configureWebPackPlugin)(options);
|
|
173
|
+
break;
|
|
174
|
+
case 'vite':
|
|
175
|
+
await (0, vite_1.configureVitePlugin)(options);
|
|
176
|
+
break;
|
|
177
|
+
case 'esbuild':
|
|
178
|
+
await (0, esbuild_1.configureEsbuildPlugin)(options);
|
|
179
|
+
break;
|
|
180
|
+
case 'rollup':
|
|
181
|
+
await (0, rollup_1.configureRollupPlugin)(options);
|
|
182
|
+
break;
|
|
183
|
+
case 'tsc':
|
|
184
|
+
await (0, sentry_cli_1.configureSentryCLI)(options, tsc_1.configureTscSourcemapGenerationFlow);
|
|
185
|
+
break;
|
|
186
|
+
case 'create-react-app':
|
|
187
|
+
await (0, sentry_cli_1.configureSentryCLI)(options, create_react_app_1.configureCRASourcemapGenerationFlow);
|
|
188
|
+
break;
|
|
189
|
+
case 'angular':
|
|
190
|
+
await (0, sentry_cli_1.configureSentryCLI)(options, angular_1.configureAngularSourcemapGenerationFlow);
|
|
191
|
+
break;
|
|
192
|
+
case 'nextjs':
|
|
193
|
+
await (0, nextjs_1.configureNextJsSourceMapsUpload)(options, wizardOptions);
|
|
194
|
+
break;
|
|
195
|
+
case 'remix':
|
|
196
|
+
await (0, remix_1.configureRemixSourceMapsUpload)(options, wizardOptions);
|
|
197
|
+
break;
|
|
198
|
+
default:
|
|
199
|
+
await (0, sentry_cli_1.configureSentryCLI)(options);
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
320
202
|
}
|
|
321
|
-
function configureCI(selectedTool, authToken) {
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
return [2 /*return*/];
|
|
357
|
-
}
|
|
358
|
-
if (!isCliBasedFlowTool) return [3 /*break*/, 3];
|
|
359
|
-
return [4 /*yield*/, (0, telemetry_1.traceStep)('ci-npm-script-setup', sentry_cli_1.setupNpmScriptInCI)];
|
|
360
|
-
case 2:
|
|
361
|
-
_a.sent();
|
|
362
|
-
_a.label = 3;
|
|
363
|
-
case 3: return [4 /*yield*/, (0, telemetry_1.traceStep)('ci-auth-token-setup', function () { return setupAuthTokenInCI(authToken); })];
|
|
364
|
-
case 4:
|
|
365
|
-
_a.sent();
|
|
366
|
-
return [2 /*return*/];
|
|
367
|
-
}
|
|
368
|
-
});
|
|
369
|
-
});
|
|
203
|
+
async function configureCI(selectedTool, authToken) {
|
|
204
|
+
const isUsingCI = await (0, clack_utils_1.abortIfCancelled)(prompts_1.default.select({
|
|
205
|
+
message: `Are you using a CI/CD tool to build and deploy your application?`,
|
|
206
|
+
options: [
|
|
207
|
+
{
|
|
208
|
+
label: 'Yes',
|
|
209
|
+
hint: 'I use a tool like GitHub Actions, GitLab, CircleCI, TravisCI, Jenkins, Vercel, ...',
|
|
210
|
+
value: true,
|
|
211
|
+
},
|
|
212
|
+
{
|
|
213
|
+
label: 'No',
|
|
214
|
+
hint: 'I build and deploy my application manually',
|
|
215
|
+
value: false,
|
|
216
|
+
},
|
|
217
|
+
],
|
|
218
|
+
initialValue: true,
|
|
219
|
+
}));
|
|
220
|
+
Sentry.setTag('using-ci', isUsingCI);
|
|
221
|
+
const isCliBasedFlowTool = [
|
|
222
|
+
'sentry-cli',
|
|
223
|
+
'tsc',
|
|
224
|
+
'angular',
|
|
225
|
+
'create-react-app',
|
|
226
|
+
].includes(selectedTool);
|
|
227
|
+
const authTokenFile = isCliBasedFlowTool
|
|
228
|
+
? clack_utils_1.SENTRY_CLI_RC_FILE
|
|
229
|
+
: clack_utils_1.SENTRY_DOT_ENV_FILE;
|
|
230
|
+
if (!isUsingCI) {
|
|
231
|
+
prompts_1.default.log.info(`No Problem! Just make sure that the Sentry auth token from ${chalk_1.default.cyan(authTokenFile)} is available whenever you build and deploy your app.`);
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
if (isCliBasedFlowTool) {
|
|
235
|
+
await (0, telemetry_1.traceStep)('ci-npm-script-setup', sentry_cli_1.setupNpmScriptInCI);
|
|
236
|
+
}
|
|
237
|
+
await (0, telemetry_1.traceStep)('ci-auth-token-setup', () => setupAuthTokenInCI(authToken));
|
|
370
238
|
}
|
|
371
239
|
exports.configureCI = configureCI;
|
|
372
|
-
function setupAuthTokenInCI(authToken) {
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
addedEnvVarToCI = _a.sent();
|
|
397
|
-
Sentry.setTag('added-env-var-to-ci', addedEnvVarToCI);
|
|
398
|
-
if (!addedEnvVarToCI) {
|
|
399
|
-
prompts_1.default.log.info("Don't forget! :)");
|
|
400
|
-
}
|
|
401
|
-
return [2 /*return*/];
|
|
402
|
-
}
|
|
403
|
-
});
|
|
404
|
-
});
|
|
240
|
+
async function setupAuthTokenInCI(authToken) {
|
|
241
|
+
prompts_1.default.log.step('Add the Sentry authentication token as an environment variable to your CI setup:');
|
|
242
|
+
// Intentially logging directly to console here so that the code can be copied/pasted directly
|
|
243
|
+
// eslint-disable-next-line no-console
|
|
244
|
+
console.log(chalk_1.default.greenBright(`
|
|
245
|
+
SENTRY_AUTH_TOKEN=${authToken}
|
|
246
|
+
`));
|
|
247
|
+
prompts_1.default.log.warn(chalk_1.default.yellow('DO NOT commit this auth token to your repository!'));
|
|
248
|
+
const addedEnvVarToCI = await (0, clack_utils_1.abortIfCancelled)(prompts_1.default.select({
|
|
249
|
+
message: 'Did you configure CI as shown above?',
|
|
250
|
+
options: [
|
|
251
|
+
{ label: 'Yes, continue!', value: true },
|
|
252
|
+
{
|
|
253
|
+
label: "I'll do it later...",
|
|
254
|
+
value: false,
|
|
255
|
+
hint: chalk_1.default.yellow('You need to set the auth token to upload source maps in CI'),
|
|
256
|
+
},
|
|
257
|
+
],
|
|
258
|
+
initialValue: true,
|
|
259
|
+
}));
|
|
260
|
+
Sentry.setTag('added-env-var-to-ci', addedEnvVarToCI);
|
|
261
|
+
if (!addedEnvVarToCI) {
|
|
262
|
+
prompts_1.default.log.info("Don't forget! :)");
|
|
263
|
+
}
|
|
405
264
|
}
|
|
406
265
|
function printOutro(url, orgSlug, projectId) {
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
266
|
+
const packageManager = (0, package_manager_1.detectPackageManger)();
|
|
267
|
+
const buildCommand = packageManager?.buildCommand ?? 'npm run build';
|
|
268
|
+
const issueStreamUrl = (0, url_1.getIssueStreamUrl)({ url, orgSlug, projectId });
|
|
269
|
+
const arrow = (0, is_unicorn_supported_1.isUnicodeSupported)() ? '→' : '->';
|
|
270
|
+
prompts_1.default.outro(`${chalk_1.default.green("That's it - everything is set up!")}
|
|
271
|
+
|
|
272
|
+
${chalk_1.default.cyan(`Test and validate your setup locally with the following Steps:
|
|
273
|
+
|
|
274
|
+
1. Build your application in ${chalk_1.default.bold('production mode')}.
|
|
275
|
+
${chalk_1.default.gray(`${arrow} For example, run ${chalk_1.default.bold(buildCommand)}.`)}
|
|
276
|
+
${chalk_1.default.gray(`${arrow} You should see source map upload logs in your console.`)}
|
|
277
|
+
2. Run your application and throw a test error.
|
|
278
|
+
${chalk_1.default.gray(`${arrow} The error should appear in Sentry:`)}
|
|
279
|
+
${chalk_1.default.gray(`${arrow} ${issueStreamUrl}`)}
|
|
280
|
+
3. Open the error in Sentry and verify that it's source-mapped.
|
|
281
|
+
${chalk_1.default.gray(`${arrow} The stack trace should show your original source code.`)}
|
|
282
|
+
`)}
|
|
283
|
+
${chalk_1.default.dim(`If you encounter any issues, please refer to the Troubleshooting Guide:
|
|
284
|
+
https://docs.sentry.io/platforms/javascript/sourcemaps/troubleshooting_js
|
|
285
|
+
|
|
286
|
+
If the guide doesn't help or you encounter a bug, please let us know:
|
|
287
|
+
https://github.com/getsentry/sentry-javascript/issues`)}
|
|
288
|
+
`);
|
|
413
289
|
}
|
|
414
290
|
//# sourceMappingURL=sourcemaps-wizard.js.map
|