Skip to main content
Version: 10.13.x

Unity SDK Release Notes

Keep track of every change to the Unity SDK. This changelog lists all additions and updates to the Unity SDK, in chronological order.

DOWNLOAD RELEASES: Access to all releases including and after v10.5.0 are available on Big Fish's GitHub release repo ↗️.

note

The Unity SDK wraps the Native Android and Native iOS SDKs. To complete your upgrade, ensure that you follow the upgrade steps for the Unity SDK in addition to the upgrade steps detailed for each of the Native BFG SDKs you are using in your project.


10.13.0 (October 2, 2025)

  • Update Appsflyer to v6.17.5
  • Update RaveScenePack to v4.5.2

Upgrading to 10.13.0

Update bfg_config.json - No newsletter dialog on login
  • Add "BigFishSettings.UI.ShowNewsletterOptInPostLogin": false to remove Newsletter opt-in dialog after login.
warning

If the object BigFishSettings.UI.ShowNewsletterOptInPostLogin the post login Newsletter dialog will be shown.

Implementation

"rave": {
"RaveSettings.General.ApplicationID": "64b93a17c8a34486a4c2598945935c98",
"BigFishSettings.UI.ShowNewsletterOptInPostLogin": false,
"RaveSettings.Facebook.ReadPermissions" : "public_profile,email,user_friends",
"RaveSettings.Facebook.LimitedLoginTracking" : false
}

10.12.2 (August 5, 2025)

Overview

  • Rave ScenePack Updated
    Updated Rave Android and iOS ScenePack to version v4.5.0.

  • User Account Creation via SUSI Removed
    The ability to create a new user account through SUSI has been removed.

Important
This hotfix is built on top of the previous release. Before applying it, please follow the integration instructions from the initial release v10.12.0. Please make sure you include the following in the dependencies section of your build.gradle. Not including this will cause a crash when users log into Rave:

  • ''implementation(Libraries.preferences)''

Deprecations

Remove any usage of:

  • BigFishSettings.General.NewsletterName
  • presentNewsletterSignup
  • presentNewsletterSignupWithOrigin
Newsletter Opt-In Flow
  • The newsletter opt-in options have been updated Rave to provide more flexibility.

  • New APIs has been introduced through the BfgNewsletterWrapper class. These APIs allow games to:

    • Initialize the newsletter sub-system
    • Check if the user has already been asked to opt in to the newsletter
    • Show the newsletter opt-in dialog
  • It is the responsibility of game teams to be sure the user shared a valid email before showing the newsletter dialog.

  • It is the responsibility of game teams to handle the newsletter sign-up (e.g., using LeanPlum to register the user).

Note:
Since this feature is new, getNewsletterConsent will return Unknown for all users, even those who may have previously accepted or declined a newsletter prompt in your own implementation. It is up to the game team to find the best solution.

Initializing Newsletter

Before using any of the newsletter-related methods, the API must be initialized with the listener GameObject’s name and callback method name:

	BfgNewsletterWrapper.Initialize(string gameObject listener, string callback)

To get the current newsletter consent state, call:

	NewsletterConsentData newsletterConsentData = BfgNewsletterWrapper.GetNewsletterConsent()
	[Serializable]
public struct NewsletterConsentData
{
public string status;//Selected newsletter status
public string timestamp;// "yyyy-MM-dd'T'HH:mm:ss'Z'" timestamp of the momente of status change

public NewsletterConsentStatus GetStatus()
{
return Enum.TryParse(status, out NewsletterConsentStatus consentStatus) ? consentStatus : NewsletterConsentStatus.Unknown;
}
}
public enum NewsletterConsentStatus
{
Unknown, // The user has not been shown the newsletter dialog
Consented, // The user accepted the newsletter
Denied // The user declined the newsletter
}

Note:
If the user closes the dialog—either by clicking the "X" button or selecting "No, thanks"—the consent status will be set to Denied.

Showing the Newsletter Dialog Manually

There are two ways to show the newsletter consent screen:

  1. Automatically after login:
    If the user is logged out, the dialog will be shown after a successful login—provided that the users have shared their email. Only occurs for Facebook, Google and Apple auth.

  2. Manually by the game team:
    At any time (after initialization), the game team may trigger the dialog by calling:

    BfgNewsletterWrapper.ShowNewsletterConsentScreen()

Receiving User Selection

To listen for the user’s selection in the newsletter dialog, implement a callback method with the following signature:

void OnNewsletterConsentSelected(string consented)

Implementation

//Create a listener GameObject to listen to newsletter callbacks
private void Awake(){
BfgNewsletterWrapper.Initialize(gameObject.name, nameof(OnNewsletterConsentSelected));
}

//Triggered when newsletter opt-in dialog is closed
private void OnNewsletterConsentSelected(string consented){
Debug.Log($"Current newsletter consent state consented");
}

//Return the current newsletter consent state
public static void GetNewsletterConsent(){
Debug.Log($"Current newsletter consent state {BfgNewsletterWrapper.GetNewsletterConsent()}");
}

//Show newsletter opt-in dialog
public static void ShowNewsletterConsentScreen(){
BfgNewsletterWrapper.ShowNewsletterConsentScreen();
}

10.12.1 (July 17, 2025)

  • BigFishScenePack is reverted to previous version to include Rave Newsletter and SUSI Signup flows.
info
  • This hotfix is built on top of the previous release. Please follow the integration instructions from the initial release 10.12.0 before applying this hotfix.

  • The binaries for the release 10.12.0 have been removed and are no longer accessible. Please use only the binary provided with this hotfix, as it fully replaces the previous release.

  • The new Newsletter API introduced on 10.12.0 is not intended for use at this time. We recommend avoiding its use until further notice, as it may be updated or removed in a future release.


