scene.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package scene
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/gogf/gf/v2/database/gredis"
  6. )
  7. const (
  8. scenePrefix = "scene-manager:alarm:"
  9. dataExpires = 7200
  10. )
  11. type GetSceneParams struct {
  12. Type string `json:"type"`
  13. Name string `json:"name"`
  14. DeviceCode string `json:"device_code"`
  15. }
  16. type InfoScene struct {
  17. Id string `json:"id"`
  18. Name string `json:"name"`
  19. Status int `json:"status"`
  20. Action string `json:"action"`
  21. Desc string `json:"desc"`
  22. SceneType string `json:"scene_type"`
  23. DeviceType string `json:"device_type"`
  24. Config string `json:"config"`
  25. Time string `json:"time"`
  26. }
  27. type Info struct {
  28. Key string `json:"key"`
  29. SceneId string `json:"scene_id"`
  30. TaskId string `json:"task_id"`
  31. Config string `json:"config"`
  32. }
  33. type Manager struct {
  34. redisClient *gredis.Redis
  35. ctx context.Context
  36. }
  37. func NewSceneManager(host string, port int) *Manager {
  38. red, _ := gredis.New(&gredis.Config{
  39. Address: fmt.Sprintf("%s:%d", host, port),
  40. Db: 2,
  41. MaxActive: 100,
  42. })
  43. ctx := context.Background()
  44. helper := &Manager{
  45. redisClient: red,
  46. ctx: ctx,
  47. }
  48. return helper
  49. }
  50. func (a *Manager) SaveScene(info *Info) error {
  51. _, err := a.redisClient.Do(a.ctx, "SET", info.Key, info.Config)
  52. if err != nil {
  53. return err
  54. }
  55. _, err = a.redisClient.Do(a.ctx, info.Key, dataExpires)
  56. if err != nil {
  57. return err
  58. }
  59. return nil
  60. }
  61. func (a *Manager) GetScene(key string) (string, error) {
  62. // get status from redis
  63. result, err := a.redisClient.Do(a.ctx, "GET", key)
  64. if err != nil {
  65. return "", err
  66. }
  67. return result.String(), nil
  68. }
  69. func (a *Manager) DeleteScene(key string) error {
  70. // get status from redis
  71. _, err := a.redisClient.Do(a.ctx, "DEL", key)
  72. if err != nil {
  73. return err
  74. }
  75. return nil
  76. }
  77. // ScanKeys 扫描所有匹配的key
  78. //func (a *Manager) ScanKeys(pattern string) ([]string, error) {
  79. // var cursor uint64
  80. // var allKeys []string
  81. // for {
  82. // // 扫描一批匹配的key
  83. // _, err := a.redisClient.Do("Scan", cursor, pattern, 100)
  84. // if err != nil {
  85. // return nil, err
  86. // }
  87. // allKeys = append(allKeys, keys...)
  88. // cursor = nextCursor
  89. // // 游标归0时结束迭代
  90. // if cursor == 0 {
  91. // break
  92. // }
  93. // }
  94. // return allKeys, nil
  95. //}