-
Notifications
You must be signed in to change notification settings - Fork 86
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Suggestions to improve LDUserBuilder API #85
Suggestions to improve LDUserBuilder API #85
Conversation
… access properties.
Looks like |
Test failure has been corrected. |
That looks really good @petrucci34! I hope someone from the team accepts your PR soon, they really need to. |
I guess @justinucd is the responsible for that? |
Thanks for this PR @petrucci34 ! We agree that this is the right direction to take |
Merging this PR into a separate branch to continue similar optimizations for other builders while keeping the existing methods as deprecated. |
Thanks @arun251 and @danialzahid94 for the feedback! Yes, it makes sense to make similar changes to |
@petrucci34 We are working on |
* Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter
* Changes user-device to device model identifier (#75) * installs new deviceModel into EnvironmentReporter and renames old deviceModel to deviceType * use CwSysCtl for macos model * Replaced entire flag store ff array instead of in place manipulation * Updated CHANGELOG and bumped version number * Added correct copy behavior to FlagStore delete and update * Improved CHANGELOG entry for 4.0.1 * Changed version to 4.1.0, updated CHANGELOG * Update 4.1.0 release date * installs ios-eventsource 4.0.2 * installs CocoaPods 1.7.2 * clears swift 5 update warning * updates circle config to use xcode 10.2.1 * advances version to 4.1.1 * installs Nimble 8.0.2 * updates SwiftLint to 0.33.0 * Update 4.1.1 release date * Improved CHANGELOG 4.1.1 description * Made CHANGELOG 4.1.1 more consistent * 4.1.2 release, updated version numbers and CHANGELOG * Made 4.1.2 CHANGELOG entry more descriptive * Rebuilt Connection Status, added unit tests, fixed warnings * Changed guard to equals in Dictionary extension, changed ConnectionInformation to struct * Fixed threading issues and reference semantics * Improved ConnectionInformation toString, fixed background behavior * Added network connectivity check, changed TimeIntervals to Optionals * Added Connection Status files to correct Target Membership, added conditional compilation of network connectivity check for WatchOS * PR review changes * More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 Co-authored-by: Mark Pokorny <[email protected]>
* Changes user-device to device model identifier (#75) * installs new deviceModel into EnvironmentReporter and renames old deviceModel to deviceType * use CwSysCtl for macos model * Replaced entire flag store ff array instead of in place manipulation * Updated CHANGELOG and bumped version number * Added correct copy behavior to FlagStore delete and update * Improved CHANGELOG entry for 4.0.1 * Changed version to 4.1.0, updated CHANGELOG * Update 4.1.0 release date * installs ios-eventsource 4.0.2 * installs CocoaPods 1.7.2 * clears swift 5 update warning * updates circle config to use xcode 10.2.1 * advances version to 4.1.1 * installs Nimble 8.0.2 * updates SwiftLint to 0.33.0 * Update 4.1.1 release date * Improved CHANGELOG 4.1.1 description * Made CHANGELOG 4.1.1 more consistent * 4.1.2 release, updated version numbers and CHANGELOG * Made 4.1.2 CHANGELOG entry more descriptive * Rebuilt Connection Status, added unit tests, fixed warnings * Changed guard to equals in Dictionary extension, changed ConnectionInformation to struct * Fixed threading issues and reference semantics * Improved ConnectionInformation toString, fixed background behavior * Added network connectivity check, changed TimeIntervals to Optionals * Added Connection Status files to correct Target Membership, added conditional compilation of network connectivity check for WatchOS * PR review changes * More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs Co-authored-by: Mark Pokorny <[email protected]>
* Changes user-device to device model identifier (#75) * installs new deviceModel into EnvironmentReporter and renames old deviceModel to deviceType * use CwSysCtl for macos model * Replaced entire flag store ff array instead of in place manipulation * Updated CHANGELOG and bumped version number * Added correct copy behavior to FlagStore delete and update * Improved CHANGELOG entry for 4.0.1 * Changed version to 4.1.0, updated CHANGELOG * Update 4.1.0 release date * installs ios-eventsource 4.0.2 * installs CocoaPods 1.7.2 * clears swift 5 update warning * updates circle config to use xcode 10.2.1 * advances version to 4.1.1 * installs Nimble 8.0.2 * updates SwiftLint to 0.33.0 * Update 4.1.1 release date * Improved CHANGELOG 4.1.1 description * Made CHANGELOG 4.1.1 more consistent * 4.1.2 release, updated version numbers and CHANGELOG * Made 4.1.2 CHANGELOG entry more descriptive * Rebuilt Connection Status, added unit tests, fixed warnings * Changed guard to equals in Dictionary extension, changed ConnectionInformation to struct * Fixed threading issues and reference semantics * Improved ConnectionInformation toString, fixed background behavior * Added network connectivity check, changed TimeIntervals to Optionals * Added Connection Status files to correct Target Membership, added conditional compilation of network connectivity check for WatchOS * PR review changes * More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs * Added single retry attempt to event post (#88) * Added single retry attempt to event post * Added payloadId to the correct point to maintain value between retries, retry on error * reportSyncComplete on 2nd error, always log on event post error, add 1 second delay with log on event post retry * Added 1 second delay to retry event post * async'd event post to prevent blocking main thread on retry sleep * Increased event test waitUntil timeout to 10 seconds * Bumped patch version, added CHANGELOG for 4.4.1 * Changed 4.4.1 entry * Further 4.4.1 entry revision * Changed retry event post for loop to function call (#89) * Clarified that event retry will only happen once in CHANGELOG Co-authored-by: Mark Pokorny <[email protected]>
* Changes user-device to device model identifier (#75) * installs new deviceModel into EnvironmentReporter and renames old deviceModel to deviceType * use CwSysCtl for macos model * Replaced entire flag store ff array instead of in place manipulation * Updated CHANGELOG and bumped version number * Added correct copy behavior to FlagStore delete and update * Improved CHANGELOG entry for 4.0.1 * Changed version to 4.1.0, updated CHANGELOG * Update 4.1.0 release date * installs ios-eventsource 4.0.2 * installs CocoaPods 1.7.2 * clears swift 5 update warning * updates circle config to use xcode 10.2.1 * advances version to 4.1.1 * installs Nimble 8.0.2 * updates SwiftLint to 0.33.0 * Update 4.1.1 release date * Improved CHANGELOG 4.1.1 description * Made CHANGELOG 4.1.1 more consistent * 4.1.2 release, updated version numbers and CHANGELOG * Made 4.1.2 CHANGELOG entry more descriptive * Rebuilt Connection Status, added unit tests, fixed warnings * Changed guard to equals in Dictionary extension, changed ConnectionInformation to struct * Fixed threading issues and reference semantics * Improved ConnectionInformation toString, fixed background behavior * Added network connectivity check, changed TimeIntervals to Optionals * Added Connection Status files to correct Target Membership, added conditional compilation of network connectivity check for WatchOS * PR review changes * More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs * Added single retry attempt to event post (#88) * Added single retry attempt to event post * Added payloadId to the correct point to maintain value between retries, retry on error * reportSyncComplete on 2nd error, always log on event post error, add 1 second delay with log on event post retry * Added 1 second delay to retry event post * async'd event post to prevent blocking main thread on retry sleep * Increased event test waitUntil timeout to 10 seconds * Bumped patch version, added CHANGELOG for 4.4.1 * Changed 4.4.1 entry * Further 4.4.1 entry revision * Changed retry event post for loop to function call (#89) * [ch65670] Fix Xcode 11.4 build and unit tests (#90) * Fixed build errors, fixed some unit tests * Added shell script to remove duplicate sourcery method mock * sed now matches specific pattern instead of line numbers * Add project config file containing run script step * Bump CircleCI Xcode to 11.4 * Bump CircleCI Xcode to 11.4.0 * Changed iPhone simulator in CircleCI from XS to Xs * Changed CircleCI xcodebuild from OS:latest to OS:12.4 * Testing NSURLRetryPolicy on CI * Removed DeprecatedCache from automock * Fix FlagStore to synchronize reads with writes. * Add xcode compatibility information to readme (#93) * Fix for concurrency bug exposed by restwrapper. (#94) * General cleanup. (#92) * [ch75316] Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache (#96) * Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache * Changed specific -1 to 0 * Added unlimited users tests * Added CHANGELOG for 4.6 * Added maxCachedUsers to objc LDConfig (#97) * Changed version to 4.6.0 Co-authored-by: Mark Pokorny <[email protected]> Co-authored-by: Gavin Whelan <[email protected]> Co-authored-by: Ben Woskow <[email protected]>
* Changes user-device to device model identifier (#75) * installs new deviceModel into EnvironmentReporter and renames old deviceModel to deviceType * use CwSysCtl for macos model * Replaced entire flag store ff array instead of in place manipulation * Updated CHANGELOG and bumped version number * Added correct copy behavior to FlagStore delete and update * Improved CHANGELOG entry for 4.0.1 * Changed version to 4.1.0, updated CHANGELOG * Update 4.1.0 release date * installs ios-eventsource 4.0.2 * installs CocoaPods 1.7.2 * clears swift 5 update warning * updates circle config to use xcode 10.2.1 * advances version to 4.1.1 * installs Nimble 8.0.2 * updates SwiftLint to 0.33.0 * Update 4.1.1 release date * Improved CHANGELOG 4.1.1 description * Made CHANGELOG 4.1.1 more consistent * 4.1.2 release, updated version numbers and CHANGELOG * Made 4.1.2 CHANGELOG entry more descriptive * Rebuilt Connection Status, added unit tests, fixed warnings * Changed guard to equals in Dictionary extension, changed ConnectionInformation to struct * Fixed threading issues and reference semantics * Improved ConnectionInformation toString, fixed background behavior * Added network connectivity check, changed TimeIntervals to Optionals * Added Connection Status files to correct Target Membership, added conditional compilation of network connectivity check for WatchOS * PR review changes * More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs * Added single retry attempt to event post (#88) * Added single retry attempt to event post * Added payloadId to the correct point to maintain value between retries, retry on error * reportSyncComplete on 2nd error, always log on event post error, add 1 second delay with log on event post retry * Added 1 second delay to retry event post * async'd event post to prevent blocking main thread on retry sleep * Increased event test waitUntil timeout to 10 seconds * Bumped patch version, added CHANGELOG for 4.4.1 * Changed 4.4.1 entry * Further 4.4.1 entry revision * Changed retry event post for loop to function call (#89) * [ch65670] Fix Xcode 11.4 build and unit tests (#90) * Fixed build errors, fixed some unit tests * Added shell script to remove duplicate sourcery method mock * sed now matches specific pattern instead of line numbers * Add project config file containing run script step * Bump CircleCI Xcode to 11.4 * Bump CircleCI Xcode to 11.4.0 * Changed iPhone simulator in CircleCI from XS to Xs * Changed CircleCI xcodebuild from OS:latest to OS:12.4 * Testing NSURLRetryPolicy on CI * Removed DeprecatedCache from automock * Fix FlagStore to synchronize reads with writes. * Add xcode compatibility information to readme (#93) * Add xcode compatibility information to readme (#93) * Fix for concurrency bug exposed by restwrapper. (#94) * General cleanup. (#92) * [ch75316] Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache (#96) * Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache * Changed specific -1 to 0 * Added unlimited users tests * Added CHANGELOG for 4.6 * Added maxCachedUsers to objc LDConfig (#97) * Changed version to 4.6.0 * [ch66864] Added startCompleteWhenFlagsReceivedTimeout (#98) * Added startCompleteWhenFlagsReceivedTimeout which allows a timeout in seconds to be given for the completion to be fired indicating that flags have been received * Fixed doc typo, removed bad ms to second conversion * Fix previous doc typo that got copied into objc * Added serial queue to timeOutCheck to fix possible race condition * Simplified unit tests by swapping if for assertion * Simplified start timeout method name, fixed doc about timedOut return * Moved DispatchQueue off of main * Moved sync dispatchqueue from variable to func * Changed labeled queue to global queue * Added test for start timeout timing out, added doc note about start timeout and starting offline * Bump version to 4.7.0 and add CHANGELOG * Changed startWaitSeconds type signature from Int to TimeInterval * Changed startWaitSeconds doc string type to TimeInterval * Clarified 4.7.0 CHANGELOG Co-authored-by: Mark Pokorny <[email protected]> Co-authored-by: Gavin Whelan <[email protected]> Co-authored-by: Ben Woskow <[email protected]>
* More PR review changes * Even more PR review changes * Removed ConnectionInformationCaching, removed redundant variables * Simplified synchronizing error behavior for connection status * DRY up setupListeners * Fixed string cases for LastConnectionFailureReason Codable * Forgot to add polling last successful connection * Store is now in Cache dir, removed listeners and 1 ldclient.shared, changed TimeInterval to Date, changed two inout's to var's * Added ConnectionModeChangedObserver * Fixed confusing docstring, removed unnecessary flag synchronizer * Changed getValue and toString to description * Changed description to computed property * Removed connectionModeCheck * Improved background connection status behavior * Changed ConnectionInformation description to computed property * Added new identify method, updated swiftlint rules * Made Identify actually change the user, fixed unit tests * Removed unnecessary _user assignment * Move swiftlint disable to LDClient, move user assignment into identifyInternal * Added private setOnline and go functions for identify * Forgot to replace go in guard with goIdentify * Copied user property unit tests for identify * Added optimization to not call setOnline when there is no completion and wasOnline is false * Testing identifyInternal change in IH * requested PR changes * Fixed convertCachedData call count, some PR feedback fixes * Simplified unit tests, added comment about thread safety * Changed lastSuccessfulConnection to lastKnownFlagValidity, added on stream close listener * Fixed handler * Remove unnecessary import * Changed eventSource access level * Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs * Added single retry attempt to event post (#88) * Added single retry attempt to event post * Added payloadId to the correct point to maintain value between retries, retry on error * reportSyncComplete on 2nd error, always log on event post error, add 1 second delay with log on event post retry * Added 1 second delay to retry event post * async'd event post to prevent blocking main thread on retry sleep * Increased event test waitUntil timeout to 10 seconds * Bumped patch version, added CHANGELOG for 4.4.1 * Changed 4.4.1 entry * Further 4.4.1 entry revision * Changed retry event post for loop to function call (#89) * [ch65670] Fix Xcode 11.4 build and unit tests (#90) * Fixed build errors, fixed some unit tests * Added shell script to remove duplicate sourcery method mock * sed now matches specific pattern instead of line numbers * Add project config file containing run script step * Bump CircleCI Xcode to 11.4 * Bump CircleCI Xcode to 11.4.0 * Changed iPhone simulator in CircleCI from XS to Xs * Changed CircleCI xcodebuild from OS:latest to OS:12.4 * Testing NSURLRetryPolicy on CI * Removed DeprecatedCache from automock * Fix FlagStore to synchronize reads with writes. * multi env: init, config, client methods, and ObjCLDClient * Remove accidentally checked in IDE file * Add xcode compatibility information to readme (#93) * Add xcode compatibility information to readme (#93) * Fixed comments, added flush to close, started migrating unit tests * Added multi environment methods to ObjCLDClient, added better comments for said methods * Changed init completion behavior for correct ordering, removed deprecated variationAndSource methods, more unit test changes * Added primary instance to instances, fixed completion behavior * Made UserEnvironmentFlagCache shared between instances, made FlagSynchronizer DispatchQueue not static * Fixed user clobbering by deep copying FlagStore * Fix for concurrency bug exposed by restwrapper. (#94) * General cleanup. (#92) * [ch75316] Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache (#96) * Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache * Changed specific -1 to 0 * Added unlimited users tests * Added CHANGELOG for 4.6 * Added maxCachedUsers to objc LDConfig (#97) * Changed version to 4.6.0 * [ch66864] Added startCompleteWhenFlagsReceivedTimeout (#98) * Added startCompleteWhenFlagsReceivedTimeout which allows a timeout in seconds to be given for the completion to be fired indicating that flags have been received * Fixed doc typo, removed bad ms to second conversion * Fix previous doc typo that got copied into objc * Added serial queue to timeOutCheck to fix possible race condition * Simplified unit tests by swapping if for assertion * Simplified start timeout method name, fixed doc about timedOut return * Moved DispatchQueue off of main * Moved sync dispatchqueue from variable to func * Changed labeled queue to global queue * Added test for start timeout timing out, added doc note about start timeout and starting offline * [ch70792] Swift EventSource (#99) * Integrating Swift eventsource. * No longer set `-sdk` on `xcodebuild` commands for circle. There seems to be some sort of interaction between `-sdk` or `SDKROOT` and the implicit dependency resolution system. Since Xcode 10.2, Xcode can find implicit dependencies in `OTHER_LINKER_FLAGS` such as when Cocoapods links a framework with `-F`. When `SDKROOT` is not set, this doesn't conflict with anything, but I believe the behavior of finding the framework as an implicit dependency is not required (I think it just resolves to the same target Cocoapods is building). If `SDKROOT` is set, xcodebuild seems to decide that it must first resolve and build the framework. It gives the warning "Multiple targets match implicit dependency for linker flags '-framework LDSwiftEventSource'", as LDSwiftEventSource generates a product by the same name (`LDSwiftEventSource.framework`) regardless of the platform/sdk being built. Now apparently it completely forgets about the set `SDKROOT` (which normally seems to be fed through and used to resolve the target being built) and decides that it should build the iOS target (no idea why, it's not even the default `SDKROOT` for `LDSwiftEventSource`). When `SDKROOT` is set to `macosx`, `xcodebuild` proceeds to simultaneously build both the iOS and macOS targets (I believe the macOS target is from Cocoapods operating correctly), then fails as it's still actually building the iOS target with the macOS SDK configuration. The actual build error is that the 'LDSwiftEventSource-iOS-umbrella.h' header can't find 'UIKit/UIKit.h' as UIKit is not available on macOS. * Update LDSwiftEventSource to 0.3.0, handle some minor todos. * This updates the circle config to actually do a `pod install`. Removes Gemfile that was for CocoaPods. * Specify sources for pod spec lint. * I think spec lint tries to test the spec file against code on the master branch, so only run a spec lint if commit is on master. * Allow warnings for now. * Bump version to 4.7.0 and add CHANGELOG * Changed startWaitSeconds type signature from Int to TimeInterval * Changed startWaitSeconds doc string type to TimeInterval * Clarified 4.7.0 CHANGELOG * Fixed no log output when isDebugMode = true * Fixed old EventSource still sticking around, removed default to fix compiler warning * Added startWaitSeconds to start, added more debug logging, added flagsynchronizer config.streamingMode * Fixed LDClient offline by putting internalIdentify in an async DispatchQueue, removed print statements * Unit tests build but LDClientSpec crashes * [ch72204] drop events after failed retry (#100) * Drop events after failed retry, as well as some general cleanup and consistency changes. * Don't disabled event reporting in background. * Added ClientServiceFactory back to init * Throttler mock isn't firing, migrating unit tests to TestContext init pattern * [ch61747] Diagnostic events (#101) * Start specs build and run but fail * Removed public set LDClient.config, added more failing specs, removed prints * Removed convenience init flagSynchronizer set to avoid malloc error, all but 2 LDClient specs build and run * All LDClient specs build and run * Fixed LDClient spec flagstore mock being replaced * Remove EventTrackingContext * Added config didSet back to init, removed outdated tests * Removed outdated tests for client not started, fixed some incorrectly ported tests * Fix more LDClient unit tests failures * Remove EventTrackingContext (#102) * Remove DeprecatedCacheModelV6, which was never needed. * A bit of cleanup. * Update some old comments. * Update diagnostic events to include count of secondary mobile keys. * Added waitUntil to internalIdentify calls to fix timing issue in some tests * Added setOnline for background tests, removed unnecessary runMode parameter on test start * set hasStarted false for starting tests * Fixed static timeOutCheck not being reset, trigger service didSet for pollingInterval tests * Added secondaryMobileKeys to ObjCLDConfig, change Array<String>? to [String]?, changed getEnvNames return, removed unnecessary returns in ClientServiceFactory, changed to internalSetOnline in close * Set instances to nil after loop in close * Remove UUID queue labels * Forgot empty FlagStore init * Added waitUntil to identify to fix Circle timing * Only internal ObjC methods can set the ObjCLDClient.ldClient * Moved all internalIdentify calls to waitUntil to fix Circle timing * Make config public private(set) * Added debug method to set config allUserAttributesPrivate * Make testing allUserAttributesPrivate method public * Move setAllUserAttributesPrivate to public * Attempted timing fix for Circle * Lowered timeout with troublesome test * Troublesome test false to true * Try synchronized instead of DispatchQueue.sync * Change sync queue and if ordering in start timeout * Forgot to add to testing version * Removed spurious changes from FlagSynchronizer and FlagStore * Try synced with if change start timeout * Changed setAllUserAttributesPrivate to apply to all instances, changed setOnline to internalSetOnline in configDidSet * Changed LDClient internal setOnline calls to internalSetOnline * Removed synced, added serial queues to identify and setonline * Removed true check in start timeout * Test removing serial queue from setOnline and identify * Change serial queues in setOnline and identify to sync * Move if outside sync serial queue in start timeout * Move if back inside serial queue but make queue async start timeout * remove static from internal method queues * Add secondaryMobileKeys to convertCacheData * Switched global to main queue in start timeout * Try name queue instead of main in start timeout * Remove internalIdentifyQueue * Changed named queue back to global, added back InternalIdentifyQueue, changed CircleCi simulator from iOS 12.4 to 13.4 * Change iOS 13.4 to 13.4.1 in Circle * Change iOS simulator from Xs to iPhone 11 Pro Max * Updating to iOS 13.4.1 on Circle fix disparity between DarklyServiceSpec on local vs Circle * Removed static from timeOutCheck and queue and made them function scope variables * Made main queues named queues in LDClientSpec * Explicitly turn off parallel testing on Circle * Added waitUntil with asyncAfter to setRunMode and background notification * Changed all asyncAfter deadlines to 0.2 * Passes thread sanitizer locally * More thread sanitizer finds * Fixed recursive sync queues in EventReporter and FlagSynchronizer * Improve Throttler code. * Hopefully fix sync queue crash in FlagChangeNotifier. * I don't think we actually want to loop through converting all environment cache data here. * changed internalIdentifyQueue to sync, added sync queue to internalSetOnline * PR feedback, removed convenience init * Fixed onSuccess tests * Removes isStarting variable, to make initialization more clear. * Removes all remaining LDFlagSource code. * Fix logging of type conversion errors. * Update more code doc for multi-environment branch changes. * Remove unnecessary objc class and improve interface for type mismatches on changed flag handlers. * Prefer `is` to `as != nil`. * Use DispatchGroup for static loops. * Make time constraint a bit more lenient for more reliable CircleCI tests. * Add a threshold for testing delay on throttler executions to prevent spurious test failures. * Replaced timeOutCheck with completed, simplified start test close, removed unnecessary string cast in LDConfig * Removed unnecessary nil check in start for tests * Removed unnecessary string cast in LDConfig, made waitUntil longer than start timeout * Fix after merge. * Change setUserSpec to identifySpec, fix doc strings * Remove internalInstances from LDClient, remove isOnlineQueue from DiagnosticReporter * Should improve LDClientSpec test runtime substantially. * 3 second for timeout seems a bit long even for circleci. * Update OHHTTPStubs for SwiftPM support. * Update DarklyServiceMock for changes in OHHTTPStubs 9.0.0 * Update DarklyServiceSpec for OHHTTPStubs 9.0.0 * Add explicit import for Foundation in tests. Make linter slightly more lienent and specify linted paths better. Fix mocks.stencil to allow specifying a defaultMockValue for an Optional type variable. Change default value for EnvironmentReporting.backgroundNotification and EnvironmentReporting.foregroundNotification to delegate to EnvironmentReporter to handle running tests on platforms without UIKit. Avoid using XCTFail. * Add initial SwiftPM Package.swift definition. Add SwiftPM build folder to .gitignore. Add missing Foundation import in LDClientSpec.swift. Comment out test that was previously disabled in the xcode test configuration, which SwiftPM doesn't use. * Use github reference for LDSwiftEventSource rather than local reference. * Try specifying ssh urls for dependencies in Package.swift as xcode is choking when adding the package. * Remove setAllUserAttributesPrivate public method * Changed ObjcLDClient to act as a wrapper instead of keeping an internal LDClient, updated doc strings * Fixed weird setOnline tests, fixed doc strings, added throws setter to secondaryMobileKeys, fixed ObjcLDClient * Fixed LDClient close tests, added getter setter doc strings for secondaryMobileKeys, removed commented out code in LDConfig, removed unnecessary setOnline method in ObjcLDClient * Fix doc strings in LDClient * Removed logs from throws in LDConfig * Added .swiftpm/ to .gitignore, removed all occurrences of fallback and replaced them with defaultValue (#111) * Added .swiftpm/ to .gitignore, removed all occurrences of fallback and replaced them with defaultValue * Change .swiftpm/ to /.swiftpm * Removed defaultValue value * Fix 2 typos * Updated SDK version and supported iOS and Xcode versions in README * Use Mint for tooling. * Update CONTRIBUTING.md Co-authored-by: Ben Woskow <[email protected]> * Add @objc annotation to start objc bridge methods. * (5.0) Use SwiftPM for SDK dependencies. (#114) * (5.0) Fix of crash when logging is enabled. (#115) Also removed unused test code. Improve documentation on LDClient.flush() * (5.0) Update installation instructions (#116) * (5.0) Changelog and some final removals and renames of public APIs (#117) Fix a bug with preventing the SDK from retrying eventsource connections when the service returns a 5XX error code. Renamed a couple of public APIs. Removed some publicly exposed implementation details. Updated CHANGELOG.md for 5.0. * [ch69438] Add ability to set additional headers on requests (#119) * A jazzy doc build and update lint configuration (#120) * [ch84954] Fix nested bundles in carthage build and missing dynamic library in SwiftPM build. (#121) * Focus week cleanup (#122) * [ch87108] Fix LDUser serialization to report redacted custom attributes in all cases (#123) * [ch87107] Add LDUser secondary attribute (#124) * [ch88282] Fix DiagnosticEvent build warnings on Xcode 12 (#125) * Update dependencies after release of Nimble 9.0.0 (#126) * Update doc comments for LDClient.identify (#127) * [ch91505] Dynamic header configuration (#128) Allow dynamic configuration of http headers through LDConfig.headerDelegate * [ch94946] Multi Environment Bug Fix: Decouple FlagStore from LDUser (#130) * Removed FlagStore from LDUser * All unit tests build and LDClientSpec doesn't crash * Fixed 1 unit test, removed unnecessary testing parameter in internalIdentify * Fixed 29 unit tests * Fixed 26 unit tests * Fix all but 4 unit tests * Removed comment * Addressed PR feedback * Removed unnecessary for each in LDUserSpec * Removed unnecessary contexts in LDUserSpec, removed user value in FlagChangeNotifierSpec * Fixed LDUserSpec context, added stub flags to DarklyServiceSpec * Make LDClientSpec init less hacky * Clear FlagStore if new user does not have cached flags, make flagStore a let * Added FlagStore back to LDUser for init from flag dictionary, check for user.flagStore on LDClient init and identify * Added deprecation comment to dictionary init for LDUser, prioritize LDUser FlagStore over cache in identify * Changed identify ordering back to cache over flagstore, made FlagStore a let * Bump version and CHANGELOG for 5.3.1 Co-authored-by: Gavin Whelan <[email protected]> Co-authored-by: Ben Woskow <[email protected]> Co-authored-by: Elliot <[email protected]>
* Reset lastKnownFlagValidity to nil when we make a successful stream connection * Made comment about lastKnownFlagValidity having a value more clear * Changed guard let to if let in DarklyService EventSource extension * Updated README, CHANGELOG, and podspec for 4.2.0 * [4.2.1] - 2019-11-15 (#81) * Added 4.2.1 changes including Dictionary fix and test and eventsource version bump * Added Carthage build files * Added attribution to CHANGELOG * Evaluation Reasons (#82) * Initial Evaluation Reasons prototype * Changed evaluationReasons to reasons, fixed mangled question mark in url query parameters * Added errorKinds * Added reason to debug events * Changed reason nil handling in events * Removed unnecessary private functions, removed event nil coalesce * Event change for reason nil * Removed if in Event for reason nil, added guard let NSNull for dictionary in Events * Added reason null to normal variation calls * Testing alternate reason null set * Change Event comparison code to add reason * Removed reason from event dictionary matches * Removed Event Equatable reason and changed Event Dictionary matches * Explicitly set featureflag reason property to nil when not send feature event for variationDetail * Fixed DeprecatedCacheModel unit tests, added v6 model tests, added variation detail unit tests, changed event reason nil check * Added variationDetail to objective c, fixed cache converter unit tests, deprecated variationAndSource * Added new files to correct target membership * Simplify featureflag reason nil check * Removed unnecessary comments, deprecated objc variationAndSource * Improved doc strings, cut down on variation doc string repetition, added reason tests for Event and EventReporter, added EvaluationDetail generic * Added ObjCEvaluationDetail to correct target membership * Differentiated objc evaluation detail return type, change reason constant in unit tests * Removed Optional value on fallback variation * Added Event test for reason false but flag reason present, cleaned up objc doc strings, changed optional types in objc evaluation detail * Experimentation 1.5 (#83) * Added trackReasons and metricValue as well as doc and unit tests * Added unit tests for reason false track reason true, added objc track without metricValue, changed and trackReason to or trackReason * Added explicit event store reason test * Fixed objc track comment * Updated reason to includeReason for clarity * Explicitly check both feature and debug events * Prepare version 4.3.0 * Update ios-eventsource to 4.1.0 (#84) * Updated ios-eventsource to 4.1.0, updated version strings * Added sentence about iOS SDK compat to CHANGELOG * pod repo update to get new eventsource version * Fixed change listener not firing when only value changes (#85) * Fixed change listener not firing when only value changes * Fixed a unit test variable name typo * Cast flag value to dictionary instead of string, improved unit test * Remove debug printout, remove unnecessary parameter * Updated CHANGELOG, README, and podspec for 4.3.2 * Adds startAwaitingFlags function (#86) * Added newStart function, updated README, podspec, and CHANGELOG * Changed newStart to startAwaitingFlags * Added doc strings for startAwaitingFlags and deprecated start * Added cocoapods lib lint flag to ignore depracted API usage in ObjCLDClient, added startAwaitingFlags to ObjC * Fixed alow to allow, changed startAwaitFlags to startCompleteWhenFlagsReceived, added unit tests for startCompleteWhenFlagsReceived * Updated deprecation message to startCompleteWhenFlagsReceived * [ch61092] Add X-LaunchDarkly-Payload-ID to event request headers (#87) * Added X-LaunchDarkly-Payload-ID header to event request headers, add string length check on LD payload ID header in header unit tests * Added CHANGELOG Added entry for event request header * Added UUID generation to DarklyService so it's regenerated on each request * Change CHANGELOG entry for new header to match other SDKs * Added single retry attempt to event post (#88) * Added single retry attempt to event post * Added payloadId to the correct point to maintain value between retries, retry on error * reportSyncComplete on 2nd error, always log on event post error, add 1 second delay with log on event post retry * Added 1 second delay to retry event post * async'd event post to prevent blocking main thread on retry sleep * Increased event test waitUntil timeout to 10 seconds * Bumped patch version, added CHANGELOG for 4.4.1 * Changed 4.4.1 entry * Further 4.4.1 entry revision * Changed retry event post for loop to function call (#89) * [ch65670] Fix Xcode 11.4 build and unit tests (#90) * Fixed build errors, fixed some unit tests * Added shell script to remove duplicate sourcery method mock * sed now matches specific pattern instead of line numbers * Add project config file containing run script step * Bump CircleCI Xcode to 11.4 * Bump CircleCI Xcode to 11.4.0 * Changed iPhone simulator in CircleCI from XS to Xs * Changed CircleCI xcodebuild from OS:latest to OS:12.4 * Testing NSURLRetryPolicy on CI * Removed DeprecatedCache from automock * Fix FlagStore to synchronize reads with writes. * multi env: init, config, client methods, and ObjCLDClient * Remove accidentally checked in IDE file * Add xcode compatibility information to readme (#93) * Add xcode compatibility information to readme (#93) * Fixed comments, added flush to close, started migrating unit tests * Added multi environment methods to ObjCLDClient, added better comments for said methods * Changed init completion behavior for correct ordering, removed deprecated variationAndSource methods, more unit test changes * Added primary instance to instances, fixed completion behavior * Made UserEnvironmentFlagCache shared between instances, made FlagSynchronizer DispatchQueue not static * Fixed user clobbering by deep copying FlagStore * Fix for concurrency bug exposed by restwrapper. (#94) * General cleanup. (#92) * [ch75316] Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache (#96) * Added maxCachedUsers to LDConfig and UserEnvironmentFlagCache * Changed specific -1 to 0 * Added unlimited users tests * Added CHANGELOG for 4.6 * Added maxCachedUsers to objc LDConfig (#97) * Changed version to 4.6.0 * [ch66864] Added startCompleteWhenFlagsReceivedTimeout (#98) * Added startCompleteWhenFlagsReceivedTimeout which allows a timeout in seconds to be given for the completion to be fired indicating that flags have been received * Fixed doc typo, removed bad ms to second conversion * Fix previous doc typo that got copied into objc * Added serial queue to timeOutCheck to fix possible race condition * Simplified unit tests by swapping if for assertion * Simplified start timeout method name, fixed doc about timedOut return * Moved DispatchQueue off of main * Moved sync dispatchqueue from variable to func * Changed labeled queue to global queue * Added test for start timeout timing out, added doc note about start timeout and starting offline * [ch70792] Swift EventSource (#99) * Integrating Swift eventsource. * No longer set `-sdk` on `xcodebuild` commands for circle. There seems to be some sort of interaction between `-sdk` or `SDKROOT` and the implicit dependency resolution system. Since Xcode 10.2, Xcode can find implicit dependencies in `OTHER_LINKER_FLAGS` such as when Cocoapods links a framework with `-F`. When `SDKROOT` is not set, this doesn't conflict with anything, but I believe the behavior of finding the framework as an implicit dependency is not required (I think it just resolves to the same target Cocoapods is building). If `SDKROOT` is set, xcodebuild seems to decide that it must first resolve and build the framework. It gives the warning "Multiple targets match implicit dependency for linker flags '-framework LDSwiftEventSource'", as LDSwiftEventSource generates a product by the same name (`LDSwiftEventSource.framework`) regardless of the platform/sdk being built. Now apparently it completely forgets about the set `SDKROOT` (which normally seems to be fed through and used to resolve the target being built) and decides that it should build the iOS target (no idea why, it's not even the default `SDKROOT` for `LDSwiftEventSource`). When `SDKROOT` is set to `macosx`, `xcodebuild` proceeds to simultaneously build both the iOS and macOS targets (I believe the macOS target is from Cocoapods operating correctly), then fails as it's still actually building the iOS target with the macOS SDK configuration. The actual build error is that the 'LDSwiftEventSource-iOS-umbrella.h' header can't find 'UIKit/UIKit.h' as UIKit is not available on macOS. * Update LDSwiftEventSource to 0.3.0, handle some minor todos. * This updates the circle config to actually do a `pod install`. Removes Gemfile that was for CocoaPods. * Specify sources for pod spec lint. * I think spec lint tries to test the spec file against code on the master branch, so only run a spec lint if commit is on master. * Allow warnings for now. * Bump version to 4.7.0 and add CHANGELOG * Changed startWaitSeconds type signature from Int to TimeInterval * Changed startWaitSeconds doc string type to TimeInterval * Clarified 4.7.0 CHANGELOG * Fixed no log output when isDebugMode = true * Fixed old EventSource still sticking around, removed default to fix compiler warning * Added startWaitSeconds to start, added more debug logging, added flagsynchronizer config.streamingMode * Fixed LDClient offline by putting internalIdentify in an async DispatchQueue, removed print statements * Unit tests build but LDClientSpec crashes * [ch72204] drop events after failed retry (#100) * Drop events after failed retry, as well as some general cleanup and consistency changes. * Don't disabled event reporting in background. * Added ClientServiceFactory back to init * Throttler mock isn't firing, migrating unit tests to TestContext init pattern * [ch61747] Diagnostic events (#101) * Start specs build and run but fail * Removed public set LDClient.config, added more failing specs, removed prints * Removed convenience init flagSynchronizer set to avoid malloc error, all but 2 LDClient specs build and run * All LDClient specs build and run * Fixed LDClient spec flagstore mock being replaced * Remove EventTrackingContext * Added config didSet back to init, removed outdated tests * Removed outdated tests for client not started, fixed some incorrectly ported tests * Fix more LDClient unit tests failures * Remove EventTrackingContext (#102) * Remove DeprecatedCacheModelV6, which was never needed. * A bit of cleanup. * Update some old comments. * Update diagnostic events to include count of secondary mobile keys. * Added waitUntil to internalIdentify calls to fix timing issue in some tests * Added setOnline for background tests, removed unnecessary runMode parameter on test start * set hasStarted false for starting tests * Fixed static timeOutCheck not being reset, trigger service didSet for pollingInterval tests * Added secondaryMobileKeys to ObjCLDConfig, change Array<String>? to [String]?, changed getEnvNames return, removed unnecessary returns in ClientServiceFactory, changed to internalSetOnline in close * Set instances to nil after loop in close * Remove UUID queue labels * Forgot empty FlagStore init * Added waitUntil to identify to fix Circle timing * Only internal ObjC methods can set the ObjCLDClient.ldClient * Moved all internalIdentify calls to waitUntil to fix Circle timing * Make config public private(set) * Added debug method to set config allUserAttributesPrivate * Make testing allUserAttributesPrivate method public * Move setAllUserAttributesPrivate to public * Attempted timing fix for Circle * Lowered timeout with troublesome test * Troublesome test false to true * Try synchronized instead of DispatchQueue.sync * Change sync queue and if ordering in start timeout * Forgot to add to testing version * Removed spurious changes from FlagSynchronizer and FlagStore * Try synced with if change start timeout * Changed setAllUserAttributesPrivate to apply to all instances, changed setOnline to internalSetOnline in configDidSet * Changed LDClient internal setOnline calls to internalSetOnline * Removed synced, added serial queues to identify and setonline * Removed true check in start timeout * Test removing serial queue from setOnline and identify * Change serial queues in setOnline and identify to sync * Move if outside sync serial queue in start timeout * Move if back inside serial queue but make queue async start timeout * remove static from internal method queues * Add secondaryMobileKeys to convertCacheData * Switched global to main queue in start timeout * Try name queue instead of main in start timeout * Remove internalIdentifyQueue * Changed named queue back to global, added back InternalIdentifyQueue, changed CircleCi simulator from iOS 12.4 to 13.4 * Change iOS 13.4 to 13.4.1 in Circle * Change iOS simulator from Xs to iPhone 11 Pro Max * Updating to iOS 13.4.1 on Circle fix disparity between DarklyServiceSpec on local vs Circle * Removed static from timeOutCheck and queue and made them function scope variables * Made main queues named queues in LDClientSpec * Explicitly turn off parallel testing on Circle * Added waitUntil with asyncAfter to setRunMode and background notification * Changed all asyncAfter deadlines to 0.2 * Passes thread sanitizer locally * More thread sanitizer finds * Fixed recursive sync queues in EventReporter and FlagSynchronizer * Improve Throttler code. * Hopefully fix sync queue crash in FlagChangeNotifier. * I don't think we actually want to loop through converting all environment cache data here. * changed internalIdentifyQueue to sync, added sync queue to internalSetOnline * PR feedback, removed convenience init * Fixed onSuccess tests * Removes isStarting variable, to make initialization more clear. * Removes all remaining LDFlagSource code. * Fix logging of type conversion errors. * Update more code doc for multi-environment branch changes. * Remove unnecessary objc class and improve interface for type mismatches on changed flag handlers. * Prefer `is` to `as != nil`. * Use DispatchGroup for static loops. * Make time constraint a bit more lenient for more reliable CircleCI tests. * Add a threshold for testing delay on throttler executions to prevent spurious test failures. * Replaced timeOutCheck with completed, simplified start test close, removed unnecessary string cast in LDConfig * Removed unnecessary nil check in start for tests * Removed unnecessary string cast in LDConfig, made waitUntil longer than start timeout * Fix after merge. * Change setUserSpec to identifySpec, fix doc strings * Remove internalInstances from LDClient, remove isOnlineQueue from DiagnosticReporter * Should improve LDClientSpec test runtime substantially. * 3 second for timeout seems a bit long even for circleci. * Update OHHTTPStubs for SwiftPM support. * Update DarklyServiceMock for changes in OHHTTPStubs 9.0.0 * Update DarklyServiceSpec for OHHTTPStubs 9.0.0 * Add explicit import for Foundation in tests. Make linter slightly more lienent and specify linted paths better. Fix mocks.stencil to allow specifying a defaultMockValue for an Optional type variable. Change default value for EnvironmentReporting.backgroundNotification and EnvironmentReporting.foregroundNotification to delegate to EnvironmentReporter to handle running tests on platforms without UIKit. Avoid using XCTFail. * Add initial SwiftPM Package.swift definition. Add SwiftPM build folder to .gitignore. Add missing Foundation import in LDClientSpec.swift. Comment out test that was previously disabled in the xcode test configuration, which SwiftPM doesn't use. * Use github reference for LDSwiftEventSource rather than local reference. * Try specifying ssh urls for dependencies in Package.swift as xcode is choking when adding the package. * Remove setAllUserAttributesPrivate public method * Changed ObjcLDClient to act as a wrapper instead of keeping an internal LDClient, updated doc strings * Fixed weird setOnline tests, fixed doc strings, added throws setter to secondaryMobileKeys, fixed ObjcLDClient * Fixed LDClient close tests, added getter setter doc strings for secondaryMobileKeys, removed commented out code in LDConfig, removed unnecessary setOnline method in ObjcLDClient * Fix doc strings in LDClient * Removed logs from throws in LDConfig * Added .swiftpm/ to .gitignore, removed all occurrences of fallback and replaced them with defaultValue (#111) * Added .swiftpm/ to .gitignore, removed all occurrences of fallback and replaced them with defaultValue * Change .swiftpm/ to /.swiftpm * Removed defaultValue value * Fix 2 typos * Updated SDK version and supported iOS and Xcode versions in README * Use Mint for tooling. * Update CONTRIBUTING.md Co-authored-by: Ben Woskow <[email protected]> * Add @objc annotation to start objc bridge methods. * (5.0) Use SwiftPM for SDK dependencies. (#114) * (5.0) Fix of crash when logging is enabled. (#115) Also removed unused test code. Improve documentation on LDClient.flush() * (5.0) Update installation instructions (#116) * (5.0) Changelog and some final removals and renames of public APIs (#117) Fix a bug with preventing the SDK from retrying eventsource connections when the service returns a 5XX error code. Renamed a couple of public APIs. Removed some publicly exposed implementation details. Updated CHANGELOG.md for 5.0. * [ch69438] Add ability to set additional headers on requests (#119) * A jazzy doc build and update lint configuration (#120) * [ch84954] Fix nested bundles in carthage build and missing dynamic library in SwiftPM build. (#121) * Focus week cleanup (#122) * [ch87108] Fix LDUser serialization to report redacted custom attributes in all cases (#123) * [ch87107] Add LDUser secondary attribute (#124) * [ch88282] Fix DiagnosticEvent build warnings on Xcode 12 (#125) * Update dependencies after release of Nimble 9.0.0 (#126) * Update doc comments for LDClient.identify (#127) * [ch91505] Dynamic header configuration (#128) Allow dynamic configuration of http headers through LDConfig.headerDelegate * [ch94946] Multi Environment Bug Fix: Decouple FlagStore from LDUser (#130) * Removed FlagStore from LDUser * All unit tests build and LDClientSpec doesn't crash * Fixed 1 unit test, removed unnecessary testing parameter in internalIdentify * Fixed 29 unit tests * Fixed 26 unit tests * Fix all but 4 unit tests * Removed comment * Addressed PR feedback * Removed unnecessary for each in LDUserSpec * Removed unnecessary contexts in LDUserSpec, removed user value in FlagChangeNotifierSpec * Fixed LDUserSpec context, added stub flags to DarklyServiceSpec * Make LDClientSpec init less hacky * Clear FlagStore if new user does not have cached flags, make flagStore a let * Added FlagStore back to LDUser for init from flag dictionary, check for user.flagStore on LDClient init and identify * Added deprecation comment to dictionary init for LDUser, prioritize LDUser FlagStore over cache in identify * Changed identify ordering back to cache over flagstore, made FlagStore a let * Bump version and CHANGELOG for 5.3.1 * Removed the guides link * Added sync queue boolean check on go completion (#131) * Update LDSwiftEventSource dependency (#132) * Correlate anonymous users (#129) * Clean up mock generation. (#133) * Remove extraneous comments. (#134) * Remove extraneous code for removing flag change observers (#135) * Non-nilable flags unchanged handler (#136) * Remove redundant args from LDClientSpec TestContext init calls (#137) * Delegate FlagMaintainingMock to FlagStore. (#138) * Remove redundant tests in LDClientSpec. (#139) * Clean up onSyncCompleteErrorSpec. (#140) * Separate transition to background tests from start tests. (#141) * Clean up observeSpec. (#142) * Improve allFlags spec. (#143) * Remove unused variation function of FlagStore. (#144) * Make service in LDClient immutable. (#145) * [ch98013] Rework the diagnostic reporter and add tests. (#146) * [ch61000] Add `isInitialized` method to the public API (#147) * Added isInitialized method and unit tests * Fix unit tests, stop double testContext.start * PR feedback * Remove returns doc * Avoid sending contextKind for non-anonymous users in feature and custom events. (#148) * Make `isInitialized` a property rather than a method. (#149) * Simplify Event Reporter (#150) * Cleanup flag store spec (#151) * Cleanup cache tests. (#152) * Added resetTimer to Throttler (#153) * Added resetTimer to Throttler * Fix race condition in access and then decrement/increment of runAttempts * PR feedback * Avoid potential issue with timer lifecycle. Co-authored-by: Gavin Whelan <[email protected]> * Prepare 5.4.1 patch release Co-authored-by: Gavin Whelan <[email protected]> Co-authored-by: Ben Woskow <[email protected]> Co-authored-by: Elliot <[email protected]>
What are these suggestions and what's the motivation?
We want to make this an even better client SDK and have a couple of suggestions to do so:
Software Engineering Best Practices
There is a well-known heuristic called the Law of Demeter that says a module should not know about the innards of the objects it manipulates. This means that an object should not expose its internal structure through accessors because to do so is to expose, rather than to hide, its internal structure. The accessors in
LDUserBuilder
ignore this principle and return a reference to the object itself eg.The API suggests the following usage:
or worse yet:
This usage has multiple problems. These methods should not invoke methods on objects that are returned by any of the allowed functions. This kind of code is often called a train wreck because it look like a bunch of coupled train cars. Chains of calls like this are generally considered to be sloppy style and should be avoided. It is usually best to split them up as follows:
Notice that in Swift,
user
can now be declared as alet
constant instead of avar
since we're no longer assigning to it.Better yet, these attributes can be declared as first-class properties. After all, the implementation barely sets the internal vars to the new values eg.
This has the added benefit of the code matching the documentation ie. a property mentioned as being optional is
nullable
.Cocoa Guidelines
While the code works, in places it does not conform to Cocoa guidelines.
as Objective-C runtime generates the ivars automatically.
->
eg. the below code is not Objective-C:It should be re-written as:
Or better yet using the
.
operator:get
,retrieve
etc as method names that return a property. The convention is to just use the property name eg.becomes:
becomes:
We believe that with the suggested changes, the SDK will become more modern and reliable.