安卓软件

1、范围

本文为脉恩空调系统协议规范

2、心跳路由客户端和心跳服务器

2.1、简要

心跳路由客户端与心跳服务器之间新增两条指令,分别为report与issue。report为设备上报数据到心跳服务器,issue为心跳服务器下发数据到心跳路由客户端。

2.2、报文概述

REPORT指令(设备侧上报数据)

1.请求指令
vendor 4字节
options TLV格式
data 不固定

2.响应指令
SN 2字节,请求指令序列号

ISSUE 指令 (业务服务器请求设备侧)

1.请求指令
vendor 4字节
options TLV格式
data 不固定

2.响应指令 与通知消息格式一致、消息类型不一致
SN 2字节,请求指令序列号
reponseCode 2字节

2.3、report与issue报文格式

+-----+----------+-----------+---------+-----+-----+--------+---------+----------+
| flag | pktlen | version | pktTye | sn | Ext | vendor | option | data |
+-----+----------+-----------+---------+-----+-----+--------+---------+----------+
| <--------------- 包头消息 ------------------------>|<-- 消息字段 -->|

pktTye:消息字段类型,新增两条消息在此基础上扩展,分别为report与issue.
pktlen : 消息长度,从vendor头开始到data尾部整个长度。
option : 建议保留,上报和下发将来一定是经常用到消息,可用作为消息字段的扩展。

2.4、report回应报文格式

+------+--------+---------+--------+----+-----+---------------+
| flag | pktlen | version | pktTye | sn | Ext | sn |
+------+--------+---------+--------+----+-----+---------------+
| <--------------- 包头消息 --------------->|<-- 消息字段 -->|

2.5、issue回应报文格式

+------+--------+---------+--------+----+-----+-------------------+
| flag | pktlen | version | pktTye | sn | Ext | sn | reponseCode |
+------+--------+---------+--------+----+-----+-------------------+
| <--------------- 包头消息 --------------->|<---- 消息字段 ---->|

2.6、实现建议:

  1. report(issue)、datalen、vendor、option属于心跳协议的一部分,由心跳服务器与客户端来负责解析。
  2. data段由厂商定义格式,可选择是否加密,心跳服务器与客户端对此段进行透明传输。
  3. CPE侧,通过分析vendor字段,可将data数据会分发到MYE程序,由MYE程序进行解析。
  4. 后台,心跳服务器将data数据放入消息队列后,由专门程序取出,分析出vendor字段并投递到相应程序中进行处理。

3、MYE、TR069客户端、心跳路由客户端之间IPC通信

3.1、简要

这三者之间的ipc通信,通过使用UDP协议,json数据格式,restful风格,方便测试、阅读、开发与维护。

3.2、心跳路由客户端与MYE

MYE上传业务数据
  • MYE将传感器采集的数据封装成med格式,通过心跳路由客户端透传到后台算法服务器。value表示一个数组,可上传多条med指令。
  • 上传数据无需返回值
{
    "cmd_url":"/heartbeatclient/business",
    "cmd_name":"report",
    "value": [{
        "med" : "xxxx"
    }]
}
发送指令到MYE
  • 后台算法服务器将med控制指令,通过心跳客户客户端透传到MYE。value表示一个数组,可上传多条med指令。
  • 下发指令无需返回值
{
    "cmd_url":"/heartbeatclient/business",
    "cmd_name":"issue",
    "value": [{
          "med" : "xxxx"
    }]
}

3.3、TR069客户端与MYE

获取zigbee模块信息
  • 查询zigbee模块信息,上报ACS。
  • 外部程序向MYE发出请求
{"cmd_url":"/zigbeeservice/module", "cmd_name":"query"}
  • MYE返回模块信息表,result返回结果,0表示成功,失败为其他值。若成功,value为模块信息表内容。
{
        "cmd_url":      "/zigbeeservice/module",
        "cmd_name":     "query",
        "result":       0,
        "value":        {
              "MACAddress":        “xxxx”,
               "NetworkPANID":     “xxx”,
               "Channels":    x,
               "numberofchildlimit":      xx,
        }
}
获取zigbee设备信息
  • 查询zigbee设备信息,上报ACS。
  • 外部程序向MYE发出请求
{"cmd_url":"/zigbeeservice/device", "cmd_name":"query", "node_mac":"xxx"}
  • MYE返回zigbee设备信息,result返回结果,0表示成功,失败为其他值。若成功,value为设备信息表内容。
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "query",
        "result":       0,
        "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
