Skip to content

Commit

Permalink
Merge pull request #59 from defold/Issue-56-app-crash-on-slow-purchase
Browse files Browse the repository at this point in the history
Check that the purchase listener is not null
  • Loading branch information
britzl authored Feb 7, 2023
2 parents f97a7ee + ad06de7 commit 5c09447
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 8 deletions.
28 changes: 21 additions & 7 deletions extension-iap/src/java/com/defold/iap/IapGooglePlay.java
Original file line number Diff line number Diff line change
Expand Up @@ -243,6 +243,20 @@ private int billingResultToDefoldResponse(BillingResult result) {
return billingResponseCodeToDefoldResponse(result.getResponseCode());
}

private void invokeOnPurchaseResultListener(IPurchaseListener purchaseListener, int billingResultCode, String purchaseData) {
if (purchaseListener == null) {
Log.w(TAG, "Received billing result but no listener has been set");
return;
}
purchaseListener.onPurchaseResult(billingResultCode, purchaseData);
}
private void invokeOnPurchaseResultListener(IPurchaseListener purchaseListener, BillingResult billingResult, Purchase purchase) {
invokeOnPurchaseResultListener(purchaseListener, billingResultToDefoldResponse(billingResult), convertPurchase(purchase));
}
private void invokeOnPurchaseResultListener(IPurchaseListener purchaseListener, BillingResult billingResult) {
invokeOnPurchaseResultListener(purchaseListener, billingResultToDefoldResponse(billingResult), "");
}

/**
* This method is called either explicitly from Lua or from extension code
* when "set_listener()" is called from Lua.
Expand Down Expand Up @@ -306,7 +320,7 @@ public void onConsumeResponse(BillingResult billingResult, String purchaseToken)
// note: we only call the purchase listener if an error happens
if (billingResult.getResponseCode() != BillingResponseCode.OK) {
Log.e(TAG, "Unable to consume purchase: " + billingResult.getDebugMessage());
purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), "");
invokeOnPurchaseResultListener(purchaseListener, billingResult);
}
}
});
Expand All @@ -329,7 +343,7 @@ public void onAcknowledgePurchaseResponse(BillingResult billingResult) {
// note: we only call the purchase listener if an error happens
if (billingResult.getResponseCode() != BillingResponseCode.OK) {
Log.e(TAG, "Unable to acknowledge purchase: " + billingResult.getDebugMessage());
purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), "");
invokeOnPurchaseResultListener(purchaseListener, billingResult);
}
}
});
Expand All @@ -348,12 +362,12 @@ private void handlePurchase(final Purchase purchase, final IPurchaseListener pur
@Override
public void onConsumeResponse(BillingResult billingResult, String purchaseToken) {
Log.d(TAG, "handlePurchase() response code " + billingResult.getResponseCode() + " purchaseToken: " + purchaseToken);
purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), convertPurchase(purchase));
invokeOnPurchaseResultListener(purchaseListener, billingResult, purchase);
}
});
}
else {
purchaseListener.onPurchaseResult(billingResponseCodeToDefoldResponse(BillingResponseCode.OK), convertPurchase(purchase));
invokeOnPurchaseResultListener(purchaseListener, billingResponseCodeToDefoldResponse(BillingResponseCode.OK), convertPurchase(purchase));
}
}

Expand All @@ -368,7 +382,7 @@ public void onPurchasesUpdated(BillingResult billingResult, List<Purchase> purch
}
}
else {
this.purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), "");
invokeOnPurchaseResultListener(this.purchaseListener, billingResult);
}
}

Expand All @@ -392,7 +406,7 @@ private void buyProduct(ProductDetails pd, final String token, final IPurchaseLi
BillingResult billingResult = billingClient.launchBillingFlow(this.activity, billingFlowParams);
if (billingResult.getResponseCode() != BillingResponseCode.OK) {
Log.e(TAG, "Purchase failed: " + billingResult.getDebugMessage());
purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), "");
invokeOnPurchaseResultListener(purchaseListener, billingResult);
}
}

Expand All @@ -417,7 +431,7 @@ public void onProductDetailsResponse(BillingResult billingResult, List<ProductDe
}
else {
Log.e(TAG, "Unable to get product details before buying: " + billingResult.getDebugMessage());
purchaseListener.onPurchaseResult(billingResultToDefoldResponse(billingResult), "");
invokeOnPurchaseResultListener(purchaseListener, billingResult);
}
}
});
Expand Down
2 changes: 1 addition & 1 deletion game.project
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ target_sdk_version = 29

[project]
title = extension-iap
dependencies = https://github.com/andsve/dirtylarry/archive/master.zip
dependencies#0 = https://github.com/andsve/dirtylarry/archive/master.zip

[library]
include_dirs = extension-iap
Expand Down

0 comments on commit 5c09447

Please sign in to comment.