Setup
This guide will walk you through setting up supastarter. We will go through the process of cloning the project, installing dependencies, setting up your database and running the local development server.
Prerequisites
Before you can get started, you will need to have the following installed on your machine.
Project setup
Create a new database
supastarter uses Prisma as an ORM (database access layer). This means you can use any database supported by Prisma, including PostgreSQL, MySQL and MongoDB. You can find all supported databases here.
Before creating a new supastarter project, make sure to have created a new database and have the connection string ready. For example when using PostgreSQL, the connection string will look something like this:
postgresql://user:password@host:port/databaseRecommended database providers are Supabase, PlanetScale and Neon.
You can also find setup guides for certain providers in the supastarter blog:
Initialize a new supastarter project
During the setup process you will be asked to provide the following information:
- Project name - The name of your project
- Database provider - The database provider you are using
- Database connection string - The connection string of your database
To create a new supastarter project all you need to do is run the following command (replace my-awesome-project with the name of your project):
npx supastarter new my-awesome-projectThis will clone and configure the supastarter repository, install all the dependencies and set up the database for you.
If you encounter any errors during the setup process, please try the manual setup instead.
First you need to clone the supastarter repository:
git clone https://github.com/supastarter/supastarter-nuxt.gitNext, we are going to install all the dependencies. Make sure you have installed pnpm before running the following command:
pnpm installNow, we need to set up the environment variables. To do this, copy the .env.local.example file in the root of your project and rename it to .env.local.
Then open the .env.local file and set at least the DATABASE_URL:
# Database
DATABASE_URL="YOUR_DATABASE_CONNECTION_STRING"This is also the place to set the variables for your mailing provider.
Here are the necessary variables for each provider:
- Plunk ->
PLUNK_API_KEY - Resend ->
RESEND_API_KEY - Postmark ->
POSTMARK_SERVER_TOKEN - Nodemailer ->
MAIL_HOST,MAIL_PORT,MAIL_USER,MAIL_PASS
Next, we need to link the correct providers for payments and mailing.
In the /packages/mail/providers/index.ts file, set the export to the provider you want to use:
export * from "./plunk";
// or export * from './resend';
// or export * from './postmark';
// or export * from './nodemailer';Do the same for the payment provider in the packages/api/modules/billing/provider/index.ts file:
export * from "./stripe";
// or export * from './lemonsqueezy';Next step is to migrate your database. Make sure to check your schema in packages/database/prisma/schema.prisma before.
To migrate the database, run the following command:
pnpm db:pushThen, to generate the Prisma client, run the following command:
pnpm db:generateThe last step is to set the supastarter repository as the upstream origin for your project, so you can pull in updates in the future.
Run the following commands:
rm -rf .git
git init
git remote add upstream https://github.com/supastarter/supastarter-nuxt.git
git add .
git commit -m "Initial commit"Set up your storage provider
Storage is necessary to upload and serve files like images for example for the avatars of users and teams. supastarter supports all S3-compatible storage providers like AWS S3, DigitalOcean Spaces, MinIO, etc. and Supabase Storage.
Start your development server
Now your app should be ready to go. To start the local development server, navigate into your project root folder and run the following command.
pnpm devOpen http://localhost:3000 in your browser to see the your app.