Added null checks

This commit is contained in:
Björn Ritzl 2023-02-06 15:56:03 +01:00
parent f97a7ee6b6
commit d74c97d5c7
2 changed files with 22 additions and 9 deletions

View File

@ -362,9 +362,13 @@ public class IapGooglePlay implements PurchasesUpdatedListener {
*/ */
@Override @Override
public void onPurchasesUpdated(BillingResult billingResult, List<Purchase> purchases) { public void onPurchasesUpdated(BillingResult billingResult, List<Purchase> purchases) {
if (billingResult.getResponseCode() == BillingResponseCode.OK && purchases != null) { if (billingResult.getResponseCode() == BillingResponseCode.OK) {
for (Purchase purchase : purchases) { if (purchases != null && !purchases.isEmpty()) {
handlePurchase(purchase, this.purchaseListener); for (Purchase purchase : purchases) {
if (purchase != null) {
handlePurchase(purchase, this.purchaseListener);
}
}
} }
} }
else { else {
@ -413,7 +417,12 @@ public class IapGooglePlay implements PurchasesUpdatedListener {
@Override @Override
public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetailsList) { public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetailsList) {
if (billingResult.getResponseCode() == BillingResponseCode.OK && (productDetailsList != null) && !productDetailsList.isEmpty()) { if (billingResult.getResponseCode() == BillingResponseCode.OK && (productDetailsList != null) && !productDetailsList.isEmpty()) {
buyProduct(productDetailsList.get(0), token, purchaseListener); for (ProductDetails productDetails : productDetailsList) {
if (productDetails != null) {
buyProduct(productDetails, token, purchaseListener);
break;
}
}
} }
else { else {
Log.e(TAG, "Unable to get product details before buying: " + billingResult.getDebugMessage()); Log.e(TAG, "Unable to get product details before buying: " + billingResult.getDebugMessage());
@ -435,10 +444,12 @@ public class IapGooglePlay implements PurchasesUpdatedListener {
@Override @Override
public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetails) { public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetails) {
if (productDetails != null) { if (productDetails != null && !productDetails.isEmpty()) {
// cache products (cache will be used to speed up buying) // cache products (cache will be used to speed up buying)
for (ProductDetails pd : productDetails) { for (ProductDetails pd : productDetails) {
IapGooglePlay.this.products.put(pd.getProductId(), pd); if (pd != null) {
IapGooglePlay.this.products.put(pd.getProductId(), pd);
}
} }
// add to list of all product details // add to list of all product details
allProductDetails.addAll(productDetails); allProductDetails.addAll(productDetails);
@ -485,9 +496,11 @@ public class IapGooglePlay implements PurchasesUpdatedListener {
@Override @Override
public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetails) { public void onProductDetailsResponse(BillingResult billingResult, List<ProductDetails> productDetails) {
JSONArray a = new JSONArray(); JSONArray a = new JSONArray();
if (billingResult.getResponseCode() == BillingResponseCode.OK) { if ((billingResult.getResponseCode() == BillingResponseCode.OK) && (productDetails != null) && !productDetails.isEmpty()) {
for (ProductDetails pd : productDetails) { for (ProductDetails pd : productDetails) {
a.put(convertProductDetails(pd)); if (pd != null) {
a.put(convertProductDetails(pd));
}
} }
} }
else { else {

View File

@ -16,7 +16,7 @@ target_sdk_version = 29
[project] [project]
title = extension-iap title = extension-iap
dependencies = https://github.com/andsve/dirtylarry/archive/master.zip dependencies#0 = https://github.com/andsve/dirtylarry/archive/master.zip
[library] [library]
include_dirs = extension-iap include_dirs = extension-iap