La verificación secundaria del usuario te permite agregar seguridad de dos factores a los comandos de voz. Esto te permite agregar seguridad adicional para ciertas acciones, como apagar una cámara de seguridad o abrir una puerta. La verificación del usuario secundaria no está vinculada a un atributo de dispositivo específico, lo que te permite decidir cuándo quieres que Google Assistant emita un desafío. Por ejemplo, puedes optar por emitir un desafío para el atributo OnOff de una cámara de seguridad, pero no emitir un desafío para el atributo OnOff de una luz. También puedes tener desafíos de problemas de Assistant en ciertas situaciones para la misma acción. Por ejemplo, puedes solicitar que Assistant emita una solicitud de desafío para abrir una puerta si no hay un llavero NFC cerca de ella, pero no emitir un desafío si el llavero está presente.
El Assistant puede emitir dos tipos de desafíos: confirmación explícita o número de identificación personal (PIN). Esto agrega un bloque de desafío a los intents QUERY
y EXECUTE
que se envían de Assistant a tu acción y acepta una respuesta de error challengeNeeded
. Luego, Assistant envía la solicitud de intent a tu acción con los datos del desafío en el bloque de desafío. Luego, puedes validar los datos del desafío para determinar si el usuario proporcionó la respuesta de seguridad correcta.
Assistant usa un diálogo para emitir el desafío, pero si usas Assistant en plataformas que no son de voz, el PIN y las confirmaciones se realizan en pantalla.
Tipos de dispositivos compatibles
La verificación secundaria del usuario es compatible con todos los tipos de dispositivos.
Características de dispositivos compatibles
La verificación secundaria del usuario es compatible con todas las características del dispositivo.
Tipos de desafíos compatibles
Estos son los tipos de desafíos de verificación secundaria del usuario admitidos:
- Sin desafío: Es una solicitud y respuesta que no usa un desafío de verificación del usuario secundario.
- ackNeeded: Es una verificación secundaria del usuario que requiere una confirmación explícita (sí o no) y también puede usar estados de atributos como comentarios de respuesta. No se recomienda este tipo de desafío para dispositivos y atributos de seguridad.
- pinNeeded: Es una verificación secundaria del usuario que requiere un número de identificación personal (PIN), ideal para dispositivos y atributos de seguridad.
Sin impugnación
En este ejemplo, se muestra una solicitud y una respuesta EXECUTE
correctas sin un desafío para encender las luces.
Usuario | Enciende las luces. |
Google Assistant | Muy bien, se encenderán 3 luces. |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.OnOff", "params": { "on": true } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "SUCCESS", "states": { "on": true, "online": true } }] } }
ackNeeded
Una autenticación de confirmación del usuario secundaria que puede usar varios estados para un atributo o una autenticación de confirmación simple.
Existen los siguientes tipos de desafíos ackNeeded
:
ackNeeded simple
En este ejemplo, se muestra una solicitud y una respuesta simples con un desafío ackNeeded
para atenuar una luz y la confirmación para atenuarla.
Usuario | Atenúa la luz de la sala de estar. |
Google Assistant | Atenúa la luz de la sala de estar. ¿Confirmas la acción? |
Usuario | Sí. |
Google Assistant | Atenúa la luz de la sala de estar. |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.BrightnessAbsolute", "params": { "brightness": 12 } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "ERROR", "errorCode": "challengeNeeded", "challengeNeeded": { "type": "ackNeeded" } }] } }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.BrightnessAbsolute", "params": { "brightness": 12 }, "challenge": { "ack": true } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "SUCCESS" }] } }
ackNeeded con estados de atributos
Una autenticación de confirmación del usuario secundaria que puede usar estados para un atributo.
Por ejemplo, si trabajas con el atributo TemperatureSetting y se configuran thermostatMode
y thermostatTemperatureSetpoint
, Assistant puede preguntar ¿Estás seguro de querer configurar la calefacción del aire acondicionado en 28 grados?
También puedes incluir un estado en una respuesta para que Assistant realice una acción específica en función de una solicitud determinada.
Los siguientes atributos y estados admiten ackNeeded
con estados de atributos. Una lista de una característica específica indica que todos sus estados son compatibles.
- ArmDisarm
currentArmLevel
currentStatusReport
- Fill
- LockUnlock
- OnOff
on
- OpenClose
- Scene
- TemperatureSetting
thermostatMode
thermostatTemperatureSetpoint
thermostatTemperatureSetpointHigh
thermostatTemperatureSetpointLow
En este ejemplo, se muestra una solicitud y una respuesta con un desafío ackNeeded
que usa un estado de rasgo. Cambia el modo del aire acondicionado a calor y establece la temperatura en 28 grados. Luego, Assistant les solicita a los usuarios que confirmen que quieren encender la calefacción y establecer la temperatura en 28 grados, ya que se muestra un thermostatTemperatureSetpoint
de 28
como estado en la respuesta.
Usuario | Establece el modo de CA en calor. |
Google Assistant | ¿Estás seguro de que quieres configurar la calefacción del aire acondicionado en 28 grados? |
Usuario | Sí. |
Google Assistant | Se establecerá la calefacción del aire acondicionado en 28 grados. |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.TemperatureSetting", "params": { "thermostatMode": "heat" } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "ERROR", "states": { "thermostatMode": "heat", "thermostatTemperatureSetpoint": 28 }, "errorCode": "challengeNeeded", "challengeNeeded": { "type": "ackNeeded" } }] } }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.TemperatureSetting", "params": { "thermostatMode": "heat" }, "challenge": { "ack": true } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "SUCCESS", "states": { "thermostatMode": "heat", "thermostatTemperatureSetpoint": 28 } }] } }
pinNeeded
Se recomienda el desafío pinNeeded
para dispositivos de seguridad.
En este ejemplo, se muestra una solicitud y una respuesta iniciales con un desafío pinNeeded
. El ejemplo muestra una respuesta con un desafío pinNeeded
, por lo que Assistant solicita el pin. En este punto, el usuario puede proporcionar un pin incorrecto o válido.
Ejemplo de solicitud y respuesta para un PIN incorrecto o válido:
Usuario | Destraba la puerta. |
Google Assistant | ¿Puedes decirme tu código de seguridad? |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.LockUnlock", "params": { "lock": false } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "ERROR", "errorCode": "challengeNeeded", "challengeNeeded": { "type": "pinNeeded" } }] } }
PIN incorrecto
En este ejemplo, se muestra la solicitud y la respuesta con un desafío challengeFailedPinNeeded
. Este desafío se debe usar después de que falle un desafío pinNeeded
inicial.
Cuando se muestra un tipo challengeFailedPinNeeded
, Assistant vuelve a solicitar el código de seguridad. Si el usuario realiza demasiados intentos fallidos, puedes mostrar una respuesta de error tooManyFailedAttempts
. Consulta Respuestas de error.
Usuario | 333222 |
Google Assistant | Lo siento, el código de seguridad es incorrecto. ¿Puedes decirme tu código de seguridad? |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.LockUnlock", "params": { "lock": false }, "challenge": { "pin": "333222" } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "ERROR", "errorCode": "challengeNeeded", "challengeNeeded": { "type": "challengeFailedPinNeeded" } }] } }
PIN válido
En este ejemplo, se muestra la solicitud y la respuesta de un PIN válido.
Usuario | 333444 |
Google Assistant | Destrabando la puerta. |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.LockUnlock", "params": { "lock": false }, "challenge": { "pin": "333444" } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "SUCCESS", "states": { "isLocked": false, "isJammed": false } }] } }
Usuario | Atenúa la luz de la sala de estar. |
Google Assistant | ¿Puedes decirme tu código de seguridad? |
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "inputs": [{ "intent": "action.devices.EXECUTE", "payload": { "commands": [{ "devices": [{ "id": "123" }], "execution": [{ "command": "action.devices.commands.BrightnessAbsolute", "params": { "brightness": 12 } }] }] } }] }
{ "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf", "payload": { "commands": [{ "ids": ["123"], "status": "ERROR", "errorCode": "challengeNeeded", "challengeNeeded": { "type": "pinNeeded" } }] } }
Respuestas de error
Estos son algunos códigos de error que se pueden mostrar con tus respuestas:
- tooManyFailedAttempts: Lo sentimos, se registraron demasiados intentos fallidos. Ve a la app del dispositivo para completar la acción.
- pinIncorrect: Lo sentimos, el código de seguridad es incorrecto.
- userCancelled: Aceptable
Consulta la lista completa de errores y excepciones.