@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/lib/Steps/Welcome.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import type { Answers } from 'inquirer';
|
|
2
|
-
|
|
3
|
-
import { dim, green } from '../Helper/Logging';
|
|
4
|
-
import { BaseStep } from './BaseStep';
|
|
5
|
-
|
|
6
|
-
export class Welcome extends BaseStep {
|
|
7
|
-
private static _didShow = false;
|
|
8
|
-
|
|
9
|
-
// eslint-disable-next-line @typescript-eslint/require-await
|
|
10
|
-
public async emit(_answers: Answers): Promise<Answers> {
|
|
11
|
-
if (Welcome._didShow) {
|
|
12
|
-
return {};
|
|
13
|
-
}
|
|
14
|
-
if (this._argv.uninstall === false) {
|
|
15
|
-
green('Sentry Wizard will help you to configure your project');
|
|
16
|
-
dim('Thank you for using Sentry :)');
|
|
17
|
-
}
|
|
18
|
-
Welcome._didShow = true;
|
|
19
|
-
return {};
|
|
20
|
-
}
|
|
21
|
-
}
|
package/lib/Steps/index.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export { Welcome } from './Welcome';
|
|
2
|
-
export { OpenSentry } from './OpenSentry';
|
|
3
|
-
export { WaitForSentry } from './WaitForSentry';
|
|
4
|
-
export { Initial } from './Initial';
|
|
5
|
-
export { SentryProjectSelector } from './SentryProjectSelector';
|
|
6
|
-
export { Result } from './Result';
|
|
7
|
-
export { ConfigureProject } from './ConfigureProject';
|
|
8
|
-
export { ChooseIntegration } from './ChooseIntegration';
|
|
9
|
-
export { ShouldConfigure } from './ShouldConfigure';
|
|
10
|
-
export { PromptForParameters } from './PromptForParameters';
|
package/lib/__tests__/Env.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { readEnvironment } from '../Helper/Env';
|
|
2
|
-
|
|
3
|
-
describe('read-env', () => {
|
|
4
|
-
test('transform', () => {
|
|
5
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
6
|
-
process.env.SENTRY_WIZARD_DEBUG = true;
|
|
7
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
8
|
-
process.env.SENTRY_WIZARD_UNINSTALL = false;
|
|
9
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
10
|
-
process.env.SENTRY_WIZARD_SKIP_CONNECT = true;
|
|
11
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
12
|
-
process.env.SENTRY_WIZARD_QUIET = true;
|
|
13
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
14
|
-
process.env.SENTRY_WIZARD_INTEGRATION = ['reactNative', 'electron'];
|
|
15
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
16
|
-
process.env.SENTRY_WIZARD_PLATFORM = ['ios', 'android'];
|
|
17
|
-
// @ts-ignore: true not assignable to string/undefined
|
|
18
|
-
process.env.SENTRY_WIZARD_URL = 'https://sentry.io';
|
|
19
|
-
expect(readEnvironment()).toEqual({
|
|
20
|
-
debug: true,
|
|
21
|
-
integration: 'reactNative,electron',
|
|
22
|
-
platform: 'ios,android',
|
|
23
|
-
quiet: true,
|
|
24
|
-
skipConnect: true,
|
|
25
|
-
uninstall: false,
|
|
26
|
-
url: 'https://sentry.io',
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
});
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* NOTE: This requires `@sentry/nextjs` version 7.3.0 or higher.
|
|
3
|
-
*
|
|
4
|
-
* NOTE: If using this with `next` version 12.2.0 or lower, uncomment the
|
|
5
|
-
* penultimate line in `CustomErrorComponent`.
|
|
6
|
-
*
|
|
7
|
-
* This page is loaded by Nextjs:
|
|
8
|
-
* - on the server, when data-fetching methods throw or reject
|
|
9
|
-
* - on the client, when `getInitialProps` throws or rejects
|
|
10
|
-
* - on the client, when a React lifecycle method throws or rejects, and it's
|
|
11
|
-
* caught by the built-in Nextjs error boundary
|
|
12
|
-
*
|
|
13
|
-
* See:
|
|
14
|
-
* - https://nextjs.org/docs/basic-features/data-fetching/overview
|
|
15
|
-
* - https://nextjs.org/docs/api-reference/data-fetching/get-initial-props
|
|
16
|
-
* - https://reactjs.org/docs/error-boundaries.html
|
|
17
|
-
*/
|
|
18
|
-
|
|
19
|
-
import * as Sentry from '@sentry/nextjs';
|
|
20
|
-
import NextErrorComponent from 'next/error';
|
|
21
|
-
|
|
22
|
-
const CustomErrorComponent = props => {
|
|
23
|
-
// If you're using a Nextjs version prior to 12.2.1, uncomment this to
|
|
24
|
-
// compensate for https://github.com/vercel/next.js/issues/8592
|
|
25
|
-
// Sentry.captureUnderscoreErrorException(props);
|
|
26
|
-
|
|
27
|
-
return <NextErrorComponent statusCode={props.statusCode} />;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
CustomErrorComponent.getInitialProps = async contextData => {
|
|
31
|
-
// In case this is running in a serverless function, await this in order to give Sentry
|
|
32
|
-
// time to send the error before the lambda exits
|
|
33
|
-
await Sentry.captureUnderscoreErrorException(contextData);
|
|
34
|
-
|
|
35
|
-
// This will contain the status code of the response
|
|
36
|
-
return NextErrorComponent.getInitialProps(contextData);
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
export default CustomErrorComponent;
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
// This file sets a custom webpack configuration to use your Next.js app
|
|
2
|
-
// with Sentry.
|
|
3
|
-
// https://nextjs.org/docs/api-reference/next.config.js/introduction
|
|
4
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/
|
|
5
|
-
|
|
6
|
-
const { withSentryConfig } = require('@sentry/nextjs');
|
|
7
|
-
|
|
8
|
-
const moduleExports = {
|
|
9
|
-
// Your existing module.exports
|
|
10
|
-
|
|
11
|
-
sentry: {
|
|
12
|
-
// Use `hidden-source-map` rather than `source-map` as the Webpack `devtool`
|
|
13
|
-
// for client-side builds. (This will be the default starting in
|
|
14
|
-
// `@sentry/nextjs` version 8.0.0.) See
|
|
15
|
-
// https://webpack.js.org/configuration/devtool/ and
|
|
16
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/#use-hidden-source-map
|
|
17
|
-
// for more information.
|
|
18
|
-
hideSourceMaps: true,
|
|
19
|
-
},
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
const sentryWebpackPluginOptions = {
|
|
23
|
-
// Additional config options for the Sentry Webpack plugin. Keep in mind that
|
|
24
|
-
// the following options are set automatically, and overriding them is not
|
|
25
|
-
// recommended:
|
|
26
|
-
// release, url, org, project, authToken, configFile, stripPrefix,
|
|
27
|
-
// urlPrefix, include, ignore
|
|
28
|
-
|
|
29
|
-
silent: true, // Suppresses all logs
|
|
30
|
-
// For all available options, see:
|
|
31
|
-
// https://github.com/getsentry/sentry-webpack-plugin#options.
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
// Make sure adding Sentry options is the last code to run before exporting, to
|
|
35
|
-
// ensure that your source maps include changes from all other Webpack plugins
|
|
36
|
-
module.exports = withSentryConfig(moduleExports, sentryWebpackPluginOptions);
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
// This file sets a custom webpack configuration to use your Next.js app
|
|
2
|
-
// with Sentry.
|
|
3
|
-
// https://nextjs.org/docs/api-reference/next.config.js/introduction
|
|
4
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/
|
|
5
|
-
const { withSentryConfig } = require('@sentry/nextjs');
|
|
6
|
-
|
|
7
|
-
// ORIGINAL CONFIG
|
|
8
|
-
module.exports = withSentryConfig(
|
|
9
|
-
module.exports,
|
|
10
|
-
{ silent: true },
|
|
11
|
-
{ hideSourceMaps: true },
|
|
12
|
-
);
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// This file configures the initialization of Sentry on the browser.
|
|
2
|
-
// The config you add here will be used whenever a page is visited.
|
|
3
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/
|
|
4
|
-
|
|
5
|
-
import * as Sentry from '@sentry/nextjs';
|
|
6
|
-
|
|
7
|
-
const SENTRY_DSN = process.env.SENTRY_DSN || process.env.NEXT_PUBLIC_SENTRY_DSN;
|
|
8
|
-
|
|
9
|
-
Sentry.init({
|
|
10
|
-
dsn: SENTRY_DSN || '___DSN___',
|
|
11
|
-
// Adjust this value in production, or use tracesSampler for greater control
|
|
12
|
-
tracesSampleRate: 1.0,
|
|
13
|
-
// ...
|
|
14
|
-
// Note: if you want to override the automatic release value, do not set a
|
|
15
|
-
// `release` value here - use the environment variable `SENTRY_RELEASE`, so
|
|
16
|
-
// that it will also get attached to your source maps
|
|
17
|
-
});
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// This file configures the initialization of Sentry on the server.
|
|
2
|
-
// The config you add here will be used whenever middleware or an Edge route handles a request.
|
|
3
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/
|
|
4
|
-
|
|
5
|
-
import * as Sentry from '@sentry/nextjs';
|
|
6
|
-
|
|
7
|
-
const SENTRY_DSN = process.env.SENTRY_DSN || process.env.NEXT_PUBLIC_SENTRY_DSN;
|
|
8
|
-
|
|
9
|
-
Sentry.init({
|
|
10
|
-
dsn: SENTRY_DSN || '___DSN___',
|
|
11
|
-
// Adjust this value in production, or use tracesSampler for greater control
|
|
12
|
-
tracesSampleRate: 1.0,
|
|
13
|
-
// ...
|
|
14
|
-
// Note: if you want to override the automatic release value, do not set a
|
|
15
|
-
// `release` value here - use the environment variable `SENTRY_RELEASE`, so
|
|
16
|
-
// that it will also get attached to your source maps
|
|
17
|
-
});
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// This file configures the initialization of Sentry on the server.
|
|
2
|
-
// The config you add here will be used whenever the server handles a request.
|
|
3
|
-
// https://docs.sentry.io/platforms/javascript/guides/nextjs/
|
|
4
|
-
|
|
5
|
-
import * as Sentry from '@sentry/nextjs';
|
|
6
|
-
|
|
7
|
-
const SENTRY_DSN = process.env.SENTRY_DSN || process.env.NEXT_PUBLIC_SENTRY_DSN;
|
|
8
|
-
|
|
9
|
-
Sentry.init({
|
|
10
|
-
dsn: SENTRY_DSN || '___DSN___',
|
|
11
|
-
// Adjust this value in production, or use tracesSampler for greater control
|
|
12
|
-
tracesSampleRate: 1.0,
|
|
13
|
-
// ...
|
|
14
|
-
// Note: if you want to override the automatic release value, do not set a
|
|
15
|
-
// `release` value here - use the environment variable `SENTRY_RELEASE`, so
|
|
16
|
-
// that it will also get attached to your source maps
|
|
17
|
-
});
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import Head from 'next/head'
|
|
2
|
-
|
|
3
|
-
const boxStyles = { padding: '12px', border: '1px solid #eaeaea', borderRadius: '10px' };
|
|
4
|
-
export default function Home() {
|
|
5
|
-
return (
|
|
6
|
-
<div>
|
|
7
|
-
<Head>
|
|
8
|
-
<title>Sentry Onboarding</title>
|
|
9
|
-
<meta name="description" content="Make your Next.js ready for Sentry" />
|
|
10
|
-
</Head>
|
|
11
|
-
|
|
12
|
-
<main style={{
|
|
13
|
-
minHeight: '100vh',
|
|
14
|
-
display: 'flex',
|
|
15
|
-
flexDirection: 'column',
|
|
16
|
-
justifyContent: 'center',
|
|
17
|
-
alignItems: 'center',
|
|
18
|
-
}}>
|
|
19
|
-
<h1 style={{ fontSize: '4rem' }}>
|
|
20
|
-
<svg style={{
|
|
21
|
-
height: '1em'
|
|
22
|
-
}} xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 44">
|
|
23
|
-
<path fill="currentColor" d="M124.32,28.28,109.56,9.22h-3.68V34.77h3.73V15.19l15.18,19.58h3.26V9.22h-3.73ZM87.15,23.54h13.23V20.22H87.14V12.53h14.93V9.21H83.34V34.77h18.92V31.45H87.14ZM71.59,20.3h0C66.44,19.06,65,18.08,65,15.7c0-2.14,1.89-3.59,4.71-3.59a12.06,12.06,0,0,1,7.07,2.55l2-2.83a14.1,14.1,0,0,0-9-3c-5.06,0-8.59,3-8.59,7.27,0,4.6,3,6.19,8.46,7.52C74.51,24.74,76,25.78,76,28.11s-2,3.77-5.09,3.77a12.34,12.34,0,0,1-8.3-3.26l-2.25,2.69a15.94,15.94,0,0,0,10.42,3.85c5.48,0,9-2.95,9-7.51C79.75,23.79,77.47,21.72,71.59,20.3ZM195.7,9.22l-7.69,12-7.64-12h-4.46L186,24.67V34.78h3.84V24.55L200,9.22Zm-64.63,3.46h8.37v22.1h3.84V12.68h8.37V9.22H131.08ZM169.41,24.8c3.86-1.07,6-3.77,6-7.63,0-4.91-3.59-8-9.38-8H154.67V34.76h3.8V25.58h6.45l6.48,9.2h4.44l-7-9.82Zm-10.95-2.5V12.6h7.17c3.74,0,5.88,1.77,5.88,4.84s-2.29,4.86-5.84,4.86Z M29,2.26a4.67,4.67,0,0,0-8,0L14.42,13.53A32.21,32.21,0,0,1,32.17,40.19H27.55A27.68,27.68,0,0,0,12.09,17.47L6,28a15.92,15.92,0,0,1,9.23,12.17H4.62A.76.76,0,0,1,4,39.06l2.94-5a10.74,10.74,0,0,0-3.36-1.9l-2.91,5a4.54,4.54,0,0,0,1.69,6.24A4.66,4.66,0,0,0,4.62,44H19.15a19.4,19.4,0,0,0-8-17.31l2.31-4A23.87,23.87,0,0,1,23.76,44H36.07a35.88,35.88,0,0,0-16.41-31.8l4.67-8a.77.77,0,0,1,1.05-.27c.53.29,20.29,34.77,20.66,35.17a.76.76,0,0,1-.68,1.13H40.6q.09,1.91,0,3.81h4.78A4.59,4.59,0,0,0,50,39.43a4.49,4.49,0,0,0-.62-2.28Z"></path>
|
|
24
|
-
</svg>
|
|
25
|
-
</h1>
|
|
26
|
-
|
|
27
|
-
<p >
|
|
28
|
-
Get started by sending us a sample error
|
|
29
|
-
</p>
|
|
30
|
-
<button type="button" style={{
|
|
31
|
-
...boxStyles,
|
|
32
|
-
backgroundColor: '#c73852',
|
|
33
|
-
borderRadius: '12px',
|
|
34
|
-
border: 'none'
|
|
35
|
-
}} onClick={() => {
|
|
36
|
-
throw new Error("Sentry Frontend Error");
|
|
37
|
-
}}>
|
|
38
|
-
Throw error
|
|
39
|
-
</button>
|
|
40
|
-
|
|
41
|
-
<p>
|
|
42
|
-
For more information, see <a href="https://docs.sentry.io/platforms/javascript/guides/nextjs/">https://docs.sentry.io/platforms/javascript/guides/nextjs/</a>
|
|
43
|
-
</p>
|
|
44
|
-
</main>
|
|
45
|
-
</div>
|
|
46
|
-
)
|
|
47
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
set -eux
|
|
3
|
-
# Move to the project root
|
|
4
|
-
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
5
|
-
cd $SCRIPT_DIR/..
|
|
6
|
-
OLD_VERSION="${1}"
|
|
7
|
-
NEW_VERSION="${2}"
|
|
8
|
-
# Do not tag and commit changes made by "npm version"
|
|
9
|
-
export npm_config_git_tag_version=false
|
|
10
|
-
npm version "${NEW_VERSION}"
|
|
@@ -1,192 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
2
|
-
import * as fs from 'fs';
|
|
3
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
4
|
-
import * as clack from '@clack/prompts';
|
|
5
|
-
import * as path from 'path';
|
|
6
|
-
import * as Sentry from '@sentry/node';
|
|
7
|
-
import * as gradle from './gradle';
|
|
8
|
-
import * as manifest from './manifest';
|
|
9
|
-
import * as codetools from './code-tools';
|
|
10
|
-
import {
|
|
11
|
-
CliSetupConfig,
|
|
12
|
-
abort,
|
|
13
|
-
addSentryCliConfig,
|
|
14
|
-
confirmContinueIfNoOrDirtyGitRepo,
|
|
15
|
-
getOrAskForProjectData,
|
|
16
|
-
printWelcome,
|
|
17
|
-
propertiesCliSetupConfig,
|
|
18
|
-
} from '../utils/clack-utils';
|
|
19
|
-
import { WizardOptions } from '../utils/types';
|
|
20
|
-
import { traceStep, withTelemetry } from '../telemetry';
|
|
21
|
-
import chalk from 'chalk';
|
|
22
|
-
|
|
23
|
-
const proguardMappingCliSetupConfig: CliSetupConfig = {
|
|
24
|
-
...propertiesCliSetupConfig,
|
|
25
|
-
name: 'proguard mappings',
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export async function runAndroidWizard(options: WizardOptions): Promise<void> {
|
|
29
|
-
return withTelemetry(
|
|
30
|
-
{
|
|
31
|
-
enabled: options.telemetryEnabled,
|
|
32
|
-
integration: 'android',
|
|
33
|
-
wizardOptions: options,
|
|
34
|
-
},
|
|
35
|
-
() => runAndroidWizardWithTelemetry(options),
|
|
36
|
-
);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
async function runAndroidWizardWithTelemetry(
|
|
40
|
-
options: WizardOptions,
|
|
41
|
-
): Promise<void> {
|
|
42
|
-
printWelcome({
|
|
43
|
-
wizardName: 'Sentry Android Wizard',
|
|
44
|
-
promoCode: options.promoCode,
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
await confirmContinueIfNoOrDirtyGitRepo();
|
|
48
|
-
|
|
49
|
-
const projectDir = process.cwd();
|
|
50
|
-
const buildGradleFiles = findFilesWithExtensions(projectDir, [
|
|
51
|
-
'.gradle',
|
|
52
|
-
'gradle.kts',
|
|
53
|
-
]);
|
|
54
|
-
|
|
55
|
-
if (!buildGradleFiles || buildGradleFiles.length === 0) {
|
|
56
|
-
clack.log.error(
|
|
57
|
-
'No Gradle project found. Please run this command from the root of your project.',
|
|
58
|
-
);
|
|
59
|
-
Sentry.captureException('No Gradle project found');
|
|
60
|
-
await abort();
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const appFile = await traceStep('Select App File', () =>
|
|
65
|
-
gradle.selectAppFile(buildGradleFiles),
|
|
66
|
-
);
|
|
67
|
-
|
|
68
|
-
const { selectedProject, selfHosted, sentryUrl, authToken } =
|
|
69
|
-
await getOrAskForProjectData(options, 'android');
|
|
70
|
-
|
|
71
|
-
// ======== STEP 1. Add Sentry Gradle Plugin to build.gradle(.kts) ============
|
|
72
|
-
clack.log.step(
|
|
73
|
-
`Adding ${chalk.bold('Sentry Gradle plugin')} to your app's ${chalk.cyan(
|
|
74
|
-
'build.gradle',
|
|
75
|
-
)} file.`,
|
|
76
|
-
);
|
|
77
|
-
const pluginAdded = await traceStep('Add Gradle Plugin', () =>
|
|
78
|
-
gradle.addGradlePlugin(
|
|
79
|
-
appFile,
|
|
80
|
-
selectedProject.organization.slug,
|
|
81
|
-
selectedProject.slug,
|
|
82
|
-
),
|
|
83
|
-
);
|
|
84
|
-
if (!pluginAdded) {
|
|
85
|
-
clack.log.warn(
|
|
86
|
-
"Could not add Sentry Gradle plugin to your app's build.gradle file. You'll have to add it manually.\nPlease follow the instructions at https://docs.sentry.io/platforms/android/#install",
|
|
87
|
-
);
|
|
88
|
-
}
|
|
89
|
-
Sentry.setTag('gradle-plugin-added', pluginAdded);
|
|
90
|
-
|
|
91
|
-
// ======== STEP 2. Configure Sentry SDK via AndroidManifest ============
|
|
92
|
-
clack.log.step(
|
|
93
|
-
`Configuring Sentry SDK via ${chalk.cyan('AndroidManifest.xml')}`,
|
|
94
|
-
);
|
|
95
|
-
const appDir = path.dirname(appFile);
|
|
96
|
-
const manifestFile = path.join(appDir, 'src', 'main', 'AndroidManifest.xml');
|
|
97
|
-
|
|
98
|
-
const manifestUpdated = traceStep('Update Android Manifest', () =>
|
|
99
|
-
manifest.addManifestSnippet(
|
|
100
|
-
manifestFile,
|
|
101
|
-
selectedProject.keys[0].dsn.public,
|
|
102
|
-
),
|
|
103
|
-
);
|
|
104
|
-
if (!manifestUpdated) {
|
|
105
|
-
clack.log.warn(
|
|
106
|
-
"Could not configure the Sentry SDK. You'll have to do it manually.\nPlease follow the instructions at https://docs.sentry.io/platforms/android/#configure",
|
|
107
|
-
);
|
|
108
|
-
}
|
|
109
|
-
Sentry.setTag('android-manifest-updated', manifestUpdated);
|
|
110
|
-
|
|
111
|
-
// ======== STEP 3. Patch Main Activity with a test error snippet ============
|
|
112
|
-
clack.log.step(
|
|
113
|
-
`Patching ${chalk.bold('Main Activity')} with a test error snippet.`,
|
|
114
|
-
);
|
|
115
|
-
const mainActivity = traceStep('Find Main Activity', () =>
|
|
116
|
-
manifest.getMainActivity(manifestFile),
|
|
117
|
-
);
|
|
118
|
-
let packageName = mainActivity.packageName;
|
|
119
|
-
if (!packageName) {
|
|
120
|
-
// if no package name in AndroidManifest, look into gradle script
|
|
121
|
-
packageName = gradle.getNamespace(appFile);
|
|
122
|
-
}
|
|
123
|
-
const activityName = mainActivity.activityName;
|
|
124
|
-
Sentry.setTag('has-activity-name', !!activityName);
|
|
125
|
-
Sentry.setTag('has-package-name', !!packageName);
|
|
126
|
-
if (!activityName || !packageName) {
|
|
127
|
-
clack.log.warn(
|
|
128
|
-
"Could not find Activity with intent action MAIN. You'll have to manually verify the setup.\nPlease follow the instructions at https://docs.sentry.io/platforms/android/#verify",
|
|
129
|
-
);
|
|
130
|
-
Sentry.captureException('Could not find Main Activity');
|
|
131
|
-
} else {
|
|
132
|
-
const packageNameStable = packageName;
|
|
133
|
-
const activityFile = traceStep('Find Main Activity Source File', () =>
|
|
134
|
-
codetools.findActivitySourceFile(appDir, packageNameStable, activityName),
|
|
135
|
-
);
|
|
136
|
-
|
|
137
|
-
const activityPatched = traceStep('Patch Main Activity', () =>
|
|
138
|
-
codetools.patchMainActivity(activityFile),
|
|
139
|
-
);
|
|
140
|
-
if (!activityPatched) {
|
|
141
|
-
clack.log.warn(
|
|
142
|
-
"Could not patch main activity. You'll have to manually verify the setup.\nPlease follow the instructions at https://docs.sentry.io/platforms/android/#verify",
|
|
143
|
-
);
|
|
144
|
-
}
|
|
145
|
-
Sentry.setTag('main-activity-patched', activityPatched);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
// ======== STEP 4. Add sentry-cli config file ============
|
|
149
|
-
clack.log.step(
|
|
150
|
-
`Configuring ${chalk.bold('proguard mappings upload')} via the ${chalk.cyan(
|
|
151
|
-
'sentry.properties',
|
|
152
|
-
)} file.`,
|
|
153
|
-
);
|
|
154
|
-
|
|
155
|
-
await addSentryCliConfig({ authToken }, proguardMappingCliSetupConfig);
|
|
156
|
-
|
|
157
|
-
// ======== OUTRO ========
|
|
158
|
-
const issuesPageLink = selfHosted
|
|
159
|
-
? `${sentryUrl}organizations/${selectedProject.organization.slug}/issues/?project=${selectedProject.id}`
|
|
160
|
-
: `https://${selectedProject.organization.slug}.sentry.io/issues/?project=${selectedProject.id}`;
|
|
161
|
-
|
|
162
|
-
clack.outro(`
|
|
163
|
-
${chalk.greenBright('Successfully installed the Sentry Android SDK!')}
|
|
164
|
-
|
|
165
|
-
${chalk.cyan(
|
|
166
|
-
`You can validate your setup by launching your application and checking Sentry issues page afterwards
|
|
167
|
-
${issuesPageLink}`,
|
|
168
|
-
)}
|
|
169
|
-
|
|
170
|
-
Check out the SDK documentation for further configuration:
|
|
171
|
-
https://docs.sentry.io/platforms/android/
|
|
172
|
-
`);
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
//find files with the given extension
|
|
176
|
-
function findFilesWithExtensions(
|
|
177
|
-
dir: string,
|
|
178
|
-
extensions: string[],
|
|
179
|
-
filesWithExtensions: string[] = [],
|
|
180
|
-
): string[] {
|
|
181
|
-
const cwd = process.cwd();
|
|
182
|
-
const files = fs.readdirSync(dir, { withFileTypes: true });
|
|
183
|
-
for (const file of files) {
|
|
184
|
-
if (file.isDirectory()) {
|
|
185
|
-
const childDir = path.join(dir, file.name);
|
|
186
|
-
findFilesWithExtensions(childDir, extensions, filesWithExtensions);
|
|
187
|
-
} else if (extensions.some((ext) => file.name.endsWith(ext))) {
|
|
188
|
-
filesWithExtensions.push(path.relative(cwd, path.join(dir, file.name)));
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
return filesWithExtensions;
|
|
192
|
-
}
|
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import * as Sentry from '@sentry/node';
|
|
4
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
5
|
-
import * as clack from '@clack/prompts';
|
|
6
|
-
import chalk from 'chalk';
|
|
7
|
-
import {
|
|
8
|
-
sentryImport,
|
|
9
|
-
sentryImportKt,
|
|
10
|
-
testErrorSnippet,
|
|
11
|
-
testErrorSnippetKt,
|
|
12
|
-
} from './templates';
|
|
13
|
-
import { findFile } from '../utils/ast-utils';
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Looks in src/main/java or src/main/kotlin for the specified {@link packageName} and
|
|
17
|
-
* {@link activityName} by concatenating them. For example:
|
|
18
|
-
*
|
|
19
|
-
* src/
|
|
20
|
-
* main/
|
|
21
|
-
* java/ or kotlin/
|
|
22
|
-
* my.package.name/
|
|
23
|
-
* ui/
|
|
24
|
-
* MainActivity.kt
|
|
25
|
-
*
|
|
26
|
-
* src/main/java can contain both .java and .kt sources, whilst src/main/kotlin only .kt
|
|
27
|
-
*
|
|
28
|
-
* @param appDir
|
|
29
|
-
* @param packageName
|
|
30
|
-
* @param activityName
|
|
31
|
-
* @returns path to the Main Activity
|
|
32
|
-
*/
|
|
33
|
-
export function findActivitySourceFile(
|
|
34
|
-
appDir: string,
|
|
35
|
-
packageName: string,
|
|
36
|
-
activityName: string,
|
|
37
|
-
): string | undefined {
|
|
38
|
-
const javaSrcDir = path.join(appDir, 'src', 'main', 'java');
|
|
39
|
-
let possibleActivityPath;
|
|
40
|
-
// if activity name starts with a dot, this means we need to concat packagename with it, otherwise
|
|
41
|
-
// the package name is already specified in the activity name itself
|
|
42
|
-
const packageNameParts = activityName.startsWith('.')
|
|
43
|
-
? packageName.split('.')
|
|
44
|
-
: [];
|
|
45
|
-
const activityNameParts = activityName.split('.');
|
|
46
|
-
|
|
47
|
-
if (fs.existsSync(javaSrcDir)) {
|
|
48
|
-
possibleActivityPath = findFile(
|
|
49
|
-
path.join(javaSrcDir, ...packageNameParts, ...activityNameParts),
|
|
50
|
-
['.kt', '.java'],
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
if (!possibleActivityPath || !fs.existsSync(possibleActivityPath)) {
|
|
55
|
-
const kotlinSrcDir = path.join(appDir, 'src', 'main', 'kotlin');
|
|
56
|
-
if (fs.existsSync(kotlinSrcDir)) {
|
|
57
|
-
possibleActivityPath = findFile(
|
|
58
|
-
path.join(kotlinSrcDir, ...packageNameParts, ...activityNameParts),
|
|
59
|
-
['.kt'],
|
|
60
|
-
);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return possibleActivityPath;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* Patches Main Activity with the test error code snippet by the specified path {@link activityFile}.
|
|
68
|
-
* Finds activity's `onCreate` method, adds the snippet and necessary imports.
|
|
69
|
-
*
|
|
70
|
-
* ```kotlin
|
|
71
|
-
* import something
|
|
72
|
-
* import something.something
|
|
73
|
-
* import io.sentry.Sentry <-- this is added by us
|
|
74
|
-
*
|
|
75
|
-
* override fun onCreate(savedInstanceState: Bundle?) {
|
|
76
|
-
* super.onCreate(savedInstanceState)
|
|
77
|
-
* // the snippet goes here <--
|
|
78
|
-
* doSomething()
|
|
79
|
-
* }
|
|
80
|
-
* ```
|
|
81
|
-
*
|
|
82
|
-
* @param activityFile
|
|
83
|
-
* @returns true if successfully patched, false otherwise
|
|
84
|
-
*/
|
|
85
|
-
export function patchMainActivity(activityFile: string | undefined): boolean {
|
|
86
|
-
if (!activityFile || !fs.existsSync(activityFile)) {
|
|
87
|
-
clack.log.warn('No main activity source file found in filesystem.');
|
|
88
|
-
Sentry.captureException('No main activity source file');
|
|
89
|
-
return false;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
const activityContent = fs.readFileSync(activityFile, 'utf8');
|
|
93
|
-
|
|
94
|
-
if (/import\s+io\.sentry\.Sentry;?/i.test(activityContent)) {
|
|
95
|
-
// sentry is already configured
|
|
96
|
-
clack.log.success(
|
|
97
|
-
chalk.greenBright(
|
|
98
|
-
`${chalk.bold(
|
|
99
|
-
'Main Activity',
|
|
100
|
-
)} is already patched with test error snippet.`,
|
|
101
|
-
),
|
|
102
|
-
);
|
|
103
|
-
return true;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
const importIndex = getLastImportLineLocation(activityContent);
|
|
107
|
-
|
|
108
|
-
let newActivityContent;
|
|
109
|
-
if (activityFile.endsWith('.kt')) {
|
|
110
|
-
newActivityContent =
|
|
111
|
-
activityContent.slice(0, importIndex) +
|
|
112
|
-
sentryImportKt +
|
|
113
|
-
activityContent.slice(importIndex);
|
|
114
|
-
} else {
|
|
115
|
-
newActivityContent =
|
|
116
|
-
activityContent.slice(0, importIndex) +
|
|
117
|
-
sentryImport +
|
|
118
|
-
activityContent.slice(importIndex);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
const onCreateMatch = /super\.onCreate\(.*?\);?/i.exec(newActivityContent);
|
|
122
|
-
if (!onCreateMatch) {
|
|
123
|
-
clack.log.warn('No onCreate method found in main activity.');
|
|
124
|
-
Sentry.captureException('No onCreate method');
|
|
125
|
-
return false;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
const onCreateIndex = onCreateMatch.index + onCreateMatch[0].length;
|
|
129
|
-
if (activityFile.endsWith('.kt')) {
|
|
130
|
-
newActivityContent =
|
|
131
|
-
newActivityContent.slice(0, onCreateIndex) +
|
|
132
|
-
testErrorSnippetKt +
|
|
133
|
-
newActivityContent.slice(onCreateIndex);
|
|
134
|
-
} else {
|
|
135
|
-
newActivityContent =
|
|
136
|
-
newActivityContent.slice(0, onCreateIndex) +
|
|
137
|
-
testErrorSnippet +
|
|
138
|
-
newActivityContent.slice(onCreateIndex);
|
|
139
|
-
}
|
|
140
|
-
fs.writeFileSync(activityFile, newActivityContent, 'utf8');
|
|
141
|
-
|
|
142
|
-
clack.log.success(
|
|
143
|
-
chalk.greenBright(
|
|
144
|
-
`Patched ${chalk.bold(
|
|
145
|
-
'Main Activity',
|
|
146
|
-
)} with the Sentry test error snippet.`,
|
|
147
|
-
),
|
|
148
|
-
);
|
|
149
|
-
|
|
150
|
-
return true;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Returns the string index of the last import statement in the given code file.
|
|
155
|
-
* Works for both Java and Kotlin import statements.
|
|
156
|
-
*
|
|
157
|
-
* @param sourceCode
|
|
158
|
-
* @returns the insert index, or 0 if none found.
|
|
159
|
-
*/
|
|
160
|
-
export function getLastImportLineLocation(sourceCode: string): number {
|
|
161
|
-
const importRegex = /import(?:\sstatic)?\s+[\w.*]+(?: as [\w.]+)?;?/gim;
|
|
162
|
-
|
|
163
|
-
let importsMatch = importRegex.exec(sourceCode);
|
|
164
|
-
let importIndex = 0;
|
|
165
|
-
while (importsMatch) {
|
|
166
|
-
importIndex = importsMatch.index + importsMatch[0].length + 1;
|
|
167
|
-
importsMatch = importRegex.exec(sourceCode);
|
|
168
|
-
}
|
|
169
|
-
return importIndex;
|
|
170
|
-
}
|