Gestión de errores en el SDK de Flutter

Todos los errores que devuelve el SDK son de tipo AdaptyErrorCode. Aquí tienes un ejemplo:

Activa los logs detallados antes de depurar. La mayoría de los AdaptyError envuelven un error subyacente de StoreKit, Play Billing, red o backend. Con los logs detallados activados (await Adapty().setLogLevel(AdaptyLogLevel.verbose) — consulta Logging), ese error se imprime en la consola, lo que normalmente te indica la causa real.

Si estas soluciones no resuelven tu problema, consulta Otros problemas para ver los pasos a seguir antes de contactar con soporte y ayudarnos a asistirte de forma más eficiente.

    try {
      final result = await adapty.makePurchase(product: product);
    } on AdaptyError catch (adaptyError) {
      if (adaptyError.code == AdaptyErrorCode.paymentCancelled) {
        // Cancelled
      }
    } catch (e) {
    }

Códigos de sistema StoreKit

ErrorCódigoSolución
unknown0Código de error que indica que ocurrió un error desconocido o inesperado.
Reintenta o consulta la sección Otros problemas.
clientInvalid1Este código de error indica que el cliente no tiene permiso para realizar la acción solicitada.
paymentCancelled2

Este código de error indica que el usuario canceló una solicitud de pago.

No se requiere ninguna acción, aunque desde el punto de vista del negocio puedes ofrecer un descuento al usuario o recordárselo más adelante.

paymentInvalid3Este error indica que uno de los parámetros de pago no fue reconocido por el App Store.
paymentNotAllowed4Este código de error indica que el usuario no tiene permiso para autorizar pagos.
storeProductNotAvailable5Este código de error indica que el producto solicitado no está disponible en el store.
Intenta reinstalar la app.
cloudServicePermissionDenied6Este código de error indica que el usuario no ha permitido el acceso a la información del servicio en la nube.
cloudServiceNetworkConnectionFailed7Este código de error indica que el dispositivo no pudo conectarse a la red.
cloudServiceRevoked8Este código de error indica que el usuario ha revocado el permiso para usar este servicio en la nube.
privacyAcknowledgementRequired9Este código de error indica que el usuario aún no ha aceptado la política de privacidad de Apple.
unauthorizedRequestData10Este código de error indica que la app intenta usar una propiedad para la cual no tiene el entitlement requerido.
invalidOfferIdentifier11

El identifier de la oferta no es válido. Por ejemplo, no has configurado una oferta con ese identificador en el App Store, o la has revocado.

Asegúrate de configurar las ofertas deseadas en App Store Connect y de pasar un identificador de oferta válido.

invalidSignature12Este código de error indica que la firma en un descuento de pago no es válida.
missingOfferParams13Este código de error indica que faltan parámetros en un descuento de pago.
invalidOfferPrice14Este código de error indica que el precio especificado en App Store Connect ya no es válido. Las ofertas deben representar siempre un precio con descuento.

Códigos de Android personalizados

ErrorCódigoSolución
adaptyNotInitialized20Debes configurar correctamente el SDK de Adapty mediante el método Adapty.activate. Aprende cómo hacerlo para Flutter.
productNotFound22Este error indica que el producto solicitado para la compra no está disponible en el store.
invalidJson23El JSON del paywall no es válido. Corrígelo en el Adapty Dashboard. Consulta el tema Personalizar el paywall con Remote Config para más detalles sobre cómo solucionarlo.
currentSubscriptionToUpdateNotFoundInHistory24No se encuentra la suscripción original que debe renovarse.
pendingPurchase25Este error indica que el estado de la compra es pendiente en lugar de completada. Consulta la página Handling pending transactions en la documentación de Android Developer para más detalles.
billingServiceTimeout97Este error indica que la solicitud ha alcanzado el tiempo de espera máximo antes de que Google Play pueda responder. Puede deberse, por ejemplo, a un retraso en la ejecución de la acción solicitada por la llamada a la Play Billing Library.
featureNotSupported98La función solicitada no es compatible con Play Store en el dispositivo actual.
billingServiceDisconnected99Este error fatal indica que la conexión de la app cliente con el servicio de Google Play Store a través del BillingClient se ha interrumpido.
billingServiceUnavailable102Este error transitorio indica que el servicio de facturación de Google Play no está disponible en este momento. En la mayoría de los casos, significa que hay un problema de conexión a la red entre el dispositivo cliente y los servicios de Google Play Billing.
billingUnavailable103

Este error indica que se produjo un error de facturación del usuario durante el proceso de compra. Algunos ejemplos de cuándo puede ocurrir:

1. La app de Play Store en el dispositivo del usuario está desactualizada.

2. El usuario se encuentra en un país no compatible.

3. El usuario es un usuario empresarial y su administrador ha deshabilitado las compras.

4. Google Play no puede cobrar el método de pago del usuario. Por ejemplo, la tarjeta de crédito del usuario puede haber caducado.

5. El usuario no ha iniciado sesión en la app de Play Store.

developerError105Este es un error fatal que indica que estás usando una API de forma incorrecta.
billingError106Este es un error fatal que indica un problema interno en Google Play.
itemAlreadyOwned107El producto consumible ya ha sido comprado.
itemNotOwned108Este error indica que la acción solicitada sobre el artículo falló sin

