Saltar al contenido

Empezar

GitHub

Puedes utilizar nuestra configuración asistida por IA para instalar el plugin. Agrega las Capgo habilidades a tu herramienta de IA utilizando el siguiente comando:

Ventana de terminal
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins

Luego utiliza el siguiente prompt:

Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/native-purchases` plugin in my project.

Si prefieres la configuración Manual, instala el plugin ejecutando los siguientes comandos y sigue las instrucciones específicas del plataforma a continuación:

  1. Instala el paquete

    Ventana de terminal
    bun add @capgo/native-purchases
  2. Sincronizar con proyectos nativos

    Ventana de terminal
    bunx cap sync
  3. Ver el soporte de facturación

    import { NativePurchases } from '@capgo/native-purchases';
    const { isBillingSupported } = await NativePurchases.isBillingSupported();
    if (!isBillingSupported) {
    throw new Error('Billing is not available on this device');
    }
  4. Cargar productos directamente desde las tiendas

    import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
    const { products } = await NativePurchases.getProducts({
    productIdentifiers: [
    'com.example.premium.monthly',
    'com.example.premium.yearly',
    'com.example.one_time_unlock'
    ],
    productType: PURCHASE_TYPE.SUBS, // Use PURCHASE_TYPE.INAPP for one‑time products
    });
    products.forEach((product) => {
    console.log(product.title, product.priceString);
    });
  5. Implementar flujos de compra y restauración

    import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
    const monthlyPlanId = 'monthly-plan'; // Base Plan ID from Google Play Console
    const transaction = await NativePurchases.purchaseProduct({
    productIdentifier: 'com.example.premium.monthly',
    planIdentifier: monthlyPlanId, // REQUIRED for Android subscriptions, ignored on iOS
    productType: PURCHASE_TYPE.SUBS,
    quantity: 1,
    });
    console.log('Transaction ID', transaction.transactionId);
    await NativePurchases.restorePurchases();
    • Crear productos y suscripciones en la tienda en App Store Connect.
    • Utilice StoreKit Local Testing o Sandbox testers para QA.
    • No se requieren ediciones del manifiesto. Asegúrese de que sus productos estén aprobados.
import { NativePurchases, PURCHASE_TYPE, Transaction } from '@capgo/native-purchases';
import { Capacitor } from '@capacitor/core';
class PurchaseService {
private premiumProduct = 'com.example.premium.unlock';
private monthlySubId = 'com.example.premium.monthly';
private monthlyPlanId = 'monthly-plan'; // Base Plan ID (Android only)
async initialize() {
const { isBillingSupported } = await NativePurchases.isBillingSupported();
if (!isBillingSupported) throw new Error('Billing unavailable');
const { products } = await NativePurchases.getProducts({
productIdentifiers: [this.premiumProduct, this.monthlySubId],
productType: PURCHASE_TYPE.SUBS,
});
console.log('Loaded products', products);
if (Capacitor.getPlatform() === 'ios') {
NativePurchases.addListener('transactionUpdated', (transaction) => {
this.handleTransaction(transaction);
});
}
}
async buyPremium(appAccountToken?: string) {
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: this.premiumProduct,
productType: PURCHASE_TYPE.INAPP,
appAccountToken,
});
await this.processTransaction(transaction);
}
async buyMonthly(appAccountToken?: string) {
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: this.monthlySubId,
planIdentifier: this.monthlyPlanId, // REQUIRED for Android subscriptions
productType: PURCHASE_TYPE.SUBS,
appAccountToken,
});
await this.processTransaction(transaction);
}
async restore() {
await NativePurchases.restorePurchases();
await this.refreshEntitlements();
}
async openManageSubscriptions() {
await NativePurchases.manageSubscriptions();
}
private async processTransaction(transaction: Transaction) {
this.unlockContent(transaction.productIdentifier);
this.validateOnServer(transaction).catch(console.error);
}
private unlockContent(productIdentifier: string) {
// persist entitlement locally
console.log('Unlocked', productIdentifier);
}
private async refreshEntitlements() {
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
console.log('Current purchases', purchases);
}
private async handleTransaction(transaction: Transaction) {
console.log('StoreKit transaction update:', transaction);
await this.processTransaction(transaction);
}
private async validateOnServer(transaction: Transaction) {
await fetch('/api/validate-purchase', {
method: 'POST',
body: JSON.stringify({
transactionId: transaction.transactionId,
receipt: transaction.receipt,
purchaseToken: transaction.purchaseToken,
}),
});
}
}
OpciónPlataformaDescripción
productIdentifieriOS + AndroidEl SKU/ID de producto configurado en App Store Connect / Google Play Console.
productTypeSolo para AndroidPURCHASE_TYPE.INAPP o PURCHASE_TYPE.SUBS. Por defecto es INAPP. Siempre se establece en SUBS para las suscripciones.
planIdentifierSuscripciones de AndroidID de plan base desde Google Play Console. Requerido para las suscripciones, ignorado en iOS y compras in-app.
billingPlanTypeSuscripciones de iOSPlan de facturación de StoreKit para comprar. Utilice 'monthly' para la facturación mensual con un compromiso de 12 meses cuando product.pricingTerms exposa esa opción.
quantityiOSSolo para compras en la aplicación, por defecto es 1. Siempre compra un artículo en Android.
appAccountTokeniOS + AndroidUUID/cadena que vincula la compra a su usuario. Es obligatorio que sea UUID en iOS; Android acepta cualquier cadena obfusca hasta 64 caracteres.
isConsumableAndroidEstablezca a true para consumir tokens automáticamente después de conceder la autorización para consumibles. Por defecto es false.

Usar getPurchases() para una vista transversal de cada transacción que los almacenes informan:

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
purchases.forEach((purchase) => {
if (purchase.isActive && purchase.expirationDate) {
console.log('iOS sub active until', purchase.expirationDate);
}
const isAndroidIapValid =
['PURCHASED', '1'].includes(purchase.purchaseState ?? '') && purchase.isAcknowledged;
if (isAndroidIapValid) {
console.log('Grant in-app entitlement for', purchase.productIdentifier);
}
});
  • iOS: Las suscripciones incluyen isActive, expirationDate, willCancely el soporte de escucha de StoreKit 2. Los compras en la aplicación requieren la validación de la factura del servidor.
  • Android: isActive/expirationDate no se rellenan; llame al desarrollador de Google Play API con el purchaseToken para el estado autoritativo. purchaseState deben ser PURCHASED y isAcknowledged debe ser true.
  • isBillingSupported() – verificar la disponibilidad en la Tienda de Mac / Google Play.
  • getProduct() / getProducts() – obtener el precio, título localizado, descripción, ofertas de introducción y términos de precios de iOS admitidos.
  • purchaseProduct() – iniciar el flujo de compra del cliente de StoreKit 2 o Billing, incluyendo los planes de facturación mensuales de iOS.
  • restorePurchases() – reproducir compras históricas y sincronizar con el dispositivo actual.
  • getPurchases() – listar todas las transacciones de iOS o compras de facturación de Play Billing.
  • manageSubscriptions() – abrir la interfaz de usuario de gestión de suscripciones nativa.
  • addListener('transactionUpdated') – manejar transacciones pendientes de StoreKit 2 cuando se inicia la aplicación (solo iOS).
  1. Muestra el precio de la tienda – Apple requiere mostrar product.title y product.priceString; nunca codifiques directamente.
  2. Utilice appAccountToken – genere determinísticamente un UUID (v5) a partir del ID del usuario para vincular compras a cuentas.
  3. Valida en el servidor – envía receipt (iOS) / purchaseToken (Android) a su back-end para la verificación.
  4. Gestiona errores con amabilidad – comprueba las cancelaciones de usuario, las fallas de red y los entornos de facturación no compatibles.
  5. Prueba exhaustivamente – sigue el iOS guía de sandbox y Android guía de sandbox.
  6. Ofrece restauración y administración – agrega botones de interfaz de usuario conectados a restorePurchases() y manageSubscriptions().

Después de que el flujo de compra funciona, utilice el Libro de estrategias de ingresos para planificar tu primer funel pagado: alcance del producto, ASO, precios, ubicación de la pantalla de pago, análisis y retroalimentación de abandono.

Los productos no se cargan

  • Asegúrate de que el ID de la cesta / ID de la aplicación coincida con la configuración de la tienda.
  • Confirma que los IDs de los productos estén activos y aprobados (App Store) o activados (Google Play).
  • Espera varias horas después de crear productos; la propagación de la tienda no es instantánea.

La compra se canceló o se quedó atascada

  • Los usuarios pueden cancelar en medio del flujo; envuelve las llamadas en try/catch y muestra mensajes de error amigables.
  • Para Android, asegúrate de que las cuentas de prueba instalen la aplicación desde la tienda Play (pista interna) para que la facturación funcione.
  • Revisa logcat/Xcode para errores de facturación cuando se ejecuta en dispositivo.

Estado de suscripción incorrecto

  • Usar getPurchases() para comparar los datos de la tienda con su caché de derechos locales.
  • En Android, siempre consulte el Google Play Developer API con el purchaseToken para obtener fechas de vencimiento o estado de reembolso.
  • En iOS, revise isActive/expirationDate y valide los recibos para detectar reembolsos o revocaciones.

Si está utilizando Getting Started para planificar la aprobación y distribución de la tienda, conecte con ella Usando @capgo/compras-nativas para la capacidad nativa en Usando @capgo/compras-nativas, @capgo/capacitor-revisión-de-aplicación-interna para el detalle de implementación en @capgo/capacitor-revisión-de-aplicación-interna, Usando @capgo/capacitor-revisión-de-aplicación-interna para la capacidad nativa en Usando @capgo/capacitor-revisión-de-aplicación-interna, @capgo/capacitor-mercado-nativo para el detalle de implementación en @capgo/capacitor-mercado-nativo, y Usando @capgo/capacitor-mercado-nativo para la capacidad nativa en Usando @capgo/capacitor-mercado-nativo.