Version 5.0 of the RevenueCat SDK enables full StoreKit 2 flow on the SDK and the RevenueCat backend by default.
We have been testing StoreKit 2 support in parallel to StoreKit 1 in our backend for a while and we believe it is ready for widespread use.
Here's some of the benefits you get with StoreKit 2:
- Better handling of a few specific edge cases which were unfixable with StoreKit 1:
- No more "Missing receipt" errors in Sandbox that could result in failure restoring purchases or getting trial eligibility status "unknown".
- No more "The purchased product was missing in the receipt" error that could cause an invalid receipt error when making a purchase.
- Future proofing: StoreKit 1 APIs are being progressively deprecated by Apple, and new features are being added to StoreKit 2.
- Faster processing time: More efficient and performant implementation of receipts validation. We have found that receipts validation can be ~200ms faster comparing to SK1 implementation for p95 of the requests.
In order to use StoreKit 2, you will need to configure your In-App Purchase Key in the RevenueCat dashboard.
The previously deprecated configuration option .with(usesStoreKit2IfAvailable: true)
has been removed. Remove it from your configuration option to continue using StoreKit 2.
The SDK will automatically use StoreKit 1 in the following versions where StoreKit 2 is not supported: on macOS 11 or earlier, iOS 14 or earlier, iPadOS 14 or earlier, tvOS 14 or earlier, or watchOS 7 or earlier.
If for any reason you need to always use StoreKit 1, it is possible to switch back using the following configuration API:
Purchases.configure(with: .builder(withAPIKey: apiKey)
.with(storeKitVersion: .storeKit1)
.build()
If you are using any 3rd party analytics SDKs to automatically track in-app purchases, you need to be aware most of them do not completely support logging purchases made with StoreKit 2. This is the case for some popular SDKs like Facebook, Mixpanel, OneSignal, Segment or Firebase. For these services, we recommend you use our data integrations.
If you're using the Firebase SDK, you'll need to follow these instructions to log purchases made with StoreKit 2.
Version 5.0 of the SDK introduces support for observer mode when making purchases with StoreKit 2. You can enable it when configuring the SDK:
Purchases.configure(with: .builder(withAPIKey: apiKey)
.with(observerMode: true, storeKitVersion: .storeKit2)
.build()
Additionally, because of the way in which StoreKit 2 operates, you must manually handle newly purchased transactions by calling Purchases.shared.handleObserverModeTransaction()
. Subscription updates will be automatically tracked.
let result = try await product.purchase()
Purchases.shared.handleObserverModeTransaction(result)
If you're using observer mode with StoreKit 1, you will need to explicitly configure the SDK to use StoreKit 1:
Purchases.configure(with: .builder(withAPIKey: apiKey)
.with(observerMode: true, storeKitVersion: .storeKit1)
.build()
If you're converting a paid app to in-app subscriptions, and want to provide existing customers with certain features, we recommend using the "original app version" field in customer info.
Because of a limitation of StoreKit 2, this field is not available if the customer is running on iOS 15, tvOS 15, macOS 12 or watchOS 8. If this is a requirement for you, we recommend switching back to StoreKit 1.
Version 5.0 of the SDK enables the Informational mode for Trusted Entitlements by default.
Informational mode logs verification errors and allow you to check customerInfo.entitlements.verificationResult
to protect your purchases from attackers.
See the Trusted Entitlements documentation for more information.
The minimum targets have been raised to the folllowing:
- iOS 13.0
- tvOS 13.0
- watchOS 6.2
- macOS 10.15
Pre-built .frameworks
are no longer included in releases, only .xcframeworks
: #3582
- The scope of the View extension
onChangeOf
is changed frompublic
tointernal
- This was never intended to be made public and to be used outside of the RevenueCat SDK