Engineering Subscriptions
Engineering Subscriptions
WWDC 2018
What is a subscription ?
data:image/s3,"s3://crabby-images/7c1a1/7c1a104a3988e3938f876b82ec99ec5f2a046665" alt=""
data:image/s3,"s3://crabby-images/64113/64113bd6b19d395a5d96670dac4f186b371aed4f" alt=""
1. Receive Transaction
data:image/s3,"s3://crabby-images/e1378/e137873e21c866953da5ff2d562c4aa75a4a229f" alt=""
data:image/s3,"s3://crabby-images/6d7ed/6d7ed1e7d7efc38e6808ad5d9a7222a756107b77" alt=""
2. Verify Authenticity
App Store Receipt
- Trusted record of App and In-App Purchases
- Stored on device
- Issued by the App Store
- Signed and verifiable
- For your app, on that device only
data:image/s3,"s3://crabby-images/67516/6751663bd46c8677aa70eade5a1f0c34dbfee755" alt=""
Receipt Validation
Don’t let you app be fooled !
- On-device validation
- Update subscription state within the app - Server-to-Server validation
- Online validation through a request to the App Store
- Update subscriptions state on your server - Do Not Use online validation directly from the device❗️
Comparing Validation Approaches
data:image/s3,"s3://crabby-images/4d95c/4d95c8338832084fdf130fd19f69892faaf2929e" alt=""
data:image/s3,"s3://crabby-images/719ea/719ea0b7c72f00fcb0a70f2aba130f8254ba3f74" alt=""
data:image/s3,"s3://crabby-images/b58fd/b58fd6870ad29393b45b09f590f33bcb8ee85bce" alt=""
3. Update Subscription Status
data:image/s3,"s3://crabby-images/ee53f/ee53f83ed388ac35ed2381b350fa9b5e8f5d09d7" alt=""
data:image/s3,"s3://crabby-images/6e1a7/6e1a76ff604e693073f135ce7283fce26c0bba4e" alt=""
Verifying Transactions
data:image/s3,"s3://crabby-images/8b653/8b653b5c2824176b2deebf44f69993e205ab9a3f" alt=""
data:image/s3,"s3://crabby-images/49521/495214d1558399685d0460ddf371220cbc42f0e9" alt=""
4. Subscription Period
data:image/s3,"s3://crabby-images/eaa71/eaa71ea6ba86e2b3cfd376d0bfae63bdfff099fd" alt=""
Verifying a Transaction
data:image/s3,"s3://crabby-images/68f8c/68f8c3870f697e460981c42876f768342a53dcdc" alt=""
Update Subscription State
data:image/s3,"s3://crabby-images/5627c/5627c4716b15fe61c8c81ad2f38a11a21a82494f" alt=""
Does the User Have an Active Subscription ? ⚠️
- Filter transactions by
original_transaction_id
- Find transaction with the lastest
expires_date
- Date in past shows user is not subscribed
- Date in future shows user is subscribed
data:image/s3,"s3://crabby-images/94fd0/94fd01e07dd07bee623bbead10060abc6af93653" alt=""
Update Subscription State
data:image/s3,"s3://crabby-images/2f6d2/2f6d22fd8f2eb74a94d689c284d96e3fea38374d" alt=""
Finish All Transactions on Device
Including all renewal transactions
data:image/s3,"s3://crabby-images/d6ab6/d6ab6a98c725b9791181bf17a7b94e071c58c512" alt=""
Renewal Transactions
data:image/s3,"s3://crabby-images/fff09/fff099e9e9e390c6c8196d9fcaa21a20c16e9cf7" alt=""
Multi Platforms
data:image/s3,"s3://crabby-images/8ac1e/8ac1e5c15da5011304df824b9c6d2b81bea163ae" alt=""
Status Polling
Discover new transactions directly from your server
- Save latest version of encoded receipt data on your server
- Treat receipt data like a token
/verifyReceipt
response also includes new transactions
- Located in thelastest_receipt_info
field
- Unlock new subscription periods without waiting for app to launch- New transactions will still appear in StoreKit on next app launch
- Must verify and finish these transactions
- Event if your server already knows about them
- Opportunity to update latest receipt data on server
data:image/s3,"s3://crabby-images/4a3e5/4a3e5db78ed50edafa45d14077a31424932f10c9" alt=""
data:image/s3,"s3://crabby-images/fbd06/fbd062c9f9d085a83bd845d4b257a9929204463b" alt=""
Reating to Billing Issues
- Observe no renewal transaction appears
- Direct user to amend their billing details
- Unblock user immediately when transaction occurs
data:image/s3,"s3://crabby-images/17698/17698833cc35e48ed6347b16bcd4b21744327b65" alt=""
Server-to-Server Notifications
- Status URL in App Store Connect
- HTTPS POST to your server for status changes
- Include
latest_transaction_info
for the transaction in question
data:image/s3,"s3://crabby-images/cf0fb/cf0fbf745dca597a3e3803f71897621172933985" alt=""
Creating User Accounts
- Offer in-app purchase before account creation
- Better user experience
- Higher conversion - Use anonymous account
- Rely onoriginal_transaction_id
to associate multiple devices
- Optionally take user through account “creation” later
data:image/s3,"s3://crabby-images/8f604/8f604f4f7404557e59d93f499166630a0d7f02e5" alt=""
Introductory Pricing
Determining user eligibility
- Need to show correct price to your user
- Check transactions to see if discount has been used
data:image/s3,"s3://crabby-images/7254b/7254b2cb8c05001c2126b845110255eb9bceaf95" alt=""
data:image/s3,"s3://crabby-images/fbfbf/fbfbfde201e5dfc99752ad83a1e447ee1060dd60" alt=""
Upgrade / Downgrade Subscriptions
Inside your app
- Just like selling an initial subscription
- Must be a subscription in the same subscription group
data:image/s3,"s3://crabby-images/1b1dc/1b1dc78388cf7694f1ab170a072f9170cb3f82ff" alt=""
- StoreKit handles the upgrade / downgrade
data:image/s3,"s3://crabby-images/f515f/f515f25033a31315ca22c8972aa18092af65e69c" alt=""
Subscription Management
In App Store account settings
- Provide a link to “Manage Your Subscription”
- Upgrade / downgrades
- Cancellation - https://apps.apple.com/account/subscriptions
- Link on the In-App Purchase Programming Guide
data:image/s3,"s3://crabby-images/56a0c/56a0c79f0e44e252142b86819025bd21d8e08fad" alt=""
Involuntary Churn
Billing retry
- Updated failed payment logic
- Expanded retry duration
- New retry strategies
- Tuning
data:image/s3,"s3://crabby-images/c8632/c8632a9ab75f8e9361115da30b1fe7f770c70385" alt=""
data:image/s3,"s3://crabby-images/42147/4214738b0a30a7641ab3bc427b12a63c983db068" alt=""
data:image/s3,"s3://crabby-images/d634d/d634d79642bd05cf553b02bd1a3b683f084c1496" alt=""
Minimizing Involuntary Churn
- Leverage subscription receipt fields
- Implement a grace period
- Customer messaging
Billing Retry
Optimization strategies
data:image/s3,"s3://crabby-images/0e061/0e06169f7dd8b43b14f788f687a50995d1d06321" alt=""
Grace Period
- Free subscription access
- While in a billing retry state
- Before a subscriber has churned - Improve recovery
data:image/s3,"s3://crabby-images/cae1a/cae1ae02a7d63f0b83b56e19cbe7ec4fd6413b20" alt=""
data:image/s3,"s3://crabby-images/a0c30/a0c30b47664612d987f5cc0e9e2e768205c5cc06" alt=""
Customer Messaging
- Messaging
- Update payment method
- Restate the value proposition - Offer limited service
- Edit billing information (new) 👍
- https://apps.apple.com/account/billing - Manage subscriptions (new) 👍
- https://apps.apple.com/account/subscriptions
data:image/s3,"s3://crabby-images/5d82b/5d82b572f15043a9d2336d181abf9ee1ade93855" alt=""
Voluntary Churn
data:image/s3,"s3://crabby-images/ef943/ef943980f2cef54ae9d5ead0ef76a63e55fbe1ab" alt=""
Minimizing Voluntary Churn
- Implement status poliing
- Offer attractive alternative subscriptions
Status Polling
- Will my subscriber churn ?
- Has my subscriber renewed ?
When to Status Poll
data:image/s3,"s3://crabby-images/ce28d/ce28da007841f9abe1a63f06fd240bb62a0a4abb" alt=""
Additional Receipt Fields
Storing subscriber status fields
- Save decoded JSON from
/verifyReceipt
data:image/s3,"s3://crabby-images/170d0/170d02642dfc36ce5905e11c35e81ebfa687ecbc" alt=""
- Or parse out specific fields
data:image/s3,"s3://crabby-images/2d977/2d9777187babce92265a607f84d79328f37362fd" alt=""
Auto Review Status
Voluntary churn
data:image/s3,"s3://crabby-images/30131/3013167bf290fc81c28d6a5a84ff1e91fbca72e1" alt=""
data:image/s3,"s3://crabby-images/416db/416dbdbcc4a580d4746f2aebdf692c0fdb6929a6" alt=""
Status Polling
Update auto renew status from server
data:image/s3,"s3://crabby-images/3e773/3e773e1a761e23b221b3fed2db41066dfbacc54d" alt=""
data:image/s3,"s3://crabby-images/7c828/7c8287c095c7bae408293476a1c3d7e66fde7328" alt=""
data:image/s3,"s3://crabby-images/d0e15/d0e157700173023e773ce0a953d348bb7e961e81" alt=""
Auto Renew Preference
data:image/s3,"s3://crabby-images/1071d/1071db26f8567bf62b111cb245e14727e9e2ba64" alt=""
data:image/s3,"s3://crabby-images/e1740/e1740a4a4d5f9730cdf38f9cc0b12e5ad602cadb" alt=""
data:image/s3,"s3://crabby-images/07641/076413fb741742b18f23fc72a11221ceb7c567e3" alt=""
Winback
- Reengate after subscribers churn
- Resubscription offers
- Customer surveys
data:image/s3,"s3://crabby-images/0af4a/0af4a47f58a25cbef96bfb3ce367bee37ba926a2" alt=""
data:image/s3,"s3://crabby-images/b1cb6/b1cb6b91fefdf9f4e42dab3a97ce2c3bab1dcf20" alt=""
Expiration Intent
data:image/s3,"s3://crabby-images/16b6e/16b6e2f04b216aa184a512e651df1814624900b4" alt=""
data:image/s3,"s3://crabby-images/b2afa/b2afa11853fae98c51858938e1213013c1a2b5a5" alt=""
Winback Lapsed Subscribers
Voluntary churn
- Survey lapsed subscribers
- Show alternative subscription products
data:image/s3,"s3://crabby-images/56b75/56b75edeb1843c1f0adb8cf30f90da69fc0d5935" alt=""
Involuntary churn
- Show alternative subscription products
- Persistent messaging in-app
- Limited subscription experience
data:image/s3,"s3://crabby-images/85f52/85f52b342a89109da37d186bbe824fa58e7b6ed6" alt=""
Reducing Subscriber Churn ⚠️
Summary
- Leverage subscription specific receipt fields
- Implement status polling
- Implement custom messaging
- Present contextual subscription offers
App Store Connect Reports (new)
- Available through the new App Store Connect API
- Report data available daily
- Can be imported for further analysis
data:image/s3,"s3://crabby-images/84abf/84abff8402f2eda8781fde8be613d24d82d41e1b" alt=""
Receipts vs Reports
data:image/s3,"s3://crabby-images/0c8ef/0c8efdb34c51bef98e08c3900b39165050628e9d" alt=""