Skip to main content

device.send(messageName, data)

Posts a message from the agent to the device

Availability

Agent

Parameters

Name Type Description
messageName String The name of the message
data Any The data to be passed to the device

Returns

Nothing

Description

This method works in partnership with agent.on() to allow messages and data to be sent from the agent to its imp. For example, if the agent calls:

device.send("setspeed", data);

and the device has already called:

agent.on("setspeed", messageHandler);

then on receipt of the message setspeed from the agent, the device’s messageHandler() function will be called and be passed the contents of the variable data, which can be any serializable Squirrel table, array, string, integer, float or boolean. See the Developer Guide Squirrel Data Serialization for Squirrel’s data serialization rules. The message handler function will always be called with exactly one parameter: the data passed to device.send(). The data parameter in both messageHandler() and device.send() is not optional. You must include a value, even if you do not plan to use it in the handler.

Example Code

The following agent code’s startTime() function uses device.send() to issue a ‘pong’ message to the device in response to the arrival of a ‘ping’ message from the device.

function startTime(time) {
// Send the device a 'pong' message immediately
device.send("pong", time);
}
// When we get a 'ping' message from the device, call startTime()
device.on("ping", startTime);
function ping() {
// Send a 'ping' message to the server with the
// current millisecond counter value
agent.send("ping", hardware.millis());
}
function returnFromAgent(startMillis) {
// Handle a 'pong' message from the server
// Get the current time
local endMillis = hardware.millis();
// Calculate how long the round trip took
local diff = endMillis - startMillis;
// Log it
server.log("Round trip took: " + diff + "ms");
// Wake up in 5 seconds and ping again
imp.wakeup(5.0, ping);
}
// When we get a 'pong' message from the agent, call returnFromAgent()
agent.on("pong", returnFromAgent);
// Start the ping-pong
ping();