Skip to main content

A modern Python library for automating WhatsApp Web using Playwright

Project description

WhatsPlay 🚀

Automatización avanzada de WhatsApp Web usando Playwright, Python y visión por computadora (OpenCV).
Permite interactuar con mensajes no leídos, autenticar mediante código QR y realizar acciones complejas a través de eventos personalizados y filtrado de mensajes.

License
Python


✨ Características

  • Eventos asíncronos: escucha eventos como on_start, on_auth, on_unread_chat.
  • Persistencia de sesión: guarda datos de autenticación en un directorio local para no escanear el QR cada vez.
  • Apertura de chat por nombre o teléfono: si no conocés el chat_name exacto, pasá el número de teléfono completo (con prefijo de país).
  • Envío y recepción de mensajes (texto y multimedia).
  • Filtros personalizados para procesar solo los mensajes que te interesen.
  • Extracción automática de código QR para autenticación.
  • Compatibilidad con servidores sin GUI gracias a Playwright en modo headless.

📦 Arquitectura

  • Modularidad: cada componente (cliente, gestor de chats, filtros, autenticación) está separado.
  • Mantenibilidad: componentes independientes y bien definidos.
  • Testabilidad: cada módulo puede probarse por separado.
  • Reutilización: los módulos pueden usarse en otros proyectos.

🛠 Instalación

Prerrequisitos

  • Python 3.8 o superior

Instalación desde PyPI

pip install whatsplay

Después de instalar la librería, descargá los navegadores de Playwright con:

python -m playwright install

▶️ Ejemplos de uso

WhatsPlay está construido sobre asyncio, por lo que todas las operaciones son asíncronas. A continuación se muestra un ejemplo básico para iniciar sesión, escuchar eventos y enviar un mensaje.

Nota: siempre usá funciones async def como manejadores de eventos, ya que el sistema de eventos los invoca de forma asíncrona.

import asyncio
from pathlib import Path
from whatsplay import Client
from whatsplay.auth import LocalProfileAuth

async def main() -> None:
    data_dir = Path.home() / "Documents" / "whatsapp_session"
    data_dir.mkdir(parents=True, exist_ok=True)

    auth = LocalProfileAuth(data_dir)
    client = Client(auth=auth, headless=False)

    @client.event("on_start")
    async def on_start():
        print("✅ Cliente iniciado")

    @client.event("on_auth")
    async def on_auth():
        print("📸 Mostrando QR en pantalla")

    @client.event("on_unread_chat")
    async def on_unread_chat(chat_name, messages):
        # Si no conocés el nombre exacto, podés usar el número de teléfono
        await client.send_message(chat_name, "Hola, este es un mensaje automático!")

    await client.start()

if __name__ == "__main__":
    asyncio.run(main())

📦 Dependencias

Principales

  • playwright – Automatización de navegador
  • opencv-python – Procesamiento de imágenes (opcional)
  • numpy – Operaciones numéricas utilizadas por OpenCV

Desarrollo

  • pytest – Framework de testing
  • pytest-asyncio – Soporte para pruebas asíncronas
  • black – Formateador de código
  • flake8 – Linter
  • mypy – Verificación de tipos
  • requests – Uso en entornos de desarrollo y pruebas

🤝 Contribuciones

  1. Hacé un fork del repositorio.
  2. Creá una rama (git checkout -b feature/nueva-funcionalidad).
  3. Commit de tus cambios (git commit -am 'Agrega nueva funcionalidad').
  4. Push (git push origin feature/nueva-funcionalidad).
  5. Abrí un Pull Request.

🗺 Roadmap

  • [✅] Soporte para mensajes multimedia (imágenes, videos, audios)
  • [✅] Filtros para mensajes (MessageFilter)

❓ FAQ

¿Es seguro usar WhatsPlay? Usa la interfaz oficial de WhatsApp Web; es tan seguro como usar WhatsApp en un navegador.

¿Puede ser detectado por WhatsApp? Siempre hay riesgo al automatizar servicios web. Úsalo bajo tu responsabilidad.

¿Funciona sin GUI? Sí, gracias al modo headless de Playwright.


🐞 Reporte de bugs

Abrí un issue con:

  • Descripción del problema
  • Pasos para reproducirlo
  • Versión de Python y dependencias
  • Logs relevantes

📄 Licencia

Licencia Apache 2.0.


⭐ Dejá una estrella si te resultó útil
Hecho con ❤️ por Markbusking

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

whatsplay-1.8.6.tar.gz (35.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

whatsplay-1.8.6-py3-none-any.whl (37.3 kB view details)

Uploaded Python 3

File details

Details for the file whatsplay-1.8.6.tar.gz.

File metadata

  • Download URL: whatsplay-1.8.6.tar.gz
  • Upload date:
  • Size: 35.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for whatsplay-1.8.6.tar.gz
Algorithm Hash digest
SHA256 42deeba472a610efebc64a4c3fb61464c70cc541c080c184b2ce0057ba93cbc5
MD5 39fe83947ad1c0586e6d374020f44878
BLAKE2b-256 96a17f26c47b1c8394f815d21c1482d8cf1cbd98522b19a38284aabed464f9dd

See more details on using hashes here.

File details

Details for the file whatsplay-1.8.6-py3-none-any.whl.

File metadata

  • Download URL: whatsplay-1.8.6-py3-none-any.whl
  • Upload date:
  • Size: 37.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for whatsplay-1.8.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5b9fa65a032840d7870ebc2c9aae92e3a624f56bcdf7c56c5703b51959ac94f0
MD5 5689099bd79468c5e5d82a393e211d9c
BLAKE2b-256 0ea33829dbfe8e70116c13b765c4418ba5f8ffdbd8f008d81e27514cb89c9b55

See more details on using hashes here.

Supported by

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