Offline Entitlements: use offline-computed CustomerInfo when server is down#2368
Merged
NachoSoto merged 18 commits intoMay 19, 2023
Merged
Conversation
751d43d to
252ab9a
Compare
c7ebe2a to
22d18c2
Compare
252ab9a to
652b749
Compare
22d18c2 to
d4f3c46
Compare
1855511 to
5b90cfb
Compare
f96ff45 to
378d554
Compare
5b90cfb to
5d5f878
Compare
378d554 to
cadce12
Compare
d5f8771 to
9ef25ab
Compare
Offline Entitlements: use offline-computed CustomerInfo when server is downOffline Entitlements: use offline-computed CustomerInfo when server is down
9ef25ab to
bc58d36
Compare
NachoSoto
commented
Mar 23, 2023
Contributor
Author
There was a problem hiding this comment.
This will only crash in DEBUG builds. We only create this prior to iOS15, where offline CustomerInfos aren't computed.
cadce12 to
c00cfdb
Compare
bc58d36 to
dfbb492
Compare
276d952 to
72033e0
Compare
3b4d9eb to
6dfeb74
Compare
Base automatically changed from
nacho/sdk-2987-compute-customerinfo-from-a-list-of
to
main
March 24, 2023 17:41
6dfeb74 to
c94a25a
Compare
14d252b to
777318f
Compare
6115e26 to
8459cb7
Compare
tonidero
approved these changes
May 19, 2023
tonidero
left a comment
Contributor
There was a problem hiding this comment.
Great job on this! I think we are handling all cases pretty well now 👍
| // https://opensource.org/licenses/MIT | ||
| // | ||
| // MockOfflineEntitlementsManager.swift | ||
| // MockOfflineEntitlementsManager.swiftz |
Contributor
There was a problem hiding this comment.
NABD but unintended change?
Contributor
Author
There was a problem hiding this comment.
Fixing in the next PR to avoid running CI just for this 😅
tonidero
approved these changes
May 19, 2023
tonidero
left a comment
Contributor
There was a problem hiding this comment.
Great job on this! I think we are handling all cases pretty well now 👍
NachoSoto
added a commit
to NachoSoto/purchases-ios
that referenced
this pull request
May 19, 2023
commit 8c4db197c672d6811d910b38264f9a3ff153e196
Author: NachoSoto <ignaciosoto90@gmail.com>
Date: Thu May 18 14:12:11 2023 -0700
`PurchasedProductsFetcher`: cache current entitlements
To optimize potentially computing offline `CustomerInfo`, this caches what's likely the most expensive part.
commit aca83398650df220dbdb11b8f2cc6f3656b140d3
Author: NachoSoto <ignaciosoto90@gmail.com>
Date: Thu May 18 13:35:10 2023 -0700
`PurchasedProductsFetcher`: don't throw errors if purchased products were found
This is a best-effort implementation. We can still compute the offline `CustomerInfo` if we found some purchased products.
Extracted from RevenueCat#2368 and added tests.
Contributor
Author
|
I did some initial sanity check and this is working well, so merging! |
NachoSoto
added a commit
that referenced
this pull request
May 19, 2023
…were found This is a best-effort implementation. We can still compute the offline `CustomerInfo` if we found some purchased products. Extracted from #2368 and added tests.
This was referenced May 31, 2023
Closed
NachoSoto
added a commit
that referenced
this pull request
Jun 1, 2023
**This is an automatic release.** ### New Features * `Offline Entitlements`: use offline-computed `CustomerInfo` when server is down (#2368) via NachoSoto (@NachoSoto) ### Bugfixes * `AppleReceipt.debugDescription`: don't pretty-print JSON (#2564) via NachoSoto (@NachoSoto) * `SK2StoreProduct`: fix crash on iOS 12 (#2565) via NachoSoto (@NachoSoto) * `GetCustomerInfo` posts receipts if there are pending transactions (#2533) via NachoSoto (@NachoSoto) ### Performance Improvements * `PurchasedProductsFetcher`: cache current entitlements (#2507) via NachoSoto (@NachoSoto) * Performance: new check to ensure serialization / deserialization is done from background thread (#2496) via NachoSoto (@NachoSoto) ### Dependency Updates * Bump fastlane from 2.212.2 to 2.213.0 (#2544) via dependabot[bot] (@dependabot[bot]) ### Other Changes * `CustomerInfoManager`: post all unfinished transactions (#2563) via NachoSoto (@NachoSoto) * `PostReceiptOperation`: added ability to also post `AdServices` token (#2566) via NachoSoto (@NachoSoto) * `Offline Entitlements`: improved computation log (#2562) via NachoSoto (@NachoSoto) * Added `TransactionPoster` tests (#2557) via NachoSoto (@NachoSoto) * Refactored `TransactionPoster`: removed 2 dependencies and abstracted parameters (#2542) via NachoSoto (@NachoSoto) * `CustomerInfoManagerTests`: wait for `getAndCacheCustomerInfo` to finish (#2555) via NachoSoto (@NachoSoto) * `StoreTransaction`: implemented `description` (#2556) via NachoSoto (@NachoSoto) * `Backend.ResponseHandler` is now `@Sendable` (#2541) via NachoSoto (@NachoSoto) * Extracted `TransactionPoster` from `PurchasesOrchestrator` (#2540) via NachoSoto (@NachoSoto) * `enableAdServicesAttributionTokenCollection`: added integration test (#2551) via NachoSoto (@NachoSoto) * `AttributionPoster`: replaced hardcoded strings with constants (#2548) via NachoSoto (@NachoSoto) * `DefaultDecodable`: moved to `Misc/Codable/DefaultDecodable.swift` (#2528) via NachoSoto (@NachoSoto) * `CircleCI`: specify device to run `backend_integration_tests` (#2547) via NachoSoto (@NachoSoto) * Created `StoreKit2TransactionFetcher` (#2539) via NachoSoto (@NachoSoto) * Fix load shedder integration tests (#2546) via Josh Holtz (@joshdholtz) * Fix doc on `Offering.getMetadataValue` (#2545) via Josh Holtz (@joshdholtz) * Extracted and tested `AsyncSequence.extractValues` (#2538) via NachoSoto (@NachoSoto) * `Offline Entitlements`: don't compute offline `CustomerInfo` when purchasing a consumable products (#2522) via NachoSoto (@NachoSoto) * `OfflineEntitlementsManager`: disable offline `CustomerInfo` in observer mode (#2520) via NachoSoto (@NachoSoto) * `BasePurchasesTests`: fixed leak detection (#2534) via NachoSoto (@NachoSoto) * `PurchaseTesterSwiftUI`: added `ProxyView` to `iOS` (#2531) via NachoSoto (@NachoSoto) * `PurchasedProductsFetcher`: removed `AppStore.sync` call (#2521) via NachoSoto (@NachoSoto) * `PurchaseTesterSwiftUI`: added new window on Mac to manage proxy (#2518) via NachoSoto (@NachoSoto) * `PurchasedProductsFetcher`: added log if fetching purchased products is slow (#2515) via NachoSoto (@NachoSoto) * `Offline Entitlements`: disable for custom entitlements mode (#2509) via NachoSoto (@NachoSoto) * `Offline Entitlements`: fixed iOS 12 tests (#2514) via NachoSoto (@NachoSoto) * `PurchasedProductsFetcher`: don't throw errors if purchased products were found (#2506) via NachoSoto (@NachoSoto) * `Offline Entitlements`: allow creating offline `CustomerInfo` with empty `ProductEntitlementMapping` (#2504) via NachoSoto (@NachoSoto) * `Offline Entitlements`: integration tests (#2501) via NachoSoto (@NachoSoto) * `CustomerInfoManager`: don't cache offline `CustomerInfo` (#2378) via NachoSoto (@NachoSoto) * `DangerousSettings`: debug-only `forceServerErrors` (#2486) via NachoSoto (@NachoSoto) * `CocoapodsInstallation`: fixed `Xcode 14.3.0` issue (#2489) via NachoSoto (@NachoSoto) * `CarthageInstallation`: removed workaround (#2488) via NachoSoto (@NachoSoto) --------- Co-authored-by: NachoSoto <ignaciosoto90@gmail.com>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Changes:
PurchasedProductsFetcherTypeto be able to mock and hold fetchers, even on older devicesProductEntitlementMappingFetcherto abstract injectingProductEntitlementMappingCustomerInfoResponseHandlerto compute offlineCustomerInfoafter a server error (see ImplementedNetworkError.isServerDown#2367). This is used by allCustomerInforequests as well asPostReceiptDataOperation.CustomerInfoResponseHandlertestsTODO:
CustomerInfo:CustomerInfoManager: don't cache offlineCustomerInfo#2378Offline Entitlements: integration tests #2501.