Skip to main content

Una biblioteca para interactuar con la API de WhatsApp desde Python usando Evolution API

Project description

Whatsapp Toolkit

Librería ligera para enviar mensajes de WhatsApp a través de la API de Envole (WhatsApp Baileys).

Permite:

  • Crear y administrar instancias de WhatsApp.
  • Conectar una instancia escaneando un código QR.
  • Enviar mensajes de texto, documentos (PDF), imágenes, stickers, ubicación y audio (nota de voz).

Toda la API pública se expone desde el módulo whatsapp_toolkit.


Instalación

Con UV Package Manager:

uv add whatsapp-toolkit

Con pip:

pip install whatsapp-toolkit

Requisitos

  • Python 3.10 o superior
  • requests >= 2.32.5

Arrancar el server local (integrado)

La librería ya incluye un modo de arranque del server (Evolution API) pensado para desarrollo local, usando Docker Compose. El flujo de uso está tal cual en los tests (ver test/test_wakpeup_evo.py).

1) Generar plantillas (docker-compose + env)

Esto crea (en el directorio que elijas):

  • docker-compose.yml
  • .env.example (ejemplo; debes copiarlo a .env y completar secretos)
  • wakeup_evolution.sh
from whatsapp_toolkit import devtools

devtools.init_local_evolution(
    path=".",
    overwrite=False,
    verbose=True,
)

2) Configurar secretos para Docker

Copia .env.example a .env y configura al menos:

  • AUTHENTICATION_API_KEY (la API key del server Evolution)
  • POSTGRES_PASSWORD

Además, para el cliente Python, normalmente usarás:

  • WHATSAPP_API_KEY
  • WHATSAPP_INSTANCE
  • WHATSAPP_SERVER_URL (por defecto http://localhost:8080/)

3) Levantar / ver logs / bajar el stack desde Python

Ejemplo (idéntico al test):

from whatsapp_toolkit import devtools

stack = devtools.local_evolution(path=".")

stack.start(
    detached=False,
    build=True,
    verbose=True,
)

# Ver logs en vivo
stack.logs(follow=True)

Comandos útiles:

from whatsapp_toolkit import devtools

stack = devtools.local_evolution(".")

stack.start(detached=True)   # Levanta en background
stack.stop()                 # Stop sin borrar volúmenes
stack.down(volumes=False)    # Down (opcional: volumes=True para limpiar datos)
stack.logs(service=None)     # o service="evolution-api"

Alternativa: script shell

Si prefieres, también puedes levantar con el script:

./wakeup_evolution.sh

UI del manager:

  • http://localhost:8080/manager/

Componentes principales

from whatsapp_toolkit import (
    WhatsappClient,
    PDFGenerator,
    obtener_gif_base64,
    obtener_imagen_base64,
)
  • WhatsappClient: cliente principal para gestionar la instancia y enviar mensajes.
  • PDFGenerator: utilidad para generar un PDF simple y devolverlo en base64 listo para enviar.
  • obtener_gif_base64(): descarga un GIF y lo devuelve en base64 para usarlo como sticker.
  • obtener_imagen_base64(): lee una imagen incluida en el paquete y la devuelve en base64 para enviarla como foto.

Internamente se usan los objetos WhatsAppInstance y WhatsAppSender, pero normalmente no necesitas usarlos directamente.


Configuración rápida

La forma más sencilla de trabajar es usando variables de entorno, igual que en los tests del proyecto.

Variables de entorno esperadas:

  • WHATSAPP_API_KEY: API key de Envole.
  • WHATSAPP_INSTANCE: nombre de la instancia (por ejemplo, "con").
  • WHATSAPP_SERVER_URL: URL del servidor de Envole. Si no se define, se usa "http://localhost:8080/".

Ejemplo mínimo de inicialización:

import os
from whatsapp_toolkit import WhatsappClient

API_KEY = os.getenv("WHATSAPP_API_KEY", "")
INSTANCE = os.getenv("WHATSAPP_INSTANCE", "con")
SERVER_URL = os.getenv("WHATSAPP_SERVER_URL", "http://localhost:8080/")

client = WhatsappClient(API_KEY, SERVER_URL, INSTANCE)

# Opcional pero recomendado: asegura la conexión (muestra QR si hace falta)
client.ensure_connected()

ensure_connected() intentará varias veces enlazar la instancia mostrando un código QR hasta que quede conectada.


Enviar mensajes básicos

Texto

Los números deben ir en formato internacional, por ejemplo México: 5214771234567.

client.send_text(
    number="5214771234567",
    text="¡Hola! Este es un mensaje de prueba 🚀",
    delay_ms=0,  # opcional, delay entre envíos en milisegundos
)

PDF como documento

Usando el generador incluido, igual que en los tests:

from whatsapp_toolkit import PDFGenerator

pdf_b64 = PDFGenerator.generar_pdf_base64(
    titulo="Prueba de PDF",
    subtitulo="Este PDF fue generado automáticamente.",
)

