Skip to main content
Question

isActive entitlement returns false after quitting & restarting the app

  • 4 September 2024
  • 6 replies
  • 67 views

Forum|alt.badge.img+6
  • Dedicated Member
  • 27 replies

When a user purchases a subscription we run the code that calls purchase():

const getInfo = useCallback(async () => {
    try {
      const info = await Purchases.getCustomerInfo();
      packageRef.current =
        info?.entitlements?.active?.[entitlementName]?.productIdentifier;

      const { isActive: isEntitled } =
        info?.entitlements?.active?.[entitlementName] || {};

      setIsActive(!!isEntitled);
      if (isEntitled) {
        setSawPaywall(true);
      }
      return info;
    } catch (e) {
      throw new Error((e as Error).message);
    }
  }, [setIsActive]);


const purchase = async (purchasePackage: PurchasesPackage) => {
    try {
      await Purchases.purchasePackage(purchasePackage);
      await getInfo();
    } catch (e) {
      if ((e as Error).message !== 'Purchase was cancelled.') {
        throw new Error((e as Error).message);
      }
    }
  };

After the subscription is successful, the app runs correctly, which navigates to the sign in page and after the user signs in, goes to our home view.

Then, if I quit the app and go back in, the paywall comes back up again.  Instead it should go to the home view.

I have traced this to an issue with the  info?.entitlements?.active?.[entitlementName].isActive part of the response of getCustomerInfo: it is returning false.

So I press “restore purchase” and the app functions fine after that.
What is causing isActive to be false yet the restore purchase updates.  I know there’s a cache on getCustomerInfo

This post has been closed for comments

6 replies

joan-cardona
RevenueCat Staff
Forum|alt.badge.img+6
  • RevenueCat Staff
  • 207 replies
  • September 6, 2024

Hi,

The first thing that I’m noticing is that here `info?.entitlements?.active?.[entitlementName]` you are already getting the entitlements that are active so you don’t need to read isActive from there.

The way to check if a user has entitlements is:
```

if(typeof customerInfo.entitlements.active[<my_entitlement_identifier>] !== "undefined") {
  // Grant user "pro" access
}
``` 

Let me know if this works!


Forum|alt.badge.img+6
  • Author
  • Dedicated Member
  • 27 replies
  • September 6, 2024

I saw that in the documentation, but I felt like reading the actual value of isActive is more explicit that checking if the my_entitlement_identifier exists. 

I will give your option a try


Forum|alt.badge.img+6
  • Author
  • Dedicated Member
  • 27 replies
  • September 6, 2024

I have tried this and it’s the same result:

 LOG  {"isActive": true}
 LOG  {"isActive": true}
 LOG  {"isEntitled": false}
 LOG  {"isActive": false}

Here you can see isActive is what is stored on my device. Then the Purchases.getCustomerInfo() runs and reads the customerInfo object, setting isEntitled to false and then updates my stored device.

If I trigger the restorePurchases() then all is updated correctly from the getCustomerInfo object.


Forum|alt.badge.img+6
  • Author
  • Dedicated Member
  • 27 replies
  • September 6, 2024

I think this is definitely a cache issue on the customer info object. If I let my app sit for more than 5 minutes it seems to work as expected. Other than restore purchases, how can I force update the cache results on RevenueCat?


Forum|alt.badge.img+6
  • Author
  • Dedicated Member
  • 27 replies
  • September 9, 2024
lucksp wrote:

I think this is definitely a cache issue on the customer info object. If I let my app sit for more than 5 minutes it seems to work as expected. Other than restore purchases, how can I force update the cache results on RevenueCat?

I can’t edit my previous post, but even after 5 minutes cache, it’s not guaranteed.  Here are some logs:

 

  • After killing app & reopening, after a successful purchase:
2024-09-06 18:00:46.557 22156-22156 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ App backgrounded

2024-09-06 18:00:46.557 22156-22156 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Found 0 unsynced attributes for App User ID: e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:00:46.558 22156-22156 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ No subscriber attributes to synchronize.

2024-09-06 18:00:49.010 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Debug logging enabled

2024-09-06 18:00:49.010 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ SDK Version - 7.0.1

2024-09-06 18:00:49.010 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Package name - com.identafly.production

2024-09-06 18:00:49.010 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  👤 Initial App User ID - null

