본문으로 이동
플러그인으로 돌아가기
@capgo/native-purchases
튜토리얼
github.com/Cap-go에서 github

네이티브 구매

API를 사용하여 간단한 네이티브 앱 내 구매, 구독 및 iOS StoreKit 의무 청구 청구 계획을 implement합니다.

안내서

자연스러운 구매에 대한 튜토리얼

Using @capgo/native-purchases

앱 내 구독을 쉽게 하세요.

설치

bun add @capgo/native-purchases
bunx cap sync

이 플러그인이 제공하는 것

  • restorePurchases - 사용자가 이전에 사용한 것을 복원하고 앱 사용자 ID를 사용자 ID와 연결합니다.
  • getAppTransaction - 앱 트랜잭션 정보를 가져옵니다. 이 정보는 사용자가 앱을 처음 다운로드하거나 구매한 날짜에 대한 세부 정보를 제공합니다.
  • isEntitledToOldBusinessModel - 원래 앱 버전과 목표 버전을 비교하여 사용자가 이전 사업 모델에서 특정 기능에 대한 권한이 있는지 결정합니다.
  • getProducts - iOS 구독 가격 조건을 포함하여 제품 메타데이터를 로드합니다.
  • purchaseProduct - 사용자가 선택한 제품과 청구 계획에 대한 구매 과정을 시작합니다.

예시 사용법

restorePurchases

사용자의 이전 구매 정보를 복원하고 사용자 ID를 연결합니다. 사용자 ID는 여러 사용자가 동일한 ID를 사용하는 경우에도 연결됩니다.

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

await NativePurchases.restorePurchases();

getAppTransaction

사용자가 앱을 처음 다운로드하거나 구매한 날짜에 대한 정보를 제공하는 앱 거래 정보를 가져옵니다.

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

원래 앱 버전과 목표 버전을 비교하여 사용자가 이전 사업 모델에서 특정 기능에 대한 권리를 갖는지 결정합니다.

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

선택한 제품에 대한 구매 과정을 시작합니다. Android 구독의 경우 Google Play 기본 계획 ID를 전달하세요. planIdentifieriOS 구독을 사용하는 경우 12개월의 약속과 함께 월별 청구를 제공하는 구독을 전달하세요. 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 버전에서 지원되는 구독을 사용하는 경우 StoreKit은 12개월의 약속과 함께 월별 청구를 제공하는 청구 계획을 노출할 수 있습니다.

구매 전에 다음 조건을 표시하세요: pricingTermsiOS 월별 약속 구독

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);
}

StoreKit은 iOS 버전에서 12개월 약속과 함께 월별 청구를 제공하는 청구 계획을 노출할 수 있습니다.