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 2.8 kB

3 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
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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/services/reward/limiter"
  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 GetTaskConfigWithLimitList() ([]*models.TaskConfigWithLimit, error) {
  52. list, err := GetTaskConfigList()
  53. if err != nil {
  54. return nil, err
  55. }
  56. if len(list) == 0 {
  57. return nil, nil
  58. }
  59. r := make([]*models.TaskConfigWithLimit, 0)
  60. l, err := limiter.GetLimitersByLimitType(models.LimitTypeTask)
  61. if err != nil {
  62. log.Error(" GetLimitersByLimitType from redis error. %v", err)
  63. return nil, err
  64. }
  65. for i := 0; i < len(list); i++ {
  66. li := list[i]
  67. t := &models.TaskConfigWithLimit{
  68. TaskCode: li.TaskCode,
  69. Tittle: li.Tittle,
  70. AwardType: li.AwardType,
  71. AwardAmount: li.AwardAmount,
  72. Creator: li.CreatorName,
  73. CreatedUnix: li.CreatedUnix,
  74. }
  75. lv := make([]*models.LimitConfigVO, 0)
  76. for j := 0; j < len(l); j++ {
  77. lj := l[j]
  78. if lj.LimitCode == li.TaskCode {
  79. lv = append(lv, lj.ToLimitConfigVO())
  80. }
  81. }
  82. t.Limiters = lv
  83. r = append(r, t)
  84. }
  85. return r, nil
  86. }
  87. func AddTaskConfig(config models.TaskConfigWithLimit, doer *models.User) error {
  88. if config.TaskCode == "" || config.AwardType == "" {
  89. log.Error(" AddTaskConfig param error")
  90. return errors.New("param error")
  91. }
  92. err := models.AddTaskConfig(config, doer)
  93. if err != nil {
  94. log.Error("add task config error,config:%v err:%v", config, err)
  95. return err
  96. }
  97. redis_client.Del(redis_key.LimitConfig(models.LimitTypeTask.Name()))
  98. redis_client.Del(redis_key.TaskConfigList())
  99. return nil
  100. }