Skip to content

encode_message

faststream.broker.parsers.encode_message #

encode_message(
    msg: Union[Sequence[SendableMessage], SendableMessage]
) -> Tuple[bytes, Optional[ContentType]]

Encodes a message.

PARAMETER DESCRIPTION
msg

The message to be encoded.

TYPE: Union[Sequence[SendableMessage], SendableMessage]

RETURNS DESCRIPTION
Tuple[bytes, Optional[ContentType]]

A tuple containing the encoded message as bytes and the content type of the message.

Source code in faststream/broker/parsers.py
def encode_message(
    msg: Union[Sequence[SendableMessage], SendableMessage],
) -> Tuple[bytes, Optional[ContentType]]:
    """Encodes a message.

    Args:
        msg: The message to be encoded.

    Returns:
        A tuple containing the encoded message as bytes and the content type of the message.

    """
    if msg is None:
        return b"", None

    if isinstance(msg, bytes):
        return msg, None

    if isinstance(msg, str):
        return msg.encode(), ContentTypes.text.value

    return (
        dump_json(msg),
        ContentTypes.json.value,
    )