mqtt_provider.go 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. package main
  2. import (
  3. "context"
  4. "github.com/gogf/gf/encoding/gjson"
  5. "sparrow/pkg/klink"
  6. "sparrow/pkg/models"
  7. "sparrow/pkg/rpcs"
  8. "sparrow/pkg/server"
  9. "time"
  10. )
  11. type MQTTProvider struct{}
  12. func NewMQTTProvider() *MQTTProvider {
  13. return &MQTTProvider{}
  14. }
  15. func (mp *MQTTProvider) ValidateDeviceToken(deviceid string, token []byte) error {
  16. args := rpcs.ArgsValidateDeviceAccessToken{
  17. Id: deviceid,
  18. AccessToken: token,
  19. }
  20. reply := rpcs.ReplyValidateDeviceAccessToken{}
  21. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.ValidateDeviceAccessToken", args, &reply)
  22. if err != nil {
  23. return err
  24. }
  25. return nil
  26. }
  27. func (mp *MQTTProvider) OnDeviceOnline(args rpcs.ArgsGetOnline, VendorId string) error {
  28. deviceOnlineCount.Inc()
  29. reply := rpcs.ReplyGetOnline{}
  30. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOnline", args, &reply)
  31. if err != nil {
  32. server.Log.Errorf("device online error. args: %v, error: %v", args, err)
  33. }
  34. var cReply rpcs.ReplyEmptyResult
  35. var cArgs rpcs.ArgsGetStatus
  36. cArgs.VendorId = VendorId
  37. cArgs.Id = args.Id
  38. if err = server.RPCCallByName(nil, rpcs.ControllerName, "Controller.Online", &cArgs, &cReply); err != nil {
  39. return err
  40. }
  41. // 下发时间同步指令
  42. var cmdArgs rpcs.ArgsSendCommand
  43. cmdArgs.Cmd = "timeSync"
  44. cmdArgs.DeviceId = args.Id
  45. cmdArgs.SubDevice = "01"
  46. cmdArgs.Params = map[string]interface{}{
  47. "value": time.Now().Unix(),
  48. }
  49. err = server.RPCCallByName(nil, rpcs.MQTTAccessName, "Access.SendCommand", cmdArgs, &cReply)
  50. if err != nil {
  51. server.Log.Errorf("发送时间同步指令:%v", cmdArgs, err)
  52. }
  53. return err
  54. }
  55. func (mp *MQTTProvider) OnDeviceOffline(deviceid string, vendorId string) error {
  56. if deviceid != "" {
  57. deviceOnlineCount.Dec()
  58. }
  59. args := rpcs.ArgsGetOffline{
  60. Id: deviceid,
  61. VendorId: vendorId,
  62. }
  63. reply := rpcs.ReplyGetOffline{}
  64. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOffline", args, &reply)
  65. if err != nil {
  66. server.Log.Errorf("device offline error. deviceid: %v, error: %v", deviceid, err)
  67. }
  68. var cReply rpcs.ReplyEmptyResult
  69. var cArgs rpcs.ArgsGetStatus
  70. cArgs.VendorId = vendorId
  71. cArgs.Id = args.Id
  72. if err = server.RPCCallByName(nil, rpcs.ControllerName, "Controller.Offline", &cArgs, &cReply); err != nil {
  73. return err
  74. }
  75. return err
  76. }
  77. func (mp *MQTTProvider) OnDeviceHeartBeat(deviceid string) error {
  78. deviceMessageCount.WithLabelValues(deviceid).Inc()
  79. args := rpcs.ArgsDeviceId{
  80. Id: deviceid,
  81. }
  82. reply := rpcs.ReplyHeartBeat{}
  83. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.HeartBeat", args, &reply)
  84. if err != nil {
  85. server.Log.Errorf("device heartbeat error. deviceid: %v, error: %v", deviceid, err)
  86. }
  87. return err
  88. }
  89. func (mp *MQTTProvider) OnDeviceMessage(deviceid, vendorId string, msgtype string, message *gjson.Json) {
  90. deviceMessageCount.WithLabelValues(deviceid).Inc()
  91. server.Log.Debugf("device {%v} message {%v} : %s", deviceid, msgtype, message.MustToJsonString())
  92. switch msgtype {
  93. case "s":
  94. act := klink.PacketAction(message.GetString("action"))
  95. if act != "" {
  96. switch act {
  97. case klink.DevSendAction:
  98. processReportStatus(deviceid, vendorId, message)
  99. case klink.DevLoginAction:
  100. _ = processDevLogin(deviceid, message.GetString("subDeviceId"))
  101. case klink.DevLogoutAction:
  102. _ = processDevLogout(deviceid, message.GetString("subDeviceId"))
  103. case klink.DevNetConfigAction:
  104. _ = processDevNetConfig(deviceid, message.GetString("md5"))
  105. case klink.ReportFirmwareAction:
  106. _ = processDeviceReportUpgrade(deviceid, message.GetString("version"))
  107. case klink.DevUpgradeAction:
  108. _ = processDeviceUpgrade(deviceid, message)
  109. }
  110. }
  111. case "e":
  112. reply := rpcs.ReplyOnEvent{}
  113. args := rpcs.ArgsOnEvent{
  114. DeviceId: deviceid,
  115. TimeStamp: message.GetUint64("timestamp"),
  116. SubDeviceId: message.GetString("subDeviceId"),
  117. SubData: message.GetJson("data").MustToJson(),
  118. VendorId: vendorId,
  119. }
  120. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnEvent", args, &reply)
  121. if err != nil {
  122. server.Log.Errorf("device on event error. args: %v, error: %v", args, err)
  123. return
  124. }
  125. default:
  126. server.Log.Infof("unknown message type: %v", msgtype)
  127. }
  128. }
  129. func processReportStatus(deviceid, vendorId string, message *gjson.Json) {
  130. reply := rpcs.ReplyOnStatus{}
  131. args := rpcs.ArgsOnStatus{
  132. DeviceId: deviceid,
  133. Timestamp: message.GetUint64("timestamp"),
  134. SubData: message.GetJson("data").MustToJson(),
  135. VendorId: vendorId,
  136. SubDeviceId: message.GetString("subDeviceId"),
  137. Action: klink.PacketAction(message.GetString("action")),
  138. }
  139. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnStatus", args, &reply)
  140. if err != nil {
  141. server.Log.Errorf("device report status error. args: %v, error: %v", args, err)
  142. return
  143. }
  144. }
  145. func processDevLogin(deviceCode, subDeviceId string) error {
  146. var args rpcs.SubDeviceArgs
  147. args.DeviceCode = deviceCode
  148. args.Status = 1
  149. args.SubDeviceId = subDeviceId
  150. var reply *models.SubDevice
  151. err := server.RPCCallByName(context.Background(), rpcs.RegistryServerName, "Registry.UpdateSubDevice", &args, &reply)
  152. if err != nil {
  153. server.Log.Errorf("子设备上线出错:%s", err.Error())
  154. }
  155. return nil
  156. }
  157. func processDevLogout(deviceCode, subDeviceId string) error {
  158. var args rpcs.SubDeviceArgs
  159. args.DeviceCode = deviceCode
  160. args.Status = 0
  161. args.SubDeviceId = subDeviceId
  162. var reply *models.SubDevice
  163. err := server.RPCCallByName(context.Background(), rpcs.RegistryServerName, "Registry.UpdateSubDevice", &args, &reply)
  164. if err != nil {
  165. server.Log.Errorf("子设备下线出错:%s", err.Error())
  166. }
  167. return nil
  168. }
  169. // 处理设备配网信息
  170. func processDevNetConfig(deviceCode, md5 string) error {
  171. args := &models.DeviceNetConfig{
  172. DeviceIdentifier: deviceCode,
  173. MD5: md5,
  174. Status: 1,
  175. }
  176. reply := rpcs.ReplyCheckDeviceNetConfig{}
  177. err := server.RPCCallByName(nil, rpcs.RegistryServerName, "Registry.CreateDeviceNetConfig", args, &reply)
  178. if err != nil {
  179. server.Log.Errorf("set device:%s net config info error:%v", deviceCode, err)
  180. }
  181. return nil
  182. }
  183. // 设备上报固件信息处理
  184. func processDeviceReportUpgrade(deviceId, version string) error {
  185. args := &rpcs.ArgsUpdateDeviceVersion{
  186. DeviceId: deviceId,
  187. Version: version,
  188. }
  189. var reply rpcs.ReplyEmptyResult
  190. err := server.RPCCallByName(nil, rpcs.RegistryServerName, "Registry.UpdateDeviceVersion", args, &reply)
  191. if err != nil {
  192. server.Log.Errorf("更新设备版本号失败:%v", err)
  193. }
  194. return nil
  195. }
  196. func processDeviceUpgrade(deviceId string, message *gjson.Json) error {
  197. var reply rpcs.ReplyEmptyResult
  198. data := gjson.New(message.GetJson("data").MustToJson())
  199. switch data.GetString("cmd") {
  200. case "download":
  201. params := gjson.New(data.GetJson("params").MustToJson())
  202. args := &rpcs.ChunkUpgrade{
  203. DeviceId: deviceId,
  204. FileId: params.GetString("fileId"),
  205. FileSize: params.GetInt64("fileSize"),
  206. Size: params.GetInt64("size"),
  207. Offset: params.GetInt("offset"),
  208. }
  209. err := server.RPCCallByName(nil, rpcs.MQTTAccessName, "Access.ChunkUpgrade", args, &reply)
  210. if err != nil {
  211. server.Log.Errorf("分片下载发送失败:%v", err)
  212. }
  213. case "downProgress":
  214. params := gjson.New(data.GetJson("params").MustToJson())
  215. var args rpcs.ArgsOtaProgress
  216. args.DeviceId = deviceId
  217. args.Progress = params.GetInt("progress")
  218. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetProgress", args, &reply)
  219. if err != nil {
  220. server.Log.Errorf("OTA升级进度获取失败:%v", err)
  221. return err
  222. }
  223. }
  224. return nil
  225. }