Zum Hauptinhalt springen
Zurück zu Plugins
@capgo/native-purchases
Tutorial
@capgo/native-purchases

Native Purchases

Implement native in-app purchases, subscriptions, und iOS StoreKit-Zahlungspläne mit einem einfachen API

Richtlinie

Tutorial zu Native-Käufen

Mit @capgo/native-purchases

In-app-Abonnements leicht gemacht.

Install

bun add @capgo/native-purchases
bunx cap sync

Was diese Plugin-Exposition enthält

  • restorePurchases - Wiederherstellt einen Benutzers vorherigen und verknüpft ihre appUserIDs mit jeder Benutzers, die auch diese verwenden .
  • getAppTransaction - Holt die App-Transaktionsinformationen, die Details über den Zeitpunkt liefern, an dem der Benutzer das Programm ursprünglich heruntergeladen oder das Programm gekauft hat.
  • isEntitledToOldBusinessModel - Vergleicht die ursprüngliche App-Version aus der App-Transaktion mit einer Zielversion, um zu bestimmen, ob der Benutzer berechtigt ist, Funktionen aus einem früheren Geschäftsmodell zu nutzen.
  • getProducts - Lädt Produktmetadaten aus dem Store, einschließlich unterstützter iOS-Abonnement-Preisbegriffe.
  • purchaseProduct - Startet den Kaufprozess für das ausgewählte Produkt und die Rechnungsstellung.

Beispiel für die Verwendung

restorePurchases

Wiederherstellt einen Benutzers vorherigen und verknüpft ihre appUserIDs mit jeder Benutzers, die auch diese verwenden .

import { NativePurchases } from '@capgo/native-purchases';

await NativePurchases.restorePurchases();

getAppTransaction

Holt die App-Transaktionsinformationen, die Details über den Zeitpunkt liefern, an dem der Benutzer das Programm ursprünglich heruntergeladen oder das Programm gekauft hat.

import { NativePurchases } from '@capgo/native-purchases';

const { appTransaction } = await NativePurchases.getAppTransaction();

// Check if user downloaded before version 2.0.0 (when subscription was added)
if (compareVersions(appTransaction.originalAppVersion, '2.0.0') < 0) {
  // User gets free access - they downloaded before subscriptions
  grantFreeAccess();
}

isEntitledToOldBusinessModel

Vergleicht die ursprüngliche App-Version aus der App-Transaktion mit einer Zielversion, um zu bestimmen, ob der Benutzer berechtigt ist, Funktionen aus einem früheren Geschäftsmodell zu nutzen.

import { NativePurchases } from '@capgo/native-purchases';

// Check if user downloaded before version 2.0.0/build 42 (when subscription was added)
const result = await NativePurchases.isEntitledToOldBusinessModel({
  targetVersion: '2.0.0',
  targetBuildNumber: '42'
});

if (result.isOlderVersion) {
  console.log(`User downloaded v${result.originalAppVersion}, granting free access`);
  grantFreeAccess();
}

purchaseProduct

Starte den Kaufprozess für das angegebene Produkt. Für Android-Abonnements übergeben Sie die Google Play-Base-Plan-ID als planIdentifier. Für unterstützte iOS-Abonnements, die monatliche Abrechnung mit einer 12-monatigen Verpflichtung anbieten, übergeben Sie billingPlanType: 'monthly'.

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';

await NativePurchases.purchaseProduct({
  productIdentifier: 'com.example.premium.monthly',
  planIdentifier: 'monthly-plan',
  productType: PURCHASE_TYPE.SUBS,
});

iOS-Monatsverpflichtungsabonnements

Auf unterstützten iOS-Versionen kann StoreKit eine monatliche Abrechnungsvereinbarung mit einer 12-monatigen Verpflichtung durch pricingTerms. Zeigen Sie diese Bedingungen auf Ihrem Zahlungsschalter vor dem Kauf an:

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';

const { products } = await NativePurchases.getProducts({
  productIdentifiers: ['com.example.premium.yearly'],
  productType: PURCHASE_TYPE.SUBS,
});

const yearlyProduct = products.find(
  (product) => product.identifier === 'com.example.premium.yearly',
);
const monthlyCommitment = yearlyProduct?.pricingTerms?.find(
  (term) => term.billingPlanType === 'monthly',
);

if (yearlyProduct && monthlyCommitment) {
  console.log('Monthly price:', monthlyCommitment.billingDisplayPrice);
  console.log('Total commitment:', monthlyCommitment.commitmentInfo?.priceString);

  const transaction = await NativePurchases.purchaseProduct({
    productIdentifier: yearlyProduct.identifier,
    productType: PURCHASE_TYPE.SUBS,
    billingPlanType: 'monthly',
  });

  console.log('Billing plan:', transaction.billingPlanType);
  console.log('Commitment ends:', transaction.commitmentInfo?.expirationDate);
}

Vollständige Referenz

Fahren Sie mit dem "@capgo/native-purchases"-Beispiel fort

Wenn Sie "@__CAPGO_KEEP_0__/native-purchases" verwenden Verwenden Sie "@capgo/native-purchases" Zahlungen und Kaufleistungen zu planen, verbinden Sie es mit @capgo/native-purchases Für die Implementierungsdetails in @capgo/native-purchases Einstieg Für die Implementierungsdetails in Einstieg Capgo Preisliste Für den Produktworkflow in Capgo Preisliste Zahlungssystem Für die Implementierungsdetails in Zahlungssystem und Revenue-Playbook Für die Implementierungsdetails in Revenue-Playbook.