Skip to content
/ mbot Public

A starter template for an AI-powered chat applications with Svelte-Typescript JS (frontend), Python FastAPI (backend), and OpenAI integration. Perfect for startups, developers, and hobbyists looking to create interactive chat experiences or experiment with modern web frameworks.

License

Notifications You must be signed in to change notification settings

mthomason/mbot

Repository files navigation

mbot: For Svelte and FastAPI Chat with OpenAI

License: MIT

Overview

mbot is an open-source starter project for building AI-powered chatbot applications. Combining a modern tech stack of Svelte for the frontend and FastAPI for the backend, it provides Firebase authentication and integrates seamlessly with OpenAI APIs.

This project is designed for:

  • AI startup enthusiasts building chat applications.
  • Developers exploring Svelte and FastAPI.
  • Hobbyists experimenting with OpenAI's GPT models.

Features

  • Modern Frontend: Built with SvelteKit for reactive UI.
  • FastAPI Backend: Async API integration with OpenAI.
  • Secure Authentication: Firebase for user authentication.
  • Boilerplate for AI Apps: A great foundation for interactive AI chat solutions.

Demo

mbot Demo


Table of Contents

  1. Features
  2. Getting Started
  3. Project Structure
  4. Environment Variables
  5. Running the Project
  6. Contributing
  7. License

Getting Started

Prerequisites

  1. Node.js
    Install from Node.js official site.
  2. Python
    Install from Python's official site.
  3. Firebase Project
    Create a Firebase project for authentication (free tier is sufficient).
  4. OpenAI API Key
    Obtain an API key from OpenAI's platform.

Installation

1. Clone the Repository

    git clone https://github.com/mthomason/mbot.git  
    cd mbot  

2. Set Up the Backend

cd backend  
python -m venv venv  
source venv/bin/activate (On Windows: venv\Scripts\activate)  
pip install -r requirements.txt  

3. Set Up the Frontend

cd frontend
npm install

4. Add your Environment Variables

See Environment Variables

5. Run the project (see Running the Project)


Project Structure

frontend/         # SvelteKit app for the UI
backend/          # FastAPI app for APIs
backend/app/      # FastAPI endpoints and logic
backend/mserv/    # Backend utilities and config
electron/         # Optional Electron app (if applicable)
docs/             # Documentation files

Environment Variables

Create a .env file in the root directory and set the following:

GOOGLE_PROJECT_ID_MBOT=your-firebase-project-id  
OPENAI_API_KEY_MBOT=your-openai-api-key  
  • GOOGLE_PROJECT_ID_MBOT: Firebase project ID for authentication.
  • OPENAI_API_KEY_MBOT: API key for OpenAI services (note: usage may incur costs).

Running the Project

Use the provided VSCode debug configuration for ease of use. Follow these steps:

  1. Open the project in VSCode.
  2. Select the Launch mbot client and server configuration.
  3. Press F5 to start debugging.

Alternatively, run the components manually:

Backend

cd backend
source venv/bin/activate
uvicorn main:fastapi_app --reload

Frontend

cd frontend
npm run dev

Contributing

Contributions are welcome! Please fork the repo and submit a pull request. Before contributing, make sure to:

  1. Write clear documentation for new features.
  2. Follow the existing code style.

License

This project is licensed under the MIT License. See the LICENSE file for details.


About

A starter template for an AI-powered chat applications with Svelte-Typescript JS (frontend), Python FastAPI (backend), and OpenAI integration. Perfect for startups, developers, and hobbyists looking to create interactive chat experiences or experiment with modern web frameworks.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published