This repository contains a Python-based AI assistant that uses OpenAI's GPT-3.5 Turbo model to generate responses to user queries received via WhatsApp. The assistant leverages the Twilio API for WhatsApp communication and the OpenAI API for generating AI responses. It is built on the Flask framework and can be deployed on any server.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
You need to have the following installed:
- Python 3.6 or later
- Flask
- Twilio
- OpenAI
- dotenv
- ngrok
You can install these packages using pip:
pip install flask twilio openai python-dotenv pyngrok
- Clone the repository:
git clone https://github.com/djpapzin/AI-Assistant-WhatsApp-Bot.git
- Navigate to the project directory:
cd AI-Assistant-WhatsApp-Bot
- Obtain your Twilio SID and Auth Token:
- Sign up for a free Twilio account if you don't have one. You can do this by visiting the Twilio website.
- Once you've signed up and logged in, you'll be directed to the Twilio Console Dashboard. Here, you'll find your Account SID and Auth Token.
- Copy these values and store them in your ".env" file.
- Connect your WhatsApp to Twilio by sending a message from your device to +1 415 523 8886 with the code provided by Twilio (e.g.,
join belong-nor
). The code will be different for each user.
- Obtain your OpenAI API key:
- Sign up for an account on the OpenAI website.
- After signing up and logging in, go to the API section in the dashboard.
- Here, you'll find your API key. Copy this value and store it in your ".env" file.
Remember to replace the placeholders in the ".env" file with your actual keys. This file is where your application will read the environment variables from. Please note that these keys are sensitive information and should not be shared or exposed publicly. Always keep them in a secure place.
- Run the application:
python main.py
The application will start running at http://0.0.0.0:5000.
- In a second terminal, start ngrok on the same port as your Flask app:
ngrok http 5000
-
Copy the Forwading URL provided by ngrok and append
/twilio/receiveMessage
to it. It should look something like this:https://3674-41-150-219-60.ngrok.io/twilio/receiveMessage
. -
Paste this URL in the Twilio sandbox configuration under "When a message comes in" and make sure the method is set to POST and save.
-
Your WhatsAppbot is now ready to receive messages.
Send a POST request to the /twilio/receiveMessage
endpoint with the following parameters:
Body
: The user's messageFrom
: The user's WhatsApp number in the formatwhatsapp:+1234567890
The AI assistant will respond to the user's message via WhatsApp.
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
This project is licensed under the MIT License - see the LICENSE.md file for details.
- OpenAI for their amazing GPT-3.5 model
- Twilio for their powerful communication APIs
If you have any questions, feel free to open an issue or contact the repository owner.
- WhatsApp: https://wa.me/+27834837699
- Twitter: @djpapzin
- Email: djpapzin@gmail.com
- Replit: https://replit.com/@DjPapzin/Whatsapp-ChatGPT-bot?v=1
- Voinenote capabilities (text-to-speech) - transcribe audio from user using openai whisper speech to text and reply with text
- Voinenote capabilities (speech-to-text) - transcribe audio from user using openai whisper speech to text and reply with audio from eleven labs.
- Add Memory using langchain conversation buffer memory.