Skip to content

mbookham7/global-app-demo

 
 

Repository files navigation

RoachRoast

A global Remix app with localization and translations that uses multi-region CockroachDB and is deployed on Fly.

🥞 Tech Stack

💾 Database Setup

This application uses Prisma to manage our database.

🧳 Migrate Schema Changes

  1. Update the DATABASE_URL environment variable with your CockroachDB connection string.
  2. Run npx prisma migrate to create the database schema.

🌎 Region Configuration

TBD

🧑‍💻 Development

🌱 Seed the Database

If you are starting with a blank database, you can populate it by running the following command

npx prisma db seed

💿 Run the Remix app locally

  • From your terminal:

    npm run dev

    This starts your app in development mode, rebuilding assets on file changes.

  • Open up https://localhost:3000 and you should be ready to go!

🚧 Deployment

This app is set up to deploy to Fly.io and comes with a GitHub Action that handles automatically deploying the app to production.

Prior to your first deployment, you'll need to do a few things:

  • Install Fly

  • Sign up and log in to Fly

    fly auth signup

    Note: If you have more than one Fly account, ensure that you are signed into the same account in the Fly CLI as you are in the browser. In your terminal, run fly auth whoami and ensure the email matches the Fly account signed into the browser.

  • Create a new app on Fly:

    fly apps create [YOUR_APP_NAME]

    Note: Make sure this name matches the app set in your fly.toml file. Otherwise, you will not be able to deploy.

  • Add a FLY_API_TOKEN to your GitHub repo. To do this, go to your user settings on Fly and create a new token, then add it to your repo secrets with the name FLY_API_TOKEN.

  • Add your environment vacriables to your fly app secrets, to do this you can run the following commands:

    fly secrets set DATABASE_URL="postgresql://" [additional secrets] --app [YOUR_APP_NAME]

    If you don't have openssl installed, you can also use 1Password to generate a random secret, just replace $(openssl rand -hex 32) with the generated secret.

Now that everything is set up you can commit and push your changes to your repo. Every commit to your main branch will trigger a deployment to your production environment.

📝 License

Copyright © 2023 Cockroach Labs.
This project is MIT licensed.

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 82.8%
  • JavaScript 9.9%
  • CSS 4.4%
  • Dockerfile 2.9%