Skip to content

Sending / Receiving Messages

The following guide is only for direct TCP connections, not for Websocket connections.

For Websocket you send/receive messages based on Websocket standards.


To send your proto message follow these steps:

  1. Change the proto message object to the bytes array (Protocol Buffer encoding) by using Google Protocol Buffer SDK for your programming language.
  2. Get the length of the byte array, change it to byte array, reverse it
  3. Send the reversed length + message byte array to the connection stream.


To receive Proto messages you have to follow these steps:

  1. Receive the first four bytes, that's the message length, reverse the byte array, and change it to integer.
  2. Use the length and receive / read that amount of bytes from the stream.
  3. Now you have the full message bytes, use Google Protocol Buffer SDK for your programming language to deserialize the message to ProtoMessage.
  4. Use the ProtoMessage payloadType field to find the actual message type, then deserialize the payload with Google Protocol Buffer SDK to that message type.


The system architecture is little-endian (that is, little end first), that's why we have to reverse the length byte array before sending.

Last update: February 6, 2023