Skip to content

marvelai-org/marvel-ai-backend

Repository files navigation

image

Marvel AI Platform

Static Badge Static Badge Static Badge Static Badge

Table of Contents

  1. Architecture
  2. Folder Structure
  3. Installation
  4. Running Locally and Testing
  5. Docker Setup Guide
  6. Environment Variables
  7. Accessing the Application

Architecture

Architecture

Folder Structure

marvel-ai-backend/
├── app/                     # Contains the main application code
│   ├── api/                 # Contains the API router for handling requests
│   │   └── router.py        # Endpoints for FastAPI to test features and handle incoming requests
│   │   └── error_utilities.py  
│   ├── assistants/            # Contains the MarvelAI tools
│   │   ├── assistant_group1/
│   │   │   ├── assistant1/
│   │   │   │   │   ├── prompt/
│   │   │   │   │   ├── tests/
│   │   │   │   │   ├── core.py
│   │   │   │   │   ├── tools.py
│   │   │   │   │   └── metadata.json
│   │   │   ├── assistant2/
│   │   │   │   │   ├── prompt/
│   │   │   │   │   ├── tests/
│   │   │   │   │   ├── core.py
│   │   │   │   │   ├── tools.py
│   │   │   │   │   └── metadata.json
│   │   │   ├── assistantN/
│   │   │   │   │   ├── prompt/
│   │   │   │   │   ├── tests/
│   │   │   │   │   ├── core.py
│   │   │   │   │   ├── tools.py
│   │   │   │   │   └── metadata.json
│   │   ├── assistant_group2/
│   │   ├── assistant_groupN/
│   │   ├── utils/
│   │   │   ├── assistants_utilities.py
│   │   │   └── assistants_config.json       
│   ├── tools/            # Contains the MarvelAI tools
│   │   ├── tool1/
│   │   │   ├── core.py
│   │   │   ├── tools.py
│   │   │   ├── prompt/
│   │   │   ├── tests/
│   │   │   └── metadata.json
│   │   ├── tool2/
│   │   │   ├── core.py
│   │   │   ├── tools.py
│   │   │   ├── prompt/
│   │   │   ├── tests/
│   │   │   └── metadata.json
│   │   ├── toolN/
│   │   │   ├── core.py
│   │   │   ├── tools.py
│   │   │   ├── prompt/
│   │   │   ├── tests/
│   │   │   └── metadata.json
│   │   ├── utils/
│   │   │   ├── tool_utilities.py
│   │   │   └── tools_config.json
│   ├── services/            # Contains service modules
│   │   ├── assistant_registry.py
│   │   ├── logger.py
│   │   ├── schemas.py
│   │   ├── tool_registry.py
│   ├── utils/               # Contains utility modules
│   │   ├── actions_for_assistants/ 
│   │   │   ├── prompts/
│   │   │   └── actions_for_assistants.py
│   │   ├── prompts_for_summarization/
│   │   ├── tests/ 
│   │   ├── allowed_file_extensions.py # The allowed file extensions 
│   │   ├── auth.py # The auth config.
│   │   ├── document_loaders_summarization.py # The document loaders used for summarization
│   │   └── document_loaders.py # The document loaders used for handling a list of documents
│   ├── .env.sample              # Contains the required env variables (CREATE AN .env file using it)
│   ├── main.py              # Main entry point for the application
├── Dockerfile               # Dockerfile for containerizing the application
├── requirements.txt         # Python dependencies 
├── app.yaml                 # Application configuration file
├── load_env.sh              # Loads env variables
├── local-start.sh           # Starts the local server
├── code-of-conduct.md          # Code of conduct for contributors
├── contribution.md           # Contribution guidelines
└── README.md                # Documentation file

Installation:

Navigate to the app directory

cd marvel-ai-backend/app

Create and activate Virtual Environment

python -m venv env
source env/bin/activate

Install Required Libraries

pip install -r requirements.txt

Running Locally and Testing

Prerequisites

  • A Google Cloud account.
  • Access to the Google Cloud Platform console.

Steps for Authentication Setup

Step 1: Create a Google Cloud Project

  1. Navigate to the Google Cloud Console and create a new project.

Step 2: Enable the Google Cloud APIs

  1. Enable the following APIs:
    • VertexAI

Step 3: Create a new AI Studio API Key

  1. Navigate to the AI Studio API Key page and create a new API key. This will connect with your Google Cloud Project.

Step 4: Create a new .env and store the API Key

  1. Create a new file called .env in the root of the project.
  2. Copy the contents of the .env.example file into the .env file.
  3. Replace the placeholder values with your API key and project ID.
  4. Set the ENV_TYPE variable to dev.

Step 5: Run the Application with Local Shell Script

  1. Run the following command to start the application:
./local-start.sh

Step 6: Set the API Header

  1. Set the api-header to dev.
  2. Send the request payload to whichever endpoint you want to test!

Docker Setup Guide

Overview

This guide is designed to help contributors set up and run the backend service using Docker. Follow these steps to ensure that your development environment is configured correctly.

Prerequisites for Docker

Before you start, ensure you have the following installed:

  • Docker
  • Python

Installation Instructions

Step 1: Build the Docker Image

Navigate to the project's root directory and build the Docker image. Typically, this is done with the following command:

docker build -t <image_name> .

Step 2: Run the Docker Container

Run the Docker container using the following command:

docker run -p 8000:8000 <image_name>

This command starts a detached container that maps port 8000 of the container to port 8000 on the host.

Environment Variables

The Docker container uses several key environment variables:

  • ENV_TYPE set to "dev" for development.
  • PROJECT_ID specifies your Google Cloud project ID.
  • It is possible to enable LangChain tracing by setting the following environment variables. More information can be found on LangSmith LANGCHAIN_TRACING_V2 LANGCHAIN_ENDPOINT LANGCHAIN_API_KEY LANGCHAIN_PROJECT
  • Ensure these variables are correctly configured in a .env file.

Accessing the Application

You can access the backend by visiting:

http://localhost:8000/docs

After your container starts, you should see the FastAPI landing page, indicating that the application is running successfully.

About

This is the Marvel Teaching Assistant ai repo.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages