These release notes show incremental updates to the BlueConic SDK for iOS, including the SDK version number, the date the update was released, and major changes or additions.
4.0.0 - December 15, 2024
Changed
Removed the requirement to add your hostname to the app's plist files. The SDK now requires to be initialized with a 'BlueConicConfiguration' object in the code via an 'initialize' function.
Reworked the SDK to require an initialization step before any other SDK functions can be called.
The SDK BlueConicEventFactory class is not available anymore. Instead, the BlueConicEventManager class can be retrieved from the SDK instance via the 'BlueConic.getInstance().getEventManager()' method.
Added
Dedicated functions for creating events that are sent to the BlueConic server for the 'PageView', 'Click', 'View', and 'Conversion' events. These functions can be called from the SDK instance.
Dedicated functions for publishing events for the 'ClickEvent', 'AdvancedEvent', 'FormSubmitEvent', 'UpdateContentEvent', and 'UpdateValuesEvent' events. These functions can be called from the BlueConicEventManager class.
Visit Listener plugin support.
Properties-Based Dialogue plugin support.
Ability to subscribe and unsubscribe to events via the BlueConicEventManager class. Currently, the supported events are related to the Properties-Based Dialogue plugin.
Ability to clear profile ID locally from the cache.
Optional callback information for a majority of the SDK functions.
Additional ability to connect to the BlueConic Simulator for testing purposes via the BlueConicConfiguration object when initializing the SDK.
Ability to set a custom app scheme instead of the default application bundle ID. This can be set via the BlueConicConfiguration object when initializing the SDK.
3.3.0 - June 12, 2024
Changed
Migrated SDK local file save location for enhanced security and added obfuscation to the file contents.
Added
Added support for timeline events in the SDK.
Fixed
Fixed minor issues with processing UI elements for Form Listeners.
3.2.0 - March 12, 2024
Added
Privacy Manifest as required by Apple Privacy Guidelines.
SDK Code signing.
3.1.0 - February 23, 2024
Added
Internal tracking for React Native usage
3.0.0 - October 26, 2023
Added
Support for Binary Framework
Support for Swift Package Manager
Changed
Updated minimum iOS version requirement to 12.
The main api class renamed from 'BlueConicClient' to 'BlueConic'.
2.9.0 - September 4, 2023
Added
Support for Swift 5.8.1
Fixed
Set (if empty) not setting values in Rule Based form listener.
Error on lightbox without content.
Order of plugin disposal/recreation after a page switch is incorrect.
2.8.10 - March 1, 2022
Added
Support for Swift 5.7.2
2.8.9 - June 7, 2022
Added
Support for Swift 5.6.1
Add increment method to BlueConic SDK for iOS.
Fixed
Sending information on deleted properties for RPC hash getProperties is not supported.
2.8.8 - November 24, 2021
Fixed
Set (if empty) not setting in Behavior Listener for Mobile SDK.
2.8.7 - September 27, 2021
Added
Support for Swift 5.5
Fixed
BlueConic SDK for iOS has a cache file that does not get cleared; slows the app down.
Clean up outdated files.
2.8.6 - May 3, 2021
Changed
BlueConic SDK for iOS creating a new profile for each pageview event. By setting bc_shared=false in the Info.plist a dedicated BlueConic cookie store is used.
Added
Support for Swift 5.4
2.8.5 - November 3, 2020
Changed
The logic in `setUrl` to only call `setHostname` when `debug` mode is `true` to avoid invalid URL as overrule hostname.
Fixed
Issue in the simulator mechanism to not overrule the hostname when `debug` mode is `false`.
2.8.4 - September 20, 2020
Added
Support for iOS 14
New method `setMobileAdId(mobileAdId)` that can be used to programmatically set the IDFA/ Mobile Advertising UID, to apply for the new rules regarding privacy, data tracking, and IDFA.
Removed
The `GlobalListener` will no longer auto-detect and set the IDFA/ Mobile Advertising UID. The profile properties "Mobile Ad Id (Most Recent)" `mobile_ad_id` & "Mobile Ad Id (all)" `mobile_ad_ids` are removed from this listener, and can be set/stored via the new method `setMobileAdId`.
2.8.3 - July 16, 2020
Fixed
A small issue in `EngagementService` where multiple items were stored with pipes (`|`) instead of separate values.
2.8.2 - June 16, 2020
Changed
BlueConicEventManager uses the BlueConic DispatchQueue.
Changed the GlobalListener to collect data without any `Context` to also support non-`ViewController` pages.
Added
Debug statements around connecting with the Simulator.
New method `setURL(url) -> Bool` to connect with the Simulator and retrieve a status `true` or `false` when the connection succeeded.
Fixed
Multithreading issues when registering Events via the `BlueConicEventManager`.
2.8.1 - April 27, 2020
Fixed
Process of `Segments` during a register of a `PAGEVIEW` event.
Support for callback methods, design for `ReactNative`-module.
2.8.0 - April 17, 2020
Changed
The internal property of the ViewController `context` to a `weak` variable, to avoid keeping a refers to this.
The `context` statement to be optional `PAGEVIEW` and/or custom events, can now trigger an event without the need of a `ViewController`.
Added
Support for Swift 5.2
New method `registerPluginClass :className` to register custom `BlueConicPlugin` classes, registering plugins and specify on class name.
New method `getSegments` retrieve all segments where the profile belongs to. BlueConic Segments are retrieved when there is a `PAGEVIEW` event created.
New method `hasSegment` validate if a profile is in a certain segment, based on Segment ID.
New method `createEvent :properties :completion` - Create event method with a callback/ completion mechanism to do follow up actions at the time BlueConic retrieved new data from the servers.
New method `createEvent :data :completion` - Create event method with a callback/ completion mechanism to do follow up actions at the time BlueConic retrieved new data from the servers.
New method `updateProfile` - Update the profile instantly push/ sync all profile property data with the profile on the BlueConic tenant.
New method `updateProfile :completion` - Update the profile method with callback/ completion mechanism to do follow up actions at the time BlueConic retrieve new profile data from the servers.
New method `getInstance` - Retrieve an instance without sending a ViewController along, improvement on the method calls `getInstance(nil)'.
New methods for `InteractionContext` to call within your `BlueConicPlugin`:
`getInteractionTypeId` The ID of the interaction type.
`getPluginType` The type of the plugin.
Extra accessibility for other (UI) Frameworks - not using `ViewController`s
Fixed
The issue for `addRefusedObjective` not pushing refused objectives.
Running background tasks on the main thread.
2.7.0 - February 17, 2020
Changed
The deprecated `UIWebView` to `WKWebView`.
Support for custom/ timeline events with context `createEvent`- custom events are now sent to BlueConic servers and could be used to store these events on the timeline.
Clear the events on `BlueConicClient` level when a `PAGEVIEW` event is called.
Execute all published `Events` after the `onLoad` of all plugins is called, so none of the published `Event`s are missing for these calls.
Moved `BlueConicEventFactory` and `BlueConicEventManager` from `Plugin`-directory to `BlueConicClient`. This is now part of the `main`.
Added
New privacy legislation methods `getPrivacyLegislation` and `setPrivacyLegislation`.
New Objectives getter methods `getConsentedObjectives`, `getRefusedObjectives`.
New Objectives setters methods `setConsentedObjectives`, `setRefusedObjectives`.
New Objectives adders methods `addConsentedObjective`, `addRefusedObjective`.
New method `isEnabled` and `setEnabled` to enable or disable the BlueConicClient SDK programmatically.
New method `registerPluginClass` to register custom `BlueConicPlugin` classes, registering plugins.
New method `createEvent: withData` that supports a map `[String: Any]`
New methods for `InteractionContext` to call within your `BlueConicPlugin`:
`getName` The name of the interaction
`getPluginType` The type of the plugin
`getPositionName` The name of the (channels) position
`getDialogueId` The ID of the dialogue ( Only used for `Action`s )
`getDialogueName` The Name of the dialogue ( Only used for `Action`s )
Fixed
Handle all events between `PAGEVIEW` event and the plugins `onLoad` method correctly.
Don't store the invalid value (`00000000-0000-0000-0000-000000000000`) to profile property `Mobile Ad ID`.
Crashes around registering plugin classes. Issue `objc_getClassList` when the parameter is not a `MutablePointer`.
Removed
All `cleanup`-event calls in `Listeners` this is no longer required this is no managed by `BlueConicClient` instead by the `BlueConicPlugin`s individually.