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.5 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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. "time"
  10. )
  11. //GetTaskConfig get task config from redis cache first
  12. // if not exist in redis, find in db and refresh the redis key
  13. func GetTaskConfig(taskType string) (*models.TaskConfig, error) {
  14. list, err := GetTaskConfigList()
  15. if err != nil {
  16. return nil, err
  17. }
  18. for _, v := range list {
  19. if v.TaskCode == taskType {
  20. return v, nil
  21. }
  22. }
  23. return nil, nil
  24. }
  25. func GetTaskConfigList() ([]*models.TaskConfig, error) {
  26. redisKey := redis_key.TaskConfigList()
  27. configStr, _ := redis_client.Get(redisKey)
  28. if configStr != "" {
  29. if configStr == redis_key.EMPTY_REDIS_VAL {
  30. return nil, nil
  31. }
  32. config := make([]*models.TaskConfig, 0)
  33. json.Unmarshal([]byte(configStr), &config)
  34. return config, nil
  35. }
  36. config, err := models.GetTaskConfigList()
  37. if err != nil {
  38. if models.IsErrRecordNotExist(err) {
  39. redis_client.Setex(redisKey, redis_key.EMPTY_REDIS_VAL, 5*time.Second)
  40. return nil, nil
  41. }
  42. return nil, err
  43. }
  44. jsonStr, _ := json.Marshal(config)
  45. redis_client.Setex(redisKey, string(jsonStr), 30*24*time.Hour)
  46. return config, nil
  47. }
  48. func GetTaskConfigWithLimitList() ([]*models.TaskConfigWithLimit, error) {
  49. list, err := GetTaskConfigList()
  50. if err != nil {
  51. return nil, err
  52. }
  53. if len(list) == 0 {
  54. return nil, nil
  55. }
  56. r := make([]*models.TaskConfigWithLimit, 0)
  57. l, err := limiter.GetLimitersByLimitType(models.LimitTypeTask)
  58. if err != nil {
  59. return nil, err
  60. }
  61. for i := 0; i < len(list); i++ {
  62. li := list[i]
  63. t := &models.TaskConfigWithLimit{
  64. TaskCode: li.TaskCode,
  65. Tittle: li.Tittle,
  66. AwardType: li.AwardType,
  67. AwardAmount: li.AwardAmount,
  68. Creator: li.CreatorName,
  69. CreatedUnix: li.CreatedUnix,
  70. }
  71. lv := make([]*models.LimitConfigVO, 0)
  72. for j := 0; j < len(l); j++ {
  73. lj := l[j]
  74. if lj.LimitCode == li.TaskCode {
  75. lv = append(lv, lj.ToLimitConfigVO())
  76. }
  77. }
  78. t.Limiters = lv
  79. r = append(r, t)
  80. }
  81. return r, nil
  82. }
  83. func AddTaskConfig(config models.TaskConfigWithLimit, doer *models.User) error {
  84. err := models.AddTaskConfig(config, doer)
  85. if err != nil {
  86. log.Error("add task config error,config:%v err:%v", config, err)
  87. return err
  88. }
  89. redis_client.Del(redis_key.LimitConfig(models.LimitTypeTask))
  90. redis_client.Del(redis_key.TaskConfigList())
  91. return nil
  92. }