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) -> boolreceive_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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file datapackage_messages-0.1.2.tar.gz.
File metadata
- Download URL: datapackage_messages-0.1.2.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
09519f9ad7e3102d9251ecd19a7dda7ff75771cd814c56ed43ce7a558f5e8ac3
|
|
| MD5 |
a89f880a3789391db466c76632edb614
|
|
| BLAKE2b-256 |
fd5af0d457f683fbe81d6c6a087d23e4815d452aee05c60fd3dc0a5879cf342e
|
File details
Details for the file datapackage_messages-0.1.2-py3-none-any.whl.
File metadata
- Download URL: datapackage_messages-0.1.2-py3-none-any.whl
- Upload date:
- Size: 3.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1666ac432a167405d50365b5156fecfc88749e2314368b85520d313eba020909
|
|
| MD5 |
ad7a12eb72225156804fdee10948105f
|
|
| BLAKE2b-256 |
bc7c19d6e862bccad78f670fb3a536abca42b918643e0002548935569e5ddb1c
|