Guia do aspersor para casa inteligente
action.devices.types.SPRINKLER
: os aspersores podem iniciar e parar (ou ligar e desligar). Eles também podem oferecer suporte a timers e/ou programações.
Esse tipo indica que o dispositivo recebe o ícone de aspersor e alguns sinônimos e aliases relacionados.
Recursos do dispositivo
Consulte a documentação de características correspondentes para ver detalhes da implementação, como atributos e estados aos quais seu serviço precisa oferecer suporte e como criar respostas de EXECUTE e CONSULTA.
Características obrigatórias
Essas características e comandos são obrigatórios, se aplicáveis ao seu
dispositivo. Se o dispositivo não oferecer suporte a essas características, insira o código de erro de
functionNotSupported
em uma resposta de CONSULTA ou EXECUTAR. Consulte Erros e exceções para mais informações.
Características recomendadas
Estas características são recomendadas, se aplicável ao seu dispositivo. No entanto, é possível combinar todas as características disponíveis para que elas correspondam melhor à funcionalidade do produto atual.
Requisitos de qualidade
- Latência: precisa ser inferior ou igual a 800 ms.
- Confiabilidade: precisa ser maior ou igual a 97%.
Exemplo de dispositivo: sprinkler simples
Esta seção contém exemplos de payloads de intent que representam um "Sprinkler" comum com base no tipo de dispositivo e nas características acima. Se você adicionar ou remover características da sua implementação, modifique suas respostas para refletir essas alterações.
Exemplo de resposta SYNC
{ "requestId": "6894439706274654512", "inputs": [ { "intent": "action.devices.SYNC" } ] }
{ "requestId": "6894439706274654512", "payload": { "agentUserId": "user123", "devices": [ { "id": "123", "type": "action.devices.types.SPRINKLER", "traits": [ "action.devices.traits.Timer", "action.devices.traits.StartStop" ], "name": { "name": "Simple sprinkler" }, "willReportState": true, "attributes": { "availableZones": [ "front", "back" ], "maxTimerLimitSec": 3600 }, "deviceInfo": { "manufacturer": "smart-home-inc", "model": "hs1234", "hwVersion": "3.2", "swVersion": "11.4" } } ] } }
Exemplo de resposta de QUERY
{ "requestId": "6894439706274654514", "inputs": [ { "intent": "action.devices.QUERY", "payload": { "devices": [ { "id": "123" } ] } } ] }
{ "requestId": "6894439706274654514", "payload": { "devices": { "123": { "status": "SUCCESS", "online": true, "isRunning": true, "activeZones": [ "front" ], "timerRemainingSec": 300 } } } }
Exemplos de comandos EXECUTE
Início do timer
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.Timer
.
{ "requestId": "6894439706274654518", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.TimerStart", "params": { "timerTimeSec": 300 } } ] } ] } } ] }
{ "requestId": "6894439706274654518", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "timerRemainingSec": 300 } } ] } }
Ajuste do timer
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.Timer
.
{ "requestId": "6894439706274654520", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.TimerAdjust", "params": { "timerTimeSec": -10 } } ] } ] } } ] }
{ "requestId": "6894439706274654520", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "timerRemainingSec": 290 } } ] } }
Pausa
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.Timer
.
{ "requestId": "6894439706274654522", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.TimerPause" } ] } ] } } ] }
{ "requestId": "6894439706274654522", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "timerRemainingSec": 300, "timerPaused": true } } ] } }
Retomar timer
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.Timer
.
{ "requestId": "6894439706274654524", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.TimerResume" } ] } ] } } ] }
{ "requestId": "6894439706274654524", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "timerRemainingSec": 300, "timerPaused": false } } ] } }
Cancelar timer
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.Timer
.
{ "requestId": "6894439706274654526", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.TimerCancel" } ] } ] } } ] }
{ "requestId": "6894439706274654526", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "timerRemainingSec": -1 } } ] } }
Iniciar parada
Para mais detalhes sobre os parâmetros de comando,
consulte a referência
action.devices.traits.StartStop
.
{ "requestId": "6894439706274654516", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.StartStop", "params": { "start": true, "zone": "back" } } ] } ] } } ] }
{ "requestId": "6894439706274654516", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "isRunning": true, "activeZones": [ "back" ] } } ] } }