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 Playwright

🧠 Descripción

WhatsPlay es una librería modular diseñada para automatizar WhatsApp Web desde Python. La arquitectura está inspirada en el patrón de eventos y la separación de responsabilidades, con módulos independientes para autenticación, interacción con la UI, lógica base, y procesamiento de imágenes.

✨ Características principales

  • Automatización de navegador con Playwright para máxima compatibilidad
  • extraccion automática de QR sin intervención manual
  • Sistema de eventos personalizado para manejo asíncrono de mensajes
  • Detección inteligente de mensajes no leídos
  • Arquitectura modular con separación clara de responsabilidades

🖼️ Arquitectura del sistema

Arquitectura

La arquitectura modular permite:

  • Escalabilidad: Fácil adición de nuevas funcionalidades
  • 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

🧪 Ejemplos de uso

Uso básico

from whatsplay import WhatsAppClient

# Crear cliente
client = WhatsAppClient()

# Handler para mensajes no leídos
@client.on_unread_chat
def handle_unread(chats):
    print("chat name: ", chats[0]['name'])
    success = await client.send_message(chats[0]['name'], "Hello!")
    if success:
        print("✅ Mensaje enviado con éxito")
    else:
        print("❌ Falló el envío del mensaje")

# Iniciar cliente
client.run()

📁 Estructura del proyecto

whatsplay/
├───examples
│       simple_example.py
│       test_client.py
│       test_main_loop.py
│       
└───src
    └───whatsplay
        │   base_client.py
        │   client.py
        │   event.py
        │   utils.py
        │   wa_elements.py
        │   __init__.py
        │
        ├───auth
        │       auth.py
        │       local_profile_auth.py
        │       no_auth.py
        │       __init__.py
        │
        ├───constants
        │       locator.py
        │       states.py
        │
        ├───events
        │       event_handler.py
        │       event_types.py
        │       __init__.py
        │
        └───filters
                message_filter.py
                __init__.py

📦 Dependencias

Principales

  • playwright - Automatización de navegador
  • opencv-python - Procesamiento de imágenes (opcional)
  • pillow - Manipulación de imágenes
  • requests - Cliente HTTP

Desarrollo

  • pytest - Framework de testing
  • black - Formateador de código
  • flake8 - Linter
  • mypy - Verificación de tipos

🤝 Contribuciones

Las contribuciones son bienvenidas. Por favor:

  1. Fork el repositorio
  2. Crea una rama para tu feature (git checkout -b feature/nueva-funcionalidad)
  3. Commit tus cambios (git commit -am 'Agrega nueva funcionalidad')
  4. Push a la rama (git push origin feature/nueva-funcionalidad)
  5. Abre un Pull Request

Guías de desarrollo

  • Sigue PEP 8 para el estilo de código
  • Actualiza la documentación cuando sea necesario
  • Usa type hints en todas las funciones públicas

📋 Roadmap

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

❓ FAQ

¿Es seguro usar WhatsPlay? WhatsPlay utiliza WhatsApp Web oficial, por lo que es tan seguro como usar WhatsApp en tu navegador.

¿Puede ser detectado por WhatsApp? WhatsPlay simula interacciones humanas normales, pero siempre existe un riesgo al automatizar servicios web, hagalo bajo su propia responsabilidad.

¿Funciona en servidores sin GUI? Sí, usando el modo headless de Playwright.

🐛 Reporte de bugs

Si encuentras un bug, por favor abre un issue incluyendo:

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

🤝 Agradecimientos

Este proyecto está inspirado y utiliza partes del código de RedShot, licenciado bajo la licencia Apache 2.0.

📄 Licencia

Este proyecto está licenciado bajo la Licencia Apache 2.0.

Copyright 2025 WhatsPlay

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Consultá el archivo LICENSE para más información.


⭐ Star este proyecto si te resulta útil

Made with ❤️ by [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.7.5.tar.gz (32.9 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.7.5-py3-none-any.whl (34.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: whatsplay-1.7.5.tar.gz
  • Upload date:
  • Size: 32.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for whatsplay-1.7.5.tar.gz
Algorithm Hash digest
SHA256 0c0726c22af8d4ad2420d4314e9b55986a52cfb39b7ecabcb6ad98286f18bf13
MD5 f0e98dfa83e511a5b0baa9c5cf7713f0
BLAKE2b-256 5b7139441fe05abf3878588cb8746bccafdbf0a8342f9930fb546155465afcdb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: whatsplay-1.7.5-py3-none-any.whl
  • Upload date:
  • Size: 34.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for whatsplay-1.7.5-py3-none-any.whl
Algorithm Hash digest
SHA256 94c07c355dd3aea470bfee89593e413b2f8a17a9a0b592f2bb963974a4d89b6e
MD5 66b19fed7b79f118af33f1899a394506
BLAKE2b-256 4994566306b68a6a1198389bf73e714c0bbd5f1206d7fd2efe2513598dfe6546

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