智慧型住宅門鎖指南
action.devices.types.DOOR - 門可以開啟和關閉,可能不只一個方向。
這類別表示裝置會取得「門」圖示,以及一些相關的同義字和別名。
裝置功能
如需實作詳細資料 (例如服務應支援的屬性和狀態,以及如何建構 EXECUTE 和 QUERY 回應),請參閱相應的特徵說明文件。
必要特徵
如果適用於裝置,就必須提供這些特徵和指令。如果裝置不支援這些特徵,請在 QUERY 或 EXECUTE 回應中輸入 functionNotSupported 的錯誤代碼。詳情請參閱「錯誤和例外狀況」一節。
建議特徵
如果適用於你的裝置,建議使用這些特徵。 不過,您可以自由混搭所有可用的特徵,盡量符合現有產品功能。
範例裝置:簡單的門
本節包含代表常見「門」的意圖酬載範例,這些範例是以裝置類型和上述特徵為依據。如果在實作中新增或移除特徵,請相應修改回覆,以反映這些變更。
SYNC 回應範例
{
"requestId": "6894439706274654512",
"inputs": [
{
"intent": "action.devices.SYNC"
}
]
}{ "requestId": "6894439706274654512", "payload": { "agentUserId": "user123", "devices": [ { "id": "123", "type": "action.devices.types.DOOR", "traits": [ "action.devices.traits.LockUnlock", "action.devices.traits.OpenClose" ], "name": { "name": "Simple door" }, "willReportState": true, "deviceInfo": { "manufacturer": "smart-home-inc", "model": "hs1234", "hwVersion": "3.2", "swVersion": "11.4" } } ] } }
QUERY 回應範例
{ "requestId": "6894439706274654514", "inputs": [ { "intent": "action.devices.QUERY", "payload": { "devices": [ { "id": "123" } ] } } ] }
{ "requestId": "6894439706274654514", "payload": { "devices": { "123": { "status": "SUCCESS", "online": true, "openPercent": 0, "isLocked": true, "isJammed": false } } } }
EXECUTE 指令範例
LockUnlock
如要進一步瞭解指令參數,請參閱
action.devices.traits.LockUnlock 參考資料。
{ "requestId": "6894439706274654516", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.LockUnlock", "params": { "lock": true } } ] } ] } } ] }
{ "requestId": "6894439706274654516", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "isLocked": true, "isJammed": false } } ] } }
OpenClose
如要進一步瞭解指令參數,請參閱
action.devices.traits.OpenClose 參考資料。
{ "requestId": "6894439706274654518", "inputs": [ { "intent": "action.devices.EXECUTE", "payload": { "commands": [ { "devices": [ { "id": "123" } ], "execution": [ { "command": "action.devices.commands.OpenClose", "params": { "openPercent": 100 } } ] } ] } } ] }
{ "requestId": "6894439706274654518", "payload": { "commands": [ { "ids": [ "123" ], "status": "SUCCESS", "states": { "online": true, "openPercent": 100 } } ] } }