En este documento, se describe cómo migrar de la biblioteca de Google Play Billing (PBL) 6 o 7 a la PBL 8 y cómo realizar la integración con las nuevas capacidades opcionales de suscripción.
Para obtener una lista completa de los cambios de la versión 8.0.0, consulta las notas de la versión.
Descripción general
La versión PBL 8 contiene mejoras en las APIs existentes y la eliminación de las APIs que se habían marcado como obsoletas anteriormente. Esta versión de la biblioteca también incluye nuevas APIs para productos únicos.
Retrocompatibilidad para la actualización de PBL
Para migrar a la PBL 8, debes actualizar o quitar algunas de las referencias a la API existentes de tu app, como se describe en las notas de la versión y más adelante en esta guía de migración.
Actualiza de PBL 6 o 7 a PBL 8
Para actualizar de PBL 6 o 7 a PBL 8, sigue estos pasos:
Actualiza la versión de la dependencia de la Biblioteca de Facturación Play en el archivo
build.gradle
de tu app.dependencies { def billingVersion = 8.0.0 implementation "com.android.billingclient:billing:$billingVersion" }
(Solo se aplica a la actualización de PBL 6 a PBL 8). Controla los cambios en la API relacionados con las suscripciones en tu app.
En la siguiente tabla, se enumeran las APIs relacionadas con las suscripciones que se quitaron en la PBL 8 y la API alternativa correspondiente que debes usar en tu app.
Se quitó la API que había quedado obsoleta en la versión 8 de la PBL API alternativa para usar setOldSkuPurchaseToken setOldPurchaseToken setReplaceProrationMode setSubscriptionReplacementMode setReplaceSkusProrationMode setSubscriptionReplacementMode Actualiza la implementación del método
queryProductDetailsAsync
.Se produjo un cambio en la firma del método
ProductDetailsResponseListener.onProductDetailsResponse
, lo que requiere cambios en tu app para la implementación dequeryProductDetailsAsync
. Para obtener más información, consulta Cómo mostrar productos disponibles para comprar.Controla las APIs quitadas.
Actualizar desde
La versión PBL 8 ya no admite las APIs que se indican en la siguiente tabla. Si tu implementación usa alguna de estas APIs quitadas, consulta la tabla para conocer las APIs alternativas correspondientes.
Se quitó la API que había quedado obsoleta en la versión 8 de la PBL API alternativa para usar APIs de queryPurchaseHistoryAsync Consulta el Historial de compras de consultas querySkuDetailsAsync queryProductDetailsAsync enablePendingPurchases() (API sin parámetros) enablePendingPurchases(PendingPurchaseParams params)
Ten en cuenta que la función enablePendingPurchases() obsoleta es funcionalmente equivalente aenablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())
.queryPurchasesAsync(String skuType, PurchasesResponseListener listener) queryPurchasesAsync BillingClient.Builder.enableAlternativeBilling BillingClient.Builder.enableUserChoiceBilling AlternativeBillingListener UserChoiceBillingListener AlternativeChoiceDetails UserChoiceDetails Actualizar desde
En la siguiente tabla, se enumeran las APIs que se quitaron en PBL 8 y las APIs alternativas correspondientes que debes usar en tu app.
Se quitó la API que había quedado obsoleta en la versión 8 de la PBL API alternativa para usar APIs de queryPurchaseHistoryAsync Consulta el Historial de compras de consultas querySkuDetailsAsync queryProductDetailsAsync enablePendingPurchases() (API sin parámetros) enablePendingPurchases(PendingPurchaseParams params)
Ten en cuenta que la función enablePendingPurchases() obsoleta es funcionalmente equivalente aenablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())
.queryPurchasesAsync(String skuType, PurchasesResponseListener listener) queryPurchasesAsync (Recomendado) Habilita la reconexión automática del servicio.
La Biblioteca de Facturación Play puede intentar restablecer automáticamente la conexión de servicio si se realiza una llamada a la API mientras el servicio está desconectado. Para obtener más información, consulta Cómo habilitar la reconexión automática del servicio.
Son cambios opcionales.
Se admiten compras pendientes para planes prepagados. Para obtener más información, consulta Cómo controlar suscripciones y transacciones pendientes.
Suscripciones con cuotas virtuales Para obtener más información, consulta Integración de suscripciones con cuotas.