Python async client for WhatsApp RPC WebSocket API
Project description
WhatsApp RPC - Python Client
Async Python client for the WhatsApp RPC WebSocket API.
Installation
pip install whatsapp-rpc
Requires the WhatsApp RPC server running separately:
npm install -g whatsapp-rpc
npx whatsapp-rpc start
Usage
import asyncio
from whatsapp_rpc import WhatsAppRPCClient
async def main():
client = WhatsAppRPCClient("ws://localhost:9400/ws/rpc")
await client.connect()
# Check status
status = await client.status()
print(status)
# Send a text message
await client.send(phone="1234567890", type="text", message="Hello!")
# Send an image
await client.send(
phone="1234567890",
type="image",
media_data={
"data": "<base64>",
"mime_type": "image/jpeg",
"caption": "Check this out!"
}
)
# List groups
groups = await client.groups()
# Get chat history
history = await client.chat_history(phone="1234567890", limit=50)
# List subscribed channels
channels = await client.newsletters()
# Get channel stats
stats = await client.newsletter_stats(jid="123456789@newsletter", count=20)
await client.close()
asyncio.run(main())
Events
async def main():
client = WhatsAppRPCClient("ws://localhost:9400/ws/rpc")
def on_event(event):
if event["method"] == "event.message_received":
print(f"New message: {event['params']['text']}")
client.event_callback = on_event
await client.connect()
# Keep running to receive events
await asyncio.sleep(3600)
await client.close()
API Methods
| Method | Description |
|---|---|
status() |
Get connection status |
start() / stop() / restart() |
Control WhatsApp service |
qr() |
Get QR code for pairing |
send(**kwargs) |
Send message (text, image, video, audio, document, location, contact) |
media(message_id) |
Download media from message |
groups() |
List all groups |
group_info(group_id) |
Get group details |
contacts(query) |
List contacts |
contact_check(phones) |
Check WhatsApp registration |
chat_history(**kwargs) |
Get message history |
typing(jid, state) |
Send typing indicator |
presence(status) |
Set online/offline |
mark_read(message_ids, chat_jid) |
Mark messages as read |
rate_limit_get() / rate_limit_set(**config) |
Rate limiting config |
newsletters(refresh) |
List subscribed channels |
newsletter_info(jid, invite, refresh) |
Get channel details |
newsletter_create(name, description, picture) |
Create a channel |
newsletter_follow(jid) |
Subscribe to a channel |
newsletter_unfollow(jid) |
Unsubscribe from a channel |
newsletter_mute(jid, mute) |
Mute/unmute a channel |
newsletter_messages(jid, count, before) |
Get channel messages |
newsletter_send(group_id, type, message, media_data) |
Send to channel (admin only) |
newsletter_mark_viewed(jid, server_ids) |
Mark messages as viewed |
newsletter_react(jid, server_id, reaction) |
React to a channel message |
newsletter_live_updates(jid) |
Subscribe to live updates |
newsletter_stats(jid, invite, count) |
Get channel statistics |
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
whatsapp_rpc-0.0.12.tar.gz
(9.1 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file whatsapp_rpc-0.0.12.tar.gz.
File metadata
- Download URL: whatsapp_rpc-0.0.12.tar.gz
- Upload date:
- Size: 9.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
76eb2637683b95fe584a1192aa16e868b07472fb035edc48f3f49dc0609d5c6c
|
|
| MD5 |
fecbc522e33ef68abcad2e18bfb9b340
|
|
| BLAKE2b-256 |
e57cc81ab8c10543ba0aa70138f281b0d94121c25c347b4494fb1559e52596c8
|
File details
Details for the file whatsapp_rpc-0.0.12-py3-none-any.whl.
File metadata
- Download URL: whatsapp_rpc-0.0.12-py3-none-any.whl
- Upload date:
- Size: 8.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
adc62e35a22af0517aec7668ff1ebf8134d46944ba60893a5fb28ffcd4878d44
|
|
| MD5 |
19a8b615a4dd555a9c952468a45ca597
|
|
| BLAKE2b-256 |
cf9ef729f4b0edf103413d7a2b94ae5541e24cd0740bd3b9195428ffb049a410
|