scene.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package scene
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/gogf/gf/database/gredis"
  6. )
  7. const (
  8. scenePrefix = "scene:"
  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. Host: host,
  40. Port: port,
  41. Db: 2,
  42. MaxActive: 100,
  43. })
  44. ctx := context.Background()
  45. helper := &Manager{
  46. redisClient: red,
  47. ctx: ctx,
  48. }
  49. return helper
  50. }
  51. func (a *Manager) SaveScene(info *Info) error {
  52. _, err := a.redisClient.DoVar("SET", info.Key, info.Config)
  53. if err != nil {
  54. return err
  55. }
  56. _, err = a.redisClient.Do("EXPIRE", info.Key, 0)
  57. if err != nil {
  58. return err
  59. }
  60. return nil
  61. }
  62. func (a *Manager) GetScene(key string) (string, error) {
  63. // get status from redis
  64. result, err := a.redisClient.DoVar("GET", key)
  65. if err != nil {
  66. return "", err
  67. }
  68. return result.String(), nil
  69. }
  70. func (a *Manager) DeleteScene(key string) error {
  71. // get status from redis
  72. _, err := a.redisClient.Do("DEL", key)
  73. if err != nil {
  74. return err
  75. }
  76. return nil
  77. }
  78. // GetAllScenes 查询所有场景信息s
  79. func (a *Manager) GetAllScenes() ([]*InfoScene, error) {
  80. // 使用KEYS命令获取所有匹配前缀的键s
  81. keys, err := a.redisClient.DoVar("KEYS", scenePrefix+"*")
  82. fmt.Printf("使用KEYS命令获取所有匹配前缀的键%v", keys)
  83. if err != nil {
  84. return nil, err
  85. }
  86. // 检查是否有数据
  87. if keys.IsEmpty() {
  88. return nil, nil
  89. }
  90. // 转换为字符串切片
  91. keyList := keys.Strings()
  92. // 存储所有结果
  93. scenes := make([]*InfoScene, 0)
  94. var scene InfoScene
  95. for _, key := range keyList {
  96. result, err := a.redisClient.DoVar("GET", key)
  97. if err != nil {
  98. return nil, err
  99. }
  100. err = result.Struct(&scene)
  101. if err != nil {
  102. return nil, err
  103. }
  104. scenes = append(scenes, &scene)
  105. }
  106. return scenes, nil
  107. }