HTTP 远程驱动
优质
小牛编辑
140浏览
2023-12-01
1.1.1. 目录
1.1.2. HTTP 远程驱动(旧版协议)
HTTP 远程驱动是接入 Homebase 推荐的方式,云对云驱动也使用此协议。
你可以通过 开发者驱动, 或 rhome 命令 来开发和调试 HTTP Driver
开发一个 HTTP 远程驱动你可能需要以下 3 个接口
/list
获取设备列表/execute
在设备上执行动作/command
(可选)用于处理用户授权,绑定,初始化等命令;相对于使用这个授权方式,我们更加推荐使用标准 OAuth2.0 接入
通用格式
HTTP 远程驱动使用 JSON 作为数据交换格式, 执行成功会返回如下字段:
成功返回
status
{int} 成功返回必须为 0data
{any} 执行结果, 根据接口类型返回不同的结果
{
"status": 0,
"data": {
"some": "data"
}
}
错误返回
status
{int} 必须 大于0 的正整数errorName
{string} 可选, 若琪定义的错误名vendorErrorCode
{string} 可选, 厂家自有错误码message
{string} status > 0 时必选;错误描述, 对错误的简短描述debugInfo
{string} 可选, 调试信息
{
"status": 1,
"errorName": "E_DRIVER_ERROR",
"vendorErrorCode": "10001",
"message": "time out",
"debugInfo": "some info for debug"
}
标准接口
POST /list
设备搜索
搜索给定用户账号下的所有设备, 包括虚拟设备, 子设备
参数:
- userAuth {Object} 用户授权信息
{
"userAuth": {
"userId": "",
"userToken": ""
}
}
返回值
标准化后的 Device 列表 { Array }:
示例
{
"status": 0,
"data": [
{
"type": "light",
"deviceId": "demoDevcie1",
"name": "灯灯灯灯",
"roomName": "客厅",
"homeName": "我的家",
"actions": {
"switch": ["on", "off"]
},
"state": {
"switch": "off"
}
},
{
"type": "light",
"deviceId": "demoDevcie2",
"name": "灯灯灯灯",
"roomName": "办公室",
"homeName": "公司",
"actions": {
"switch": ["on", "off"]
},
"state": {
"switch": "off"
}
}
]
}
POST /execute
执行操作指令, 并返回可确定的最新状态
设备执行操作, 将返回最新状态
参数
- device
{Object}
- device.deviceId
{String}
, 厂商设备ID, 可以包含不可变数据, 与厂商ID一起,可以唯一确认一台设备 - device.state
{Object}
, 获取设备当前状态 - device.userAuth
{Object}
, 用户授权信息 - action
{Object}
需要执行的操作, 参考文档 actions and state
request
{
"device": {
"deviceId": "xxx",
"state": {
"switch": "on"
},
"userAuth": {
"userId": "",
"userToken": ""
}
},
"action": {
"property": "switch",
"name": "on"
}
}
response
{
"status": 0,
"data": {
"switch": "on"
}
}
返回值
Object 设备最新状态, 如果无法确定设备的状态, 返回字段可以置空, 返回的设备状态将被缓存到虚拟设备中去
POST /command
执行特定指令
执行自定义指令
说明:
- 如果是用户名,密码登录的 Driver 必须提供
login
command,返回 userId,userToken - 如果是 OAuth 登录的, 必须提供
OAuth
command, 返回 OAuth loginUrl
参数
- command
{String}
- params
{Object}
request sample
{
"command": "login",
"params": {
"username": "superman",
"password": "xxxxxx"
}
}
response sample
{
"status": 0,
"data": {
"userId": "superman",
"userToken": "DFGHJKLCVBNMFGHJKL"
}
}
常用指令 Command
command OAuth
OAuth 授权方式必须提供 OAuth Command, 输入回调地址, 返回 OAuth 登陆地址
- 返回的地址必须可以在浏览器里面打开
- 地址里面包含 callbackURL , 注意需要 encode
- 用户授权完成, 需要重定向到
callbackURL
, url 中添加 OAuthRefresh
params:
callbackURL
授权成功后的回调页面
request
{
"command": "OAuth",
"params": {
"callbackURL": "https://homebase.rokid.com/bar?a=1"
}
}
returns { String } 登录跳转 URL
response
{
"status": 0,
"data": "https://oauth.yourbrand.com?redirect=http%3A%2F%2Fhomebase.rokid.com%2Fbar%3Fa%3D1"
}
command OAuthRefresh
OAuth 授权方式必须要有, 输入回调地址, 返回 OAuth 登陆地址
params:
userId
用户IduserToken
用户TokenrefreshToken
用户的 refreshToken, 可选
{
"userId": "superman",
"userToken": "fjfjfjfjfjfj"
}
returns result
- result.userId {可选}
- result.userToken 新的用户Token
- result.expiredTime 更新过期时间, 秒为单位, UTC 时间戳
- result.refreshToken 可选, 更新 refreshToken
{
"status": 0,
"data": {
"userToken": "",
"expiredTime": ""
}
}
command login
params:
- username 用户Id
- password 密码
{
"username": "superman",
"password": "superman_password"
}
returns result
- result.userToken
{
"status": 0,
"data": {
"userToken": "userToken"
}
}
如何描述你的设备?
请参考: 设备定义