From 3b838bccf09e44a13bbeccda64e728c3f3c480bb Mon Sep 17 00:00:00 2001 From: Matias Pequeno Date: Mon, 5 Jun 2023 20:00:49 -0300 Subject: [PATCH 1/4] Use Rollbar Apple SDK 3 for native crash collection --- rollbar_flutter/ios/Classes/RollbarFlutterPlugin.m | 6 ++---- rollbar_flutter/ios/rollbar_flutter.podspec | 5 ++--- 2 files changed, 4 insertions(+), 7 deletions(-) diff --git a/rollbar_flutter/ios/Classes/RollbarFlutterPlugin.m b/rollbar_flutter/ios/Classes/RollbarFlutterPlugin.m index 1358ef1..9265267 100644 --- a/rollbar_flutter/ios/Classes/RollbarFlutterPlugin.m +++ b/rollbar_flutter/ios/Classes/RollbarFlutterPlugin.m @@ -1,6 +1,5 @@ @import SystemConfiguration; @import RollbarNotifier; -@import RollbarPLCrashReporter; #import "RollbarFlutterPlugin.h" @@ -19,13 +18,12 @@ - (void)handleMethodCall:(FlutterMethodCall *)call { if ([@"initialize" isEqualToString:call.method]) { NSDictionary *arguments = call.arguments; - RollbarConfig *config = [[RollbarConfig alloc] init]; + RollbarMutableConfig *config = [[RollbarMutableConfig alloc] init]; config.destination.accessToken = (NSString *)arguments[@"accessToken"]; config.destination.environment = (NSString *)arguments[@"environment"]; config.loggingOptions.codeVersion = (NSString *)arguments[@"codeVersion"]; - id collector = [[RollbarPLCrashCollector alloc] init]; - [Rollbar initWithConfiguration:config crashCollector:collector]; + [Rollbar initWithConfiguration:config]; result(nil); } else if ([@"persistencePath" isEqualToString:call.method]) { diff --git a/rollbar_flutter/ios/rollbar_flutter.podspec b/rollbar_flutter/ios/rollbar_flutter.podspec index 358621b..a2ef33b 100644 --- a/rollbar_flutter/ios/rollbar_flutter.podspec +++ b/rollbar_flutter/ios/rollbar_flutter.podspec @@ -16,10 +16,9 @@ Connect your Flutter applications to Rollbar for error reporting. s.source_files = 'Classes/**/*' s.public_header_files = 'Classes/**/*.h' s.dependency 'Flutter' - s.dependency 'RollbarNotifier', '~> 2.3.4' - s.dependency 'RollbarPLCrashReporter', '~> 2.3.4' + s.dependency 'RollbarNotifier', '~> 3.0.1' s.static_framework = true - s.platform = :ios, '13.0' + s.platform = :ios, '14.0' # Flutter.framework does not contain a i386 slice. s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', From 4d344a425e594c02e0733569367b6a11bd1a9a5e Mon Sep 17 00:00:00 2001 From: Matias Pequeno Date: Mon, 5 Jun 2023 20:01:02 -0300 Subject: [PATCH 2/4] Always use latest sqlite3 libs --- rollbar_flutter/pubspec.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rollbar_flutter/pubspec.yaml b/rollbar_flutter/pubspec.yaml index 51d6021..2678670 100644 --- a/rollbar_flutter/pubspec.yaml +++ b/rollbar_flutter/pubspec.yaml @@ -14,7 +14,7 @@ dependencies: sdk: flutter meta: ^1.7.0 connectivity_plus: ^3.0.0 - sqlite3_flutter_libs: '0.5.12' + sqlite3_flutter_libs: ^0.5.12 rollbar_common: ^1.1.0 rollbar_dart: ^1.3.0 From ac80c42ab47807920de915f1b36accc501ac243d Mon Sep 17 00:00:00 2001 From: Matias Pequeno Date: Mon, 5 Jun 2023 20:01:54 -0300 Subject: [PATCH 3/4] Updated iOS example project to use the Rollbar Apple SDK 3 --- .../ios/Runner.xcodeproj/project.pbxproj | 76 +++++++------------ .../xcshareddata/xcschemes/Runner.xcscheme | 8 +- 2 files changed, 31 insertions(+), 53 deletions(-) diff --git a/rollbar_flutter/example/ios/Runner.xcodeproj/project.pbxproj b/rollbar_flutter/example/ios/Runner.xcodeproj/project.pbxproj index a17b87a..0fc33a9 100644 --- a/rollbar_flutter/example/ios/Runner.xcodeproj/project.pbxproj +++ b/rollbar_flutter/example/ios/Runner.xcodeproj/project.pbxproj @@ -14,7 +14,7 @@ 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; }; - CA983656C878EC019B64828E /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DFAF899D05FE95D1DEE08E52 /* Pods_Runner.framework */; }; + DB7CB68E0C9ADBB3923D7B72 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = C1AD03F4FAC57D506C54CE7E /* Pods_Runner.framework */; }; /* End PBXBuildFile section */ /* Begin PBXCopyFilesBuildPhase section */ @@ -33,8 +33,10 @@ /* Begin PBXFileReference section */ 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = ""; }; 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = ""; }; + 35410FCB89901EB813A73E3E /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; }; 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = ""; }; - 742017FEA321A244B14431F7 /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; }; + 5A6223782FAAF825C3DA565E /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; }; + 60FC3BC7BE54318F2318329F /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; }; 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = ""; }; 7AFFD8ED1D35381100E5BB4D /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AppDelegate.h; sourceTree = ""; }; 7AFFD8EE1D35381100E5BB4D /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = AppDelegate.m; sourceTree = ""; }; @@ -46,9 +48,7 @@ 97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; 97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; 97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; - BA51E93435F180AE31586B93 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; }; - D2D4739B5BCFB234777F8D4A /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; }; - DFAF899D05FE95D1DEE08E52 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + C1AD03F4FAC57D506C54CE7E /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ @@ -56,7 +56,7 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( - CA983656C878EC019B64828E /* Pods_Runner.framework in Frameworks */, + DB7CB68E0C9ADBB3923D7B72 /* Pods_Runner.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -66,9 +66,9 @@ 96A5165E35C2AB5B66047336 /* Pods */ = { isa = PBXGroup; children = ( - 742017FEA321A244B14431F7 /* Pods-Runner.debug.xcconfig */, - D2D4739B5BCFB234777F8D4A /* Pods-Runner.release.xcconfig */, - BA51E93435F180AE31586B93 /* Pods-Runner.profile.xcconfig */, + 5A6223782FAAF825C3DA565E /* Pods-Runner.debug.xcconfig */, + 35410FCB89901EB813A73E3E /* Pods-Runner.release.xcconfig */, + 60FC3BC7BE54318F2318329F /* Pods-Runner.profile.xcconfig */, ); path = Pods; sourceTree = ""; @@ -91,7 +91,7 @@ 97C146F01CF9000F007C117D /* Runner */, 97C146EF1CF9000F007C117D /* Products */, 96A5165E35C2AB5B66047336 /* Pods */, - E00D0E774CBD7FE183FEDA79 /* Frameworks */, + C573E8CE153D7C4DDF7F809F /* Frameworks */, ); sourceTree = ""; }; @@ -127,10 +127,10 @@ name = "Supporting Files"; sourceTree = ""; }; - E00D0E774CBD7FE183FEDA79 /* Frameworks */ = { + C573E8CE153D7C4DDF7F809F /* Frameworks */ = { isa = PBXGroup; children = ( - DFAF899D05FE95D1DEE08E52 /* Pods_Runner.framework */, + C1AD03F4FAC57D506C54CE7E /* Pods_Runner.framework */, ); name = Frameworks; sourceTree = ""; @@ -142,15 +142,14 @@ isa = PBXNativeTarget; buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */; buildPhases = ( - 728A4D31ACF8E2448135E056 /* [CP] Check Pods Manifest.lock */, + EB417D8CE14BCC87D1C34648 /* [CP] Check Pods Manifest.lock */, 9740EEB61CF901F6004384FC /* Run Script */, 97C146EA1CF9000F007C117D /* Sources */, 97C146EB1CF9000F007C117D /* Frameworks */, 97C146EC1CF9000F007C117D /* Resources */, 9705A1C41CF9048500538489 /* Embed Frameworks */, 3B06AD1E1E4923F5004D2608 /* Thin Binary */, - C61E5DBB581C92D3DB00ADC9 /* [CP] Copy Pods Resources */, - 925AF82D935326C27F96F91B /* [CP] Embed Pods Frameworks */, + D0899767864D468492CB4E7C /* [CP] Embed Pods Frameworks */, ); buildRules = ( ); @@ -224,29 +223,22 @@ shellPath = /bin/sh; shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin"; }; - 728A4D31ACF8E2448135E056 /* [CP] Check Pods Manifest.lock */ = { + 9740EEB61CF901F6004384FC /* Run Script */ = { isa = PBXShellScriptBuildPhase; + alwaysOutOfDate = 1; buildActionMask = 2147483647; files = ( ); - inputFileListPaths = ( - ); inputPaths = ( - "${PODS_PODFILE_DIR_PATH}/Podfile.lock", - "${PODS_ROOT}/Manifest.lock", - ); - name = "[CP] Check Pods Manifest.lock"; - outputFileListPaths = ( ); + name = "Run Script"; outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt", ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; - showEnvVarsInLog = 0; + shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; }; - 925AF82D935326C27F96F91B /* [CP] Embed Pods Frameworks */ = { + D0899767864D468492CB4E7C /* [CP] Embed Pods Frameworks */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( @@ -263,36 +255,26 @@ shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n"; showEnvVarsInLog = 0; }; - 9740EEB61CF901F6004384FC /* Run Script */ = { - isa = PBXShellScriptBuildPhase; - alwaysOutOfDate = 1; - buildActionMask = 2147483647; - files = ( - ); - inputPaths = ( - ); - name = "Run Script"; - outputPaths = ( - ); - runOnlyForDeploymentPostprocessing = 0; - shellPath = /bin/sh; - shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; - }; - C61E5DBB581C92D3DB00ADC9 /* [CP] Copy Pods Resources */ = { + EB417D8CE14BCC87D1C34648 /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-resources-${CONFIGURATION}-input-files.xcfilelist", ); - name = "[CP] Copy Pods Resources"; + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; outputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-resources-${CONFIGURATION}-output-files.xcfilelist", + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt", ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-resources.sh\"\n"; + shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; showEnvVarsInLog = 0; }; /* End PBXShellScriptBuildPhase section */ diff --git a/rollbar_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/rollbar_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme index 3db53b6..c87d15a 100644 --- a/rollbar_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme +++ b/rollbar_flutter/example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme @@ -27,8 +27,6 @@ selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" shouldUseLaunchSchemeArgsEnv = "YES"> - - - - + + - - Date: Mon, 5 Jun 2023 20:02:19 -0300 Subject: [PATCH 4/4] Bumped version to 1.4.0 --- rollbar_flutter/example/pubspec.yaml | 2 +- rollbar_flutter/ios/rollbar_flutter.podspec | 2 +- rollbar_flutter/pubspec.yaml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/rollbar_flutter/example/pubspec.yaml b/rollbar_flutter/example/pubspec.yaml index 340a4a9..19d5d19 100644 --- a/rollbar_flutter/example/pubspec.yaml +++ b/rollbar_flutter/example/pubspec.yaml @@ -1,6 +1,6 @@ name: rollbar_flutter_example description: Demonstrates how to use the rollbar_flutter plugin. -version: 1.3.1 +version: 1.4.0 publish_to: 'none' # Remove this line if you wish to publish to pub.dev diff --git a/rollbar_flutter/ios/rollbar_flutter.podspec b/rollbar_flutter/ios/rollbar_flutter.podspec index a2ef33b..88d46ec 100644 --- a/rollbar_flutter/ios/rollbar_flutter.podspec +++ b/rollbar_flutter/ios/rollbar_flutter.podspec @@ -4,7 +4,7 @@ # Pod::Spec.new do |s| s.name = 'rollbar_flutter' - s.version = '1.2.0' + s.version = '1.4.0' s.summary = 'Connect your Flutter applications to Rollbar for error reporting.' s.description = <<-DESC Connect your Flutter applications to Rollbar for error reporting. diff --git a/rollbar_flutter/pubspec.yaml b/rollbar_flutter/pubspec.yaml index 2678670..172a242 100644 --- a/rollbar_flutter/pubspec.yaml +++ b/rollbar_flutter/pubspec.yaml @@ -1,6 +1,6 @@ name: rollbar_flutter description: Connect your Flutter applications to Rollbar for error reporting. -version: 1.3.1 +version: 1.4.0 homepage: https://www.rollbar.com documentation: https://docs.rollbar.com/docs/flutter#flutter repository: https://github.com/rollbar/rollbar-flutter