client.send_media(
    number="5214771234567",
    media_b64=pdf_b64,
    filename="prueba_envole_api.pdf",
    caption="Aquí tienes el PDF solicitado.",
    # mediatype y mimetype por default ya son de documento/PDF
)

Imagen como foto

El propio paquete trae una imagen de ejemplo que puedes reutilizar tal como se hace en los tests:

from whatsapp_toolkit import obtener_imagen_base64

imagen_b64 = obtener_imagen_base64()

client.send_media(
    number="5214771234567",
    media_b64=imagen_b64,
    filename="prueba_imagen.jpg",
    caption="Aquí tienes la imagen solicitada.",
    mediatype="image",
    mimetype="image/jpeg",
)

Sticker

Puedes enviar un GIF como sticker pasando el base64 del GIF animado:

from whatsapp_toolkit import obtener_gif_base64

gif_b64 = obtener_gif_base64()

client.send_sticker(
    number="5214771234567",
    sticker_b64=gif_b64,
)

Ubicación

client.send_location(
    number="5214771234567",
    name="Ubicación de prueba",
    address="Calle Falsa 123, Ciudad Ejemplo",
    latitude=19.4326,
    longitude=-99.1332,
)

Audio (nota de voz)

Para enviar audio solo necesitas una cadena base64 del archivo OGG/OPUS (o WAV) que quieras mandar. El proyecto incluye en los tests un ejemplo de generación de audio con Piper, pero en producción puedes usar cualquier TTS o grabación propia:

audio_b64 = "..."  # audio en base64 (OGG/OPUS recomendado)

client.send_audio(
    number="5214771234567",
    audio_b64=audio_b64,
)

Administración de instancia y grupos

Algunos métodos útiles del cliente:

# Crear y borrar instancia
client.create_instance()       # Crea una nueva instancia en el servidor Envole
client.delete_instance()       # Elimina la instancia actual

# Forzar mostrar QR manualmente en cualquier momento
client.connect_instance_qr()

# Listar grupos (opcionalmente con participantes)
groups = client.fetch_groups(get_participants=True)

# Forzar conexión a un número específico (cuando la API lo soporta)
client.connect_number("5214771234567")

Flujo de prueba completo (similar a test_api_cruda)

Un flujo típico para pruebas locales se parece a lo que hay en test/test_api_cruda.py:

import os
from whatsapp_toolkit import WhatsappClient, PDFGenerator, obtener_gif_base64, obtener_imagen_base64

API_KEY = os.getenv("WHATSAPP_API_KEY", "")
INSTANCE = os.getenv("WHATSAPP_INSTANCE", "con")
SERVER_URL = os.getenv("WHATSAPP_SERVER_URL", "http://localhost:8080/")

client = WhatsappClient(API_KEY, SERVER_URL, INSTANCE)
client.ensure_connected()

numero = "5214771234567"  # tu número o un grupo

# Texto
client.send_text(numero, "¡Hola! Esta es una prueba de envío de mensajes vía Envole API 🚀")

# PDF
pdf_b64 = PDFGenerator.generar_pdf_base64("Prueba de PDF", "Este es un PDF generado y enviado.")
client.send_media(numero, pdf_b64, filename="prueba.pdf", caption="Aquí tienes el PDF.")

# Sticker
gif_b64 = obtener_gif_base64()
client.send_sticker(numero, gif_b64)

# Imagen
img_b64 = obtener_imagen_base64()
client.send_media(numero, img_b64, filename="prueba.jpg", caption="Imagen de prueba", mediatype="image", mimetype="image/jpeg")

# Ubicación
client.send_location(numero, "Ubicación de prueba", "Calle Falsa 123", 19.4326, -99.1332)

Con esto deberías poder replicar y adaptar fácilmente el comportamiento que se demuestra en los tests del repositorio.

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

whatsapp_toolkit-1.3.0.tar.gz (65.0 kB view details)

Uploaded Source

Built Distribution

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

whatsapp_toolkit-1.3.0-py3-none-any.whl (66.5 kB view details)

Uploaded Python 3

File details

Details for the file whatsapp_toolkit-1.3.0.tar.gz.

File metadata

  • Download URL: whatsapp_toolkit-1.3.0.tar.gz
  • Upload date:
  • Size: 65.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for whatsapp_toolkit-1.3.0.tar.gz
Algorithm Hash digest
SHA256 f10f6a510b67b7ea85ad74eaf2981d5fd023a8ef1e3ce17e342b99506398a65e
MD5 8cc68a54d33704a7364e0f46f64e83e9
BLAKE2b-256 efccb9fd52a05bff72e5166cb87f6267ee9dae7be5034f4aca004c7a07247453

See more details on using hashes here.

File details

Details for the file whatsapp_toolkit-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: whatsapp_toolkit-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 66.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for whatsapp_toolkit-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d23b10d97cf13ce5b87cc42164aae4d378f9e6e58c88bcaab1947019b0c2c9fd
MD5 964fd5fa6b730c3e018cb9f2b3504881
BLAKE2b-256 917546dc6ff209477a634a2f9133b07752090a2722412c65993669d16c9b7ddb

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