Skip to main content

Python wrapper for the WhatsApp Cloud API

Project description

PyWa Logo

PyWa • Python wrapper for the WhatsApp Cloud API

PyPI Downloads PyPI Version Tests Docs License CodeFactor Telegram

PyWa is a Fast, Simple, Modern and easy-to-use Python framework for building WhatsApp bots using the WhatsApp Cloud API.

📄 Quick Documentation Index

>> Get StartedWhatsApp ClientHandlersFiltersUpdatesFlowsExamples


Features

  • 🚀 Fast and simple to use. No need to worry about the low-level details.

  • 💬 Send text messages with interactive keyboards, images, videos, documents, audio, locations, contacts, etc.

  • 📩 Receive messages, callbacks, message status updates, etc.

  • ♻️ Create, send and listen to Flows (NEW!)

  • 🔄 Built-in support for webhooks (Flask, FastAPI, etc.)

  • 🔬 Filters for handling incoming updates

  • 📄 Send and create templates

  • ✅ Fully typed, documented and tested


👨‍💻 Usage

  • Create a WhatsApp client and send a message

from pywa import WhatsApp

wa = WhatsApp(
    phone_id='100458559237541',
    token='xxxxxxxxxxxxxxx'
)

wa.send_message(
    to='9876543210',
    text='Hello from PyWa!'
)
  • Create a WhatsApp client, pass a web server app (Flask in this example) and start the webhook:

    > See Handlers for more information.

from pywa import WhatsApp
from flask import Flask
from pywa.types import Message, CallbackButton, Button
from pywa.filters import text, callback

flask_app = Flask(__name__)
wa = WhatsApp(
    phone_id='1234567890',
    token='xxxxxxx',
    server=flask_app,
    callback_url='https://xyz.ngrok-free.app',
    verify_token='xyz123',
    app_id=123456,
    app_secret='yyyyyy'
)

@wa.on_message(text.matches('Hello', 'Hi'))
def hello(client: WhatsApp, msg: Message):
    msg.react('👋')
    msg.reply_text(
        text=f'Hello {msg.from_user.name}!',
        buttons=[
            Button(
                title='Click me!',
                callback_data='id:123'
            )
        ]
    )

@wa.on_callback_button(callback.data_startswith('id'))
def click_me(client: WhatsApp, clb: CallbackButton):
    clb.reply_text('You clicked me!')

flask_app.run()  # Run the flask app to start the server

🎛 Installation

  • Install using pip3:

pip3 install -U pywa
  • Install from source (the bleeding edge):

git clone https://github.com/david-lev/pywa.git
cd pywa && pip3 install -U .
  • If you going to use the webhook features, here is shortcut to install the required dependencies:

pip3 install -U "pywa[flask]"
pip3 install -U "pywa[fastapi]"
  • If you going to use the Flow features and want to use the default FlowRequestDecryptor and the default FlowResponseEncryptor, here is shortcut to install the required dependencies:

pip3 install -U "pywa[cryptography]"

💾 Requirements

📖 Setup and Usage

See the Documentation for detailed instructions

☑️ TODO

  • Add support for async

  • Add support for more web frameworks (Django, Starlette, etc.)

  • Add support for more types of updates (account_alerts, phone_number_quality_updates, template_category_updates, etc.)

  • Add more examples and guides

Feel free to open an issue if you have any suggestions. or even better - submit a PR!

📝 License

This project is licensed under the MIT License - see the LICENSE file for details

🔱 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

🙏 Acknowledgments

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

pywa-1.14.0.tar.gz (95.6 kB view details)

Uploaded Source

Built Distribution

pywa-1.14.0-py3-none-any.whl (91.7 kB view details)

Uploaded Python 3

File details

Details for the file pywa-1.14.0.tar.gz.

File metadata

  • Download URL: pywa-1.14.0.tar.gz
  • Upload date:
  • Size: 95.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pywa-1.14.0.tar.gz
Algorithm Hash digest
SHA256 ec10668541c1915fce43ad7e26f79815d03320b1fb547ad1070ff3fae4d72f3d
MD5 1eda1798112ea10adec6763b39d5c745
BLAKE2b-256 9f80c1cd6a897aa4855748c335545d8e0da32a6219a87507be9717d945876a18

See more details on using hashes here.

File details

Details for the file pywa-1.14.0-py3-none-any.whl.

File metadata

  • Download URL: pywa-1.14.0-py3-none-any.whl
  • Upload date:
  • Size: 91.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pywa-1.14.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a28bc678bdcba4f3e758f779c0f8bb8408e921762eb59d4fcd4a9f16bc3a1a1c
MD5 39483beca9af2868d6ffdf8d613c96c6
BLAKE2b-256 285e89c3aaf2b94eef3706078ab26596a97f0127ce2d19b00c43ee5b1a5a93ee

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page