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. Permitiendo una logica de comunicacion por mensajes estructurados.

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

Instalacion

Para instalar la libreria unicamente ejecuta en un terminal:

$ pip install datapackage-messages

Control

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

  • write(data: bytes): funcion de escritura. Debe retornar un valor booleano
  • read(): 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) -> 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 como una unidad logica atomica, asegurandose del orden y estructura, delegando la fiabilidad de entrega al transporte subyacente. 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 primer paquete de datos recibido pendiente en la cola (FIFO); posteriormente se descarta de la cola y se retorna el siguiente

Uso

Importacion

from datapackage import Datapackage

Instanciacion

datapackage = Datapackage(
    read_function=read_func,
    write_function=write_func
)

# Se utilizaron funciones de ejemplo. Puede trabajar sobre cualquier funcion que opere conceptualmente sobre un flujo de datos secuenciales

Envio de paquete de datos

data = {
    "TIMESTAMP":1234,
    "DATA":"¡Hola, mundo!"
}

datapackage.send_datapackage(data)

Recepcion de paquete de datos

received_response = datapackage.receive_datapackage()

Indicaciones

  • La libreria no implementa cifrado, compresion, ni procesamiento de datos.
  • No se impone un tamaño limite para los paquetes de datos; pero es recomendable no transmitir paquetes de datos demasiado grandes.
  • La fiabilidad de entrega depende totalmente del transporte subyacente; la libreria solo proporciona fiabilidad en el orden de recepcion.
  • El delimitador de paquetes de datos utilizado y transmitido podria colisionar con el contenido.
  • La libreria no expone mecanismos para pasar parametros dinamicos a las funciones subyacentes de escritura y lectura; dichas funciones deben encapsular internamente su propia logica.

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.12.tar.gz (3.9 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.12-py3-none-any.whl (4.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: datapackage_messages-0.1.12.tar.gz
  • Upload date:
  • Size: 3.9 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.12.tar.gz
Algorithm Hash digest
SHA256 4b0c50e44f574f4b29636263fcce569e07f697202edd839f9648c12396ea46eb
MD5 332e6ee34330ad52052623e9a2e88e4a
BLAKE2b-256 d36c57608ad4dc65c0e2cbff40f6cd76cfdfcf77836a40f7817a4ad047a3b2c5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for datapackage_messages-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 a725cd3a85f0fa3e19e23d0ceb3d51c26d8d58cad341b1ad29327e8438d0b1b7
MD5 fc8b152eb0187dbc18b1a269d142cf6d
BLAKE2b-256 39f91a657e48a61fe09c61591dd63d0b0169a883f702fdb93a598d75562622ba

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