You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

task_config.go 5.2 kB

2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. package task
  2. import (
  3. "code.gitea.io/gitea/models"
  4. "code.gitea.io/gitea/modules/log"
  5. "code.gitea.io/gitea/modules/redis/redis_client"
  6. "code.gitea.io/gitea/modules/redis/redis_key"
  7. "code.gitea.io/gitea/modules/redis/redis_lock"
  8. "encoding/json"
  9. "errors"
  10. "time"
  11. )
  12. //GetTaskConfig get task config from redis cache first
  13. // if not exist in redis, find in db and refresh the redis key
  14. func GetTaskConfig(taskType string) (*models.TaskConfig, error) {
  15. list, err := GetTaskConfigList()
  16. if err != nil {
  17. log.Error(" GetTaskConfigList error. %v", err)
  18. return nil, err
  19. }
  20. for _, v := range list {
  21. if v.TaskCode == taskType {
  22. return v, nil
  23. }
  24. }
  25. return nil, nil
  26. }
  27. func GetTaskConfigList() ([]*models.TaskConfig, error) {
  28. redisKey := redis_key.TaskConfigList()
  29. configStr, _ := redis_client.Get(redisKey)
  30. if configStr != "" {
  31. if configStr == redis_key.EMPTY_REDIS_VAL {
  32. return nil, nil
  33. }
  34. config := make([]*models.TaskConfig, 0)
  35. json.Unmarshal([]byte(configStr), &config)
  36. return config, nil
  37. }
  38. config, err := models.GetTaskConfigList()
  39. if err != nil {
  40. log.Error(" GetTaskConfigList from model error. %v", err)
  41. if models.IsErrRecordNotExist(err) {
  42. redis_client.Setex(redisKey, redis_key.EMPTY_REDIS_VAL, 5*time.Second)
  43. return nil, nil
  44. }
  45. return nil, err
  46. }
  47. jsonStr, _ := json.Marshal(config)
  48. redis_client.Setex(redisKey, string(jsonStr), 30*24*time.Hour)
  49. return config, nil
  50. }
  51. func GetTaskConfigPageWithDeleted(opt models.ListOptions) ([]*models.TaskAndLimiterConfig, int64, error) {
  52. config, count, err := models.GetTaskConfigPageWithDeleted(opt)
  53. if err != nil {
  54. log.Error(" GetTaskConfigPageWithDeleted from model error. %v", err)
  55. if models.IsErrRecordNotExist(err) {
  56. return nil, 0, nil
  57. }
  58. return nil, 0, err
  59. }
  60. return config, count, nil
  61. }
  62. func GetTaskConfigWithLimitList(opt models.ListOptions) (*models.TaskConfigWithLimitResponse, error) {
  63. list, n, err := GetTaskConfigPageWithDeleted(opt)
  64. if err != nil {
  65. return nil, err
  66. }
  67. if len(list) == 0 {
  68. return nil, nil
  69. }
  70. r := make([]*models.TaskConfigWithSingleLimit, 0)
  71. for i := 0; i < len(list); i++ {
  72. li := list[i]
  73. t := &models.TaskConfigWithSingleLimit{
  74. ID: li.TaskConfig.ID,
  75. TaskCode: li.TaskConfig.TaskCode,
  76. AwardType: li.TaskConfig.AwardType,
  77. AwardAmount: li.TaskConfig.AwardAmount,
  78. Creator: li.TaskConfig.CreatorName,
  79. CreatedUnix: li.TaskConfig.CreatedUnix,
  80. IsDeleted: li.TaskConfig.DeletedAt > 0,
  81. DeleteAt: li.TaskConfig.DeletedAt,
  82. LimitNum: li.LimitConfig.LimitNum,
  83. RefreshRate: li.LimitConfig.RefreshRate,
  84. }
  85. r = append(r, t)
  86. }
  87. return &models.TaskConfigWithLimitResponse{
  88. Records: r,
  89. Page: opt.Page,
  90. PageSize: opt.PageSize,
  91. Total: n,
  92. }, nil
  93. }
  94. func AddTaskConfig(config models.TaskConfigWithLimit, doer *models.User) error {
  95. if config.TaskCode == "" || config.AwardType == "" {
  96. log.Error(" EditTaskConfig param error")
  97. return errors.New("param error")
  98. }
  99. var lock = redis_lock.NewDistributeLock(redis_key.TaskConfigOperateLock(config.TaskCode, config.AwardType))
  100. isOk, _ := lock.LockWithWait(3*time.Second, 3*time.Second)
  101. if !isOk {
  102. return errors.New("Get lock failed")
  103. }
  104. defer lock.UnLock()
  105. t, err := models.GetTaskConfigByTaskCode(config.TaskCode)
  106. if err != nil && !models.IsErrRecordNotExist(err) {
  107. return err
  108. }
  109. if t != nil {
  110. return errors.New("task config is exist")
  111. }
  112. for i, l := range config.Limiters {
  113. if l.Scope == "" {
  114. config.Limiters[i].Scope = models.LimitScopeSingleUser.Name()
  115. }
  116. }
  117. err = models.NewTaskConfig(config, doer)
  118. if err != nil {
  119. log.Error("add task config error,config:%v err:%v", config, err)
  120. return err
  121. }
  122. redis_client.Del(redis_key.LimitConfig(models.LimitTypeTask.Name()))
  123. redis_client.Del(redis_key.TaskConfigList())
  124. return nil
  125. }
  126. func EditTaskConfig(config models.TaskConfigWithLimit, doer *models.User) error {
  127. if config.TaskCode == "" || config.AwardType == "" || config.ID <= 0 {
  128. log.Error(" EditTaskConfig param error")
  129. return errors.New("param error")
  130. }
  131. var lock = redis_lock.NewDistributeLock(redis_key.TaskConfigOperateLock(config.TaskCode, config.AwardType))
  132. isOk, _ := lock.LockWithWait(3*time.Second, 3*time.Second)
  133. if !isOk {
  134. return errors.New("Get lock failed")
  135. }
  136. defer lock.UnLock()
  137. t, err := models.GetTaskConfigByID(config.ID)
  138. if err != nil {
  139. return err
  140. }
  141. if t == nil {
  142. return errors.New("task config is not exist")
  143. }
  144. for i, l := range config.Limiters {
  145. if l.Scope == "" {
  146. config.Limiters[i].Scope = models.LimitScopeSingleUser.Name()
  147. }
  148. }
  149. err = models.EditTaskConfig(config, doer)
  150. if err != nil {
  151. log.Error("add task config error,config:%v err:%v", config, err)
  152. return err
  153. }
  154. redis_client.Del(redis_key.LimitConfig(models.LimitTypeTask.Name()))
  155. redis_client.Del(redis_key.TaskConfigList())
  156. return nil
  157. }
  158. func DelTaskConfig(id int64, doer *models.User) error {
  159. if id == 0 {
  160. log.Error(" EditTaskConfig param error")
  161. return errors.New("param error")
  162. }
  163. err := models.DelTaskConfig(id, doer)
  164. if err != nil {
  165. log.Error("del task config error,err:%v", err)
  166. return err
  167. }
  168. redis_client.Del(redis_key.LimitConfig(models.LimitTypeTask.Name()))
  169. redis_client.Del(redis_key.TaskConfigList())
  170. return nil
  171. }