Skip to main content

Este paquete nos permite consumir el API de mercado libre

Project description

MeliAPIClient

MeliAPIClient es un cliente moderno y robusto para interactuar con la API de Mercado Libre en Python. Diseñado con una arquitectura modular basada en composición, soporta el manejo de múltiples sesiones concurrentes, renovación automática de tokens, y almacenamiento flexible de credenciales (archivos locales, memoria o bases de datos), manteniendo el 100% de compatibilidad con desarrollos antiguos.


Características Clave

  • Doble Interfaz: Interfaz clásica (Legacy) para compatibilidad con código existente, e interfaz moderna (Composición) para nuevos desarrollos.
  • Gestión Eficiente de Tokens: Renovación automática y transparente de tokens expirados antes de cada petición HTTP.
  • Almacenamiento Personalizado (TokenStorage): Guarda tus tokens en archivos JSON locales, en memoria, o directamente en tu base de datos (PostgreSQL, SQLite, MySQL, Redis, etc.) mediante funciones callback.
  • Multi-cuenta / Multisesión: Capacidad de gestionar múltiples cuentas de Mercado Libre en paralelo sin colisiones.
  • Recursos Completos: Gestión de órdenes, facturas, envíos, publicaciones (stock/precios), reputación, tendencias y opiniones de productos.
  • Excepciones Específicas: Manejo preciso de errores de red y respuestas del API de Mercado Libre.

Instalación

Instala el módulo directamente desde el entorno local de tu proyecto:

pip install MeliAPIClient

Uso Básico (Interfaz Clásica)

Si ya tienes un script que utiliza el formato tradicional de tres archivos JSON (ml_keys.json, ml_token.json, ml_user.json), puedes continuar usándolo exactamente igual. El módulo renovará automáticamente el token de acceso usando el motor moderno de fondo.

from MeliAPIClient import Session, Order, Bill, Ship

def run():
    # Inicialización tradicional
    session = Session("ml_keys.json", "ml_token.json", "ml_user.json")
    
    # Instanciación clásica de recursos
    orders_api = Order(session)
    bills_api = Bill(session)
    ship_api = Ship(session)

    # Listado de órdenes del vendedor
    mis_ordenes = orders_api.list(year=2026, month=6)
    print("Órdenes:", mis_ordenes)

    # Detalle de envío
    info_envio = ship_api.info("4028374928")
    print("Envío:", info_envio)

if __name__ == "__main__":
    run()

Uso Avanzado (Interfaz Moderna)

El diseño moderno utiliza la composición a través de un único cliente centralizado (MeliClient) y propiedades perezosas para acceder a los recursos.

from MeliAPIClient import MeliClient, FileTokenStorage

# 1. Definir dónde almacenar el token de esta sesión específica
storage = FileTokenStorage("tokens/cuenta_1.json")

# 2. Inicializar el cliente
client = MeliClient(
    client_id="TU_CLIENT_ID",
    client_secret="TU_CLIENT_SECRET",
    token_storage=storage
)

# 3. Consultar recursos usando nomenclatura estándar y tipado estático
# Ejemplo: Obtener información detallada de una publicación
producto = client.items.get("MCO123456789")
print(f"Producto: {producto['title']} | Precio: {producto['price']}")

# Actualizar stock de un producto
client.items.update_stock("MCO123456789", nuevo_stock=15)

Persistencia en Bases de Datos (Estrategia CallbackTokenStorage)

Si quieres guardar los tokens de acceso en una base de datos (por ejemplo, en un modelo de Django, SQLAlchemy, o en Redis) en lugar de archivos JSON locales, utiliza CallbackTokenStorage inyectando funciones de carga y guardado:

from MeliAPIClient import MeliClient, CallbackTokenStorage

# Supongamos que tienes un modelo Django o SQLAlchemy para las credenciales
def load_token_from_db():
    credential = CredencialMercadoLibre.objects.get(id=1)
    return {
        "access_token": credential.access_token,
        "refresh_token": credential.refresh_token,
        "expires_in": credential.expires_in,
        "created_at": credential.created_at,
        "expires_at": credential.expires_at,
        "user_id": credential.user_id,
    }

