@sentry/wizard 4.0.0 → 4.0.1
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/CHANGELOG.md +6 -2
- package/dist/lib/Steps/Integrations/Electron.js +1 -1
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/package.json +5 -2
- 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/COPYING +0 -3575
- package/bin.ts +0 -143
- package/codecov.yml +0 -15
- package/e2e-tests/.env.example +0 -11
- package/e2e-tests/README.md +0 -63
- package/e2e-tests/jest.config.ts +0 -22
- package/e2e-tests/package.json +0 -14
- package/e2e-tests/run.sh +0 -15
- package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/project.pbxproj +0 -52
- package/e2e-tests/test-applications/apple/damaged-missing-configuration-list/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/project.pbxproj +0 -62
- package/e2e-tests/test-applications/apple/no-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/project.pbxproj +0 -470
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project.xcodeproj/xcshareddata/xcschemes/Project1.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project1/Project1App.swift +0 -10
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-multi-targets/Project2/Project2App.swift +0 -10
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/project.pbxproj +0 -382
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Project.xcodeproj/xcshareddata/xcschemes/Project.xcscheme +0 -78
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/ContentView.swift +0 -7
- package/e2e-tests/test-applications/apple/spm-swiftui-single-target/Sources/MainApp.swift +0 -10
- package/e2e-tests/test-applications/flutter-test-app/.metadata +0 -45
- package/e2e-tests/test-applications/flutter-test-app/README.md +0 -16
- package/e2e-tests/test-applications/flutter-test-app/analysis_options.yaml +0 -28
- package/e2e-tests/test-applications/flutter-test-app/android/app/build.gradle +0 -44
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/debug/AndroidManifest.xml +0 -7
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/AndroidManifest.xml +0 -45
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/kotlin/com/example/flutter_magic/MainActivity.kt +0 -5
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable/launch_background.xml +0 -12
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/drawable-v21/launch_background.xml +0 -12
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-hdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-mdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values/styles.xml +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/main/res/values-night/styles.xml +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/app/src/profile/AndroidManifest.xml +0 -7
- package/e2e-tests/test-applications/flutter-test-app/android/build.gradle +0 -18
- package/e2e-tests/test-applications/flutter-test-app/android/gradle/wrapper/gradle-wrapper.properties +0 -5
- package/e2e-tests/test-applications/flutter-test-app/android/gradle.properties +0 -3
- package/e2e-tests/test-applications/flutter-test-app/android/settings.gradle +0 -25
- package/e2e-tests/test-applications/flutter-test-app/lib/main.dart +0 -125
- package/e2e-tests/test-applications/flutter-test-app/linux/CMakeLists.txt +0 -145
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/CMakeLists.txt +0 -88
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.cc +0 -11
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugin_registrant.h +0 -15
- package/e2e-tests/test-applications/flutter-test-app/linux/flutter/generated_plugins.cmake +0 -23
- package/e2e-tests/test-applications/flutter-test-app/linux/main.cc +0 -6
- package/e2e-tests/test-applications/flutter-test-app/linux/my_application.cc +0 -124
- package/e2e-tests/test-applications/flutter-test-app/linux/my_application.h +0 -18
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Debug.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/Flutter-Release.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Flutter/GeneratedPluginRegistrant.swift +0 -10
- package/e2e-tests/test-applications/flutter-test-app/macos/Podfile +0 -43
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/AppDelegate.swift +0 -9
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json +0 -68
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Base.lproj/MainMenu.xib +0 -343
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/AppInfo.xcconfig +0 -14
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Debug.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Release.xcconfig +0 -2
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Configs/Warnings.xcconfig +0 -13
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/DebugProfile.entitlements +0 -12
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Info.plist +0 -32
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/MainFlutterWindow.swift +0 -15
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner/Release.entitlements +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.pbxproj +0 -705
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +0 -98
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/contents.xcworkspacedata +0 -7
- package/e2e-tests/test-applications/flutter-test-app/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- package/e2e-tests/test-applications/flutter-test-app/macos/RunnerTests/RunnerTests.swift +0 -12
- package/e2e-tests/test-applications/flutter-test-app/pubspec.lock +0 -213
- package/e2e-tests/test-applications/flutter-test-app/pubspec.yaml +0 -89
- package/e2e-tests/test-applications/flutter-test-app/test/widget_test.dart +0 -30
- package/e2e-tests/test-applications/flutter-test-app/web/favicon.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-192.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-192.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/icons/Icon-maskable-512.png +0 -0
- package/e2e-tests/test-applications/flutter-test-app/web/index.html +0 -38
- package/e2e-tests/test-applications/flutter-test-app/web/manifest.json +0 -35
- package/e2e-tests/test-applications/flutter-test-app/windows/CMakeLists.txt +0 -108
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/CMakeLists.txt +0 -109
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.cc +0 -11
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugin_registrant.h +0 -15
- package/e2e-tests/test-applications/flutter-test-app/windows/flutter/generated_plugins.cmake +0 -23
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/CMakeLists.txt +0 -40
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/Runner.rc +0 -121
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.cpp +0 -71
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/flutter_window.h +0 -33
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/main.cpp +0 -43
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/resource.h +0 -16
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/resources/app_icon.ico +0 -0
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/runner.exe.manifest +0 -14
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.cpp +0 -65
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/utils.h +0 -19
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.cpp +0 -288
- package/e2e-tests/test-applications/flutter-test-app/windows/runner/win32_window.h +0 -102
- package/e2e-tests/test-applications/nextjs-test-app/next.config.mjs +0 -4
- package/e2e-tests/test-applications/nextjs-test-app/package.json +0 -22
- package/e2e-tests/test-applications/nextjs-test-app/src/app/layout.tsx +0 -20
- package/e2e-tests/test-applications/nextjs-test-app/src/app/page.tsx +0 -90
- package/e2e-tests/test-applications/nuxt-3-test-app/README.md +0 -75
- package/e2e-tests/test-applications/nuxt-3-test-app/nuxt.config.ts +0 -5
- package/e2e-tests/test-applications/nuxt-3-test-app/package.json +0 -18
- package/e2e-tests/test-applications/nuxt-3-test-app/public/favicon.ico +0 -0
- package/e2e-tests/test-applications/nuxt-3-test-app/public/robots.txt +0 -1
- package/e2e-tests/test-applications/nuxt-4-test-app/README.md +0 -75
- package/e2e-tests/test-applications/nuxt-4-test-app/nuxt.config.ts +0 -6
- package/e2e-tests/test-applications/nuxt-4-test-app/package.json +0 -18
- package/e2e-tests/test-applications/nuxt-4-test-app/public/favicon.ico +0 -0
- package/e2e-tests/test-applications/nuxt-4-test-app/public/robots.txt +0 -1
- package/e2e-tests/test-applications/remix-test-app/app/entry.client.tsx +0 -18
- package/e2e-tests/test-applications/remix-test-app/app/entry.server.tsx +0 -140
- package/e2e-tests/test-applications/remix-test-app/app/root.tsx +0 -30
- package/e2e-tests/test-applications/remix-test-app/app/routes/_index.tsx +0 -48
- package/e2e-tests/test-applications/remix-test-app/app/tailwind.css +0 -3
- package/e2e-tests/test-applications/remix-test-app/package.json +0 -37
- package/e2e-tests/test-applications/remix-test-app/postcss.config.js +0 -6
- package/e2e-tests/test-applications/remix-test-app/tailwind.config.ts +0 -9
- package/e2e-tests/test-applications/remix-test-app/vite.config.ts +0 -16
- package/e2e-tests/test-applications/sveltekit-test-app/package.json +0 -21
- package/e2e-tests/test-applications/sveltekit-test-app/src/app.d.ts +0 -13
- package/e2e-tests/test-applications/sveltekit-test-app/src/app.html +0 -11
- package/e2e-tests/test-applications/sveltekit-test-app/src/lib/index.ts +0 -1
- package/e2e-tests/test-applications/sveltekit-test-app/src/routes/+page.svelte +0 -2
- package/e2e-tests/test-applications/sveltekit-test-app/svelte.config.js +0 -18
- package/e2e-tests/test-applications/sveltekit-test-app/vite.config.ts +0 -6
- package/e2e-tests/tests/flutter.test.ts +0 -127
- package/e2e-tests/tests/nextjs.test.ts +0 -161
- package/e2e-tests/tests/nuxt-3.test.ts +0 -189
- package/e2e-tests/tests/nuxt-4.test.ts +0 -188
- package/e2e-tests/tests/remix.test.ts +0 -277
- package/e2e-tests/tests/sveltekit.test.ts +0 -284
- package/e2e-tests/utils/index.ts +0 -456
- package/index.ts +0 -2
- package/lib/Constants.ts +0 -118
- package/lib/Helper/BottomBar.ts +0 -28
- package/lib/Helper/Env.ts +0 -7
- package/lib/Helper/File.ts +0 -65
- package/lib/Helper/Git.ts +0 -39
- package/lib/Helper/Logging.ts +0 -44
- package/lib/Helper/MergeConfig.ts +0 -19
- package/lib/Helper/Package.ts +0 -80
- package/lib/Helper/SentryCli.ts +0 -139
- package/lib/Helper/Wizard.ts +0 -58
- package/lib/Helper/__tests__/File.ts +0 -15
- package/lib/Helper/__tests__/MergeConfig.ts +0 -98
- package/lib/Helper/__tests__/SentryCli.ts +0 -86
- package/lib/Helper/test-fixtures/next.config.1-merged.js +0 -18
- package/lib/Helper/test-fixtures/next.config.1.js +0 -6
- package/lib/Helper/test-fixtures/next.config.2.js +0 -8
- package/lib/Helper/test-fixtures/next.config.3-merged.js +0 -21
- package/lib/Helper/test-fixtures/next.config.3.js +0 -9
- package/lib/Helper/test-fixtures/next.config.4-merged.js +0 -21
- package/lib/Helper/test-fixtures/next.config.4.js +0 -9
- package/lib/Setup.ts +0 -40
- package/lib/Steps/BaseStep.ts +0 -25
- package/lib/Steps/ChooseIntegration.ts +0 -144
- package/lib/Steps/ConfigureProject.ts +0 -10
- package/lib/Steps/Initial.ts +0 -35
- package/lib/Steps/Integrations/BaseIntegration.ts +0 -42
- package/lib/Steps/Integrations/Cordova.ts +0 -283
- package/lib/Steps/Integrations/Electron.ts +0 -164
- package/lib/Steps/Integrations/MobileProject.ts +0 -72
- package/lib/Steps/OpenSentry.ts +0 -80
- package/lib/Steps/PromptForParameters.ts +0 -200
- package/lib/Steps/Result.ts +0 -22
- package/lib/Steps/SentryProjectSelector.ts +0 -83
- package/lib/Steps/ShouldConfigure.ts +0 -10
- package/lib/Steps/WaitForSentry.ts +0 -56
- package/lib/Steps/Welcome.ts +0 -21
- package/lib/Steps/index.ts +0 -10
- package/lib/__tests__/Env.ts +0 -29
- package/scripts/NextJs/configs/_error.js +0 -39
- package/scripts/NextJs/configs/next.config.js +0 -36
- package/scripts/NextJs/configs/next.config.template.js +0 -12
- package/scripts/NextJs/configs/sentry.client.config.js +0 -17
- package/scripts/NextJs/configs/sentry.edge.config.js +0 -17
- package/scripts/NextJs/configs/sentry.server.config.js +0 -17
- package/scripts/NextJs/sentry_sample_error.js +0 -47
- package/scripts/craft-pre-release.sh +0 -10
- package/src/android/android-wizard.ts +0 -192
- package/src/android/code-tools.ts +0 -170
- package/src/android/gradle.ts +0 -250
- package/src/android/manifest.ts +0 -180
- package/src/android/templates.ts +0 -86
- package/src/apple/apple-wizard.ts +0 -269
- package/src/apple/cocoapod.ts +0 -73
- package/src/apple/code-tools.ts +0 -147
- package/src/apple/fastlane.ts +0 -170
- package/src/apple/templates.ts +0 -65
- package/src/apple/xcode-manager.ts +0 -404
- package/src/flutter/code-tools.ts +0 -284
- package/src/flutter/flutter-wizard.ts +0 -164
- package/src/flutter/templates.ts +0 -90
- package/src/nextjs/nextjs-wizard.ts +0 -1007
- package/src/nextjs/templates.ts +0 -525
- package/src/nextjs/utils.ts +0 -21
- package/src/nuxt/nuxt-wizard.ts +0 -188
- package/src/nuxt/sdk-example.ts +0 -135
- package/src/nuxt/sdk-setup.ts +0 -352
- package/src/nuxt/templates.ts +0 -303
- package/src/nuxt/types.ts +0 -8
- package/src/nuxt/utils.ts +0 -42
- package/src/react-native/expo-env-file.ts +0 -55
- package/src/react-native/expo-metro.ts +0 -212
- package/src/react-native/expo.ts +0 -175
- package/src/react-native/git.ts +0 -25
- package/src/react-native/glob.ts +0 -13
- package/src/react-native/gradle.ts +0 -26
- package/src/react-native/javascript.ts +0 -103
- package/src/react-native/metro.ts +0 -599
- package/src/react-native/options.ts +0 -5
- package/src/react-native/react-native-wizard.ts +0 -512
- package/src/react-native/uninstall.ts +0 -109
- package/src/react-native/xcode.ts +0 -302
- package/src/remix/codemods/express-server.ts +0 -44
- package/src/remix/codemods/handle-error.ts +0 -118
- package/src/remix/codemods/root-common.ts +0 -63
- package/src/remix/codemods/root-v1.ts +0 -41
- package/src/remix/codemods/root-v2.ts +0 -153
- package/src/remix/remix-wizard.ts +0 -261
- package/src/remix/sdk-example.ts +0 -120
- package/src/remix/sdk-setup.ts +0 -546
- package/src/remix/templates.ts +0 -11
- package/src/remix/utils.ts +0 -96
- package/src/run.ts +0 -211
- package/src/sourcemaps/sourcemaps-wizard.ts +0 -364
- package/src/sourcemaps/tools/angular.ts +0 -42
- package/src/sourcemaps/tools/create-react-app.ts +0 -19
- package/src/sourcemaps/tools/esbuild.ts +0 -65
- package/src/sourcemaps/tools/nextjs.ts +0 -114
- package/src/sourcemaps/tools/remix.ts +0 -90
- package/src/sourcemaps/tools/rollup.ts +0 -67
- package/src/sourcemaps/tools/sentry-cli.ts +0 -287
- package/src/sourcemaps/tools/tsc.ts +0 -144
- package/src/sourcemaps/tools/types.ts +0 -11
- package/src/sourcemaps/tools/vite.ts +0 -300
- package/src/sourcemaps/tools/webpack.ts +0 -383
- package/src/sourcemaps/utils/detect-tool.ts +0 -46
- package/src/sourcemaps/utils/other-wizards.ts +0 -167
- package/src/sourcemaps/utils/sdk-version.ts +0 -266
- package/src/sveltekit/sdk-example.ts +0 -56
- package/src/sveltekit/sdk-setup.ts +0 -667
- package/src/sveltekit/sveltekit-wizard.ts +0 -192
- package/src/sveltekit/templates.ts +0 -185
- package/src/sveltekit/utils.ts +0 -50
- package/src/telemetry.ts +0 -144
- package/src/utils/ast-utils.ts +0 -270
- package/src/utils/bash.ts +0 -57
- package/src/utils/clack-utils.ts +0 -1536
- package/src/utils/debug.ts +0 -20
- package/src/utils/package-json.ts +0 -51
- package/src/utils/package-manager.ts +0 -172
- package/src/utils/release-registry.ts +0 -19
- package/src/utils/semver.ts +0 -33
- package/src/utils/sentrycli-utils.ts +0 -24
- package/src/utils/string.ts +0 -7
- package/src/utils/types.ts +0 -77
- package/src/utils/url.ts +0 -27
- package/src/utils/vendor/is-unicorn-supported.ts +0 -29
- package/test/android/code-tools.test.ts +0 -49
- package/test/apple/cocoapod.test.ts +0 -310
- package/test/apple/code-tools.test.ts +0 -1042
- package/test/apple/fastfile.test.ts +0 -555
- package/test/apple/templates.test.ts +0 -191
- package/test/apple/xcode-manager.test.ts +0 -1068
- package/test/flutter/code-tools.test.ts +0 -212
- package/test/flutter/templates.test.ts +0 -100
- package/test/nextjs/templates.test.ts +0 -429
- package/test/nuxt/templates.test.ts +0 -255
- package/test/react-native/expo-metro.test.ts +0 -81
- package/test/react-native/expo.test.ts +0 -86
- package/test/react-native/gradle.test.ts +0 -310
- package/test/react-native/javascript.test.ts +0 -134
- package/test/react-native/metro.test.ts +0 -396
- package/test/react-native/xcode.test.ts +0 -401
- package/test/remix/client-entry.test.ts +0 -122
- package/test/remix/server-instrumentation.test.ts +0 -36
- package/test/sourcemaps/tools/sentry-cli.test.ts +0 -57
- package/test/sourcemaps/tools/tsc.test.ts +0 -181
- package/test/sourcemaps/tools/vite.test.ts +0 -149
- package/test/sourcemaps/tools/webpack.test.ts +0 -303
- package/test/sveltekit/templates.test.ts +0 -152
- package/test/utils/ast-utils.test.ts +0 -264
- package/test/utils/clack-utils.test.ts +0 -224
- package/types/read-env.d.ts +0 -3
- package/types/xcode.d.ts +0 -527
package/src/run.ts
DELETED
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
2
|
-
import * as clack from '@clack/prompts';
|
|
3
|
-
import { abortIfCancelled } from './utils/clack-utils';
|
|
4
|
-
import { runReactNativeWizard } from './react-native/react-native-wizard';
|
|
5
|
-
|
|
6
|
-
import { run as legacyRun } from '../lib/Setup';
|
|
7
|
-
import type { PreselectedProject, WizardOptions } from './utils/types';
|
|
8
|
-
import { runFlutterWizard } from './flutter/flutter-wizard';
|
|
9
|
-
import { runAndroidWizard } from './android/android-wizard';
|
|
10
|
-
import { runAppleWizard } from './apple/apple-wizard';
|
|
11
|
-
import { runNextjsWizard } from './nextjs/nextjs-wizard';
|
|
12
|
-
import { runNuxtWizard } from './nuxt/nuxt-wizard';
|
|
13
|
-
import { runRemixWizard } from './remix/remix-wizard';
|
|
14
|
-
import { runSvelteKitWizard } from './sveltekit/sveltekit-wizard';
|
|
15
|
-
import { runSourcemapsWizard } from './sourcemaps/sourcemaps-wizard';
|
|
16
|
-
import { readEnvironment } from '../lib/Helper/Env';
|
|
17
|
-
import type { Platform } from '../lib/Constants';
|
|
18
|
-
import type { PackageDotJson } from './utils/package-json';
|
|
19
|
-
import { readFileSync } from 'node:fs';
|
|
20
|
-
|
|
21
|
-
type WizardIntegration =
|
|
22
|
-
| 'reactNative'
|
|
23
|
-
| 'flutter'
|
|
24
|
-
| 'ios'
|
|
25
|
-
| 'android'
|
|
26
|
-
| 'cordova'
|
|
27
|
-
| 'electron'
|
|
28
|
-
| 'nextjs'
|
|
29
|
-
| 'nuxt'
|
|
30
|
-
| 'remix'
|
|
31
|
-
| 'sveltekit'
|
|
32
|
-
| 'sourcemaps';
|
|
33
|
-
|
|
34
|
-
type Args = {
|
|
35
|
-
integration?: WizardIntegration;
|
|
36
|
-
|
|
37
|
-
uninstall: boolean;
|
|
38
|
-
signup: boolean;
|
|
39
|
-
skipConnect: boolean;
|
|
40
|
-
debug: boolean;
|
|
41
|
-
quiet: boolean;
|
|
42
|
-
disableTelemetry: boolean;
|
|
43
|
-
promoCode?: string;
|
|
44
|
-
preSelectedProject?: {
|
|
45
|
-
authToken: string;
|
|
46
|
-
selfHosted: boolean;
|
|
47
|
-
dsn: string;
|
|
48
|
-
projectId: string;
|
|
49
|
-
projectSlug: string;
|
|
50
|
-
projectName: string;
|
|
51
|
-
orgId: string;
|
|
52
|
-
orgName: string;
|
|
53
|
-
orgSlug: string;
|
|
54
|
-
};
|
|
55
|
-
url?: string;
|
|
56
|
-
platform?: Platform[];
|
|
57
|
-
org?: string;
|
|
58
|
-
project?: string;
|
|
59
|
-
saas?: boolean;
|
|
60
|
-
forceInstall?: boolean;
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
function preSelectedProjectArgsToObject(
|
|
64
|
-
args: Args,
|
|
65
|
-
): PreselectedProject | undefined {
|
|
66
|
-
if (!args.preSelectedProject) {
|
|
67
|
-
return undefined;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
authToken: args.preSelectedProject.authToken,
|
|
72
|
-
selfHosted: args.preSelectedProject.selfHosted,
|
|
73
|
-
project: {
|
|
74
|
-
id: args.preSelectedProject.projectId,
|
|
75
|
-
keys: [
|
|
76
|
-
{
|
|
77
|
-
dsn: {
|
|
78
|
-
public: args.preSelectedProject.dsn,
|
|
79
|
-
},
|
|
80
|
-
},
|
|
81
|
-
],
|
|
82
|
-
organization: {
|
|
83
|
-
id: args.preSelectedProject.orgId,
|
|
84
|
-
name: args.preSelectedProject.orgName,
|
|
85
|
-
slug: args.preSelectedProject.orgSlug,
|
|
86
|
-
},
|
|
87
|
-
slug: args.preSelectedProject.projectSlug,
|
|
88
|
-
},
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
export async function run(argv: Args) {
|
|
93
|
-
const finalArgs = {
|
|
94
|
-
...argv,
|
|
95
|
-
...readEnvironment(),
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
let integration = finalArgs.integration;
|
|
99
|
-
if (!integration) {
|
|
100
|
-
clack.intro(`Sentry Wizard ${tryGetWizardVersion()}`);
|
|
101
|
-
|
|
102
|
-
integration = await abortIfCancelled(
|
|
103
|
-
clack.select({
|
|
104
|
-
message: 'What do you want to set up?',
|
|
105
|
-
options: [
|
|
106
|
-
{ value: 'reactNative', label: 'React Native' },
|
|
107
|
-
{ value: 'flutter', label: 'Flutter' },
|
|
108
|
-
{ value: 'ios', label: 'iOS' },
|
|
109
|
-
{ value: 'android', label: 'Android' },
|
|
110
|
-
{ value: 'cordova', label: 'Cordova' },
|
|
111
|
-
{ value: 'electron', label: 'Electron' },
|
|
112
|
-
{ value: 'nextjs', label: 'Next.js' },
|
|
113
|
-
{ value: 'nuxt', label: 'Nuxt' },
|
|
114
|
-
{ value: 'remix', label: 'Remix' },
|
|
115
|
-
{ value: 'sveltekit', label: 'SvelteKit' },
|
|
116
|
-
{ value: 'sourcemaps', label: 'Configure Source Maps Upload' },
|
|
117
|
-
],
|
|
118
|
-
}),
|
|
119
|
-
);
|
|
120
|
-
|
|
121
|
-
if (!integration) {
|
|
122
|
-
clack.log.error('No integration selected. Exiting.');
|
|
123
|
-
return;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
clack.outro(`Starting ${integration} setup`);
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const wizardOptions: WizardOptions = {
|
|
130
|
-
telemetryEnabled: !finalArgs.disableTelemetry,
|
|
131
|
-
promoCode: finalArgs.promoCode,
|
|
132
|
-
url: finalArgs.url,
|
|
133
|
-
orgSlug: finalArgs.org,
|
|
134
|
-
projectSlug: finalArgs.project,
|
|
135
|
-
saas: finalArgs.saas,
|
|
136
|
-
preSelectedProject: preSelectedProjectArgsToObject(finalArgs),
|
|
137
|
-
forceInstall: finalArgs.forceInstall,
|
|
138
|
-
};
|
|
139
|
-
|
|
140
|
-
switch (integration) {
|
|
141
|
-
case 'reactNative':
|
|
142
|
-
await runReactNativeWizard({
|
|
143
|
-
...wizardOptions,
|
|
144
|
-
uninstall: finalArgs.uninstall,
|
|
145
|
-
});
|
|
146
|
-
break;
|
|
147
|
-
|
|
148
|
-
case 'flutter':
|
|
149
|
-
await runFlutterWizard(wizardOptions);
|
|
150
|
-
break;
|
|
151
|
-
|
|
152
|
-
case 'ios':
|
|
153
|
-
await runAppleWizard(wizardOptions);
|
|
154
|
-
break;
|
|
155
|
-
|
|
156
|
-
case 'android':
|
|
157
|
-
await runAndroidWizard(wizardOptions);
|
|
158
|
-
break;
|
|
159
|
-
|
|
160
|
-
case 'nextjs':
|
|
161
|
-
await runNextjsWizard(wizardOptions);
|
|
162
|
-
break;
|
|
163
|
-
|
|
164
|
-
case 'nuxt':
|
|
165
|
-
await runNuxtWizard(wizardOptions);
|
|
166
|
-
break;
|
|
167
|
-
|
|
168
|
-
case 'remix':
|
|
169
|
-
await runRemixWizard(wizardOptions);
|
|
170
|
-
break;
|
|
171
|
-
|
|
172
|
-
case 'sveltekit':
|
|
173
|
-
await runSvelteKitWizard(wizardOptions);
|
|
174
|
-
break;
|
|
175
|
-
|
|
176
|
-
case 'sourcemaps':
|
|
177
|
-
await runSourcemapsWizard(wizardOptions);
|
|
178
|
-
break;
|
|
179
|
-
|
|
180
|
-
case 'cordova':
|
|
181
|
-
argv.integration = 'cordova';
|
|
182
|
-
void legacyRun(argv);
|
|
183
|
-
break;
|
|
184
|
-
|
|
185
|
-
case 'electron':
|
|
186
|
-
argv.integration = 'electron';
|
|
187
|
-
void legacyRun(argv);
|
|
188
|
-
break;
|
|
189
|
-
|
|
190
|
-
default:
|
|
191
|
-
clack.log.error('No setup wizard selected!');
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
/**
|
|
196
|
-
* TODO: replace with rollup replace whenever we switch to rollup
|
|
197
|
-
*/
|
|
198
|
-
function tryGetWizardVersion(): string {
|
|
199
|
-
let version = process.env.npm_package_version;
|
|
200
|
-
if (!version) {
|
|
201
|
-
try {
|
|
202
|
-
const wizardPkgJson = JSON.parse(
|
|
203
|
-
readFileSync('../package.json', 'utf-8'),
|
|
204
|
-
) as PackageDotJson;
|
|
205
|
-
version = wizardPkgJson.version;
|
|
206
|
-
} catch {
|
|
207
|
-
// ignore
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
return version ?? '';
|
|
211
|
-
}
|
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
2
|
-
import clack from '@clack/prompts';
|
|
3
|
-
import chalk from 'chalk';
|
|
4
|
-
import * as Sentry from '@sentry/node';
|
|
5
|
-
|
|
6
|
-
import {
|
|
7
|
-
abort,
|
|
8
|
-
abortIfCancelled,
|
|
9
|
-
confirmContinueIfNoOrDirtyGitRepo,
|
|
10
|
-
SENTRY_DOT_ENV_FILE,
|
|
11
|
-
printWelcome,
|
|
12
|
-
SENTRY_CLI_RC_FILE,
|
|
13
|
-
getOrAskForProjectData,
|
|
14
|
-
} from '../utils/clack-utils';
|
|
15
|
-
import { isUnicodeSupported } from '../utils/vendor/is-unicorn-supported';
|
|
16
|
-
import type { SourceMapUploadToolConfigurationOptions } from './tools/types';
|
|
17
|
-
import { configureVitePlugin } from './tools/vite';
|
|
18
|
-
import { setupNpmScriptInCI, configureSentryCLI } from './tools/sentry-cli';
|
|
19
|
-
import { configureWebPackPlugin } from './tools/webpack';
|
|
20
|
-
import { configureTscSourcemapGenerationFlow } from './tools/tsc';
|
|
21
|
-
import { configureRollupPlugin } from './tools/rollup';
|
|
22
|
-
import { configureEsbuildPlugin } from './tools/esbuild';
|
|
23
|
-
import type { WizardOptions } from '../utils/types';
|
|
24
|
-
import { configureCRASourcemapGenerationFlow } from './tools/create-react-app';
|
|
25
|
-
import { ensureMinimumSdkVersionIsInstalled } from './utils/sdk-version';
|
|
26
|
-
import { traceStep, withTelemetry } from '../telemetry';
|
|
27
|
-
import { checkIfMoreSuitableWizardExistsAndAskForRedirect } from './utils/other-wizards';
|
|
28
|
-
import { configureAngularSourcemapGenerationFlow } from './tools/angular';
|
|
29
|
-
import type { SupportedTools } from './utils/detect-tool';
|
|
30
|
-
import { detectUsedTool } from './utils/detect-tool';
|
|
31
|
-
import { configureNextJsSourceMapsUpload } from './tools/nextjs';
|
|
32
|
-
import { configureRemixSourceMapsUpload } from './tools/remix';
|
|
33
|
-
import { detectPackageManger } from '../utils/package-manager';
|
|
34
|
-
import { getIssueStreamUrl } from '../utils/url';
|
|
35
|
-
|
|
36
|
-
export async function runSourcemapsWizard(
|
|
37
|
-
options: WizardOptions,
|
|
38
|
-
): Promise<void> {
|
|
39
|
-
return withTelemetry(
|
|
40
|
-
{
|
|
41
|
-
enabled: options.telemetryEnabled,
|
|
42
|
-
integration: 'sourcemaps',
|
|
43
|
-
wizardOptions: options,
|
|
44
|
-
},
|
|
45
|
-
() => runSourcemapsWizardWithTelemetry(options),
|
|
46
|
-
);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
async function runSourcemapsWizardWithTelemetry(
|
|
50
|
-
options: WizardOptions,
|
|
51
|
-
): Promise<void> {
|
|
52
|
-
printWelcome({
|
|
53
|
-
wizardName: 'Sentry Source Maps Upload Configuration Wizard',
|
|
54
|
-
message: `This wizard will help you upload source maps to Sentry as part of your build.
|
|
55
|
-
Thank you for using Sentry :)${
|
|
56
|
-
options.telemetryEnabled
|
|
57
|
-
? `
|
|
58
|
-
|
|
59
|
-
(This setup wizard sends telemetry data and crash reports to Sentry.
|
|
60
|
-
You can turn this off by running the wizard with the '--disable-telemetry' flag.)`
|
|
61
|
-
: ''
|
|
62
|
-
}`,
|
|
63
|
-
promoCode: options.promoCode,
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
const moreSuitableWizard = await traceStep(
|
|
67
|
-
'check-framework-wizard',
|
|
68
|
-
checkIfMoreSuitableWizardExistsAndAskForRedirect,
|
|
69
|
-
);
|
|
70
|
-
if (moreSuitableWizard) {
|
|
71
|
-
await traceStep('run-framework-wizard', () => moreSuitableWizard(options));
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
await confirmContinueIfNoOrDirtyGitRepo();
|
|
76
|
-
|
|
77
|
-
await traceStep('check-sdk-version', ensureMinimumSdkVersionIsInstalled);
|
|
78
|
-
|
|
79
|
-
const { selfHosted, selectedProject, sentryUrl, authToken } =
|
|
80
|
-
await getOrAskForProjectData(options);
|
|
81
|
-
|
|
82
|
-
const wizardOptionsWithPreSelectedProject = {
|
|
83
|
-
...options,
|
|
84
|
-
preSelectedProject: {
|
|
85
|
-
project: selectedProject,
|
|
86
|
-
authToken,
|
|
87
|
-
selfHosted,
|
|
88
|
-
},
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
const selectedTool = await traceStep('select-tool', askForUsedBundlerTool);
|
|
92
|
-
|
|
93
|
-
Sentry.setTag('selected-tool', selectedTool);
|
|
94
|
-
|
|
95
|
-
if (selectedTool === 'no-tool') {
|
|
96
|
-
clack.log.info(
|
|
97
|
-
"No Problem! But in this case, there's nothing to configure :)",
|
|
98
|
-
);
|
|
99
|
-
await abort('Exiting, have a great day!', 0);
|
|
100
|
-
return;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
await traceStep('tool-setup', () =>
|
|
104
|
-
startToolSetupFlow(
|
|
105
|
-
selectedTool,
|
|
106
|
-
{
|
|
107
|
-
orgSlug: selectedProject.organization.slug,
|
|
108
|
-
projectSlug: selectedProject.slug,
|
|
109
|
-
selfHosted,
|
|
110
|
-
url: sentryUrl,
|
|
111
|
-
authToken,
|
|
112
|
-
},
|
|
113
|
-
wizardOptionsWithPreSelectedProject,
|
|
114
|
-
),
|
|
115
|
-
);
|
|
116
|
-
|
|
117
|
-
await traceStep('ci-setup', () => configureCI(selectedTool, authToken));
|
|
118
|
-
|
|
119
|
-
traceStep('outro', () =>
|
|
120
|
-
printOutro(
|
|
121
|
-
sentryUrl,
|
|
122
|
-
selectedProject.organization.slug,
|
|
123
|
-
selectedProject.id,
|
|
124
|
-
),
|
|
125
|
-
);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
async function askForUsedBundlerTool(): Promise<SupportedTools> {
|
|
129
|
-
const selectedTool = await abortIfCancelled(
|
|
130
|
-
clack.select({
|
|
131
|
-
message: 'Which framework, bundler or build tool are you using?',
|
|
132
|
-
options: [
|
|
133
|
-
{
|
|
134
|
-
label: 'Angular',
|
|
135
|
-
value: 'angular',
|
|
136
|
-
hint: 'Select this option if you are using Angular.',
|
|
137
|
-
},
|
|
138
|
-
{
|
|
139
|
-
label: 'Create React App',
|
|
140
|
-
value: 'create-react-app',
|
|
141
|
-
hint: 'Select this option if you set up your app with Create React App.',
|
|
142
|
-
},
|
|
143
|
-
{
|
|
144
|
-
label: 'Next.js',
|
|
145
|
-
value: 'nextjs',
|
|
146
|
-
hint: 'Select this option if you want to set up source maps in a Next.js project.',
|
|
147
|
-
},
|
|
148
|
-
{
|
|
149
|
-
label: 'Remix',
|
|
150
|
-
value: 'remix',
|
|
151
|
-
hint: 'Select this option if you want to set up source maps in a Remix project.',
|
|
152
|
-
},
|
|
153
|
-
{
|
|
154
|
-
label: 'Webpack',
|
|
155
|
-
value: 'webpack',
|
|
156
|
-
hint: 'Select this if you are using Webpack and you have access to your Webpack config.',
|
|
157
|
-
},
|
|
158
|
-
{
|
|
159
|
-
label: 'Vite',
|
|
160
|
-
value: 'vite',
|
|
161
|
-
hint: 'Select this if you are using Vite and you have access to your Vite config.',
|
|
162
|
-
},
|
|
163
|
-
{
|
|
164
|
-
label: 'esbuild',
|
|
165
|
-
value: 'esbuild',
|
|
166
|
-
hint: 'Select this if you are using esbuild and you have access to your esbuild config.',
|
|
167
|
-
},
|
|
168
|
-
{
|
|
169
|
-
label: 'Rollup',
|
|
170
|
-
value: 'rollup',
|
|
171
|
-
hint: 'Select this if you are using Rollup and you have access to your Rollup config.',
|
|
172
|
-
},
|
|
173
|
-
{
|
|
174
|
-
label: 'tsc',
|
|
175
|
-
value: 'tsc',
|
|
176
|
-
hint: 'Configure source maps when using tsc as build tool',
|
|
177
|
-
},
|
|
178
|
-
{
|
|
179
|
-
label: 'I use another tool',
|
|
180
|
-
value: 'sentry-cli',
|
|
181
|
-
hint: 'This will configure source maps upload for you using sentry-cli',
|
|
182
|
-
},
|
|
183
|
-
{
|
|
184
|
-
label: "I don't minify, transpile or bundle my code",
|
|
185
|
-
value: 'no-tool',
|
|
186
|
-
hint: 'This will exit the wizard',
|
|
187
|
-
},
|
|
188
|
-
],
|
|
189
|
-
initialValue: await detectUsedTool(),
|
|
190
|
-
}),
|
|
191
|
-
);
|
|
192
|
-
|
|
193
|
-
return selectedTool;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
async function startToolSetupFlow(
|
|
197
|
-
selctedTool: SupportedTools,
|
|
198
|
-
options: SourceMapUploadToolConfigurationOptions,
|
|
199
|
-
wizardOptions: WizardOptions,
|
|
200
|
-
): Promise<void> {
|
|
201
|
-
switch (selctedTool) {
|
|
202
|
-
case 'webpack':
|
|
203
|
-
await configureWebPackPlugin(options);
|
|
204
|
-
break;
|
|
205
|
-
case 'vite':
|
|
206
|
-
await configureVitePlugin(options);
|
|
207
|
-
break;
|
|
208
|
-
case 'esbuild':
|
|
209
|
-
await configureEsbuildPlugin(options);
|
|
210
|
-
break;
|
|
211
|
-
case 'rollup':
|
|
212
|
-
await configureRollupPlugin(options);
|
|
213
|
-
break;
|
|
214
|
-
case 'tsc':
|
|
215
|
-
await configureSentryCLI(options, configureTscSourcemapGenerationFlow);
|
|
216
|
-
break;
|
|
217
|
-
case 'create-react-app':
|
|
218
|
-
await configureSentryCLI(options, configureCRASourcemapGenerationFlow);
|
|
219
|
-
break;
|
|
220
|
-
case 'angular':
|
|
221
|
-
await configureSentryCLI(
|
|
222
|
-
options,
|
|
223
|
-
configureAngularSourcemapGenerationFlow,
|
|
224
|
-
);
|
|
225
|
-
break;
|
|
226
|
-
case 'nextjs':
|
|
227
|
-
await configureNextJsSourceMapsUpload(options, wizardOptions);
|
|
228
|
-
break;
|
|
229
|
-
case 'remix':
|
|
230
|
-
await configureRemixSourceMapsUpload(options, wizardOptions);
|
|
231
|
-
break;
|
|
232
|
-
default:
|
|
233
|
-
await configureSentryCLI(options);
|
|
234
|
-
break;
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
export async function configureCI(
|
|
239
|
-
selectedTool: SupportedTools,
|
|
240
|
-
authToken: string,
|
|
241
|
-
): Promise<void> {
|
|
242
|
-
const isUsingCI = await abortIfCancelled(
|
|
243
|
-
clack.select({
|
|
244
|
-
message: `Are you using a CI/CD tool to build and deploy your application?`,
|
|
245
|
-
options: [
|
|
246
|
-
{
|
|
247
|
-
label: 'Yes',
|
|
248
|
-
hint: 'I use a tool like GitHub Actions, GitLab, CircleCI, TravisCI, Jenkins, Vercel, ...',
|
|
249
|
-
value: true,
|
|
250
|
-
},
|
|
251
|
-
{
|
|
252
|
-
label: 'No',
|
|
253
|
-
hint: 'I build and deploy my application manually',
|
|
254
|
-
value: false,
|
|
255
|
-
},
|
|
256
|
-
],
|
|
257
|
-
initialValue: true,
|
|
258
|
-
}),
|
|
259
|
-
);
|
|
260
|
-
|
|
261
|
-
Sentry.setTag('using-ci', isUsingCI);
|
|
262
|
-
|
|
263
|
-
const isCliBasedFlowTool = [
|
|
264
|
-
'sentry-cli',
|
|
265
|
-
'tsc',
|
|
266
|
-
'angular',
|
|
267
|
-
'create-react-app',
|
|
268
|
-
].includes(selectedTool);
|
|
269
|
-
|
|
270
|
-
const authTokenFile = isCliBasedFlowTool
|
|
271
|
-
? SENTRY_CLI_RC_FILE
|
|
272
|
-
: SENTRY_DOT_ENV_FILE;
|
|
273
|
-
|
|
274
|
-
if (!isUsingCI) {
|
|
275
|
-
clack.log.info(
|
|
276
|
-
`No Problem! Just make sure that the Sentry auth token from ${chalk.cyan(
|
|
277
|
-
authTokenFile,
|
|
278
|
-
)} is available whenever you build and deploy your app.`,
|
|
279
|
-
);
|
|
280
|
-
return;
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
if (isCliBasedFlowTool) {
|
|
284
|
-
await traceStep('ci-npm-script-setup', setupNpmScriptInCI);
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
await traceStep('ci-auth-token-setup', () => setupAuthTokenInCI(authToken));
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
async function setupAuthTokenInCI(authToken: string) {
|
|
291
|
-
clack.log.step(
|
|
292
|
-
'Add the Sentry authentication token as an environment variable to your CI setup:',
|
|
293
|
-
);
|
|
294
|
-
|
|
295
|
-
// Intentially logging directly to console here so that the code can be copied/pasted directly
|
|
296
|
-
// eslint-disable-next-line no-console
|
|
297
|
-
console.log(
|
|
298
|
-
chalk.greenBright(`
|
|
299
|
-
SENTRY_AUTH_TOKEN=${authToken}
|
|
300
|
-
`),
|
|
301
|
-
);
|
|
302
|
-
|
|
303
|
-
clack.log.warn(
|
|
304
|
-
chalk.yellow('DO NOT commit this auth token to your repository!'),
|
|
305
|
-
);
|
|
306
|
-
|
|
307
|
-
const addedEnvVarToCI = await abortIfCancelled(
|
|
308
|
-
clack.select({
|
|
309
|
-
message: 'Did you configure CI as shown above?',
|
|
310
|
-
options: [
|
|
311
|
-
{ label: 'Yes, continue!', value: true },
|
|
312
|
-
{
|
|
313
|
-
label: "I'll do it later...",
|
|
314
|
-
value: false,
|
|
315
|
-
hint: chalk.yellow(
|
|
316
|
-
'You need to set the auth token to upload source maps in CI',
|
|
317
|
-
),
|
|
318
|
-
},
|
|
319
|
-
],
|
|
320
|
-
initialValue: true,
|
|
321
|
-
}),
|
|
322
|
-
);
|
|
323
|
-
|
|
324
|
-
Sentry.setTag('added-env-var-to-ci', addedEnvVarToCI);
|
|
325
|
-
|
|
326
|
-
if (!addedEnvVarToCI) {
|
|
327
|
-
clack.log.info("Don't forget! :)");
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
function printOutro(url: string, orgSlug: string, projectId: string) {
|
|
332
|
-
const packageManager = detectPackageManger();
|
|
333
|
-
const buildCommand = packageManager?.buildCommand ?? 'npm run build';
|
|
334
|
-
|
|
335
|
-
const issueStreamUrl = getIssueStreamUrl({ url, orgSlug, projectId });
|
|
336
|
-
|
|
337
|
-
const arrow = isUnicodeSupported() ? '→' : '->';
|
|
338
|
-
|
|
339
|
-
clack.outro(`${chalk.green("That's it - everything is set up!")}
|
|
340
|
-
|
|
341
|
-
${chalk.cyan(`Test and validate your setup locally with the following Steps:
|
|
342
|
-
|
|
343
|
-
1. Build your application in ${chalk.bold('production mode')}.
|
|
344
|
-
${chalk.gray(`${arrow} For example, run ${chalk.bold(buildCommand)}.`)}
|
|
345
|
-
${chalk.gray(
|
|
346
|
-
`${arrow} You should see source map upload logs in your console.`,
|
|
347
|
-
)}
|
|
348
|
-
2. Run your application and throw a test error.
|
|
349
|
-
${chalk.gray(`${arrow} The error should appear in Sentry:`)}
|
|
350
|
-
${chalk.gray(`${arrow} ${issueStreamUrl}`)}
|
|
351
|
-
3. Open the error in Sentry and verify that it's source-mapped.
|
|
352
|
-
${chalk.gray(
|
|
353
|
-
`${arrow} The stack trace should show your original source code.`,
|
|
354
|
-
)}
|
|
355
|
-
`)}
|
|
356
|
-
${chalk.dim(
|
|
357
|
-
`If you encounter any issues, please refer to the Troubleshooting Guide:
|
|
358
|
-
https://docs.sentry.io/platforms/javascript/sourcemaps/troubleshooting_js
|
|
359
|
-
|
|
360
|
-
If the guide doesn't help or you encounter a bug, please let us know:
|
|
361
|
-
https://github.com/getsentry/sentry-javascript/issues`,
|
|
362
|
-
)}
|
|
363
|
-
`);
|
|
364
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
2
|
-
import clack from '@clack/prompts';
|
|
3
|
-
import chalk from 'chalk';
|
|
4
|
-
import { abortIfCancelled } from '../../utils/clack-utils';
|
|
5
|
-
|
|
6
|
-
const angularJsonTemplate = chalk.gray(`{
|
|
7
|
-
"projects": {
|
|
8
|
-
"your-project": {
|
|
9
|
-
"architect": {
|
|
10
|
-
"build": {
|
|
11
|
-
"options": {
|
|
12
|
-
${chalk.greenBright(`"sourceMap": true`)}
|
|
13
|
-
},
|
|
14
|
-
},
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}`);
|
|
19
|
-
|
|
20
|
-
export async function configureAngularSourcemapGenerationFlow(): Promise<void> {
|
|
21
|
-
clack.log.info(
|
|
22
|
-
`Enable generating source maps in your ${chalk.bold('angular.json')} file:`,
|
|
23
|
-
);
|
|
24
|
-
|
|
25
|
-
// Intentially logging directly to console here so that the code can be copied/pasted directly
|
|
26
|
-
// eslint-disable-next-line no-console
|
|
27
|
-
console.log(angularJsonTemplate);
|
|
28
|
-
|
|
29
|
-
await abortIfCancelled(
|
|
30
|
-
clack.select({
|
|
31
|
-
message: `Verify that you are generating source maps when building your Angular app.`,
|
|
32
|
-
options: [
|
|
33
|
-
{
|
|
34
|
-
label: 'I checked!',
|
|
35
|
-
hint: 'My build output folder contains .js.map files after a build.',
|
|
36
|
-
value: true,
|
|
37
|
-
},
|
|
38
|
-
],
|
|
39
|
-
initialValue: true,
|
|
40
|
-
}),
|
|
41
|
-
);
|
|
42
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
2
|
-
import clack from '@clack/prompts';
|
|
3
|
-
import { abortIfCancelled } from '../../utils/clack-utils';
|
|
4
|
-
|
|
5
|
-
export async function configureCRASourcemapGenerationFlow(): Promise<void> {
|
|
6
|
-
await abortIfCancelled(
|
|
7
|
-
clack.select({
|
|
8
|
-
message: `Verify that you are generating source maps when building your React app.\nGenerally this should already happen unless you set the GENERATE_SOURCEMAPS environment variable to false.`,
|
|
9
|
-
options: [
|
|
10
|
-
{
|
|
11
|
-
label: 'I checked!',
|
|
12
|
-
hint: 'My build output folder contains .js.map files after a build.',
|
|
13
|
-
value: true,
|
|
14
|
-
},
|
|
15
|
-
],
|
|
16
|
-
initialValue: true,
|
|
17
|
-
}),
|
|
18
|
-
);
|
|
19
|
-
}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
2
|
-
import clack, { select } from '@clack/prompts';
|
|
3
|
-
import chalk from 'chalk';
|
|
4
|
-
import {
|
|
5
|
-
abortIfCancelled,
|
|
6
|
-
addDotEnvSentryBuildPluginFile,
|
|
7
|
-
getPackageDotJson,
|
|
8
|
-
installPackage,
|
|
9
|
-
} from '../../utils/clack-utils';
|
|
10
|
-
import { hasPackageInstalled } from '../../utils/package-json';
|
|
11
|
-
|
|
12
|
-
import {
|
|
13
|
-
SourceMapUploadToolConfigurationFunction,
|
|
14
|
-
SourceMapUploadToolConfigurationOptions,
|
|
15
|
-
} from './types';
|
|
16
|
-
|
|
17
|
-
const getCodeSnippet = (options: SourceMapUploadToolConfigurationOptions) =>
|
|
18
|
-
chalk.gray(`
|
|
19
|
-
${chalk.greenBright(
|
|
20
|
-
'const { sentryEsbuildPlugin } = require("@sentry/esbuild-plugin");',
|
|
21
|
-
)}
|
|
22
|
-
|
|
23
|
-
require("esbuild").build({
|
|
24
|
-
${chalk.greenBright(
|
|
25
|
-
'sourcemap: true, // Source map generation must be turned on',
|
|
26
|
-
)}
|
|
27
|
-
plugins: [
|
|
28
|
-
// Put the Sentry esbuild plugin after all other plugins
|
|
29
|
-
${chalk.greenBright(`sentryEsbuildPlugin({
|
|
30
|
-
authToken: process.env.SENTRY_AUTH_TOKEN,
|
|
31
|
-
org: "${options.orgSlug}",
|
|
32
|
-
project: "${options.projectSlug}",${
|
|
33
|
-
options.selfHosted ? `\n url: "${options.url}",` : ''
|
|
34
|
-
}
|
|
35
|
-
}),`)}
|
|
36
|
-
],
|
|
37
|
-
});
|
|
38
|
-
`);
|
|
39
|
-
|
|
40
|
-
export const configureEsbuildPlugin: SourceMapUploadToolConfigurationFunction =
|
|
41
|
-
async (options) => {
|
|
42
|
-
await installPackage({
|
|
43
|
-
packageName: '@sentry/esbuild-plugin',
|
|
44
|
-
alreadyInstalled: hasPackageInstalled(
|
|
45
|
-
'@sentry/esbuild-plugin',
|
|
46
|
-
await getPackageDotJson(),
|
|
47
|
-
),
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
clack.log.step(`Add the following code to your esbuild config:`);
|
|
51
|
-
|
|
52
|
-
// Intentially logging directly to console here so that the code can be copied/pasted directly
|
|
53
|
-
// eslint-disable-next-line no-console
|
|
54
|
-
console.log(getCodeSnippet(options));
|
|
55
|
-
|
|
56
|
-
await abortIfCancelled(
|
|
57
|
-
select({
|
|
58
|
-
message: 'Did you copy the snippet above?',
|
|
59
|
-
options: [{ label: 'Yes, continue!', value: true }],
|
|
60
|
-
initialValue: true,
|
|
61
|
-
}),
|
|
62
|
-
);
|
|
63
|
-
|
|
64
|
-
await addDotEnvSentryBuildPluginFile(options.authToken);
|
|
65
|
-
};
|