Mulai Berlari
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/native-purchases`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/native-purchases/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Pemasangan
Judul bagian “Pemasangan”Anda dapat menggunakan Pengaturan Bantu AI kami untuk menginstal plugin. Tambahkan Capgo kemampuan ke alat AI Anda menggunakan perintah berikut:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-pluginsLalu gunakan prompt berikut:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/native-purchases` plugin in my project.Jika Anda lebih suka Pengaturan Manual, instal plugin dengan menjalankan perintah-perintah berikut dan ikuti instruksi spesifik platform di bawah ini:
-
Pasang paket
Jendela terminal bun add @capgo/native-purchases -
Sinkronisasi dengan proyek asli
Jendela terminal bunx cap sync -
Periksa dukungan billing
import { NativePurchases } from '@capgo/native-purchases';const { isBillingSupported } = await NativePurchases.isBillingSupported();if (!isBillingSupported) {throw new Error('Billing is not available on this device');} -
Muat produk secara langsung dari toko
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);}); -
Implementasikan alur pembelian & restorasi
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';const monthlyPlanId = 'monthly-plan'; // Base Plan ID from Google Play Consoleconst transaction = await NativePurchases.purchaseProduct({productIdentifier: 'com.example.premium.monthly',planIdentifier: monthlyPlanId, // REQUIRED for Android subscriptions, ignored on iOSproductType: PURCHASE_TYPE.SUBS,quantity: 1,});console.log('Transaction ID', transaction.transactionId);await NativePurchases.restorePurchases();- Buat produk dalam aplikasi dan langganan di App Store Connect.
- Gunakan StoreKit Local Testing atau Sandbox tester untuk QA.
- Tidak perlu edit manifest. Pastikan produk Anda disetujui.
- Buat produk dan langganan dalam aplikasi di Google Play Console.
- Unggah setidaknya sebuah versi uji internal dan tambahkan pengujian lisensi.
- Tambahkan izin billing ke
AndroidManifest.xml:
<uses-permission android:name="com.android.vending.BILLING" /> - Buat produk dalam aplikasi dan langganan di App Store Connect.
Contoh pembelian layanan
Judul bagian “Contoh pembelian layanan”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, }), }); }}Pilihan pembelian yang diperlukan
Judul bagian “Pilihan pembelian yang diperlukan”| Pilihan | Platform | Deskripsi |
|---|---|---|
productIdentifier | iOS + Android | Kode SKU/ID Produk yang diatur di App Store Connect / Google Play Console. |
productType | Hanya Android | PURCHASE_TYPE.INAPP atau PURCHASE_TYPE.SUBS. Defaultnya adalah INAPP. Selalu ditetapkan sebagai SUBS untuk langganan. |
planIdentifier | Langganan Android | ID Rencana Dasar dari Google Play Console. Diperlukan untuk langganan, diabaikan pada iOS dan pembelian dalam aplikasi. |
billingPlanType | Langganan iOS | Rencana pembayaran StoreKit untuk membeli. Gunakan 'monthly' untuk pembayaran bulanan dengan komitmen 12 bulan ketika product.pricingTerms mengekspos opsi tersebut. |
quantity | IOS | Hanya untuk pembelian dalam aplikasi, default ke 1. Android selalu membeli item satu. |
appAccountToken | IOS + Android | UUID/ string yang terkait dengan pembelian pengguna. Diperlukan untuk UUID di iOS; Android menerima string yang dienkripsi hingga 64 karakter. |
isConsumable | Android | Ditetapkan ke true untuk mengonsumsi token secara otomatis setelah memberikan hak untuk konsumables. Default ke false. |
Mengecek status hak
Bab berjudul “Mengecek status hak”Pakai getPurchases() untuk tampilan lintas platform dari setiap transaksi yang dilaporkan oleh toko-toko:
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); }});Tindakan platform
Judul bagian “Tindakan platform”- iOS: Langganan termasuk
isActive,expirationDate,willCanceldan dukungan pemantauan StoreKit 2. Pembelian dalam aplikasi memerlukan validasi bukti penerimaan server. - Android:
isActive/expirationDatetidak diisi; hubungi pengembang Google Play Developer API denganpurchaseTokenuntuk status yang otoritatif.purchaseStateharusPURCHASEDdanisAcknowledged__CAPGO_KEEP_0__ harus diaturtrue.
API Referensi Cepat
Judul Bagian “API Referensi Cepat”isBillingSupported()– Periksa ketersediaan StoreKit / Google Play.getProduct()/getProducts()– Fetch harga, judul lokal, deskripsi, tawaran intro, dan istilah harga iOS yang didukung.purchaseProduct()– Mulai alur pembelian StoreKit 2 atau Billing klien, termasuk rencana pembayaran bulanan iOS.restorePurchases()– Ulangi pembelian sejarah dan sinkronkan ke perangkat saat ini.getPurchases()– Daftar semua transaksi iOS atau pembelian Play Billing.manageSubscriptions()– Buka antarmuka manajemen langganan native.addListener('transactionUpdated')– Tangani transaksi StoreKit 2 yang menunggu ketika aplikasi Anda dimulai (hanya iOS).
Praktik Terbaik
Judul Bagian “Praktik Terbaik”- Tampilkan harga toko – Apple memerlukan menampilkan
product.titledanproduct.priceString; jangan pernah mengkodekan secara keras. - Gunakan
appAccountToken– untuk menghasilkan UUID (v5) secara deterministik dari ID pengguna untuk menghubungkan pembelian ke akun. - Validasi di server – kirim
receipt(iOS) /purchaseToken(Android) ke backend Anda untuk verifikasi. - Tangani kesalahan dengan sopan – periksa pembatalan pengguna, gagal jaringan, dan lingkungan pembayaran yang tidak didukung.
- Tes secara menyeluruh – ikuti panduan sandbox iOS dan panduan sandbox.
- Android Tawarkan pengembalian & manajemen
restorePurchases()– tambahkan tombol UI yang terhubung kemanageSubscriptions().
Judul bagian “Langkah-langkah pendapatan berikutnya” Setelah alur pembelian berfungsi, gunakan buku pegangan pendapatan Untuk merencanakan funnel pembayaran pertama: skop produk, Aplikasi Penelusuran, harga, penempatan paywall, analisis, dan umpan balik pengguguran.
Pengaturan
Bagian berjudul “Pengaturan”Produk tidak terbuka
- Pastikan ID aplikasi / ID aplikasi sesuai dengan konfigurasi toko.
- Konfirmasi bahwa ID produk aktif dan disetujui (App Store) atau diaktifkan (Google Play).
- Tunggu beberapa jam setelah membuat produk; penyebaran toko tidak instan.
Pembelian dibatalkan atau terjebak
- Pengguna dapat membatalkan di tengah alur; tutup panggilan dengan
try/catchdan permukaan pesan kesalahan yang ramah. - Untuk Android, pastikan akun uji instal aplikasi dari Play Store (track internal) sehingga Billing berfungsi.
- Periksa logcat/Xcode untuk kesalahan billing ketika menjalankan di perangkat.
Status langganan salah
- Gunakan
getPurchases()untuk membandingkan data toko dengan cache hak istimewa lokal Anda. - Pada Android, selalu tanyakan ke Google Play Developer API dengan
purchaseTokenuntuk mendapatkan tanggal kedaluwarsa atau status pengembalian uang. - Pada iOS, periksa
isActive/expirationDatedan validasi tagihan untuk mendeteksi pengembalian uang atau pembatalan.
Lanjutkan dari Getting Started
Judul bagian “Lanjutkan dari Getting Started”Jika Anda menggunakan Getting Started untuk merencanakan persetujuan toko dan distribusi, hubungkan dengan Menggunakan @capgo/native-purchases untuk kemampuan asli di Menggunakan @capgo/native-purchases, @capgo/capacitor-in-app-review untuk detail implementasi di @capgo/capacitor-in-app-review, Menggunakan @capgo/capacitor-in-app-review untuk kemampuan asli di Menggunakan @capgo/capacitor-in-app-review, @capgo/capacitor-native-market untuk detail implementasi di @capgo/capacitor-native-market, dan Menggunakan @capgo/capacitor-native-market untuk kemampuan asli di Menggunakan @capgo/capacitor-native-market.