2024-09-06 18:00:49.011 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchases configured with response verification: DISABLED

2024-09-06 18:00:49.011 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  👤 Identifying App User ID: e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:00:49.012 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Deleting old synced subscriber attributes that don't belong to e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:00:49.024 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Listener set

2024-09-06 18:00:49.041 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Starting connection for com.android.billingclient.api.BillingClientImpl@4d30063

2024-09-06 18:00:49.047 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Sending latest CustomerInfo to listener.

2024-09-06 18:00:49.053 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  Retrieving customer info with policy: CACHED_OR_FETCHED

2024-09-06 18:00:49.054 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Vending CustomerInfo from cache.

2024-09-06 18:00:49.054 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Checking if cache is stale AppInBackground true

2024-09-06 18:00:49.070 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ App foregrounded

2024-09-06 18:00:49.070 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ CustomerInfo cache is stale, updating from network in foreground.

2024-09-06 18:00:49.071 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  Retrieving customer info with policy: FETCH_CURRENT

2024-09-06 18:00:49.072 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Updating pending purchase queue

2024-09-06 18:00:49.084 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Offerings cache is stale, updating from network in foreground

2024-09-06 18:00:49.085 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  😻 Start Offerings update from network.

2024-09-06 18:00:49.087 22518-22518 [Purchases] - WARN      com.identafly.production             W  Request already scheduled with jitter delay, adding existing callbacks to unjittered request with key: BackgroundAwareCallbackCacheKey(cacheKey=[/subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b/offerings], appInBackground=false)

2024-09-06 18:00:49.088 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Updating pending purchase queue

2024-09-06 18:00:49.096 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Found 0 unsynced attributes for App User ID: e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:00:49.097 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ No subscriber attributes to synchronize.

2024-09-06 18:00:49.120 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Starting connection for com.android.billingclient.api.BillingClientImpl@4d30063

2024-09-06 18:00:49.188 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Billing Service Setup finished for com.android.billingclient.api.BillingClientImpl@4d30063

2024-09-06 18:00:49.190 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Updating pending purchase queue

2024-09-06 18:00:49.259 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Querying purchases

2024-09-06 18:00:49.358 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase of type SUBS with hash MMOfcSL2MVgfi4JCO8/WuxMP5s8=

2024-09-06 18:00:49.359 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Cleaning previously sent tokens

