Seguimiento de eventos dentro de la aplicación
Realice un seguimiento de los eventos dentro de la aplicación para analizar el rendimiento de la campaña y medir los indicadores clave de rendimiento (KPI), como inicios de sesión de usuarios, registros, finalización de tutoriales o hitos de progresión.
Eventos y atributos estándar
Tipos de eventos
Singular admite dos tipos de eventos para adaptarse a las necesidades de seguimiento universales y específicas de la aplicación.
-
Eventos estándar: Eventos predefinidos (por ejemplo,
sngLogin,sngContentView) reconocidos por Singular y admitidos por las redes publicitarias para la generación de informes y la optimización. El uso de eventos estándar simplifica la configuración, ya que Singular los añade automáticamente a la lista de eventos sin necesidad de definirlos manualmente. Consulte la Lista de eventos y atributos estándar para ver los nombres completos de los eventos y los atributos recomendados. -
Eventos personalizados: Eventos exclusivos de su aplicación (por ejemplo,
Signup,AchievementUnlocked) que no coinciden con los eventos estándar de Singular.
Recomendación: Utilice eventos estándar siempre que sea posible para la compatibilidad con redes publicitarias y el reconocimiento automático en la lista de eventos de Singular.
Su equipo de UA, marketing o comercial debe compilar la lista de eventos basándose en los KPI de marketing de su organización. Consulte la guía How to Track In-App Events: Guía para clientes de Singular Attribution para la planificación.
Limitaciones de los eventos personalizados
Los eventos personalizados tienen limitaciones específicas de caracteres y codificación para garantizar la compatibilidad con socios y soluciones de análisis de terceros.
Limitaciones de eventos personalizados:
- Idioma: Pase los nombres y atributos de los eventos en inglés para garantizar la compatibilidad con socios y soluciones de análisis de terceros.
- Nombres de eventos: Limitados a 32 caracteres ASCII. Las cadenas no ASCII deben tener menos de 32 bytes cuando se convierten a UTF-8.
- Atributos y valores: Limitado a 500 caracteres ASCII
Envío de eventos
Método de eventos
Realiza el seguimiento de eventos simples sin atributos adicionales utilizando el método event().
import 'package:singular_flutter_sdk/singular.dart';
// Track a simple custom event
Singular.event('SignUp');
// Track a standard event
Singular.event('sngLogin');
Firmadel método:
static void event(String eventName)
Para ver la lista completa de métodos, consulta la referencia de métodos de eventos.
Método EventWithArgs
Realiza el seguimiento de eventos con atributos personalizados adicionales para proporcionar un contexto más rico y permitir una segmentación detallada en los informes.
import 'package:singular_flutter_sdk/singular.dart';
// Track custom event with attributes
Singular.eventWithArgs('LevelComplete', {
'level': 5,
'score': 1250,
'time_spent': 45.3
});
// Track standard event with recommended attributes
Singular.eventWithArgs('sngTutorialComplete', {
'sngAttrContent': 'Flutter Basics',
'sngAttrContentId': '32',
'sngAttrContentType': 'video',
'sngAttrSuccess': 'yes'
});
Firma del método:
static void eventWithArgs(String eventName, Map args)
Para obtener la lista completa de métodos, consulte la referencia del método eventWithArgs.
Mejores prácticas
- Utilice eventos estándar: Prefiera eventos estándar para compatibilidad con redes publicitarias y reconocimiento automático en la lista de eventos de Singular.
- Validar atributos: Compruebe que los atributos coinciden con el formato esperado y los límites de caracteres antes de enviarlos
- Depurar eventos: Habilite el registro del SDK durante el desarrollo para verificar que los eventos se envían correctamente y se activan en los momentos adecuados.
- Coordine con los equipos: Trabaje con su equipo de UA/marketing para garantizar que los eventos rastreados se ajustan a los KPI de su aplicación.
- Pruebe antes de la producción: Pruebe los eventos en un entorno de desarrollo para verificar la exactitud de los datos en Singular Dashboard.
Seguimiento de los ingresos dentro de la aplicación
Realice un seguimiento de los ingresos procedentes de compras dentro de la aplicación (IAP), suscripciones y fuentes de ingresos personalizadas para medir el rendimiento de la campaña y el retorno de la inversión publicitaria (ROAS).
Los datos de ingresos fluyen a través de tres canales:
- Informes interactivos: Visualiza las métricas de ingresos en el panel de control de Singular.
- Registros de exportación: Acceso a datos ETL detallados para análisis personalizados
- Postbacks en tiempo real: Envíe eventos de ingresos a plataformas externas
¿Por qué realizar un seguimiento de los eventos de ingresos?
- Análisis enriquecidos: Capture datos detallados de transacciones para mejorar los informes de Singular
- Prevención del fraude: Incluya recibos de transacciones (por ejemplo, de Google Play o Apple App Store) para validar las compras y combatir el fraude dentro de la aplicación.
- Optimización de campañas: Mida el ROI vinculando los ingresos a los esfuerzos de marketing
Práctica recomendada: Pasar el objeto de compra completo
Recomendamos encarecidamente pasar el objeto de compra devuelto desde el proceso In-App Purchase (IAP) de Android (Google Play Billing) o iOS (StoreKit). Esto asegura que Singular reciba los detalles completos de la transacción, incluyendo:
- ID del producto
- Precio
- Moneda
- ID de la transacción
- Datos del recibo (para validación)
Al pasar el objeto de compra completo, permite una generación de informes más rica y aprovecha las capacidades de detección de fraude de Singular, en particular para las transacciones de Google Play.
Integración de compras dentro de la aplicación
Captura del objeto de compra IAP
Utilice el paquete in_app_purchase de Flutter para recuperar el objeto de compra con los detalles completos de la transacción.
- Flutter: Utiliza el paquete in_app_purchase para acceder a los detalles de compra tanto de iOS StoreKit como de Android Google Play Billing.
Método InAppPurchase
Realice un seguimiento de los eventos de compra dentro de la aplicación con detalles de compra para la validación de ingresos y la prevención del fraude.
Firmas de métodos:
static void inAppPurchase(String eventName, SingularIAP purchase)
static void inAppPurchaseWithAttributes(String eventName, SingularIAP purchase, Map attributes)
Para obtener la lista completa de métodos, consulte la referencia del método inAppPurchase.
Ejemplo de implementación de IAP completo
Implemente un receptor de compras completo que capture eventos de IAP y los envíe a Singular con objetos de compra específicos de la plataforma.
import 'dart:io' show Platform;
import 'package:in_app_purchase/in_app_purchase.dart';
import 'package:in_app_purchase_android/in_app_purchase_android.dart';
import 'package:in_app_purchase_storekit/in_app_purchase_storekit.dart';
import 'package:singular_flutter_sdk/singular.dart';
import 'package:singular_flutter_sdk/singular_iap.dart';
Future<void> handlePurchase(PurchaseDetails purchaseDetails) async {
if (purchaseDetails.status != PurchaseStatus.purchased &&
purchaseDetails.status != PurchaseStatus.restored) {
return;
}
final response = await InAppPurchase.instance
.queryProductDetails({purchaseDetails.productID});
if (response.productDetails.isEmpty) {
return;
}
final product = response.productDetails.first;
// Extract price and currency with platform-specific handling
double price = 0.0;
String currency = 'USD';
if (Platform.isAndroid && product is GooglePlayProductDetails) {
final offer = product.productDetails.oneTimePurchaseOfferDetails;
price = (offer?.priceAmountMicros ?? 0) / 1000000;
currency = offer?.priceCurrencyCode ?? 'USD';
} else if (Platform.isIOS && product is AppStoreProductDetails) {
price = product.skProduct.price;
currency = product.skProduct.priceLocale.currencyCode ?? 'USD';
}
SingularIAP? singularPurchase;
if (Platform.isAndroid && purchaseDetails is GooglePlayPurchaseDetails) {
singularPurchase = SingularAndroidIAP(
price,
currency,
purchaseDetails.billingClientPurchase.signature,
purchaseDetails.billingClientPurchase.originalJson,
);
} else if (Platform.isIOS && purchaseDetails is AppStorePurchaseDetails) {
singularPurchase = SingularIOSIAP(
price,
currency,
purchaseDetails.productID,
purchaseDetails.skPaymentTransaction.transactionIdentifier ?? '',
purchaseDetails.verificationData.serverVerificationData,
);
} else {
return;
}
const String eventName = 'iap_purchase';
// Track with attributes (use only ONE tracking method)
Singular.inAppPurchaseWithAttributes(eventName, singularPurchase, {
'user_level': 42,
'is_first_purchase': true,
'gems_balance': 1500
});
await InAppPurchase.instance.completePurchase(purchaseDetails);
}
Seguimiento manual de ingresos
Ingresos sin validación de compra
Realice un seguimiento de los ingresos pasando la divisa, el importe y los detalles opcionales del producto sin el objeto de compra. Tenga en cuenta que este método no proporciona recibos de transacción para su validación.
Importante: Al enviar eventos de ingresos sin un objeto de compra válido, Singular no valida las transacciones. Recomendamos encarecidamente utilizar los métodos inAppPurchase() descritos anteriormente siempre que sea posible.
Nota: Pase la divisa como un código de divisa ISO 4217 de tres letras, por ejemplo, USD, EUR, INR.
Método CustomRevenue
Rastrea eventos de ingresos personalizados con un nombre de evento, moneda e importe especificados.
import 'package:singular_flutter_sdk/singular.dart';
// Track custom revenue event
Singular.customRevenue('PremiumUpgrade', 'USD', 9.99);
Firma del método:
static void customRevenue(String eventName, String currency, double amount)
Para obtener la lista completa de métodos, consulte la referencia del método customRevenue.
Método CustomRevenueWithAttributes
Realiza el seguimiento de eventos de ingresos personalizados con un nombre de evento, divisa, importe y atributos personalizados adicionales especificados.
import 'package:singular_flutter_sdk/singular.dart';
// Track custom revenue event with attributes
Singular.customRevenueWithAttributes('PremiumBundlePurchase', 'USD', 99.99, {
'productSKU': 'premium_bundle_xyz',
'productName': 'Premium Bundle',
'productCategory': 'Bundles',
'productQuantity': 1,
'discount_applied': true
});
Firmadel método:
static void customRevenueWithAttributes(
String eventName,
String currency,
double amount,
Map attributes
)
Para obtener la lista completa de métodos, consulte la referencia del método customRevenueWithAttributes.
Método customRevenueWithAllAttributes
Realiza un seguimiento de los eventos de ingresos personalizados con todos los atributos posibles, incluidos SKU del producto, nombre, categoría, cantidad y atributos personalizados.
import 'package:singular_flutter_sdk/singular.dart';
// Track custom revenue with all attributes
Singular.customRevenueWithAllAttributes(
'CoinPackagePurchase',
'USD',
4.99,
'coin_package_abc123',
'Coin Pack 10',
'Virtual Currency',
2,
{
'payment_method': 'google_play',
'transaction_id': 'T12345'
}
);
Firmadel método:
static void customRevenueWithAllAttributes(
String eventName,
String currency,
double amount,
String productSKU,
String productName,
String productCategory,
int productQuantity,
Map attributes
)
Para obtener la lista completa de métodos, consulte la referencia del método customRevenueWithAllAttributes.
Ingresos por suscripción
Seguimiento de suscripciones
Singular ofrece una guía completa sobre la implementación de eventos de suscripción utilizando el SDK de Singular. La guía cubre el seguimiento de eventos de suscripción dentro de la aplicación en varias plataformas.
- Lea la Guía de implementación técnica de eventos de suscripción si desea realizar un seguimiento de los ingresos por suscripción
Seguimiento de eventos híbridos (avanzado)
Singular recomienda enviar todos los eventos e ingresos a través del SDK de Singular integrado en su aplicación para una atribución óptima. Sin embargo, Singular puede recopilar eventos de otras fuentes cuando sea necesario.
Los eventos enviados fuera del SDK de Singular deben cumplir con los requisitos de documentación de eventos de servidor a servidor de Singular y proporcionar identificadores de dispositivo coincidentes para una atribución correcta.
Importante:
Se producirán discrepancias si los identificadores de dispositivo utilizados en las solicitudes de eventos de servidor a servidor no tienen un identificador de dispositivo coincidente en Singular. Tenga en cuenta las siguientes posibilidades:
- Eventos tempranos: Si se recibe una solicitud de evento antes de que Singular SDK haya registrado el identificador de dispositivo de una sesión de aplicación, la solicitud de evento se considerará la "primera sesión" para el dispositivo desconocido, y Singular atribuirá el dispositivo como una atribución orgánica.
- Identificadores no coincidentes: Si Singular SDK registró un identificador de dispositivo, pero difiere del identificador de dispositivo especificado en la solicitud de evento de servidor a servidor, el evento se atribuirá incorrectamente.
Guías de seguimiento de eventos híbridos
Envío de eventos desde un servidor interno
Recopile datos de ingresos de su servidor interno para analizar el rendimiento de la campaña y el ROI.
Requisitos:
- Capturar identificadores de dispositivos: Desde un evento de registro o inicio de sesión dentro de la aplicación, capture y pase los identificadores de dispositivo y almacene estos datos con el ID de usuario en su servidor. Dado que los identificadores de dispositivo pueden cambiar para un usuario, actualice los identificadores cuando un usuario genere una sesión de aplicación. Esto garantiza que el evento del lado del servidor se atribuya al dispositivo correcto.
- Identificadores específicos de la plataforma: Los eventos del lado del servidor son específicos de cada plataforma y sólo deben enviarse con el identificador de dispositivo que coincida con la plataforma del dispositivo (por ejemplo, IDFA o IDFV para dispositivos iOS, GAID para dispositivos Android)
- Actualizaciones en tiempo real: Utilice el mecanismo Singular Internal BI postback para empujar un evento en tiempo real a su endpoint interno para que pueda actualizar el conjunto de datos en el lado del servidor. Consulte las preguntas frecuentes sobre postback de BIinterno
- Detalles de Implementación: Revise la sección de Seguimiento de Ingresos en la guía de Integración Servidor a Servidor para más detalles.
Envío de Eventos desde un Proveedor de Ingresos
Integre proveedores de ingresos de terceros como RevenueCat o adapty para enviar ingresos por compras y suscripciones a Singular.
Proveedores compatibles:
- RevenueCat: Más información en la documentación de RevenueCat
- adapty: Más información en la documentaciónde adapty
Envío de eventos desde Segment
Habilite Segment para enviar eventos a Singular en paralelo con el SDK de Singular añadiendo un destino "Cloud-Mode" en Segment.
Siga la guía de implementación Integración Singular-Segment para obtener instrucciones detalladas de configuración.