mqtt_provider.go 5.4 KB

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