获取zigbee配置表
  • 获取zigbee设备配置,上传ACS。
  • 外部程序向MYE发出请求
{"cmd_url":"/zigbeeservice/device", "cmd_name":"getconf", "node_mac":"xxx"}
  • MYE返回zigbee设备配置信息,result返回结果,0表示成功,失败为其他值。若成功,value为设备配置表内容。
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "getconf",
        "result":       0,
        "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
下发zigbee配置表
  • 设置zigbee设备配置。
  • 外部程序向MYE发出请求,配置zigbee设备。
{
    "cmd_url":"/zigbeeservice/device",
    "cmd_name":"setconf",
    "node_mac":"xxx",
    "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
  • MYE返回zigbee设备配置信息,result返回结果,0表示成功,失败为其他值。
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "setconf",
        "result":       0,
}
配置上报(当前需求待定)
  • zigbee设备配置发生变化,主动上报。
  • MYE发出请求,上报改变配置
{
    "cmd_url":"/tr069client/device",
    "cmd_name":"updateconf",
    "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
  • MYE返回zigbee设备配置信息,result返回结果,0表示成功,失败为其他值。
{
        "cmd_url":      "/tr069client/device",
        "cmd_name":     "updateconf",
        "result":       0,
}
获取当前完整拓扑信息表
  • 获取当前zigbee网络完整topo信息,上传ACS。
  • 外部程序向MYE发出请求
{"cmd_url":"/zigbeeservice/topo", "cmd_name":"enum"}
  • MYE返回zigbee设备配置信息,result返回结果,0表示成功,失败为其他值。若成功,value表示数组,为当前所有zigbee设备拓扑信息表集合。
{
        "cmd_url":      "/zigbeeservice/topo",
        "cmd_name":     "enum",
        "result":       0,
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
更新节点
  • 当zigbee网络中,某设备发生拓扑改变,主动上报tr069客户端。
  • MYE发出请求,value表示数组,为所有改变拓扑信息集合。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "update",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
  • tr069客户端返回结果,result返回0表示成功,失败为其他值。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "update",
        "result":       0,
}
添加节点
  • 当zigbee网络中,添加了设备,发生拓扑改变,主动上报tr069客户端。
  • MYE发出请求,value表示数组,为所有改变拓扑信息集合。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "add",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
  • tr069客户端返回结果,result返回0表示成功,失败为其他值。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "add",
        "result":       0,
}
删除节点
  • 当zigbee网络中,移除了设备,发生拓扑改变,主动上报tr069客户端。
  • MYE发出请求,value表示数组,为所有改变拓扑信息集合。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "delete",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
  • tr069客户端返回结果,result返回0表示成功,失败为其他值。
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "delete",
        "result":       0,
}
升级zigbee模块
  • 升级zigbee模块。
  • 外部程序向MYE发出请求。
{
    "cmd_url":"/zigbeeservice/module",
    "cmd_name":"upgrade",
    "url":"xxx",
    "md5":"xxx",
}
升级zigbee设备
  • 升级zigbee设备。
  • 外部程序向MYE发出请求。
{
    "cmd_url":"/zigbeeservice/device",
    "cmd_name":"upgrade",
    "node_mac":"xxx",
    "url":"xxx",
    "md5":"xxx",
}
  • MYE返回结果,result返回0表示成功,失败为其他值。
{
        "cmd_url":"/zigbeeservice/device",
        "cmd_name":"upgrade",
        "node_mac":"xxx",
        "result":0,
}

你可能感兴趣的:(安卓软件)