10.12.0 (July 14, 2025)

  • (Android) Rave is updated to v4.3.2-patch3.
  • (Android) CDN URL is updated to support https
  • New user account creation through SUSI has been removed
  • Newsletter opt-in flow is now supported by BFGSDK
  • Android target API is updated from 34 to 35
  • Google Play Billing Library is updated from 6 to 7.1.1

Upgrading to 10.12.0

Newsletter opt-in flow
warning

This flow is not intended for use at this time. We recommend avoiding its use until further notice, as it may be updated or removed in a future release.

  • The newsletter opt-in options has been removed from Rave, as it has been deprecated and not working for a long time.

  • A new set of newsletter APIs has been added via the new bfgNewsletter class. These APIs can be used to get whether the user has already been asked if they want to sign up for the newsletter, and then set whether the user accepted or declined the newsletter. Signing up for the newsletter and displaying a newsletter opt-in dialog is now the responsibility of game teams (for example, using LeanPlum to sign the user up for newsletters).

NOTE: Because this feature is new, getNewsletterConsent will return Unknown for all users, even if they have accepted or declined your newsletter implementation in the past.

warning

Deprecations

  • Remove any usage of BigFishSettings.General.NewsletterName setting.
  • Remove any usage of presentNewsletterSignup and presentNewsletterSignupWithOrigin APIs.

Implementation

NewsletterConsentStatus newsletterConsentStatus = BfgNewsletterWrapper.GetNewsletterConsent(); 
if (newsletterConsentStatus == NewsletterConsentStatus.Unknown)
{
if (bfgRave.isCurrentAuthenticated())
{
if (!string.IsNullOrEmpty(bfgRave.currentRaveEmail()))
{
Debug.Log("User never made a selection. Starting newsletter flow.");
_instance.ShowNewsletterDialog();
}
}
}
else
{
Debug.Log($"User made a selection before. User selection: {newsletterConsentStatus.ToString()}");
}
...
buttonConcent.onClick.AddListener(() => {
SaveNewsletterConsent(NewsletterConsentStatus.Consented);
});
buttonDeny.onClick.AddListener(() => {
SaveNewsletterConsent(NewsletterConsentStatus.Denied);
});
(Android) Rave Update

Update Rave to v4.3.2-patch3 to fix a crash on Android 6 devices.

Android Target API Update

Update Android Target API to 35

Google Play Billing Library Update

Update Google Play Billing Library to 7.1.1


10.11.0 (May 29, 2025)

[AppsFlyer Update] - AppsFlyer is updated to version 6.15.0

Upgrading to v10.11.0

iOS - Appsflyer Update

[AppsFlyer Update] - Please update AppsFlyerLib.xcframework

Android - Appsflyer Update

[AppsFlyer Update] - Update mainTemplate.gradle dependency com.appsflyer:af-android-sdk:6.4.1 to com.appsflyer:af-android-sdk:6.15.0


10.10.2 (May 02, 2025)

  • Rave updated to v4.3.2-patch2.
  • BigFishScenePack is updated to fix SUSI auth issue.

Upgrading to v10.10.2

iOS - BigFishScenePack Update
  1. Update BigFishScenePack.xcframework and BigFishScenePack.bundle.
Android - Gradle update
  1. Open mainTemplate.gradle and update Facebook version: implementation("com.facebook.android:facebook-android-sdk:18.0.2")
  2. Add the following dependency: implementation("androidx.preference:preference-ktx:1.2.1")
  3. Update the following files:
  • bfgLib-debug.aar
  • bfgLib-release.aar
  • RaveFacebookPlugin.aar
  • RaveGooglePlugin.aar
  • RaveSocial.aar
  • RaveUtils.aar
  • XMLScene.aar

10.10.1 (March 14, 2025)

  • Implemented reportUserAcquisitionEvent in bfgGameReporting on Android to log custom events to AppsFlyer, and make this a public function.

Upgrading to v10.10.1

Update mainGradleTemplate file

To update mainGradleTemplate:

MainGradleTemplate will be automatically updated by ExternalDependencyManager


10.10.0 (February 27, 2025)

  • Updated Native Android SDK to 8.10.0, which includes updates to 3rd party libraries.
  • Updated Native iOS SDK to 8.8.0, which includes Xcode 16.2 compatibility.
  • Added Xcode 16.2 compatibility.
  • Updated minimum iOS version to v13.
  • Updated Rave to v 4.3.3.
  • Updated BigFishScenePack with Rave v4.3.3.
  • Updated Unity 3D to v2022.3.31f1.
  • Updated OpenSSL to v3.3.2000.

Upgrading to v10.10.0

Updating the XCFrameworks

To upgrade to v10.10.0, update the following XCFrameworks:

  • Rave: Replace RaveSocial.xcframework with the new version.
  • OpenSSL: Replace openssl.xcframework with the new version.
  • BigFishScenePack: Replace BigFishScenePack.xcframework with the new version.
(Android) Update Rave

To update Rave, navigate to Rave Android 4.3.0 Release to download and integrate Rave v4.3.0 to your game.


10.9.1 (September 27, 2024)

warning

If you upgrade to v10.9.1, you are required to add the URL cdn-f2p.bigfishgames.com to your Exception Domains in your info.plist file. If you do not make this change, the delta will not work.

  • No updates were made to the Native Android SDK in this release.
  • Updated the Native iOS SDK to v8.7.1, which includes the removal of Akamai URL.
  • (iOS) Replaced harcoded Akamai URL from the SDK with cdn-f2p.bigfishgames.com.
  • Updated OpenSSL to v3.1.5001.
  • Fixed the broken symlinks issue by updating the copying process of libraries. The symlinks inside the signed frameworks were breaking during the copying process of libraries, which caused a signature error in the exported Xcode project.

Upgrading to v10.9.1

Replacing the Akamai URL

To replace the Akamai URL:

  1. Navigate to your Exception Domains in your Info.plist file.
  2. Add cdn-f2p.bigfishgames.com to your exceptions.

The SDK now uses cdn-f2p.bigfishgames.com instead of the Akamai URL to get the current real-world time. The URL is now configurable in the bfg_config.json file. This was primarily done for future-proofing. Configuring the URL is optional, and will default to using the recommended cdn-f2p.bigfishgames.com URL.

If you need to customize your TimeStamp URL, follow the guidelines below:

  • The time stamp URL has the current time in its response header with the 'Date' key.
  • Add the time stamp URL to your exception domains list if it is not a secure (http) URL.
  • Add the following code into your bfg_config.json file with your custom URL value for the key "time_stamp_url".
"time_stamp": {
"time_stamp_url": "http://yourcustomtimestampurl.com"
}
Updating OpenSLL

Replace the openssl.xcframework with the new version.


10.9.0 (August 20, 2024)

warning

The v10.9.0 has a critical bug that has been fixed in the v10.9.1 release. Do not upgrade to this version.

If you have already upgraded to v10.9.0, you are required to upgrade to v10.9.1.

  • Updated the Native Android SDK to v8.9.0, which includes updates to 3rd party libraries.
  • Updated the Native iOS SDK to v8.7.0, which includes support for arm64 simulator architecture.
  • (iOS) Updated BigFishScenePack to resolve an error in the Facebook login flow.

Upgrading to v10.9.0

(iOS) Update BigFishScenePack

Replace the BigFishScenePack.xcframework with the new version.


10.8.1 (June 06, 2024)

  • No updates were made to the Native Android SDK in this release.
  • Updated the Native iOS SDK to v8.6.1, which includes bug fixes.
  • Updated BigFishScenePack to resolve an unexpected error.

Upgrading to v10.8.1

Update BigFishScenePack (iOS only)
  1. Replace the BigFishScenePack.xcframework with the new version.
  2. Replace the BigFishScenePack.bundle with the new version.

10.8.0 (May 21, 2024)

  • Updated the Native Android SDK to v8.8.0, which includes an update to Google Play Billing Library.
  • Updated the Native iOS SDK to v8.6.0, which includes updates to 3rd party libraries.
  • Updated Facebook Unity SDK for iOS to v17.0.1.
  • Fixed a Unity SDK application crash from Unity 2022.3.17 LTS+ due to a missing static method.
  • Fixed a bug where Success purchases generated exceptions.

Upgrading to v10.8.0

info

If your xcworkspace file is not generated after a Unity iOS build, make sure you run the pod install command for the exported Xcode project.

Update the Facebook SDK

Update the value of facebookClientToken in the iOSBuildConfig.json file with the value found under Settings > Advanced > Client Token in the Facebook App Dashboard.

Since the BFG SDK now uses the Facebook SDKs as pod dependencies, remove the following Facebook frameworks from the folder, com.bfg.sdk/Runtime/Plugins/iOS/Extras~/XCFrameworks/Dynamic

  • FBAEMKit.xcframework
  • FBSDKCoreKit_Basics.xcframework
  • FBSDKCoreKit.xcframework
  • FBSDKLoginKit.xcframework
  • FBSDKShareKit.xcframework

10.7.1 (March 29, 2024)

  • Updated the Native Android SDK to v8.7.0, which includes an update to the Rave SDK.
  • No updates were made to the Native iOS SDK in this release.
  • Updated the Firebase Unity SDK to v11.6.0 to support Android API 34.
  • Android Billing: Removed deprecated methods bfgPurchaseAndroid.startUsingService() and bfgPurchase.startService() as they are no longer required for initialization of the billing service. The method bfgPurchaseAndroid.setupService() should be used to initialize Android purchasing.
  • Android Manifest: A custom AndroidManifest.xml file can now be placed directly in the Assets/Plugins/Android folder without build errors and file deletion. The path to it can specified in the Build Settings option of the BFG menu in Unity.

10.7.0 (March 22, 2024)

  • No updates were made to the Native Android SDK in this release.
  • Updated the Native iOS SDK to v8.5.0, which includes the Privacy Manifest file.
  • Firebase Analytics: The Unity iOS SDK will automatically enable and disable the setting based on the user's GDPR selection.
  • Unity Sample App: Added the priceString field to the ProductInfo class of the APurchaseController file in the Unity Sample App to demonstrate the usage of localized price strings on iOS devices.
  • Removed deprecation warnings from bfgGameReporting.logCustomEvent() methods. These methods are still the preferred way of sending custom events.

Upgrading to v10.7.0

Remove calls to Firebase Analytics

Remove any manual calls to FirebaseAnalytics.SetAnalyticsCollectionEnabled(bool) within your Unity project. These calls are no longer needed because Firebase Analytics will automatically enable and disable the setting based on the user's GDPR selection.


10.6.1 (Feb 15, 2024)

  • Updated the Native Android SDK to v8.6.1, which includes a fix for the standalone newsletter sign-up.
  • Updated the Native iOS SDK to v8.4.1, which includes a fix for the standalone newsletter sign-up.
  • Updated libraries to include bug fixes in iOS and Android.

10.6.0 (Jan 09, 2024)

  • Updated the Native Android SDK to v8.6.0, which includes an update to the Facebook SDK.
  • Updated the Native iOS SDK to v8.4.0, which includes an update to the Zendesk SDK.
  • Unity Update: Updated to Unity v2022.3.10 LTS which includes an update to Gradle v7.1.2. Additionally, updated the Sample App to support the new version of Unity.
  • UPM Integration: Added the ability to integrate or upgrade the Unity SDK using the “Add package from tarball” Unity Package Manager option.
  • Added Newsletter Opt-In checkbox for all localities and text updates for the checkbox and policies.
  • iOS Updated to Zendesk v7.0 for chatbot support.

