Skip to content

Latest commit

 

History

History
594 lines (478 loc) · 46.6 KB

CHANGELOG.md

File metadata and controls

594 lines (478 loc) · 46.6 KB

Changelog

[5.0.0-pre.3] - 2024-08-21

Added

  • Apple - Updated to StoreKit 2.
    • All features previously in StoreKit 1 are still supported.
    • New features from StoreKit 2 will be supported in a later release.
    • StoreKit 1 is no longer supported and iOS devices will require iOS 15.0 or later.
    • Added support for AppAccountToken, allowing associating purchases with an app-specific account identifier. It can be set using SetAppAccountToken(Guid token) on the StoreExtendedService (e.g., IAppleStoreExtendedService.SetAppAccountToken), and it is also exposed in the IAppleOrderInfo interface for better integration with order details. For more details, see AppAccountToken documentation.
  • Apple - Updated PrivacyInfo.xcprivacy to reflect that IAP no longer uses required reason API.

Changed

  • Apple - CrossPlatformValidator is no longer used for receipt validation for Apple since StoreKit2 does it.
  • Apple - Receipt obfuscation for Apple has been removed.
  • Apple - Product.appleProductIsRestored is now obsolete since it's no longer used with StoreKit2.

Fixed

  • Fixed Non-Consumables being treated as Consumables (introduced by Unity IAP 5.0.0-pre.1)

[5.0.0-pre.1] - 2024-07-26

In-app purchasing 5.0.0 is a major overhaul of this package. Consult the Coded IAP 5.0.0 Sample for a complete example of how to use this new version.

Added

  • Retry Policies:
    • Add StoreService.Connect method which initiates the connection to the store.
    • Add IRetryPolicy interface that can be implemented to provide a custom retry policy. IRetryPolicy.ShouldRetry(IRetryPolicyInformation) determines if the request should retried and can wait before retrying.
    • Add basic implementations of the IRetryPolicy such as ExponentialRetryPolicy , MaximumNumberOfAttemptsRetryPolicy, NoRetriesPolicy and TimeLimitRetryPolicy.
  • New callbacks on IAP Button and IAP Listener for all the events

Fixed:

  • Apple - Fixed SubscriptionPeriodUnit to return the correct values: Week = 1, Month = 2 (previously Month = 1, Week = 2)
  • Apple - Fixed isFamilyShareable on tvOS to be only available on supported versions (14.0 and above).

Changed

  • IAP logs are prefixed with InAppPurchasing.
  • IAP Catalog
    • Removed Apple Configuration, Google Configuration and Catalog Export from IAP Catalog since this is no longer supported by the stores.
    • Moved the Google Configuration Price under Descriptions which is displayed when products havn't been retrieved yet or in Fake Store
  • Assemblies starting with UnityEngine.Purchasing have been renamed to Unity.Purchasing

Removed

  • Support for Windows Store (Universal Windows Platform)
  • Support for the Unity 2020 Editor and Engine. Please upgrade to Unity 2021.3 or later.
  • Android - Support for the Unity Distribution Portal via the In-App Purchasing package. You may still use the Unity Distribution Portal in older versions of In-App Purchasing, or by writing your own implementation of the Unity Distribution Portal SDK directly, or as a custom store.
  • Support for Legacy Analytics (com.unity.modules.unityanalytics). Please use Unity Game Services Analytics instead (com.unity.services.analytics).

[4.12.1] - 2024-07-11

Changed

  • Apple - The change where Product.appleProductIsRestored was no longer sent to ProcessPurchase has been reverted.

Fixed

  • GooglePlay - Fixed an issue where a warning was output in the logs when retrieving purchases.

[4.12.1-pre.4] - 2024-07-02

Fixed

  • GooglePlay - Fixed an issue that happens on Windows when disabling the IAP Dependencies.
  • GooglePlay - Fixed an InvalidOperationException that could occur when obtaining purchases. (Since Unity IAP 4.6.0)

[4.12.1-pre.3] - 2024-06-26

Changed

  • Apple - Retrieved purchases from the store will be considered as appleProductIsRestored.
  • Apple - Product.appleProductIsRestored will no longer be sent to ProcessPurchase since they have already been processed.
  • Apple - The changes above will improve Analytics data by avoiding duplicate purchase events.

Fixed

  • GooglePlay - Fixed an issue where dependencies were added after dependency resolution happened resulting in an error.
  • GooglePlay - Fixed Product.receipt's price_amount_micros returning the price instead of the price in micro-units.
  • GooglePlay - Fixed NullReferenceException occurring when retrieving products on Unity Engine 2021.2 and earlier.
  • GooglePlay - Fixed OnProductReceived callback not being fired with an invalid ProductID.

[4.12.1-pre.1] - 2024-06-06

Fixed

  • GooglePlay - Fixed errors related to CloneReference on Unity Engine 2021.1.

Removed

  • Removed unnecessary Android dependency, androidx.activity:activity-compose:1.3.1, which could cause conflicts with other plugins.

[4.12.0] - 2024-06-04

Added

  • GooglePlay - IGooglePlayStoreExtensions.GetObfuscatedAccountId(Product product) has been added to obtain the obfuscated account ID of the purchase set with IGooglePlayConfiguration.SetObfuscatedAccountId.
  • GooglePlay - IGooglePlayStoreExtensions.GetObfuscatedProfileId(Product product) has been added to obtain the obfuscated profile ID of the purchase set with IGooglePlayConfiguration.SetObfuscatedProfileId.
  • Apple - Added visionOS support

