@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
|
@@ -1,269 +0,0 @@
|
|
|
1
|
-
/* eslint-disable max-lines */
|
|
2
|
-
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
3
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
4
|
-
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
5
|
-
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
6
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
7
|
-
import clack from '@clack/prompts';
|
|
8
|
-
import * as fs from 'fs';
|
|
9
|
-
import * as path from 'path';
|
|
10
|
-
import { XcodeProject } from './xcode-manager';
|
|
11
|
-
import * as codeTools from './code-tools';
|
|
12
|
-
import * as bash from '../utils/bash';
|
|
13
|
-
import * as SentryUtils from '../utils/sentrycli-utils';
|
|
14
|
-
import { SentryProjectData, WizardOptions } from '../utils/types';
|
|
15
|
-
import * as Sentry from '@sentry/node';
|
|
16
|
-
import { traceStep, withTelemetry } from '../telemetry';
|
|
17
|
-
import * as cocoapod from './cocoapod';
|
|
18
|
-
import * as fastlane from './fastlane';
|
|
19
|
-
|
|
20
|
-
/* eslint-enable @typescript-eslint/no-unused-vars */
|
|
21
|
-
|
|
22
|
-
import {
|
|
23
|
-
askToInstallSentryCLI,
|
|
24
|
-
printWelcome,
|
|
25
|
-
abort,
|
|
26
|
-
askForItemSelection,
|
|
27
|
-
confirmContinueIfNoOrDirtyGitRepo,
|
|
28
|
-
getOrAskForProjectData,
|
|
29
|
-
} from '../utils/clack-utils';
|
|
30
|
-
|
|
31
|
-
export async function runAppleWizard(options: WizardOptions): Promise<void> {
|
|
32
|
-
return withTelemetry(
|
|
33
|
-
{
|
|
34
|
-
enabled: options.telemetryEnabled,
|
|
35
|
-
integration: 'ios',
|
|
36
|
-
wizardOptions: options,
|
|
37
|
-
},
|
|
38
|
-
() => runAppleWizardWithTelementry(options),
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
async function runAppleWizardWithTelementry(
|
|
43
|
-
options: WizardOptions,
|
|
44
|
-
): Promise<void> {
|
|
45
|
-
printWelcome({
|
|
46
|
-
wizardName: 'Sentry Apple Wizard',
|
|
47
|
-
promoCode: options.promoCode,
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
await confirmContinueIfNoOrDirtyGitRepo();
|
|
51
|
-
|
|
52
|
-
const hasCli = bash.hasSentryCLI();
|
|
53
|
-
Sentry.setTag('has-cli', hasCli);
|
|
54
|
-
if (!hasCli) {
|
|
55
|
-
if (
|
|
56
|
-
!(await traceStep('Ask for SentryCLI', () => askToInstallSentryCLI()))
|
|
57
|
-
) {
|
|
58
|
-
clack.log.warn(
|
|
59
|
-
"Without sentry-cli, you won't be able to upload debug symbols to Sentry. You can install it later by following the instructions at https://docs.sentry.io/cli/",
|
|
60
|
-
);
|
|
61
|
-
Sentry.setTag('CLI-Installed', false);
|
|
62
|
-
} else {
|
|
63
|
-
await bash.installSentryCLI();
|
|
64
|
-
Sentry.setTag('CLI-Installed', true);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
const projectDir = process.cwd();
|
|
69
|
-
const xcodeProjFiles = searchXcodeProject(projectDir);
|
|
70
|
-
|
|
71
|
-
if (!xcodeProjFiles || xcodeProjFiles.length === 0) {
|
|
72
|
-
clack.log.error(
|
|
73
|
-
'No Xcode project found. Please run this command from the root of your project.',
|
|
74
|
-
);
|
|
75
|
-
await abort();
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
let xcodeProjFile;
|
|
80
|
-
|
|
81
|
-
if (xcodeProjFiles.length === 1) {
|
|
82
|
-
xcodeProjFile = xcodeProjFiles[0];
|
|
83
|
-
Sentry.setTag('multiple-projects', false);
|
|
84
|
-
} else {
|
|
85
|
-
Sentry.setTag('multiple-projects', true);
|
|
86
|
-
xcodeProjFile = (
|
|
87
|
-
await traceStep('Choose Xcode project', () =>
|
|
88
|
-
askForItemSelection(
|
|
89
|
-
xcodeProjFiles,
|
|
90
|
-
'Which project do you want to add Sentry to?',
|
|
91
|
-
),
|
|
92
|
-
)
|
|
93
|
-
).value;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
const pbxproj = path.join(projectDir, xcodeProjFile, 'project.pbxproj');
|
|
97
|
-
|
|
98
|
-
if (!fs.existsSync(pbxproj)) {
|
|
99
|
-
clack.log.error(`No pbxproj found at ${xcodeProjFile}`);
|
|
100
|
-
await abort();
|
|
101
|
-
return;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
const { project, apiKey } = await getSentryProjectAndApiKey(options);
|
|
105
|
-
|
|
106
|
-
const xcProject = new XcodeProject(pbxproj);
|
|
107
|
-
|
|
108
|
-
const availableTargets = xcProject.getAllTargets();
|
|
109
|
-
|
|
110
|
-
if (availableTargets.length == 0) {
|
|
111
|
-
clack.log.error(`No suitable target found in ${xcodeProjFile}`);
|
|
112
|
-
Sentry.setTag('No-Target', true);
|
|
113
|
-
await abort();
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
const target =
|
|
118
|
-
availableTargets.length == 1
|
|
119
|
-
? availableTargets[0]
|
|
120
|
-
: (
|
|
121
|
-
await traceStep('Choose target', () =>
|
|
122
|
-
askForItemSelection(
|
|
123
|
-
availableTargets,
|
|
124
|
-
'Which target do you want to add Sentry to?',
|
|
125
|
-
),
|
|
126
|
-
)
|
|
127
|
-
).value;
|
|
128
|
-
|
|
129
|
-
SentryUtils.createSentryCLIRC(projectDir, { auth_token: apiKey.token });
|
|
130
|
-
clack.log.info(
|
|
131
|
-
'We created a ".sentryclirc" file in your project directory in order to provide an auth token for Sentry CLI.\nIt was also added to your ".gitignore" file.\nAt your CI enviroment, you can set the SENTRY_AUTH_TOKEN environment variable instead. See https://docs.sentry.io/cli/configuration/#auth-token for more information.',
|
|
132
|
-
);
|
|
133
|
-
|
|
134
|
-
let hasCocoa = cocoapod.usesCocoaPod(projectDir);
|
|
135
|
-
Sentry.setTag('cocoapod-exists', hasCocoa);
|
|
136
|
-
|
|
137
|
-
if (hasCocoa) {
|
|
138
|
-
const pm = (
|
|
139
|
-
await traceStep('Choose a package manager', () =>
|
|
140
|
-
askForItemSelection(
|
|
141
|
-
['Swift Package Manager', 'CocoaPods'],
|
|
142
|
-
'Which package manager would you like to use to add Sentry?',
|
|
143
|
-
),
|
|
144
|
-
)
|
|
145
|
-
).value;
|
|
146
|
-
|
|
147
|
-
hasCocoa = pm === 'CocoaPods';
|
|
148
|
-
if (hasCocoa) {
|
|
149
|
-
const podAdded = await traceStep('Add CocoaPods reference', () =>
|
|
150
|
-
cocoapod.addCocoaPods(projectDir),
|
|
151
|
-
);
|
|
152
|
-
Sentry.setTag('cocoapod-added', podAdded);
|
|
153
|
-
if (!podAdded) {
|
|
154
|
-
clack.log.warn(
|
|
155
|
-
"Could not add Sentry pod to your Podfile. You'll have to add it manually.\nPlease follow the instructions at https://docs.sentry.io/platforms/apple/guides/ios/#install",
|
|
156
|
-
);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
Sentry.setTag('package-manager', hasCocoa ? 'cocoapods' : 'SPM');
|
|
162
|
-
traceStep('Update Xcode project', () => {
|
|
163
|
-
xcProject.updateXcodeProject(project, target, !hasCocoa, true);
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
const codeAdded = traceStep('Add code snippet', () => {
|
|
167
|
-
const files = xcProject.filesForTarget(target);
|
|
168
|
-
if (files === undefined || files.length == 0) return false;
|
|
169
|
-
|
|
170
|
-
return codeTools.addCodeSnippetToProject(
|
|
171
|
-
projectDir,
|
|
172
|
-
files,
|
|
173
|
-
project.keys[0].dsn.public,
|
|
174
|
-
);
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
Sentry.setTag('Snippet-Added', codeAdded);
|
|
178
|
-
|
|
179
|
-
if (!codeAdded) {
|
|
180
|
-
clack.log.warn(
|
|
181
|
-
'Added the Sentry dependency to your project but could not add the Sentry code snippet. Please add the code snipped manually by following the docs: https://docs.sentry.io/platforms/apple/guides/ios/#configure',
|
|
182
|
-
);
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
const hasFastlane = fastlane.fastFile(projectDir);
|
|
186
|
-
Sentry.setTag('fastlane-exists', hasFastlane);
|
|
187
|
-
if (hasFastlane) {
|
|
188
|
-
const addLane = await clack.confirm({
|
|
189
|
-
message:
|
|
190
|
-
'Found a Fastfile in your project. Do you want to configure a lane to upload debug symbols to Sentry?',
|
|
191
|
-
});
|
|
192
|
-
Sentry.setTag('fastlane-desired', addLane);
|
|
193
|
-
if (addLane) {
|
|
194
|
-
const added = await traceStep('Configure fastlane', () =>
|
|
195
|
-
fastlane.addSentryToFastlane(
|
|
196
|
-
projectDir,
|
|
197
|
-
project.organization.slug,
|
|
198
|
-
project.slug,
|
|
199
|
-
),
|
|
200
|
-
);
|
|
201
|
-
Sentry.setTag('fastlane-added', added);
|
|
202
|
-
if (added) {
|
|
203
|
-
clack.log.step(
|
|
204
|
-
'A new step was added to your fastlane file. Now and you build your project with fastlane, debug symbols and source context will be uploaded to Sentry.',
|
|
205
|
-
);
|
|
206
|
-
} else {
|
|
207
|
-
clack.log.warn(
|
|
208
|
-
'Could not edit your fastlane file to upload debug symbols to Sentry. Please follow the instructions at https://docs.sentry.io/platforms/apple/guides/ios/dsym/#fastlane',
|
|
209
|
-
);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
clack.log.success(
|
|
215
|
-
'Sentry was successfully added to your project! Run your project to send your first event to Sentry. Go to Sentry.io to see whether everything is working fine.',
|
|
216
|
-
);
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
//Prompt for Sentry project and API key
|
|
220
|
-
async function getSentryProjectAndApiKey(
|
|
221
|
-
options: WizardOptions,
|
|
222
|
-
): Promise<{ project: SentryProjectData; apiKey: { token: string } }> {
|
|
223
|
-
const { selectedProject, authToken } = await getOrAskForProjectData(options);
|
|
224
|
-
return { project: selectedProject, apiKey: { token: authToken } };
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
function searchXcodeProject(at: string): string[] {
|
|
228
|
-
const projs = findFilesWithExtension(at, '.xcodeproj');
|
|
229
|
-
if (projs.length > 0) {
|
|
230
|
-
return projs;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
const workspace = findFilesWithExtension(at, '.xcworkspace');
|
|
234
|
-
if (workspace.length == 0) {
|
|
235
|
-
return [];
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
const xsworkspacedata = path.join(
|
|
239
|
-
at,
|
|
240
|
-
workspace[0],
|
|
241
|
-
'contents.xcworkspacedata',
|
|
242
|
-
);
|
|
243
|
-
if (!fs.existsSync(xsworkspacedata)) {
|
|
244
|
-
return [];
|
|
245
|
-
}
|
|
246
|
-
const groupRegex = /location *= *"group:([^"]+)"/gim;
|
|
247
|
-
const content = fs.readFileSync(xsworkspacedata, 'utf8');
|
|
248
|
-
let matches = groupRegex.exec(content);
|
|
249
|
-
|
|
250
|
-
while (matches) {
|
|
251
|
-
const group = matches[1];
|
|
252
|
-
const groupPath = path.join(at, group);
|
|
253
|
-
if (
|
|
254
|
-
!group.endsWith('Pods.xcodeproj') &&
|
|
255
|
-
group.endsWith('.xcodeproj') &&
|
|
256
|
-
fs.existsSync(groupPath)
|
|
257
|
-
) {
|
|
258
|
-
projs.push(group);
|
|
259
|
-
}
|
|
260
|
-
matches = groupRegex.exec(content);
|
|
261
|
-
}
|
|
262
|
-
return projs;
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
//find files with the given extension
|
|
266
|
-
function findFilesWithExtension(dir: string, extension: string): string[] {
|
|
267
|
-
const files = fs.readdirSync(dir);
|
|
268
|
-
return files.filter((file) => file.endsWith(extension));
|
|
269
|
-
}
|
package/src/apple/cocoapod.ts
DELETED
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import * as bash from '../utils/bash';
|
|
4
|
-
import * as Sentry from '@sentry/node';
|
|
5
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
6
|
-
import * as clack from '@clack/prompts';
|
|
7
|
-
import chalk from 'chalk';
|
|
8
|
-
|
|
9
|
-
export function usesCocoaPod(projPath: string): boolean {
|
|
10
|
-
return fs.existsSync(path.join(projPath, 'Podfile'));
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export async function addCocoaPods(projPath: string): Promise<boolean> {
|
|
14
|
-
const podfile = path.join(projPath, 'Podfile');
|
|
15
|
-
|
|
16
|
-
const podContent = fs.readFileSync(podfile, 'utf8');
|
|
17
|
-
|
|
18
|
-
if (
|
|
19
|
-
/^\s*pod\s+(['"]Sentry['"]|['"]SentrySwiftUI['"])\s*$/im.test(podContent)
|
|
20
|
-
) {
|
|
21
|
-
// Already have Sentry pod
|
|
22
|
-
return true;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
let podMatch = /^( *)pod\s+['"](\w+)['"] *$/im.exec(podContent);
|
|
26
|
-
if (!podMatch) {
|
|
27
|
-
// No Podfile is empty, will try to add Sentry pod after "use_frameworks!"
|
|
28
|
-
const frameworkMatch = /^( *)use_frameworks![^\n]* *$/im.exec(podContent);
|
|
29
|
-
if (!frameworkMatch) {
|
|
30
|
-
return false;
|
|
31
|
-
}
|
|
32
|
-
podMatch = frameworkMatch;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const insertIndex = podMatch.index + podMatch[0].length;
|
|
36
|
-
const newFileContent =
|
|
37
|
-
podContent.slice(0, insertIndex) +
|
|
38
|
-
'\n' +
|
|
39
|
-
podMatch[1] +
|
|
40
|
-
"pod 'Sentry'\n" +
|
|
41
|
-
podContent.slice(insertIndex);
|
|
42
|
-
fs.writeFileSync(podfile, newFileContent, 'utf8');
|
|
43
|
-
|
|
44
|
-
clack.log.step('Sentry pod added to the project podFile.');
|
|
45
|
-
|
|
46
|
-
await podInstall();
|
|
47
|
-
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export async function podInstall(dir = '.') {
|
|
52
|
-
const installSpinner = clack.spinner();
|
|
53
|
-
installSpinner.start("Running 'pod install'. This may take a few minutes...");
|
|
54
|
-
|
|
55
|
-
try {
|
|
56
|
-
await bash.execute(`cd ${dir} && pod repo update`);
|
|
57
|
-
await bash.execute(`cd ${dir} && pod install --silent`);
|
|
58
|
-
installSpinner.stop('Pods installed.');
|
|
59
|
-
Sentry.setTag('pods-installed', true);
|
|
60
|
-
} catch (e) {
|
|
61
|
-
installSpinner.stop('Failed to install pods.');
|
|
62
|
-
Sentry.setTag('pods-installed', false);
|
|
63
|
-
clack.log.error(
|
|
64
|
-
`${chalk.red(
|
|
65
|
-
'Encountered the following error during pods installation:',
|
|
66
|
-
// eslint-disable-next-line @typescript-eslint/restrict-template-expressions
|
|
67
|
-
)}\n\n${e}\n\n${chalk.dim(
|
|
68
|
-
'If you think this issue is caused by the Sentry wizard, let us know here:\nhttps://github.com/getsentry/sentry-wizard/issues',
|
|
69
|
-
)}`,
|
|
70
|
-
);
|
|
71
|
-
Sentry.captureException('Sentry pod install failed.');
|
|
72
|
-
}
|
|
73
|
-
}
|
package/src/apple/code-tools.ts
DELETED
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import * as Sentry from '@sentry/node';
|
|
2
|
-
import * as fs from 'fs';
|
|
3
|
-
import * as path from 'path';
|
|
4
|
-
import * as templates from './templates';
|
|
5
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
6
|
-
import * as clack from '@clack/prompts';
|
|
7
|
-
|
|
8
|
-
const swiftAppLaunchRegex =
|
|
9
|
-
/(func\s+application\s*\(\s*_\s+application:\s*[^,]+,\s*didFinishLaunchingWithOptions[^,]+:\s*[^)]+\s*\)\s+->\s+Bool\s+{)|func\s+applicationDidFinishLaunching\s*\(\s*_\s+aNotification:\s+Notification\s*\)\s*{/im;
|
|
10
|
-
const objcAppLaunchRegex =
|
|
11
|
-
/-\s*\(\s*BOOL\s*\)\s*application:\s*\(\s*UIApplication\s*\*\s*\)\s*application\s+didFinishLaunchingWithOptions:\s*\(\s*NSDictionary\s*\*\s*\)\s*launchOptions\s*{/im;
|
|
12
|
-
const swiftUIRegex = /@main\s+struct[^:]+:\s*(SwiftUI\.)?App\s*{/im;
|
|
13
|
-
|
|
14
|
-
function isAppDelegateFile(filePath: string): boolean {
|
|
15
|
-
const appLaunchRegex = filePath.toLowerCase().endsWith('.swift')
|
|
16
|
-
? swiftAppLaunchRegex
|
|
17
|
-
: objcAppLaunchRegex;
|
|
18
|
-
|
|
19
|
-
const fileContent = fs.readFileSync(filePath, 'utf8');
|
|
20
|
-
return appLaunchRegex.test(fileContent) || swiftUIRegex.test(fileContent);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
function findAppDidFinishLaunchingWithOptions(
|
|
24
|
-
dir: string,
|
|
25
|
-
files: string[] | undefined = undefined,
|
|
26
|
-
): string | null {
|
|
27
|
-
if (!files) {
|
|
28
|
-
files = fs.readdirSync(dir);
|
|
29
|
-
files = files.map((f) => path.join(dir, f));
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
//iterate over subdirectories later,
|
|
33
|
-
//the appdelegate usually is in the top level
|
|
34
|
-
const dirs: string[] = [];
|
|
35
|
-
|
|
36
|
-
for (const filePath of files) {
|
|
37
|
-
if (
|
|
38
|
-
filePath.endsWith('.swift') ||
|
|
39
|
-
filePath.endsWith('.m') ||
|
|
40
|
-
filePath.endsWith('.mm')
|
|
41
|
-
) {
|
|
42
|
-
if (fs.existsSync(filePath) && isAppDelegateFile(filePath)) {
|
|
43
|
-
return filePath;
|
|
44
|
-
}
|
|
45
|
-
} else if (
|
|
46
|
-
!path.basename(filePath).startsWith('.') &&
|
|
47
|
-
!filePath.endsWith('.xcodeproj') &&
|
|
48
|
-
!filePath.endsWith('.xcassets') &&
|
|
49
|
-
fs.existsSync(filePath) &&
|
|
50
|
-
fs.lstatSync(filePath).isDirectory()
|
|
51
|
-
) {
|
|
52
|
-
dirs.push(filePath);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
for (const dr of dirs) {
|
|
57
|
-
const result = findAppDidFinishLaunchingWithOptions(dr);
|
|
58
|
-
if (result) return result;
|
|
59
|
-
}
|
|
60
|
-
return null;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export function addCodeSnippetToProject(
|
|
64
|
-
projPath: string,
|
|
65
|
-
files: string[],
|
|
66
|
-
dsn: string,
|
|
67
|
-
): boolean {
|
|
68
|
-
const appDelegate = findAppDidFinishLaunchingWithOptions(projPath, files);
|
|
69
|
-
if (!appDelegate) {
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const fileContent = fs.readFileSync(appDelegate, 'utf8');
|
|
74
|
-
const isSwift = appDelegate.toLowerCase().endsWith('.swift');
|
|
75
|
-
const appLaunchRegex = isSwift ? swiftAppLaunchRegex : objcAppLaunchRegex;
|
|
76
|
-
const importStatement = isSwift ? 'import Sentry\n' : '@import Sentry;\n';
|
|
77
|
-
const checkForSentryInit = isSwift ? 'SentrySDK.start' : '[SentrySDK start';
|
|
78
|
-
let codeSnippet = isSwift
|
|
79
|
-
? templates.getSwiftSnippet(dsn)
|
|
80
|
-
: templates.getObjcSnippet(dsn);
|
|
81
|
-
|
|
82
|
-
Sentry.setTag('code-language', isSwift ? 'swift' : 'objc');
|
|
83
|
-
Sentry.setTag(
|
|
84
|
-
'ui-engine',
|
|
85
|
-
swiftUIRegex.test(fileContent) ? 'swiftui' : 'uikit',
|
|
86
|
-
);
|
|
87
|
-
|
|
88
|
-
if (fileContent.includes(checkForSentryInit)) {
|
|
89
|
-
//already initialized
|
|
90
|
-
clack.log.info(
|
|
91
|
-
'Sentry is already initialized in your AppDelegate. Skipping adding the code snippet.',
|
|
92
|
-
);
|
|
93
|
-
return true;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
let match = appLaunchRegex.exec(fileContent);
|
|
97
|
-
if (!match) {
|
|
98
|
-
const swiftUIMatch = swiftUIRegex.exec(fileContent);
|
|
99
|
-
if (!swiftUIMatch) {
|
|
100
|
-
// This branch is not reached, because we already checked for SwiftUI in isAppDelegateFile
|
|
101
|
-
return false;
|
|
102
|
-
}
|
|
103
|
-
//Is SwiftUI with no init
|
|
104
|
-
match = swiftUIMatch;
|
|
105
|
-
codeSnippet = ` init() {\n${codeSnippet} }`;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
const insertIndex = match.index + match[0].length;
|
|
109
|
-
let newFileContent =
|
|
110
|
-
fileContent.slice(0, insertIndex) +
|
|
111
|
-
'\n' +
|
|
112
|
-
codeSnippet +
|
|
113
|
-
fileContent.slice(insertIndex);
|
|
114
|
-
|
|
115
|
-
if (newFileContent.indexOf(importStatement) < 0) {
|
|
116
|
-
const firstImport = /^[ \t]*import +\w+.*$/m.exec(newFileContent);
|
|
117
|
-
if (firstImport) {
|
|
118
|
-
const importIndex = firstImport.index + firstImport[0].length;
|
|
119
|
-
newFileContent =
|
|
120
|
-
newFileContent.slice(0, importIndex) +
|
|
121
|
-
'\n' +
|
|
122
|
-
importStatement +
|
|
123
|
-
newFileContent.slice(importIndex);
|
|
124
|
-
} else {
|
|
125
|
-
newFileContent = importStatement + newFileContent;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
fs.writeFileSync(appDelegate, newFileContent, 'utf8');
|
|
130
|
-
|
|
131
|
-
clack.log.step('Added Sentry initialization code snippet to ' + appDelegate);
|
|
132
|
-
return true;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
/**
|
|
136
|
-
* Exported for testing purposes, but should not be used in other modules.
|
|
137
|
-
*/
|
|
138
|
-
export let exportForTesting: {
|
|
139
|
-
isAppDelegateFile: typeof isAppDelegateFile;
|
|
140
|
-
findAppDidFinishLaunchingWithOptions: typeof findAppDidFinishLaunchingWithOptions;
|
|
141
|
-
};
|
|
142
|
-
if (process.env.NODE_ENV === 'test') {
|
|
143
|
-
exportForTesting = {
|
|
144
|
-
isAppDelegateFile,
|
|
145
|
-
findAppDidFinishLaunchingWithOptions,
|
|
146
|
-
};
|
|
147
|
-
}
|
package/src/apple/fastlane.ts
DELETED
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
import * as path from 'path';
|
|
3
|
-
import { askForItemSelection } from '../utils/clack-utils';
|
|
4
|
-
import * as templates from './templates';
|
|
5
|
-
// @ts-ignore - clack is ESM and TS complains about that. It works though
|
|
6
|
-
import * as clack from '@clack/prompts';
|
|
7
|
-
|
|
8
|
-
export function fastFile(projectPath: string): string | null {
|
|
9
|
-
const fastlanePath = path.join(projectPath, 'fastlane', 'Fastfile');
|
|
10
|
-
return fs.existsSync(fastlanePath) ? fastlanePath : null;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
function findIOSPlatform(
|
|
14
|
-
content: string,
|
|
15
|
-
): { index: number; length: number } | null {
|
|
16
|
-
const platformRegex = /^ *platform\s+:([^ ]+)[^\n]*\n/gim;
|
|
17
|
-
let match = platformRegex.exec(content);
|
|
18
|
-
if (!match) {
|
|
19
|
-
// No platform found, treat whole file as one platform.
|
|
20
|
-
return { index: 0, length: content.length };
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
let index = -1;
|
|
24
|
-
while (match) {
|
|
25
|
-
if (match[1] === 'ios') {
|
|
26
|
-
index = match.index + match[0].length;
|
|
27
|
-
break;
|
|
28
|
-
}
|
|
29
|
-
match = platformRegex.exec(content);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
if (index === -1) {
|
|
33
|
-
return null;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
//After finding the platform, we need to find the end of the platform block.
|
|
37
|
-
//This solution has the assumption that the file is well formed,
|
|
38
|
-
//which is not a perfect solution, but it's good enough assumption.
|
|
39
|
-
const platformEndRegex = /^end[^\n]*/gim;
|
|
40
|
-
match = platformEndRegex.exec(content.slice(index));
|
|
41
|
-
if (!match) {
|
|
42
|
-
return null;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return { index, length: match.index };
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
function findLanes(
|
|
49
|
-
content: string,
|
|
50
|
-
): { index: number; length: number; name: string }[] | null {
|
|
51
|
-
const laneRegex = /^ {2}lane\s+:([^ ]+)[^\n]*\n/gim;
|
|
52
|
-
let match = laneRegex.exec(content);
|
|
53
|
-
if (!match) {
|
|
54
|
-
return null;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
const lanes: { index: number; length: number; name: string }[] = [];
|
|
58
|
-
while (match) {
|
|
59
|
-
const laneEnd = /^ {2}end/m.exec(
|
|
60
|
-
content.slice(match.index + match[0].length),
|
|
61
|
-
);
|
|
62
|
-
if (laneEnd === null) {
|
|
63
|
-
return null;
|
|
64
|
-
}
|
|
65
|
-
lanes.push({
|
|
66
|
-
index: match.index + match[0].length,
|
|
67
|
-
length: laneEnd.index,
|
|
68
|
-
name: match[1],
|
|
69
|
-
});
|
|
70
|
-
match = laneRegex.exec(content);
|
|
71
|
-
}
|
|
72
|
-
return lanes;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
function addSentryToLane(
|
|
76
|
-
content: string,
|
|
77
|
-
lane: { index: number; length: number; name: string },
|
|
78
|
-
org: string,
|
|
79
|
-
project: string,
|
|
80
|
-
): string {
|
|
81
|
-
const laneContent = content.slice(lane.index, lane.index + lane.length);
|
|
82
|
-
const sentryCLIMatch = /sentry_cli\s*\([^)]+\)/gim.exec(laneContent);
|
|
83
|
-
if (sentryCLIMatch) {
|
|
84
|
-
// Sentry already added to lane. Update it.
|
|
85
|
-
return (
|
|
86
|
-
content.slice(0, sentryCLIMatch.index + lane.index) +
|
|
87
|
-
templates.getFastlaneSnippet(org, project).trim() +
|
|
88
|
-
content.slice(
|
|
89
|
-
sentryCLIMatch.index + sentryCLIMatch[0].length + lane.index,
|
|
90
|
-
)
|
|
91
|
-
);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
// Sentry not added to lane. Add it.
|
|
95
|
-
return (
|
|
96
|
-
content.slice(0, lane.index + lane.length) +
|
|
97
|
-
'\n' +
|
|
98
|
-
templates.getFastlaneSnippet(org, project) +
|
|
99
|
-
'\n' +
|
|
100
|
-
content.slice(lane.index + lane.length)
|
|
101
|
-
);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
export async function addSentryToFastlane(
|
|
105
|
-
projectPath: string,
|
|
106
|
-
org: string,
|
|
107
|
-
project: string,
|
|
108
|
-
): Promise<boolean> {
|
|
109
|
-
const fastFilePath = fastFile(projectPath);
|
|
110
|
-
if (!fastFilePath) {
|
|
111
|
-
return false;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
const fileContent = fs.readFileSync(fastFilePath, 'utf8');
|
|
115
|
-
const platform = findIOSPlatform(fileContent);
|
|
116
|
-
if (!platform) {
|
|
117
|
-
return false;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
const platformContent = fileContent.slice(
|
|
121
|
-
platform.index,
|
|
122
|
-
platform.index + platform.length,
|
|
123
|
-
);
|
|
124
|
-
const lanes = findLanes(platformContent);
|
|
125
|
-
lanes?.forEach((l) => (l.index += platform.index));
|
|
126
|
-
|
|
127
|
-
if (!lanes || lanes.length === 0) {
|
|
128
|
-
clack.log.warn('No suitable lanes in your Fastfile.');
|
|
129
|
-
return false;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
let newFileContent: string | undefined;
|
|
133
|
-
if (lanes.length === 1) {
|
|
134
|
-
newFileContent = addSentryToLane(fileContent, lanes[0], org, project);
|
|
135
|
-
} else {
|
|
136
|
-
const laneNames = lanes.map((l) => l.name);
|
|
137
|
-
const selectedLane = await askForItemSelection(
|
|
138
|
-
laneNames,
|
|
139
|
-
'Select lane to add Sentry to:',
|
|
140
|
-
);
|
|
141
|
-
if (selectedLane === undefined) {
|
|
142
|
-
return false;
|
|
143
|
-
}
|
|
144
|
-
newFileContent = addSentryToLane(
|
|
145
|
-
fileContent,
|
|
146
|
-
lanes[selectedLane.index],
|
|
147
|
-
org,
|
|
148
|
-
project,
|
|
149
|
-
);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
fs.writeFileSync(fastFilePath, newFileContent, 'utf8');
|
|
153
|
-
return true;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
/**
|
|
157
|
-
* Exported for testing purposes, but should not be used in other modules.
|
|
158
|
-
*/
|
|
159
|
-
export let exportForTesting: {
|
|
160
|
-
findIOSPlatform: typeof findIOSPlatform;
|
|
161
|
-
findLanes: typeof findLanes;
|
|
162
|
-
addSentryToLane: typeof addSentryToLane;
|
|
163
|
-
};
|
|
164
|
-
if (process.env.NODE_ENV === 'test') {
|
|
165
|
-
exportForTesting = {
|
|
166
|
-
findIOSPlatform,
|
|
167
|
-
findLanes,
|
|
168
|
-
addSentryToLane,
|
|
169
|
-
};
|
|
170
|
-
}
|