mqtt_provider.go 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  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.Params = map[string]interface{}{
  46. "value": time.Now().Unix(),
  47. }
  48. err = server.RPCCallByName(nil, rpcs.MQTTAccessName, "Access.SendCommand", cmdArgs, &cReply)
  49. if err != nil {
  50. server.Log.Errorf("发送时间同步指令:%v", cmdArgs, err)
  51. }
  52. return err
  53. }
  54. func (mp *MQTTProvider) OnDeviceOffline(deviceid string, vendorId string) error {
  55. if deviceid != "" {
  56. deviceOnlineCount.Dec()
  57. }
  58. args := rpcs.ArgsGetOffline{
  59. Id: deviceid,
  60. VendorId: vendorId,
  61. }
  62. reply := rpcs.ReplyGetOffline{}
  63. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOffline", args, &reply)
  64. if err != nil {
  65. server.Log.Errorf("device offline error. deviceid: %v, error: %v", deviceid, err)
  66. }
  67. var cReply rpcs.ReplyEmptyResult
  68. var cArgs rpcs.ArgsGetStatus
  69. cArgs.VendorId = vendorId
  70. cArgs.Id = args.Id
  71. if err = server.RPCCallByName(nil, rpcs.ControllerName, "Controller.Offline", &cArgs, &cReply); err != nil {
  72. return err
  73. }
  74. return err
  75. }
  76. func (mp *MQTTProvider) OnDeviceHeartBeat(deviceid string) error {
  77. deviceMessageCount.WithLabelValues(deviceid).Inc()
  78. args := rpcs.ArgsDeviceId{
  79. Id: deviceid,
  80. }
  81. reply := rpcs.ReplyHeartBeat{}
  82. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.HeartBeat", args, &reply)
  83. if err != nil {
  84. server.Log.Errorf("device heartbeat error. deviceid: %v, error: %v", deviceid, err)
  85. }
  86. return err
  87. }
  88. func (mp *MQTTProvider) OnDeviceMessage(deviceid, vendorId string, msgtype string, message *gjson.Json) {
  89. deviceMessageCount.WithLabelValues(deviceid).Inc()
  90. server.Log.Infof("device {%v} message {%v} : %s", deviceid, msgtype, message.MustToJsonString())
  91. switch msgtype {
  92. case "s":
  93. act := klink.PacketAction(message.GetString("action"))
  94. if act != "" {
  95. switch act {
  96. case klink.DevSendAction:
  97. processReportStatus(deviceid, vendorId, message)
  98. case klink.DevLoginAction:
  99. _ = processDevLogin(deviceid, message.GetString("subDeviceId"))
  100. case klink.DevLogoutAction:
  101. _ = processDevLogout(deviceid, message.GetString("subDeviceId"))
  102. case klink.DevNetConfigAction:
  103. _ = processDevNetConfig(deviceid, message.GetString("md5"))
  104. }
  105. }
  106. case "e":
  107. reply := rpcs.ReplyOnEvent{}
  108. args := rpcs.ArgsOnEvent{
  109. DeviceId: deviceid,
  110. TimeStamp: message.GetUint64("timestamp"),
  111. SubDeviceId: message.GetString("subDeviceId"),
  112. SubData: message.GetJson("data").MustToJson(),
  113. VendorId: vendorId,
  114. }
  115. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnEvent", args, &reply)
  116. if err != nil {
  117. server.Log.Errorf("device on event error. args: %v, error: %v", args, err)
  118. return
  119. }
  120. default:
  121. server.Log.Infof("unknown message type: %v", msgtype)
  122. }
  123. }
  124. func processReportStatus(deviceid, vendorId string, message *gjson.Json) {
  125. reply := rpcs.ReplyOnStatus{}
  126. args := rpcs.ArgsOnStatus{
  127. DeviceId: deviceid,
  128. Timestamp: message.GetUint64("timestamp"),
  129. SubData: message.GetJson("data").MustToJson(),
  130. VendorId: vendorId,
  131. SubDeviceId: message.GetString("subDeviceId"),
  132. Action: klink.PacketAction(message.GetString("action")),
  133. }
  134. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnStatus", args, &reply)
  135. if err != nil {
  136. server.Log.Errorf("device report status error. args: %v, error: %v", args, err)
  137. return
  138. }
  139. }
  140. func processDevLogin(deviceCode, subDeviceId string) error {
  141. var args rpcs.SubDeviceArgs
  142. args.DeviceCode = deviceCode
  143. args.Status = 1
  144. args.SubDeviceId = subDeviceId
  145. var reply *models.SubDevice
  146. err := server.RPCCallByName(context.Background(), rpcs.RegistryServerName, "Registry.UpdateSubDevice", &args, &reply)
  147. if err != nil {
  148. server.Log.Errorf("子设备上线出错:%s", err.Error())
  149. }
  150. return nil
  151. }
  152. func processDevLogout(deviceCode, subDeviceId string) error {
  153. var args rpcs.SubDeviceArgs
  154. args.DeviceCode = deviceCode
  155. args.Status = 0
  156. args.SubDeviceId = subDeviceId
  157. var reply *models.SubDevice
  158. err := server.RPCCallByName(context.Background(), rpcs.RegistryServerName, "Registry.UpdateSubDevice", &args, &reply)
  159. if err != nil {
  160. server.Log.Errorf("子设备下线出错:%s", err.Error())
  161. }
  162. return nil
  163. }
  164. // 处理设备配网信息
  165. func processDevNetConfig(deviceCode, md5 string) error {
  166. args := &models.DeviceNetConfig{
  167. DeviceIdentifier: deviceCode,
  168. MD5: md5,
  169. Status: 1,
  170. }
  171. reply := rpcs.ReplyCheckDeviceNetConfig{}
  172. err := server.RPCCallByName(nil, rpcs.RegistryServerName, "Registry.CreateDeviceNetConfig", args, &reply)
  173. if err != nil {
  174. server.Log.Errorf("set device:%s net config info error:%v", deviceCode, err)
  175. }
  176. return nil
  177. }