task_queue_info.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package cache_center
  2. import (
  3. "fmt"
  4. "github.com/allanpk716/ChineseSubFinder/internal/pkg/cache_center/models"
  5. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_folder"
  6. "github.com/allanpk716/ChineseSubFinder/internal/pkg/my_util"
  7. "os"
  8. "path/filepath"
  9. )
  10. func (c *CacheCenter) TaskQueueClear() error {
  11. // 没有必要删除 DB 中的数据,直接删除外部的缓存文件即可
  12. err := my_folder.ClearFolder(c.taskQueueSaveRootPath)
  13. if err != nil {
  14. return err
  15. }
  16. return nil
  17. }
  18. func (c *CacheCenter) TaskQueueSave(taskPriority int, taskQueueBytes []byte) error {
  19. defer c.locker.Unlock()
  20. c.locker.Lock()
  21. var taskQueues []models.TaskQueueInfo
  22. c.db.Where("priority = ?", taskPriority).Find(&taskQueues)
  23. // 写入到本地存储
  24. saveFPath := filepath.Join(c.taskQueueSaveRootPath, fmt.Sprintf("%d", taskPriority)+".tq")
  25. err := my_util.WriteFile(saveFPath, taskQueueBytes)
  26. if err != nil {
  27. return err
  28. }
  29. relPath, err := filepath.Rel(c.taskQueueSaveRootPath, saveFPath)
  30. if err != nil {
  31. return err
  32. }
  33. if len(taskQueues) == 0 {
  34. // 不存在,需要新建
  35. nowTaskQueue := models.TaskQueueInfo{
  36. Priority: taskPriority,
  37. RelPath: relPath,
  38. }
  39. c.db.Save(&nowTaskQueue)
  40. } else {
  41. // 存在,需要更新
  42. taskQueues[0].RelPath = relPath
  43. c.db.Save(&taskQueues[0])
  44. }
  45. return nil
  46. }
  47. func (c *CacheCenter) TaskQueueRead() (map[int][]byte, error) {
  48. defer c.locker.Unlock()
  49. c.locker.Lock()
  50. var taskQueues []models.TaskQueueInfo
  51. c.db.Find(&taskQueues)
  52. outTaskQueueBytes := make(map[int][]byte, 0)
  53. for _, taskQueue := range taskQueues {
  54. oneTaskQueueFPath := filepath.Join(c.taskQueueSaveRootPath, taskQueue.RelPath)
  55. if my_util.IsFile(oneTaskQueueFPath) == false {
  56. continue
  57. }
  58. bytes, err := os.ReadFile(oneTaskQueueFPath)
  59. if err != nil {
  60. return nil, err
  61. }
  62. outTaskQueueBytes[taskQueue.Priority] = bytes
  63. }
  64. return outTaskQueueBytes, nil
  65. }