coap_provider.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package main
  2. import (
  3. "sparrow/pkg/protocol"
  4. "sparrow/pkg/rpcs"
  5. "sparrow/pkg/server"
  6. )
  7. type CoAPProvider struct {
  8. }
  9. func NewCoAPProvider() *CoAPProvider {
  10. return &CoAPProvider{}
  11. }
  12. func (mp *CoAPProvider) ValidateDeviceToken(deviceid string, token []byte) error {
  13. args := rpcs.ArgsValidateDeviceAccessToken{
  14. Id: deviceid,
  15. AccessToken: token,
  16. }
  17. reply := rpcs.ReplyValidateDeviceAccessToken{}
  18. err := server.RPCCallByName(nil, "devicemanager", "DeviceManager.ValidateDeviceAccessToken", args, &reply)
  19. if err != nil {
  20. server.Log.Errorf("validate device token error. deviceid : %v, token : %v, error: %v", deviceid, token, err)
  21. return err
  22. }
  23. return nil
  24. }
  25. func (mp *CoAPProvider) OnDeviceOnline(args rpcs.ArgsGetOnline) error {
  26. reply := rpcs.ReplyGetOnline{}
  27. err := server.RPCCallByName(nil, "devicemanager", "DeviceManager.GetOnline", args, &reply)
  28. if err != nil {
  29. server.Log.Errorf("device online error. args: %v, error: %v", args, err)
  30. }
  31. return err
  32. }
  33. func (mp *CoAPProvider) OnDeviceOffline(deviceid string) error {
  34. args := rpcs.ArgsGetOffline{
  35. Id: deviceid,
  36. }
  37. reply := rpcs.ReplyGetOffline{}
  38. err := server.RPCCallByName(nil, "devicemanager", "DeviceManager.GetOffline", args, &reply)
  39. if err != nil {
  40. server.Log.Errorf("device offline error. deviceid: %v, error: %v", deviceid, err)
  41. }
  42. return err
  43. }
  44. func (mp *CoAPProvider) OnDeviceHeartBeat(deviceid string) error {
  45. args := rpcs.ArgsDeviceId{
  46. Id: deviceid,
  47. }
  48. reply := rpcs.ReplyHeartBeat{}
  49. err := server.RPCCallByName(nil, "devicemanager", "DeviceManager.HeartBeat", args, &reply)
  50. if err != nil {
  51. server.Log.Errorf("device heartbeat error. deviceid: %v, error: %v", deviceid, err)
  52. }
  53. return err
  54. }
  55. func (mp *CoAPProvider) OnDeviceMessage(deviceid string, msgtype string, message []byte) {
  56. server.Log.Infof("device {%v} message {%v} : %x", deviceid, msgtype, message)
  57. data := &protocol.Data{}
  58. err := data.UnMarshal(message)
  59. if err != nil {
  60. server.Log.Errorf("unmarshal data error : %v", err)
  61. return
  62. }
  63. server.Log.Debugf("data %#v", data.SubData)
  64. }