@sentry/wizard 4.0.0 → 4.0.2
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 +11 -2
- package/dist/NextJs/configs/next.config.js +1 -1
- package/dist/bin.js +2 -1
- package/dist/bin.js.map +1 -1
- package/dist/bump-version.js +28 -0
- package/dist/craft-pre-release.sh +2 -0
- package/dist/lib/Steps/Initial.js +2 -12
- package/dist/lib/Steps/Initial.js.map +1 -1
- package/dist/lib/Steps/Integrations/Electron.js +1 -1
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/dist/src/nextjs/templates.js +1 -1
- package/dist/src/nextjs/templates.js.map +1 -1
- package/dist/src/run.js +2 -18
- package/dist/src/run.js.map +1 -1
- package/dist/src/telemetry.js +2 -16
- package/dist/src/telemetry.js.map +1 -1
- package/dist/src/utils/clack-utils.d.ts +16 -0
- package/dist/src/utils/clack-utils.js +53 -45
- package/dist/src/utils/clack-utils.js.map +1 -1
- package/dist/src/version.d.ts +1 -0
- package/dist/src/version.js +7 -0
- package/dist/src/version.js.map +1 -0
- package/dist/test/nextjs/templates.test.js +4 -4
- package/dist/test/nextjs/templates.test.js.map +1 -1
- package/dist/test/utils/clack-utils.test.js +52 -0
- package/dist/test/utils/clack-utils.test.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/android/gradle.ts
DELETED
|
@@ -1,250 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
2
|
-
import * as fs from 'fs';
|
|
3
|
-
import { abortIfCancelled, askForItemSelection } from '../utils/clack-utils';
|
|
4
|
-
import {
|
|
5
|
-
plugin,
|
|
6
|
-
pluginKts,
|
|
7
|
-
pluginsBlock,
|
|
8
|
-
pluginsBlockKts,
|
|
9
|
-
sourceContext,
|
|
10
|
-
sourceContextKts,
|
|
11
|
-
} from './templates';
|
|
12
|
-
import * as bash from '../utils/bash';
|
|
13
|
-
import * as Sentry from '@sentry/node';
|
|
14
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
15
|
-
import * as clack from '@clack/prompts';
|
|
16
|
-
import chalk from 'chalk';
|
|
17
|
-
import { fetchSdkVersion } from '../utils/release-registry';
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* A Gradle project may contain multiple modules, some of them may be applications, some of them may be libraries.
|
|
21
|
-
* We are only interested in applications. For example:
|
|
22
|
-
*
|
|
23
|
-
* myproject/
|
|
24
|
-
* app/
|
|
25
|
-
* lib1/
|
|
26
|
-
* lib2/
|
|
27
|
-
* wearApp/
|
|
28
|
-
*
|
|
29
|
-
* In this case^ we are interested in app/ and wearApp/
|
|
30
|
-
*
|
|
31
|
-
* @param buildGradleFiles a list of build.gradle(.kts) paths that contain the com.android.application plugin
|
|
32
|
-
* @returns the selected project for setting up
|
|
33
|
-
*/
|
|
34
|
-
export async function selectAppFile(
|
|
35
|
-
buildGradleFiles: string[],
|
|
36
|
-
): Promise<string> {
|
|
37
|
-
const appFiles = [];
|
|
38
|
-
for (let index = 0; index < buildGradleFiles.length; index++) {
|
|
39
|
-
const file = buildGradleFiles[index];
|
|
40
|
-
const text = fs.readFileSync(file, 'utf8');
|
|
41
|
-
if (/\(?["']com\.android\.application["']\)?(?!.*\S)/.test(text)) {
|
|
42
|
-
appFiles.push(file);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
if (appFiles.length === 0) {
|
|
47
|
-
Sentry.setTag('custom-build-logic', true);
|
|
48
|
-
const appFile = await abortIfCancelled(
|
|
49
|
-
clack.text({
|
|
50
|
-
message: `Unable to find your app's directory.
|
|
51
|
-
Please enter the relative path to your app's build.gradle file from the root project`,
|
|
52
|
-
placeholder: 'app/build.gradle.kts',
|
|
53
|
-
validate(value) {
|
|
54
|
-
if (!value.includes('.gradle') || !fs.existsSync(value))
|
|
55
|
-
return `Not a valid gradle file.`;
|
|
56
|
-
},
|
|
57
|
-
}),
|
|
58
|
-
);
|
|
59
|
-
return appFile;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
let appFile;
|
|
63
|
-
if (appFiles.length === 1) {
|
|
64
|
-
Sentry.setTag('multiple-projects', false);
|
|
65
|
-
appFile = appFiles[0];
|
|
66
|
-
} else {
|
|
67
|
-
Sentry.setTag('multiple-projects', true);
|
|
68
|
-
appFile = (
|
|
69
|
-
await askForItemSelection(
|
|
70
|
-
appFiles,
|
|
71
|
-
'Which project do you want to add Sentry to?',
|
|
72
|
-
)
|
|
73
|
-
).value;
|
|
74
|
-
}
|
|
75
|
-
Sentry.setTag('custom-build-logic', false);
|
|
76
|
-
return appFile;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Patches a build.gradle(.kts) file that contains `com.android.application` plugin.
|
|
81
|
-
* There are multiple cases we have to handle here:
|
|
82
|
-
* - An existing `plugins {}` block:
|
|
83
|
-
* - We just have to add our plugin inside the block
|
|
84
|
-
* - No existing `plugins {}` block
|
|
85
|
-
* - We have to add the entire block in the beginning of the file, BUT *after imports*
|
|
86
|
-
*
|
|
87
|
-
* For example (2nd case):
|
|
88
|
-
*
|
|
89
|
-
* ```
|
|
90
|
-
* import net.ltgt.gradle.errorprone.errorprone
|
|
91
|
-
*
|
|
92
|
-
* // our plugins block goes here <--
|
|
93
|
-
* plugins {
|
|
94
|
-
* id("io.sentry.android.gradle") version "3.12.0"
|
|
95
|
-
* }
|
|
96
|
-
*
|
|
97
|
-
* apply(plugin = "com.android.application")
|
|
98
|
-
*
|
|
99
|
-
* android {
|
|
100
|
-
* ...
|
|
101
|
-
* }
|
|
102
|
-
* ```
|
|
103
|
-
*
|
|
104
|
-
* In the end we run `./gradlew` to verify the config is build-able and not broken.
|
|
105
|
-
*
|
|
106
|
-
* @param appFile the selected Gradle application project
|
|
107
|
-
* @returns true if successfully added Sentry Gradle config, false otherwise
|
|
108
|
-
*/
|
|
109
|
-
export async function addGradlePlugin(
|
|
110
|
-
appFile: string,
|
|
111
|
-
orgSlug: string,
|
|
112
|
-
projectSlug: string,
|
|
113
|
-
): Promise<boolean> {
|
|
114
|
-
const gradleScript = fs.readFileSync(appFile, 'utf8');
|
|
115
|
-
|
|
116
|
-
if (/\(?["']io\.sentry\.android\.gradle["']\)?/.test(gradleScript)) {
|
|
117
|
-
// sentry gradle plugin is already installed
|
|
118
|
-
clack.log.success(
|
|
119
|
-
chalk.greenBright(
|
|
120
|
-
`${chalk.bold(
|
|
121
|
-
'Sentry Gradle plugin',
|
|
122
|
-
)} is already added to the project.`,
|
|
123
|
-
),
|
|
124
|
-
);
|
|
125
|
-
maybeAddSourceContextConfig(appFile, gradleScript, orgSlug, projectSlug);
|
|
126
|
-
return true;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const pluginVersion = await fetchSdkVersion(
|
|
130
|
-
'sentry.java.android.gradle-plugin',
|
|
131
|
-
);
|
|
132
|
-
const pluginsBlockMatch = /plugins\s*{[^{}]*}/.exec(gradleScript);
|
|
133
|
-
let newGradleScript;
|
|
134
|
-
if (!pluginsBlockMatch) {
|
|
135
|
-
// no "plugins {}" block, we can just add our own after imports
|
|
136
|
-
const regex = /import\s+[\w.]+/gm;
|
|
137
|
-
let importsMatch = regex.exec(gradleScript);
|
|
138
|
-
let insertIndex = 0;
|
|
139
|
-
while (importsMatch) {
|
|
140
|
-
insertIndex = importsMatch.index + importsMatch[0].length + 1;
|
|
141
|
-
importsMatch = regex.exec(gradleScript);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (appFile.endsWith('.kts')) {
|
|
145
|
-
newGradleScript =
|
|
146
|
-
gradleScript.slice(0, insertIndex) +
|
|
147
|
-
pluginsBlockKts(pluginVersion) +
|
|
148
|
-
gradleScript.slice(insertIndex);
|
|
149
|
-
} else {
|
|
150
|
-
newGradleScript =
|
|
151
|
-
gradleScript.slice(0, insertIndex) +
|
|
152
|
-
pluginsBlock(pluginVersion) +
|
|
153
|
-
gradleScript.slice(insertIndex);
|
|
154
|
-
}
|
|
155
|
-
} else {
|
|
156
|
-
const insertIndex =
|
|
157
|
-
pluginsBlockMatch.index + pluginsBlockMatch[0].length - 1;
|
|
158
|
-
if (appFile.endsWith('.kts')) {
|
|
159
|
-
newGradleScript =
|
|
160
|
-
gradleScript.slice(0, insertIndex) +
|
|
161
|
-
pluginKts(pluginVersion) +
|
|
162
|
-
gradleScript.slice(insertIndex);
|
|
163
|
-
} else {
|
|
164
|
-
newGradleScript =
|
|
165
|
-
gradleScript.slice(0, insertIndex) +
|
|
166
|
-
plugin(pluginVersion) +
|
|
167
|
-
gradleScript.slice(insertIndex);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
fs.writeFileSync(appFile, newGradleScript, 'utf8');
|
|
171
|
-
|
|
172
|
-
maybeAddSourceContextConfig(appFile, newGradleScript, orgSlug, projectSlug);
|
|
173
|
-
|
|
174
|
-
const buildSpinner = clack.spinner();
|
|
175
|
-
|
|
176
|
-
buildSpinner.start(
|
|
177
|
-
'Running ./gradlew to verify changes (this may take a few minutes)...',
|
|
178
|
-
);
|
|
179
|
-
|
|
180
|
-
try {
|
|
181
|
-
await bash.execute('./gradlew');
|
|
182
|
-
buildSpinner.stop(
|
|
183
|
-
chalk.greenBright(
|
|
184
|
-
`${chalk.bold('Sentry Gradle plugin')} added to the project.`,
|
|
185
|
-
),
|
|
186
|
-
);
|
|
187
|
-
} catch (e) {
|
|
188
|
-
buildSpinner.stop();
|
|
189
|
-
Sentry.captureException('Gradle Sync failed');
|
|
190
|
-
return false;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
return true;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
/**
|
|
197
|
-
* Looks for the applications packageName (namespace) in the specified build.gradle(.kts) file.
|
|
198
|
-
*
|
|
199
|
-
* ```
|
|
200
|
-
* android {
|
|
201
|
-
* namespace 'my.package.name' <-- this is what we extract
|
|
202
|
-
*
|
|
203
|
-
* compileSdkVersion = 31
|
|
204
|
-
* ...
|
|
205
|
-
* }
|
|
206
|
-
* ```
|
|
207
|
-
* @param appFile
|
|
208
|
-
* @returns the packageName(namespace) of the app if available
|
|
209
|
-
*/
|
|
210
|
-
export function getNamespace(appFile: string): string | undefined {
|
|
211
|
-
const gradleScript = fs.readFileSync(appFile, 'utf8');
|
|
212
|
-
|
|
213
|
-
const namespaceMatch = /namespace\s*=?\s*['"]([^'"]+)['"]/i.exec(
|
|
214
|
-
gradleScript,
|
|
215
|
-
);
|
|
216
|
-
if (!namespaceMatch || namespaceMatch.length <= 1) {
|
|
217
|
-
clack.log.warn('Unable to determine application package name.');
|
|
218
|
-
Sentry.captureException('No package name');
|
|
219
|
-
return undefined;
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
const namespace = namespaceMatch[1];
|
|
223
|
-
return namespace;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
/**
|
|
227
|
-
* Adds source context configuration to the gradleScript if `sentry {}` block is not yet configured,
|
|
228
|
-
*
|
|
229
|
-
* @param appFile
|
|
230
|
-
* @param gradleScript
|
|
231
|
-
*/
|
|
232
|
-
function maybeAddSourceContextConfig(
|
|
233
|
-
appFile: string,
|
|
234
|
-
gradleScript: string,
|
|
235
|
-
orgSlug: string,
|
|
236
|
-
projectSlug: string,
|
|
237
|
-
) {
|
|
238
|
-
if (!/sentry\s*\{[^}]*\}/i.test(gradleScript)) {
|
|
239
|
-
// if no sentry {} block is configured, we add our own with source context enabled
|
|
240
|
-
if (appFile.endsWith('.kts')) {
|
|
241
|
-
fs.appendFileSync(
|
|
242
|
-
appFile,
|
|
243
|
-
sourceContextKts(orgSlug, projectSlug),
|
|
244
|
-
'utf8',
|
|
245
|
-
);
|
|
246
|
-
} else {
|
|
247
|
-
fs.appendFileSync(appFile, sourceContext(orgSlug, projectSlug), 'utf8');
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
package/src/android/manifest.ts
DELETED
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
3
|
-
import * as fs from 'fs';
|
|
4
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
5
|
-
import * as clack from '@clack/prompts';
|
|
6
|
-
import * as Sentry from '@sentry/node';
|
|
7
|
-
import { manifest } from './templates';
|
|
8
|
-
import xml, { Attributes, ElementCompact } from 'xml-js';
|
|
9
|
-
import chalk from 'chalk';
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Looks for the closing </application> tag in the manifest and adds the Sentry config after it.
|
|
13
|
-
*
|
|
14
|
-
* For example:
|
|
15
|
-
* ```xml
|
|
16
|
-
* <manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
|
17
|
-
* xmlns:tools="http://schemas.android.com/tools">
|
|
18
|
-
*
|
|
19
|
-
* <application>
|
|
20
|
-
* ...
|
|
21
|
-
* // this is what we add and more
|
|
22
|
-
* <meta-data android:name="io.sentry.dsn" android:value="__dsn__" />
|
|
23
|
-
* </application> <!-- we are looking for this one
|
|
24
|
-
* </manifest>
|
|
25
|
-
* ```
|
|
26
|
-
*
|
|
27
|
-
* @param manifestFile the path to the main AndroidManifest.xml file
|
|
28
|
-
* @param dsn
|
|
29
|
-
* @returns true if successfully patched the manifest, false otherwise
|
|
30
|
-
*/
|
|
31
|
-
export function addManifestSnippet(manifestFile: string, dsn: string): boolean {
|
|
32
|
-
if (!fs.existsSync(manifestFile)) {
|
|
33
|
-
clack.log.warn('AndroidManifest.xml not found.');
|
|
34
|
-
Sentry.captureException('No AndroidManifest file');
|
|
35
|
-
return false;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const manifestContent = fs.readFileSync(manifestFile, 'utf8');
|
|
39
|
-
|
|
40
|
-
if (/android:name="io\.sentry[^"]*"/i.test(manifestContent)) {
|
|
41
|
-
// sentry is already configured
|
|
42
|
-
clack.log.success(chalk.greenBright('Sentry SDK is already configured.'));
|
|
43
|
-
return true;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const applicationMatch = /<\/application>/i.exec(manifestContent);
|
|
47
|
-
if (!applicationMatch) {
|
|
48
|
-
clack.log.warn('<application> tag not found within the manifest.');
|
|
49
|
-
Sentry.captureException('No <application> tag');
|
|
50
|
-
return false;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
const insertionIndex = applicationMatch.index;
|
|
54
|
-
const newContent =
|
|
55
|
-
manifestContent.slice(0, insertionIndex) +
|
|
56
|
-
manifest(dsn) +
|
|
57
|
-
manifestContent.slice(insertionIndex);
|
|
58
|
-
fs.writeFileSync(manifestFile, newContent, 'utf8');
|
|
59
|
-
|
|
60
|
-
clack.log.success(
|
|
61
|
-
chalk.greenBright(
|
|
62
|
-
`Updated ${chalk.bold(
|
|
63
|
-
'AndroidManifest.xml',
|
|
64
|
-
)} with the Sentry SDK configuration.`,
|
|
65
|
-
),
|
|
66
|
-
);
|
|
67
|
-
|
|
68
|
-
return true;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* There might be multiple <activity> in the manifest, as well as multiple <activity-alias> with category LAUNCHER,
|
|
73
|
-
* but only one main activity with action MAIN. We are looking for this one by parsing xml and walking it.
|
|
74
|
-
*
|
|
75
|
-
* In addition, older Android versions required to specify the packag name in the manifest,
|
|
76
|
-
* while the new ones - in the Gradle config. So we are just sanity checking if the package name
|
|
77
|
-
* is in the manifest and returning it as well.
|
|
78
|
-
*
|
|
79
|
-
* For example:
|
|
80
|
-
*
|
|
81
|
-
* ```xml
|
|
82
|
-
* <manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
|
83
|
-
* xmlns:tools="http://schemas.android.com/tools"
|
|
84
|
-
* package="com.example.sample">
|
|
85
|
-
*
|
|
86
|
-
* <application>
|
|
87
|
-
* <activity
|
|
88
|
-
* android:name="ui.MainActivity"
|
|
89
|
-
* ...other props>
|
|
90
|
-
* <intent-filter>
|
|
91
|
-
* <action android:name="android.intent.action.MAIN" /> <!-- we are looking for this one
|
|
92
|
-
*
|
|
93
|
-
* <category android:name="android.intent.category.LAUNCHER" />
|
|
94
|
-
* </intent-filter>
|
|
95
|
-
* </activity>
|
|
96
|
-
* </application>
|
|
97
|
-
* </manifest>
|
|
98
|
-
* ```
|
|
99
|
-
*
|
|
100
|
-
* @param manifestFile path to the AndroidManifest.xml file
|
|
101
|
-
* @returns package name (if available in the manifest) + the main activity name
|
|
102
|
-
*/
|
|
103
|
-
export function getMainActivity(manifestFile: string): {
|
|
104
|
-
packageName?: string;
|
|
105
|
-
activityName?: string;
|
|
106
|
-
} {
|
|
107
|
-
if (!fs.existsSync(manifestFile)) {
|
|
108
|
-
clack.log.warn('AndroidManifest.xml not found.');
|
|
109
|
-
Sentry.captureException('No AndroidManifest file');
|
|
110
|
-
return {};
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
const manifestContent = fs.readFileSync(manifestFile, 'utf8');
|
|
114
|
-
const converted: ElementCompact = xml.xml2js(manifestContent, {
|
|
115
|
-
compact: true,
|
|
116
|
-
});
|
|
117
|
-
const activities: ElementCompact[] | ElementCompact | undefined =
|
|
118
|
-
converted.manifest?.application?.activity;
|
|
119
|
-
const packageName: string | undefined =
|
|
120
|
-
converted.manifest?._attributes?.['package'];
|
|
121
|
-
|
|
122
|
-
if (!activities) {
|
|
123
|
-
clack.log.warn('No activity found in AndroidManifest.');
|
|
124
|
-
Sentry.captureException('No Activity');
|
|
125
|
-
return {};
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
let mainActivity;
|
|
129
|
-
if (Array.isArray(activities)) {
|
|
130
|
-
const withIntentFilter = activities.filter((a) => !!a['intent-filter']);
|
|
131
|
-
mainActivity = withIntentFilter.find((a) => isMainActivity(a));
|
|
132
|
-
} else if (isMainActivity(activities)) {
|
|
133
|
-
mainActivity = activities;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
if (!mainActivity) {
|
|
137
|
-
clack.log.warn('No main activity found in AndroidManifest.');
|
|
138
|
-
Sentry.captureException('No Main Activity');
|
|
139
|
-
return {};
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
const attrs = mainActivity._attributes;
|
|
143
|
-
const activityName = attrs?.['android:name'] as string | undefined;
|
|
144
|
-
return { packageName: packageName, activityName: activityName };
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
function isMainActivity(activity: ElementCompact): boolean {
|
|
148
|
-
const intentFilters: ElementCompact[] | ElementCompact =
|
|
149
|
-
activity['intent-filter'];
|
|
150
|
-
if (Array.isArray(intentFilters)) {
|
|
151
|
-
return intentFilters.some((i) => {
|
|
152
|
-
const action: ElementCompact[] | ElementCompact | undefined = i.action;
|
|
153
|
-
return hasMainAction(action);
|
|
154
|
-
});
|
|
155
|
-
} else {
|
|
156
|
-
const action: ElementCompact[] | ElementCompact | undefined =
|
|
157
|
-
intentFilters.action;
|
|
158
|
-
return hasMainAction(action);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
function hasMainAction(
|
|
163
|
-
action: ElementCompact[] | ElementCompact | undefined,
|
|
164
|
-
): boolean {
|
|
165
|
-
if (!action) {
|
|
166
|
-
return false;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
function isMain(attrs?: Attributes): boolean {
|
|
170
|
-
return attrs?.['android:name'] === 'android.intent.action.MAIN';
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
if (Array.isArray(action)) {
|
|
174
|
-
return action.some((c) => {
|
|
175
|
-
return isMain(c._attributes);
|
|
176
|
-
});
|
|
177
|
-
} else {
|
|
178
|
-
return isMain(action._attributes);
|
|
179
|
-
}
|
|
180
|
-
}
|
package/src/android/templates.ts
DELETED
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
export const pluginsBlock = (version = '3.12.0') => `
|
|
2
|
-
plugins {
|
|
3
|
-
id 'io.sentry.android.gradle' version '${version}'
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
`;
|
|
7
|
-
|
|
8
|
-
export const pluginsBlockKts = (version = '3.12.0') => `
|
|
9
|
-
plugins {
|
|
10
|
-
id("io.sentry.android.gradle") version "${version}"
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
`;
|
|
14
|
-
|
|
15
|
-
export const plugin = (version = '3.12.0') => `
|
|
16
|
-
id 'io.sentry.android.gradle' version '${version}'
|
|
17
|
-
`;
|
|
18
|
-
|
|
19
|
-
export const pluginKts = (version = '3.12.0') => `
|
|
20
|
-
id("io.sentry.android.gradle") version "${version}"
|
|
21
|
-
`;
|
|
22
|
-
|
|
23
|
-
export const manifest = (dsn: string) => `
|
|
24
|
-
<!-- Required: set your sentry.io project identifier (DSN) -->
|
|
25
|
-
<meta-data android:name="io.sentry.dsn" android:value="${dsn}" />
|
|
26
|
-
|
|
27
|
-
<!-- enable automatic breadcrumbs for user interactions (clicks, swipes, scrolls) -->
|
|
28
|
-
<meta-data android:name="io.sentry.traces.user-interaction.enable" android:value="true" />
|
|
29
|
-
<!-- enable screenshot for crashes (could contain sensitive/PII data) -->
|
|
30
|
-
<meta-data android:name="io.sentry.attach-screenshot" android:value="true" />
|
|
31
|
-
<!-- enable view hierarchy for crashes -->
|
|
32
|
-
<meta-data android:name="io.sentry.attach-view-hierarchy" android:value="true" />
|
|
33
|
-
|
|
34
|
-
<!-- enable the performance API by setting a sample-rate, adjust in production env -->
|
|
35
|
-
<meta-data android:name="io.sentry.traces.sample-rate" android:value="1.0" />
|
|
36
|
-
`;
|
|
37
|
-
|
|
38
|
-
export const sentryImport = `import io.sentry.Sentry;\n`;
|
|
39
|
-
|
|
40
|
-
export const sentryImportKt = `import io.sentry.Sentry\n`;
|
|
41
|
-
|
|
42
|
-
export const testErrorSnippet = `
|
|
43
|
-
// waiting for view to draw to better represent a captured error with a screenshot
|
|
44
|
-
findViewById(android.R.id.content).getViewTreeObserver().addOnGlobalLayoutListener(() -> {
|
|
45
|
-
try {
|
|
46
|
-
throw new Exception("This app uses Sentry! :)");
|
|
47
|
-
} catch (Exception e) {
|
|
48
|
-
Sentry.captureException(e);
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
`;
|
|
52
|
-
|
|
53
|
-
export const testErrorSnippetKt = `
|
|
54
|
-
// waiting for view to draw to better represent a captured error with a screenshot
|
|
55
|
-
findViewById<android.view.View>(android.R.id.content).viewTreeObserver.addOnGlobalLayoutListener {
|
|
56
|
-
try {
|
|
57
|
-
throw Exception("This app uses Sentry! :)")
|
|
58
|
-
} catch (e: Exception) {
|
|
59
|
-
Sentry.captureException(e)
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
`;
|
|
63
|
-
|
|
64
|
-
export const sourceContext = (orgSlug: string, projectSlug: string) => `
|
|
65
|
-
|
|
66
|
-
sentry {
|
|
67
|
-
org = "${orgSlug}"
|
|
68
|
-
projectName = "${projectSlug}"
|
|
69
|
-
|
|
70
|
-
// this will upload your source code to Sentry to show it as part of the stack traces
|
|
71
|
-
// disable if you don't want to expose your sources
|
|
72
|
-
includeSourceContext = true
|
|
73
|
-
}
|
|
74
|
-
`;
|
|
75
|
-
|
|
76
|
-
export const sourceContextKts = (orgSlug: string, projectSlug: string) => `
|
|
77
|
-
|
|
78
|
-
sentry {
|
|
79
|
-
org.set("${orgSlug}")
|
|
80
|
-
projectName.set("${projectSlug}")
|
|
81
|
-
|
|
82
|
-
// this will upload your source code to Sentry to show it as part of the stack traces
|
|
83
|
-
// disable if you don't want to expose your sources
|
|
84
|
-
includeSourceContext.set(true)
|
|
85
|
-
}
|
|
86
|
-
`;
|