How to Get Paid in Flutter with Stripe

This is my guide on the fastest way to get paid with Stripe and Flutter. I'll walk through step-by-step instructions on how I set up stripe integration, how I associate purchases (subscriptions & one-time payments) with users, and how I keep track of all of that within Supabase. Afterwards, I'll talk about the review process and how to tip-toe around the strict AppStore rules.
Stripe + Supabase Integration
Stripe has a lot of built-in complexity to handle many edge cases. But at the end of the day, what's most important on the Supabase side is to know which user purchased what product or whether or not they are subscribed. My approach to this is to have an active_products column that is synced with Stripe and keeps track of the users' purchased products and products they are currently subscribed to. I also take advantage of Stripe's checkout portal so I don't need to create the payment UI myself.
User Payment Flow
- User creates an account (through Supabase)
- The user goes to the pricing page and selects a payment option
- The link redirects them to the Flutter app with the price id from Stripe
- A function is called from the Flutter app which creates a custom checkout portal link
- The user is redirected to the stripe portal link and makes the purchase
- A stripe webhook is triggered which updates active_products
- After the purchase, the user is redirected back to the app
- The app now knows the user's purchases through the stripe table
Setup
- To get things started, you'll need to set up a Stripe account and a Supabase account.
- Run the following SQL commands to create Stripe tables that will sync with stripe
- Create two Supabase functions, one to generate a checkout link and another to handle stripe webhooks.
- After deploying the functions, connect the webhook with Stripe and select all events.
- Enable, the checkout portal in stripe by clicking "Save Changes".
- Now in your Flutter app, you can call the checkout function to generate a link so the user can begin their checkout
- Finally, you can make a simple query to check whether or not the user is subscribed
If you're also interested in setting up analytics, transactional emails, release pipelines, or just want to play around with the demo, I encourage you to check out my open-source flutter production boilerplate. It has everything you need to build your startup.
Tip Toeing the Android and Apple App Store
So now you have Stripe set up with the checkout portal and webhooks in place, the payment process should work for web apps. But, the Apple App Store and Google Play Stores have strict guidelines on what can and cannot be done. There are ways to tiptoe around these guidelines. For example, apps like Netflix, Spotify, and Audible use this approach to circumvent the huge 30% commission Apple has. For us, we do it because it's a hassle to integrate with the respective app stores.
Here's how these companies do it:
- Netflix: You are only able to sign in from the app, you are unable to sign up and pay.
- Spotify: When you try to access a premium feature, it directs you to a page that says "You can't upgrade to Premium in the app. We know, it's not ideal."
- Audible: When you click "Buy more Credits" you see a current subscription page with text saying "To manage your account, visit the Audible site or call customer support"
Depending on what type of app you have and what business model you are using you can try one of the approaches above. Below are additional tips to help get you approved:
- Do not mention payments within the app and remove all links to the pricing page. I use the kIsWebflag (or Platform flags) to hide payment stuff in Flutter.
- Remove your paywalls, and direct the user to a page to tell them to manage their account on the web. Use wording similar to Spotify or Audible.
Additional Options:
Depending on your app sometimes, it doesn't make sense to tip-toe around the app store. Below is a pros and cons table to help you figure out which solution is the best for you. I either recommend using Stripe or RevenueCat, it doesn't make sense to do a self-implementation of this.
| Pros | Cons | |
|---|---|---|
| Stripe | Lower Fees, All payments done in Stripe, Unified Analytics | More hoops for the user to jump through in order to pay | 
| RevenueCat | Higher Conversion Rates, No need to handle syncing the backend, Unified Analytics | Web implementation requires Stripe regardless, Higher fees with Revenue Cat, App Store, and Play Store, Longer setup time | 
| Self Implementation | Higher Conversion Rates, Circumvent RevenueCat Fees | Requires you to create webhooks and backend sync for Stripe/App Store/Play Store, No unified analytics out of the box | 
Note: You can sign up for Apple's small business program to only get charged 15% commission fee instead of 30%
