Skip to content

A Chatbot that integrates AI models from OpenAI, Google Gemini, Anthropic, etc for versatile conversations, featuring workflow tools and workspace management, built on a scalable PostgreSQL database with Supabase to boost productivity.

License

Notifications You must be signed in to change notification settings

immortalshadow007/ELW-Chatbot

Repository files navigation

ELW Chatbot

The open-source AI chat app for everyone.

Official Hosted Version

Use ELW Chatbot without having to host it yourself!

Find the official hosted version of ELW Chatbot here.

Issues

The "Issues" will not be limited to only the issue. The "Issues" will also have info on the work-in-progress part of the development process.

Updating

In your terminal at the root of your local ELW Chatbot repository, run:

npm run update

If you run a hosted instance you'll also need to run:

npm run db-push

to apply the latest migrations to your live database.

Local Quickstart

Follow these steps to get your own ELW Chatbot instance running locally.

You can watch the full video tutorial here.

1. Clone the Repo

git clone https://github.com/immortalshadow007/ELW-Chatbot.git

2. Install Dependencies

Open a terminal in the root directory of your local ELW Chatbot repository and run:

npm install

3. Install Supabase & Run Locally

Why Supabase?

Previously, we used local browser storage to store data. However, this was not a good solution for a few reasons:

  • Security issues
  • Limited storage
  • Limits multi-modal use cases

The above mentioned issue could be resolved without supabase but using the supabase simplifies the process of all the extra setup needed to address the security concerns and reduce cost incurred.

We now use Supabase because it's easy to use, it's open-source, it's Postgres, and it has a free tier for hosted instances.

1. Install Docker

You will need to install Docker to run Supabase locally. You can download it here for free.

2. Install Supabase CLI

MacOS/Linux

brew install supabase/tap/supabase

Windows

scoop bucket add supabase https://github.com/supabase/scoop-bucket.git
scoop install supabase

Linux

npm install -g supabase

3. Start Supabase

In your terminal at the root of your local ELW Chatbot repository, run:

supabase start

4. Fill in Secrets

1. Environment Variables

In your terminal at the root of your local ELW Chatbot repository, run:

cp .env.local.example .env.local

Get the required values by running:

supabase status

Note: Use API URL from supabase status for NEXT_PUBLIC_SUPABASE_URL

Now go to your .env.local file and fill in the values.

If the environment variable is set, it will disable the input in the user settings.

2. SQL Setup

In the 1st migration file supabase/migrations/20240108234540_setup.sql you will need to replace 2 values with the values you got above:

  • project_url (line 53): http://supabase_kong_chatbotui:8000 (default) can remain unchanged if you don't change your project_id in the config.toml file
  • service_role_key (line 54): You got this value from running supabase status

This prevents issues with storage files not being deleted properly.

There is a possibiltiy that SQL setup might fail in extremely rare case. If the SQL setup fails I recommend creating the tables in the database manually using the sql files located in src/supabase/migrations. If a simple and compiled query is needed please refer to the text file in the documentation directory.

5. Install Ollama (optional for local models)

Follow the instructions here.

6. Run app locally

In your terminal at the root of your local ELW Chatbot repository, run:

npm run chat

Your local instance of ELW Chatbot should now be running at http://localhost:3000. Be sure to use a compatible node version (i.e. v18).

You can view your backend GUI at http://localhost:54323/project/default/editor.

Hosted Quickstart

Follow these steps to get your own ELW Chatbot instance running in the cloud.

1. Follow Local Quickstart

Repeat steps 1-4 in "Local Quickstart" above.

You will want separate repositories for your local and hosted instances.

Create a new repository for your hosted instance of ELW Chatbot on GitHub and push your code to it.

2. Setup Backend with Supabase

1. Create a new project

Go to Supabase and create a new project.

2. Get Project Values

Once you are in the project dashboard, click on the "Project Settings" icon tab on the far bottom left.

Here you will get the values for the following environment variables:

  • Project Ref: Found in "General settings" as "Reference ID"

  • Project ID: Found in the URL of your project dashboard (Ex: https://supabase.com/dashboard/project/<YOUR_PROJECT_ID>/settings/general)

While still in "Settings" click on the "API" text tab on the left.

Here you will get the values for the following environment variables:

  • Project URL: Found in "API Settings" as "Project URL"

  • Anon key: Found in "Project API keys" as "anon public"

  • Service role key: Found in "Project API keys" as "service_role" (Reminder: Treat this like a password!)

3. Configure Auth

Next, click on the "Authentication" icon tab on the far left.

In the text tabs, click on "Providers" and make sure "Email" is enabled.

We recommend turning off "Confirm email" for your own personal instance. But if you are comfortable the recommendation can be ignored.

4. Connect to Hosted DB

Open up your repository for your hosted instance of ELW Chatbot.

In the 1st migration file supabase/migrations/20240108234540_setup.sql you will need to replace 2 values with the values you got above:

  • project_url (line 53): Use the Project URL value from above
  • service_role_key (line 54): Use the Service role key value from above

Now, open a terminal in the root directory of your local ELW Chatbot repository. We will execute a few commands here.

Login to Supabase by running:

supabase login

Next, link your project by running the following command with the "Project ID" you got above:

supabase link --project-ref <project-id>

Your project should now be linked.

Finally, push your database to Supabase by running:

supabase db push

Your hosted database should now be set up!

3. Setup Frontend with Vercel

Go to Vercel and create a new project.

In the setup page, import your GitHub repository for your hosted instance of ELW Chatbot. Within the project Settings, in the "Build & Development Settings" section, switch Framework Preset to "Next.js".

In environment variables, add the following from the values you got above:

  • NEXT_PUBLIC_SUPABASE_URL
  • NEXT_PUBLIC_SUPABASE_ANON_KEY
  • SUPABASE_SERVICE_ROLE_KEY
  • NEXT_PUBLIC_OLLAMA_URL (only needed when using local Ollama models; default: http://localhost:11434)

You can also add API keys as environment variables.

  • OPENAI_API_KEY
  • AZURE_OPENAI_API_KEY
  • AZURE_OPENAI_ENDPOINT
  • AZURE_GPT_45_VISION_NAME

For the full list of environment variables, refer to the '.env.local.example' file. If the environment variables are set for API keys, it will disable the input in the user settings.

Click "Deploy" and wait for your frontend to deploy.

Once deployed, you should be able to use your hosted instance of ELW Chatbot via the URL Vercel gives you.

Contact

Message Kartik on Twitter/X or [LinkedIn] (https://www.linkedin.com/in/kartik-a-a51122176/)

About

A Chatbot that integrates AI models from OpenAI, Google Gemini, Anthropic, etc for versatile conversations, featuring workflow tools and workspace management, built on a scalable PostgreSQL database with Supabase to boost productivity.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published