Module pantools.send_recv

Expand source code
import socket
import struct
import pickle
from .logger import logger

def send_size(sock: socket, data: bytes):
    # data is bytes()
    b = bytearray()
    b += struct.pack(">i", len(data))
    logger.info(f"send_size sends {len(b)} {len(data)} followed by the data")
    sock.sendall(b)
    sock.sendall(data)

# an alias since json was really a dict!
def send_json(sock: socket, d: dict):
    send_dict(sock, d)

def send_dict(sock: socket, d: dict):
    #convert dictionary to bytes
    message = pickle.dumps(d)
    logger.debug(f"sending dictionary")
    send_size(sock, message)

def recv_dict(sock: socket) -> dict:
    b = recv_size(sock)
    return pickle.loads(b)

def recv_size(sock: socket) -> str:
    # data length is packed into 4 bytes
    total_bytes_read = 0
    size_of_message = 0

    #chunk = bytes("", "utf-8")
    length_field = bytearray()
    buffer = bytearray()

    #
    # Read Message Length Field (size 4)
    #
    while total_bytes_read < 4:
        sz_to_recv = 4 - len(length_field)
        chunk = sock.recv(sz_to_recv)
        if (len(chunk) < sz_to_recv):
            raise Exception("Was reading {} bytes but got only {}".format(sz_to_recv, len(chunk)))
        else:
            total_bytes_read += len(chunk)
            length_field += chunk

    size_of_message = struct.unpack(">i", length_field)[0]
    
    logger.info("size of message is: {}".format(size_of_message))

    total_bytes_read = 0
    while total_bytes_read < size_of_message:
        # receives bytes!
        want = size_of_message - len(buffer)
        chunk = sock.recv(want)
        logger.info("wanted to read {} and read chunk: {}".format(want, len(chunk)))
        total_bytes_read += len(chunk)
        buffer += chunk

    logger.info(f"  done reading chunks: total size is {len(buffer)}")
    if (total_bytes_read != len(buffer)):
        print("XXXXXXXXXXX SRIOUS ERROR! XXXXXXXXXXXX")
    return buffer
    

Functions

def recv_dict(sock: ) ‑> dict
Expand source code
def recv_dict(sock: socket) -> dict:
    b = recv_size(sock)
    return pickle.loads(b)
def recv_size(sock: ) ‑> str
Expand source code
def recv_size(sock: socket) -> str:
    # data length is packed into 4 bytes
    total_bytes_read = 0
    size_of_message = 0

    #chunk = bytes("", "utf-8")
    length_field = bytearray()
    buffer = bytearray()

    #
    # Read Message Length Field (size 4)
    #
    while total_bytes_read < 4:
        sz_to_recv = 4 - len(length_field)
        chunk = sock.recv(sz_to_recv)
        if (len(chunk) < sz_to_recv):
            raise Exception("Was reading {} bytes but got only {}".format(sz_to_recv, len(chunk)))
        else:
            total_bytes_read += len(chunk)
            length_field += chunk

    size_of_message = struct.unpack(">i", length_field)[0]
    
    logger.info("size of message is: {}".format(size_of_message))

    total_bytes_read = 0
    while total_bytes_read < size_of_message:
        # receives bytes!
        want = size_of_message - len(buffer)
        chunk = sock.recv(want)
        logger.info("wanted to read {} and read chunk: {}".format(want, len(chunk)))
        total_bytes_read += len(chunk)
        buffer += chunk

    logger.info(f"  done reading chunks: total size is {len(buffer)}")
    if (total_bytes_read != len(buffer)):
        print("XXXXXXXXXXX SRIOUS ERROR! XXXXXXXXXXXX")
    return buffer
def send_dict(sock: , d: dict)
Expand source code
def send_dict(sock: socket, d: dict):
    #convert dictionary to bytes
    message = pickle.dumps(d)
    logger.debug(f"sending dictionary")
    send_size(sock, message)
def send_json(sock: , d: dict)
Expand source code
def send_json(sock: socket, d: dict):
    send_dict(sock, d)
def send_size(sock: , data: bytes)
Expand source code
def send_size(sock: socket, data: bytes):
    # data is bytes()
    b = bytearray()
    b += struct.pack(">i", len(data))
    logger.info(f"send_size sends {len(b)} {len(data)} followed by the data")
    sock.sendall(b)
    sock.sendall(data)