mqtt_provider.go 5.5 KB

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