Códigos personalizados de StoreKit

ErrorCódigoSolución
noProductIDsFound1000

Este error indica que ninguno de los productos que solicitaste en el paywall están disponibles para comprar en el App Store, aunque figuren en él. A veces puede ir acompañado de una advertencia InvalidProductIdentifiers. Si la advertencia aparece sin error, ignórala.

Si encuentras este error, sigue los pasos de la sección Solución para el error Code-1000 noProductIDsFound.

noProductsFound1001Este error indica que el producto solicitado para la compra no está disponible en la store.
productRequestFailed1002No se pueden obtener los productos disponibles en este momento.
cantMakePayments1003Las compras in-app no están permitidas en este dispositivo. Consulta la guía de solución de problemas.
noPurchasesToRestore1004Este error indica que el App Store no encontró ninguna compra que restaurar.
cantReadReceipt1005

No hay ningún recibo válido disponible en el dispositivo. Esto puede ser un problema durante las pruebas en sandbox.

En el sandbox, no tendrás un archivo de recibo válido hasta que realices una compra, así que asegúrate de hacer una antes de acceder a él. Durante las pruebas en sandbox, verifica también que hayas iniciado sesión en el dispositivo con una cuenta sandbox de Apple válida.

productPurchaseFailed1006La compra del producto falló. Este error envuelve un error subyacente de StoreKit — lee el error envuelto (o activa los logs detallados para verlo en la consola) para conocer el motivo real. El error envuelto suele ser uno de los códigos de StoreKit del 0 al 14 de la tabla anterior — los más comunes son paymentCancelled, paymentInvalid, paymentNotAllowed o invalidOfferPrice. Si no puedes identificar un motivo concreto, prueba con un nuevo perfil sandbox; si sigue fallando, contacta con el soporte de Apple.
missingOfferSigningParams1007

Este error indica problemas con la integración de Adapty o con las ofertas.

Consulta Configurar la integración con App Store y Ofertas para ver cómo configurarlas.

refreshReceiptFailed1010Este error indica que no se recibió el recibo. Solo aplica a StoreKit 1.
receiveRestoredTransactionsFailed1011La restauración de la compra falló.

Códigos de red personalizados

ErrorCódigoSolución
notActivated2002El SDK de Adapty no está activado.
Suele ocurrir cuando una pantalla de bienvenida o un hook de UI temprano llama a métodos de Adapty antes de que Adapty().activate devuelva un resultado. El síntoma es intermitente y puede no reproducirse en el emulador porque los tiempos en dispositivos reales son distintos. Usa await en el Future de activate antes de programar cualquier otra llamada al SDK. Consulta Orden de llamadas en el SDK de Flutter para ver la secuencia completa.
badRequest2003Solicitud incorrecta.
Asegúrate de haber completado todos los pasos necesarios para integrar con App Store.
serverError2004Error del servidor.
Vuelve a intentarlo después de un tiempo. Si el problema persiste, contacta con el equipo de soporte de Adapty.
networkFailed2005Este error indica problemas con la conexión de red en el dispositivo del usuario.
Prueba a desactivar la VPN o a cambiar de red móvil a WiFi, o viceversa.
decodingFailed2006Este error indica que la decodificación de la respuesta falló.
Revisa tu código y asegúrate de que los parámetros que envías son válidos. Por ejemplo, este error puede indicar que estás usando una clave de API no válida.
encodingFailed2009Este error indica que la codificación de la solicitud falló.
analyticsDisabled3000No podemos gestionar eventos de analítica porque has desactivado esa opción.
wrongParam3001Este error indica que alguno de tus parámetros no es correcto.
Si usas el Paywall Builder de Adapty y no puedes mostrar un paywall por este error, activa Show on device en el Paywall Builder.
Otra posible causa es que la versión del archivo de respaldo local no coincida con la versión del SDK. Descarga un archivo nuevo desde el dashboard.
activateOnceError3005No es posible llamar al método .activate más de una vez.
profileWasChanged3006El perfil del usuario cambió durante la operación.
Esto ocurre cuando se llama a un método mientras Adapty().identify todavía está en curso — la llamada en vuelo llega a un perfil que está a punto de ser reemplazado y el SDK la rechaza. Usa siempre await con identify antes de cualquier llamada de acción del usuario. Consulta Orden de llamadas en el SDK de Flutter.
unsupportedData3007Este error indica que el formato de datos no es compatible con el SDK.
persistingDataError3100Se produjo un error al guardar los datos.
fetchTimeoutError3101Este error indica que la operación de obtención de datos superó el tiempo de espera.

Otros problemas

Si todavía no has encontrado una solución, los siguientes pasos pueden ser:

  • Actualizar el SDK a la última versión: Recomendamos siempre actualizar a las últimas versiones del SDK, ya que son más estables e incluyen correcciones para problemas conocidos.
  • Contacta con el equipo de soporte u obtén ayuda de otros desarrolladores en el foro de soporte.
  • Contacta con el equipo de soporte en [email protected] o a través del chat: Si no puedes actualizar el SDK o la actualización no resolvió el problema, contacta con nuestro equipo de soporte. Ten en cuenta que tu problema se resolverá más rápido si activas el registro detallado y compartes los logs con el equipo. También puedes adjuntar fragmentos de código relevantes.