- Architecture
- Folder Structure
- Installation
- Running Locally and Testing
- Docker Setup Guide
- Environment Variables
- Accessing the Application
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
cd marvel-ai-backend/app
python -m venv env
source env/bin/activate
pip install -r requirements.txt
- A Google Cloud account.
- Access to the Google Cloud Platform console.
- Navigate to the Google Cloud Console and create a new project.
- Enable the following APIs:
- VertexAI
- Navigate to the AI Studio API Key page and create a new API key. This will connect with your Google Cloud Project.
- Create a new file called
.env
in the root of the project. - Copy the contents of the
.env.example
file into the.env
file. - Replace the placeholder values with your API key and project ID.
- Set the
ENV_TYPE
variable todev
.
- Run the following command to start the application:
./local-start.sh
- Set the api-header to
dev
. - Send the request payload to whichever endpoint you want to test!
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.
Before you start, ensure you have the following installed:
- Docker
- Python
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> .
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.
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.
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.