Skip to content

Latest commit

 

History

History
397 lines (260 loc) · 16.9 KB

CHANGELOG.md

File metadata and controls

397 lines (260 loc) · 16.9 KB

3.3.0

⚠️ Breaking Changes

Activation

  • You no longer need to activate AdaptyUI separately, as it is now handled automatically during the usual activation process. Use .withMediaCacheConfiguration in AdaptyConfiguration if you wish to override the default settings:
await Adapty().activate(
  configuration: AdaptyConfiguration(apiKey: 'YOUR_API_KEY')
    ..withMediaCacheConfiguration(...),
);

Integrations and Attribution Configuration. Read More.

  • New Method for Setting Integration Identifiers:

    • Introduced setIntegrationIdentifier(key:value:):
      • Previously, integrations were configured using the updateProfile method, passing integration IDs to the builder.
      • Now, use setIntegrationIdentifier to set integration identifiers with a key and value.
  • Updated updateAttribution Method:

    • The source parameter is now a String instead of an enum.
    • The networkUserId parameter has been removed. Use setIntegrationIdentifier to set the networkUserId instead.

Observer Mode. Read More.

  • ‼️ Transactions must now be explicitly reported when using Observer Mode:
    • Replace calls to setVariationId() with reportTransaction(transactionId:,variationId:) after every transaction.finish().
    • The variationId parameter in reportTransaction is now optional.

