Whatsapp API Multi Device Version
Feature
- Send whatsapp via http API, docs/openapi.yml for more details
- 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"
- For more command
./main --help
Required (without docker)
- Mac OS:
brew install vips
brew install ffmpeg
export CGO_CFLAGS_ALLOW="-Xpreprocessor"
- Linux:
sudo apt update
sudo apt install libvips-dev
sudo apt install ffmpeg
- Windows (not recomended, prefer using WSL):
- install vips library, or you can check here https://www.libvips.org/install.html
- install ffmpeg, download here
- add to vips & ffmpg to environment variable
How to use
Basic
- Clone this repo
git clone https://github.com/aldinokemal/go-whatsapp-web-multi-device
- open via cmd/terminal
- run
go install github.com/markbates/pkger/cmd/pkger@latest
- run
cd src
- run
pkger && go run main.go
- open
http://localhost:3000
- run
go run main.go --help
for more detail flags
Docker (you don't need to install in required)
- Clone this repo
git clone https://github.com/aldinokemal/go-whatsapp-web-multi-device
- open via cmd/terminal
- run
docker-compose up -d --build
- open
http://localhost:3000
Build your own binary
- Clone this repo
git clone https://github.com/aldinokemal/go-whatsapp-web-multi-device
- open via cmd/terminal
- run
go install github.com/markbates/pkger/cmd/pkger@latest
- run
cd src
- run
- Linux & MacOS:
pkger && go build -o whatsapp
- Windows (CMD, not PowerShell):
pkger.exe && go build -o whatsapp.exe
- Linux & MacOS:
- run
- Linux & MacOS:
./whatsapp
- run
./whatsapp --help
for more detail flags
- run
- Windows:
.\whatsapp.exe
or you can double-click it- run
.\whatsapp.exe --help
for more detail flags
- run
- Linux & MacOS:
- open
http://localhost:3000
in browser
Production Mode (docker)
docker run --detach --publish=3000:3000 --name=whatsapp --restart=always --volume=$(docker volume create --name=whatsapp):/app/storages aldinokemal2104/go-whatsapp-web-multidevice --autoreply="Dont't reply this message please"
Production Mode (binary)
- download binary from release
You can fork or edit this source code !
Current API
You can check docs/openapi.yml for detail API, furthermore you can generate HTTP Client from this API using openapi-generator
Feature | Menu | Method | URL |
---|---|---|---|
Login | GET | /app/login | |
Logout | GET | /app/logout | |
Reconnect | GET | /app/reconnect | |
User Info | GET | /user/info | |
User Avatar | GET | /user/avatar | |
User My Group List | GET | /user/my/groups | |
User My Privacy Setting | GET | /user/my/privacy | |
Send Message | POST | /send/message | |
Send Image | POST | /send/image | |
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 | |
Revoke Message | POST | /message/:message_id/revoke | |
React Message | POST | /message/:message_id/react | |
Join Group With Link | POST | /group/join-with-link | |
Leave Group | POST | /group/leave |
โ
= Available
โ = Not Available Yet
App User Interface
- Homepage
- Login
- Send Message
- Send Image
- Send File
- Send Video
- Send Contact
- Send Location
- Revoke Message
- Reaction Message
- User Info
- User Avatar
- My Privacy
- My Group
- Auto Reply
- Basic Auth Prompt
Mac OS NOTE
- Please do this if you have an error (invalid flag in pkg-config --cflags: -Xpreprocessor)
export CGO_CFLAGS_ALLOW="-Xpreprocessor"