Autumn is an open-source pricing & billing platform
npx skills add https://github.com/useautumn/autumn --skill billingInstallez cette compétence avec la CLI et commencez à utiliser le flux de travail SKILL.md dans votre espace de travail.

Autumn is an open-source layer between Stripe and your application, allowing you to create any pricing model and embed it with a couple lines of code. On Autumn you can build:
All this without having to handle webhooks, upgrades/downgrades, cancellations or payment fails.
Cloud: The quickest way to start using Autumn is through our cloud service.
Self Hosted: If you'd like to self-host Autumn:
bun installedbun install
bun setup
bun db:generate && bun db:migrate
For Windows
docker compose -f docker-compose.dev.yml up
For mac/linux:
docker compose -f docker-compose.unix.yml up
That's it! You should be able to see the Autumn dashboard on http://localhost:3000.
⚠️ To log in, enter an email at the sign in page, and an OTP should appear in your console / terminal. Normally, we use Resend to email an OTP or Google OAuth -- these can be set up by providing your credentials in
server/.env
ℹ️ Our set up script initializes the required env vars and (optionally) a Supabase instance. If you'd like to use your own Postgres instance, you can do so -- just paste the connection string in the
DATABASE_URLenv variable atserver/.env
If you encounter a SyntaxError: Unexpected end of JSON input error when running bun setup again after previously running it, you may need to clear your database tables first. This is a known issue that can occur when running database migrations multiple times.
To resolve this:
1️⃣ Billing infra gets complex fast
More than payments: it's building permission management, metering, usage limits with cron jobs, and connecting it to upgrade, downgrade, cancellation and failed payments states. Race conditions, edge cases, and other bugs will slow you down.
2️⃣ Billing and app logic should be decoupled
Growing companies iterate on pricing often: raising prices, experimenting with credits or charging for a new feature. DB migrations, rebuilding in-app flows, internal dashboards for custom pricing and grandfathering users on old pricing is a nightmare.
First, create your products and plans on the dashboard. We support any pricing model. Some popular ones we've seen include:
Next, all your billing logic can be implemented through just 3 functions:
/attach: One function call for all purchase flows. We return a Stripe Checkout URL, or handle an upgrade/downgrade.const { attach } = useAutumn();
<button
onClick={async () => {
await attach({ productId: "pro" });
}}
>
Upgrade to Pro
</button>
/check: Check whether a customer has access to a product, feature or remaining usage.const { check } = useAutumn();
const { data } = await check({ featureId: "ai_tokens" })
!data.allowed && alert("AI limit reached")
/track: When a customer uses a usage-based feature, record a usage event.const { track } = useAutumn();
await track({
featureId: "ai_tokens",
value: 1312
})
Contributing 🤝: If you're interested in contributing, you can check out our guide here. All types of help are appreciated :)
Support 💬: If you need any type of support, we're typically most responsive on our Discord channel, but feel free to email us [email protected] too!
Thanks to all our contributors for helping make autumn a better product!