Changed

  • Upgraded com.unity.services.core from 1.8.2 to 1.12.5 to include their Apple privacy manifest.
  • GooglePlay - Dependencies are now injected in the gradle files. The Billing aar is no longer included.
  • GooglePlay - Billing Library updated to 6.2.1 (was previously 5.2.1). No new feature support was added. Subscriptions must still have only 1 base plan.
  • GooglePlay - Updated the internal implementation to use productDetails instead of skuDetails to solve the setOfferToken warning issued by Google.
  • GooglePlay - IGooglePlayStoreExtensions.GetPurchaseState(Product product) has been updated to use the getPurchaseState() instead of getOriginalJson(). This change will make the purchase state more reliable.
  • GooglePlay - IGooglePlayStoreExtensions.ConfirmSubscriptionPriceChange has been marked [Obsolete] as it is no longer supported since Google Play Billing Library 6.0.0. For alternatives, see the price changes guide.
  • GooglePlay - IStoreListener.OnInitializeFailed for InitializationFailureReason.PurchasingUnavailable will now return the BillingResponseCode when product retrieval is successful, but an error occured and no products were returned.

Fixed

  • Fixed OnPurchaseFailed - It now returns the productId (previously the transactionId) in the PurchaseFailureDescription when the product isn't available for purchase.
  • Fixed a NullReferenceException when retrieving products on Unity Engine 2020.

Removed

  • GooglePlay - The iconUrl and skuDetailsToken sub-entry to the Product.receipt's "Payload"'s "skuDetails" will now return an empty string since they are no longer supported.

[4.11.0] - 2024-03-06

Added

  • GooglePlay - IGooglePlayConfiguration.SetMaxConnectionAttempts(int maxConnectionAttempts) has been added to specify the max connection attempts to the Google Play Store.
  • Apple - Added privacy manifest to comply with Apple's new privacy requirements. More details on how the Unity Engine supports this can be found here.
  • Added ConfigurationBuilder.logUnavailableProducts to specify if unavailable products should be logged.

Changed

  • GooglePlay - The default max connection attempt to the Google Play Store has been increased from 1 to 3. See IGooglePlayConfiguration.SetMaxConnectionAttempts to configure this to a different value.
  • Apple - The log when retrieving products (SKProductsResponse) now also contains the invalid products count.
  • Improved IStoreListener.OnInitializeFailed for InitializationFailureReason.NoProductsAvailable by adding a message to clarify whether the store returned products or not.

Fixed

  • GooglePlay - Fixed AndroidJavaObject not being disposed causing a global reference table overflow in an edge case.
  • GooglePlay - Fixed bug causing BillingClient duplication resulting in ANR.
  • Apple - Fixed isFamilyShareable on tvOS to be only available on supported versions (14.0 and above).
  • Apple - Error codes when a purchase fails now always returns the code from Apple instead of defaulting to SKErrorUnknown.
  • Fixed Analytics' transactionServer being null.

[4.10.0] - 2023-09-07

Changed

  • Unity Distribution Portal - IAP will retract support for UDP at some point in the near future (Announcement TBD). Until then, all UDP features will continue to function, but the public interfaces, as well as some private functions are now marked [Obsolete]. In the next major update these will all be removed and UDP will cease to function with that version of In-App Purchasing and those that follow.
  • Unity Distribution Portal - If the editor is unable to connect to the UDP backend, the developer can now use some UDP catalog features in offline mode. This allows the developer to continue to enter prices, meaning that prices will need to be synced manually. In this case, we strongly suggest you sync your prices properly once connection is re-established. A warning message will display in the Catalog if the editor is unable to connect to the UDP backend.
  • Analytics - The Legacy Analytics built-in module, com.unity.modules.unityanalytics, is now no longer a dependency. You may now remove it from your project if you don't use it. Make sure it is in your project if you do use it.
  • Project Settings - In the Services Project Settings page of the Editor, we have changed the endpoint from which the Google Play Key is obtained. Also, instead of setting the key directly in the editor, there is now a dashboard link to set it directly on the backend to avoid future errors.

Fixed

  • Google Play - Some versions of the Unity Editor compiler were stripping GooglePurchaseUpdatedListener.onPurchasesUpdated, which was assigned as a callback to the Google Billing module, causing a lack of purchase failure callbacks, and logging "No such proxy method:". Also fixed this for BillingClientStateListener.onBillingServiceDisconnected, BillingClientStateListener.onBillingSetupFinished and SkuDetailsResponseListener.onSkuDetailsResponse.

[4.9.4] - 2023-08-01

Changed

  • Google Play - Billing Library updated to 5.2.1 (was previously 5.1.0). No new feature support was added, this is simply to add compatibility with Android 14.
  • Apple - Using the CrossPlatformValidation (or AppleValidator), receipts will now be validated if their certificate chain is encoded in SHA-256 instead of SHA-1. Old receipts encoded in SHA-1 will still be validated. See Apple Technical Note.

[4.9.3] - 2023-05-17

