Skip to content

Whatsapp Assistant using FastAPI, Google Gemini, WhisperAI, Twilio and Ngrok

Notifications You must be signed in to change notification settings

Hercules45/WhatsApp-Assistant

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

WhatsApp Assistant

This repository contains a FastAPI-based WhatsApp assistant that interacts with users via Twilio API. It allows users to send text and audio messages, which are processed and responded to accordingly. The bot utilizes various tools and APIs, including Twilio for message handling, Google Gemini for response generation, and WhisperAI for speech-to-text conversion.

FastAPI WhatsApp Bot

Features

  • Receive and respond to text messages from WhatsApp users.
  • Process incoming audio messages, transcribe them into text using WhisperAI, and generate appropriate responses using Google Gemini.
  • Utilize Twilio API for message handling and communication with WhatsApp users.
  • Integrate FastAPI as a backend server for handling HTTP requests.

Installation

To run the FastAPI WhatsApp bot locally, follow these steps:

  1. Clone this repository to your local machine:

    git clone https://github.com/Hercules45/WhatsApp-Assistant.git
    
  2. Install the required Python dependencies:

    pip install requirements.txt
    
  3. Set up the necessary environment variables by creating a .env file and adding the following variables:

    TWILIO_ACCOUNT_SID = "Your Account SID"
    TWILIO_AUTH_TOKEN = "Your Token"
    GEMINI_API_KEY = "GEMINI KEY"
    
  4. To use the WhisperAI, you need to need to follow their official documentation:

    WhisperAI Documentation

  5. Run the FastAPI Applicatio with uvicorn in the terminal:

    uvicorn main:app --host 0.0.0.0 --port 8000
    
  6. Use NGROK to connect your local url to public url for sending/testing with Whatsapp messages:

    • Download Ngrok
    • You also need to add the Ngrok app location to the system environment variables for it to run in the terminal.
    • Run in terminal (localhost/port should be same as FastAPI host/port:
      ngrok http localhost:port
      
      A public URL will be created.
    • Update the Twilio account settings with public URL Console -> Develop -> Messaging -> Send a Message -> Sandbox Settings.
    • Since our FastAPI endpoint for recieving is /message ,don't forget to add the route in the URL pasted.
  7. Follow the Twilio documentation on how to send message to the twilio number.