Upgrading to v10.6.0

Update to Unity v2022.3.10 LTS

With the update to Unity v2022.3.10 LTS, the minimum requirements are now:

  • iOS v12
  • Java v11
  • Gradle v7.1.2
  • Android Studio Bumblebee v2021.1.1+

Update Gradle by setting the two new gradle files, baseProjectTemplate.gradle and settingsTemplate.gradle, in the Android Player Settings.

Update Unity Sample App

Overwrite the modified files in your project’s /Assets/Plugins/Android/ folder with the files in the BfgUnitySdkSample-2022.3.10/Assets/Plugins/Android/ folder and re-apply any changes your team also made to those files. Additionally, add the two new gradle files as "Custom Base Gradle Template" and "Custom Gradle Settings Template" in the Android Player Settings.

Update for UPM Integration
  1. Download unity-sdk-10.6.0.tgz from Big Fish’s GitHub release repo ↗️.
  2. Extract the contents of the downloaded file, unity-sdk-10.6.0.tgz.
  3. Open the extracted contents and locate the file, unity-sdk-10.6.0-upm.tgz.
  4. Copy the file unity-sdk-10.6.0-upm.tgz to a location on your machine where you would like Unity to import it from.
  5. Open Unity and navigate to Window > Package Manager.
  6. In the Package Manager window, click the + button in the upper-left corner.
  7. Select Add package from tarball and select the Unity SDK tarball file you copied earlier. Unity will automatically re-import it and compile once selected.
  8. Navigate to your Packages list. You will see [BFG] SDK in your Packages list, pointing to the version you downloaded.
(iOS) Update Zendesk Version

