I’m building a subscription flow for a SaaS service where the user must enter the card details from the outset, even if there’s a trial period. Trying to understand the sequence of APIs that need to be called. There are gaps in my understanding of the API sequencing, so I’d appreciate if anyone can help correct the following before I set out building this. Hopefully this will also help others embarking on a similar journey.
One time initialization
- Create CatalogItems for each feature of the SaaS service
- Create CatalogItemVariations for each subscription plan mapping to the features that are included (modeled as CatalogItems)
- Create SubscriptionPlans for each tier of subscription e.g. Starter, Premium, Enterprise and associate with the CatalogItemVariation for that subscription plan
- Create SubscriptionVariations for each payment cadence e.g. a Monthly variation and an Annual variation. Include ones or more phases in each variation, depending on whether there’s a free trial offered at the start. Use STATIC pricing for each phase.
- Create OrderTemplates for each subscription tier x payment cadence. e.g. Starter Monthly, Starter Annual, Premium Monthly, Premium Annual
User subscription flow
- Display Subscriptions in the FE - Use Catalog API - List Catalog
- User selects their tier and chooses payment cadence (Monthly/Annual) clicks Subscribe
- BE creates payment link using Checkout API with subscription plan id set in checkout options and order line items set to order template IDs. Order created by API and Order ID returned in response.
- FE redirects user to payment link
- User enters credit card info and submits payment form. Do I need a webhook here to fire on payment success and create the subscription with that order ID (and customer, location, subscription variation ids)?
- User redirected to thank you page.
I’m not sure when I need to create the customer record, I can presumably do so prior to any of this, or maybe only do so once a successful payment has been made.
Greatly appreciate any feedback on this flow as I get to grips with the Square API.