Sauter au contenu

Créer un groupe d'abonnements iOS

Les groupes de souscriptions sont essentiels pour organiser et gérer plusieurs niveaux de souscriptions dans votre application iOS. Comprendre comment ils fonctionnent est crucial pour mettre en œuvre la fonctionnalité d'amélioration, de dégradation et de croisement de niveau.

Un groupe d'abonnements est une collection de souscriptions liées que les utilisateurs peuvent choisir entre. Les utilisateurs ne peuvent s'abonner qu'à une souscription au sein d'un groupe à la fois. Lorsqu'ils changent de souscription, Apple gère la transition automatiquement.

Pourquoi les groupes d'abonnements sont-ils importants ?

Section intitulée “Pourquoi les groupes d'abonnements sont-ils importants ?”

Les groupes d'abonnements permettent :

  • Tarification échelonnée: Proposer des plans de base, premium et ultime
  • Différentes durées: Options mensuelles, annuelles et à vie
  • Logique de mise à niveau/diminution: Gestion automatique des changements de souscription
  • Gestion simplifiée: Regrouper les souscriptions liées

Dans un groupe, chaque abonnement doit être classé par ordre de valeur décroissante (niveau 1) à la valeur la plus basse. Cette classification détermine comment les changements d'abonnement sont classés :

Hiérarchie des groupes d'abonnement

Niveau 1 (Valeur la plus élevée)

  • Annuel Premium (99,99 $ par an)
  • Mensuel Ultimate (19,99 $ par mois)

Niveau 2 (Valeur moyenne)

  • Tarif Annuel Standard (49,99 $/an)
  • Tarif Mensuel Premium (9,99 $/mois)

Niveau 3 (Valeur la plus basse)

  • Tarif Annuel de Base (29,99 $/an)
  • Tarif Mensuel Standard (4,99 $/mois)

Apple gère automatiquement trois types de changements de souscription en fonction du classement de niveau :

1. Mise à niveau

Passer à

Section intitulée « 1. Mise à niveau » niveau supérieur abonnement (par exemple, niveau 2 → niveau 1).

Comportement :

  • Prend effet immédiatement
  • L'utilisateur reçoit un remboursement partiel pour le temps restant
  • Un nouvel abonnement commence aussitôt

Exemple :

// User currently has: Standard Monthly (Level 2)
// User upgrades to: Premium Annual (Level 1)
// Result: Immediate access to Premium, refund for unused Standard time

Passer à un abonnement de niveau inférieur (par exemple, niveau 1 → niveau 2). Comportement :

Prend effet à la date de renouvellement suivante

  • L'utilisateur conserve son abonnement actuel jusqu'à la fin de la période Le nouveau abonnement commence automatiquement après expiration
  • Exemple :
  • Copier dans le presse-papier

3. Augmenter le niveau

// User currently has: Premium Annual (Level 1)
// User downgrades to: Standard Monthly (Level 2)
// Result: Premium access continues until annual renewal date, then switches

Passer à une autre abonnement au même niveau de tarification.

Le comportement dépend de la durée :

Durée différente → Se comporte comme dégradation

  • Prend effet à la date de renouvellement suivante
  • Exemple : Abonnement mensuel Premium (Niveau 1) → Abonnement annuel Premium (Niveau 1)

Même durée → Se comporte comme amélioration

  • Prend effet immédiatement
  • Exemple : Premium Mensuel (Niveau 1) → Ultimate Mensuel (Niveau 1)
  1. Naviguez vers les Abonnements

    Dans App Store Connect, sélectionnez votre application et allez à Monétiser > Abonnements.

  2. Créer un groupe

    Cliquez + à côté de “Groupe d'abonnements” pour créer un nouveau groupe.

  3. Nommer le groupe

    Choisissez un nom descriptif qui reflète les abonnements qu'il contient :

    • “Accès Premium”
    • “Plans de Stockage Cloud”
    • “Fonctionnalités Pro”
  4. Ajouter des Abonnements

    Après avoir créé le groupe, ajoutez des abonnements individuels à celui-ci. Chaque abonnement aura un classement de niveau.

  5. Définir les Classements de Niveau

    Organisez les abonnements du plus élevé (1) au plus bas. Considérez :

    • Les plans annuels sont généralement classés plus haut que les plans mensuels
    • Les tarifs plus élevés sont classés au-dessus des tarifs moins élevés
    • Les tarifs ultimes/premium sont classés en haut