3.2.5

  • [iOS] Fix errors in Xcode 15.0 (#100).
  • [iOS] Fix an issue where an unwanted profile was sometimes created after the identify method was called

3.2.4

  • [iOS] Added support for Xcode 16.2
  • [iOS] Fixed support for Xcode 15.x

3.2.3

  • AdaptyUI: Internal improvements to paywall rendering
  • Fixed an issue where isActivated() method returned incorrect value
  • Fixed an issue where content field of AdaptyUIDialog was not displaying correctly
  • Fixed an issue with subscriptionUpdateParams wrong serialization
  • Added setupAfterHotRestart method to Adapty and AdaptyUI which allows you to initialize the plugin after hot restart. Please check isActivated before calling this method. Please consider using this method in debug builds only to avoid any unexpected issues in release builds.

3.2.2

  • added missing models exports

3.2.1

  • AdaptyErrorCode change final to const
  • [Android] Plugin fix

3.2.0

🎉 Meet the Adapty Flutter SDK 3.2.0!

With this version we're introducing support for the new paywall builder that offers more templates and layout flexibility. Note that:

  • This version doesn't support paywalls created in the legacy (current) paywall builder
  • But you can easily migrate those with a single press of a button in Adapty Dashboard

On top of that, this version also offers complete support of StoreKit 2 and Swift 6 on the iOS side. See more here.

Breaking Changes:

  • Adapty and AdaptyUI are now a single module, so you don't need to import them separately.
  • makePurchase now returns AdaptyPurchaseResult instead of AdaptyPurchasedInfo.
  • getProductsIntroductoryOfferEligibility(products:) has been removed. The getPaywallProducts function now returns a product object with prepopulated offer information. Consider using the getPaywallProductsWithoutDeterminingOffer(paywall:) method if you need to load products without determining offer eligibilities.
  • paywallViewDidFinishPurchase now accepts AdaptyPurchaseResult instead of AdaptyPurchasedInfo.
  • paywallViewDidSelectProduct now accepts String (productId) instead of AdaptyPaywallProduct.
  • paywallViewDidCancelPurchase has been removed. Please use the purchaseResult from paywallViewDidFinishPurchase to detect purchase cancellations.

2.10.4

  • [Android] Add parameters to activate method

2.10.3

  • Support for Flutter 3.22+

2.10.2

  • Support for Flutter 3.22+

2.10.1

  • Support for Adapty iOS SDK 2.10.3
  • Support for Adapty Android SDK 2.10.4

2.10.0

⚠️ Warning: In this version, we have changed the minimal supported versions:

  • The minimal iOS version is now 12.2.
  • The minimal Xcode version is now 15.0.

⚠️ Breaking Changes:

  • [iOS] We are no longer support AdaptyStoreKit2Usage parameter in the the Adapty-Info.plist method. Adapty SDK now utilizes the StoreKit 2 method for introductory offer eligibility checks if available.

2.9.3

  • [Android] Fixed the incorrect format of some analytics events in rare cases.

2.9.2

  • Added support for AdaptyUI 2.1.x
  • [iOS] Fixed an issue with wrong device name in some cases on MacOS.

2.9.1

  • [iOS] Fixed support for Swift 5.7.x (Xcode 14.0 - 14.2)
  • [iOS] Fixed an issue with repeated calls to the API when the device is offline
  • [Android] Redesigned analytics event system
  • [Android] Improved mechanism for usage logs collection

2.9.0

⚠️ Warning: This version relies on StoreKit 2 instead of StoreKit 1. Starting from this version, you must connect your account to Apple In-App Purchase API in Adapty Dashboard. Otherwise, we won't be able to make or validate purchases.

New:

  • Since this version we are using CDN. This technology helps us to synchronize data much faster.
  • Added an option to retrieve paywalls from local cache by passing fetchPolicy parameter into .getPaywall() method
  • Added an option to specify paywall fetching timeout by passing loadTimeout parameter into .getPaywall() method

Read More in our documentation.

Breaking Changes:

  • placementId parameter has been added to the getPaywall method, replacing the previously unnamed parameter id. Read More
  • AdaptyEnableUsageLogs of Adapty-Info.plist is no longer supported, since this feature is enabled by default. Read More
  • If you will not put the AdaptyStoreKit2Usage parameter to Adapty-Info.plist, the default value will be .forIntroEligibilityCheck (this means that by default we will fetch introductory offers eligibility using StoreKit 2). Read More

2.7.1

  • [Android] fixes for AdaptyUI library

2.7.0

  • [iOS] Update Adapty-iOS dependency to 2.7.0
  • [Android] Update Adapty-Android dependency to 2.7.0

2.6.2

  • [Android] Updated retry logic according to new PBL error.

2.6.1

  • [Android] Fixed error on purchase validation.
  • [Android] Support for Google Billing Library v5+. Read More
  • [iOS] Since this version, the Adapty SDK will observe StoreKit 2 transactions, which will be helpful if you are using observer mode.
  • [iOS] Introduced a new functionality for retrieving introductory offers eligibility using StoreKit 2. To fetch it, you should now use a separate method called .getProductsIntroductoryOfferEligibility. The behavior of this function depends on your Adapty SDK configuration. It will utilize StoreKit 2 if available or fallback to a legacy logic based on receipt analysis. For more detailed information, please refer to our documentation. Read more
  • AdaptyPaywallProduct now has a unified structure for both systems.

2.6.0

  • [Android] Support for Google Billing Library v5+. Read More
  • [iOS] Since this version, the Adapty SDK will observe StoreKit 2 transactions, which will be helpful if you are using observer mode.
  • [iOS] Introduced a new functionality for retrieving introductory offers eligibility using StoreKit 2. To fetch it, you should now use a separate method called .getProductsIntroductoryOfferEligibility. The behavior of this function depends on your Adapty SDK configuration. It will utilize StoreKit 2 if available or fallback to a legacy logic based on receipt analysis. For more detailed information, please refer to our documentation. Read more
  • AdaptyPaywallProduct now has a unified structure for both systems.

2.4.4

  • Added hasViewConfiguration for AdaptyPaywall object

2.4.3

  • [iOS] Improved variation_id delivery mechanism when validating purchases (iOS 2.4.4)
  • [iOS] Improved mechanism for Usage Logs collection (iOS 2.4.5)
  • [iOS] Fixed a bug which caused wrong error codes from StoreKit to be passed to the cross platform SDKs (iOS 2.4.5)

2.4.2

  • Redesigned analytics event system
  • Added an option to activate usage logs
  • isOneTime property of AdaptyProfile.NonSubscription was deprecated, use isConsumable instead

2.4.1

  • [Android] fixed subscription change functionality

2.4.0

  • Changed the logic of working with fallback paywalls - now the SDK will not wait for the creation of a profile
  • Added an option to set airbridgeDeviceId to user profile
  • The logging system has been improved: all requests and responses from the server are now logged in verbose mode, and the computation required for logging has been optimized
  • Increased the length and number of custom attributes

2.3.1

  • [Android] updated dependency to 2.3.2

2.3.0

  • Added an option to specify the paywall locale.
  • [iOS] updated dependency to 2.3.3
  • [Android] updated dependency to 2.3.1

2.2.5

  • [iOS] Fixed a bug that caused a new anonymous user to be created when migrating from earlier versions of the SDK.

2.2.4

  • [iOS] Fixed didUpdateProfileStream serialization bug.

2.2.3

  • Added integration with Firebase and Google Analytics. Read more.
  • [Android] Fixed a bug when products returned in a wrong order

2.2.2

  • [iOS] Fixed a bug when some additional purchase parameters were not sent in Observer Mode.

2.2.1

  • [Android] fixed parsing error for free trial fields.
  • Updated errors documentation.

2.2.0

Meet the second version of the Adapty SDK 🎉

See our What's new in Adapty Flutter SDK 2.0 doc for API updates. Adapty 2.0 introduces the following updates:

Breaking changes:

  • Adapty now is singleton. Use Adapty().someMethodCall() instead of Adapty.someMethodCall()
  • User-initiated purchases are now automatically processed by the system, so we have removed the deferredPurchasesStream and makeDeferredPurchase() method.
  • We are no longer support Visual Paywalls and Promo Campaigns features, so you should remove the calls to the corresponding methods, if there were any
  • Instead of getting all paywalls in one request with the .getPaywalls(), it must be done separately for each paywall using .getPaywall(id:)
  • Products are no longer part of the paywall, they must be loaded separately with .getPaywallProducts(paywall:)
  • It is no longer possible to use products outside of the paywall. If you need to handle a product, create a separate paywall for it (or for multiple products).
  • introductoryOfferEligibility – instead of true/false we give a more extended list of options
  • The AdaptyProfileParametersBuilder is redesigned:
    • Methods, related to custom attributes now can throw an exception, if key or value didn't pass validation
    • Added an option to pass null values to builder functions for more convenience
    • You can now remove customAttributes with the function .removeCustomAttribute("key")
    • You have to use .build() method and pass resulting AdaptyProfileParameters object to .updateProfile method
  • .setAnalyticsDisabled() method has been eliminated. Use the .setAnalyticsDisabled method of AdaptyProfileParametersBuilder.
  • The forceUpdate parameter was removed from the getPaywall method. The result will always be up to date if it is possible to retrieve data from the server

Renames

  • PurchaserInfo renamed to AdaptyProfile
  • .getPurchaserInfo renamed to .getProfile
  • didReceivePurchaserInfoStream was also renamed to .didUpdateProfileStream
  • developerId field of AdaptyPaywall was renamed to id
  • AdaptyAttributionNetwork renamed to AdaptyAttributionSource

Fixes

  • Fixed wrong behavior of fallback paywalls in some cases
  • .setFallbackPaywalls() method now does not return errors related to StoreKit product retrieval
  • Incorrect user segmentation in some rare cases

Additions:

  • Ability to log onboard screens with .logShowOnboarding(). Read more
  • Added ability to get previously set customAttributes, now it is part of AdaptyProfile

Under the hood:

  • The server interaction layer was rewritten from scratch.
  • The initial request sequence has been optimized and simplified
  • Reduced the number of API calls made by SDK. Some of the request are now faster and transfer less data.
  • Independent requests can be executed simultaneously
  • StoreKit interaction layer was refactored

Full documentation can be found in here.

1.0.14

  • Fixed type cast in the makeDeferredPurchase method

1.0.13

  • Upgraded with iOS SDK version 1.17.7 and Android SDK version 1.11.0

1.0.12

  • [Android] fixed localized properties

1.0.11

  • Support for Flutter 3.0

1.0.10

  • Ability to use Adapty-Info.plist for storing initialization parameters

1.0.9

  • The getPromo method now works for Android Issue 34
  • Fixed typo in word "deferred" Issue 35

1.0.8

  • Updated PurchaserInfoModel property profileId access level to public

1.0.7

  • [iOS] Added support for disabling IDFA collection
  • [Android] Improved handling clicks on push notifications

1.0.6

  • [iOS] Added support for AdServices attribution tracking
  • [Android] internal sdk improvements

1.0.5

  • [Android] added logLevel ALL, logLevel VERBOSE doesn't include analytical logs, but ALL does
  • changed example for updating custom attribution
  • various improvements

1.0.4

  • added toString for AdaptyAccessLevelInfo, AdaptySubscriptionInfo, AdaptyNonSubscriptionInfo models

1.0.3

  • Added new log level "all"
  • Fallback paywalls offline work
  • [iOS] Added optional offerId parameter to makePurchase method

1.0.2

  • [iOS] Updated AdaptyProfileParameterBuilder to work with ATTrackingManager.AuthorizationStatus
  • Removed usage of dart ffi
  • Made receipt validation api method private

1.0.1

  • [Android] Added support for fallback paywalls

1.0.0

  • Graduate package to a stable release. See pre-releases prior to this version for changelog entries.

1.0.0-nullsafety.0

  • Enable null safety
  • Require Dart 2.12 or greater.

0.3.6

  • [Android] fixed localizedTitle in product

0.3.5

  • [iOS] Added isFamilyShareable property to product for iOS 14+.
  • [iOS] Added .presentCodeRedemptionSheet() to public SDK API

0.3.4

  • [Android] Small fix in requests

0.3.3

  • [iOS] Added retry for createProfile request in case of poor connection or if server is down.
  • [Android] Added gzip support
  • Removed unnecessary event channel invocations for .getPaywalls() and .getPurchaserInfo() methods

0.3.2

  • Fixed .getPaywalls() callback without an internet connection (Android only)

0.3.1

  • Added .setFacebookAnonymousId method to AdaptyProfileParameterBuilder
  • Added freeTrialPeriod property of AdaptyProduct model (Android only)

0.3.0

  • Added ability to connect observer mode purchase with a paywall it was made from using .setTransactionVariationId method
  • Added ability to opt-out from external analytics services using .setExternalAnalyticsEnabled method
  • Added public abTestName and name properties to AdaptyPaywall and to nested products array.
  • Paywall views must be reported using .logShowPaywall(paywall) method from now on, otherwise, views will not be collected.

0.2.0

  • Plugin initialization scheme changed to prevent missing transaction on iOS.
  • Added .logShowPaywall(paywall) to manually record paywall show event.
  • Added apnsTokenString to public properties.
  • Removed state from .getPurchaserInfo() callback. Added forceUpdate as an optional request parameter.
  • Removed state from .getPaywalls() callback. Added forceUpdate as an optional request parameter.

0.1.2

  • empty string custom payload fixed
  • updateAttribution() fixed on Android
  • getPurchaserInfo() stability improved
  • verbose logLevel removed as default

0.1.1

  • customPayloadString added to Paywall
  • birthday fix in updateProfile

0.1.0

  • Initial release