В моей заявке была сделана функция пожертвования. (Приложение с разрешением на покупку внутри приложения доступно в google play и в скачанной версии, эта функция работает) Я сделал это с помощью библиотеки easy из anjlab . Я начал обновлять приложение и переписал его одновременно на Kotlin . Донат перестал работать по какой-то причине. Я решил переделать код из библиотеки anjlab в новую библиотеку биллинга от Google. Когда я пытаюсь сделать покупку, я получаю
responseCode = -1 (сервисное соединение отключено).
Я попытался возобновить соединение, используя startConnection
(это), попытался изменить версию в gradle , загрузил новую версию в библиотеку apk . Ни старое, ни новое не работает (если скачать из гугл плей, тот, который опубликован, работает). Код написан по рекомендации от Google. Я тестирую приложение, подписанное на реальном устройстве
SettingsFramgent.kt (только причастный код)
package *
import android.content.Intent
import androidx.preference.PreferenceFragmentCompat
import android.os.Bundle
import android.widget.Toast
import androidx.preference.Preference
import com.starikov.datecalc.R
class SettingsFragment : PreferenceFragmentCompat(), SettingsContract.View {
private lateinit var presenter: SettingsContract.Presenter
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
setPreferencesFromResource(R.xml.preferences, rootKey)
presenter = SettingsPresenter(activity!!)
presenter.attachView(this)
val makeDonatePref: Preference = findPreference(MAKE_DONATE_KEY)!!
makeDonatePref.setOnPreferenceClickListener { presenter.makeDonateClicked(); true }
presenter.viewIsReady()
}
override fun showToast(resId: Int) {
Toast.makeText(activity, resId, Toast.LENGTH_LONG).show()
}
override fun startActivity(intent: Intent) {
activity!!.startActivity(intent)
}
override fun onDestroy() {
super.onDestroy()
presenter.detachView()
if (activity!!.isFinishing) {
presenter.destroy()
}
}
companion object {
private const val MAKE_DONATE_KEY = "make_donate"
}
}
SettingsPresenter.kt
package *
import android.app.Activity
import android.content.ActivityNotFoundException
import android.content.Intent
import android.net.Uri
import com.android.billingclient.api.*
import com.starikov.datecalc.common.PresenterBase
import com.android.billingclient.api.BillingClient
import com.android.billingclient.api.SkuDetailsParams
import com.android.billingclient.api.BillingFlowParams
import com.starikov.datecalc.R
import java.util.*
internal class SettingsPresenter internal constructor(private val activity: Activity)
: PresenterBase<SettingsContract.View>(), SettingsContract.Presenter {
private lateinit var billingClient: BillingClient
private var skuDetailsMap: HashMap<String, SkuDetails> = HashMap()
override fun makeDonateClicked() {
initBillingProcessor()
launchBilling(DONATE_PRODUCT_ID)
}
override fun destroy() {
billingClient.endConnection()
}
override fun viewIsReady() {}
private fun initBillingProcessor() {
billingClient = BillingClient.newBuilder(activity)
.enablePendingPurchases()
.setListener {
billingResult, purchases ->
if (billingResult?.responseCode == BillingClient.BillingResponseCode.OK && purchases != null) {
//purchase done
view!!.showToast(R.string.thanks_for_donate)
}
}.build()
billingClient.startConnection(object : BillingClientStateListener {
override fun onBillingSetupFinished(billingResult: BillingResult?) {
if (billingResult?.responseCode == BillingClient.BillingResponseCode.OK) {
// **place of logs**
querySkuDetails()
}
}
override fun onBillingServiceDisconnected() {
//if wrong
}
})
}
private fun launchBilling(skuId: String) {
val billingFlowParams = BillingFlowParams.newBuilder()
.setSkuDetails(skuDetailsMap[skuId])
.build()
billingClient.launchBillingFlow(activity, billingFlowParams)
}
private fun querySkuDetails() {
val skuDetailsParamsBuilder = SkuDetailsParams.newBuilder()
val skuList = ArrayList<String>()
skuList.add(DONATE_PRODUCT_ID)
skuDetailsParamsBuilder.setSkusList(skuList).setType(BillingClient.SkuType.INAPP)
billingClient.querySkuDetailsAsync(skuDetailsParamsBuilder.build()) { billingResult, skuDetailsList ->
if (billingResult?.responseCode == BillingClient.BillingResponseCode.OK) {
for (skuDetails in skuDetailsList!!) {
skuDetailsMap[skuDetails.sku] = skuDetails
}
}
}
}
companion object {
private const val DONATE_PRODUCT_ID = "donate"
}
}
В " месте журналов " я проверил billingResult.responseCode = -1; debugMessage = "Подключение к службе отключено"
Понятия не имею, что делать. Заранее спасибо за помощь