Skip to content

Commit

Permalink
Fix "Nothing to Restore" even when transactions exist
Browse files Browse the repository at this point in the history
  • Loading branch information
mshibanami committed Jun 14, 2021
1 parent 9270d2f commit ecaddfc
Showing 1 changed file with 23 additions and 14 deletions.
37 changes: 23 additions & 14 deletions Sources/SwiftyStoreKit/PaymentQueueController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,10 @@ class PaymentQueueController: NSObject, SKPaymentTransactionObserver {
private let completeTransactionsController: CompleteTransactionsController
unowned let paymentQueue: PaymentQueue
private var entitlementRevocation: EntitlementRevocation?

private let restorationDispatchQueue = DispatchQueue(
label: "com.musevisions.SwiftyStoreKit.restorationDispatchQueue",
qos: DispatchQoS.background)

deinit {
paymentQueue.remove(self)
}
Expand Down Expand Up @@ -236,19 +239,21 @@ class PaymentQueueController: NSObject, SKPaymentTransactionObserver {
* 3. complete transactions (transactionState: .purchased, .failed, .restored, .deferred)
* Any transactions where state == .purchasing are ignored.
*/
var unhandledTransactions = transactions.filter { $0.transactionState != .purchasing }

if unhandledTransactions.count > 0 {

unhandledTransactions = paymentsController.processTransactions(transactions, on: paymentQueue)

unhandledTransactions = restorePurchasesController.processTransactions(unhandledTransactions, on: paymentQueue)

unhandledTransactions = completeTransactionsController.processTransactions(unhandledTransactions, on: paymentQueue)
restorationDispatchQueue.sync {
var unhandledTransactions = transactions.filter { $0.transactionState != .purchasing }

if unhandledTransactions.count > 0 {
let strings = unhandledTransactions.map { $0.debugDescription }.joined(separator: "\n")
print("unhandledTransactions:\n\(strings)")

unhandledTransactions = paymentsController.processTransactions(transactions, on: paymentQueue)

unhandledTransactions = restorePurchasesController.processTransactions(unhandledTransactions, on: paymentQueue)

unhandledTransactions = completeTransactionsController.processTransactions(unhandledTransactions, on: paymentQueue)

if unhandledTransactions.count > 0 {
let strings = unhandledTransactions.map { $0.debugDescription }.joined(separator: "\n")
print("unhandledTransactions:\n\(strings)")
}
}
}
}
Expand All @@ -262,11 +267,15 @@ class PaymentQueueController: NSObject, SKPaymentTransactionObserver {
}

func paymentQueue(_ queue: SKPaymentQueue, restoreCompletedTransactionsFailedWithError error: Error) {
restorePurchasesController.restoreCompletedTransactionsFailed(withError: error)
restorationDispatchQueue.async { [weak self] in
self?.restorePurchasesController.restoreCompletedTransactionsFailed(withError: error)
}
}

func paymentQueueRestoreCompletedTransactionsFinished(_ queue: SKPaymentQueue) {
restorePurchasesController.restoreCompletedTransactionsFinished()
restorationDispatchQueue.async { [weak self] in
self?.restorePurchasesController.restoreCompletedTransactionsFinished()
}
}

func paymentQueue(_ queue: SKPaymentQueue, updatedDownloads downloads: [SKDownload]) {
Expand Down

0 comments on commit ecaddfc

Please sign in to comment.