Changed

  • Analytics events are now sent when a purchase has been confirmed (ConfirmPendingTransaction or ProcessPurchase returning PurchaseProcessingResult.Complete). This will improve the accuracy of revenue tracking by no longer considering pending purchases.
  • Updated Product.transactionID, Product.hasReceipt and Product.receipt documentation to include pending transaction use cases.
  • Updated samples to use IDetailedStoreListener and its improved OnPurchaseFailed callback.
  • Added a new RefreshAppReceipt(Action<string> successCallback, Action<string> errorCallback) callback containing more information when the errorCallback is invoked in IAppleExtensions : IStoreListener.

Fixed

  • OnPurchaseFailed will no longer log an error when there's only new IAP Buttons with no IAP Listener.
  • Apple - Improved the accuracy of Product.appleProductIsRestored when using the restore transaction button. These will now correctly be flagged as true.
  • Codeless - OnPurchaseFailed(Product, PurchaseFailureDescription) callback was not invoked in IAP Listener

[4.8.0] - 2023-04-12

Added

  • Added new IAP Button in the editor. This new button allows for more UI customization. The new button will no longer update the button fields by default.
  • Added a new event OnProductFetched(Product) to the IAP Listener and to the IAP Button it is called after fetching products from the app stores.
  • Added a new OnPurchaseFailed(Product, PurchaseFailureDescription) callback containing more information on the failed purchase in IDetailedStoreListener : IStoreListener

Changed

  • IAP Button is now obsolete.
  • Google Play - Billing Library update from version 4.0.0 to 5.1.0 Google Release Notes. New Google Billing features are not supported yet, they will be included in a future major update.
  • Removed the nullable operator ? from public interfaces and classes.
  • IStoreListener.OnPurchaseFailed is now obsolete.
  • When present, Analytics 4.4.0 and above will now use the new interface IAnalyticsStandardEventComponent from Services Cores 1.8.1.
  • Upgraded com.unity.services.core from 1.5.2 to 1.8.1.

Fixed

  • Samples - Some samples had IAP 4.6.0 IStoreListener changes not completely implemented causing compilation errors.

[4.7.0] - 2023-02-09

Added

  • Added storeSpecificErrorCode to PurchaseFailureDescription.message when available.

Fixed

  • Unity IAP will consider the call to UnityPurchasing.initialize completed before invoking the correct callback IStoreListener.OnInitialized or IStoreListener.OnInitializeFailed. This prevents these callbacks from being invoked more than once per initialization.
  • GooglePlay - Fixed No such proxy method exception in our representation of BillingClientStateListener.onBillingServiceDisconnected() introduced by Unity IAP 4.6.0
  • Apple - Fixed a NullReferenceException happening when the receipt isn't found.

Changed

  • Removed com.unity.services.analytics from the IAP SDK dependencies

[4.6.0] - 2023-02-02

Added

  • Added a new restore transaction callback RestoreTransactions(Action<bool, string> callback) to obtain the error string when RestoreTransactions is not successful (IAppleExtensions and IGooglePlayStoreExtensions).
  • Added a new initialize failed callback IStoreListener.OnInitializeFailed(InitializationFailureReason, string) to obtain the error string when OnInitializeFailed is invoked.
  • Added a new setup failed callback IStoreCallback.OnSetupFailed(InitializationFailureReason, string) to obtain the error string when OnSetupFailed is invoked.
  • Added a new FetchAdditionalProducts. The failCallback contains an error string. IStoreController.FetchAdditionalProducts(HashSet<ProductDefinition>, Action, Action<InitializationFailureReason, string>)
  • Apple - Product.appleOriginalTransactionId : Returns the original transaction ID. This field is only available when the purchase was made in the active session.
  • Apple - Product.appleProductIsRestored : Indicates whether the product has been restored.
  • GooglePlay - IGooglePlayConfiguration.SetFetchPurchasesExcludeDeferred(bool exclude) has been added to revert to the previous behaviour. This is not recommended and should only be used if Deferred purchases are handled in your IStoreListener.ProcessPurchase.
  • GooglePlay - IGooglePlayStoreExtensions.GetPurchaseState(Product product) has been added to obtain the GooglePurchaseState of a product.
  • GooglePlay - Added missing values to GoogleBillingResponseCode in order to output it in PurchaseFailureDescription's message when available.
  • Codeless - Added to the IAP Button the option to add a script for the On Transactions Restored: void OnTransactionsRestored(bool success, string? error)

Changed

  • Upgraded com.unity.services.core from 1.3.1 to 1.5.2
  • Upgraded com.unity.services.analytics from 4.0.1 to 4.2.0
  • The old OnInitializeFailed OnInitializeFailed(InitializationFailureReason error) was marked Obsolete
  • The old OnSetupFailed OnSetupFailed(InitializationFailureReason reason) was marked Obsolete
  • The old FetchAdditionalProducts FetchAdditionalProducts(HashSet<ProductDefinition> additionalProducts, Action successCallback, Action<InitializationFailureReason> failCallback) was marked Obsolete
  • The old restore transaction callback RestoreTransactions(Action<bool> callback) was marked Obsolete (IAppleExtensions and IGooglePlayStoreExtensions).
  • Apple - Transactions received from Apple that are invalid (where the product is not entitled) will no longer output the Finishing transaction log. This only affects transactions that never reached the ProcessPurchase.
  • GooglePlay - The enum GooglePurchaseState now recognizes 4 as Deferred.

