보조 사용자 확인을 사용하면 음성 명령에 2단계 보안을 추가할 수 있습니다. 이렇게 하면 보안 카메라 끄기, 문 열기와 같은 특정 작업에 대한 보안을 추가할 수 있습니다. 보조 사용자 인증은 특정 기기 트레잇에 연결되어 있지 않으므로 Google Assistant에서 챌린지를 실행할 시기를 결정할 수 있습니다. 예를 들어 보안 카메라의 OnOff 트레잇에 대해 챌린지를 실행하고 조명의 OnOff 트레잇에 대해서는 챌린지를 실행하지 않을 수 있습니다. 동일한 작업에 대해 특정 상황에서 Assistant 문제 챌린지가 있을 수도 있습니다. 예를 들어 NFC 키 카드가 문 근처에 있지 않으면 Assistant에 문 열기 챌린지 요청을 발행하도록 요청하고 키 카드가 있는 경우에는 챌린지를 발행하지 않을 수 있습니다.
Assistant는 명시적 확인 또는 PIN 번호라는 두 가지 유형의 챌린지를 실행할 수 있습니다. 이렇게 하면 Assistant에서 작업으로 다시 전송된 QUERY
및 EXECUTE
인텐트에 챌린지 블록이 추가되고 challengeNeeded
오류 응답이 수락됩니다. 그런 다음 Assistant는 챌린지 블록의 챌린지 데이터와 함께 인텐트 요청을 작업으로 다시 전송합니다. 그런 다음 챌린지 데이터를 검증하여 사용자가 올바른 보안 응답을 제공했는지 확인할 수 있습니다.
Assistant는 대화상자를 사용하여 챌린지를 실행하지만 음성이 아닌 표시 경로에서 Assistant를 사용하는 경우 PIN 및 확인이 화면에서 이루어집니다.
지원되는 기기 유형
보조 사용자 인증은 모든 기기 유형에서 지원됩니다.
지원되는 기기 트레잇
보조 사용자 인증은 모든 기기 트레잇에서 지원됩니다.
지원되는 질문 유형
지원되는 2차 사용자 인증 챌린지 유형은 다음과 같습니다.
- 챌린지 없음: 보조 사용자 인증 챌린지를 사용하지 않는 요청 및 응답입니다.
- ackNeeded: 명시적 확인 (예 또는 아니요)이 필요하며 트레잇 상태를 응답 피드백으로 사용할 수도 있는 보조 사용자 확인입니다. 보안 기기 및 트레잇에는 이 챌린지 유형이 권장되지 않습니다.
- pinNeeded - 보안 기기 및 트레잇에 적합한 PIN (개인 식별 번호)이 필요한 보조 사용자 인증입니다.
챌린지 없음
이 예에서는 조명 켜기 관련 챌린지 없이 성공적인 EXECUTE
요청 및 응답을 보여줍니다.
사용자 | 조명 켜 줘 |
Google Assistant | 알겠습니다. 조명 3개를 켭니다. |
{ "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
트레잇 또는 간단한 확인 인증에 여러 상태를 사용할 수 있는 보조 사용자 확인 인증입니다.
ackNeeded
챌린지 유형에는 다음과 같은 유형이 있습니다.
ackNeeded 간단
이 예에서는 조명을 어둡게 하는 ackNeeded
챌린지와 조명을 어둡게 하는 확인이 포함된 간단한 요청과 응답을 보여줍니다.
사용자 | 거실 조명 어둡게 해 줘. |
Google Assistant | 거실 조명 어둡게 해 줘. 계속하시겠습니까? |
사용자 | 예. |
Google Assistant | 거실 조명 어둡게 해 줘 |
{ "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
트레잇에 상태를 사용할 수 있는 보조 사용자 확인 인증입니다.
예를 들어 TemperatureSetting 트레잇을 사용 중이고 thermostatMode
와 thermostatTemperatureSetpoint
가 모두 설정된 경우 Assistant는 에어컨의 난방을 28도로 설정하시겠어요?라고 물을 수 있습니다.
응답에 상태를 포함하여 Assistant가 지정된 요청에 따라 특정 작업을 실행하도록 할 수도 있습니다.
다음 트레잇 및 상태는 트레잇 상태로 ackNeeded
를 지원합니다. 특정 트레잇의 목록은 모든 상태가 지원됨을 나타냅니다.
- ArmDisarm
currentArmLevel
currentStatusReport
- Fill
- LockUnlock
- OnOff
on
- OpenClose
- Scene
- TemperatureSetting
thermostatMode
thermostatTemperatureSetpoint
thermostatTemperatureSetpointHigh
thermostatTemperatureSetpointLow
이 예에서는 트레잇 상태를 사용하는 ackNeeded
챌린지가 포함된 요청과 응답을 보여줍니다. 에어컨 모드를 난방으로 변경하고 온도를 28도로 설정합니다. 그런 다음 Assistant는 응답에서 28
의 thermostatTemperatureSetpoint
가 상태로 반환되므로 사용자에게 난방을 켜고 온도를 28도로 설정하는 확인을 요청합니다.
사용자 | 에어컨 모드를 난방으로 설정합니다. |
Google Assistant | 에어컨의 난방을 28도로 설정하시겠습니까? |
사용자 | 예. |
Google Assistant | 에어컨의 난방을 28도로 설정합니다. |
{ "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
pinNeeded
챌린지는 보안 기기에 권장됩니다.
이 예에서는 pinNeeded
챌린지가 포함된 초기 요청 및 응답을 보여줍니다. 이 예에서는 pinNeeded
챌린지가 포함된 응답을 반환하므로 Assistant이 PIN을 요청합니다. 이 시점에서 사용자는 잘못된 PIN이나 유효한 PIN을 입력할 수 있습니다.
잘못된 PIN 또는 유효한 PIN에 대한 샘플 요청 및 응답은 다음과 같습니다.
사용자 | 문을 열어 줘. |
Google Assistant | 보안 코드를 알려 주시겠어요? |
{ "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
이 예에서는 challengeFailedPinNeeded
챌린지가 있는 요청과 응답을 보여줍니다. 이 챌린지는 초기 pinNeeded
챌린지가 실패한 후에 사용해야 합니다.
challengeFailedPinNeeded
유형이 반환되면 Assistant에서 보안 코드를 다시 요청합니다. 사용자가 너무 많은 횟수로 실패하면 tooManyFailedAttempts
오류 응답을 반환할 수 있습니다. 오류 응답을 참고하세요.
사용자 | 333222 |
Google Assistant | 죄송합니다. 보안 코드가 잘못되었습니다. 보안 코드를 알려 주시겠어요? |
{ "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
이 예에서는 유효한 PIN의 요청과 응답을 보여줍니다.
사용자 | 333444 |
Google Assistant | 문을 엽니다. |
{ "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 } }] } }
사용자 | 거실 조명 어둡게 해 줘. |
Google Assistant | 보안 코드를 알려 주시겠어요? |
{ "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" } }] } }
오류 응답
다음은 응답과 함께 반환될 수 있는 몇 가지 오류 코드입니다.
- tooManyFailedAttempts - 죄송합니다. 실패한 시도 횟수가 너무 많습니다. 기기의 앱으로 이동하여 작업을 완료하세요.
- pinIncorrect - 죄송합니다. 보안 코드가 잘못되었습니다.
- userCancelled - 확인
오류 및 예외의 전체 목록을 참고하세요.