From e64ed8576d30a7fa2d8d13ccb0210c1b8a39f777 Mon Sep 17 00:00:00 2001 From: Desu Sai Venkat Date: Fri, 8 Dec 2023 17:21:43 +0530 Subject: [PATCH 1/5] fix: handled race condition generating invalid event payloads --- Sources/Classes/RSClient.m | 44 +++++++++++++++++++++++++------------- 1 file changed, 29 insertions(+), 15 deletions(-) diff --git a/Sources/Classes/RSClient.m b/Sources/Classes/RSClient.m index 0e086b41..216a9f2a 100644 --- a/Sources/Classes/RSClient.m +++ b/Sources/Classes/RSClient.m @@ -19,11 +19,19 @@ static RSUserSession *_userSession = nil; static RSOption* _defaultOptions = nil; static NSString* _deviceToken = nil; +static NSRecursiveLock* recursiveLock = nil; @implementation RSClient + (instancetype) getInstance { - return _instance; + if (recursiveLock == nil) { + recursiveLock = [[NSRecursiveLock alloc] init]; + } + RSClient* client; + [recursiveLock lock]; + client = _instance; + [recursiveLock unlock]; + return client; } + (instancetype)getInstance:(NSString *)writeKey { @@ -42,20 +50,26 @@ + (instancetype)initiate:(NSString *)writeKey config:(RSConfig * __nullable)conf if ([writeKey length] == 0) { [RSLogger logError:WRITE_KEY_ERROR]; } - if (_instance == nil) { - static dispatch_once_t onceToken; - dispatch_once(&onceToken, ^{ - _instance = [[self alloc] init]; - if (options != nil) { - _defaultOptions = options; - _instance->_options = options; - } - RSConfig *_config = (config != nil) ? config : [[RSConfig alloc] init]; - _repository = [RSEventRepository initiate:writeKey config:_config client:_instance options:options]; - if(_deviceToken != nil && [_deviceToken length] != 0) { - [_instance.context putDeviceToken:_deviceToken]; - } - }); + [recursiveLock lock]; + @try { + if (_instance == nil) { + static dispatch_once_t onceToken; + dispatch_once(&onceToken, ^{ + _instance = [[self alloc] init]; + if (options != nil) { + _defaultOptions = options; + _instance->_options = options; + } + RSConfig *_config = (config != nil) ? config : [[RSConfig alloc] init]; + _repository = [RSEventRepository initiate:writeKey config:_config client:_instance options:options]; + if(_deviceToken != nil && [_deviceToken length] != 0) { + [_instance.context putDeviceToken:_deviceToken]; + } + }); + } + } + @finally { + [recursiveLock unlock]; } return _instance; } From c1e53dd2dc74cadd1c74ebeb92d59de0bb8e8c03 Mon Sep 17 00:00:00 2001 From: Desu Sai Venkat Date: Fri, 8 Dec 2023 17:22:02 +0530 Subject: [PATCH 2/5] fix: deleted invalid events (without anonId) generated due to race condition while sdk initialization --- Sources/Classes/Headers/Public/RSEnums.h | 1 + Sources/Classes/RSCloudModeManager.m | 24 ++++++++++++++++++++++++ Sources/Classes/RSNetworkManager.m | 3 +++ 3 files changed, 28 insertions(+) diff --git a/Sources/Classes/Headers/Public/RSEnums.h b/Sources/Classes/Headers/Public/RSEnums.h index 513a7ec6..3d66acf7 100644 --- a/Sources/Classes/Headers/Public/RSEnums.h +++ b/Sources/Classes/Headers/Public/RSEnums.h @@ -22,6 +22,7 @@ typedef enum { NETWORK_ERROR, NETWORK_SUCCESS, WRONG_WRITE_KEY, + MISSING_ANONYMOUSID_AND_USERID, INVALID_URL, RESOURCE_NOT_FOUND, NETWORK_UNAVAILABLE, diff --git a/Sources/Classes/RSCloudModeManager.m b/Sources/Classes/RSCloudModeManager.m index afc60ea4..51b4257a 100644 --- a/Sources/Classes/RSCloudModeManager.m +++ b/Sources/Classes/RSCloudModeManager.m @@ -70,6 +70,10 @@ - (void) startCloudModeProcessor { [RSMetricsReporter report:SDKMETRICS_CM_ATTEMPT_ABORT forMetricType:COUNT withProperties:@{SDKMETRICS_TYPE: SDKMETRICS_DATA_PLANE_URL_INVALID} andValue:1]; break; } + else if (response.state == MISSING_ANONYMOUSID_AND_USERID) { + [RSLogger logError:@"RSCloudModeManager: CloudModeProcessor: Request Failed as the batch payload contains events without anonymousId and userId, hence deleting those events from DB"]; + [self deleteEventsWithoutAnonymousId:dbMessage]; + } else if (response.state == NETWORK_ERROR) { [RSLogger logDebug:[[NSString alloc] initWithFormat:@"RSCloudModeManager: CloudModeProcessor: Retrying in: %d s", abs(sleepCount - strongSelf->config.sleepTimeout)]]; [RSMetricsReporter report:SDKMETRICS_CM_ATTEMPT_RETRY forMetricType:COUNT withProperties:nil andValue:1]; @@ -79,6 +83,26 @@ - (void) startCloudModeProcessor { }); } +- (void) deleteEventsWithoutAnonymousId: (RSDBMessage*) dbMessage { + NSMutableArray* messages = dbMessage.messages; + NSMutableArray* messageIds = dbMessage.messageIds; + NSMutableArray* messagesToBeDeleted = [[NSMutableArray alloc] init]; + + for(int i=0; i 0) { + [RSLogger logDebug:[[NSString alloc] initWithFormat:@"RSCloudModeManager: CloudModeProcessor: Deleting events without anonymousId: %@", [RSUtils getCSVString:messagesToBeDeleted]]]; + [self->dbPersistentManager clearEventsFromDB:messagesToBeDeleted]; + } +} + + (NSString*) getPayloadFromMessages: (RSDBMessage*)dbMessage{ if ([RSUtils isDBMessageEmpty:dbMessage]) { [RSLogger logDebug:@"Payload construction aborted because the dbMessage is empty."]; diff --git a/Sources/Classes/RSNetworkManager.m b/Sources/Classes/RSNetworkManager.m index a30d9692..c96f3bfa 100644 --- a/Sources/Classes/RSNetworkManager.m +++ b/Sources/Classes/RSNetworkManager.m @@ -85,6 +85,9 @@ -(RSNetworkResponse*) sendNetworkRequest: (NSString*) payload toEndpoint:(ENDPOI weakResult.state = RESOURCE_NOT_FOUND; } else if (weakResult.statusCode == 400) { weakResult.state = BAD_REQUEST; + } else if (![weakResult.errorPayload isEqualToString:@""] && [[weakResult.errorPayload lowercaseString] rangeOfString:@"request neither has anonymousid nor userid"].location != NSNotFound) { + [RSLogger logError:[[NSString alloc] initWithFormat:@"RSNetworkManager: sendNetworkRequest: Request to url %@ failed with statusCode %ld due to events missing anonymousId or userId",requestEndPoint, weakResult.statusCode]]; + weakResult.state = MISSING_ANONYMOUSID_AND_USERID; } else if (![weakResult.errorPayload isEqualToString:@""] && [[weakResult.errorPayload lowercaseString] rangeOfString:@"invalid write key"].location != NSNotFound) { [RSLogger logError:[[NSString alloc] initWithFormat:@"RSNetworkManager: sendNetworkRequest: Request to url %@ failed with statusCode %ld due to invalid write key",requestEndPoint, weakResult.statusCode ]]; weakResult.state = WRONG_WRITE_KEY; From 9af2eb0184ee8daaed83f7f2d8a2625ae9737d15 Mon Sep 17 00:00:00 2001 From: Desu Sai Venkat Date: Fri, 8 Dec 2023 17:22:17 +0530 Subject: [PATCH 3/5] chore: minor changes --- Podfile.lock | 4 +- Rudder.xcodeproj/project.pbxproj | 222 +++++++++++++++---------------- 2 files changed, 113 insertions(+), 113 deletions(-) diff --git a/Podfile.lock b/Podfile.lock index 5786a11e..3937530b 100644 --- a/Podfile.lock +++ b/Podfile.lock @@ -3,7 +3,7 @@ PODS: - RSCrashReporter (= 1.0.0) - RudderKit (= 1.4.0) - RSCrashReporter (1.0.0) - - Rudder (1.23.0): + - Rudder (1.23.1): - MetricsReporter (= 1.1.1) - RudderKit (1.4.0) - SQLCipher (4.5.4): @@ -33,7 +33,7 @@ EXTERNAL SOURCES: SPEC CHECKSUMS: MetricsReporter: d4265e0ac833e2c0078bbe044b3f9dbe29f53a48 RSCrashReporter: 7e26b51ac816e967acb58fa458040946a93a9e65 - Rudder: 125d9dc03e178b35b0f74487aa694afe1a8e6f4f + Rudder: 18897c785af9cfe84c2be2a1d15a645edbeda6d0 RudderKit: d9d6997696e1642b753d8bdf94e57af643a68f03 SQLCipher: 905b145f65f349f26da9e60a19901ad24adcd381 diff --git a/Rudder.xcodeproj/project.pbxproj b/Rudder.xcodeproj/project.pbxproj index 08667682..ae4a406e 100644 --- a/Rudder.xcodeproj/project.pbxproj +++ b/Rudder.xcodeproj/project.pbxproj @@ -9,11 +9,11 @@ /* Begin PBXBuildFile section */ 06CABC332630C6B00097BEFF /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 06CABC322630C6B00097BEFF /* Foundation.framework */; }; 06CABC352630C6D30097BEFF /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 06CABC2E2630C6660097BEFF /* UIKit.framework */; }; - 4EA9B1A591D8D4CC8B76DBB7 /* Pods_Rudder_watchOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 8F3CD20AD2E48323C2970A86 /* Pods_Rudder_watchOS.framework */; }; - 77EAE9965A2A7A663D468D2C /* Pods_RudderTests_tvOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 949DD501A3F38045A4E00FA6 /* Pods_RudderTests_tvOS.framework */; }; - 8B1D4DBB170C25CF4AA279DA /* Pods_Rudder_iOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 58171D93A3B1D46CE5290478 /* Pods_Rudder_iOS.framework */; }; - CFCD270DE231C4A075BD38A8 /* Pods_RudderTests_watchOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 943B1CC3CEB238C3BEDE2380 /* Pods_RudderTests_watchOS.framework */; }; - DE3740B9E153AAA5950B12EA /* Pods_Rudder_tvOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 0DDBD76EDA28FAB0AEFA6703 /* Pods_Rudder_tvOS.framework */; }; + 4C60FD1333361B5B023CA360 /* Pods_Rudder_iOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 70448FAEEB2723BFF792C9F1 /* Pods_Rudder_iOS.framework */; }; + 8ECDC3114AD83DF5F79903DE /* Pods_RudderTests_tvOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9274A6D90879FB5CF84AF2D9 /* Pods_RudderTests_tvOS.framework */; }; + A8B04575E1294C0DBD20DA06 /* Pods_Rudder_watchOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DC7B1A40E9FE6ACF0011DDFC /* Pods_Rudder_watchOS.framework */; }; + B8AD4C7A9EF6C87646B56E7E /* Pods_RudderTests_iOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 949240B316EFFE7D80CE31AF /* Pods_RudderTests_iOS.framework */; }; + DAB5EF5D2A403B7144307D79 /* Pods_Rudder_tvOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = B63925D4CED033974D27B692 /* Pods_Rudder_tvOS.framework */; }; ED0CA6EA2A7D08B900899C1C /* RSTransformationEvent.h in Headers */ = {isa = PBXBuildFile; fileRef = F6F2FA752A53D8310025D510 /* RSTransformationEvent.h */; settings = {ATTRIBUTES = (Public, ); }; }; ED0CA6EB2A7D08B900899C1C /* RSTransformationEvent.h in Headers */ = {isa = PBXBuildFile; fileRef = F6F2FA752A53D8310025D510 /* RSTransformationEvent.h */; settings = {ATTRIBUTES = (Public, ); }; }; ED0CA6EC2A7D08D800899C1C /* RSTransformationRequest.h in Headers */ = {isa = PBXBuildFile; fileRef = F6F2FA732A53CD9F0025D510 /* RSTransformationRequest.h */; settings = {ATTRIBUTES = (Public, ); }; }; @@ -691,7 +691,7 @@ ED9990922A6926E000031B06 /* RSMetricsReporter.m in Sources */ = {isa = PBXBuildFile; fileRef = ED99908D2A6926E000031B06 /* RSMetricsReporter.m */; }; ED9990932A6926E000031B06 /* RSMetricsReporter.m in Sources */ = {isa = PBXBuildFile; fileRef = ED99908D2A6926E000031B06 /* RSMetricsReporter.m */; }; EDEF1B312A835A90002B3E57 /* Security.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = EDEF1B302A835A90002B3E57 /* Security.framework */; }; - EE0DFE4EAE35E8445128DDEB /* Pods_RudderTests_iOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CD482BF023CD34D068C0C685 /* Pods_RudderTests_iOS.framework */; }; + F11CB429DDAC9F01F1A126A8 /* Pods_RudderTests_watchOS.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = BB0F1AEF9137A0C3DBE44385 /* Pods_RudderTests_watchOS.framework */; }; F6B4B52729C8236100344864 /* RSCloudModeManager.h in Headers */ = {isa = PBXBuildFile; fileRef = F6B4B51D29C8236100344864 /* RSCloudModeManager.h */; settings = {ATTRIBUTES = (Public, ); }; }; F6B4B52829C8236100344864 /* RSBackGroundModeManager.h in Headers */ = {isa = PBXBuildFile; fileRef = F6B4B51E29C8236100344864 /* RSBackGroundModeManager.h */; settings = {ATTRIBUTES = (Public, ); }; }; F6B4B52A29C8236100344864 /* RSDeviceModeManager.h in Headers */ = {isa = PBXBuildFile; fileRef = F6B4B52029C8236100344864 /* RSDeviceModeManager.h */; settings = {ATTRIBUTES = (Public, ); }; }; @@ -743,27 +743,27 @@ /* End PBXContainerItemProxy section */ /* Begin PBXFileReference section */ + 006C6A62C15BA0516469EDFA /* Pods-RudderTests-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS.debug.xcconfig"; sourceTree = ""; }; 06CABB842630C3CA0097BEFF /* Rudder.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Rudder.framework; sourceTree = BUILT_PRODUCTS_DIR; }; 06CABC2E2630C6660097BEFF /* UIKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = UIKit.framework; path = Platforms/MacOSX.platform/Developer/SDKs/MacOSX11.1.sdk/System/iOSSupport/System/Library/Frameworks/UIKit.framework; sourceTree = DEVELOPER_DIR; }; 06CABC322630C6B00097BEFF /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = Platforms/MacOSX.platform/Developer/SDKs/MacOSX11.1.sdk/System/Library/Frameworks/Foundation.framework; sourceTree = DEVELOPER_DIR; }; - 078FD5B41E7A8995606635EB /* Pods-RudderTests-iOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-iOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS.debug.xcconfig"; sourceTree = ""; }; - 07E380E737D74F7557BC8CC7 /* Pods-Rudder-watchOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-watchOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-watchOS/Pods-Rudder-watchOS.release.xcconfig"; sourceTree = ""; }; - 0DDBD76EDA28FAB0AEFA6703 /* Pods_Rudder_tvOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_tvOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - 0E6D2075D7BF95ED6BC0CA67 /* Pods-RudderTests-iOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-iOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS.release.xcconfig"; sourceTree = ""; }; - 1543D4AF7EB5F8A09D5EAE56 /* Pods-Rudder-watchOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-watchOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-watchOS/Pods-Rudder-watchOS.debug.xcconfig"; sourceTree = ""; }; - 4349A69C1F26C1696566463E /* Pods-Rudder-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-tvOS/Pods-Rudder-tvOS.debug.xcconfig"; sourceTree = ""; }; - 58171D93A3B1D46CE5290478 /* Pods_Rudder_iOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_iOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - 5E2BB3B59A2757BEE358B752 /* Pods-RudderTests-watchOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-watchOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS.debug.xcconfig"; sourceTree = ""; }; - 6A441BA33CFE6E3CA199A18F /* Pods-Rudder-iOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-iOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-iOS/Pods-Rudder-iOS.debug.xcconfig"; sourceTree = ""; }; - 74B255C905B56C48BB830448 /* Pods-RudderTests-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS.debug.xcconfig"; sourceTree = ""; }; - 7563B70270F46D35F3B97E68 /* Pods-Rudder-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-tvOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-tvOS/Pods-Rudder-tvOS.release.xcconfig"; sourceTree = ""; }; - 8F3CD20AD2E48323C2970A86 /* Pods_Rudder_watchOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_watchOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - 943B1CC3CEB238C3BEDE2380 /* Pods_RudderTests_watchOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_watchOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - 949DD501A3F38045A4E00FA6 /* Pods_RudderTests_tvOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_tvOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - A2AEC06AC179D727A690D2E4 /* Pods-Rudder-iOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-iOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-iOS/Pods-Rudder-iOS.release.xcconfig"; sourceTree = ""; }; - CD482BF023CD34D068C0C685 /* Pods_RudderTests_iOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_iOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; - D13FB366981B9CD6B0697ECC /* Pods-RudderTests-watchOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-watchOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS.release.xcconfig"; sourceTree = ""; }; - DD603392F568EF532092B324 /* Pods-RudderTests-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-tvOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS.release.xcconfig"; sourceTree = ""; }; + 0820CF4E6412DD78BB128A2E /* Pods-RudderTests-iOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-iOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS.debug.xcconfig"; sourceTree = ""; }; + 17EB7E8FCC582E07307AAA5F /* Pods-Rudder-iOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-iOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-iOS/Pods-Rudder-iOS.release.xcconfig"; sourceTree = ""; }; + 21DF38C4D8CCCF9ABF87BD1F /* Pods-Rudder-watchOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-watchOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-watchOS/Pods-Rudder-watchOS.debug.xcconfig"; sourceTree = ""; }; + 4968B32A5EF64C08B25C4C2C /* Pods-RudderTests-watchOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-watchOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS.release.xcconfig"; sourceTree = ""; }; + 571414DC3A36F4534C4A851E /* Pods-RudderTests-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-tvOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS.release.xcconfig"; sourceTree = ""; }; + 6B3EEAD25DDA5898233436F1 /* Pods-Rudder-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-tvOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-tvOS/Pods-Rudder-tvOS.release.xcconfig"; sourceTree = ""; }; + 70448FAEEB2723BFF792C9F1 /* Pods_Rudder_iOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_iOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 80DD5B34D7F8DD4FF9320813 /* Pods-RudderTests-iOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-iOS.release.xcconfig"; path = "Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS.release.xcconfig"; sourceTree = ""; }; + 87AB52C02D5F1ECA099F7430 /* Pods-Rudder-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-tvOS/Pods-Rudder-tvOS.debug.xcconfig"; sourceTree = ""; }; + 9274A6D90879FB5CF84AF2D9 /* Pods_RudderTests_tvOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_tvOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 949240B316EFFE7D80CE31AF /* Pods_RudderTests_iOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_iOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + A3C9514C38CAEBF9FFD6F9AD /* Pods-Rudder-iOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-iOS.debug.xcconfig"; path = "Target Support Files/Pods-Rudder-iOS/Pods-Rudder-iOS.debug.xcconfig"; sourceTree = ""; }; + B25B234D1AB86B5E667BD1A3 /* Pods-RudderTests-watchOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RudderTests-watchOS.debug.xcconfig"; path = "Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS.debug.xcconfig"; sourceTree = ""; }; + B63925D4CED033974D27B692 /* Pods_Rudder_tvOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_tvOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + BB0F1AEF9137A0C3DBE44385 /* Pods_RudderTests_watchOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RudderTests_watchOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + C1FF3A8F3DD59D25CAA4E01E /* Pods-Rudder-watchOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Rudder-watchOS.release.xcconfig"; path = "Target Support Files/Pods-Rudder-watchOS/Pods-Rudder-watchOS.release.xcconfig"; sourceTree = ""; }; + DC7B1A40E9FE6ACF0011DDFC /* Pods_Rudder_watchOS.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Rudder_watchOS.framework; sourceTree = BUILT_PRODUCTS_DIR; }; ED04A2482986C1750080A88D /* xccov-to-generic.sh */ = {isa = PBXFileReference; lastKnownFileType = text.script.sh; path = "xccov-to-generic.sh"; sourceTree = ""; }; ED056314291AABFD00BAEE65 /* sonar-project.properties */ = {isa = PBXFileReference; lastKnownFileType = text; path = "sonar-project.properties"; sourceTree = ""; }; ED1C4C8829E6CCC7007007C9 /* find-tag.sh */ = {isa = PBXFileReference; lastKnownFileType = text.script.sh; path = "find-tag.sh"; sourceTree = ""; }; @@ -1031,7 +1031,7 @@ 06CABC332630C6B00097BEFF /* Foundation.framework in Frameworks */, 06CABC352630C6D30097BEFF /* UIKit.framework in Frameworks */, EDEF1B312A835A90002B3E57 /* Security.framework in Frameworks */, - 8B1D4DBB170C25CF4AA279DA /* Pods_Rudder_iOS.framework in Frameworks */, + 4C60FD1333361B5B023CA360 /* Pods_Rudder_iOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1041,7 +1041,7 @@ files = ( ED998F0F2A69003600031B06 /* Foundation.framework in Frameworks */, ED998F102A69003600031B06 /* UIKit.framework in Frameworks */, - DE3740B9E153AAA5950B12EA /* Pods_Rudder_tvOS.framework in Frameworks */, + DAB5EF5D2A403B7144307D79 /* Pods_Rudder_tvOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1051,7 +1051,7 @@ files = ( ED998FDF2A69024E00031B06 /* Foundation.framework in Frameworks */, ED998FE02A69024E00031B06 /* UIKit.framework in Frameworks */, - 4EA9B1A591D8D4CC8B76DBB7 /* Pods_Rudder_watchOS.framework in Frameworks */, + A8B04575E1294C0DBD20DA06 /* Pods_Rudder_watchOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1060,7 +1060,7 @@ buildActionMask = 2147483647; files = ( ED9990312A69102400031B06 /* Rudder.framework in Frameworks */, - 77EAE9965A2A7A663D468D2C /* Pods_RudderTests_tvOS.framework in Frameworks */, + 8ECDC3114AD83DF5F79903DE /* Pods_RudderTests_tvOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1069,7 +1069,7 @@ buildActionMask = 2147483647; files = ( ED99903F2A69103B00031B06 /* Rudder.framework in Frameworks */, - EE0DFE4EAE35E8445128DDEB /* Pods_RudderTests_iOS.framework in Frameworks */, + B8AD4C7A9EF6C87646B56E7E /* Pods_RudderTests_iOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1078,7 +1078,7 @@ buildActionMask = 2147483647; files = ( ED99904D2A69104B00031B06 /* Rudder.framework in Frameworks */, - CFCD270DE231C4A075BD38A8 /* Pods_RudderTests_watchOS.framework in Frameworks */, + F11CB429DDAC9F01F1A126A8 /* Pods_RudderTests_watchOS.framework in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1116,12 +1116,12 @@ EDEF1B302A835A90002B3E57 /* Security.framework */, 06CABC322630C6B00097BEFF /* Foundation.framework */, 06CABC2E2630C6660097BEFF /* UIKit.framework */, - 58171D93A3B1D46CE5290478 /* Pods_Rudder_iOS.framework */, - 0DDBD76EDA28FAB0AEFA6703 /* Pods_Rudder_tvOS.framework */, - 8F3CD20AD2E48323C2970A86 /* Pods_Rudder_watchOS.framework */, - CD482BF023CD34D068C0C685 /* Pods_RudderTests_iOS.framework */, - 949DD501A3F38045A4E00FA6 /* Pods_RudderTests_tvOS.framework */, - 943B1CC3CEB238C3BEDE2380 /* Pods_RudderTests_watchOS.framework */, + 70448FAEEB2723BFF792C9F1 /* Pods_Rudder_iOS.framework */, + B63925D4CED033974D27B692 /* Pods_Rudder_tvOS.framework */, + DC7B1A40E9FE6ACF0011DDFC /* Pods_Rudder_watchOS.framework */, + 949240B316EFFE7D80CE31AF /* Pods_RudderTests_iOS.framework */, + 9274A6D90879FB5CF84AF2D9 /* Pods_RudderTests_tvOS.framework */, + BB0F1AEF9137A0C3DBE44385 /* Pods_RudderTests_watchOS.framework */, ); name = Frameworks; sourceTree = ""; @@ -1129,18 +1129,18 @@ DFB2363B6EC8D146934DE8DD /* Pods */ = { isa = PBXGroup; children = ( - 6A441BA33CFE6E3CA199A18F /* Pods-Rudder-iOS.debug.xcconfig */, - A2AEC06AC179D727A690D2E4 /* Pods-Rudder-iOS.release.xcconfig */, - 4349A69C1F26C1696566463E /* Pods-Rudder-tvOS.debug.xcconfig */, - 7563B70270F46D35F3B97E68 /* Pods-Rudder-tvOS.release.xcconfig */, - 1543D4AF7EB5F8A09D5EAE56 /* Pods-Rudder-watchOS.debug.xcconfig */, - 07E380E737D74F7557BC8CC7 /* Pods-Rudder-watchOS.release.xcconfig */, - 078FD5B41E7A8995606635EB /* Pods-RudderTests-iOS.debug.xcconfig */, - 0E6D2075D7BF95ED6BC0CA67 /* Pods-RudderTests-iOS.release.xcconfig */, - 74B255C905B56C48BB830448 /* Pods-RudderTests-tvOS.debug.xcconfig */, - DD603392F568EF532092B324 /* Pods-RudderTests-tvOS.release.xcconfig */, - 5E2BB3B59A2757BEE358B752 /* Pods-RudderTests-watchOS.debug.xcconfig */, - D13FB366981B9CD6B0697ECC /* Pods-RudderTests-watchOS.release.xcconfig */, + A3C9514C38CAEBF9FFD6F9AD /* Pods-Rudder-iOS.debug.xcconfig */, + 17EB7E8FCC582E07307AAA5F /* Pods-Rudder-iOS.release.xcconfig */, + 87AB52C02D5F1ECA099F7430 /* Pods-Rudder-tvOS.debug.xcconfig */, + 6B3EEAD25DDA5898233436F1 /* Pods-Rudder-tvOS.release.xcconfig */, + 21DF38C4D8CCCF9ABF87BD1F /* Pods-Rudder-watchOS.debug.xcconfig */, + C1FF3A8F3DD59D25CAA4E01E /* Pods-Rudder-watchOS.release.xcconfig */, + 0820CF4E6412DD78BB128A2E /* Pods-RudderTests-iOS.debug.xcconfig */, + 80DD5B34D7F8DD4FF9320813 /* Pods-RudderTests-iOS.release.xcconfig */, + 006C6A62C15BA0516469EDFA /* Pods-RudderTests-tvOS.debug.xcconfig */, + 571414DC3A36F4534C4A851E /* Pods-RudderTests-tvOS.release.xcconfig */, + B25B234D1AB86B5E667BD1A3 /* Pods-RudderTests-watchOS.debug.xcconfig */, + 4968B32A5EF64C08B25C4C2C /* Pods-RudderTests-watchOS.release.xcconfig */, ); path = Pods; sourceTree = ""; @@ -1858,7 +1858,7 @@ isa = PBXNativeTarget; buildConfigurationList = 06CABB982630C3CA0097BEFF /* Build configuration list for PBXNativeTarget "Rudder-iOS" */; buildPhases = ( - B0555A2EA83A75C13E79A13D /* [CP] Check Pods Manifest.lock */, + 4E7FF8B15B0C9D0B14B73A20 /* [CP] Check Pods Manifest.lock */, 06CABB7F2630C3CA0097BEFF /* Headers */, 06CABB802630C3CA0097BEFF /* Sources */, 06CABB812630C3CA0097BEFF /* Frameworks */, @@ -1877,7 +1877,7 @@ isa = PBXNativeTarget; buildConfigurationList = ED998F122A69003600031B06 /* Build configuration list for PBXNativeTarget "Rudder-tvOS" */; buildPhases = ( - 04765A1B5695BDA3756ECA43 /* [CP] Check Pods Manifest.lock */, + 885B02AFC7727CDE1ABDC8EB /* [CP] Check Pods Manifest.lock */, ED998E482A69003600031B06 /* Headers */, ED998EAE2A69003600031B06 /* Sources */, ED998F0E2A69003600031B06 /* Frameworks */, @@ -1896,7 +1896,7 @@ isa = PBXNativeTarget; buildConfigurationList = ED998FE22A69024E00031B06 /* Build configuration list for PBXNativeTarget "Rudder-watchOS" */; buildPhases = ( - B2BE11BC4A73400467A9CB20 /* [CP] Check Pods Manifest.lock */, + 3A2DC3B8C06A5E96F6739294 /* [CP] Check Pods Manifest.lock */, ED998F182A69024E00031B06 /* Headers */, ED998F7E2A69024E00031B06 /* Sources */, ED998FDE2A69024E00031B06 /* Frameworks */, @@ -1915,11 +1915,11 @@ isa = PBXNativeTarget; buildConfigurationList = ED9990342A69102400031B06 /* Build configuration list for PBXNativeTarget "RudderTests-tvOS" */; buildPhases = ( - 7BEC5760323793D04C57BF7D /* [CP] Check Pods Manifest.lock */, + 2E15979446768585E83A1317 /* [CP] Check Pods Manifest.lock */, ED9990292A69102400031B06 /* Sources */, ED99902A2A69102400031B06 /* Frameworks */, ED99902B2A69102400031B06 /* Resources */, - 7AEB0E8890498574C2D68BAF /* [CP] Embed Pods Frameworks */, + AEE1EB1DAEAD4D36E7246CE5 /* [CP] Embed Pods Frameworks */, ); buildRules = ( ); @@ -1935,11 +1935,11 @@ isa = PBXNativeTarget; buildConfigurationList = ED9990422A69103B00031B06 /* Build configuration list for PBXNativeTarget "RudderTests-iOS" */; buildPhases = ( - 3283D5B8C04C16B869F17268 /* [CP] Check Pods Manifest.lock */, + B3469C8EE835288FCB22583C /* [CP] Check Pods Manifest.lock */, ED9990372A69103A00031B06 /* Sources */, ED9990382A69103A00031B06 /* Frameworks */, ED9990392A69103A00031B06 /* Resources */, - B6CB91B398F2F737F3EDB2C0 /* [CP] Embed Pods Frameworks */, + A798478366B3E694740E1A7A /* [CP] Embed Pods Frameworks */, ); buildRules = ( ); @@ -1955,11 +1955,11 @@ isa = PBXNativeTarget; buildConfigurationList = ED9990502A69104B00031B06 /* Build configuration list for PBXNativeTarget "RudderTests-watchOS" */; buildPhases = ( - 6D3278BBC2FA391CD3FCC71C /* [CP] Check Pods Manifest.lock */, + 1A74610DC85841F981BFB968 /* [CP] Check Pods Manifest.lock */, ED9990452A69104B00031B06 /* Sources */, ED9990462A69104B00031B06 /* Frameworks */, ED9990472A69104B00031B06 /* Resources */, - 50EF77DFBFAF3A6C7C1DF433 /* [CP] Embed Pods Frameworks */, + CAEC4EACD5EAFC47D2CBB121 /* [CP] Embed Pods Frameworks */, ); buildRules = ( ); @@ -2097,7 +2097,7 @@ /* End PBXResourcesBuildPhase section */ /* Begin PBXShellScriptBuildPhase section */ - 04765A1B5695BDA3756ECA43 /* [CP] Check Pods Manifest.lock */ = { + 1A74610DC85841F981BFB968 /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( @@ -2112,14 +2112,14 @@ outputFileListPaths = ( ); outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-Rudder-tvOS-checkManifestLockResult.txt", + "$(DERIVED_FILE_DIR)/Pods-RudderTests-watchOS-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; }; - 3283D5B8C04C16B869F17268 /* [CP] Check Pods Manifest.lock */ = { + 2E15979446768585E83A1317 /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( @@ -2134,31 +2134,36 @@ outputFileListPaths = ( ); outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-RudderTests-iOS-checkManifestLockResult.txt", + "$(DERIVED_FILE_DIR)/Pods-RudderTests-tvOS-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; }; - 50EF77DFBFAF3A6C7C1DF433 /* [CP] Embed Pods Frameworks */ = { + 3A2DC3B8C06A5E96F6739294 /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", ); - name = "[CP] Embed Pods Frameworks"; + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; outputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-Rudder-watchOS-checkManifestLockResult.txt", ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks.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; }; - 6D3278BBC2FA391CD3FCC71C /* [CP] Check Pods Manifest.lock */ = { + 4E7FF8B15B0C9D0B14B73A20 /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( @@ -2173,75 +2178,70 @@ outputFileListPaths = ( ); outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-RudderTests-watchOS-checkManifestLockResult.txt", + "$(DERIVED_FILE_DIR)/Pods-Rudder-iOS-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; }; - 7AEB0E8890498574C2D68BAF /* [CP] Embed Pods Frameworks */ = { + 885B02AFC7727CDE1ABDC8EB /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", ); - name = "[CP] Embed Pods Frameworks"; + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; outputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-Rudder-tvOS-checkManifestLockResult.txt", ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks.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; }; - 7BEC5760323793D04C57BF7D /* [CP] Check Pods Manifest.lock */ = { + A798478366B3E694740E1A7A /* [CP] Embed Pods Frameworks */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", ); - inputPaths = ( - "${PODS_PODFILE_DIR_PATH}/Podfile.lock", - "${PODS_ROOT}/Manifest.lock", - ); - name = "[CP] Check Pods Manifest.lock"; + name = "[CP] Embed Pods Frameworks"; outputFileListPaths = ( - ); - outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-RudderTests-tvOS-checkManifestLockResult.txt", + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", ); 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"; + shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks.sh\"\n"; showEnvVarsInLog = 0; }; - B0555A2EA83A75C13E79A13D /* [CP] Check Pods Manifest.lock */ = { + AEE1EB1DAEAD4D36E7246CE5 /* [CP] Embed Pods Frameworks */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", ); - inputPaths = ( - "${PODS_PODFILE_DIR_PATH}/Podfile.lock", - "${PODS_ROOT}/Manifest.lock", - ); - name = "[CP] Check Pods Manifest.lock"; + name = "[CP] Embed Pods Frameworks"; outputFileListPaths = ( - ); - outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-Rudder-iOS-checkManifestLockResult.txt", + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", ); 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"; + shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-tvOS/Pods-RudderTests-tvOS-frameworks.sh\"\n"; showEnvVarsInLog = 0; }; - B2BE11BC4A73400467A9CB20 /* [CP] Check Pods Manifest.lock */ = { + B3469C8EE835288FCB22583C /* [CP] Check Pods Manifest.lock */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( @@ -2256,28 +2256,28 @@ outputFileListPaths = ( ); outputPaths = ( - "$(DERIVED_FILE_DIR)/Pods-Rudder-watchOS-checkManifestLockResult.txt", + "$(DERIVED_FILE_DIR)/Pods-RudderTests-iOS-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; }; - B6CB91B398F2F737F3EDB2C0 /* [CP] Embed Pods Frameworks */ = { + CAEC4EACD5EAFC47D2CBB121 /* [CP] Embed Pods Frameworks */ = { isa = PBXShellScriptBuildPhase; buildActionMask = 2147483647; files = ( ); inputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks-${CONFIGURATION}-input-files.xcfilelist", ); name = "[CP] Embed Pods Frameworks"; outputFileListPaths = ( - "${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", + "${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks-${CONFIGURATION}-output-files.xcfilelist", ); runOnlyForDeploymentPostprocessing = 0; shellPath = /bin/sh; - shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-iOS/Pods-RudderTests-iOS-frameworks.sh\"\n"; + shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RudderTests-watchOS/Pods-RudderTests-watchOS-frameworks.sh\"\n"; showEnvVarsInLog = 0; }; /* End PBXShellScriptBuildPhase section */ @@ -2809,7 +2809,7 @@ }; 06CABB992630C3CA0097BEFF /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 6A441BA33CFE6E3CA199A18F /* Pods-Rudder-iOS.debug.xcconfig */; + baseConfigurationReference = A3C9514C38CAEBF9FFD6F9AD /* Pods-Rudder-iOS.debug.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -2854,7 +2854,7 @@ }; 06CABB9A2630C3CA0097BEFF /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = A2AEC06AC179D727A690D2E4 /* Pods-Rudder-iOS.release.xcconfig */; + baseConfigurationReference = 17EB7E8FCC582E07307AAA5F /* Pods-Rudder-iOS.release.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -2898,7 +2898,7 @@ }; ED998F132A69003600031B06 /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 4349A69C1F26C1696566463E /* Pods-Rudder-tvOS.debug.xcconfig */; + baseConfigurationReference = 87AB52C02D5F1ECA099F7430 /* Pods-Rudder-tvOS.debug.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -2943,7 +2943,7 @@ }; ED998F142A69003600031B06 /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 7563B70270F46D35F3B97E68 /* Pods-Rudder-tvOS.release.xcconfig */; + baseConfigurationReference = 6B3EEAD25DDA5898233436F1 /* Pods-Rudder-tvOS.release.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -2987,7 +2987,7 @@ }; ED998FE32A69024E00031B06 /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 1543D4AF7EB5F8A09D5EAE56 /* Pods-Rudder-watchOS.debug.xcconfig */; + baseConfigurationReference = 21DF38C4D8CCCF9ABF87BD1F /* Pods-Rudder-watchOS.debug.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -3032,7 +3032,7 @@ }; ED998FE42A69024E00031B06 /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 07E380E737D74F7557BC8CC7 /* Pods-Rudder-watchOS.release.xcconfig */; + baseConfigurationReference = C1FF3A8F3DD59D25CAA4E01E /* Pods-Rudder-watchOS.release.xcconfig */; buildSettings = { ALLOW_TARGET_PLATFORM_SPECIALIZATION = YES; APPLICATION_EXTENSION_API_ONLY = NO; @@ -3076,7 +3076,7 @@ }; ED9990352A69102400031B06 /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 74B255C905B56C48BB830448 /* Pods-RudderTests-tvOS.debug.xcconfig */; + baseConfigurationReference = 006C6A62C15BA0516469EDFA /* Pods-RudderTests-tvOS.debug.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; @@ -3098,7 +3098,7 @@ }; ED9990362A69102400031B06 /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = DD603392F568EF532092B324 /* Pods-RudderTests-tvOS.release.xcconfig */; + baseConfigurationReference = 571414DC3A36F4534C4A851E /* Pods-RudderTests-tvOS.release.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; @@ -3120,7 +3120,7 @@ }; ED9990432A69103B00031B06 /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 078FD5B41E7A8995606635EB /* Pods-RudderTests-iOS.debug.xcconfig */; + baseConfigurationReference = 0820CF4E6412DD78BB128A2E /* Pods-RudderTests-iOS.debug.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; @@ -3152,7 +3152,7 @@ }; ED9990442A69103B00031B06 /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 0E6D2075D7BF95ED6BC0CA67 /* Pods-RudderTests-iOS.release.xcconfig */; + baseConfigurationReference = 80DD5B34D7F8DD4FF9320813 /* Pods-RudderTests-iOS.release.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; @@ -3184,7 +3184,7 @@ }; ED9990512A69104B00031B06 /* Debug */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 5E2BB3B59A2757BEE358B752 /* Pods-RudderTests-watchOS.debug.xcconfig */; + baseConfigurationReference = B25B234D1AB86B5E667BD1A3 /* Pods-RudderTests-watchOS.debug.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; @@ -3206,7 +3206,7 @@ }; ED9990522A69104B00031B06 /* Release */ = { isa = XCBuildConfiguration; - baseConfigurationReference = D13FB366981B9CD6B0697ECC /* Pods-RudderTests-watchOS.release.xcconfig */; + baseConfigurationReference = 4968B32A5EF64C08B25C4C2C /* Pods-RudderTests-watchOS.release.xcconfig */; buildSettings = { CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; CODE_SIGN_STYLE = Automatic; From 749ba44d62705ee197dc47e7946dc348b9664718 Mon Sep 17 00:00:00 2001 From: Desu Sai Venkat Date: Tue, 12 Dec 2023 17:11:30 +0530 Subject: [PATCH 4/5] fix: restricting direct access to RSClient instance without acquiring lock --- Sources/Classes/RSClient.m | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/Sources/Classes/RSClient.m b/Sources/Classes/RSClient.m index 216a9f2a..ed373162 100644 --- a/Sources/Classes/RSClient.m +++ b/Sources/Classes/RSClient.m @@ -433,7 +433,14 @@ - (void)trackLifecycleEvents:(NSDictionary *)launchOptions { } + (instancetype)sharedInstance { - return _instance; + if (recursiveLock == nil) { + recursiveLock = [[NSRecursiveLock alloc] init]; + } + RSClient* client; + [recursiveLock lock]; + client = _instance; + [recursiveLock unlock]; + return client; } + (RSOption*) getDefaultOptions { @@ -472,11 +479,11 @@ + (void)putDeviceToken:(NSString *_Nonnull)deviceToken { [RSLogger logDebug:@"User Opted out for tracking the activity, hence dropping the device token"]; return; } - if(_instance == nil) { + if([RSClient sharedInstance] == nil) { _deviceToken = deviceToken; return; } - [_instance.context putDeviceToken:deviceToken]; + [[RSClient sharedInstance].context putDeviceToken:deviceToken]; } } From 749f16dac72c3ffa60452e8db305422b520420b9 Mon Sep 17 00:00:00 2001 From: Desu Sai Venkat Date: Tue, 12 Dec 2023 17:26:31 +0530 Subject: [PATCH 5/5] fix: fixed issues with the parsing of network response --- Sources/Classes/RSClient.m | 3 +++ Sources/Classes/RSNetworkManager.m | 4 ++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/Sources/Classes/RSClient.m b/Sources/Classes/RSClient.m index ed373162..13f23542 100644 --- a/Sources/Classes/RSClient.m +++ b/Sources/Classes/RSClient.m @@ -50,6 +50,9 @@ + (instancetype)initiate:(NSString *)writeKey config:(RSConfig * __nullable)conf if ([writeKey length] == 0) { [RSLogger logError:WRITE_KEY_ERROR]; } + if (recursiveLock == nil) { + recursiveLock = [[NSRecursiveLock alloc] init]; + } [recursiveLock lock]; @try { if (_instance == nil) { diff --git a/Sources/Classes/RSNetworkManager.m b/Sources/Classes/RSNetworkManager.m index c96f3bfa..773af2ed 100644 --- a/Sources/Classes/RSNetworkManager.m +++ b/Sources/Classes/RSNetworkManager.m @@ -83,14 +83,14 @@ -(RSNetworkResponse*) sendNetworkRequest: (NSString*) payload toEndpoint:(ENDPOI weakResult.responsePayload = nil; if(weakResult.statusCode == 404) { weakResult.state = RESOURCE_NOT_FOUND; - } else if (weakResult.statusCode == 400) { - weakResult.state = BAD_REQUEST; } else if (![weakResult.errorPayload isEqualToString:@""] && [[weakResult.errorPayload lowercaseString] rangeOfString:@"request neither has anonymousid nor userid"].location != NSNotFound) { [RSLogger logError:[[NSString alloc] initWithFormat:@"RSNetworkManager: sendNetworkRequest: Request to url %@ failed with statusCode %ld due to events missing anonymousId or userId",requestEndPoint, weakResult.statusCode]]; weakResult.state = MISSING_ANONYMOUSID_AND_USERID; } else if (![weakResult.errorPayload isEqualToString:@""] && [[weakResult.errorPayload lowercaseString] rangeOfString:@"invalid write key"].location != NSNotFound) { [RSLogger logError:[[NSString alloc] initWithFormat:@"RSNetworkManager: sendNetworkRequest: Request to url %@ failed with statusCode %ld due to invalid write key",requestEndPoint, weakResult.statusCode ]]; weakResult.state = WRONG_WRITE_KEY; + }else if (weakResult.statusCode == 400) { + weakResult.state = BAD_REQUEST; } else { weakResult.state = NETWORK_ERROR; }