Blog
Clone Slack's fair per-seat pricing in a simple way

Clone Slack's fair per-seat pricing in a simple way

Lago is an open-source billing API that helps engineers implement faster their billing engines. More and more companies, such as Notion or Slack, are implementing a complex per-seat fair pricing model.

What is a fair per-seat pricing?

You only make your customers pay for active members and what they really use. Members added or removed during a billing period are pro-rated based on the number of days used.

Fair seat pricing

The total number of units to be paid at the end of a period depends on the actual number of days really used by the members.

Lago has developed a special feature to implement faster than ever this fair pricing policy, called persistent billable metrics. Let’s try to replicate Slack’s pricing with Lago!

Prerequisites

You can find the main Lago repository here.

Before we get started, you need to:

  1. Install Docker on your machine;
  2. Make sure Docker Compose is installed and available (it should be the case if you’ve chosen to install Docker via Docker Desktop);
  3. Make sure Git is installed on your machine; and
  4. A cup of tea (or coffee)! ☕️

💡 We use basic CURL API calls for this demo, but Lago also provides API clients in order to make the implementation process easier.

1. Setting up your Lago billing engine

Start running Lago on your own environment. You will have access to the Lago API and Lago UI (frontend admin panel to perform no-code tasks).

Code snippet to install Lago
Run this code in your terminal

You can now open your browser and go to http://localhost to connect to the application. Lago's API is exposed at http://localhost:3000.

If needed, you can override your environment variables (learn more).

2. Creating a persistent billable metric

As our user seats are billed month over month unless you remove a user, we are going to use the persistent billable metrics, with a recurring_count aggregation. This means that you won’t have to send an event each month for a user who was added a few months ago and who’s still using your product. Lago will keep it in your “billing memory” until you remove this user.

Creation of a billable metric via the API
Creation of a billable metric via the API
List of billable metrics in the app
List of billable metrics in the app

It’s useful to emphasize several points here:

  • The aggregation property used is the seat_id. Lago counts the number of unique seat_id at the end of each billing period; and
  • The recurring_count aggregation type enables the creation of a fair per-seat pricing (we’ll talk about the creation of events later).

3. Creating a price plan with per-seat charges

To replicate Slack’s pricing, we can focus on building the Pro plan, starting at €8.25 per active user if you pay monthly.

Creation of a plan via the API
Creation of a plan via the API
Creation of a charge via the user interface
Creation of a charge via the user interface

Let’s break down the code written above:

  • The Pro plan has no base subscription amount. Therefore, amount_cents is set to 0 for the plan;
  • The amount_currency is in EUR. But you can use any available currency;
  • The charges and the plan are paid in_arrears. This means everything is billed based on the consumption of the period; and
  • Only one usage-based charge is created. Each seat is priced €8.25 per full month. Pro-rated charges will be determined by the events sent to Lago.

4. Create a customer and assign the Pro plan

First, let’s create a customer using the API. As Airbnb is a power customer of Slack, we can take this company as an example.

Creation of a customer via the API
Creation of a customer via the API
List of customers in the app
List of customers in the app

Then, we assign the Pro plan to this Airbnb customer.

Creation of a subscription via the API
Creation of a subscription via the API
Active subscription in the app
Active subscription in the app

About the subscription request:

  • The external_id of the subscription is unique (you can choose your own ID); and
  • The assigned plan has an anniversary billing time, which means that this Pro plan will be billed on the same day each month, depending on the subscription’s anniversary date (in this case, the 19th of each month).

5. Send events to create pro-rated user seats

Each user seat is priced €8.25 for a full month. Let’s send events to get a better understanding of this logic. Lago allows you to send persistent events:

5.1 User added for full month or persisted from previous billing periods

Use the operation_type called add to add a user seat to Lago’s billing system.

Seat 1 added via the API
Seat 1 added via the API
Seat 1 visible in the app
Seat 1 visible in the app

5.2 User added in the middle of the current period

Seat 2 added via the API
Seat 2 added via the API
Seat 2 added to the current usage
Seat 2 added to the current usage

As the user seat is added in the middle of the month, Lago automatically creates a pro-rated charge based on the number of days used.

In this example, one user was added for the full month and the other only for half the month.

5.3 User removed in the middle of the current period

A user who’s removed during a period is also charged with a pro-rated amount based on the number of days used. Use the operation_type set to remove to remove a user seat during a period.

Seat removed via the API
Seat removed via the API

6. The invoice

Let’s take a closer look at the PDF invoice created by Lago: it shows the seat history for the billing period under consideration. This detailed invoice provides the information necessary for your customers to understand the billing method.

Invoice breakdown for per-seat pricing
Invoice breakdown for per-seat pricing

This is how Lago can help you implement a per-seat billing system in just a few hours (not months). It’s easy to build but also easy to maintain.

Focus on building, not billing

Whether you choose premium or host the open-source version, you'll never worry about billing again.

Lago Premium

The optimal solution for teams with control and flexibility.

lago-cloud-version

Lago Open Source

The optimal solution for small projects.

lago-open-source-version