# WhatsApp API Multi Device Version [![Patreon](https://img.shields.io/badge/Support%20on-Patreon-orange.svg)](https://www.patreon.com/c/aldinokemal) **If you're using this tools to generate income, consider supporting its development by becoming a Patreon member!** Your support helps ensure the library stays maintained and receives regular updates! ___ ![release version](https://img.shields.io/github/v/release/aldinokemal/go-whatsapp-web-multidevice) ![Build Image](https://github.com/aldinokemal/go-whatsapp-web-multidevice/actions/workflows/build-docker-image.yaml/badge.svg) ![release windows](https://github.com/aldinokemal/go-whatsapp-web-multidevice/actions/workflows/release-windows.yml/badge.svg) ![release linux](https://github.com/aldinokemal/go-whatsapp-web-multidevice/actions/workflows/release-linux.yml/badge.svg) ![release macos](https://github.com/aldinokemal/go-whatsapp-web-multidevice/actions/workflows/release-mac.yml/badge.svg) ## Support for `ARM` & `AMD` Architecture along with `MCP` Support Download: - [Release](https://github.com/aldinokemal/go-whatsapp-web-multidevice/releases/latest) - [Docker Image](https://hub.docker.com/r/aldinokemal2104/go-whatsapp-web-multidevice/tags) ## Feature - Send WhatsApp message via http API, [docs/openapi.yml](./docs/openapi.yaml) for more details - **MCP (Model Context Protocol) Server Support** - Integrate with AI agents and tools using standardized protocol - Mention someone - `@phoneNumber` - example: `Hello @628974812XXXX, @628974812XXXX` - Post Whatsapp Status - Compress image before send - Compress video before send - Change OS name become your app (it's the device name when connect via mobile) - `--os=Chrome` or `--os=MyApplication` - Basic Auth (able to add multi credentials) - `--basic-auth=kemal:secret,toni:password,userName:secretPassword`, or you can simplify - `-b=kemal:secret,toni:password,userName:secretPassword` - Customizable port and debug mode - `--port 8000` - `--debug true` - Auto reply message - `--autoreply="Don't reply this message"` - Webhook for received message - `--webhook="http://yourwebhook.site/handler"`, or you can simplify - `-w="http://yourwebhook.site/handler"` - Webhook Secret Our webhook will be sent to you with an HMAC header and a sha256 default key `secret`. You may modify this by using the option below: - `--webhook-secret="secret"` ## Configuration You can configure the application using either command-line flags (shown above) or environment variables. Configuration can be set in three ways (in order of priority): 1. Command-line flags (highest priority) 2. Environment variables 3. `.env` file (lowest priority) ### Environment Variables To use environment variables: 1. Copy `.env.example` to `.env` in your project root 2. Modify the values in `.env` according to your needs 3. Or set the same variables as system environment variables See [.env.example](./src/.env.example) for all available configuration options. Note: Command-line flags will override any values set in environment variables or `.env` file. - For more command `./main --help` ## Required (without docker) - Mac OS: - `brew install ffmpeg` - `export CGO_CFLAGS_ALLOW="-Xpreprocessor"` - Linux: - `sudo apt update` - `sudo apt install ffmpeg` - Windows (not recomended, prefer using [WSL](https://docs.microsoft.com/en-us/windows/wsl/install)): - install ffmpeg, download [here](https://www.ffmpeg.org/download.html#build-windows) - add to ffmpeg to [environment variable](https://www.google.com/search?q=windows+add+to+environment+path) ## How to use ### Basic 1. Clone this repo: `git clone https://github.com/aldinokemal/go-whatsapp-web-multidevice` 2. Open the folder that was cloned via cmd/terminal. 3. run `cd src` 4. run `go run main.go` 5. Open `http://localhost:3000` ### Docker (you don't need to install in required) 1. Clone this repo: `git clone https://github.com/aldinokemal/go-whatsapp-web-multidevice` 2. Open the folder that was cloned via cmd/terminal. 3. run `docker-compose up -d --build` 4. open `http://localhost:3000` ### Build your own binary 1. Clone this repo `git clone https://github.com/aldinokemal/go-whatsapp-web-multidevice` 2. Open the folder that was cloned via cmd/terminal. 3. run `cd src` 4. run 1. Linux & MacOS: `go build -o whatsapp` 2. Windows (CMD / PowerShell): `go build -o whatsapp.exe` 5. run 1. Linux & MacOS: `./whatsapp` 1. run `./whatsapp --help` for more detail flags 2. Windows: `.\whatsapp.exe` or you can double-click it 1. run `.\whatsapp.exe --help` for more detail flags 6. open `http://localhost:3000` in browser ### MCP Server (Model Context Protocol) This application can also run as an MCP server, allowing AI agents and tools to interact with WhatsApp through a standardized protocol. 1. Clone this repo `git clone https://github.com/aldinokemal/go-whatsapp-web-multidevice` 2. Open the folder that was cloned via cmd/terminal. 3. run `cd src` 4. run `go run main.go mcp` or build the binary and run `./whatsapp mcp` 5. The MCP server will start on `http://localhost:8080` by default #### MCP Server Options - `--host localhost` - Set the host for MCP server (default: localhost) - `--port 8080` - Set the port for MCP server (default: 8080) #### Available MCP Tools - `whatsapp_send_text` - Send text messages - `whatsapp_send_contact` - Send contact cards - `whatsapp_send_link` - Send links with captions - `whatsapp_send_location` - Send location coordinates #### MCP Endpoints - SSE endpoint: `http://localhost:8080/sse` - Message endpoint: `http://localhost:8080/message` ### MCP Configuration make sure you have running MCP server, `./whatsapp mcp` ```json { "mcpServers": { "whatsapp": { "url": "http://localhost:8080/sse" } } ``` ### Production Mode (docker) ```bash docker run --detach --publish=3000:3000 --name=whatsapp --restart=always --volume=$(docker volume create --name=whatsapp):/app/storages aldinokemal2104/go-whatsapp-web-multidevice rest --autoreply="Dont't reply this message please" ``` ### Production Mode (docker compose) create `docker-compose.yml` file with the following configuration: ```yml services: whatsapp: image: aldinokemal2104/go-whatsapp-web-multidevice container_name: whatsapp restart: always ports: - "3000:3000" volumes: - whatsapp:/app/storages command: - rest - --basic-auth=admin:admin - --port=3000 - --debug=true - --os=Chrome - --account-validation=false volumes: whatsapp: ``` or with env file ```yml services: whatsapp: image: aldinokemal2104/go-whatsapp-web-multidevice container_name: whatsapp restart: always ports: - "3000:3000" volumes: - whatsapp:/app/storages command: - rest environment: - APP_BASIC_AUTH=admin:admin - APP_PORT=3000 - APP_DEBUG=true - APP_OS=Chrome - APP_ACCOUNT_VALIDATION=false volumes: whatsapp: ``` ### Production Mode (binary) - download binary from [release](https://github.com/aldinokemal/go-whatsapp-web-multidevice/releases) You can fork or edit this source code ! ## Current API ### MCP (Model Context Protocol) API - MCP server provides standardized tools for AI agents to interact with WhatsApp - Supports Server-Sent Events (SSE) transport - Available tools: `whatsapp_send_text`, `whatsapp_send_contact`, `whatsapp_send_link`, `whatsapp_send_location` - Compatible with MCP-enabled AI tools and agents ### HTTP REST API - [API Specification Document](https://bump.sh/aldinokemal/doc/go-whatsapp-web-multidevice). - Check [docs/openapi.yml](./docs/openapi.yaml) for detailed API specifications. - Use [SwaggerEditor](https://editor.swagger.io) to visualize the API. - Generate HTTP clients using [openapi-generator](https://openapi-generator.tech/#try). | Feature | Menu | Method | URL | |---------|----------------------------------------|--------|---------------------------------------| | ✅ | Login with Scan QR | GET | /app/login | | ✅ | Login With Pair Code | GET | /app/login-with-code | | ✅ | Logout | GET | /app/logout | | ✅ | Reconnect | GET | /app/reconnect | | ✅ | Devices | GET | /app/devices | | ✅ | User Info | GET | /user/info | | ✅ | User Avatar | GET | /user/avatar | | ✅ | User Change Avatar | POST | /user/avatar | | ✅ | User Change PushName | POST | /user/pushname | | ✅ | User My Groups | GET | /user/my/groups | | ✅ | User My Newsletter | GET | /user/my/newsletters | | ✅ | User My Privacy Setting | GET | /user/my/privacy | | ✅ | User My Contacts | GET | /user/my/contacts | | ✅ | Send Message | POST | /send/message | | ✅ | Send Image | POST | /send/image | | ✅ | Send Audio | POST | /send/audio | | ✅ | Send File | POST | /send/file | | ✅ | Send Video | POST | /send/video | | ✅ | Send Contact | POST | /send/contact | | ✅ | Send Link | POST | /send/link | | ✅ | Send Location | POST | /send/location | | ✅ | Send Poll / Vote | POST | /send/poll | | ✅ | Send Presence | POST | /send/presence | | ✅ | Revoke Message | POST | /message/:message_id/revoke | | ✅ | React Message | POST | /message/:message_id/reaction | | ✅ | Delete Message | POST | /message/:message_id/delete | | ✅ | Edit Message | POST | /message/:message_id/update | | ✅ | Read Message (DM) | POST | /message/:message_id/read | | ✅ | Star Message | POST | /message/:message_id/star | | ✅ | Join Group With Link | POST | /group/join-with-link | | ✅ | Leave Group | POST | /group/leave | | ✅ | Create Group | POST | /group | | ✅ | Add Participants in Group | POST | /group/participants | | ✅ | Remove Participant in Group | POST | /group/participants/remove | | ✅ | Promote Participant in Group | POST | /group/participants/promote | | ✅ | Demote Participant in Group | POST | /group/participants/demote | | ✅ | List Requested Participants in Group | POST | /group/participants/requested | | ✅ | Approve Requested Participant in Group | POST | /group/participants/requested/approve | | ✅ | Reject Requested Participant in Group | POST | /group/participants/requested/reject | | ✅ | Unfollow Newsletter | POST | /newsletter/unfollow | ```txt ✅ = Available ❌ = Not Available Yet ``` ## User Interface ### MCP UI - Setup MCP (tested in cursor) ![Setup MCP](https://i.ibb.co/vCg4zNWt/mcpsetup.png) - Test MCP ![Test MCP](https://i.ibb.co/B2LX38DW/mcptest.png) - Successfully setup MCP ![Success MCP](https://i.ibb.co/1fCx0Myc/mcpsuccess.png) ### HTTP REST API UI | Description | Image | |----------------------|------------------------------------------------------------------------------------------| | Homepage | ![Homepage](https://i.ibb.co/251sHyF/Homepage.png) | | Login | ![Login](https://i.ibb.co.com/xJyCWv8/login.png) | | Login With Code | ![Login With Code](https://i.ibb.co.com/YDjyXby/login-With-Code.png) | | Send Message | ![Send Message](https://i.ibb.co.com/7Y0wJ5R/send-Message.png) | | Send Image | ![Send Image](https://i.ibb.co.com/NtyLLdS/send-Image.png) | | Send File | ![Send File](https://i.ibb.co.com/D94yvnX/sendFile.png) | | Send Video | ![Send Video](https://i.ibb.co.com/r0LdRFH/send-Video.png) | | Send Contact | ![Send Contact](https://i.ibb.co.com/NsFfQBv/send-Contact.png) | | Send Location | ![Send Location](https://i.ibb.co.com/vDGmFvk/send-Location.png) | | Send Audio | ![Send Audio](https://i.ibb.co.com/XJdQLP8/send-Audio.png) | | Send Poll | ![Send Poll](https://i.ibb.co.com/4TswfT3/sendPoll.png?v=1) | | Send Presence | ![Send Presence](https://i.ibb.co.com/NSTC3QX/send-Presence.png) | | Revoke Message | ![Revoke Message](https://i.ibb.co.com/r4nDc57/revoke-Message.png) | | Delete Message | ![Delete Message](https://i.ibb.co.com/dtrTJ1M/delete-Message.png) | | Reaction Message | ![Reaction Message](https://i.ibb.co.com/fNqJXF0/react-Message.png) | | Edit Message | ![Edit Message](https://i.ibb.co.com/Vx5cQMg/update-Message.png) | | User Info | ![User Info](https://i.ibb.co.com/qd7J7Nd/Search-User-Info.png) | | User Avatar | ![User Avatar](https://i.ibb.co.com/zbSzpP3/Search-Avatar.png) | | My Privacy | ![My Privacy](https://i.ibb.co.com/HCLxGHr/My-Privacy.png) | | My Group | ![My Group](https://i.ibb.co.com/p19dFQ5/list-Group.png) | | Create Group | ![My Group](https://i.ibb.co.com/YLT5Hyh/create-Group.png) | | Join Group with LInk | ![My Group](https://i.ibb.co.com/x5p95J7/join-Group-With-Link.png) | | Auto Reply | ![Auto Reply](https://i.ibb.co.com/D4rTytX/IMG-20220517-162500.jpg) | | Basic Auth Prompt | ![Basic Auth Prompt](https://i.ibb.co.com/PDjQ92W/Screenshot-2022-11-06-at-14-06-29.png) | | Manage Participant | ![Manage Participant](https://i.ibb.co.com/x7yn9nY/Manage-Participant.png) | | My Newsletter | ![List Newsletter](https://i.ibb.co.com/BLvyS9j/My-Newsletter.png) | ### Mac OS NOTE - Please do this if you have an error (invalid flag in pkg-config --cflags: -Xpreprocessor) `export CGO_CFLAGS_ALLOW="-Xpreprocessor"` ## Important - This project is unofficial and not affiliated with WhatsApp. - Please use official WhatsApp API to avoid any issues. - We only able to run MCP or REST API, this is limitation from whatsmeow library. independent MCP will be available in the future.