Skip to content

Control Message Structure

Julian Knight edited this page Nov 3, 2017 · 23 revisions

This page is to be used for design notes around the control channel.

The control channel is a separate Socket.IO channel to the data channels (The server channel sends from the server to the client, the client channel goes from the client to the server). Each instance of a uibuilder node gets it own Socket.IO session and you can limit messages to specific clients by using the _clientId (delete it if you want to send a message from a specific client to all clients connected to a node instance).

The control channel is there to keep control information separate to the general data.

The general structure of a control message is:

{ "type": "<text>" }

But other properties can be added as required.

Initially, only 2 control messages have been used. Two more have now been added. Each of these is (v0.4.8+) copied to output port 2 - you will need debug nodes to show the whole msg as msg.payload is not used. msg.topic is also added from the last input msg or from the node itself.

  • type = server connected (server -> client): Sent when Socket.IO connects to client. Additional properties:

    • "debug": <boolean> - tells the client whether uibuilderfe.js should use debug mode or not
    • "_socketId": socket.id - ensures control msg only sent to the correct client
  • type = shutdown (server -> client): Sent when the node instance is either redeployed or removed from Node-RED.

  • type = client disconnect (server only) Additional properties:

    • "_socketId": socket.id - so we know which client disconnected
    • "reason": <string> - The disconnection reason
  • type = socket error (server only) Additional properties:

    • "_socketId": socket.id - so we know which client errored
    • "error": <string> - The error

While no control messages are currently sent from the client to the server, you can do this manually by using uibuilder.sendCtrl(msg) (uibuilderfe v0.4.8+).

Note that if you reload a connected client page, you get a disconnect msg followed by a connect but they have different client ids because Socket.IO assigns a new one on connect.

What to use control messages for

Some ideas

  • Send standard information to new client connections
  • Keep track of utilisation of your web app (analytics, charging, ...)
  • Send alerts if too many clients connect (or too few)

Questions, thoughts and ideas for future design

Questions

Please add any questions you want answering here - please start them with your initials

  • JK: Should the server have a 2nd output port for passing on control messages? OR should they be passed out of the standard port. If using the standard port, should there be an option to turn them on/off?

    CDL: I suggest the 2nd output port solution. I can't see any reason to not do that, and if the user wants to use the messages then it is simpler if they appear on a different port.

    JK: Thanks Colin, I agree.

Ideas

Please add any ideas you have here for further discussion and design. Please start with your initials.

NOTE: I've moved the comments on caching to its own page.

Clone this wiki locally