Logo

dev-resources.site

for different kinds of informations.

Getting started with Open SaaS

Published at
4/21/2024
Categories
wasp
node
react
Author
rbatista19
Categories
3 categories in total
wasp
open
node
open
react
open
Author
10 person written this
rbatista19
open
Getting started with Open SaaS

When building Article Generation and Meeting Reminders, I decided to get started as fast as possible. So I looked for a free boilerplate and stumbled upon Open SaaS, which used YC-backed Wasp. It is a full-stack React + NodeJS + Prisma that takes 8 hours to get started with.

Their documentation is brilliant, and great support over Discord. I decided to list here the full walkthrough on how to set up the development environment so that it is a simple copy-paste for you.

For frontend deployment, I used Netlify (for the generous free package) and the recommended fly.io for server + database (also cheap package).

Run development commands

Start development database:

cd app && wasp start db
Enter fullscreen mode Exit fullscreen mode

View development database in Prisma:

wasp db studio
Enter fullscreen mode Exit fullscreen mode

Start development app:

cd app && wasp start
Enter fullscreen mode Exit fullscreen mode

Start development blog:

cd blog && npm install && npm run dev
Enter fullscreen mode Exit fullscreen mode

Run frontend deployment commands

Locate the folder:

cd .wasp/build/web-app
Enter fullscreen mode Exit fullscreen mode

Install dependencies:

npm install && REACT_APP_API_URL={your-server-URL} npm run build
Enter fullscreen mode Exit fullscreen mode

Deploy preview:

netlify deploy

Deploy to production:

netlify deploy --prod

Every time there is a Wasp app rebuild (with wasp build), it will remove your .wasp/build/ directory. Until the GitHub issue is fixed, you need to update netlify.toml’s publish line to:

  publish = ".wasp/build/web-app/build"
Enter fullscreen mode Exit fullscreen mode

Run backend & db deployment commands

Locate the folder:

cd .wasp/build/
Enter fullscreen mode Exit fullscreen mode

Deploy preview:

flyctl deploy --remote-only --config ../../src/shared/fly-server.toml
Enter fullscreen mode Exit fullscreen mode

Every time there is a Wasp app rebuild (with wasp build), it will remove your .wasp/build/ directory. That’s why there is a copy of the file in app/src/shared/.

Run blog deployment commands

Locate the folder:

cd blog
Enter fullscreen mode Exit fullscreen mode

Build the app:

npm run build
Enter fullscreen mode Exit fullscreen mode

Deploy preview:

netlify deploy
Enter fullscreen mode Exit fullscreen mode

Deploy to production:

netlify deploy --prod
Enter fullscreen mode Exit fullscreen mode

Good luck with building, hopefully it will be faster now!

Featured ones: