scene.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package scene
  2. import (
  3. "context"
  4. "github.com/gogf/gf/database/gredis"
  5. )
  6. const (
  7. scenePrefix = "scene:"
  8. dataExpires = 7200
  9. )
  10. type GetSceneParams struct {
  11. Type string `json:"type"`
  12. Name string `json:"name"`
  13. DeviceCode string `json:"device_code"`
  14. }
  15. type InfoScene struct {
  16. Id string `json:"id"`
  17. Name string `json:"name"`
  18. Status int `json:"status"`
  19. Action string `json:"action"`
  20. Desc string `json:"desc"`
  21. SceneType string `json:"scene_type"`
  22. DeviceType string `json:"device_type"`
  23. Config string `json:"config"`
  24. Time string `json:"time"`
  25. }
  26. type Info struct {
  27. Key string `json:"key"`
  28. SceneId string `json:"scene_id"`
  29. TaskId string `json:"task_id"`
  30. Config string `json:"config"`
  31. }
  32. type Manager struct {
  33. redisClient *gredis.Redis
  34. ctx context.Context
  35. }
  36. func NewSceneManager(host string, port int) *Manager {
  37. red := gredis.New(&gredis.Config{
  38. Host: host,
  39. Port: 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.DoVar("SET", info.Key, info.Config)
  52. if err != nil {
  53. return err
  54. }
  55. _, err = a.redisClient.Do("EXPIRE", 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.DoVar("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("DEL", key)
  72. if err != nil {
  73. return err
  74. }
  75. return nil
  76. }
  77. // GetAllScenes 查询所有场景信息s
  78. func (a *Manager) GetAllScenes() ([]*InfoScene, error) {
  79. // 使用KEYS命令获取所有匹配前缀的键
  80. keys, err := a.redisClient.DoVar("KEYS", scenePrefix+"*")
  81. if err != nil {
  82. return nil, err
  83. }
  84. // 检查是否有数据
  85. if keys.IsEmpty() {
  86. return nil, nil
  87. }
  88. // 转换为字符串切片
  89. keyList := keys.Strings()
  90. // 存储所有结果
  91. scenes := make([]*InfoScene, 0)
  92. var scene InfoScene
  93. for _, key := range keyList {
  94. result, err := a.redisClient.DoVar("GET", key)
  95. if err != nil {
  96. return nil, err
  97. }
  98. err = result.Struct(&scene)
  99. if err != nil {
  100. return nil, err
  101. }
  102. scenes = append(scenes, &scene)
  103. }
  104. return scenes, nil
  105. }