A Next.js application that demonstrates how to use the Turso Platforms API to create a database per user.
The app below uses a database per user, and is powered by Turso.
https://turso-per-user-starter.vercel.app
Deploy your own Turso powered platform in a few easy steps...
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY
- Clerk public keyCLERK_SECRET_KEY
- Clerk secret keyTURSO_API_TOKEN
- Platform API TokenTURSO_ORG
- Org nameTURSO_DATABASE_NAME
- Database nameTURSO_GROUP_AUTH_TOKEN
- Group TokenYou may optionally set up webhooks to automate the creation of databases in the background — learn more.
Start building your Turso powered platform in a few simple steps...
Begin by cloning this repository to your machine:
git clone https://github.com/notrab/turso-per-user-starter.gitcd turso-per-user-starter
Run the following:
cp .env.example .envnpm install
Follow the instructions to install the Turso CLI, and then run the following:
turso db create <database-name>
Alternatively, you can sign up on the web, and create a new database from there.
Now update .env
to include your organization, and database name:
TURSO_ORG=TURSO_DATABASE_NAME=
The
TURSO_ORG
can be your personal username, or the name of any organization you have with other users.
Run the following:
turso group tokens create <database-name>
Now update .env
to include the group token:
TURSO_GROUP_AUTH_TOKEN=
If you didn't already have one, a new group will be created for you with the name
default
.
Run the following:
npm run db:migrate
If you make changes to
db/schema.ts
, make sure to runnpm run db:generate
to create the migrations, andnpm run db:migrate
to apply them.
Run the following:
turso auth api-tokens mint clerk
Then set the API token in the .env
file:
TURSO_API_TOKEN=
Sign up to Clerk and create a new application.
Add your Clerk public key and secret key to the .env
file:
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=CLERK_SECRET_KEY=
Run the following:
npm run dev
Now open http://localhost:3000 with your browser to try out the app!
You can automate the creation of databases per user in the background with webhooks.
Read the wiki for more information on how to set up webhooks with Clerk during development, and production.
A Next.js application that demonstrates how to use the Turso Platforms API to create a database per user.
The app below uses a database per user, and is powered by Turso.
https://turso-per-user-starter.vercel.app
Deploy your own Turso powered platform in a few easy steps...
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY
- Clerk public keyCLERK_SECRET_KEY
- Clerk secret keyTURSO_API_TOKEN
- Platform API TokenTURSO_ORG
- Org nameTURSO_DATABASE_NAME
- Database nameTURSO_GROUP_AUTH_TOKEN
- Group TokenYou may optionally set up webhooks to automate the creation of databases in the background — learn more.
Start building your Turso powered platform in a few simple steps...
Begin by cloning this repository to your machine:
git clone https://github.com/notrab/turso-per-user-starter.gitcd turso-per-user-starter
Run the following:
cp .env.example .envnpm install
Follow the instructions to install the Turso CLI, and then run the following:
turso db create <database-name>
Alternatively, you can sign up on the web, and create a new database from there.
Now update .env
to include your organization, and database name:
TURSO_ORG=TURSO_DATABASE_NAME=
The
TURSO_ORG
can be your personal username, or the name of any organization you have with other users.
Run the following:
turso group tokens create <database-name>
Now update .env
to include the group token:
TURSO_GROUP_AUTH_TOKEN=
If you didn't already have one, a new group will be created for you with the name
default
.
Run the following:
npm run db:migrate
If you make changes to
db/schema.ts
, make sure to runnpm run db:generate
to create the migrations, andnpm run db:migrate
to apply them.
Run the following:
turso auth api-tokens mint clerk
Then set the API token in the .env
file:
TURSO_API_TOKEN=
Sign up to Clerk and create a new application.
Add your Clerk public key and secret key to the .env
file:
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=CLERK_SECRET_KEY=
Run the following:
npm run dev
Now open http://localhost:3000 with your browser to try out the app!
You can automate the creation of databases per user in the background with webhooks.
Read the wiki for more information on how to set up webhooks with Clerk during development, and production.