From 40ffc7bb0bf3dc37880f4835942066901d89892e Mon Sep 17 00:00:00 2001 From: "Ng Wing Tat, David" Date: Fri, 10 Nov 2023 00:39:18 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20Fix=20react-native-iap=20method?= =?UTF-8?q?=20calls?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/models/iapStore/iap-store.ts | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/app/models/iapStore/iap-store.ts b/app/models/iapStore/iap-store.ts index 879d8a56d..434ce4ae8 100644 --- a/app/models/iapStore/iap-store.ts +++ b/app/models/iapStore/iap-store.ts @@ -1,9 +1,13 @@ /* eslint-disable @typescript-eslint/interface-name-prefix */ import { Platform, Alert } from "react-native" -import RNIap, { +import { Product, Purchase, PurchaseError, + getAvailablePurchases, + getProducts, + requestSubscription, + validateReceiptIos, } from "react-native-iap" import { @@ -55,10 +59,13 @@ export const IAPStoreModel = types if (receipt) { // TODO: Validation on Android if (Platform.OS === "ios") { - const result: any = yield RNIap.validateReceiptIos({ - "receipt-data": receipt, - password: self.getConfig("IAP_IOS_SHARED_SECRET"), - }, self.getConfig("IAP_IOS_IS_SANDBOX") === "true") + const result: any = yield validateReceiptIos({ + receiptBody: { + "receipt-data": receipt, + password: self.getConfig("IAP_IOS_SHARED_SECRET"), + }, + isTest: self.getConfig("IAP_IOS_IS_SANDBOX") === "true", + }) if (result) { if (result.status === 0) { self.purchasedSKUs.add(SKU_COM_OICE_MEMBERSHIP) @@ -76,7 +83,7 @@ export const IAPStoreModel = types fetchProducts: flow(function * () { self.isFetchingProducts = true try { - self.products = yield RNIap.getProducts([SKU_COM_OICE_MEMBERSHIP]) + self.products = yield getProducts({ skus: [SKU_COM_OICE_MEMBERSHIP]}) } catch (error) { logError(error) } finally { @@ -85,7 +92,7 @@ export const IAPStoreModel = types }), requestSubscription: flow(function * (sku: string) { try { - yield RNIap.requestSubscription(sku, false) + yield requestSubscription({ sku }) } catch (error) { logError(error) } @@ -93,7 +100,7 @@ export const IAPStoreModel = types restorePurchases: flow(function * () { self.isRestoringPurchases = true try { - const purchases: Purchase[] = yield RNIap.getAvailablePurchases() + const purchases: Purchase[] = yield getAvailablePurchases() let hasSubscription = false purchases.forEach(purchase => { switch (purchase.productId) {