Saltare al contenuto

Crea Gruppo di Abbonamento iOS

I gruppi di abbonamento sono essenziali per organizzare e gestire più livelli di abbonamento nella tua app iOS. È fondamentale capire come funzionano per implementare la funzionalità di aggiornamento, riduzione e crossgrade.

Un gruppo di abbonamenti è una raccolta di abbonamenti correlati che gli utenti possono scegliere tra loro. Gli utenti possono abbonarsi solo a un abbonamento all'interno di un gruppo alla volta. Quando cambiano abbonamento, Apple gestisce automaticamente la transizione.

I gruppi di abbonamenti consentono:

  • Prezzi a gradini: Offre piani base, premium e ultimate
  • Durate diverse: Opzioni mensili, annuali e a vita
  • Logica di aggiornamento/abbassamento: Gestione automatica delle modifiche degli abbonamenti
  • Gestione semplificata: Gruppa insieme abbonamenti correlati

All'interno di un gruppo, ogni abbonamento dovrebbe essere classificato in base al valore più alto (livello 1) e al valore più basso. Questa classificazione determina come le modifiche agli abbonamenti vengono classificate:

Gerarchia dei livelli di abbonamento

Livello 1 (Valore più alto)

  • Premium Annuale (99,99€/anno)
  • Ultimo Mensile (19,99€/mese)

Livello 2 (Valore medio)

  • Standard Annuale ($49,99/anno)
  • Premium Mensile ($9,99/mese)

Livello 3 (Valore più basso)

  • Basic Annuale ($29,99/anno)
  • Standard Mensile ($4,99/mese)

L'Apple gestisce automaticamente tre tipi di modifiche della sottoscrizione in base alla classificazione del livello:

Passare a livello superiore sottoscrizione (ad esempio, livello 2 → livello 1).

Comportamento:

  • Ha effetto immediatamente
  • L'utente riceve rimborso proporzionato per il tempo residuo
  • La nuova sottoscrizione inizia subito

Esempio:

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

Passare a una sottoscrizione di livello inferiore (ad esempio, livello 1 → livello 2). Comportamento:

Ha effetto alla data di rinnovo successiva

  • L'utente mantiene la sottoscrizione corrente fino alla scadenza del periodo La nuova sottoscrizione inizia automaticamente dopo la scadenza
  • Esempio:
  • Copia negli appunti

3. Migliora il livello

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

Passaggio a un'altra sottoscrizione allo stesso livello di tariffa.

Il comportamento dipende dalla durata:

Durata diversa → Si comporta come abbassamento di livello

  • Ha effetto alla data di rinnovo successiva
  • Esempio: Abbonamento mensile Premium (Livello 1) → Abbonamento annuale Premium (Livello 1)

Durata identica → Si comporta come elevazione di livello

  • Ha effetto immediatamente
  • Esempio: Premium Mensile (Livello 1) → Ultimate Mensile (Livello 1)
  1. Naviga alle Abbonamenti

    In App Store Connect, seleziona il tuo app e vai a Monetizza > Abbonamenti.

  2. Crea Gruppo

    Clicca + a lato “Gruppi di Abbonamento” per creare un nuovo gruppo.

  3. Nome del Gruppo

    Scegli un nome descrittivo che rifletta gli abbonamenti che contiene:

    • “Accesso Premium”
    • “Piani di Archiviazione Cloud”
    • “Caratteristiche Pro”
  4. Aggiungi Abbonamenti

    Dopo aver creato il gruppo, aggiungi gli abbonamenti individuali a esso. Ogni abbonamento avrà un livello di classifica.

  5. Imposta Classifiche di Livello

    Ordina gli abbonamenti dal valore più alto (1) al valore più basso. Considera:

    • I piani annuali solitamente hanno un livello di classifica più alto rispetto a quelli mensili
    • I livelli più costosi si collocano sopra quelli meno costosi
    • I livelli ultimate/premium hanno il livello di classifica più alto

Il plugin native-purchases gestisce automaticamente la logica delle sottoscrizioni di gruppo:

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

Comunicare sempre il comportamento di modifica in modo chiaro:

Per gli Aggiornamenti:

“Avrai accesso immediato alle funzionalità Premium. Ti prorateremo la tua sottoscrizione corrente.”

Per Riduzioni di Livello:

“Mantenrai l'accesso Premium fino alla data di rinnovo [renewal date], quindi passerai a Standard.”

Per Crossgrade:

“Il tuo piano cambierà a fatturazione annuale alla prossima rinnovo il [date].”

Utilizza le notifiche del server di Apple Store Server Notifications v2 o il tuo backend di validazione di ricevuta per riflettere le modifiche di StoreKit nel tuo database. Abbinare le notifiche del server con l'ascoltatore per mantenere sincronizzati sia il client che il backend. transactionUpdated Pratiche Raccomandate

Sezione intitolata “Pratiche Raccomandate”

Organizzazione dei Gruppi
  • Mantieni le sottoscrizioni correlate nello stesso gruppo
  • Non mescolare funzionalità non correlate (ad esempio, archiviazione e rimozione degli annunci)
  • Crea gruppi separati per diversi set di funzionalità
  • Piani annuali → Livello superiore rispetto a quelli mensili (per stesso livello)
  • Livelli più costosi → Livello superiore
  • Considera il valore, non solo il prezzo
  • Mostra la sottoscrizione corrente chiaramente
  • Visualizza tutte le opzioni disponibili nel gruppo
  • Indicare le modifiche che sono immediate vs. a rinnovo
  • Consentire lo switching facile tra piani
  • Testare tutti gli scenari di aggiornamento
  • Testare tutti gli scenari di riduzione
  • Verificare il comportamento di crossgrade
  • Controllare l'invio di webhook
Level 1: Ultimate Monthly ($19.99)
Level 2: Premium Monthly ($9.99)
Level 3: Basic Monthly ($4.99)
  • Basic → Premium: Aggiorna (immediato)
  • Premium → Ultimate: Aggiorna (immediato)
  • Ultimate → Premium: Riduci (alla rinnovazione)
  • Basic → Ultimate: Aggiorna (immediato)
Level 1: Premium Annual ($99.99/year)
Level 2: Premium Monthly ($9.99/month)
  • Mensile → Annuale: Migliora (alla rinnovazione)
  • Annuale → Mensile: Riduci (alla rinnovazione)
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)

Questa configurazione fornisce la massima flessibilità mantenendo una logica di aggiornamento/scostamento chiara.

Abbonamento non presente nel gruppo:

  • Verifica che sia assegnato al gruppo corretto
  • Controlla che sia almeno in stato “Pronto per la presentazione”
  • Assicurati che l'ID del prodotto sia corretto

Comportamento di aggiornamento/scostamento errato:

  • Verifica i livelli di classifica (1 = più alto)
  • Verifica che i livelli di abbonamento siano sensati
  • Controlla che i livelli siano impostati correttamente

Prodotti da gruppi diversi:

  • Gli utenti possono sottoscrivere a più gruppi contemporaneamente
  • Questo è intenzionale - mantenere i prodotti correlati nello stesso gruppo

getActiveProducts che mostra più abbonamenti:

  • Controlla se gli abbonamenti sono in gruppi diversi
  • Verifica che l'utente non sia sottoscritto tramite Family Sharing
  • Verifica lo stato dell'abbonamento in App Store Connect

Per ulteriori informazioni, si prega di consultare la documentazione ufficiale di Apple sui gruppi di abbonamento.