Cuando los usuarios interactúan con Google Assistant para consultar el
estado actual de un dispositivo, tu fulfillment recibe un
action.devices.QUERY intent que contiene una
lista de IDs de dispositivos (según lo proporciona tu respuesta SYNC).
Tu fulfillment recibe un
action.devices.EXECUTE intent
cuando los usuarios envían comandos a Assistant para controlar tu
dispositivo.
Cómo controlar intents QUERY
Tu respuesta QUERY incluye un conjunto completo de estados para cada uno de los atributos admitidos por los dispositivos solicitados.
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.QUERY", "payload": { "devices": [{ "id": "123", "customData": { "fooValue": 74, "barValue": true, "bazValue": "foo" } }, { "id": "456", "customData": { "fooValue": 12, "barValue": false, "bazValue": "bar" } }] } }] }
JSON
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "devices": { "123": { "on": true, "online": true, "status": "SUCCESS" }, "456": { "on": true, "online": true, "status": "SUCCESS", "brightness": 80, "color": { "name": "cerulean", "spectrumRGB": 31655 } } } } }
Node.js
const {smarthome} = require('actions-on-google'); const app = smarthome(); // ... app.onQuery((body, headers) => { // TODO Get device state return { requestId: body.requestId, payload: { devices: { 123: { on: true, online: true, status: "SUCCESS" }, 456: { on: true, online: true, status: "SUCCESS", brightness: 80, color: { name: "cerulean", spectrumRGB: 31655 } } } } }; });
Java
@NotNull @Override public QueryResponse onQuery(@NotNull QueryRequest queryRequest, @Nullable Map<?, ?> map) { QueryResponse.Payload payload = new QueryResponse.Payload(); payload.setDevices( new HashMap<String, Map<String, Object>>() { { put( "123", new HashMap<String, Object>() { { put("on", true); put("online", true); put("status", "SUCCESS"); } }); put( "456", new HashMap<String, Object>() { { put("on", true); put("online", true); put("status", "SUCCESS"); put("brightness", 80); put( "color", new HashMap<String, Object>() { { put("name", "cerulean"); put("spectrumRGB", 31655); } }); } }); } }); return new QueryResponse(queryRequest.getRequestId(), payload); }
Para obtener más información, consulta la documentación de referencia del intent QUERY.
Cómo controlar intents EXECUTE
Al igual que QUERY, un solo intent puede segmentar varios IDs de dispositivos. Un solo intent EXECUTE también puede contener varios comandos distintos que se le dan a un grupo de dispositivos. Por ejemplo, un intent activado puede establecer el brillo y el color en un grupo de luces, o establecer varias luces, cada una con un color diferente. Tu respuesta EXECUTE debe mostrar el nuevo estado del dispositivo después de la ejecución.
Usa Report State
cuando cambie el estado del dispositivo de los usuarios. Por ejemplo, debido a un intent EXECUTE o a un cambio de estado local (como accionar manualmente un interruptor de luz).
Esto mantiene Google Home Graph sincronizado con tu servicio en la nube.
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123", "customData": { "fooValue": 74, "barValue": true, "bazValue": "sheepdip" } }, { "id": "456", "customData": { "fooValue": 36, "barValue": false, "bazValue": "moarsheep" } }], "execution": [{ "command": "action.devices.commands.OnOff", "params": { "on": true } }] }] } }] }
JSON
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "on": true, "online": true } }, { "ids": [ "456" ], "status": "ERROR", "errorCode": "deviceTurnedOff" } ] } }
Node.js
const {smarthome} = require('actions-on-google'); const app = smarthome(); // ... app.onExecute((body, headers) => { // TODO Send command to device return { requestId: body.requestId, payload: { commands: [{ ids: ["123"], status: "SUCCESS", states: { on: true, online: true } }, { ids: ["456"], status: "ERROR", errorCode: "deviceTurnedOff" }] } }; });
Java
@NotNull @Override public ExecuteResponse onExecute( @NotNull ExecuteRequest executeRequest, @Nullable Map<?, ?> map) { ExecuteResponse.Payload payload = new ExecuteResponse.Payload(); payload.setCommands( new Commands[] { new Commands( new String[] {"123"}, "SUCCESS", new HashMap<String, Object>() { { put("on", true); put("online", true); } }, null, null), new Commands(new String[] {"456"}, "ERROR", null, "deviceTurnedOff", null) }); return new ExecuteResponse(executeRequest.getRequestId(), payload); }
Para obtener más información, consulta la documentación de referencia del EXECUTE
intent.
Respuestas de estado
Tus respuestas QUERY y EXECUTE incluyen un campo status para informar el resultado de la solicitud. Cada respuesta de estado puede proporcionar uno de los siguientes valores:
SUCCESS: La solicitud se realizó correctamente.OFFLINE: El dispositivo de destino está sin conexión o no se puede acceder a él.EXCEPTIONS: Hay un problema o una alerta asociada con la solicitud.ERROR: La solicitud falló con elerrorCodecorrespondiente.
Para ERROR y EXCEPTIONS, consulta
Cómo controlar errores y excepciones y
Errores y excepciones para obtener más
detalles.