Integraciones de analytics
Adapty envía todos los eventos de suscripción a servicios de analítica como Amplitude, Mixpanel y AppMetrica. También podemos enviar eventos a tu servidor mediante la integración de webhook. Lo mejor de todo es que no tienes que enviar ninguno de los eventos tú mismo; nosotros lo hacemos por ti. Solo asegúrate de configurar la integración en el Adapty Dashboard.
Adapty admite la integración con los siguientes servicios de analítica de terceros:
¿No ves tu proveedor de analítica?
¡Dínoslo! Crea una solicitud de función y lo consideraremos.
Propiedades de los eventos
Los eventos de webhook se envían en formato JSON. Todos los eventos siguen la misma estructura, pero sus campos varían según el tipo de evento, el store y tu configuración específica.
| Propiedad | Tipo | Descripción |
|---|---|---|
| profile_id | uuid | ID de usuario de Adapty. |
| currency | str | Moneda local (por defecto USD). |
| price_usd | float | Precio del producto antes de la comisión de Apple/Google. Ingresos brutos. |
| proceeds_usd | float | Precio del producto después de la comisión de Apple/Google. Ingresos netos. |
| net_revenue_usd | float | Ingresos netos (ingresos después de la comisión de Apple/Google e impuestos) en USD. Puede estar vacío. |
| price_local | float | Precio del producto antes de la comisión de Apple/Google en moneda local. Ingresos brutos. |
| proceeds_local | float | Precio del producto después de la comisión de Apple/Google en moneda local. Ingresos netos. |
| transaction_id | str | Identificador único de una transacción, como una compra o renovación. |
| original_transaction_id | str | Identificador de la transacción de compra original. |
| purchase_date | ISO 8601 date | Fecha y hora de la compra del producto. |
| original_purchase_date | ISO 8601 date | Fecha y hora de la compra original. |
| environment | str | Puede ser Sandbox o Production. |
| vendor_product_id | str | ID del producto en App Store de Apple, Google Play Store o Stripe. |
| base_plan_id | str | ID del plan base en Google Play Store o ID de precio en Stripe. |
| event_datetime | ISO 8601 date | Fecha y hora del evento. |
| store | str | Puede ser app_store o play_store. |
| trial_duration | str | Duración del período de prueba en días. Se envía con el formato ” days”, por ejemplo, “7 days”. |
| cancellation_reason | str | Motivo por el que el usuario canceló una suscripción. Puede ser iOS y Android voluntarily_cancelled, billing_error, refund iOS price_increase, product_was_not_available, unknown Android new_subscription_replace, cancelled_by_developer |
| subscription_expires_at | ISO 8601 date | Fecha de expiración de la suscripción. Normalmente en el futuro. |
| consecutive_payments | int | Número de períodos que un usuario lleva suscrito sin interrupciones. Incluye el período actual. |
| rate_after_first_year | bool | Booleano que indica si la suscripción cumple los requisitos para una comisión reducida (normalmente el 15%) tras un año de renovaciones continuas. Las tasas de comisión varían según la elegibilidad del programa y el país. Consulta Comisión del store e impuestos para más detalles. |
| promotional_offer_id | str | ID de la oferta promocional indicado en la sección de productos del Adapty Dashboard. |
| store_offer_category | str | Puede ser introductory o promotional. |
| store_offer_discount_type | str | Puede ser free_trial, pay_as_you_go o pay_up_front. |
| paywall_name | str | Nombre del paywall donde se originó la transacción. |
| paywall_revision | int | Revisión del paywall donde se originó la transacción. El valor está establecido en 1. |
| developer_id | str | ID de desarrollador (SDK) del placement donde se originó la transacción. |
| ab_test_name | str | Nombre de la prueba A/B donde se originó la transacción. |
| ab_test_revision | int | Revisión de la prueba A/B donde se originó la transacción. El valor está establecido en 1. |
| cohort_name | str | Nombre de la audiencia a la que pertenece el perfil. |
| profile_event_id | uuid | ID único del evento que puede usarse para deduplicación. |
| store_country | str | El país que nos envía el store. |
| profile_ip_address | str | IP del perfil (puede ser IPv4 o IPv6, con preferencia por IPv4 cuando esté disponible). Se actualiza cada vez que cambia la IP del dispositivo. |
| profile_country | str | Determinado por Adapty según la IP del perfil. |
| profile_total_revenue_usd | float | Ingresos totales del perfil, incluidos los reembolsos. |
| variation_id | uuid | ID único del paywall donde se realizó la compra. |
| access_level_id | str | ID del nivel de acceso de pago. |
| is_active | bool | Booleano que indica si el nivel de acceso de pago está activo para el perfil. |
| will_renew | bool | Booleano que indica si el nivel de acceso de pago se renovará. |
| is_refund | bool | Booleano que indica si la transacción fue reembolsada. |
| is_lifetime | bool | Booleano que indica si el nivel de acceso de pago es de por vida. |
| is_in_grace_period | bool | Booleano que indica si el perfil está en período de gracia. |
| starts_at | ISO 8601 date | Fecha y hora en que el nivel de acceso de pago comienza para el usuario. |
| renewed_at | ISO 8601 date | Fecha y hora en que el acceso de pago se renovará. |
| expires_at | ISO 8601 date | Fecha y hora en que el acceso de pago expirará. |
| activated_at | ISO 8601 date | Fecha y hora en que el acceso de pago fue activado. |
| billing_issue_detected_at | ISO 8601 date | Fecha y hora del problema de facturación. |
| profile_has_access_level | Bool | Booleano que indica si el perfil tiene un nivel de acceso activo (solo webhook). |
Cada evento incluye las siguientes propiedades:
transaction_id, original_transaction_id, purchase_date, original_purchase_date, environment, vendor_product_id, event_datetime, store.
Además, algunos eventos tienen propiedades adicionales. Para los eventos subscription_refunded y non_subscription_purchase_refunded, es obligatorio proporcionar los valores de price_usd y proceeds_usd como propiedades adicionales.
| Nombre del evento | Propiedades |
|---|---|
| subscription_initial_purchase | price_usd, proceeds_usd, subscription_expires_at, consecutive_payments, rate_after_first_year, trial_duration |
| subscription_renewed | price_usd, proceeds_usd, subscription_expires_at, consecutive_payments, rate_after_first_year, trial_duration |
| subscription_cancelled | cancellation_reason, trial_duration |
| trial_started | subscription_expires_at, trial_duration |
| trial_converted | price_usd, proceeds_usd, subscription_expires_at, consecutive_payments, rate_after_first_year, trial_duration |
| trial_cancelled | cancellation_reason, trial_duration |
| non_subscription_purchase | price_usd, proceeds_usd |
| billing_issue_detected | subscription_expires_at, trial_duration |
| entered_grace_period | subscription_expires_at, trial_duration |
Ejemplo de evento
{
"price_usd": 9.99,
"proceeds_usd": 6.99,
"transaction_id": "1000000628581600",
"original_transaction_id": "1000000628581600",
"purchase_date": "2020-02-18T18:40:22.000000+0000",
"original_purchase_date": "2020-02-18T18:40:22.000000+0000",
"environment": "Sandbox",
"vendor_product_id": "premium",
"event_datetime": "2020-02-18T18:40:22.000000+0000",
"store": "app_store"
}
Adapty envía eventos a tu servidor y a sistemas de analítica de terceros.
La propiedad profile_ip_address se sincroniza con la IP actual del dispositivo. Cada vez que los servidores de Adapty reciben información del SDK, la IP se actualizará si difiere de la que tenemos registrada.
Configurar el identificador del perfil
- Configura el identificador del perfil para la analítica seleccionada usando las instrucciones para instrucciones para configurar atributos de usuario en tu app iOS, Android, React Native, Flutter y Unity .
Evitar duplicados
No olvides desactivar el envío de eventos de suscripción desde los dispositivos y tu servidor para evitar duplicados.
Deshabilitar la analítica externa para un cliente específico
Es posible que quieras dejar de enviar eventos de analítica para un cliente concreto. Esto es útil si tu app ofrece la opción de no participar en servicios de analítica.
Para deshabilitar la analítica externa de un cliente, usa el método updateProfile(). Crea un objeto AdaptyProfileParameters.Builder y establece el valor correspondiente.
Cuando la analítica externa está bloqueada, Adapty no enviará ningún evento a ninguna integración para ese usuario específico. Si quieres deshabilitar una integración para todos los usuarios de tu app, simplemente desactívala en el Adapty Dashboard.