lago/README.md

224 lines
14 KiB
Markdown
Raw Normal View History

<!-- PROJECT LOGO -->
<p align="center">
<a href="https://github.com/getlago/lago">
2022-10-28 12:55:01 +07:00
<img src="https://uploads-ssl.webflow.com/635119506e36baf5c267fecd/635b6df0ee8effaa54c1fa42_banner-open-graph.jpg" alt="Lago">
</a>
<h1 align="center">Lago</h2>
<p align="center">
2022-10-28 12:55:01 +07:00
Open Source Metering & Usage-Based Billing
<br />
<br />
2022-10-16 00:12:11 +07:00
The best alternative to Chargebee, Recurly or Stripe Billing.
<br />
For usage-based, subscription-based, and all the nuances of pricing in between.
<br />
<br />
2022-10-16 00:12:11 +07:00
<a href="https://www.getlago.com/slack">Slack</a>
·
<a href="https://getlago.com">Website</a>
·
<a href="https://github.com/getlago/lago/issues">Issues</a>
·
2023-04-06 20:42:24 +07:00
<a href="https://getlago.canny.io/">Roadmap</a>
</p>
</p>
2023-04-04 19:58:39 +07:00
<p align="center">
<a href="https://www.producthunt.com/posts/lago?utm_source=badge-top-post-badge&utm_medium=badge&utm_souce=badge-lago" target="_blank"><img src="https://api.producthunt.com/widgets/embed-image/v1/top-post-badge.svg?post_id=386328&theme=light&period=monthly" alt="Lago - Open&#0045;source&#0032;alternative&#0032;to&#0032;Stripe&#0032;Billing&#0032;and&#0032;Chargebee | Product Hunt" style="width: 250px; height: 54px;" width="250" height="54" />
2023-04-04 19:58:39 +07:00
</a>
</p>
<p align="center">
<a href="https://www.producthunt.com/posts/lago?utm_source=badge-top-post-topic-badge&utm_medium=badge&utm_souce=badge-lago" target="_blank"><img src="https://api.producthunt.com/widgets/embed-image/v1/top-post-topic-badge.svg?post_id=386328&theme=light&period=monthly&topic_id=267" alt="Lago - Open&#0045;source&#0032;alternative&#0032;to&#0032;Stripe&#0032;Billing&#0032;and&#0032;Chargebee | Product Hunt" style="width: 250px; height: 54px;" width="250" height="54" /></a>
</p>
<p align="center">
2022-10-16 00:12:11 +07:00
<a href="https://www.getlago.com/slack"><img src="https://img.shields.io/badge/Lago%20Slack%20Community-lago.slack.com-%234A154B" alt="Join Lago on Slack"></a>
<a href="https://github.com/getlago/lago/stargazers"><img src="https://img.shields.io/github/stars/getlago/lago" alt="Github Stars"></a>
<a href="https://news.ycombinator.com/item?id=31424450"><img src="https://img.shields.io/badge/Hacker%20News-777-%23FF6600" alt="Hacker News"></a>
<a href="https://github.com/getlago/lago/blob/main/LICENSE"><img src="https://img.shields.io/badge/license-AGPLv3-purple" alt="License"></a>
<a href="https://twitter.com/getlago"><img src="https://img.shields.io/twitter/follow/getlago?style=flat"></a>
2022-08-29 20:06:36 +07:00
<a href="https://www.ycombinator.com"><img src="https://img.shields.io/badge/Backed%20by-Y%20Combinator-%23f26625"></a>
</p>
<!-- ABOUT THE PROJECT -->
2022-10-16 00:12:11 +07:00
## The programmable API for usage-based billing
2023-08-25 21:32:44 +07:00
[![Lago Billing System Presentation](https://img.youtube.com/vi/dXnoMRetsr4/0.jpg)](https://www.youtube.com/watch?v=dXnoMRetsr4)
### The problem: Billing systems are still a nightmare for engineers
![Billing nightmare](https://uploads-ssl.webflow.com/6244531a40ad7ef5475ad9b3/62827b2f6fa52239b0db0fa4_Blog%20Post%20Image%20Standalone.png)
Engineers be like…
Read more first-hand experiences from Qonto, Algolia, Pleo, Segment, or the 350+. Hackernews comments [here](https://news.ycombinator.com/item?id=31424450).
2024-03-26 16:50:24 +07:00
**The Solution:** Lago, the open-source billing API for product-led SaaS
- Event-based: if you can track it, you can charge for it;
- Built for product-led growth companies;
- Hybrid pricing: subscription and usage;
- Hybrid go-to-market motion: self-serve and sales-led.
**Open-source, open architecture:**
- Composable: connect Lago to any of your internal systems or tools (i.e. any payment gateway, CRM, CPQ, accounting software);
- Pricing: were not rent seekers, were not asking for a % of your revenue. Our self-hosted version is free. Our cloud version is priced like a SaaS;
- Privacy: your data never has to leave your infrastructure.
## ✨ Features
- **[Usage metering](https://www.getlago.com/products/metering)**: Lago's event-based architecture provides a solid foundation for building a fair pricing model that scales with your business.
- **[Price plans](https://www.getlago.com/products/plans)**: Lago supports all pricing models. Create pay-as-you-go and hybrid plans in no time with our intuitive user interface or API.
- **[Coupons](https://www.getlago.com/products/coupons)**: Create engaging marketing campaigns and increase conversion with coupons that customers can redeem to get a discount.
2022-11-30 15:54:45 +07:00
- **[Add-ons](https://www.getlago.com/products/add-on)**: Why wait until the end of the billing cycle to get paid? Lago allows you to create one-time charges that are invoiced on the fly.
- **[Invoicing](https://www.getlago.com/products/invoicing)**: Depending on the configuration of your plans, Lago automatically calculates what each customer owes you and generates invoices.
- **[Prepaid credits](https://www.getlago.com/products/prepaid-credits)**: Unlock recurring revenue opportunities for pay-as-you-go pricing models with Lagos prepaid credit features.
## 🔔 Stay up to date
2023-04-23 20:41:46 +07:00
Lago launched its v0.1 on June 2nd, 2022. Lots of new features are coming, and are generally released on a bi-weekly basis. Watch updates of this repository to be notified of future updates.
[Check out our public roadmap](https://getlago.canny.io/)
## 🔖 License
Distributed under the AGPLv3 License. Read more [here](https://www.getlago.com/blog/open-source-licensing-and-why-lago-chose-agplv3).
## Current Releases
| Project | Release Badge |
|--------------------|-----------------------------------------------------------------------------------------------------|
| **Lago** | [![Lago Release](https://img.shields.io/github/v/release/getlago/lago)](https://github.com/getlago/lago/releases) |
| **Lago API** | [![Lago API Release](https://img.shields.io/github/v/release/getlago/lago-api)](https://github.com/getlago/lago-api/releases) |
| **Lago front** | [![Lago front Testing Release](https://img.shields.io/github/v/release/getlago/lago-front)](https://github.com/getlago/lago-front/releases) |
| **Lago Go Client** | [![Lago Go Client Testing Release](https://img.shields.io/github/v/release/getlago/lago-go-client)](https://github.com/getlago/lago-go-client/releases) |
| **lago-gotenberg** | [![lago-gotenberg Release](https://img.shields.io/github/v/release/getlago/lago-gotenberg)](https://github.com/getlago/lago-gotenberg/releases) |
| **Lago JavaScript Client** | [![Lago JavaScript Client Release](https://img.shields.io/github/v/release/getlago/lago-javascript-client)](https://github.com/getlago/lago-javascript-client/releases) |
| **Lago OpenAPI** | [![Lago OpenAPI Release](https://img.shields.io/github/v/release/getlago/lago-openapi)](https://github.com/getlago/lago-openapi/releases) |
| **Lago Python Client** | [![Lago Python Client Release](https://img.shields.io/github/v/release/getlago/lago-python-client)](https://github.com/getlago/lago-python-client/releases) |
| **Lago Ruby Client** | [![Lago Ruby Client Release](https://img.shields.io/github/v/release/getlago/lago-ruby-client)](https://github.com/getlago/lago-ruby-client/releases) |
## 💻 Deploy locally
### Requirements
1. Install Docker on your machine;
2. Make sure Docker Compose is installed and available (it should be the case if you have chosen to install Docker via Docker Desktop); and
3. Make sure Git is installed on your machine.
### Run the app
To start using Lago, run the following commands in a shell:
#### On a fresh install
##### 1 :Clone the Repository:
```bash
# Get the code
git clone --depth 1 https://github.com/getlago/lago.git
# Go to Lago folder
cd lago
```
##### 2 : Set Up Environment Variables: Run the following script to copy the example .env file, generate necessary keys, and populate the .env file:
```bash
# Copy the example .env file and populate keys
cp .env.example .env
echo "SECRET_KEY_BASE=\"$(openssl rand -hex 64)\"" >> .env
echo "LAGO_RSA_PRIVATE_KEY=\"$(openssl genrsa 2048 | base64)\"" >> .env
echo "LAGO_ENCRYPTION_PRIMARY_KEY=\"$(openssl rand -base64 32)\"" >> .env
echo "LAGO_ENCRYPTION_DETERMINISTIC_KEY=\"$(openssl rand -base64 32)\"" >> .env
echo "LAGO_ENCRYPTION_KEY_DERIVATION_SALT=\"$(openssl rand -base64 32)\"" >> .env
```
##### 3 : Launch the API Service:
```bash
docker compose -f docker-compose.new.yml up -d api
```
##### 4 : Create and Migrate the Database:
```bash
docker compose exec api rails db:create
docker compose exec api rails db:migrate
```
##### 5 : Launch All Services:
```bash
docker compose -f docker-compose.new.yml up -d
```
#### After an update
```bash
docker compose -f docker-compose.new.yml up -d
```
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.
2024-03-26 16:50:24 +07:00
Note that if our docker server is not at http://localhost, the following env variables must be set: `LAGO_API_URL`. This may be on the command line or in your .env file. For example:
```
LAGO_API_URL="http://192.168.122.71:3000"
LAGO_FRONT_URL="http://192.168.122.71"
```
### Find your API key
Your API Key can be found directly in the UI:
1. Access the **Developer** section from the sidebar;
2. The first tab of this section is related to your **API keys**; and
3. Click the **Copy** button to copy it to clipboard.
### Analytics and tracking
Please note that Lago, by default, tracks basic actions performed on your self-hosted instance. If you do not disable tracking, you may receive specific communications or product updates. However, rest assured that Lago will not collect any personal information about your customers or financial information about your invoices.
If you would like to know more about Lago's analytics or remove the entire tracking, please refer to [this page](https://doc.getlago.com/guide/self-hosted/tracking-analytics) for comprehensive information.
### Version, environment variables and components
Docker images are always updated to the last stable version in the docker-compose.yml file. You can use a different tag if needed by checking the releases list.
Lago uses the following environment variables to configure the components of the application. You can override them to customise your setup. Take a closer look are our [documentation](https://doc.getlago.com/docs/guide/self-hosting/docker#configuration).
2023-04-23 20:41:46 +07:00
## ☁️ Use our cloud-based product
Contact our team at hello@getlago.com to get started with Lago Cloud. More information on [our website](https://www.getlago.com/pricing).
## 🚀 Getting the most out of Lago
- See the [documentation](https://doc.getlago.com) to learn more about all the features;
- Use our [templates](https://www.getlago.com/resources/templates/all) to get inspiration and learn how to reproduce Algolias, Segments and Klaviyos pricing models;
2024-05-02 14:08:32 +07:00
- Join our [Slack community](https://www.getlago.com/slack) if you need help, or want to chat, were here to help;
- Contribute on GitHub: read our [guidelines](https://github.com/getlago/lago/blob/main/CONTRIBUTING.md);
- Follow us on [Twitter](https://twitter.com/GetLago) for the latest news;
- You can email us as well: hello@getlago.com.
2023-04-23 20:41:46 +07:00
## 🧑‍💻 Contributions and development environment
2023-04-23 20:41:46 +07:00
You can follow this [guide](https://github.com/getlago/lago/wiki/Development-Environment) to set up a Lago development environment on your machine. This guide is intended for people willing to contribute to Lago. If you want to try Lago on your local system, we recommend that you take a look at Lago's public documentation.
You can contribute by following our [guidelines](https://github.com/getlago/lago/blob/main/CONTRIBUTING.md).
## 💡 Philosophy
2024-03-26 16:50:24 +07:00
B2B SaaS has evolved, but billing has not yet.
### 1- Were not in the “subscription economy” anymore. And we wont go “full usage-based pricing” quite yet
Pricings are now mostly hybrid: they include a usage-based component (i.e. “if you use more you pay more”) and a subscription component (i.e. a recurring fee for basic usage).
Not all software companies will go full “usage-based” like Snowflake for instance. This model is the new standard for cloud infrastructure products. However, in other areas of SaaS, users want to know beforehand how much they will pay to control their spending and software companies want to be able to predict recurring revenues.
### 2- Go-to-market is not either bottom-up or top-down anymore
2024-03-26 16:50:24 +07:00
SaaS used to be either self-service (SMBs) or sales-led (Enterprises).
Go-to-market now mixes the self-service (all customers access the same price plans) and sales-led (customers get a custom quote from a sales representative) motions.
A typical journey involves an individual contributor in a company who tests a new tool, puts their corporate credit card in, and starts spreading the use of the tool within the organization. At that point, the VP or head of department might want to upgrade to a custom plan tailored to the needs of the whole organization.
2024-03-26 16:50:24 +07:00
As a result, billing needs to be flexible, automated, and transparent enough to embrace this hybrid go-to-market motion as well.
### 3- The “rent seeker” pricing of current billing solutions needs to stop
Why do payment companies take a cut on revenues?
Because the higher the amount, the higher the risk for them (e.g. fraud, disputes, etc.).
Why did billing companies adopt the same pricing structure? Were not able to provide an answer that makes sense. Its been said on the internet that they did this because they could (read more [here](https://news.ycombinator.com/item?id=16766846)).
### One last thing…
Lago is agnostic and we aim at being as transparent as possible, so we wont nudge or lock you into using a specific tool in exchange for using our billing API ([learn more](https://www.gmass.co/blog/negotiating-stripe-fees/)).