2024-09-06 18:00:49.359 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.359 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Saving tokens [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.359 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.359 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ No pending purchases to sync

2024-09-06 18:00:49.360 22518-22617 [Purchases] - WARN      com.identafly.production             W  Request already scheduled with jitter delay, adding existing callbacks to unjittered request with key: BackgroundAwareCallbackCacheKey(cacheKey=[/subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b], appInBackground=false)

2024-09-06 18:00:49.476 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request started: GET /subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b/offerings

2024-09-06 18:00:49.477 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request completed with status: GET /subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b/offerings 304

2024-09-06 18:00:49.482 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Requesting products from the store with identifiers: core_annual, core_monthly

2024-09-06 18:00:49.496 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Querying purchases

2024-09-06 18:00:49.497 22518-22518 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Querying purchases

2024-09-06 18:00:49.591 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase of type SUBS with hash MMOfcSL2MVgfi4JCO8/WuxMP5s8=

2024-09-06 18:00:49.591 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Cleaning previously sent tokens

2024-09-06 18:00:49.592 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.592 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Saving tokens [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.592 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.593 22518-22610 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ No pending purchases to sync

2024-09-06 18:00:49.593 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Products request finished for core_annual, core_monthly

2024-09-06 18:00:49.594 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  💰 Retrieved productDetailsList: ProductDetails{jsonString='{"productId":"core_annual","type":"subs","title":"Annual Subscription (IdentaFly: A.I. Fly Fishing)","name":"Annual Subscription","description":"Annual Access to IdentaFly","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_","subscriptionOfferDetails":[{"offerIdToken":"AdogOgGtzbj3ECwWHBmd5PSeFIKYw\/+Ra0IMvtAojx6YKXWoOnecpAtlIMqYYu8XzHnxB0N+ndI1ayY=","basePlanId":"annual","pricingPhases":[{"priceAmountMicros":29990000,"priceCurrencyCode":"USD","formattedPrice":"$29.99","billingPeriod":"P1Y","recurrenceMode":1}],"offerTags":[]}]}', parsedJson={"productId":"core_annual","type":"subs","title":"Annual Subscription (IdentaFly: A.I. Fly Fishing)","name":"Annual Subscription","description":"Annual Access to IdentaFly","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_","subscriptionOfferDetails":[{"offerIdToken":"AdogOgGtzbj3ECwWHBmd5PSeFIKYw\/+Ra0IMvtAojx6YKXWoOnecpAtlIMqYYu8XzHnxB0N+ndI1ayY=","basePlanId":"annual","pricingPhases":[{"priceAmountMicros":29990000,"priceCurrencyCode":"USD","formattedPrice":"$29.99","billingPeriod":"P1Y","recurrenceMode":1}],"offerTags":[]}]}, productId='core_annual', productType='subs', title='Annual Subscription (IdentaFly: A.I. Fly Fishing)', productDetailsToken='AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_', subscriptionOfferDetails=[com.android.billingclient.api.ProductDetails$SubscriptionOfferDetails@9408f8]}, ProductDetails{jsonString='{"productId":"core_monthly","type":"subs","title":"Monthly Subscription (IdentaFly: A.I. Fly Fishing)","name":"Monthly Subscription","description":"Access to all features","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i","subscriptionOfferDetails":[{"offerIdToken":"AdogOgHDux53e4\/dKsHmZ0r5gE9aO\/5OgAcAb\/1Q5CIj6+8l+016VWFGmpbTyfA9VHigXsk5Lvw7yRiO0+Ay","basePlanId":"monthly","pricingPhases":[{"priceAmountMicros":5990000,"priceCurrencyCode":"USD","formattedPrice":"$5.99","billingPeriod":"P1M","recurrenceMode":1}],"offerTags":[]}]}', parsedJson={"productId":"core_monthly","type":"subs","title":"Monthly Subscription (IdentaFly: A.I. Fly Fishing)","name":"Monthly Subscription","description":"Access to all features","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i","subscriptionOfferDetails":[{"offerIdToken":"AdogOgHDux53e4\/dKsHmZ0r5gE9aO\/5OgAcAb\/1Q5CIj6+8l+016VWFGmpbTyfA9VHigXsk5Lvw7yRiO0+Ay","basePlanId":"monthly","pricingPhases":[{"priceAmountMicros":5990000,"priceCurrencyCode":"USD","formattedPrice":"$5.99","billingPeriod":"P1M","recurrenceMode":1}],"offerTags":[]}]}, productId='core_monthly', productType='subs', title='Monthly Subscription (IdentaFly: A.I. Fly Fishing)', productDetailsToken='AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i', subscriptionOfferDetails=[com.android.billingclient.api.ProductDetails$SubscriptionOfferDetails@19391d1]}

2024-09-06 18:00:49.595 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  💰 core_annual - ProductDetails{jsonString='{"productId":"core_annual","type":"subs","title":"Annual Subscription (IdentaFly: A.I. Fly Fishing)","name":"Annual Subscription","description":"Annual Access to IdentaFly","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_","subscriptionOfferDetails":[{"offerIdToken":"AdogOgGtzbj3ECwWHBmd5PSeFIKYw\/+Ra0IMvtAojx6YKXWoOnecpAtlIMqYYu8XzHnxB0N+ndI1ayY=","basePlanId":"annual","pricingPhases":[{"priceAmountMicros":29990000,"priceCurrencyCode":"USD","formattedPrice":"$29.99","billingPeriod":"P1Y","recurrenceMode":1}],"offerTags":[]}]}', parsedJson={"productId":"core_annual","type":"subs","title":"Annual Subscription (IdentaFly: A.I. Fly Fishing)","name":"Annual Subscription","description":"Annual Access to IdentaFly","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_","subscriptionOfferDetails":[{"offerIdToken":"AdogOgGtzbj3ECwWHBmd5PSeFIKYw\/+Ra0IMvtAojx6YKXWoOnecpAtlIMqYYu8XzHnxB0N+ndI1ayY=","basePlanId":"annual","pricingPhases":[{"priceAmountMicros":29990000,"priceCurrencyCode":"USD","formattedPrice":"$29.99","billingPeriod":"P1Y","recurrenceMode":1}],"offerTags":[]}]}, productId='core_annual', productType='subs', title='Annual Subscription (IdentaFly: A.I. Fly Fishing)', productDetailsToken='AEuhp4JgZjCtgW-5_nRFtetsy80omNtGDpR5bIBCORdfUMl_ccvJdHzUmmo8k0htt9W_', subscriptionOfferDetails=[com.android.billingclient.api.ProductDetails$SubscriptionOfferDetails@9408f8]}

2024-09-06 18:00:49.595 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  💰 core_monthly - ProductDetails{jsonString='{"productId":"core_monthly","type":"subs","title":"Monthly Subscription (IdentaFly: A.I. Fly Fishing)","name":"Monthly Subscription","description":"Access to all features","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i","subscriptionOfferDetails":[{"offerIdToken":"AdogOgHDux53e4\/dKsHmZ0r5gE9aO\/5OgAcAb\/1Q5CIj6+8l+016VWFGmpbTyfA9VHigXsk5Lvw7yRiO0+Ay","basePlanId":"monthly","pricingPhases":[{"priceAmountMicros":5990000,"priceCurrencyCode":"USD","formattedPrice":"$5.99","billingPeriod":"P1M","recurrenceMode":1}],"offerTags":[]}]}', parsedJson={"productId":"core_monthly","type":"subs","title":"Monthly Subscription (IdentaFly: A.I. Fly Fishing)","name":"Monthly Subscription","description":"Access to all features","localizedIn":["en-US"],"skuDetailsToken":"AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i","subscriptionOfferDetails":[{"offerIdToken":"AdogOgHDux53e4\/dKsHmZ0r5gE9aO\/5OgAcAb\/1Q5CIj6+8l+016VWFGmpbTyfA9VHigXsk5Lvw7yRiO0+Ay","basePlanId":"monthly","pricingPhases":[{"priceAmountMicros":5990000,"priceCurrencyCode":"USD","formattedPrice":"$5.99","billingPeriod":"P1M","recurrenceMode":1}],"offerTags":[]}]}, productId='core_monthly', productType='subs', title='Monthly Subscription (IdentaFly: A.I. Fly Fishing)', productDetailsToken='AEuhp4I5Mr4yAWMR-MoJG23kC5-A-x2TkOsKGACuiumqyx9IEh9zgNMAfI1jicpVuQ_i', subscriptionOfferDetails=[com.android.billingclient.api.ProductDetails$SubscriptionOfferDetails@19391d1]}

2024-09-06 18:00:49.597 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase of type SUBS with hash MMOfcSL2MVgfi4JCO8/WuxMP5s8=

2024-09-06 18:00:49.597 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Cleaning previously sent tokens

2024-09-06 18:00:49.597 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.598 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Saving tokens [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.600 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:00:49.600 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ No pending purchases to sync

2024-09-06 18:00:49.849 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Vending Offerings from cache

2024-09-06 18:00:49.849 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Checking if cache is stale AppInBackground false

2024-09-06 18:00:49.873 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  Retrieving customer info with policy: CACHED_OR_FETCHED

2024-09-06 18:00:49.874 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Vending CustomerInfo from cache.

2024-09-06 18:00:49.874 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Checking if cache is stale AppInBackground false

2024-09-06 18:00:49.936 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request started: GET /subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:00:49.936 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request completed with status: GET /subscribers/e5573727-fb06-4da5-9c01-02ccb7dea17b 304

2024-09-06 18:00:49.937 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  😻 CustomerInfo updated from network.

2024-09-06 18:00:50.090 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ setAttributes called
  • Here is the log result for "RESTORE PURCHASE"2024-09-06 18:02:15.947 22518-22567
[Purchases] - DEBUG     com.identafly.production             D  ℹ️ Restoring purchases
2024-09-06 18:02:15.949 22518-22567 [Purchases] - WARN      com.identafly.production             W  ⚠️ allowSharingPlayStoreAccount is set to false and restorePurchases has been called. This will 'alias' any app user id's sharing the same receipt. Are you sure you want to do this? More info here: https://errors.rev.cat/allowsSharingPlayStoreAccount

2024-09-06 18:02:15.951 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Querying purchase history for type subs

2024-09-06 18:02:16.206 22518-22617 [Purchases] - INFO      com.identafly.production             I  😻💰 Purchase history retrieved skus: [core_monthly], purchaseTime: 1725667155810, purchaseToken: idieljaogooonnbjmjogbjgp.AO-J1Ow3xprkryb2qBZggdebBALBpSdTxaXDVmJPUROcoMNfBIqtMsfUHD4GOyltMczp7rOYLDkLRjJgTBooAgdAqr2TSff0Gaf6UX2kjBXao5NkYzdSGGE

2024-09-06 18:02:16.207 22518-22617 [Purchases] - INFO      com.identafly.production             I  😻💰 Purchase history retrieved skus: [core_annual], purchaseTime: 1725293834618, purchaseToken: aibmeklekjjmeneopoimeien.AO-J1OwLDbDOJxrDTCPpPSCKE0eFrQsf0EKWt6JB-CJBXxGpQKs403EymRbvTxnCuO9khuMbHJ4Igchm7pgk1xRaLfHdCnBggnmZ-XsDtTIr4YQVRrGT74M

2024-09-06 18:02:16.209 22518-22617 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Querying purchase history for type inapp

2024-09-06 18:02:16.373 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase history is empty.

2024-09-06 18:02:16.376 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Found 0 unsynced attributes for App User ID: e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:02:16.383 22518-22616 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Found 0 unsynced attributes for App User ID: e5573727-fb06-4da5-9c01-02ccb7dea17b

2024-09-06 18:02:21.744 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request started: POST /receipts

2024-09-06 18:02:21.745 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request completed with status: POST /receipts 200

2024-09-06 18:02:21.748 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ CustomerInfo updated, sending to listener.

2024-09-06 18:02:21.750 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  💰 Acknowledging purchase with token aibmeklekjjmeneopoimeien.AO-J1OwLDbDOJxrDTCPpPSCKE0eFrQsf0EKWt6JB-CJBXxGpQKs403EymRbvTxnCuO9khuMbHJ4Igchm7pgk1xRaLfHdCnBggnmZ-XsDtTIr4YQVRrGT74M

2024-09-06 18:02:21.751 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase StoreTransaction(orderId=null, productIds=[core_annual], type=SUBS, purchaseTime=1725293834618, purchaseToken=aibmeklekjjmeneopoimeien.AO-J1OwLDbDOJxrDTCPpPSCKE0eFrQsf0EKWt6JB-CJBXxGpQKs403EymRbvTxnCuO9khuMbHJ4Igchm7pgk1xRaLfHdCnBggnmZ-XsDtTIr4YQVRrGT74M, purchaseState=UNSPECIFIED_STATE, isAutoRenewing=null, signature=RFIdSVHaM9uluA/t9NvD1RjuNLeoCBpUyW0EhorhBTjn0aDAHJidxOPmDufmlWF+wViCrHKd+uj31CtoMSExItTWohkuUkKR3qHjaVIa5kh6qmIo7bqBxE9yJM0LNM0tb/Cu58VLfQCMPLy81SUbN5grf4N9kSGQk0nV3kar+vNG0WSk3nr2EUkc2VE2evHIDojaX1T1von9/fZhfDr27DlweOMjP/+BkmZWmFjTte4EW2UKjDmgpmPKv+FJswFaXaO/uhW2PJDa6GT7fAL/2YQXDrRhz2ZltuqJxHd9Dm7cZhZuqxn1T29maDYDviR+1EA80AhX4gU+kJzHsmI41Q==, originalJson={"productId":"core_annual","purchaseToken":"aibmeklekjjmeneopoimeien.AO-J1OwLDbDOJxrDTCPpPSCKE0eFrQsf0EKWt6JB-CJBXxGpQKs403EymRbvTxnCuO9khuMbHJ4Igchm7pgk1xRaLfHdCnBggnmZ-XsDtTIr4YQVRrGT74M","purchaseTime":1725293834618,"quantity":1,"developerPayload":null}, presentedOfferingIdentifier=null, storeUserID=null, purchaseType=GOOGLE_RESTORED_PURCHASE, marketplace=null, subscriptionOptionId=null, replacementMode=null) restored

2024-09-06 18:02:21.915 22518-22610 [Purchases] - ERROR     com.identafly.production             E  🤖‼️ Error acknowledging purchase. Will retry next queryPurchases. DebugMessage: Item is not owned by the user.. ErrorCode: ITEM_NOT_OWNED.

2024-09-06 18:02:22.478 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request started: POST /receipts

2024-09-06 18:02:22.479 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  API request completed with status: POST /receipts 200

2024-09-06 18:02:22.483 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  💰 Acknowledging purchase with token idieljaogooonnbjmjogbjgp.AO-J1Ow3xprkryb2qBZggdebBALBpSdTxaXDVmJPUROcoMNfBIqtMsfUHD4GOyltMczp7rOYLDkLRjJgTBooAgdAqr2TSff0Gaf6UX2kjBXao5NkYzdSGGE

2024-09-06 18:02:22.484 22518-22600 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Purchase StoreTransaction(orderId=null, productIds=[core_monthly], type=SUBS, purchaseTime=1725667155810, purchaseToken=idieljaogooonnbjmjogbjgp.AO-J1Ow3xprkryb2qBZggdebBALBpSdTxaXDVmJPUROcoMNfBIqtMsfUHD4GOyltMczp7rOYLDkLRjJgTBooAgdAqr2TSff0Gaf6UX2kjBXao5NkYzdSGGE, purchaseState=UNSPECIFIED_STATE, isAutoRenewing=null, signature=OB0hdmk3P+rgM2th+yP92B8HD7qm1HLP3Z+0Jnhlu9EwuSejIfsI9EIOph0iVKLBdIiKF3vhcP6WHUZX6bViGQZiCtOs63XGHm29Ye0/8wSSc+3ATpPPMnF+5aPOvNwN4MPeR2AbN9fCq27eQnzyyMfzmpjJveq3eloqiPR4OXPWXadz30hm8Jf9uPpxZFs0b4DPWqriTTKAL+14ohD0TXbRHG0F7wF7ujO26wO6VldiCWlbrnNt7huWvUJk7ytWQ84gGKh5blH5p5Qtc6VtGcxXVMptuS/3d9CfGwi3eRg1LSxN1oi8drPmiyK1fWc9bPAlDpaKzqZ7M09UWqHCPA==, originalJson={"productId":"core_monthly","purchaseTime":1725667155810,"purchaseToken":"idieljaogooonnbjmjogbjgp.AO-J1Ow3xprkryb2qBZggdebBALBpSdTxaXDVmJPUROcoMNfBIqtMsfUHD4GOyltMczp7rOYLDkLRjJgTBooAgdAqr2TSff0Gaf6UX2kjBXao5NkYzdSGGE","quantity":1}, presentedOfferingIdentifier=null, storeUserID=null, purchaseType=GOOGLE_RESTORED_PURCHASE, marketplace=null, subscriptionOptionId=null, replacementMode=null) restored

2024-09-06 18:02:22.493 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  Retrieving customer info with policy: CACHED_OR_FETCHED

2024-09-06 18:02:22.496 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Vending CustomerInfo from cache.

2024-09-06 18:02:22.496 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Checking if cache is stale AppInBackground false

2024-09-06 18:02:22.651 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Saving token idieljaogooonnbjmjogbjgp.AO-J1Ow3xprkryb2qBZggdebBALBpSdTxaXDVmJPUROcoMNfBIqtMsfUHD4GOyltMczp7rOYLDkLRjJgTBooAgdAqr2TSff0Gaf6UX2kjBXao5NkYzdSGGE with hash MMOfcSL2MVgfi4JCO8/WuxMP5s8=

2024-09-06 18:02:22.651 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens already posted: [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:02:22.652 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Tokens in cache before saving [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:02:22.652 22518-22620 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Saving tokens [MMOfcSL2MVgfi4JCO8/WuxMP5s8=]

2024-09-06 18:02:23.767 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  Retrieving customer info with policy: CACHED_OR_FETCHED

2024-09-06 18:02:23.768 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Vending CustomerInfo from cache.

2024-09-06 18:02:23.769 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ Checking if cache is stale AppInBackground false

2024-09-06 18:02:24.236 22518-22567 [Purchases] - DEBUG     com.identafly.production             D  ℹ️ setAttributes called

As you can see, there is a line item: "💰 Acknowledging purchase with token" after refreshing.  

Why is this not available when opening the app prior?


  • New Member
  • 1 reply
  • September 9, 2024

We seem to be having a similar issue, on app launch it’s stale. By re-authenticating or backgrounding and foregrounding the app it seems to work again until you kill and relaunch the app.

We check if a user has entitlements by doing:

EntitlementInfos.active.isNotEmpty()

Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings