Instalar y configurar el SDK de Adapty para Kotlin Multiplatform
El SDK de Adapty incluye dos módulos clave para una integración fluida en tu app móvil:
- Core Adapty: Este SDK esencial es necesario para que Adapty funcione correctamente en tu app.
- AdaptyUI (
io.adapty:adapty-kmp-ui): Este módulo es necesario si utilizas el Adapty Paywall Builder con la capa de renderizado de Compose Multiplatform (view.present()). Si tu proyecto no usa Compose Multiplatform, puedes usarcreateNativePaywallViewycreateNativeOnboardingViewdel módulo principal en su lugar.
¿Quieres ver un ejemplo real de cómo se integra el SDK de Adapty en una app móvil? Echa un vistazo a nuestra app de ejemplo, que muestra la configuración completa, incluyendo la visualización de paywalls, la realización de compras y otras funcionalidades básicas.
Para un recorrido completo de implementación, también puedes ver el vídeo:
Requisitos
El SDK de Adapty para Kotlin Multiplatform es compatible con Xcode 16.2 y versiones posteriores.
Adapty es compatible con Google Play Billing Library hasta la versión 8.x. Por defecto, Adapty funciona con Google Play Billing Library v.7.0.0, pero si quieres forzar una versión posterior, puedes añadir la dependencia manualmente.
Instalar el SDK es el paso 5 de la configuración de Adapty. Para que las compras funcionen en tu app, también necesitas conectar tu app a los stores, y luego crear productos, un paywall y un placement en el Adapty Dashboard. La guía de inicio rápido explica todos los pasos necesarios.
Instala el SDK de Adapty con Gradle
La instalación del SDK de Adapty con Gradle es necesaria tanto para apps Android como iOS.
Elige el método de configuración de dependencias:
- Gradle estándar: añade las dependencias a tu
build.gradlea nivel de módulo - Si tu proyecto usa archivos
.gradle.kts, añade las dependencias a tubuild.gradle.ktsa nivel de módulo - Si usas catálogos de versiones, añade las dependencias a tu archivo
libs.versions.tomly luego referéncialas enbuild.gradle.kts
Si recibes un error relacionado con Maven, asegúrate de tener mavenCentral() en tus scripts de Gradle.
Instrucciones para añadirlo
Si tu proyecto no tiene dependencyResolutionManagement en tu settings.gradle, añade lo siguiente a tu build.gradle de nivel superior al final de repositories:
allprojects {
repositories {
...
mavenCentral()
}
}De lo contrario, añade lo siguiente a tu settings.gradle en repositories de la sección dependencyResolutionManagement:
dependencyResolutionManagement {
...
repositories {
...
google()
mavenCentral()
}
}Activar el SDK de Adapty
Configuración básica
Añade la inicialización lo antes posible, normalmente en tu código Kotlin compartido para ambas plataformas.
El SDK de Adapty solo necesita activarse una vez en tu app.
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.build()
Adapty.activate(configuration = config)
.onSuccess {
Log.d("Adapty", "SDK initialised")
}
.onError { error ->
Log.e("Adapty", "Adapty init error: ${error.message}")
}
Espera a que activate finalice antes de llamar a cualquier otro método del SDK de Adapty. Consulta Orden de llamadas en el SDK de Kotlin Multiplatform para ver la secuencia completa.
Para obtener tu Public SDK Key:
- Ve al Adapty Dashboard y navega a App settings → General.
- En la sección Api keys, copia la Public SDK Key (NO la Secret Key).
- Reemplaza
"YOUR_PUBLIC_SDK_KEY"en el código.
- Asegúrate de usar la clave SDK pública para la inicialización de Adapty; la clave secreta debe usarse únicamente para la API del servidor.
- Las claves SDK son únicas para cada app, así que si tienes varias apps asegúrate de elegir la correcta.
Ahora configura los paywalls en tu app:
- Si usas Adapty Paywall Builder, primero activa el módulo AdaptyUI a continuación, y luego sigue la guía de inicio rápido del Paywall Builder.
- Si construyes tu propia interfaz de paywall, consulta la guía de inicio rápido para paywalls personalizados.
Activa el módulo AdaptyUI del SDK de Adapty
Si tienes previsto activar el módulo AdaptyUI para usar el Adapty Paywall Builder, asegúrate de establecer .withActivateUI(true) en tu configuración.
importante En tu código, debes activar el módulo principal de Adapty antes de activar AdaptyUI.
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withActivateUI(true) // true for activating the AdaptyUI module
.build()
Adapty.activate(configuration = config)
.onSuccess {
Log.d("Adapty", "SDK initialised")
}
.onError { error ->
Log.e("Adapty", "Adapty init error: ${error.message}")
}
Configurar Proguard (Android)
Antes de lanzar tu app en producción, es posible que necesites añadir -keep class com.adapty.** { *; } a tu configuración de Proguard.
Configuración opcional
Registro de actividad
Configurar el sistema de registro
Adapty registra errores e información importante para ayudarte a entender qué está pasando. Los niveles disponibles son los siguientes:
| Level | Description |
|---|---|
AdaptyLogLevel.ERROR | Solo se registrarán los errores. |
AdaptyLogLevel.WARN | Se registrarán los errores y los mensajes del SDK que no causan errores críticos pero que merecen atención. |
AdaptyLogLevel.INFO | Se registrarán errores, advertencias y varios mensajes informativos. Valor predeterminado. |
AdaptyLogLevel.VERBOSE | Se registrará cualquier información adicional que pueda ser útil durante la depuración, como llamadas a funciones, consultas a la API, etc. |
AdaptyLogLevel.DEBUG | Se registrará la información más detallada, incluidos los datos de depuración internos. |
| Puedes establecer el nivel de log en tu app antes de configurar Adapty: |
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withLogLevel(AdaptyLogLevel.VERBOSE) // recommended for development
.build()
Políticas de datos
Deshabilitar la recopilación y el uso compartido de la dirección IP
Al activar el módulo de Adapty, establece ipAddressCollectionDisabled en true para deshabilitar la recopilación y el uso compartido de la dirección IP del usuario. El valor predeterminado es false.
Usa este parámetro para mejorar la privacidad del usuario, cumplir con las normativas regionales de protección de datos (como GDPR o CCPA) o reducir la recopilación de datos innecesaria cuando las funciones basadas en IP no son necesarias para tu app.
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withIpAddressCollectionDisabled(true)
.build()
Deshabilitar la recopilación y el uso compartido del ID publicitario
Al activar el módulo de Adapty, establece appleIdfaCollectionDisabled (iOS) o googleAdvertisingIdCollectionDisabled (Android) en true para deshabilitar la recopilación de identificadores publicitarios. El valor predeterminado es false.
Usa este parámetro para cumplir con las políticas de App Store/Play Store, evitar que se muestre el aviso de App Tracking Transparency o si tu app no necesita atribución publicitaria ni analíticas basadas en identificadores de publicidad.
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withGoogleAdvertisingIdCollectionDisabled(true) // Android only
.withAppleIdfaCollectionDisabled(true) // iOS only
.build()
Configurar la caché de medios para AdaptyUI
Por defecto, AdaptyUI almacena en caché los medios (como imágenes y vídeos) para mejorar el rendimiento y reducir el uso de red. Puedes personalizar los ajustes de caché proporcionando una configuración personalizada.
Usa mediaCache para sobrescribir los ajustes de caché por defecto:
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withMediaCacheConfiguration(
AdaptyConfig.MediaCacheConfiguration(
memoryStorageTotalCostLimit = 200 * 1024 * 1024, // 200 MB
memoryStorageCountLimit = Int.MAX_VALUE,
diskStorageSizeLimit = 200 * 1024 * 1024 // 200 MB
)
)
.build()
Habilitar niveles de acceso locales (Android)
Por defecto, los niveles de acceso locales están desactivados para Android. Para habilitarlos, establece withLocalAccessLevelAllowed en true:
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withGoogleLocalAccessLevelAllowed(true)
.build()
Borrar datos al restaurar desde copia de seguridad
Cuando withAppleClearDataOnBackup se establece en true, el SDK detecta cuándo la app se restaura desde una copia de seguridad de iCloud y elimina todos los datos almacenados localmente por el SDK, incluida la información de perfil en caché, los detalles de productos y los paywalls. El SDK se inicializa entonces con un estado limpio. El valor predeterminado es false.
Solo se elimina la caché local del SDK. El historial de transacciones con Apple y los datos de usuario en los servidores de Adapty permanecen sin cambios.
val config = AdaptyConfig
.Builder("PUBLIC_SDK_KEY")
.withAppleClearDataOnBackup(true)
.build()
Solución de problemas
Reglas de copia de seguridad en Android (configuración de Auto Backup)
Algunos SDKs (incluido Adapty) incluyen su propia configuración de Android Auto Backup. Si utilizas varios SDKs que definen reglas de copia de seguridad, el fusionador de manifiestos de Android puede fallar con un error relacionado con android:fullBackupContent, android:dataExtractionRules o android:allowBackup.
Síntomas típicos del error: Manifest merger failed: Attribute application@dataExtractionRules value=(@xml/your_data_extraction_rules) is also present at [com.other.sdk:library:1.0.0] value=(@xml/other_sdk_data_extraction_rules)
Estos cambios deben realizarse en el directorio de la plataforma Android (normalmente en la carpeta android/ de tu proyecto).
Para resolverlo, necesitas:
-
Indicar al fusionador de manifiestos que use los valores de tu app para los atributos relacionados con la copia de seguridad.
-
Crear archivos de reglas de copia de seguridad que combinen las reglas de Adapty con las de otros SDKs.
1. Añade el namespace tools a tu manifiesto
En tu archivo AndroidManifest.xml, asegúrate de que la etiqueta raíz <manifest> incluya tools:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.app">
...
</manifest>
2. Sobreescribe los atributos de copia de seguridad en <application>
En el mismo archivo AndroidManifest.xml, actualiza la etiqueta <application> para que tu app proporcione los valores definitivos e indique al fusionador de manifiestos que reemplace los valores de las librerías:
<application
android:name=".App"
android:allowBackup="true"
android:fullBackupContent="@xml/sample_backup_rules"
android:dataExtractionRules="@xml/sample_data_extraction_rules"
tools:replace="android:fullBackupContent,android:dataExtractionRules">
...
</application>
Si algún SDK también define android:allowBackup, inclúyelo en tools:replace:
tools:replace="android:allowBackup,android:fullBackupContent,android:dataExtractionRules"
3. Crea los archivos de reglas de copia de seguridad combinadas
Crea archivos XML en el directorio res/xml/ de tu proyecto Android que combinen las reglas de Adapty con las de otros SDKs. Android utiliza distintos formatos de reglas de copia de seguridad según la versión del sistema operativo, por lo que crear ambos archivos garantiza la compatibilidad con todas las versiones de Android que admite tu app.
Los ejemplos a continuación usan AppsFlyer como SDK de terceros de muestra. Reemplaza o añade reglas para cualquier otro SDK que uses en tu app.
Para Android 12 y superior (usa el nuevo formato de reglas de extracción de datos):
<?xml version="1.0" encoding="utf-8"?>
<data-extraction-rules>
<cloud-backup>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="appsflyer-purchase-data"/>
<exclude domain="database" path="afpurchases.db"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
</cloud-backup>
<device-transfer>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="appsflyer-purchase-data"/>
<exclude domain="database" path="afpurchases.db"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
</device-transfer>
</data-extraction-rules>
Para Android 11 e inferior (usa el formato legado de contenido de copia de seguridad completa):
<?xml version="1.0" encoding="utf-8"?>
<full-backup-content>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
En un proyecto Kotlin Multiplatform, aplica estos cambios en el módulo de la aplicación Android (el que genera el APK/AAB), por ejemplo, androidApp o app:
- Manifest:
androidApp/src/main/AndroidManifest.xml - XML de reglas de copia de seguridad:
androidApp/src/main/res/xml/
Las compras fallan al volver desde otra app en Android
Si la Activity que inicia el flujo de compra utiliza un launchMode no predeterminado, Android puede recrearla o reutilizarla de forma incorrecta cuando el usuario regresa desde Google Play, una aplicación bancaria o un navegador. Esto puede provocar que el resultado de la compra se pierda o se trate como cancelado.
Para garantizar que las compras funcionen correctamente, utiliza únicamente los modos de lanzamiento standard o singleTop para la Activity que inicia el flujo de compra, y evita cualquier otro modo.
En tu AndroidManifest.xml, asegúrate de que la Activity que inicia el flujo de compra esté configurada como standard o singleTop:
<activity
android:name=".MainActivity"
android:launchMode="standard" />