Fixed

  • Analytics - A ServicesInitializationException introduced in Analytics 4.3.0 is now handled properly.
  • Analytics - Fixed an issue where transactions events were invalidated when there was no localization data for a product.
  • GooglePlay - Fixed a NullReferenceException when querying sku details while the BillingClient is not ready.
  • GooglePlay - Fixed Application Not Responding (ANR) when foregrounding the application while disconnected from the Google Play Store.
  • GooglePlay - Limited the occurence of PurchasingUnavailable errors when retrieving products while in a disconnected state to once per connection.
  • GooglePlay - Deferred purchases are, by default, no longer sent to IStoreListener.ProcessPurchase when fetching purchases. This avoids the possibility of granting products that were not paid for. These purchases will only be processed once they become Purchased. This can be reverted with IGooglePlayConfiguration.SetFetchPurchasesExcludeDeferred(bool exclude) to not exclude them, but Deferred purchases will need to be handled in IStoreListener.ProcessPurchase.
  • Unity IAP will consider the call to UnityPurchasing.initialize completed before invoking the correct callback IStoreListener.OnInitialized or IStoreListener.OnInitializeFailed. This prevents these callbacks from being invoked more than once per initialization.

[4.5.2] - 2022-10-28

Fixed

  • Removed unused exception variable causing a compiler warning CS0168.
  • Telemetry - Calls to telemetry reporting were occasionally tripping a NullReferenceException, IndexOutOfRangeException or KeyNotFoundException, for some users. These exceptions are now caught safely and logged. These failures are also mitigated by moving all Telemetry calls to the main thread. Issue noticed in IAP 4.4.1, but may be older.
  • Apple - Optimized memory usage when processing transactions to prevent out of memory crash when processing transactions on launch.
  • Batch Mode - Calls to UnityPurchasingEditor.TargetAndroidStore to select UDP will now successfully check UDP package installation and log an error instead of throwing a blocking popup when executed as part of a Batch Mode command.
  • Analytics - Removed escape characters for receipt JSON which was causing parsing issues in the backend.
  • GooglePlay - Fixed a bug causing a crash when retrying to finish a transaction while disconnected

[4.5.1] - 2022-10-13

Fixed

  • GooglePlay - Fixed deferred purchases being processed when the app is foregrounded. Issue introduced in Unity IAP 4.5.0.
  • GooglePlay - Fixed a NullReferenceException in DequeueQueryProducts happening when launching the app. Issue introduced in Unity IAP 4.2.0.
  • Analytics - Fixed a NullReferenceException when reporting failed transactions of purchase unavailable products. Issue introduced in Unity IAP 4.2.0.
  • Analytics - Legacy Analytics will no longer report events in custom UGS environments, which would cause misreported live sales figures. Issue introduced in Unity IAP 4.2.0.

[4.5.0] - 2022-09-23

Added

  • Apple - Add support for Family Sharing.
    • API IAppleConfiguration.SetEntitlementsRevokedListener(Action<List<Product>> called when entitlement to a products are revoked. The Action will be called with the list of revoked products. See documentation "Store Guides" > "iOS & Mac App Stores" for a sample usage.
    • API - Product metadata is now available in AppleProductMetadata from ProductMetadata.GetAppleProductMetadata() via IStoreController.products.
    • API AppleProductMetadata.isFamilyShareable indicated if the product is family shareable.
    • Apple App Store - 11 Family Sharing sample that showcases how to use Unity IAP to manage family shared purchases.

Fixed

  • GooglePlay - Processing out-of-app purchases such as Promo codes no longer requires the app to be restarted. The purchase will be processed the next time the app is foregrounded. Technical limitation: In the case of promo codes, if the app is opened while the code is redeemed, you might receive an additional call to IStoreListener.OnPurchaseFailed with PurchaseFailureReason.Unknown. This can be safely ignored.
  • GooglePlay - Fixed a NullReferenceException that would rarely occur when retrieving products due to a concurrency issue introduced in Unity IAP 4.2.0

[4.4.1] - 2022-08-11

Fixed

  • GooglePlay - Fixed NullReferenceException and ArgumentException that would rarely occur due to a concurrency issue introduced in Unity IAP 4.2.0
  • Amazon - Set android:export to true to support Android API level 31+

[4.4.0] - 2022-07-11

Added

  • GooglePlay - Google Play Billing Library version 4.0.0.
    • The Multi-quantity feature is not yet supported by the IAP package and will come in a future update. Do not enable Multi-quantity in the Google Play Console.
    • Add support for the IMMEDIATE_AND_CHARGE_FULL_PRICE proration mode. Use GooglePlayProrationMode.ImmediateAndChargeFullPrice for easy access.
    • The "skuDetails" in the receipt json is now an array of the old structure, not just one object. It will only have one element in most cases, so if this is being parsed in your app, treat it like an array and get the first element by default.

Fixed

  • GooglePlay - Fix IGooglePlayConfiguration.SetDeferredPurchaseListener and IGooglePlayConfiguration.SetDeferredProrationUpgradeDowngradeSubscriptionListener callbacks sometimes not being called from the main thread.
  • GooglePlay - When configuring IGooglePlayConfiguration.SetQueryProductDetailsFailedListener(Action<int> retryCount), the action will be invoked with retryCount starting at 1 instead of 0.
  • GooglePlay - Added a validation when upgrading/downgrading a subscription that calls IStoreListener.OnPurchaseFailed with PurchaseFailureReason.ProductUnavailable when the old transaction id is empty or null. This can occur when attempting to upgrade/downgrade a subscription that the user doesn't own.

[4.3.0] - 2022-06-16

Added

  • GooglePlay - API IGooglePlayConfiguration.SetQueryProductDetailsFailedListener(Action<int>) called when Unity IAP fails to query product details. The Action will be called on each query product details failure with the retry count. See documentation "Store Guides" > "Google Play" for a sample usage.

[4.2.1] - 2022-06-14

Fixed

  • Downgrade com.unity.services.core from 1.4.1 to 1.3.1 due to a new bug found in 1.4.1

[4.2.0] - 2022-06-13

Added

  • Feature to automatically initialize Unity Gaming Services through the catalog UI. Please see the documentation for more details.

Changed

  • The In-App Purchasing package now requires Unity Gaming Services to have been initialized before it can be used. For the time being IAP will continue working as usual, but will log a warning if Unity Gaming Services has not been initialized. In future releases of this package, initializing Unity Gaming Services will be mandatory. Please see the documentation for more details.

[4.2.0-pre.2] - 2022-04-28

Added

Changed

  • The Analytics notice in the In-App Purchasing service window has been removed for Unity Editors 2022 and up.

[4.2.0-pre.1] - 2022-04-07

Added

  • Support for the new Unity Analytics transaction event.
  • The package will now send telemetry diagnostic and metric events to help improve the long-term reliability and performance of the package.

Changed

  • The minimum Unity Editor version supported is 2020.3.
  • The In-App Purchasing service window now links to the new Unity Dashboard for Unity Editors 2022 and up.

Fixed

  • GooglePlay - Fixed OnInitializeFailed never called if GooglePlay BillingClient is not ready during initialization.
  • GooglePlay - GoogleBilling is allowed to initialize correctly even if the user's Google account is logged out, so long as it is linked. The user will need to log in to their account to continue making purchases.
  • Fixed a build error DirectoryNotFoundException that occurred when the build platform was iOS or tvOS and the build target was another platform.

[4.1.5] - 2022-05-17

Fixed

  • GooglePlay - Fixed a null reference exception introduced in Unity IAP 4.1.4 that could happen when cancelling an in-app purchase.

[4.1.4] - 2022-03-30

Fixed

  • GooglePlay - Fixed issue where if an app is backgrounded while a purchase is being processed, an OnPurchaseFailed would be called with the purchase failure reason UserCancelled, even if the purchase was successful.

[4.1.3] - 2022-01-11

Fixed

  • Removed deprecated UnityWebRequest calls, updating them to use safer ones. This avoids compiler warnings that may occur.
  • Fixed a serious edge case where Apple StoreKit receipt parsing might fail, preventing validation. A portion of receipts on iOS could be affected and cause Unity IAP to freeze after the purchase completed, but before the SDK can finalize the purchase. The user will have to uninstall and reinstall your app in order to recover from this. Your customer service will have to refund the user's purchase or apply the purchase in some other way outside of Unity IAP. This bug was accidentally introduced in Unity IAP 4.1.0. To avoid encountering this problem with your app, we suggest you update to this version.

[4.1.2] - 2021-11-15

Fixed

  • Various internal obsolete warnings have been removed, allowing the project to be compiled with errors as warnings enabled.

[4.1.1] - 2021-10-28

Changed

  • A default store will be selected for each platform. For Android the default store will be Google. All other platforms already had default stores.

[4.1.0] - 2021-09-20

Added

  • Apple - Add support for receipt validation with StoreKit Test. See the Receipt Validation Obfuscator manual for a usage recommendation. See also the sample "05 Local Receipt Validation" for an example.
  • GooglePlay - Add support for controlling automatic fetching of purchases at initialization, with IGooglePlayConfiguration.SetFetchPurchasesAtInitialize(bool). Use to help distinguish previously seen purchases from new purchases. Then to fetch previously seen purchases use IGooglePlayExtensions.RestorePurchases(Action<bool>).

Changed

  • Menu items for this package were renamed from Unity IAP -> In-App Purchasing and have been moved from Window > Unity IAP to Services > In-App Purchasing.
  • Choosing an Android app store target before building the Android Build Target is now required. A build error will be emitted otherwise. Set this with the Store Selector window (Services > In-App Purchasing > Switch Store ...) or the API (UnityPurchasingEditor.TargetAndroidStore()). The default Android app store is now AppStore.NotSpecified and is visible in the window as <Select a targeted store>. Previously the default app store was the Google Play Store for the Android Build Target. See the Store Selector documentation for more
  • Apple - Workaround rare crash seen if nil NSLocaleCurrencyCode is received when extracting localized currency code from [SKProduct priceLocale] when fetching products. Substitutes ISO Unknown Currency code "XXX" into ProductMetadata.isoCurrencyCode.
  • Removed warning log Already recorded transaction.
  • Codeless - The default setting for enabling Codeless Auto Initialization in new projects' catalogs is now true instead of false. (As seen in the Catalog Editor as "Automatically initialize UnityPurchasing (recommended)").

Fixed

  • Fixed warning, missing await for async call in ExponentialRetryPolicy.cs

Removed

  • Removed the original and complex Unity IAP sample known as "Example", or "IAP Demo". Please use the recently added samples for a granular introduction to In-App Purchasing features.

[4.0.3] - 2021-08-18

Added

  • Added samples to the Package Manager Details view:
    • Apple Sample - Restoring Transactions
    • Apple Sample - Handling Deferred Purchases
    • Apple Sample - Detecting Fraud
    • Apple Sample - Getting Introductory Prices
    • Apple Sample - Present Code Redemption Sheet
    • Apple Sample - Can Make Payments
    • Apple Sample - Retrieving Product Receipts
    • Apple Sample - Subscription Upgrade Downgrade
    • Apple Sample - Promoting Products
  • Apple - Added support for fetching the current store promotion order of products on this device with void IAppleExtensions.FetchStorePromotionOrder(Action<List<Product>> successCallback, Action errorCallback)
  • Apple - Added support for fetching the current store promotion visibility of a product on this device with void FetchStorePromotionVisibilitySuccess(Product product, AppleStorePromotionVisibility visibility)

Fixed

  • Apple - Fixed issue with unknown products being processed with NonConsumable type.

Fixed

  • GooglePlay - Fixed issue that led to purchases failing with a ProductUnavailable error when fetching additional products multiple times in quick succession.
  • GooglePlay - Fixed issue that led to purchases failing with a ProductUnavailable error when a game had been running for some time.
  • GooglePlay - Fixed issue that led to initialization failing with a NoProductsAvailable error when the network is interrupted while initializing, requiring the user to restart the app. Now Unity IAP handle initialization with poor network connectivity by retrying periodically. This retry behavior is consistent with our Apple App Store's, and with the previous version of our Google Play Store's implementations.

Changed

[4.0.0] - 2021-07-19

Added

  • Codeless Listener method to access the store configuration after initialization.
    • CodelessIAPStoreListener.Instance.GetStoreConfiguration
  • Several samples to the Package Manager Details view for com.unity.purchasing:
    • Fetching additional products
    • Integrating self-provided backend receipt validation
    • Local receipt validation
    • Google Play Store - Upgrade and downgrade subscriptions
    • Google Play Store - Restoring Transactions
    • Google Play Store - Confirming subscription price change
    • Google Play Store - Handling Deferred Purchases
    • Google Play Store - Fraud detection
    • Apple App Store - Refreshing app receipts
  • Google Play - GooglePlayProrationMode enum that represent Google's proration modes and added IGooglePlayStoreExtensions.UpgradeDowngradeSubscription using the enum.

Fixed

  • GooglePlay - Fixed Application Not Responding (ANR) error at Product initialization. The Google Play SkuDetailsResponseListener.onSkuDetailsResponse callback is now quickly handled.
  • Amazon - Fixed Product.metadata.localizedPrice incorrectly being 0.00 for certain price formats.
  • Apple, Mac App Store - Fixes Apple Silicon "arm64" support, missing from unitypurchasing bundle.

Changed

  • Reorganized and renamed APIs:
    • CodelessIAPStoreListener.Instance.ExtensionProvider.GetExtension to CodelessIAPStoreListener.Instance.GetStoreExtensions to match the new GetStoreConfiguration API, above
    • IGooglePlayStoreExtensions.NotifyDeferredProrationUpgradeDowngradeSubscription to IGooglePlayConfiguration.NotifyDeferredProrationUpgradeDowngradeSubscription
    • IGooglePlayStoreExtensions.NotifyDeferredPurchase to IGooglePlayConfiguration.NotifyDeferredPurchase
    • IGooglePlayStoreExtensions.SetDeferredProrationUpgradeDowngradeSubscriptionListener to IGooglePlayConfiguration.SetDeferredProrationUpgradeDowngradeSubscriptionListener
    • IGooglePlayStoreExtensions.SetDeferredPurchaseListener to IGooglePlayConfiguration.SetDeferredPurchaseListener
    • IGooglePlayStoreExtensions.SetObfuscatedAccountId to IGooglePlayConfiguration.SetObfuscatedAccountId
    • IGooglePlayStoreExtensions.SetObfuscatedProfileId to IGooglePlayConfiguration.SetObfuscatedProfileId
  • Apple - Change the order of execution of the post-process build script, which adds the StoreKitFramework such that other post-process build scripts can run after it.
  • Changed the Target Android Menu app store selection feature to display a window under Window > Unity IAP > Switch Store.... To set the app store for the next build, first use Build Settings to activate the Android build target.
  • For the future Unity 2022
    • Moved Unity IAP menu items from Window > Unity IAP > ... to Services > In-App Purchasing > ...
    • Updated and added new functionnality to the Services > In-App Purchasing window in the Project Settings. The Current Targeted Store selector and Receipt Obfuscator settings are now accessible from this window.

Removed

  • Samsung Galaxy - Removed Samsung Galaxy Store in-app purchasing support. Use the Unity Distribution Portal for the continued support of the Samsung Galaxy Store.
    • All related classes and implementations have been removed including AppStore.SamsungApps.
  • Removed the following obsolete API:
    • CloudCatalogImpl
    • CloudCatalogUploader
    • CloudJSONProductCatalogExporter
    • EventDestType
    • All GooglePlayReceipt constructors. Use GooglePlayReceipt(string productID, string orderID, string packageName, string purchaseToken, DateTime purchaseTime, GooglePurchaseState purchaseState) instead.
    • IAndroidStoreSelection.androidStore
    • IDs.useCloudCatalog
    • IGooglePlayConfiguration.SetPublicKey
    • IGooglePlayConfiguration.UsePurchaseTokenForTransactionId
    • IGooglePlayConfiguration.aggressivelyRecoverLostPurchases
    • IGooglePlayStoreExtensionsMethod.FinishAdditionalTransaction
    • IGooglePlayStoreExtensionsMethod.GetProductJSONDictionary
    • IGooglePlayStoreExtensionsMethod.IsOwned
    • IGooglePlayStoreExtensionsMethod.SetLogLevel
    • IManagedStoreConfig
    • IManagedStoreExtensions
    • IStoreCallback.OnPurchasesRetrieved. Use IStoreCallback.OnAllPurchasesRetrieved instead.
    • Promo
    • StandardPurchasingModule.Instance(AndroidStore). Use StandardPurchasingModule.Instance(AppStore) instead.
    • StandardPurchasingModule.androidStore. Use StandardPurchasingModule.appStore instead.
    • StandardPurchasingModule.useMockBillingSystem. Use IMicrosoftConfiguration instead.
    • StoreTestMode
    • UnityPurchasingEditor.TargetAndroidStore(AndroidStore). Use TargetAndroidStore(AppStore) instead.
    • WinRT class. Use WindowsStore instead.
    • WindowsPhone8 class. Use WindowsStore instead.

[3.2.3] - 2021-07-08

Fixed

  • GooglePlay - Fix DuplicateTransaction errors seen during purchase, after a purchase had previously been Acknowledged with Google.
  • GooglePlay - Fix DuplicateTransaction errors seen after a user starts a purchase on a game with Unity IAP 1.x or 2.x, quits their game, upgrades their game to include a version of Unity IAP 3.x, and tries to finish consuming / completing that old purchase.

[3.2.2] - 2021-06-02

Added

Fixed

  • WebGL - While WebGL is not supported with an included app store implementation, the WebGL Player will no longer crash when the StandardPurchasingModule.Initialize API is called if Project Settings > Player > WebGL > Publishing Settings > Enable Exceptions > "Explicitly Thrown Exceptions Only" or "None" are set.
  • Amazon - Better support for Android R8 compiler. Added minification (Project Settings > Player > Publishing Settings > Minify) "keep" ProGuard rules.

[3.2.1] - 2021-05-18

Changed

  • Manual and API documentation updated.

[3.2.0] - 2021-05-17

Added

  • GooglePlay - Automatic resumption of initialization when a user's device initially does not have a Google account, and they correct that Android setting without killing the app, then they resume the app. NOTE this does not impact Unity IAP's behavior when a user removes their Google account after initialization.
  • GooglePlay - API IGooglePlayConfiguration.SetServiceDisconnectAtInitializeListener(Action) called when Unity IAP fails to connect to the underlying Google Play Billing service. The Action may be called multiple times after UnityPurchasing.Initialize if a user does not have a Google account added to their Android device. Initialization of Unity IAP will remain paused until this is corrected. Inform the user they must add a Google account in order to be able to purchase. See documentation "Store Guides" > "Google Play" for a sample usage.
  • GooglePlay - It is now possible to check if a purchased product is pending or not by calling IsPurchasedProductDeferred() from GooglePlayStoreExtensions.
  • UDP - RegisterPurchaseDeferredListener in IUDPExtensions can be used to assign a callback for pending purchases.

Fixed

  • GooglePlay - Receipts for Pending purchases are now UnifiedReceipts and not raw Google receipts. Any parsers you have for these can extract the raw receipt json by parsing the "Payload" field.
  • Editor - The Fake Store UI used in Play Mode in the Editor, as well as some unsupported platforms has been restored. A null reference exception when trying to make a purchase no longer occurs.
  • UDP - Added a null check when comparing Store-Specific IDs

Changed:

  • Samsung Galaxy - Support is being deprecated when not using Unity Distribution Portal as a target. The feature will be removed soon. Please use the Unity Distribution Portal package with IAP for full Samsung Galaxy support.

[3.1.0] - 2021-04-15

Added

  • GooglePlay - Google Play Billing Library version 3.0.3.
    • Fixes a broken purchase flow when user resumed their app through the Android Launcher after interrupting an ongoing purchase. Now IStoreListener.OnPurchaseFailed(PurchaseFailureDescription.reason: PurchaseFailureReason.UserCancelled) is called on resumption. E.g. first the user initiates a purchase, then sees the Google purchasing dialog, and sends their app to the background via the device's Home key. They tap the app's icon in the Launcher, see no dialog, and, finally, the app will now receive this callback.

Changed

  • string StandardPurchasingModule.k_PackageVersion is obsolete and will incorrectly report "3.0.1". Please use the new string StandardPurchasingModule.Version to read the correct current version of this package.
  • Reduced logging, and corrected the severity of several logs.

Fixed

  • tvOS - build errors due to undesirable call to [[SKPaymentQueue defaultQueue] presentCodeRedemptionSheet] which will now only be used for iOS 14.
  • tvOS, macOS - Builds missing Xcode project In-App Purchasing capability and StoreKit.framework.
  • Security - Tangle files causing compilation errors on platforms not supported by Security: non-GooglePlay and non-Apple.
  • GooglePlay - Subscription upgrade/downgrade using proration mode DEFERRED (via IGooglePlayStoreExtensions.UpgradeDowngradeSubscription(string oldSku, string newSku, int desiredProrationMode)) reported OnPurchaseFailed with PurchaseFailureReason.Unknown, when the deferred subscription upgrade/downgrade succeeded. This subscription change generates no immediate transaction and no receipt. Now a custom Action<Product> can be called when the change succeeds, and is set by the new SetDeferredProrationUpgradeDowngradeSubscriptionListener API:
    • Adds IGooglePlayStoreExtensions.SetDeferredProrationUpgradeDowngradeSubscriptionListener(Action<Product> action). Sets listener for deferred subscription change events. Deferred subscription changes only take effect at the renewal cycle and no transaction is done immediately, therefore there is no receipt nor token. The Action<Product> is the deferred subscription change event. No payout is granted here. Instead, notify the user that the subscription change will take effect at the next renewal cycle.

[3.0.2] - 2021-03-30

Added

  • Comprehensive manual and API documentation.

[3.0.1] - 2021-03-08

Removed

  • Pre-release disclaimer.

[3.0.0] - 2021-03-05

[3.0.0-pre.7] - 2021-03-03

Added

  • GooglePlay - populate Product.receipt for Action<Product> parameter returned by IGooglePlayStoreExtensions.SetDeferredPurchaseListener callback

Changed

  • WinRT - This feature is now shipped as C# code under assembly definitions instead of .dll files.
  • Security - This feature is now shipped as C# code under assembly definitions instead of .dll files.
  • Receipt Validation Obfuscator - The Tangle File Obfuscate function is now Editor-only and no longer part of the Runtime Security module.

Fixed

  • Windows Standalone - launches FakeStore when detected by StandardPurchasingModule; disentangled from WinRT
  • Security - restored Receipt Validation Obfuscator Editor functionality
  • GooglePlay - fix regression, avoiding exception when using IGooglePlayConfiguration while running on a non-Google target

[3.0.0-pre.6] - 2021-02-09

Fixed

  • WinRT - There was a bad path being pointed to by the .dll's meta file, preventing compilation to this target.

[3.0.0-pre.5] - 2021-01-12

Added

public void ShowSubscriptionOfferRedemption(IExtensionProvider extensions)
{
   var appleExtensions = extensions.GetExtension<IAppleExtensions>();
   appleExtensions.PresentOfferRedemptionSheet();
}

Fixed

  • Security and WinRT stub dlls and references to Analytics no longer break builds unsupported platforms like PS4, XboxOne, Switch and Lumin. These platforms are still unsupported but will no longer raise errors on build.

Removed

  • Support for Facebook in-app purchasing is no longer provided. All classes and implementations have been removed.

[3.0.0-pre.4] - 2020-10-09

  • Fix builds for UWP

[3.0.0-pre.3] - 2020-10-09

  • First integration into Unity 2021
  • Includes changes listed in CHANGELOG-ASSETSTORE.md, starting from version 1, ending 2020-10-09
  • This is the first release of the Unified Unity In App Purchasing, combining the old package and its Asset Store Components.

[2.2.2] - 2021-01-19

  • Fixed logs incorrectly formatted showing “purchases({0}): -id of product-”
  • Renamed method IStoreCallback.OnPurchasesRetrieved to IStoreCallback.OnAllPurchasesRetrieved, deprecated old method name. This is to fix a problem when refreshing receipts.

[2.2.1] - 2020-11-19

  • Fixed exposure of function calls at runtime used by the Asset Store Package 2.2.0 and up.

[2.2.0] - 2020-10-22

  • Google Billing v3

[2.1.2] - 2020-09-20

Fix migration tooling's obfuscator file destination path to target Scripts instead of Resources

[2.1.1] - 2020-08-25

  • Fix compilation compatibility with platforms that don't use Unity Analytics (ex: PS4)
  • Fix compilation compatibility with "Scripting Runtime Version" option set to ".Net 3.5 Equivalent (Deprecated)" in Unity 2018.4

[2.1.0] - 2020-06-29

  • Source Code provided instead of precompiled dlls.
  • Live vs Stub DLLs are now using asmdef files to differentiate their targeting via the Editor
  • Fixed errors regarding failing to find assemblies when toggling In-App Purchasing in the Service Window or Purchasing Service Settings
  • Fixed failure to find UI assemblies when updating the Editor version.
  • Added menu to support eventual migration to In-App Purchasing version 3.

[2.0.6] - 2019-02-18

  • Remove embedded prebuilt assemblies.

[2.0.5] - 2019-02-08

  • Fixed Unsupported platform error

[2.0.4] - 2019-01-20

  • Added editor and playmode testing.

[2.0.3] - 2018-06-14

  • Fixed issue related to 2.0.2 that caused new projects to not compile in the editor.
  • Engine dll is enabled for editor by default.
  • Removed meta data that disabled engine dll for windows store.

[2.0.2] - 2018-06-12

  • Fixed issue where TypeLoadException occured while using "UnityEngine.Purchasing" because SimpleJson was not found. fogbugzId: 1035663.

[2.0.1] - 2018-02-14

  • Fixed issue where importing the asset store package would fail due to importer settings.

[2.0.0] - 2018-02-07

  • Fixed issue with IAP_PURCHASING flag not set on project load.