DEV Community

Cover image for What makes a good subscription billing system?
Shoplytics
Shoplytics

Posted on • Updated on

What makes a good subscription billing system?

What makes a good billing system?

A few months back i was asked to collaborate on a payments solution for Send With SES - a wrapper service to send Emails, SMS, and Push Notifications from your own AWS Account. The mandate was to make the subscription billing process very smooth and 100% transparent to end users.

We studied the current trend. The general process for SaaS companies is to have ...

  • exotically named subscription plans.
  • mostly 3-4 plan varieties compared in a columnar format - but some very complex.
  • one of the plan (definitely not the cheapest one) is given a special label, like “Popular”.
  • an 'Enterprise Plan' that doesn't have a price. Just a 'Contact Us'.
  • roundabout cancellations process.
  • delete data on subscription cancellations.
  • This is followed by some FAQs where one of the question is “Can i cancel my subscription?”, to which the answer is, “Of course you can anytime.”

Nothing wrong about these patterns. To each his own. Somebody started this and it became an acceptable trend. Our objective was to make things more simpler.

So our question was, "How can we simplify things and be better?"

A customer who wishes to use a subscription product or service faces multiple decision points. We narrowed these down to the following …

  1. Selecting a subscription plan.
  2. Upgrading/downgrading plans.
  3. Adding/managing credit cards.
  4. Payment history.
  5. Data retention.
  6. Billing communications.
  7. Refunds.
  8. Cancellations.

Once we identified customer decision points we had to figure out ways to simplify them. Simplifying each process boiled down to be more of a Management decision or a UIUX decision than a technical one. In all cases we found that simplifying a process automatically made the process more transparent.

Here's some points on what we did with small explanations of why. Some are Management decisions while the rest are UIUX decisions. YMMV.

  1. Unified Billing Dashboard. We made a single page UI for everything related to billing ... View All Plans, Switch Plans, Add/Delete Cards, Set Default Card, Billing History, Download Invoices, Cancel Subscription ... EVERYTHING can be achieved from one single page. Our objective was to achieve any end-user-intent within 2 clicks.
    sendwithses.com unified billing dashboard

  2. No Exotic Names: Our plans are simply named, Free, Small, Medium, Large, and Extra Large. So when somebody says, "We are using the 'Medium Plan' in Send With SES", others in their office will automatically know there are alternate plans like ‘Small’ or ‘Large’. This is not the case when you say something like, "We are using the 'Garden Plan'". Our plan names are easy to remember and communicate.
    sendwithses.com pricing

  3. All Plans Include All Features. The first question that comes up when signing up for a subscription is, “Which plan do i select?" So the potential user does a feature comparison of all available plans and the associated mental math. We save potential customers a lot of mental time and trouble by saying "All our plans include all features". So a 'Free' user has ALL the features that an 'Enterprise' user has. Only the usage amount varies.

  4. All Prices Mentioned Upfront. The next question that comes up when signing up for a subscription is, "How much will i be spending?" Most companies list prices for all plans except the Top/Enterprise Plan which just has a 'Contact Us' button. This creates some uneasiness, "Will i be ransomed into this product/service if i start to grow?" We avoid this situation by listing the price for our 'Extra Large' plan (which is our unlimited top end Enterprise plan).

  5. Free Plan - No Credit Card Needed. This is something many do. Nothing different about us here.

  6. Refunds. - All refunds are prorated and processed automatically. For example, if a user signs up for the 'Medium Plan ($150)' on 1st and cancels on 15th, they are immediately issued a refund of $75. We do have a refund policy to prevent plan abuse and protect our platform.

  7. Subscription Cancellations. - Don’t bury the cancel subscription button. If a customer wants to exit - they will. We placed a large and prominent TrashBin icon below the pricing plans. In our case, simply switching back to the 'Free Plan' will stop customer billing immediately.
    Alt Text

  8. Data Retention. - A customer may no longer need a paid subscription plan but may need historical data generated when they were on a paid plan. As mentioned earlier, simply switching back to our 'Free Plan' will stop customer billing immediately but they will not lose any old data that was generated.

  9. Easy Upgrade/Downgrade Plans. - All available plans are shown in Billing Dashboard. When user selects any plan, a popup is presented which shows the amount that will be billed, the card it will be billed to, and some important billing support information. A plan can be changed in two clicks.
    sendwithses.com plan change

  10. Easy Add/Remove Credit Cards. - The top-right of the Billing Dashboard has a 'My Cards' button. Clicking it will open a popup where user can add/delete credit cards and set default card.
    sendwithses.com payment cards

  11. Payment History. - Full historical table with invoice download options. Also shows date and time of billing.
    sendwithses.com full payment history with invoice downloads

  12. Total Cost Calculator. - Given the unique nature of our product (i.e. in addition to Send With SES charges, end user may incur extra charges in their AWS Account), we made a Total Cost Calculator that is linked to from the pricing page.
    sendwithses.com total cost calculator

  13. Customer Communication. - We keep customer communications to a bare minimum. The only automated emails we send out are a one-time welcome email on registration, an upcoming payment email, and an invoice-receipt email after payment is made.

Concluding ...

Is our approach working? Probably yes. Since launch (Jan-2018) we have received only one billing related support query.

= = = = =
About Send With SES.

Send With SES is a wrapper built around AWS for sending Emails, SMS, and Push Notifications (coming soon) to your customers at low cost while ensuring high deliverability.

You can consider Send With SES as an alternative to AWS Pinpoint. Unlimited Contacts/Subscribers. Scale to billions of messages. Just sign in to get started with the Free Plan. No credit card needed.
= = = = =

Top comments (0)