def save_token_to_db(token_data):
    # Esta función es llamada automáticamente por el cliente cada vez que el token se renueva
    CredencialMercadoLibre.objects.update_or_create(
        id=1,
        defaults={
            "access_token": token_data.get("access_token"),
            "refresh_token": token_data.get("refresh_token"),
            "expires_in": token_data.get("expires_in"),
            "created_at": token_data.get("created_at"),
            "expires_at": token_data.get("expires_at"),
            "user_id": token_data.get("user_id"),
        }
    )

# Inicializar con almacenamiento de base de datos
db_storage = CallbackTokenStorage(load_callback=load_token_from_db, save_callback=save_token_to_db)

client = MeliClient(
    client_id="TU_CLIENT_ID",
    client_secret="TU_CLIENT_SECRET",
    token_storage=db_storage
)

Guía de Recursos Disponibles

1. Órdenes (client.orders)

  • orders.get(order_id): Obtiene el detalle de una orden.
  • orders.search(seller_id=None, year=None, month=None): Busca órdenes de un periodo de tiempo.
  • orders.get_pack(pack_id): Obtiene información de un paquete de envíos.

2. Facturas (client.bills)

  • bills.get_billing_info(order_id): Detalles de facturación del cliente.
  • bills.has_fiscal_document(pack_id): Verifica si el paquete tiene factura adjunta.
  • bills.upload_fiscal_document(pack_id, file_path): Sube una factura en formato PDF.

3. Envíos (client.shipments)

  • shipments.get(shipment_id): Obtiene toda la información de tracking de un envío.

4. Publicaciones (client.items)

  • items.create(body): Publica un nuevo producto.
  • items.get(item_id): Detalle completo de una publicación.
  • items.update(item_id, body): Actualización masiva de campos.
  • items.update_price(item_id, nuevo_precio): Actualiza el precio del producto.
  • items.update_stock(item_id, nuevo_stock): Actualiza el stock disponible.
  • items.get_visits(item_id): Cantidad de visitas de una publicación.

5. Métricas e Inteligencia (client.metrics)

  • metrics.get_seller_info(seller_id=None): Datos públicos del vendedor.
  • metrics.get_seller_reputation(seller_id=None): Termómetro de reputación (reclamos, cancelaciones, retrasos).
  • metrics.get_item_reviews(item_id): Calificaciones por estrellas y comentarios de productos.
  • metrics.get_trends(site_id, category_id=None): Palabras clave más buscadas en un país (ej. MCO) o categoría.
  • metrics.get_questions(seller_id=None, item_id=None, status=None): Preguntas recibidas por el vendedor.

Control de Errores

El módulo define excepciones claras que heredan de MeliError:

from MeliAPIClient.exceptions import MeliAPIError, MeliTokenExpiredError

try:
    client.items.update_price("MCO999999", 5000)
except MeliAPIError as e:
    print(f"Error del API ({e.status_code}): {e.message} | Código: {e.error_code}")
except MeliTokenExpiredError:
    print("El refresh token ha expirado. Es necesario re-autenticar la aplicación manualmente.")

Créditos y Contribuciones


Licencia

Este proyecto está bajo la Licencia MIT.

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

meliapiclient-0.0.5.tar.gz (14.6 kB view details)

Uploaded Source

Built Distribution

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

meliapiclient-0.0.5-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

Details for the file meliapiclient-0.0.5.tar.gz.

File metadata

  • Download URL: meliapiclient-0.0.5.tar.gz
  • Upload date:
  • Size: 14.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for meliapiclient-0.0.5.tar.gz
Algorithm Hash digest
SHA256 b1f30606f05d5f8781842868708d1f6346241f08359879e76d2f7a9eb78e3ed3
MD5 d2ab82be0f00dd491503d2bbcdbded70
BLAKE2b-256 2f1a4d61685f2048e3fb0ef8649bf61f932c74d3ee817f09cd81835f122416b2

See more details on using hashes here.

File details

Details for the file meliapiclient-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: meliapiclient-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 16.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.6

File hashes

Hashes for meliapiclient-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 528aaa4aeed3614621a41fdb6a6e7a433082661a6fcca49ce686ae32821cddaf
MD5 c0b4903042f0d90b67641110ac61d0e4
BLAKE2b-256 c62dd08e082e3144e70ae084e197430e9867dbcd42158b63d1c1be4125b24013

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