|
|
@ -107,15 +107,59 @@ public class ActivityBilling extends ActivityBase implements
|
|
|
|
getSupportFragmentManager().addOnBackStackChangedListener(this);
|
|
|
|
getSupportFragmentManager().addOnBackStackChangedListener(this);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (Helper.isPlayStoreInstall() || isTesting(this)) {
|
|
|
|
if (Helper.isPlayStoreInstall() || isTesting(this))
|
|
|
|
|
|
|
|
try {
|
|
|
|
Log.i("IAB start");
|
|
|
|
Log.i("IAB start");
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
billingClient = BillingClient.newBuilder(getApplicationContext()
|
|
|
|
billingClient = BillingClient.newBuilder(getApplicationContext())
|
|
|
|
.enablePendingPurchases()
|
|
|
|
.enablePendingPurchases()
|
|
|
|
.setListener(this)
|
|
|
|
.setListener(this)
|
|
|
|
.build();
|
|
|
|
.build();
|
|
|
|
billingClient.startConnection(this);
|
|
|
|
billingClient.startConnection(this);
|
|
|
|
|
|
|
|
getLifecycle().addObserver(new LifecycleObserver() {
|
|
|
|
|
|
|
|
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
|
|
|
|
|
|
|
|
public void onDestroyed() {
|
|
|
|
|
|
|
|
getLifecycle().removeObserver(this);
|
|
|
|
|
|
|
|
if (billingClient != null)
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
Log.i("IAB end");
|
|
|
|
|
|
|
|
billingClient.endConnection();
|
|
|
|
|
|
|
|
billingClient = null;
|
|
|
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
|
|
|
|
Log.e(ex);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
|
|
|
|
Log.e(ex);
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
Exception java.lang.RuntimeException:
|
|
|
|
|
|
|
|
at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:4171)
|
|
|
|
|
|
|
|
at android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:4317)
|
|
|
|
|
|
|
|
at android.app.servertransaction.LaunchActivityItem.execute (LaunchActivityItem.java:101)
|
|
|
|
|
|
|
|
at android.app.servertransaction.TransactionExecutor.executeCallbacks (TransactionExecutor.java:135)
|
|
|
|
|
|
|
|
at android.app.servertransaction.TransactionExecutor.execute (TransactionExecutor.java:95)
|
|
|
|
|
|
|
|
at android.app.ActivityThread$H.handleMessage (ActivityThread.java:2576)
|
|
|
|
|
|
|
|
at android.os.Handler.dispatchMessage (Handler.java:106)
|
|
|
|
|
|
|
|
at android.os.Looper.loopOnce (Looper.java:226)
|
|
|
|
|
|
|
|
at android.os.Looper.loop (Looper.java:313)
|
|
|
|
|
|
|
|
at android.app.ActivityThread.main (ActivityThread.java:8772)
|
|
|
|
|
|
|
|
at java.lang.reflect.Method.invoke (Method.java)
|
|
|
|
|
|
|
|
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:571)
|
|
|
|
|
|
|
|
at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1067)
|
|
|
|
|
|
|
|
Caused by java.lang.IllegalStateException: Too many bind requests(999+) for service Intent { act=com.android.vending.billing.InAppBillingService.BIND pkg=com.android.vending cmp=com.android.vending/com.google.android.finsky.billing.iab.InAppBillingService (has extras) }
|
|
|
|
|
|
|
|
at android.app.ContextImpl.bindServiceCommon (ContextImpl.java:2115)
|
|
|
|
|
|
|
|
at android.app.ContextImpl.bindService (ContextImpl.java:2024)
|
|
|
|
|
|
|
|
at android.content.ContextWrapper.bindService (ContextWrapper.java:870)
|
|
|
|
|
|
|
|
at com.android.billingclient.api.BillingClientImpl.startConnection (com.android.billingclient:billing@@4.1.0:52)
|
|
|
|
|
|
|
|
at eu.faircode.email.ActivityBilling.onCreate (ActivityBilling.java:116)
|
|
|
|
|
|
|
|
at eu.faircode.email.ActivityView.onCreate (ActivityView.java:192)
|
|
|
|
|
|
|
|
at android.app.Activity.performCreate (Activity.java:8565)
|
|
|
|
|
|
|
|
at android.app.Activity.performCreate (Activity.java:8544)
|
|
|
|
|
|
|
|
at android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1384)
|
|
|
|
|
|
|
|
at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:4152)
|
|
|
|
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -152,14 +196,6 @@ public class ActivityBilling extends ActivityBase implements
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
protected void onDestroy() {
|
|
|
|
|
|
|
|
//if (billingClient != null)
|
|
|
|
|
|
|
|
// billingClient.endConnection();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
super.onDestroy();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@NonNull
|
|
|
|
@NonNull
|
|
|
|
static String getSkuPro(Context context) {
|
|
|
|
static String getSkuPro(Context context) {
|
|
|
|
if (isTesting(context))
|
|
|
|
if (isTesting(context))
|
|
|
@ -334,6 +370,8 @@ public class ActivityBilling extends ActivityBase implements
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void delegate() {
|
|
|
|
public void delegate() {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
|
|
|
|
if (!getLifecycle().getCurrentState().isAtLeast(Lifecycle.State.STARTED))
|
|
|
|
|
|
|
|
return;
|
|
|
|
boolean ready = billingClient.isReady();
|
|
|
|
boolean ready = billingClient.isReady();
|
|
|
|
Log.i("IAB ready=" + ready);
|
|
|
|
Log.i("IAB ready=" + ready);
|
|
|
|
if (!ready)
|
|
|
|
if (!ready)
|
|
|
@ -450,6 +488,8 @@ public class ActivityBilling extends ActivityBase implements
|
|
|
|
if (isPurchaseValid(purchase)) {
|
|
|
|
if (isPurchaseValid(purchase)) {
|
|
|
|
editor.putBoolean("pro", true);
|
|
|
|
editor.putBoolean("pro", true);
|
|
|
|
editor.putLong(sku + ".cached", new Date().getTime());
|
|
|
|
editor.putLong(sku + ".cached", new Date().getTime());
|
|
|
|
|
|
|
|
editor.putString("iab_json", purchase.getOriginalJson());
|
|
|
|
|
|
|
|
editor.putString("iab_signature", purchase.getSignature());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!purchase.isAcknowledged())
|
|
|
|
if (!purchase.isAcknowledged())
|
|
|
@ -643,6 +683,10 @@ public class ActivityBilling extends ActivityBase implements
|
|
|
|
// User pressed back or canceled a dialog
|
|
|
|
// User pressed back or canceled a dialog
|
|
|
|
return "USER_CANCELED";
|
|
|
|
return "USER_CANCELED";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case BillingClient.BillingResponseCode.NETWORK_ERROR:
|
|
|
|
|
|
|
|
// A network error occurred during the operation
|
|
|
|
|
|
|
|
return "NETWORK_ERROR";
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
return Integer.toString(result.getResponseCode());
|
|
|
|
return Integer.toString(result.getResponseCode());
|
|
|
|
}
|
|
|
|
}
|
|
|
|