安卓软件

2016-03-14  本文已影响0人  prfeng0618

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上传业务数据
{
    "cmd_url":"/heartbeatclient/business",
    "cmd_name":"report",
    "value": [{
        "med" : "xxxx"
    }]
}
发送指令到MYE
{
    "cmd_url":"/heartbeatclient/business",
    "cmd_name":"issue",
    "value": [{
          "med" : "xxxx"
    }]
}

3.3、TR069客户端与MYE

获取zigbee模块信息
{"cmd_url":"/zigbeeservice/module", "cmd_name":"query"}
{
        "cmd_url":      "/zigbeeservice/module",
        "cmd_name":     "query",
        "result":       0,
        "value":        {
              "MACAddress":        “xxxx”,
               "NetworkPANID":     “xxx”,
               "Channels":    x,
               "numberofchildlimit":      xx,
        }
}
获取zigbee设备信息
{"cmd_url":"/zigbeeservice/device", "cmd_name":"query", "node_mac":"xxx"}
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "query",
        "result":       0,
        "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
获取zigbee配置表
{"cmd_url":"/zigbeeservice/device", "cmd_name":"getconf", "node_mac":"xxx"}
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "getconf",
        "result":       0,
        "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
下发zigbee配置表
{
    "cmd_url":"/zigbeeservice/device",
    "cmd_name":"setconf",
    "node_mac":"xxx",
    "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
{
        "cmd_url":      "/zigbeeservice/device",
        "cmd_name":     "setconf",
        "result":       0,
}
配置上报(当前需求待定)
{
    "cmd_url":"/tr069client/device",
    "cmd_name":"updateconf",
    "value":        {
              "xxxx" :        “xxxx”,
               "xxxx":     “xxx”,
               "xxxx":    x,
               "xxxx":      xx,
        }
}
{
        "cmd_url":      "/tr069client/device",
        "cmd_name":     "updateconf",
        "result":       0,
}
获取当前完整拓扑信息表
{"cmd_url":"/zigbeeservice/topo", "cmd_name":"enum"}
{
        "cmd_url":      "/zigbeeservice/topo",
        "cmd_name":     "enum",
        "result":       0,
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
更新节点
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "update",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "update",
        "result":       0,
}
添加节点
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "add",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "add",
        "result":       0,
}
删除节点
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "delete",
        "value":        [{
              "xxxx" :        "xxxx",
               "xxxx":     "xxx",
               "xxxx":    "xxx",
               "xxxx":    "xxx",
        }]
}
{
        "cmd_url":      "/tr069client/topo",
        "cmd_name":     "delete",
        "result":       0,
}
升级zigbee模块
{
    "cmd_url":"/zigbeeservice/module",
    "cmd_name":"upgrade",
    "url":"xxx",
    "md5":"xxx",
}
升级zigbee设备
{
    "cmd_url":"/zigbeeservice/device",
    "cmd_name":"upgrade",
    "node_mac":"xxx",
    "url":"xxx",
    "md5":"xxx",
}
{
        "cmd_url":"/zigbeeservice/device",
        "cmd_name":"upgrade",
        "node_mac":"xxx",
        "result":0,
}
上一篇 下一篇

猜你喜欢

热点阅读