mqtt_provider.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. package main
  2. import (
  3. "github.com/gogf/gf/encoding/gjson"
  4. "sparrow/pkg/klink"
  5. "sparrow/pkg/models"
  6. "sparrow/pkg/rpcs"
  7. "sparrow/pkg/server"
  8. )
  9. type MQTTProvider struct{}
  10. func NewMQTTProvider() *MQTTProvider {
  11. return &MQTTProvider{}
  12. }
  13. func (mp *MQTTProvider) ValidateDeviceToken(deviceid string, token []byte) error {
  14. args := rpcs.ArgsValidateDeviceAccessToken{
  15. Id: deviceid,
  16. AccessToken: token,
  17. }
  18. reply := rpcs.ReplyValidateDeviceAccessToken{}
  19. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.ValidateDeviceAccessToken", args, &reply)
  20. if err != nil {
  21. server.Log.Errorf("validate device token error. deviceid : %v, token : %v, error: %v", deviceid, token, err)
  22. return err
  23. }
  24. return nil
  25. }
  26. func (mp *MQTTProvider) OnDeviceOnline(args rpcs.ArgsGetOnline, VendorId string) error {
  27. reply := rpcs.ReplyGetOnline{}
  28. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOnline", args, &reply)
  29. if err != nil {
  30. server.Log.Errorf("device online error. args: %v, error: %v", args, err)
  31. }
  32. var cReply rpcs.ReplyEmptyResult
  33. var cArgs rpcs.ArgsGetStatus
  34. cArgs.VendorId = VendorId
  35. cArgs.Id = args.Id
  36. if err = server.RPCCallByName(nil, rpcs.ControllerName, "Controller.Online", &cArgs, &cReply); err != nil {
  37. return err
  38. }
  39. deviceOnlineCount.Inc()
  40. return err
  41. }
  42. func (mp *MQTTProvider) OnDeviceOffline(deviceid string, vendorId string) error {
  43. args := rpcs.ArgsGetOffline{
  44. Id: deviceid,
  45. VendorId: vendorId,
  46. }
  47. reply := rpcs.ReplyGetOffline{}
  48. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOffline", args, &reply)
  49. if err != nil {
  50. server.Log.Errorf("device offline error. deviceid: %v, error: %v", deviceid, err)
  51. }
  52. var cReply rpcs.ReplyEmptyResult
  53. var cArgs rpcs.ArgsGetStatus
  54. cArgs.VendorId = vendorId
  55. cArgs.Id = args.Id
  56. if err = server.RPCCallByName(nil, rpcs.ControllerName, "Controller.Offline", &cArgs, &cReply); err != nil {
  57. return err
  58. }
  59. deviceOnlineCount.Dec()
  60. return err
  61. }
  62. func (mp *MQTTProvider) OnDeviceHeartBeat(deviceid string) error {
  63. deviceMessageCount.WithLabelValues(deviceid).Inc()
  64. args := rpcs.ArgsDeviceId{
  65. Id: deviceid,
  66. }
  67. reply := rpcs.ReplyHeartBeat{}
  68. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.HeartBeat", args, &reply)
  69. if err != nil {
  70. server.Log.Errorf("device heartbeat error. deviceid: %v, error: %v", deviceid, err)
  71. }
  72. return err
  73. }
  74. func (mp *MQTTProvider) OnDeviceMessage(deviceid, vendorId string, msgtype string, message *gjson.Json) {
  75. deviceMessageCount.WithLabelValues(deviceid).Inc()
  76. server.Log.Infof("device {%v} message {%v} : %s", deviceid, msgtype, message.MustToJsonString())
  77. switch msgtype {
  78. case "s":
  79. act := klink.PacketAction(message.GetString("action"))
  80. if act != "" {
  81. switch act {
  82. case klink.DevSendAction:
  83. processReportStatus(deviceid, vendorId, message)
  84. //case klink.DevLoginAction:
  85. // _ = processDevLogin(deviceid)
  86. //case klink.DevLogoutAction:
  87. // _ = processDevLogout(deviceid)
  88. case klink.DevNetConfigAction:
  89. _ = processDevNetConfig(deviceid, message.GetString("md5"))
  90. }
  91. }
  92. case "e":
  93. reply := rpcs.ReplyOnEvent{}
  94. args := rpcs.ArgsOnEvent{
  95. DeviceId: deviceid,
  96. TimeStamp: message.GetUint64("timestamp"),
  97. SubDeviceId: message.GetString("subDeviceId"),
  98. SubData: message.GetJson("data").MustToJson(),
  99. VendorId: vendorId,
  100. }
  101. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnEvent", args, &reply)
  102. if err != nil {
  103. server.Log.Errorf("device on event error. args: %v, error: %v", args, err)
  104. return
  105. }
  106. default:
  107. server.Log.Infof("unknown message type: %v", msgtype)
  108. }
  109. }
  110. func processReportStatus(deviceid, vendorId string, message *gjson.Json) {
  111. reply := rpcs.ReplyOnStatus{}
  112. args := rpcs.ArgsOnStatus{
  113. DeviceId: deviceid,
  114. Timestamp: message.GetUint64("timestamp"),
  115. SubData: message.GetJson("data").MustToJson(),
  116. VendorId: vendorId,
  117. SubDeviceId: message.GetString("subDeviceId"),
  118. Action: klink.PacketAction(message.GetString("action")),
  119. }
  120. err := server.RPCCallByName(nil, rpcs.ControllerName, "Controller.OnStatus", args, &reply)
  121. if err != nil {
  122. server.Log.Errorf("device report status error. args: %v, error: %v", args, err)
  123. return
  124. }
  125. }
  126. func processDevLogin(subDeviceId string) error {
  127. reply := rpcs.ReplyGetOnline{}
  128. var args rpcs.ArgsGetOnline
  129. args.Id = subDeviceId
  130. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOnline", args, &reply)
  131. if err != nil {
  132. server.Log.Errorf("device online error. args: %v, error: %v", args, err)
  133. }
  134. return err
  135. }
  136. func processDevLogout(subDeviceId string) error {
  137. args := rpcs.ArgsGetOffline{
  138. Id: subDeviceId,
  139. }
  140. reply := rpcs.ReplyGetOffline{}
  141. err := server.RPCCallByName(nil, rpcs.DeviceManagerName, "DeviceManager.GetOffline", args, &reply)
  142. if err != nil {
  143. server.Log.Errorf("device offline error. deviceid: %v, error: %v", subDeviceId, err)
  144. }
  145. return err
  146. }
  147. // 处理设备配网信息
  148. func processDevNetConfig(deviceCode, md5 string) error {
  149. args := &models.DeviceNetConfig{
  150. DeviceIdentifier: deviceCode,
  151. MD5: md5,
  152. Status: 1,
  153. }
  154. reply := rpcs.ReplyCheckDeviceNetConfig{}
  155. err := server.RPCCallByName(nil, rpcs.RegistryServerName, "Registry.CreateDeviceNetConfig", args, &reply)
  156. if err != nil {
  157. server.Log.Errorf("set device:%s net config info error:%v", deviceCode, err)
  158. }
  159. return nil
  160. }