@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/react-native/expo.ts
DELETED
|
@@ -1,175 +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 chalk from 'chalk';
|
|
4
|
-
import * as fs from 'fs';
|
|
5
|
-
import { EOL } from 'os';
|
|
6
|
-
|
|
7
|
-
import { isPlainObject } from '@sentry/utils';
|
|
8
|
-
import * as Sentry from '@sentry/node';
|
|
9
|
-
import {
|
|
10
|
-
makeCodeSnippet,
|
|
11
|
-
showCopyPasteInstructions,
|
|
12
|
-
} from '../utils/clack-utils';
|
|
13
|
-
import { RNCliSetupConfigContent } from './react-native-wizard';
|
|
14
|
-
import { traceStep } from '../telemetry';
|
|
15
|
-
|
|
16
|
-
export const SENTRY_EXPO_PLUGIN_NAME = '@sentry/react-native/expo';
|
|
17
|
-
export const DEPRECATED_SENTRY_EXPO_PLUGIN_NAME = 'sentry-expo';
|
|
18
|
-
|
|
19
|
-
export const SENTRY_PLUGIN_FUNCTION_NAME = 'withSentry';
|
|
20
|
-
|
|
21
|
-
const APP_CONFIG_JSON = `app.json`;
|
|
22
|
-
|
|
23
|
-
export interface AppConfigJson {
|
|
24
|
-
expo?: {
|
|
25
|
-
plugins?: Array<[string, undefined | Record<string, unknown>]>;
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function printSentryExpoMigrationOutro(): void {
|
|
30
|
-
clack.outro(
|
|
31
|
-
`Deprecated ${chalk.cyan(
|
|
32
|
-
'sentry-expo',
|
|
33
|
-
)} package installed in your dependencies. Please follow the migration guide at ${chalk.cyan(
|
|
34
|
-
'https://docs.sentry.io/platforms/react-native/migration/sentry-expo/',
|
|
35
|
-
)}`,
|
|
36
|
-
);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Finds app.json in the project root and add Sentry Expo `withSentry` plugin.
|
|
41
|
-
*/
|
|
42
|
-
export async function patchExpoAppConfig(options: RNCliSetupConfigContent) {
|
|
43
|
-
function showInstructions() {
|
|
44
|
-
return showCopyPasteInstructions(
|
|
45
|
-
APP_CONFIG_JSON,
|
|
46
|
-
getSentryAppConfigJsonCodeSnippet(options),
|
|
47
|
-
'This ensures auto upload of source maps during native app build.',
|
|
48
|
-
);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const appConfigJsonExists = fs.existsSync(APP_CONFIG_JSON);
|
|
52
|
-
|
|
53
|
-
Sentry.setTag(
|
|
54
|
-
'app-config-file-status',
|
|
55
|
-
appConfigJsonExists ? 'found' : 'not-found',
|
|
56
|
-
);
|
|
57
|
-
if (!appConfigJsonExists) {
|
|
58
|
-
return await showInstructions();
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
const patched = await patchAppConfigJson(APP_CONFIG_JSON, options);
|
|
62
|
-
if (!patched) {
|
|
63
|
-
return await showInstructions();
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
async function patchAppConfigJson(
|
|
68
|
-
path: string,
|
|
69
|
-
options: RNCliSetupConfigContent,
|
|
70
|
-
): Promise<boolean> {
|
|
71
|
-
const appConfigContent = (
|
|
72
|
-
await fs.promises.readFile(path, { encoding: 'utf-8' })
|
|
73
|
-
).toString();
|
|
74
|
-
const patchedContent = traceStep('app-config-json-patch', () =>
|
|
75
|
-
addWithSentryToAppConfigJson(appConfigContent, options),
|
|
76
|
-
);
|
|
77
|
-
if (patchedContent === null) {
|
|
78
|
-
return false;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
try {
|
|
82
|
-
await fs.promises.writeFile(path, patchedContent);
|
|
83
|
-
} catch (error) {
|
|
84
|
-
Sentry.setTag('app-config-file-status', 'json-write-error');
|
|
85
|
-
clack.log.error(`Unable to write ${chalk.cyan('app.config.json')}.`);
|
|
86
|
-
return false;
|
|
87
|
-
}
|
|
88
|
-
Sentry.setTag('app-config-file-status', 'json-write-success');
|
|
89
|
-
clack.log.success(
|
|
90
|
-
`Added Sentry Expo plugin to ${chalk.cyan('app.config.json')}.`,
|
|
91
|
-
);
|
|
92
|
-
return true;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
export function addWithSentryToAppConfigJson(
|
|
96
|
-
appConfigContent: string,
|
|
97
|
-
options: RNCliSetupConfigContent,
|
|
98
|
-
): string | null {
|
|
99
|
-
try {
|
|
100
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
101
|
-
const parsedAppConfig: AppConfigJson = JSON.parse(appConfigContent);
|
|
102
|
-
const includesWithSentry =
|
|
103
|
-
appConfigContent.includes(SENTRY_EXPO_PLUGIN_NAME) ||
|
|
104
|
-
appConfigContent.includes(DEPRECATED_SENTRY_EXPO_PLUGIN_NAME);
|
|
105
|
-
|
|
106
|
-
if (includesWithSentry) {
|
|
107
|
-
Sentry.setTag('app-config-file-status', 'already-patched');
|
|
108
|
-
clack.log.warn(
|
|
109
|
-
`Your ${chalk.cyan(
|
|
110
|
-
'app.config.json',
|
|
111
|
-
)} already includes the Sentry Expo plugin.`,
|
|
112
|
-
);
|
|
113
|
-
return null;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
if (
|
|
117
|
-
parsedAppConfig.expo !== undefined &&
|
|
118
|
-
!isPlainObject(parsedAppConfig.expo)
|
|
119
|
-
) {
|
|
120
|
-
Sentry.setTag('app-config-file-status', 'invalid-json');
|
|
121
|
-
return null;
|
|
122
|
-
}
|
|
123
|
-
if (
|
|
124
|
-
parsedAppConfig.expo &&
|
|
125
|
-
parsedAppConfig.expo.plugins !== undefined &&
|
|
126
|
-
!Array.isArray(parsedAppConfig.expo.plugins)
|
|
127
|
-
) {
|
|
128
|
-
Sentry.setTag('app-config-file-status', 'invalid-json');
|
|
129
|
-
return null;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
parsedAppConfig.expo = parsedAppConfig.expo ?? {};
|
|
133
|
-
parsedAppConfig.expo.plugins = parsedAppConfig.expo.plugins ?? [];
|
|
134
|
-
parsedAppConfig.expo.plugins.push([
|
|
135
|
-
SENTRY_EXPO_PLUGIN_NAME,
|
|
136
|
-
{
|
|
137
|
-
url: options.url,
|
|
138
|
-
project: options.project,
|
|
139
|
-
organization: options.org,
|
|
140
|
-
},
|
|
141
|
-
]);
|
|
142
|
-
|
|
143
|
-
return JSON.stringify(parsedAppConfig, null, 2) + EOL;
|
|
144
|
-
} catch (error) {
|
|
145
|
-
Sentry.setTag('app-config-file-status', 'invalid-json');
|
|
146
|
-
clack.log.error(
|
|
147
|
-
`Unable to parse your ${chalk.cyan(
|
|
148
|
-
'app.config.json',
|
|
149
|
-
)}. Make sure it has a valid format!`,
|
|
150
|
-
);
|
|
151
|
-
return null;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
export function getSentryAppConfigJsonCodeSnippet({
|
|
156
|
-
url,
|
|
157
|
-
project,
|
|
158
|
-
org,
|
|
159
|
-
}: Omit<RNCliSetupConfigContent, 'authToken'>) {
|
|
160
|
-
return makeCodeSnippet(true, (unchanged, plus, _minus) => {
|
|
161
|
-
return unchanged(`{
|
|
162
|
-
"name": "my app",
|
|
163
|
-
"plugins": [
|
|
164
|
-
${plus(`[
|
|
165
|
-
"@sentry/react-native/expo",
|
|
166
|
-
{
|
|
167
|
-
"url": "${url}",
|
|
168
|
-
"project": "${project}",
|
|
169
|
-
"organization": "${org}"
|
|
170
|
-
}
|
|
171
|
-
]`)}
|
|
172
|
-
],
|
|
173
|
-
}`);
|
|
174
|
-
});
|
|
175
|
-
}
|
package/src/react-native/git.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
|
|
3
|
-
const GITIGNORE_FILENAME = '.gitignore';
|
|
4
|
-
|
|
5
|
-
export async function addToGitignore(filepath: string): Promise<boolean> {
|
|
6
|
-
/**
|
|
7
|
-
* Don't check whether the given file is ignored because:
|
|
8
|
-
* 1. It's tricky to check it without git.
|
|
9
|
-
* 2. Git might not be installed or accessible.
|
|
10
|
-
* 3. It's convenient to use a module to interact with git, but it would
|
|
11
|
-
* increase the size x2 approximately. Docs say to run the Wizard without
|
|
12
|
-
* installing it, and duplicating the size would slow the set-up down.
|
|
13
|
-
* 4. The Wizard is meant to be run once.
|
|
14
|
-
* 5. A message is logged informing users it's been added to the gitignore.
|
|
15
|
-
* 6. It will be added to the gitignore as many times as it runs - not a big
|
|
16
|
-
* deal.
|
|
17
|
-
* 7. It's straightforward to remove it from the gitignore.
|
|
18
|
-
*/
|
|
19
|
-
try {
|
|
20
|
-
await fs.promises.appendFile(GITIGNORE_FILENAME, `\n${filepath}\n`);
|
|
21
|
-
return true;
|
|
22
|
-
} catch {
|
|
23
|
-
return false;
|
|
24
|
-
}
|
|
25
|
-
}
|
package/src/react-native/glob.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import * as glob from 'glob';
|
|
2
|
-
|
|
3
|
-
export const XCODE_PROJECT = 'ios/*.xcodeproj/project.pbxproj';
|
|
4
|
-
export const APP_BUILD_GRADLE = '**/app/build.gradle';
|
|
5
|
-
|
|
6
|
-
const IGNORE_PATTERNS = ['node_modules/**', 'ios/Pods/**', '**/Pods/**'];
|
|
7
|
-
export function getFirstMatchedPath(pattern: string): string | undefined {
|
|
8
|
-
const matches = glob.sync(pattern, {
|
|
9
|
-
ignore: IGNORE_PATTERNS,
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
return matches[0];
|
|
13
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
|
|
3
|
-
const applyFrom = `apply from: new File(["node", "--print", "require.resolve('@sentry/react-native/package.json')"].execute().text.trim(), "../sentry.gradle")`;
|
|
4
|
-
|
|
5
|
-
export function doesAppBuildGradleIncludeRNSentryGradlePlugin(
|
|
6
|
-
content: string,
|
|
7
|
-
): boolean {
|
|
8
|
-
return content.includes('sentry.gradle');
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export function addRNSentryGradlePlugin(content: string): string {
|
|
12
|
-
return content.replace(/^android {/m, (match) => `${applyFrom}\n${match}`);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function removeRNSentryGradlePlugin(content: string): string {
|
|
16
|
-
return content.replace(/^\s*apply from:.*sentry\.gradle.*;?\s*?\r?\n/m, '');
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export function writeAppBuildGradle(path: string, newContent: string): void {
|
|
20
|
-
const currentContent = fs.readFileSync(path, 'utf-8');
|
|
21
|
-
if (newContent === currentContent) {
|
|
22
|
-
return;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
fs.writeFileSync(path, newContent, 'utf-8');
|
|
26
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
/* eslint-disable max-lines */
|
|
2
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
3
|
-
import clack from '@clack/prompts';
|
|
4
|
-
import chalk from 'chalk';
|
|
5
|
-
import * as path from 'path';
|
|
6
|
-
import * as process from 'process';
|
|
7
|
-
import * as fs from 'fs';
|
|
8
|
-
import * as Sentry from '@sentry/node';
|
|
9
|
-
|
|
10
|
-
import { traceStep } from '../telemetry';
|
|
11
|
-
import {
|
|
12
|
-
makeCodeSnippet,
|
|
13
|
-
showCopyPasteInstructions,
|
|
14
|
-
} from '../utils/clack-utils';
|
|
15
|
-
import { getFirstMatchedPath } from './glob';
|
|
16
|
-
import { RN_SDK_PACKAGE } from './react-native-wizard';
|
|
17
|
-
|
|
18
|
-
export async function addSentryInit({ dsn }: { dsn: string }) {
|
|
19
|
-
const prefixGlob = '{.,./src,./app}';
|
|
20
|
-
const suffixGlob = '@(j|t|cj|mj)s?(x)';
|
|
21
|
-
const universalGlob = `@(App|_layout).${suffixGlob}`;
|
|
22
|
-
const jsFileGlob = `${prefixGlob}/+(${universalGlob})`;
|
|
23
|
-
const jsPath = traceStep('find-app-js-file', () =>
|
|
24
|
-
getFirstMatchedPath(jsFileGlob),
|
|
25
|
-
);
|
|
26
|
-
Sentry.setTag('app-js-file-status', jsPath ? 'found' : 'not-found');
|
|
27
|
-
if (!jsPath) {
|
|
28
|
-
clack.log.warn(
|
|
29
|
-
`Could not find main App file. Place the following code snippet close to the Apps Root component.`,
|
|
30
|
-
);
|
|
31
|
-
await showCopyPasteInstructions(
|
|
32
|
-
'App.js or _layout.tsx',
|
|
33
|
-
getSentryInitColoredCodeSnippet(dsn),
|
|
34
|
-
'This ensures the Sentry SDK is ready to capture errors.',
|
|
35
|
-
);
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
const jsRelativePath = path.relative(process.cwd(), jsPath);
|
|
39
|
-
|
|
40
|
-
const js = fs.readFileSync(jsPath, 'utf-8');
|
|
41
|
-
const includesSentry = doesJsCodeIncludeSdkSentryImport(js, {
|
|
42
|
-
sdkPackageName: RN_SDK_PACKAGE,
|
|
43
|
-
});
|
|
44
|
-
if (includesSentry) {
|
|
45
|
-
Sentry.setTag('app-js-file-status', 'already-includes-sentry');
|
|
46
|
-
clack.log.warn(
|
|
47
|
-
`${chalk.cyan(
|
|
48
|
-
jsRelativePath,
|
|
49
|
-
)} already includes Sentry. We wont't add it again.`,
|
|
50
|
-
);
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
traceStep('add-sentry-init', () => {
|
|
55
|
-
const newContent = addSentryInitWithSdkImport(js, { dsn });
|
|
56
|
-
|
|
57
|
-
clack.log.success(
|
|
58
|
-
`Added ${chalk.cyan('Sentry.init')} to ${chalk.cyan(jsRelativePath)}.`,
|
|
59
|
-
);
|
|
60
|
-
|
|
61
|
-
fs.writeFileSync(jsPath, newContent, 'utf-8');
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
Sentry.setTag('app-js-file-status', 'added-sentry-init');
|
|
65
|
-
clack.log.success(
|
|
66
|
-
chalk.green(`${chalk.cyan(jsRelativePath)} changes saved.`),
|
|
67
|
-
);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export function addSentryInitWithSdkImport(
|
|
71
|
-
js: string,
|
|
72
|
-
{ dsn }: { dsn: string },
|
|
73
|
-
): string {
|
|
74
|
-
return js.replace(
|
|
75
|
-
/^([^]*)(import\s+[^;]*?;$)/m,
|
|
76
|
-
(match: string) => `${match}
|
|
77
|
-
${getSentryInitPlainTextSnippet(dsn)}`,
|
|
78
|
-
);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
export function doesJsCodeIncludeSdkSentryImport(
|
|
82
|
-
js: string,
|
|
83
|
-
{ sdkPackageName }: { sdkPackageName: string },
|
|
84
|
-
): boolean {
|
|
85
|
-
return !!js.match(sdkPackageName);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
export function getSentryInitColoredCodeSnippet(dsn: string) {
|
|
89
|
-
return makeCodeSnippet(true, (_unchanged, plus, _minus) => {
|
|
90
|
-
return plus(getSentryInitPlainTextSnippet(dsn));
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
export function getSentryInitPlainTextSnippet(dsn: string) {
|
|
95
|
-
return `import * as Sentry from '@sentry/react-native';
|
|
96
|
-
|
|
97
|
-
Sentry.init({
|
|
98
|
-
dsn: '${dsn}',
|
|
99
|
-
|
|
100
|
-
// uncomment the line below to enable Spotlight (https://spotlightjs.com)
|
|
101
|
-
// spotlight: __DEV__,
|
|
102
|
-
});`;
|
|
103
|
-
}
|