Agent skill

subscription-offers

Generates StoreKit 2 code for all subscription offer types — introductory, promotional, offer codes, and win-back. Includes eligibility checks, offer presentation, and the preferredSubscriptionOffer modifier. Use when adding subscription offers, free trials, or promotional pricing.

Stars 127
Forks 10

Install this agent skill to your Project

npx add-skill https://github.com/rshankras/claude-code-apple-skills/tree/main/skills/generators/subscription-offers

SKILL.md

Subscription Offers Generator

Generate complete StoreKit 2 implementation for all four subscription offer types with eligibility verification, offer presentation, and transaction handling.

When This Skill Activates

Use this skill when the user:

  • Asks to "add subscription offers" or "set up free trial"
  • Mentions "introductory offer", "promotional offer", or "offer codes"
  • Wants "StoreKit 2 offers" implementation
  • Asks about "subscription pricing" or "discounted subscription"
  • Mentions "preferredSubscriptionOffer" or "eligibility check"

Pre-Generation Checks

1. Project Context Detection

  • Check for existing StoreKit implementations (import StoreKit)
  • Check deployment target (iOS 16.4+ for SubscriptionStoreView offers, iOS 15+ for manual)
  • Look for existing product/subscription group IDs
  • Identify if paywall-generator was already used

2. Conflict Detection

Glob: **/*Offer*.swift, **/*Eligibility*.swift
Grep: "introductoryOffer" or "promotionalOffers" or "winBackOffers"

If existing offer code found, ask:

  • Extend with additional offer types?
  • Replace existing implementation?

Offer Types Reference

1. Introductory Offers

  • Who: New subscribers who haven't previously subscribed
  • Types: Free trial, pay-as-you-go, pay-up-front
  • Limit: One per subscription group per Apple ID
  • StoreKit 2: product.subscription?.introductoryOffer

2. Promotional Offers

  • Who: Current or lapsed subscribers (you control eligibility)
  • Types: Free, pay-as-you-go, pay-up-front
  • Limit: Up to 10 per subscription group
  • Requires: Server-side signature generation
  • StoreKit 2: product.subscription?.promotionalOffers

3. Offer Codes

  • Who: Anyone with a valid code (you distribute)
  • Types: Free or discounted period
  • Limit: Configurable per campaign in App Store Connect
  • StoreKit 2: try await AppStore.presentOfferCodeRedeemSheet()

4. Win-Back Offers

  • Who: Previously subscribed users who churned
  • Types: Free or discounted period
  • Eligibility: Automatic via App Store (iOS 18+)
  • StoreKit 2: product.subscription?.winBackOffers

Configuration Questions

Ask user via AskUserQuestion:

  1. Which offer types? (multi-select)

    • Introductory offer (free trial / discounted first period)
    • Promotional offers (targeted discounts for eligible users)
    • Offer codes (redeemable codes you distribute)
    • Win-back offers (re-engage churned subscribers)
  2. Introductory offer details (if selected)

    • Free trial: 3 days / 7 days / 14 days / 30 days
    • Pay-as-you-go: discounted rate for X periods
    • Pay-up-front: discounted rate for full period
  3. Deployment target

    • iOS 15+ (manual offer UI)
    • iOS 16.4+ (SubscriptionStoreView with offers)
    • iOS 18+ (win-back offer support)
  4. Server-side signature (if promotional offers selected)

    • Will you generate signatures server-side?
    • Use App Store Server Library?

Generation Process

Step 1: Read Templates

Read templates.md for all offer implementation code.

Step 2: Create Core Files

  1. SubscriptionOfferManager.swift — Central offer management

    • Offer eligibility checking for all types
    • Offer presentation logic
    • Transaction handling for offer purchases
  2. OfferEligibility.swift — Eligibility verification

    • Introductory offer eligibility (isEligibleForIntroOffer)
    • Promotional offer eligibility (your business logic)
    • Win-back offer eligibility (iOS 18+)
  3. OfferConfiguration.swift — Offer type definitions and configuration

Step 3: Create UI Files (conditional)

  1. OfferBannerView.swift — Contextual offer banners

    • Shows appropriate offer based on user state
    • Introductory offer for new users
    • Promotional offer for at-risk subscribers
    • Win-back offer for churned subscribers
  2. OfferCodeRedemptionView.swift — Offer code entry UI (if offer codes selected)

Step 4: Create Optional Files

  1. OfferSignatureProvider.swift — Server-side signature handling (if promotional offers)
  2. OfferAnalytics.swift — Track offer impression, tap, and conversion events

Step 5: Determine File Location

- If Sources/Store/ exists → Sources/Store/Offers/
- If Store/ exists → Store/Offers/
- If Subscriptions/ exists → Subscriptions/Offers/
- Otherwise → Offers/

Output Format

Files Created

Store/Offers/
├── SubscriptionOfferManager.swift    # Central offer management
├── OfferEligibility.swift            # Eligibility verification
├── OfferConfiguration.swift          # Offer type definitions
├── OfferBannerView.swift             # Contextual offer UI
├── OfferCodeRedemptionView.swift     # Code entry (optional)
├── OfferSignatureProvider.swift      # Server signatures (optional)
└── OfferAnalytics.swift              # Offer tracking (optional)

Integration Steps

Check Introductory Offer Eligibility:

swift
let manager = SubscriptionOfferManager()
let isEligible = await manager.isEligibleForIntroOffer(
    productID: "com.app.subscription.monthly"
)

Present Best Available Offer:

swift
// Automatically selects the best offer for the user's state
let offer = await manager.bestAvailableOffer(
    for: "com.app.subscription.monthly"
)

// Use with SubscriptionStoreView (iOS 16.4+)
SubscriptionStoreView(groupID: groupID)
    .preferredSubscriptionOffer(offer)

Present Offer Code Sheet:

swift
// iOS 16+
try await AppStore.presentOfferCodeRedeemSheet()

Win-Back Offer (iOS 18+):

swift
let winBackOffers = await manager.availableWinBackOffers(
    for: "com.app.subscription.monthly"
)
if let bestOffer = winBackOffers.first {
    // Present win-back UI
}

Testing Instructions

  1. StoreKit Configuration file: Add offer configurations
  2. Test each offer type in Sandbox environment
  3. Verify eligibility logic: Test with new, current, and lapsed accounts
  4. Test edge cases: Expired trials, multiple subscription groups, family sharing

App Store Connect Setup

  1. Go to App Store Connect > Subscriptions > Your Group
  2. Introductory Offer: Set in subscription pricing section
  3. Promotional Offers: Create under "Subscription Prices" > "Promotional Offers"
  4. Offer Codes: Create under "Offer Codes" tab
  5. Win-Back Offers: Configure under "Win-Back Offers" (iOS 18+)

References

  • templates.md — All production Swift templates
  • Related: generators/win-back-offers — Dedicated win-back flow skill
  • Related: generators/paywall-generator — Full paywall with offer integration
  • Related: app-store/marketing-strategy — Strategic offer planning

Didn't find tool you were looking for?

Be as detailed as possible for better results