Path: blob/main/internal/offline_download/pikpak/util.go
1562 views
package pikpak12import (3"context"4"time"56"github.com/Xhofe/go-cache"7"github.com/alist-org/alist/v3/drivers/pikpak"8"github.com/alist-org/alist/v3/internal/op"9"github.com/alist-org/alist/v3/pkg/singleflight"10)1112var taskCache = cache.NewMemCache(cache.WithShards[[]pikpak.OfflineTask](16))13var taskG singleflight.Group[[]pikpak.OfflineTask]1415func (p *PikPak) GetTasks(pikpakDriver *pikpak.PikPak) ([]pikpak.OfflineTask, error) {16key := op.Key(pikpakDriver, "/drive/v1/task")17if !p.refreshTaskCache {18if tasks, ok := taskCache.Get(key); ok {19return tasks, nil20}21}22p.refreshTaskCache = false23tasks, err, _ := taskG.Do(key, func() ([]pikpak.OfflineTask, error) {24ctx := context.Background()25phase := []string{"PHASE_TYPE_RUNNING", "PHASE_TYPE_ERROR", "PHASE_TYPE_PENDING", "PHASE_TYPE_COMPLETE"}26tasks, err := pikpakDriver.OfflineList(ctx, "", phase)27if err != nil {28return nil, err29}30// 添加缓存 10s31if len(tasks) > 0 {32taskCache.Set(key, tasks, cache.WithEx[[]pikpak.OfflineTask](time.Second*10))33} else {34taskCache.Del(key)35}36return tasks, nil37})38if err != nil {39return nil, err40}41return tasks, nil42}434445