Remove the existing Zendesk xcframework files from your project and replace them with the frameworks found in/frameworks/ThirdParty/Zendesk/*. It's no longer necessary to strip architectures before submitting your game to the App Store.

(iOS) Update to support Newsletter Opt-In

Update your /Frameworks/ThirdParty/RaveSocial.xcframework and /Frameworks/Resources/BigFishScenePack.bundle or the entire com.bfg.sdk package with the files from the release.


10.5.0 (Sept 26, 2023)

  • Updated the Native Android SDK to v8.5.0, which adds support for Google Billing 6.
  • Updated the Native iOS SDK to v8.3.0, which includes minor updates to the iOS Sample App.
  • Updated Google Billing libraries to v6.0.1.
  • Hardened purchasing for null product properties in iOS.

Upgrading to v10.5.0

(Android) Update to Google Billing v6

To update Google Billing to v6.0.1, update the Google billing version in the mainTemplate.gradle file to 6.0.1:

dependencies {    
implementation 'com.android.billingclient:billing:6.0.1'
}

10.4.0 (June 23, 2023)

  • Updated the Native Android SDK to v8.4.0, which adds support for Google Billing 5.
  • Updated the Native iOS SDK to v8.2.0, which updates the Facebook SDK.
  • Updated Google Billing version to v5.0.0.
  • Updated the Unity iOS Facebook SDK to v11.2.1. Facebook Graph API v10 will be deprecated at the end of June 2023.
  • Added a new SDK component PersistentUnityMessageHandler, which is used to receive Unity SDK notifications across all Unity scenes. Prior to this release, developers used the UnityMessageHandler component to every scene individually.
  • Added DisableBitcode.cs post-build step to the Unity Sample App in response to Xcode 14 ending support for the BITCODE_ENABLED option.
  • Fixed a typo in the BFG SDK notification variable bfgCommon.NOTIFICATION_PURCHASE_SUCCEEDED_WITH_RECEIPT. This typo caused purchase data, including the purchase receipt, to not be passed into Unity observers of bfgCommon.NOTIFICATION_PURCHASE_SUCCEEDED_WITH_RECEIPT. Refer to GooglePurchaseController.cs in the Unity Sample App for usage of NOTIFICATION_PURCHASE_SUCCEEDED_WITH_RECEIPT.

Upgrading to v10.4.0

Update Facebook Graph Version

Facebook Graph API v10 will be deprecated at the end of June 2023.

  1. Update the version used in any calls to the Facebook Graph API for your app.
  2. Update the version used in the Facebook dashboard under Settings > Advanced > Update API Version.
Update to PersistentUnityMessageHandler

To use the new PersistentUnityMessageHandler:

  1. Remove all instances of the UnityMessageHandler component usage from all Unity scenes in your app.
  2. Inside your init/bootstrap scene, create a new GameObject and add the PersistentUnityMessageHandler component to it.

The UnityMessageHandler component, which actually handles processing the notifications and calling your listeners in Unity, will automatically be added next to the PersistentUnityMessageHandler component in your GameObject.

(Android) Update to Google Billing v5

To update Google Billing to v5.0.0, update the Google billing version in the mainTemplate.gradle file to 5.0.0:

dependencies {    
implementation 'com.android.billingclient:billing:5.0.0'
}
(iOS) Update Facebook SDK

To update the Facebook SDK for iOS targets:

  1. Remove the following frameworks from your project:
    • FBSDKCoreKit.framework
    • FBSDKLoginKit.framework
    • FBSDKShareKit.framework
  2. Replace the removed frameworks with their xcframework files found in com.bfg.sdk/Runtime/Plugins/iOS/Extras~/XCFrameworks/Dynamic.
  3. Add FBAEMKit.xcframework and FBSDKCoreKit_Basics.xcframework from the same directory.
  4. In the Unity Editor, navigate to General > Frameworks & Libraries and set each of the xcframeworks above to ‘Embed and sign’.

10.3.0 (Apr 6, 2023)

  • Updated the Native Android SDK to v8.3.0, which includes minor bug fixes.
  • Updated the Native iOS SDK to v8.1.0, which includes updates to AppsFlyer, Zendesk, and the minimum iOS version.
  • iOS Updated the Sample App to disable bitcode for iOS in a Unity project. Apps submitted to the Apps Store as of April 2023 must be built in Xcode 14 with bitcode disabled. The updated sample project can be found in Samples/BfgUnitySdkSample-2021.3.9/Assets/Scripts/Editor/DisableBitcode.cs.

Upgrading to v10.3.0

(iOS) Update to Xcode 14

Apps submitted to the Apps Store as of April 2023 must be built in Xcode 14 with bitcode disabled. After updating to Xcode 14, ensure you disable bitcode:

  1. In Xcode, open Build Settings.
  2. Search for ‘bitcode’ and set Bitcode Enabled to "NO" for your project and targets.

This does not impact dependencies.

(iOS) Update AppsFlyer

Remove AppsFlyerLib.xcframework from your project and replace it with the new version found in the framework/ThirdParty directory.

The AppsFlyerLib.xcframework is found in com.bfg.sdk/Runtime/Plugins/iOS/Extras~/XCFrameworks/Dynamic

(iOS) Update Zendesk
  1. Remove the reference to the strip-architectures script from your Build Phases > Run Script that points to the old Zendesk frameworks.
  2. Change the minimum SDK version to 11 under the General tab.
  3. Remove the following old Zendesk frameworks from your project:
    • CommonUISDK.framework
    • ZendeskCoreSDK.framework
    • ZendeskProviderSDK.framework
    • ZendeskSDK.framework
  4. Add the following new xcframeworks from the distribution framework/ThirdParty/Zendesk directory to your project:
    • CommonUISDK.xcframework
    • MessagingAPI.xcframework
    • MessagingSDK.xcframework
    • SDKConfigurations.xcframework
    • SupportProvidersSDK.xcframework
    • SupportSDK.xcframework
    • ZendeskCoreSDK.xcframework
  5. Go to General > Frameworks & Libraries to set each of the xcframeworks above to "Embed and sign".

The Zendesk xcframework files are found in com.bfg.sdk/Runtime/Plugins/iOS/Extras~/XCFrameworks/Dynamic


10.2.0 (Nov 23, 2022)

  • Updated the Native Android SDK to v8.2.0, which includes an update to Zendesk.
  • Updated the Native iOS SDK to v8.0.0, which includes minor bug fixes.
  • Unity Sample App: Updated the Big Fish Unity Sample to run on LTS Unity 2021.3.9f1. Older versions of the Unity sample app are removed.
  • Added LTS Unity 2021.3.9f1 support. LTS Unity can be downloaded from here using the Unity Hub install option.
  • (Android) Updated minimum Android SDK to v22. NOTE: If you’re updating to Unity 2021 then the minimum Android SDK is v22. If you are on Unity 2020 or earlier, the minimum Android SDK remains v21.
  • Updated the Unity SDK to encrypt the config file, bfg_config.json file during post-build. The file, bfg_config_encrypted is added to the exported project, and the SDK will load the encrypted config if available. The config file, bfg_config.json can be removed if desired for security reasons. If the encrypted file is removed, the SDK will fall back and use the plain text version instead.
  • Fixed a crash in the Unity SDK that occurs when attempting to purchase using a null productId.
  • (Android) Added support for the latest Android Studio versions Chipmunk and Dolphin.
  • (Android) Built Native Android plugin with Gradle v6.5.1 to align more with the Unity toolchain requirements (unity 2021.3.9f1 requires min version 6.1.1).
  • (iOS) Updated Unity SDK hardware strings and device common names for the latest iOS devices.
  • (iOS) Investigated compatibility with newer Apple M1 chips. Due to 3rd party dependencies, apps built with Apple M1 chips need to disable bitcode.

Upgrading to v10.2.0

(Android) Upgrade Zendesk and minSdkVersion

To update Zendesk and the minimum SDK version:

  1. Open the ProjectSettings.asset file through Unity Player Settings.
  2. Navigate to the “Other Settings” drop-down.
  3. Update the minimum SDK.API version to 22.
  4. Open the project manifest file, AndroidManifest.xml file and add the following code:
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
<uses-permission android:name="android.permission.READ_MEDIA_VIDEO" />
  1. Open your mainTemplate.gradle file and add/update the following dependencies:
dependencies {
implementation group: 'com.zendesk', name: 'support', version: '5.1.0'
implementation 'com.zendesk.belvedere2:belvedere:3.0.5'
}
(Android) Resolve android:screenOrientation errors

To resolve an error referring to android:screenOrientation when building your app:

  1. Open your project's launcher manifest file, LauncherManifest.xml.
  2. Find the <Activity> tag and add the following:
tools:replace="android:screenOrientation"
  1. Open your project's gradle file, mainTemplate.gradle.
  2. Add the following line to the very bottom of your gradle file when using IL2CPP as your scripting backend:
**IL_CPP_BUILD_SETUP**

10.1.0 (Aug 25, 2022)

  • Updated Native Android SDK to v8.1.0, which adds support for Google Billing 4 and Android 13.
  • Updated Unity (iOS & Android) SDK Firebase Crashlytics and Analytics to v9.3.0 to keep the SDK and game teams up-to-date with the latest changes and fixes.
  • Fixed the following warning when building an exported Unity-Android gradle project in Android Studio: “The option setting 'android.enableR8=false' is deprecated”.
  • Updated com.google.gms:google-services:4.3.0 to com.google.gms:google-services:4.3.2 in launcherTemplate.gradle to fix the following warning in Android Studio:
”WARNING: API 'variant.getMergeResources()' is obsolete and has been replaced with 'variant.getMergeResourcesProvider()'“.
  • Added encryption of the bfg_config.json file during post build.

Upgrading to v10.1.0

Update Firebase Crashlytics and Analytics
  1. Remove all current Crashlytics and Analytics 7.0.1 folders from your Unity Project
  2. Remove all external-dependency-manager@1.2.162 folders from your Unity Project
info

external-dependency-manager@1.2.172 is required for the Crashlytics and Analytics updates and will be installed automatically when either the updated Crashlytics or Analytics 9.3.0 .unitypackage is installed.

  1. Download the Crashlytics 9.3.0 ↗️ unitypackage.
  2. Download the [Analytics 9.3.0(https://dl.google.com/firebase/sdk/unity/dotnet4/FirebaseAnalytics_9.3.0.unitypackage) ↗️ unitypackage.
  3. Install Crashlytics and Analytics 9.3.0 into your Unity app using the Assets > Import Package > Custom Package menu.
info

The Google Dependency Manager will try to resolve the installation. If it fails to do so or you experience issues, you can try forcing the resolution using the Unity menu: Assets > External Dependency Manager > Android Resolver > Force Resolve.

If you run into a CocoaPods compatibility error, you will need to update your Cocoapods to the version the error mentions before building.

(Android) Upgrade to Android 13 support

Update the Target API Level value to 33 in your Unity Project in the Android Player Settings.

(Android) Fix API warning errors

Update your project's gradle file, mainTemplate.gradle file with the following in order to resolve the warning: “WARNING: API 'variant.getMergeResources()' is obsolete and has been replaced with 'variant.getMergeResourcesProvider()' “.

dependencies {
classpath 'com.google.gms:google-services:4.3.2'
}
Configure bfg_config.json encryption

The file bfg_config_encrypted is added to the exported project, and the SDK will load the encrypted config if available. The bfg_config.json can be removed if desired for security reasons. If the bfg_config_encrypted file is removed, the SDK will fall back and use the plain text bfg_config.json file.


10.0.0 (July 25, 2022)

  • Updated the Native Android SDK to v8.0.0, which adds support for Android 12 / API 31.
  • Updated the Native iOS SDK to v7.7.2, which adds the ability to configure AppsFlyer via the bfg_config.json file.
  • Added Android 12 (API 31) support.
  • Added LTS Unity 2020.3.32f1 support.
  • Updated the Big Fish Unity Sample to run on LTS Unity 2020.3.32f1. The updated sample is now named BfgUnitySdkSample-2020.3.32.
  • Added the ability to configure AppsFlyer dev key may now be configured from bfg_config.json.
  • Expanded bfgRave.sharedInstance().requestAccountDeletion() method to support deletion of non-authenticated (“guest”) Rave accounts.
  • Removed the FailedForAuth notification.
  • Removed BfgUnitySdkSample-2019.4-unsupported sample project.

Upgrading to v10.0.0

(Android) Update versionCode in Gradle file

Update the versionCode in your build.gradle file to [10.0.0]. If you fail to update the version code, you will receive the following error:

Rave Socialization Error

Required Rave Setting
"ravesettings.general.serveurl" is not set
(Android) Upgrade targetSDKVersion in Gradle file

Update the targetSdkVersion and compileSdkVersion to 31 in your project's gradle file, build.gradle as follows:

compileSdkVersion 31

defaultConfig {
minSdkVersion 16
targetSdkVersion 31
}
(Android) Update 3rd Party Dependencies

Update the 3rd party dependencies in your project's gradle file and gradle properties file to fix an incompatibility with the current Facebook SDK version and Android 12.

  1. Make the following updates to the dependencies section of your project's gradle file, build.gradle:
classpath 'com.android.tools.build:gradle:4.0.0'
implementation 'com.facebook.android:facebook-android-sdk:12.3.0'
implementation 'com.squareup.moshi:moshi:1.12.0'
ext.kotlin_version = '1.5.10'
  1. Make the following updates to your gradle properties file, gradle-wrapper.properties:
distributionUrl=https\://services.gradle.org/distributions/gradle-6.1.1-all.zip

Note: If you compile in release mode and get the following error: Invoke-customs are only supported starting with android 0 --min-api 26 ↗️, the cause is most likely due to the Kotlin update. This problem can be fixed by adding the following to your build.gradle file:

android {
lintOptions {
abortOnError false
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
Update the Moshi plugin

Updating the JSON plugin called Moshi is required. After upgrading your app, this update introduced an issue with how the SDK handles auto-loading and caching config files, specifically for Rave initialization.

Note: Fresh app installs do not have this issue.

(Android) Set android:exported values to "true"

Set the android:exported="true/false" flag in all activity, service, and receiver tags to "true":

<activity
android:name=".MainActivity"
android:label="@string/app_name"
android:launchMode="singleTask"
android:theme="@style/BFG.Material.DarkActionBar.Fullscreen"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>

</activity>
warning

If you set the value to "false" in your main activity, your app will not launch.

Remove FailedForAuth notification code

If you are gating account deletion on users currently logged into a Rave-based account, you need to remove this gate. Rave creates and tracks “guest” account information for users who aren’t logged in, which must be removed when an account deletion request is made. Any code that depends on the FailedForAuth notification will no longer be called. We recommend that you either remove or re-write any required code that depends on the FailedForAuth notification.


9.6.1 (June 8, 2022)

  • Updated Native iOS SDK to v7.7.1, which contains an account deletion hot fix. To comply with Apple account deletion policy, requestAccountDeletion() has been expanded to handle unauthenticated (guest) accounts.
  • Removed the FailedForAuth notification, and any code that depends on this will no longer be called. We recommend that you either remove or re-write any required code that depends on the FailedForAuth notification being sent from iOS to Unity.

9.6.0 (May 13, 2022)

  • Updated Native Android SDK to v7.8.0, which removes the Cross Sell functionality from the BFG SDK.
  • Updated Native iOS SDK to v7.7.0, which removes the Cross Sell functionality from the BFG SDK.
  • Removed the Cross Sell button from the Unity Sample App. This completes the removal of all Cross Sell functionality. If you have any remaining Cross Sell Button logic or UI in your project, you will need to remove it.
  • Added Android functionality to access the user’s current Rave email address using bfgRave.currentRaveEmail().

9.5.0 (Feb 28, 2022)

  • Updated Native Android SDK to v7.7.0, which adds support for Account Deletion on Android mobile devices.
  • Updated Native iOS SDK to v7.6.0, which adds support for Promoted In-App Purchases and updates iOS AppsFlyer.
  • Android Account Deletion: Added a new wrapper method bfgRave.sharedInstance().requestAccountDeletion(). This method will send a Zendesk support request including the current rave id to Customer Service for processing. One of the following NSNotifications will be received from this method: BFG_RAVE_ACCOUNT_DELETION_REQUEST_SUCCEEDED or BFG_RAVE_ACCOUNT_DELETION_REQUEST_FAILED.
  • iOS Promoted In-App Purchases: Added two new wrapper methods to support promoted in-app purchases. Use bfgPurchase.hasDeferredPayments() to determine if there are Promoted In-App Purchases to queue and bfgPurchase.processDeferredPayments() to process queued Promoted In-App Purchases.

9.4.1 (Jan 4, 2022)

This release adds support for iOS Account Deletion on iOS mobile devices to support privacy requirements effective June 30th, 2022. An Android version will come in a future release as it is not a requirement by the Google Play Store (yet).

This release contains the following changes:

  • Updated Native iOS SDK to v7.5.1, which adds support for Account Deletion on iOS mobile devices.
  • iOS Account Deletion: Added new wrapper method bfgRave.requestAccountDeletion(). This method will send a Zendesk support request including the current rave id to Customer Service for processing. One of the following NSNotifications will be received from this method: BFG_RAVE_ACCOUNT_DELETION_REQUEST_SUCCEEDED or BFG_RAVE_ACCOUNT_DELETION_REQUEST_FAILED.

9.4.0 (Nov 18, 2021)

  • Updated Native Android SDK to v7.6.0, which addresses the JCenter deprecation.
  • Updated Native iOS SDK to v7.5.0, which fixes a display issue in Zendesk.
  • (Android) Fixed the method bfgPurchaseAndroid.finishPurchase() to correctly be called for non-consumables on purchase completion.
  • (Android) Removed the "Re Enable Non-Consumable" button and command from the sample application because no automatic mechanism for this exists on Google's end. If you need to re-enable a non-consumable purchase:
    • Make the purchase of the non-consumable product, change it to a consumable product, refund it through the Google Play Console, then finally change it back to a non-consumable product.
  • (Android) Added missing SDK localization for DE, NL, JA, KR, ES, FR, PT-BR, ZH-CN, ZH-TW, RU, and IT.
  • (Android) Added missing Google and Amazon purchasing event handlers to the Sample App.

9.3.2 (Oct 25, 2021)

This release updates the Native Android SDK to v7.5.1, which addresses missing localization strings.


9.3.1 (Oct 19, 2021)

  • (Android) Fixed a bug in v9.3.0, where MTS incorrectly reported the BFG Android SDK build version
warning

If you upgraded to v9.3.0, you are required to upgrade to v9.3.1. To do so, simply replace your Android .aar with the 9.3.1 .aar to get the version number update.


9.3.0 (Oct 14, 2021)

This version adds compatibility to Android 11/API 30 ↗️. Games will need to be compatible with Android 11 / API 30 starting November 1, 2021 if you want to be able to post updates to Google Play Store moving forward.

This release includes the following changes:

  • Updated Native Android SDK to v7.5.0, which adds Android 11 / API 30 compatibility.
  • Updated Native iOS SDK to v7.4.0, which adds iOS 15 compatibility.
  • Android 11 / API 30 compatibility check: The Unity SDK is compatible with Android 11 / API 30.
  • iOS 15 compatibility check: The Unity SDK is compatible with iOS version 15.
  • (iOS) The "bfgsdkunity" URI scheme is no longer erroneously included in the built Xcode project's Info.plist for external teams when using the SDK post-process build system.
  • Removed all references to the Age Gate functionality as it has been deprecated.

9.2.1 (Sept 29, 2021)

(Android) Fixed a bug in v9.2.0, where MTS incorrectly reported the BFG Android SDK build version.

warning

If you upgraded to v9.2.0, you are required to upgrade to v9.2.1. To do so, simply replace your Android .aar with the 9.2.1 .aar to get the version number update.


9.2.0 (Sept 24, 2021)

  • Updated Native Android SDK to v7.4.0, which includes minor bug fixes.
  • Updated Native iOS SDK to v7.3.0, which includes minor bug fixes.
  • Deprecated BfgUnitySdkSample-2019.4 and renamed to BfgUnitySdkSample-2019.4-unsupported.
  • Removed BfgUnitySdkSample-2019.2 which will no longer be supported.
  • Added BfgUnitySdkSample-2020.3 built off of Unity 2020.3.3f1 LTS. Using Unity 2020+ will require you to set iOS 11 as the minimum iOS version within Unity "Player Settings".

9.1.0 (Aug 24, 2021)

  • Updated Native Android SDK to v7.3.0, which includes required updates to Android billing.
  • Updated Native iOS SDK to v7.2.5, which includes minor bug fixes.
  • Adds the GetAllAuthSources API to BfgRaveUtilities to retrieve auth types a user is signed in with.

9.0.2 (May 24, 2021)

  • Updated Native iOS SDK to v7.2.4. This includes a change to how games retrieve Facebook permissions in Limited Login and Classic modes.
  • Updated Facebook SDK to v9.2.0. This update supports additional social permissions in limited login mode.
  • Updated Rave SDK to version 3.9.11
  • Updated AppsFlyer SDK to version 6.2.6
  • (Sample app only) Removes calls to set Facebook read permissions after the ATT dialog is dismissed
  • Adds the ability to retrieve app-associated Facebook friends, if the user is authenticated through Facebook, using the new asynchronous method bfgRave getAppAssociatedFacebookFriends.

9.0.1 (Apr 29, 2021)

This release modifies bfgutils::attStatus to return the status for all iOS versions again. This is needed to properly set the FB login mode on iOS versions 14.0 through 14.4.

  • Updated the Native iOS SDK to v7.2.3.

Known Issues

Our Sample code currently does not handle two edge case scenarios, though these could be handled fairly easily at the game implementation level if needed:

  • On iOS 14.0 to 14.4, since ATT is not displayed, toggling the global ATT setting does not cause a cold start for the application. Because of this, if a game uses the sample code we have in our Sample apps or in the developer docs, the Facebook login mode is not updated immediately (i.e., when the app is warm started after the ATT tracking setting has changed). It will be updated appropriately on the next cold start. This can be handled by checking the ATT status on every warm start.
  • On iOS 14.0 to 14.4, a user may globally disable the ATT tracking, which will cause the app to be set to limited login mode. If the user then re-enables tracking globally, there is currently no sample code for the app to re-enable classic login mode. We cannot reenable classic mode without prompting the user for ATT, so it is not advised to switch back to classic mode. This can be handled by the app by checking for iOS 14.0 to 14.4 on every warm or cold start, and switching the login mode back to classic.

9.0.0 (Apr 27, 2021)

Apple released information on April 20th, Upcoming App Tracking Transparency requirements, which states that iOS 14.5 will become the first version where App Tracking Transparency is enforced.

This hotfix includes the following changes to account for this update:

  • Disables ATT consent calls for iOS 14.0 - iOS 14.4 (ATT dialog cannot be displayed)
  • Add a new method to check whether or not the ATT dialog should be displayed: bfgManager::attMeetsSystemRequirements. This will only return true for iOS 14.5 and higher versions.
  • Modified attSelectionRequired and requestTrackingAuthorization to use this new method.
  • Modified bfgutils::attStatus to use this new method (but this was quickly ‘undone’ in 7.2.3 (see change list above for 7.2.3)
  • This also changes MTS events so that the appTrackingTransparencyStatus flag will not be included for iOS versions 14.0 to 14.4 (and it is still not included in iOS 13 and lower - though this is not new to 7.2.2).
  • Removes AppsFlyer call for waitForATTUserAuthorization (timeout for starting AF) when ATT consent dialog is not shown (this fix applies to games on earlier versions of iOS14)). The game could still add this call themselves however.

Unity Note

This was the first release where we moved the Unity SDK to be on a new versioning line of its own. Unity is now version 9.0.0, which includes the Native iOS SDK v7.2.2 and Native Android SDK v7.1.5.


7.2.1 (Apr 7, 2021)

  • Updated the AppsFlyer SDK to 6.2.4. This includes fixes for SKAdNetwork.
  • Updated the Facebook SDK to 9.0.1 and includes Limited Login
  • Updated the Rave SDK to 3.9.10-402, which includes support for Limited Login and a fix for SIWA login. Note: the BigFishScenePack.bundle was updated and must be updated by all games.
  • Update Zendesk to send iOS 9 users to a non-javascript web portal
  • Update Zendesk to handle sending users to the correct localized Zendesk site, or default to English for non-supported languages, on a game by game basis.
  • Expose a new API for sending custom events to AppsFlyer (support for SKAdNetwork)
  • Updated Crashlytics on Unity builds to include the Unity version for fatal and non-fatal events (key: “UnityVersion”)
  • Fixed an issue with bfgResourcesUniversal targeting the iPhoneSimulator platform, which was causing build issues in Unity
  • Added an optional ‘game controlled AppsFlyer startup’ mode that is intended to be used only by games that are not displaying the ATT dialog
  • Fixed high severity issue in deserializing MTS events for older versions of the SDK.

7.2.0 (Jan 21, 2021)

  • Unity SDK now delivered as a Unity Package for ease of integration
  • ATT framework APIs exposed via new SDK methods, wrapped for Unity developers
  • ATT status now included in MTS device info payload
  • Minimum iOS version support is now 10
  • Firebase Crashlytics (7.0.1) and Analytics (7.0.1) are now included using the official Unity SDKs rather than embedding in the native layers
  • Updated 3rd Party SDKs
    • AppsFlyer SDK updated to version 6.0.3
    • Facebook SDK updated to version 8.2
    • Rave SDK updated to version 3.9.8-399
    • Zendesk SDK updated to version 4.0.1

7.1.1 (Aug 2020)

  • Fixed high severity issue in deserializing MTS events for older versions of the SDK.

7.1.0 (July 2020)

  • Updated Zendesk SDK to version 5.0 (iOS) and 3.0.2 (Android). This update to Zendesk removes the UIWebView which was present in their SDK.
  • PromoCode (aka redemption service) support is now included in the SDK.
  • Added support for developers who integrate Firebase Analytics.