Stripe & Supabase SaaS Starter Kit

R
Renaudil y a 2 jours
0

Description

Full SaaS starter kit with Stripe for payments and Supabase for auth.

npx boilerapp stripe-supabase-saas-starter-kit

文档

NextJs SaaS Starter Template

<img width="1122" alt="image" src="https://github.com/user-attachments/assets/63e761c4-aece-47c2-a320-f1cc18bf916b"> <img width="920" alt="image" src="https://github.com/user-attachments/assets/55384d22-cd09-46e4-b92d-e535b7d948fd"> <img width="1115" alt="image" src="https://github.com/user-attachments/assets/9ec724e6-d46f-4849-a790-efca329d1102"> <img width="1115" alt="image" src="https://github.com/user-attachments/assets/c5c1a61b-7ff3-49fd-9dea-8104026dd1e6"> <img width="1141" alt="image" src="https://github.com/user-attachments/assets/06559a5a-ca19-40bb-bf00-d3d2cbd94ee1">

This is the ultimate Next.js SAAS starter kit that includes a landing page, integrations with Supabase auth(Oauth, forget password, etc), PostgresDB with DrizzleORM and Stripe to collect payments, setup subscriptions and allow users to edit subscriptions/payment options.

  • Full sign up/ sign in/ logout/ forget password/ password reset flow
  • Oauth with Google and Github
  • Utilize Stripe Pricing Table and Stripe Checkout to setup customer billing
  • Integration with Stripe Customer Portal to allow users to manage billing settings
  • Protected routes under /dashboard
  • Drizzle ORM/Postgres integration
  • Tailwind CSS/shadcn
  • Stripe webhooks/ API hook to get customer current plan

Getting Started

As we will be setting up both dev and prod environments, simply use .env.local to develop locally and .env for production environments

Setup Supabase

  1. Create a new project on Supabase
  2. ADD SUPABASE_URL and SUPABASE_ANON_KEY to your .env file

image 4. Add NEXT_PUBLIC_WEBSITE_URL to let Supabase know where to redirect the user after the Oauth flow(if using oauth).

Setup Google OAUTH Social Auth

You can easily set up social auth with this template. First navigate to google cloud and create a new project. All code is written. You just need to add the GOOGLE_OAUTH_CLIENT_ID and GOOGLE_OAUTH_CLIENT_SECRET to your .env file.

  1. Follow these instructions to set up Google OAuth.

Setup Github OAUTH Social Auth

You can easily set up social auth with this template. First navigate to google cloud and create a new project. All code is written. You just need to add the GITHUB_OAUTH_CLIENT_ID and GITHUB_OAUTH_CLIENT_SECRET to your .env file.

  1. Follow these instructions to set up Github OAuth.

Setup Postgres DB

You can use any Postgres db with this boilerplate code. Feel free to use Vercel's Marketplace to browse through a collection of first-party services to add to your Vercel project.

Add DATABASE_URL to .env file e.g postgresql://${USER}:${PASSWORD}@xxxx.us-east-2.aws.neon.tech/saas-template?sslmode=require

Setup OAuth with Social Providers

Setup redirect url

  1. Go to Supabase dashboard
  2. Go to Authentication > Url Configuration
  3. Place production url into "Site URL". <img width="1093" alt="image" src="https://github.com/user-attachments/assets/c10a5233-ad47-4005-b9ae-ad80fc626022">

Setup Stripe

In order to collect payments and setup subscriptions for your users, we will be making use of Stripe Checkout and Stripe Pricing Tables and Stripe Webhooks

  1. Register for Stripe
  2. get your STRIPE_SECRET_KEY key and add it to .env. Stripe has both a Test and Production API key. Once you verify your business on Stripe, you will be able to get access to production mode in Stripe which would come with a production API key. But until then, we can use Stripe's Test Mode to build our app

image

  1. Open up stripeSetup.ts and change your product information
  2. run npm run stripe:setup to setup your Stripe product
  3. Create a new Pricing Table and add your newly created products
  4. When creating your new Pricing Table, set the Confirmation Page to Don't show confirmation page. Add YOUR_PUBLIC_URL/subscribe/success as the value(use http://localhost:3000/subscribe/success for local development). This will redirect the user to your main dashboard when they have completed their checkout. For prod, this will be your public url

image

  1. Add NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY and NEXT_PUBLIC_STRIPE_PRICING_TABLE_ID to .env image

Your pricing table should now be set up

Setup Database

This boilerplate uses Drizzle ORM to interact with a PostgresDb.

Before we start, please ensure that you have DATABASE_URL set.

To create the necessary tables to start, run npm run db:migrate

To alter or add a table

  1. navigate to /utils/db/schema.ts
  2. Edit/add a table
  3. run npm run db:generate to generate migration files
  4. run npm run db:migrate to apply migration
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev

Open http://localhost:3000 with your browser to see the result.

Setup Stripe for Local Development

To receive webhook events from Stripe while developing locally, follow these steps:

  1. Install the Stripe CLI
    Download and install the Stripe CLI if you haven’t already. This tool allows your local server to receive webhook events from Stripe.

  2. Start the webhook listener
    Run the following command to forward Stripe events to your local server:

npm run stripe:listen

This command starts the Stripe CLI in listening mode and forwards incoming webhook events to http://localhost:3000/webhook/stripe.

Deploy on Vercel

The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.

Check out our Next.js deployment documentation for more details.

Prix

Gratuit

FREE

评论 (0)

常见问题

常见问题解答 (FAQ)

有问题?我们有答案。如果您找不到想要的答案,请随时联络我们。

Boilerapp 是一个专门用于分享 Boilerplates、入门套件(Starter Kits)和项目模版的开发者社区平台。我们的目标很简单:为您节省初始配置(Setup)的时间,让您可以专注于真正重要的代码。无论您是在寻找简单的代码库还是完整的 SaaS 项目,都能在这里找到。

还有其他问题?

我们的团队随时为您提供帮助。联络我们,我们将尽快回复。