docs:blox:blox-wifi-messages

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
docs:blox:blox-wifi-messages [2024/08/28 14:05]
admin
docs:blox:blox-wifi-messages [2024/08/28 17:26] (current)
admin
Line 7: Line 7:
 ===== Message Sending and Receiving : ===== ===== Message Sending and Receiving : =====
  
-BLOX devices communicate using [[https://en.wikipedia.org/wiki/User_Datagram_Protocol|UDP]] to send (broadcast) and receive messages. Each message includes a sensor value (analog or digital) and a unique TagID you get to set. The tags allows devices to filter whether they need to pay attention to the message+BLOX devices communicate using [[https://en.wikipedia.org/wiki/User_Datagram_Protocol|UDP]] to send (broadcast) and receive messages. Each message includes a sensor value (analog or digital) and a unique ID Tag you get to set. The tags allows devices to filter whether they need to pay attention to the message
  
-**TagID-Based Processing**:+**ID Tag****-Based Processing**:
  
-   * **Sending**: When BLOX1 sends a message, you tags the sensor value with a specific TagID+   * **Sending**: When BLOX1 sends a message, you tags the sensor value with a specific ID Tag
-  * **Receiving**: All devices on the network receive the message. However, each BLOX device is configured to act only on messages with specific TagIDs+  * **Receiving**: All devices on the network receive the message. However, each BLOX device is configured to act only on messages with specific ID Tags
-      * **BLOX2 Example**: If BLOX 2 is set up with an IF block to look for a message with a certain TagID, it will execute subsequent blocks when a message with that TagID is received, using the included sensor value. +      * **BLOX2 Example**: If BLOX 2 is set up with an IF block to look for a message with a certain ID Tag, it will execute subsequent blocks when a message with that ID Tag is received, using the included sensor value. 
-      * **BLOX3 Example**: If BLOX 3 is not set up to listen for that TagID, it will ignore the message.+      * **BLOX3 Example**: If BLOX 3 is not set up to listen for that ID Tag, it will ignore the message.
 **Multiple Listeners**: **Multiple Listeners**:
  
-Multiple BLOX devices can be configured to respond to the same TagID, allowing for coordinated actions across devices.+Multiple BLOX devices can be configured to respond to the same ID Tag, allowing for coordinated actions across devices.
  
 **Cross-Platform Compatibility**: **Cross-Platform Compatibility**:
Line 24: Line 24:
  
 This setup provides a flexible and extensible way to manage inter-device communication and integration with other networked applications. This setup provides a flexible and extensible way to manage inter-device communication and integration with other networked applications.
 +
 +===== 6.6.3.2 Sending Messages =====
 +
 +You can send analog or digital sensor values
 +
 +Note the matching ID Tags (compared to receiving section below) to identify the outgoing messages
 +
 +^Sending an analog sensor value^Sending a digital sensor value|
 +|{{:docs:blox:pasted:20240828-170512.png}}|{{:docs:blox:pasted:20240828-172440.png}}|
 +
 +----
 +
 +===== 6.6.3.3 Receiving Messages =====
 +
 +Received messages are available as "sensors" for use on the other device / devices
 +
 +Note the matching ID Tags (compared to sending section above) to identify the incoming messages
 +
 +^Receiving analog sensor value^Receiving digital sensor value|
 +|{{docs:blox:pasted:20240828-172622.png}}|{{:docs:blox:pasted:20240828-172524.png}}|
 +
 +----
 +
 +===== 6.6.3.4 Monitoring / troubleshooting messages =====
 +
 +You can see broadcast messages in the BLOX Serial/USB logs
 +
 +{{:docs:blox:pasted:20240828-171736.png}}
 +
 +Messages are broadcast unencrypted for simplicity. This also allows you to very easily monitor and troubleshoot issues, as well as integrate it into other scripts and programs
 +
 +For example you can listen out for messages / send messages from a computer to help you troubleshoot
 +
 +{{:docs:blox:pasted:20240828-171245.png}}
 +
 +----
 +
 +===== 6.6.3.4 3rd party integration =====
 +
 +You can use your own code to send and receive UDP messages in the format of idtagstring=value on port 49160
  
 **Technical Details**: **Technical Details**:
Line 29: Line 69:
 BLOX sends and receives on port 49160 BLOX sends and receives on port 49160
  
-===== 6.6.3.2 Sending Messages =====+Data is sent as a simple string in the format idtag=value. For analog sensors the value is the numeric value. For digital sensors its 0/1 respectively. Quite simple and easy 
 + 
 +For example: Sending via a custom nodejs program 
 +<code> 
 + 
 +const dgram require('dgram'); 
 + 
 +// Create a UDP socket 
 +const client dgram.createSocket('udp4'); 
 + 
 +// Enable broadcast on the socket 
 +client.on('listening', function() { 
 +  client.setBroadcast(true); 
 +}); 
 + 
 +// The message to send 
 +const message Buffer.from('analog_read_1_blox_2=115'); // construct value dynamically in your own code 
 + 
 +// The target port and broadcast address 
 +const PORT = 49160; 
 +const BROADCAST_ADDR = '255.255.255.255'; 
 + 
 +// Send the message 
 +client.send(message, 0, message.length, PORT, BROADCAST_ADDR, (err) => { 
 +  if (err) { 
 +    console.error(`Error sending message: ${err}`); 
 +  } else { 
 +    console.log('Message broadcasted successfully'); 
 +  } 
 +  client.close(); 
 +}); 
 + 
 +</code> 
 + 
 +For example: Receiving via a custom nodejs program 
 + 
 +<code> 
 +const dgram = require('dgram'); 
 + 
 +// Create a UDP socket for the server 
 +const server = dgram.createSocket('udp4'); 
 + 
 +// Define the port to listen on 
 +const PORT = 49160; 
 + 
 +// Event listener for when the server receives a message 
 +server.on('message', (msg, rinfo) => { 
 +  const message = msg.toString(); 
 +  const keyValue = message.split('='); 
 + 
 +  // Check if the message is in the expected format 
 +  if (keyValue.length === && keyValue[0] === 'analog_read_1_blox_2') { 
 +    const value keyValue[1]; 
 +    console.log(`Received analog_read_1_blox_2 value: ${value}`); 
 +    // do something with the value 
 +  } 
 +}); 
 + 
 +// Event listener for when the server starts listening 
 +server.on('listening', () => { 
 +  const address = server.address(); 
 +  console.log(`Server listening on ${address.address}:${address.port}`); 
 +}); 
 + 
 +// Bind the server to the port 
 +server.bind(PORT); 
 + 
 +</code> 
  
-===== 6.6.3.3 Receiving Messages ===== 
  
  
docs/blox/blox-wifi-messages.1724853927.txt.gz · Last modified: 2024/08/28 14:05 by admin