cache.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package model
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. "math/rand"
  7. "one-api/common"
  8. "strings"
  9. "sync"
  10. "time"
  11. )
  12. const (
  13. TokenCacheSeconds = 60 * 60
  14. UserId2GroupCacheSeconds = 60 * 60
  15. )
  16. func CacheGetTokenByKey(key string) (*Token, error) {
  17. var token Token
  18. if !common.RedisEnabled {
  19. err := DB.Where("`key` = ?", key).First(&token).Error
  20. return &token, err
  21. }
  22. tokenObjectString, err := common.RedisGet(fmt.Sprintf("token:%s", key))
  23. if err != nil {
  24. err := DB.Where("`key` = ?", key).First(&token).Error
  25. if err != nil {
  26. return nil, err
  27. }
  28. jsonBytes, err := json.Marshal(token)
  29. if err != nil {
  30. return nil, err
  31. }
  32. err = common.RedisSet(fmt.Sprintf("token:%s", key), string(jsonBytes), TokenCacheSeconds*time.Second)
  33. if err != nil {
  34. common.SysError("Redis set token error: " + err.Error())
  35. }
  36. return &token, nil
  37. }
  38. err = json.Unmarshal([]byte(tokenObjectString), &token)
  39. return &token, err
  40. }
  41. func CacheGetUserGroup(id int) (group string, err error) {
  42. if !common.RedisEnabled {
  43. return GetUserGroup(id)
  44. }
  45. group, err = common.RedisGet(fmt.Sprintf("user_group:%d", id))
  46. if err != nil {
  47. group, err = GetUserGroup(id)
  48. if err != nil {
  49. return "", err
  50. }
  51. err = common.RedisSet(fmt.Sprintf("user_group:%d", id), group, UserId2GroupCacheSeconds*time.Second)
  52. if err != nil {
  53. common.SysError("Redis set user group error: " + err.Error())
  54. }
  55. }
  56. return group, err
  57. }
  58. var group2model2channels map[string]map[string][]*Channel
  59. var channelSyncLock sync.RWMutex
  60. func InitChannelCache() {
  61. newChannelId2channel := make(map[int]*Channel)
  62. var channels []*Channel
  63. DB.Find(&channels)
  64. for _, channel := range channels {
  65. newChannelId2channel[channel.Id] = channel
  66. }
  67. var abilities []*Ability
  68. DB.Find(&abilities)
  69. groups := make(map[string]bool)
  70. for _, ability := range abilities {
  71. groups[ability.Group] = true
  72. }
  73. newGroup2model2channels := make(map[string]map[string][]*Channel)
  74. for group := range groups {
  75. newGroup2model2channels[group] = make(map[string][]*Channel)
  76. }
  77. for _, channel := range channels {
  78. groups := strings.Split(channel.Group, ",")
  79. for _, group := range groups {
  80. models := strings.Split(channel.Models, ",")
  81. for _, model := range models {
  82. if _, ok := newGroup2model2channels[group][model]; !ok {
  83. newGroup2model2channels[group][model] = make([]*Channel, 0)
  84. }
  85. newGroup2model2channels[group][model] = append(newGroup2model2channels[group][model], channel)
  86. }
  87. }
  88. }
  89. channelSyncLock.Lock()
  90. group2model2channels = newGroup2model2channels
  91. channelSyncLock.Unlock()
  92. common.SysLog("Channels synced from database")
  93. }
  94. func SyncChannelCache(frequency int) {
  95. for {
  96. time.Sleep(time.Duration(frequency) * time.Second)
  97. common.SysLog("Syncing channels from database")
  98. InitChannelCache()
  99. }
  100. }
  101. func CacheGetRandomSatisfiedChannel(group string, model string) (*Channel, error) {
  102. if !common.RedisEnabled {
  103. return GetRandomSatisfiedChannel(group, model)
  104. }
  105. channelSyncLock.RLock()
  106. defer channelSyncLock.RUnlock()
  107. channels := group2model2channels[group][model]
  108. if len(channels) == 0 {
  109. return nil, errors.New("channel not found")
  110. }
  111. idx := rand.Intn(len(channels))
  112. return channels[idx], nil
  113. }