Gestión de errores en el SDK de iOS
El SDK de Adapty tiene su propio contenedor para todo tipo de errores, llamado AdaptyError. Básicamente, todo error que devuelve el SDK es un AdaptyError. Tiene dos propiedades útiles: originalError y adaptyErrorCode, que se describen a continuación.
originalError contiene el error original en caso de que necesites trabajar directamente con él. Puede ser SKError, NSError o simplemente un Error genérico de Swift. Esta propiedad es opcional, ya que algunos errores pueden ser generados directamente por el SDK —como datos inconsistentes o faltantes— y no tendrán un error original sobre el que se construyó el wrapper.
adaptyErrorCode se puede usar para gestionar problemas comunes, como:
- credenciales no válidas
- errores de red
- pagos cancelados
- problemas de facturación
- recibo no válido
- y mucho más
Es bastante sencillo comprobar el error buscando códigos específicos y reaccionar en consecuencia.
do {
let info = try await Adapty.makePurchase(product: product)
} catch {
if error.adaptyErrorCode == .paymentCancelled {
// purchase was cancelled
// you can offer discount to your user or remind them later
}
}
Activa los logs detallados antes de depurar. La mayoría de los AdaptyError envuelven un error subyacente de StoreKit, de red o del backend. Con los logs detallados activados (Adapty.logLevel = .verbose — consulta Logging), ese error envuelto se imprime en la consola, lo que normalmente indica la causa real. La propiedad originalError se rellena independientemente del nivel de log — los logs detallados simplemente lo muestran en la consola.
Si estas soluciones no resuelven tu problema, consulta Otros problemas para conocer los pasos a seguir antes de contactar con el soporte y así ayudarnos a asistirte de forma más eficiente.
Errores de StoreKit
| Error | Código | Solución |
|---|---|---|
| unknown | 0 | Código de error que indica que ocurrió un error desconocido o inesperado. Vuelve a intentarlo o consulta la sección Otros problemas. |
| clientInvalid | 1 | Este código de error indica que el cliente no tiene permiso para realizar la acción intentada. |
| paymentCancelled | 2 | 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 de la lógica de negocio puedes ofrecer un descuento al usuario o recordárselo más adelante. |
| paymentInvalid | 3 | Este error indica que uno de los parámetros de pago no fue reconocido por el App Store. |
| paymentNotAllowed | 4 | Este código de error indica que el usuario no tiene permiso para autorizar pagos. |
| storeProductNotAvailable | 5 | Este código de error indica que el producto solicitado no está disponible en el store. Intenta reinstalar la app. |
| cloudServicePermissionDenied | 6 | Este código de error indica que el usuario no ha permitido el acceso a la información del servicio en la nube. |
| cloudServiceNetworkConnectionFailed | 7 | Este código de error indica que el dispositivo no pudo conectarse a la red. |
| cloudServiceRevoked | 8 | Este código de error indica que el usuario ha revocado el permiso para usar este servicio en la nube. |
| privacyAcknowledgementRequired | 9 | Este código de error indica que el usuario aún no ha aceptado la política de privacidad de Apple. |
| unauthorizedRequestData | 10 | Este código de error indica que la app está intentando usar una propiedad para la que no tiene el entitlement necesario. |
| invalidOfferIdentifier | 11 | El Asegúrate de configurar las ofertas deseadas en App Store Connect y de pasar un identificador de oferta válido. |
| invalidSignature | 12 | Este código de error indica que la firma en un descuento de pago no es válida. |
| missingOfferParams | 13 | Este código de error indica que faltan parámetros en un descuento de pago. |
| invalidOfferPrice | 14 | Este código de error indica que el precio que especificaste en App Store Connect ya no es válido. Las ofertas siempre deben representar un precio con descuento. |
| noProductIDsFound | 1000 | Este error indica que ninguno de los productos que solicitaste en el paywall está disponible para comprar en el App Store, aunque estén listados allí. A veces puede aparecer junto con una advertencia Si encuentras este error, sigue los pasos de la sección Solución para el error Code-1000 |
| productRequestFailed | 1002 | No se pueden obtener los productos disponibles en este momento. |
| cantMakePayments | 1003 | Las compras in-app no están permitidas en este dispositivo. Consulta la guía de solución de problemas. |
| cantReadReceipt | 1005 | 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 hagas una compra real, 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. |
| productPurchaseFailed | 1006 | La compra del producto falló. Esto envuelve un error subyacente de StoreKit; lee originalError (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, siendo los más habituales 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. |
| refreshReceiptFailed | 1010 | La operación de actualización del recibo falló. |
| fetchSubscriptionStatusFailed | 1020 | No se pudo obtener el estado de la suscripción desde el App Store. |
| unknownTransactionId | 1030 | El identificador de transacción es desconocido. |
| paymentPendingError | 1050 | El pago está pendiente en este momento. |
Errores de red
| Error | Código | Solución |
|---|---|---|
| notActivated | 2002 | El SDK de Adapty no está activado. Se produce con más frecuencia cuando una pantalla de bienvenida o un hook de UI temprano llama a métodos de Adapty antes de que Adapty.activate devuelva el resultado. El síntoma es intermitente y puede no reproducirse en el simulador porque el timing en un dispositivo real es diferente. Espera a que el manejador de completado o el resultado asíncrono de activate finalice antes de programar cualquier otra llamada al SDK. Consulta Orden de llamadas en el SDK de iOS para ver la secuencia completa. |
| badRequest | 2003 | Solicitud incorrecta. Asegúrate de haber completado todos los pasos necesarios para integrarte con el App Store. |
| serverError | 2004 | Error de servidor. Vuelve a intentarlo pasado un tiempo. Si el problema persiste, contacta con el equipo de soporte de Adapty. |
| networkFailed | 2005 | Este error indica problemas con la conexión de red en el dispositivo del usuario. Prueba a desactivar la VPN o cambiar de red celular a WiFi, o viceversa. |
| decodingFailed | 2006 | Este 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. |
| encodingFailed | 2009 | Este error indica que la codificación de la solicitud falló. |
Errores generales
| Error | Código | Solución |
|---|---|---|
| analyticsDisabled | 3000 | No podemos gestionar eventos de analítica porque la has desactivado. |
| wrongParam | 3001 | Este error indica que alguno de tus parámetros no es correcto. Si usas el Paywall Builder de Adapty y no puedes mostrar un paywall debido a 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 nuevo archivo desde el dashboard. |
| activateOnceError | 3005 | No es posible llamar al método .activate más de una vez. |
| profileWasChanged | 3006 | El perfil de usuario cambió durante la operación. Esto ocurre cuando se llama a un método mientras Adapty.identify aún 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 (o su completion handler) antes de cualquier llamada de acción del usuario. Consulta Call order in iOS SDK. |
| unsupportedData | 3007 | Este error indica que el formato de datos no es compatible con el SDK. |
| unidentifiedUserLogout | 3020 | No es posible llamar al método logout para un usuario no identificado. |
| fetchTimeoutError | 3101 | Este error indica que la operación de fetch ha superado el tiempo de espera. |
| operationInterrupted | 9000 | El sistema interrumpió esta operación. |
Otros problemas
Si aún no has encontrado una solución, los siguientes pasos pueden ser:
- Actualizar el SDK a la última versión: Siempre recomendamos 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 estás listo para actualizar el SDK o no te ha ayudado, 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.