An open-source starter kit based on an open-source starter kit by Midday. Ported to Convex.
Website · Issues · What's included · Prerequisites · Getting Started · Deploying to Production
Everything you need to build a production ready SaaS, it's an opinionated stack using Convex and the latest Next.js framework, a monorepo with a focus on code reuse and best practices that will grow with your business.
Convex - Authentication, database, storage, background jobs, validated server actions, cache, rate limiting
Next.js - Framework
Turborepo - Build system
Biome - Linter, formatter
TailwindCSS - Styling
Shadcn - UI components
TypeScript - Type safety
React Email - Email templates
Resend - Email delivery
i18n - Internationalization
Sentry - Error handling/monitoring
OpenPanel - Analytics
Polar - Billing
nuqs - Type-safe search params state manager
next-themes - Theme manager
.
├── apps # App workspace
│ ├── app # App - your product
│ ├── web # Marketing site
│ └── ...
├── packages # Shared packages between apps
│ ├── analytics # OpenPanel analytics
│ ├── backend # Convex (API, Auth, Database, Storage, Background Jobs, Validated Server Actions, Cache, Rate Limiting)
│ ├── email # React email library
│ ├── logger # Logger library
│ └── ui # Shared UI components (Shadcn)
├── tooling # are the shared configuration that are used by the apps and packages
│ └── typescript # Shared TypeScript configuration
├── .cursorrules # Cursor rules specific to this project
├── biome.json # Biome configuration
├── turbo.json # Turbo configuration
├── LICENSE
└── README.md
Bun is the only prerequisite you need to install before getting started.
To install Bun, please follow the official installation instructions:
You have two options to create a new v1 project:
To create a new v1 project using our CLI tool, run:
bun create @convex-dev/v1@latest
This command will guide you through the process of setting up your project, including:
- Creating a new directory for your project
- Cloning the v1 repository
- Installing dependencies
- Initializing a git repository
- Setting up the Convex backend
- Configuring authentication
- Setting up environment variables
- Adding test products to Polar
- Seeding the database for subscriptions
After the setup is complete, you can start your development server by running:
cd your-project-name
bun dev
If you prefer to set up the project manually, follow these steps:
-
Clone the repository:
bunx degit get-convex/v1 v1 cd v1
-
Install dependencies:
bun install
-
Initialize git repository:
git init && git commit -am 'initial commit'
-
Set up Convex backend:
cd packages/backend npm run setup
This will create a new Convex project. It will fail after project creation due to missing environment variables, which is expected at this stage.
-
Set up authentication:
npx @convex-dev/auth
Follow the prompts to configure authentication for your project.
-
Set up environment variables: If you prefer to set up services manually or want more control over the process, refer to the Detailed Service Setup Instructions section below.
-
Copy Convex environment variables:
- Copy the contents of
packages/backend/.env
- Paste these variables into the environment variables panel in your Convex dashboard
- Copy the contents of
-
Initialize Polar products and seed database:
cd packages/backend bunx convex run init
-
Start the development server:
bun dev
This starts everything in development mode (web, app, api, email).
Alternatively, you can start specific parts of the application:
bun dev:web
: starts the web appbun dev:app
: starts the appbun dev:convex
: starts the Convex APIbun dev:email
: starts the email app
Click to expand detailed setup instructions
If you choose to manually set up services and environment variables, follow these steps for each service:
-
Create a new project at https://dashboard.convex.dev
-
Obtain your Convex URL from the dashboard under 'Settings' > 'URL & Deploy Key'
-
Add the following to
apps/web/.env
andapps/app/.env
:# The Convex URL from the dashboard. It should look like 'https://example-123.convex.cloud' NEXT_PUBLIC_CONVEX_URL=https://foobar-42.convex.cloud
-
Create an account at https://openpanel.dev
-
Create a new project in the OpenPanel dashboard
-
Add the following to
apps/app/.env
:# The secret key from OpenPanel dashboard under 'Settings' > 'Projects'. Starts with 'sec_' OPENPANEL_SECRET_KEY=sec_foobarfoobarfoobarfoobar42
-
Add the following to
apps/web/.env
andapps/app/.env
:# The client ID from OpenPanel dashboard under 'Settings' > 'Projects' NEXT_PUBLIC_OPENPANEL_CLIENT_ID=foo-bar-42-baz-qux-42
-
Set up a project on https://sentry.io
-
Add the following to
apps/app/.env
:# The DSN from Sentry dashboard under 'Settings' > 'Projects' > [Your Project] > 'Client Keys (DSN)' NEXT_PUBLIC_SENTRY_DSN=https://foobarfoobar42@foobar42.ingest.sentry.io/42424242 # The auth token generated in Sentry dashboard under 'Settings' > 'Auth Tokens' SENTRY_AUTH_TOKEN=foobarfoobarfoobarfoobarfoobar42 # Your Sentry organization slug, found in the URL when in your Sentry dashboard SENTRY_ORG=your-org-name # The name of your Sentry project SENTRY_PROJECT=your-project-name
-
Create an account at https://resend.com
-
Add the following to
packages/backend/.env
:# The API key from Resend dashboard under 'API Keys'. Starts with 're_' RESEND_API_KEY=re_foobarfoobarfoobarfoobarfoobar42 # (Optional) The email address you want to use as the sender for authentication emails # Make sure it's verified in your Resend account under 'Domains' RESEND_SENDER_EMAIL_AUTH=auth@yourdomain.com
-
Set up an account at https://polar.sh Note: If you're just testing, be sure to switch to Sandbox via the top left dropdown in the dashboard before proceeding.
-
Add the following to
packages/backend/.env
:# Generate this in Polar dashboard under 'Account' > 'Developer settings' # Required permissions: 'products:read', 'products:write', 'subscriptions:read' POLAR_ACCESS_TOKEN=pat_foobarfoobarfoobarfoobarfoobar42 # Find this in Polar dashboard under 'Settings' POLAR_ORGANIZATION_ID=org_foobarfoobar42 # Create a webhook in Polar dashboard under 'Settings' > 'Webhooks' # The webhook should point to: https://your-convex-deployment.convex.site/events/polar POLAR_WEBHOOK_SECRET=whsec_foobarfoobarfoobarfoobarfoobar42
-
Set up your Cal.com account
-
Add the following to
apps/web/.env
:# Your public Cal.com link, e.g., 'https://cal.com/yourusername' NEXT_PUBLIC_CAL_LINK=https://cal.com/your-username
-
Set up an account at https://loops.so
-
Add the following to
packages/backend/.env
:# The ID of the Loops form you want to use, found in the Loops dashboard LOOPS_FORM_ID=foobarfoobar42
-
Set up Google OAuth 2.0 credentials following the guide at https://support.google.com/cloud/answer/6158849?hl=en
-
Add the following to
packages/backend/.env
:# The client ID from your Google OAuth 2.0 credentials AUTH_GOOGLE_ID=424242424242-foobarfoobarfoobarfoobar42.apps.googleusercontent.com # The client secret from your Google OAuth 2.0 credentials AUTH_GOOGLE_SECRET=GOCSPX-foobarfoobarfoobarfoobar42
-
Set up the authorized redirect URI in your Google Cloud Console:
- Use your Convex deployment's HTTP Actions URL with the path '/api/auth/callback/google'
- Example: 'https://your-convex-deployment.convex.site/api/auth/callback/google'
- You can find your Convex deployment's HTTP Actions URL in the Convex dashboard under 'Settings' > 'URL & Deploy Key'
-
Add both http://localhost:3000 and http://localhost:3001 to the list of authorized JavaScript origins for local development.
After setting up all the required services and environment variables, proceed to step 7 in the Getting Started section to copy the Convex environment variables to your Convex dashboard.
For more detailed information on each component, refer to their respective documentation linked in the "What's included" section above.
To deploy your v1 project to production, follow these steps:
This repo contains two Next.js apps, you can deploy one or both to Vercel. Each would be a separate Vercel project.
Steps to deploy a Vercel project with Convex can be found here.
-
NEXT_PUBLIC_APP_URL Optional for apps/web This is the URL for your deployed app, e.g.,
https://your-app.vercel.app
. It is used by the marketing site to link to the app. -
NEXT_PUBLIC_CONVEX_URL Required for both apps This is the URL for your deployed Convex instance, e.g.,
https://your-project-name.convex.cloud
.