Skip to content

meteron-ai/roomfix

Repository files navigation

This project generates new designs of your room with AI

Room Fix AI

How it works

It uses an ML model called ControlNet to generate variations of rooms. This application gives you the ability to upload a photo of any room, which will send it through this ML Model using a Next.js API route, and return your generated room. The ML Model is hosted on Replicate and Upload is used for image storage.

Running Locally

Cloning the repository the local machine.

git clone https://github.com/meteron-ai/roomfix

Creating an account on Replicate to get an API key.

  1. Go to Replicate to create an account.
  2. Click on your profile picture in the top right corner, and click on "Dashboard".
  3. Click on "Account" in the navbar. And, here you can find your API token, copy it.

Creating an account on Meteron which will provide queuing, storage and APIs to retrieve the images

  1. Go to Meteron to create an account.
  2. Click on "Add Cluster" button and select "Replicate", give it a name replicate then set the token from the previous section.
  3. Get your Meteron API key from API keys tab.
  4. Set this key as an environment variable.

Storing the API keys in .env

Create a file in root directory of project with env. And store your API key in it, as shown in the .example.env file.

If you'd also like to do rate limiting, create an account on UpStash, create a Redis database, and populate the two environment variables in .env as well. If you don't want to do rate limiting, you don't need to make any changes.

Installing the dependencies.

npm install

Running the application.

Then, run the application in the command line and it will be available at http://localhost:3000.

npm run dev

Auth setup

  1. Use openssl rand -base64 32 to generate NEXTAUTH_SECRET
  2. Add DB URL and SHADOW DB URL from Neon
  3. Create a new project in console.cloud.google.com
  4. Click configure consent screen in API credentials page and click external
  5. Add an app name, do not upload logo, add authorized domain
  6. Publish app
  7. Create credentials -> Oauth client ID (web application). The "Authorized redirect URIs" used when creating the credentials must include your full domain and end in the callback path. For example:
  1. Run npx prisma db push && prisma migrate dev && prisma generate

One-Click Deploy

Deploy the example using Vercel:

Deploy with Vercel