Welcome to the WhatsApp AI Assistant repository, where you'll find a remarkable WhatsApp chatbot designed to function as your very own AI-powered personal assistant. This chatbot leverages the power of Language Model (LLM) technology. As of now, it only supports Bing Chat and the jailbreak for it, codenamed Sydney.
Sydney | OpenRouter Models* |
---|---|
sydney_demo.mp4 |
Coming soon |
Feature | Sydney (BingAI Jailbreak) | OpenRouter Models* |
---|---|---|
Google/Bing Searching | ✅ | ✅ |
Google Calendar | ❌ | ❌ |
Google Places | ❌ | ❌ |
Gmail | ❌ | ❌ |
Communication Capability | ✅ | ✅ |
Group Chat Compatibility | ✅ | ✅ |
Voice Message Capability | ✅ | ✅ |
Create Basic Text Reminders | ✅ | ❌ |
Image Recognition | ✅ | ❌ |
Image Generation | ❌ | ❌ |
PDF Reading | ❌ | ❌ |
NOTE: We do not test every LLM that OpenRouter provides. Typically, we only test OpenAI GPT-3.5, Anthropic Claude 2 and Google Gemini Pro.
- Node.js >= 18.15.0
- Node.js version >= 20.x.x users you should use
node --loader ts-node/esm src/index.ts
instead ofpnpm start
- A spare WhatsApp number
Sydney/BingChat
- Clone this repository
git clone https://github.com/WAppAI/assistant.git
- Install the dependencies
pnpm install
- Rename .env.example to
.env
cp .env.example .env
-
Login with your Bing account and edit
.env
'sBING_COOKIES
environment variable to the cookies string from bing.com. For detailed instructions here.NOTE: Occasionally, you might encounter an error stating,
User needs to solve CAPTCHA to continue.
To resolve this issue, please solve the captcha [here]https://www.bing.com/turing/captcha/challenge, while logged in with the same account associated with your BING_COOKIES. -
Read and fill in the remaining information in the
.env
file. -
Run
pnpm build
- Start the bot
pnpm start
-
Connect your WhatsApp account to the bot by scanning the generated QR Code in the CLI.
-
Send a message to your WhatsApp account to start a conversation with Sydney!
OpenRouter
- Clone this repository
git clone https://github.com/WAppAI/assistant.git
- Install the dependencies
pnpm install
- Rename .env.example to
.env
cp .env.example .env
-
Read and fill in the remaining information in the
.env
file. -
Run
pnpm build
- Start the bot
pnpm start
-
Connect your WhatsApp account to the bot by scanning the generated QR Code in the CLI.
-
Send a message to your WhatsApp account to start a conversation with the bot!
The AI's are designed to respond to natural language queries from users. You can ask them questions, or just have a casual conversation.
When dealing with voice messages, you have two options for transcription: utilizing the Whisper API or the local method. Each option has its own considerations, including cost and performance.
Whisper API:
- Cost: Utilizing the Whisper API incurs a cost of US$0.06 per 10 minutes of audio.
- Setup:
- Obtain an OpenAI API key and place it in the
.env
file under theOPENAI_API_KEY
variable. - Set
TRANSCRIPTION_ENABLED
to"true"
andTRANSCRIPTION_METHOD
to"whisper-api"
. While setting a language inTRANSCRIPTION_LANGUAGE
is not mandatory, it is recommended for better performance.
- Obtain an OpenAI API key and place it in the
Local Mode:
- Cost: The local method is free but may be slower and less precise.
- Setup:
- Download a model of your choice from here. Download any
.bin
file and place it in the./whisper/models
folder. - Modify the
.env
file by changingTRANSCRIPTION_ENABLED
to"true"
,TRANSCRIPTION_METHOD
to"local"
, and"TRANSCRIPTION_MODEL"
with the name of the model you downloaded. While setting a language inTRANSCRIPTION_LANGUAGE
is not mandatory, it is recommended for better performance.
- Download a model of your choice from here. Download any
To utilize it in a group chat, you will need to either mention it by using her username with the "@" symbol (e.g., @Sydney) or reply directly to her last message.
!help
: Displays a message listing all available commands.!help
followed by a specific command, e.g.,!help reset
: Provides detailed information about the selected command.- If you wish to customize the command prefix, you can do so in the
.env
file to better suit your preferences.
Your contributions to Sydney are welcome in any form. Whether you'd like to:
-
Report Issues: If you come across bugs or have ideas for new features, please open an issue to discuss and track these items.
-
Submit Pull Requests (PRs): Feel free to contribute directly by opening pull requests. Your contributions are greatly appreciated and help improve Sydney.
Your involvement is valued, and you're encouraged to contribute in the way that suits you best.
Both creators of this project, Veigamann and Luisotee, are currently seeking new job opportunities.
If you have any job opportunities, please feel free to contact us through the emails provided in our GitHub profiles.