Skip to main content

Librería de paquetes de datos para mensajes estructurados sobre comunicaciones

Project description

Presentacion

Esta libreria proporciona una abstraccion generica para el uso de paquetes de datos sobre comunicaciones.

Los paquetes de datos son presentados como un diccionario (dict), y serializados en bytes en formato JSON para su envio, o deserializados de bytes en formato JSON a un diccionario (dict) en su recepcion, de manera que el intercambio de mensajes estructurados es simple y potente

Control

La libreria requiere que se le proporcione acceso a dos funciones:

  • ```write(data: bytes)``: funcion de escritura. Debe retornar un valor booleano
  • read(**args, **kwargs): funcion de lectura. Debe retornar bytes

Internamente permite el envio ordenado de paquetes de datos completos, y la recepcion de paquetes de datos ordenados por orden de recepcion, con funciones de alto nivel:

  • send_datapackage(data_package: dict, **args, **kwargs) -> bool
  • receive_datapackage(timeout: int = None) -> dict

Operacion bloqueante: si hay un paquete de datos disponible en la cola, retorna el primero recibido (mas antiguo), si no lo hay, espera hasta que haya uno, o expire el tiempo limite (si aplica)

Implementacion

La libreria convierte los datos (diccionarios) en secuencias de bytes serializadas en formato JSON, aplicando un delimitador para definir la limitacion entre un paquete de datos y otro. De esta manera, cada paquete de datos enviado se envia de manera atomica, asegurandose del orden, y fiabilidad de entrega. Por parte de la recepcion, los paquetes de datos son reconstruidos a partir de bytes serializados, y almacenados de manera ordenada en una cola interna de paquetes: cada llamada a: receive_datapackage retorna el ultimo paquete de datos recibido no extraido; posteriormente se descarta de la cola y se retorna el siguiente

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

datapackage_messages-0.1.4.tar.gz (3.0 kB view details)

Uploaded Source

Built Distribution

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

datapackage_messages-0.1.4-py3-none-any.whl (3.5 kB view details)

Uploaded Python 3

File details

Details for the file datapackage_messages-0.1.4.tar.gz.

File metadata

  • Download URL: datapackage_messages-0.1.4.tar.gz
  • Upload date:
  • Size: 3.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for datapackage_messages-0.1.4.tar.gz
Algorithm Hash digest
SHA256 371ef8b1933961e80d20011e7a482767cd0ff7079e8b3d5a04ff7e6e042899ff
MD5 2a662240fd9e9da39b9028d1ee119c6d
BLAKE2b-256 bccd15e48fe220cc157bb6651535f465a0fd60f83a7f9592b5d7b1a13e7e6b23

See more details on using hashes here.

File details

Details for the file datapackage_messages-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for datapackage_messages-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b9fee9e40228b3e9853136fbb7c2f720c6cb0f0e44b160f11f38adc33392ef1f
MD5 7dcf7891333c77cb47bb43f94692df22
BLAKE2b-256 6ad08425f10c026272a7c14da500dad2a08479a810d09c0fe97890ed9125b539

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