Le plugin native-purchases gère automatiquement la logique des groupes d'abonnements :

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Fetch all subscriptions in a group
const { products } = await NativePurchases.getProducts({
productIdentifiers: ['premium_monthly', 'premium_annual', 'ultimate_monthly'],
productType: PURCHASE_TYPE.SUBS,
});
// Display current subscription using StoreKit transactions
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
const activeSubs = purchases.filter((purchase) => purchase.isActive);
// Detect pending downgrade/cancellation (StoreKit sets willCancel === true)
const pendingChange = purchases.find((purchase) => purchase.willCancel === true);
if (pendingChange) {
console.log('Subscription will stop auto-renewing on', pendingChange.expirationDate);
}
// Purchase (StoreKit handles upgrades/downgrades automatically)
await NativePurchases.purchaseProduct({
productIdentifier: 'premium_annual',
productType: PURCHASE_TYPE.SUBS,
});
// Listen for StoreKit updates (fires on upgrades/downgrades/refunds)
NativePurchases.addListener('transactionUpdated', (transaction) => {
console.log('Subscription updated:', transaction);
});
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
// Get current subscription info
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
const currentSubscription = purchases.find(
(purchase) => purchase.subscriptionState === 'subscribed',
);
if (currentSubscription) {
// StoreKit reports if user cancelled auto-renew
if (currentSubscription.willCancel) {
console.log(
`User cancelled. Access remains until ${currentSubscription.expirationDate}`,
);
}
if (currentSubscription.isUpgraded) {
console.log('User recently upgraded to this plan.');
}
}
// Listen for automatic upgrades/downgrades
NativePurchases.addListener('transactionUpdated', (transaction) => {
console.log('Subscription changed!', transaction);
if (transaction.subscriptionState === 'revoked') {
revokeAccess();
} else if (transaction.isActive) {
unlockPremiumFeatures();
}
});

Communiquez toujours clairement le comportement de changement :

Pour les mises à jour :

« Vous obtiendrez un accès immédiat aux fonctionnalités Premium. Nous proratiserons votre abonnement actuel. »

Pour les Degréments :

“Vous conserverez l'accès Premium jusqu'à [date de renouvellement], puis vous passerez à Standard.”

Pour les Croisgrader :

“Votre plan changera à la facturation annuelle à la prochaine renouvellement le [date].”

Utilisez les notifications de serveur de l'App Store de Apple ou votre propre backend de validation de récépissé pour refléter les modifications de StoreKit dans votre base de données. Associez les notifications de serveur avec le transactionUpdated écouteur afin que le client et le backend restent synchronisés.

  • Conserver les abonnements liés dans le même groupe
  • N'associez pas des fonctionnalités non liées (par exemple, stockage et suppression des publicités)
  • Créez des groupes séparés pour différents ensembles de fonctionnalités
  • Plans annuels → Niveau supérieur que les plans mensuels (pour le même niveau)
  • Niveaux plus chers → Niveau supérieur
  • Prenez en compte la valeur, et non seulement le prix
  • Affichez clairement l'abonnement actuel
  • Affichez toutes les options disponibles dans le groupe
  • Indiquer les changements immédiats vs. à la renouvellement
  • Permettre un changement facile entre les plans
  • Tester tous les scénarios de mise à niveau
  • Tester tous les scénarios de dégradation
  • Vérifier le comportement de croisade
  • Vérifier l'envoi de webhook
Level 1: Ultimate Monthly ($19.99)
Level 2: Premium Monthly ($9.99)
Level 3: Basic Monthly ($4.99)
  • De base → Premium : Mise à niveau (immédiate)
  • Premium → Ultimate : Mise à niveau (immédiate)
  • Ultimate → Premium : Degrader (à la renouvellement)
  • De base → Ultimate : Mise à niveau (immédiate)
Level 1: Premium Annual ($99.99/year)
Level 2: Premium Monthly ($9.99/month)
  • Mensuel → Annuel : Croiser (à la renouvellement)
  • Annuel → Mensuel : Degrader (à la renouvellement)
Level 1: Ultimate Annual ($199/year)
Level 2: Ultimate Monthly ($19.99/month)
Level 3: Premium Annual ($99/year)
Level 4: Premium Monthly ($9.99/month)
Level 5: Basic Annual ($49/year)
Level 6: Basic Monthly ($4.99/month)

Cette configuration offre la plus grande flexibilité tout en maintenant une logique d'amélioration/diminution claire.

Abonnement ne s'affiche pas dans le groupe :

  • Vérifiez qu'il est affecté au groupe correct
  • Vérifiez qu'il est au moins en « Prêt à soumettre »
  • Assurez-vous que l'ID du produit est correct

Comportement d'amélioration/diminution incorrect :

  • Vérifiez que les classements de niveau sont corrects (1 = le plus élevé)
  • Vérifiez que les niveaux de souscription ont du sens
  • Vérifiez que les niveaux sont correctement configurés

Produits de différents groupes :

  • Les utilisateurs peuvent s'abonner à plusieurs groupes simultanément
  • Cela est intentionnel - garder les produits liés dans le même groupe

getActiveProducts montrant plusieurs abonnements :

  • Vérifiez si les abonnements se trouvent dans des groupes différents
  • Vérifiez que l'utilisateur n'est pas abonné via le partage familial
  • Vérifiez l'état de l'abonnement dans App Store Connect

Pour plus de détails, consultez la documentation officielle d'Apple sur les groupes d'abonnement.