180 lines
5.7 KiB
Go
180 lines
5.7 KiB
Go
package cache
|
|
|
|
import (
|
|
"context"
|
|
"github.com/fthvgb1/wp-go/cache"
|
|
"github.com/fthvgb1/wp-go/helper"
|
|
"github.com/fthvgb1/wp-go/helper/slice"
|
|
"github.com/fthvgb1/wp-go/internal/pkg/config"
|
|
"github.com/fthvgb1/wp-go/internal/pkg/dao"
|
|
"github.com/fthvgb1/wp-go/internal/pkg/logs"
|
|
"github.com/fthvgb1/wp-go/internal/pkg/models"
|
|
"github.com/fthvgb1/wp-go/internal/plugins"
|
|
"sync"
|
|
"time"
|
|
)
|
|
|
|
var postContextCache *cache.MapCache[uint64, dao.PostContext]
|
|
var archivesCaches *Arch
|
|
var categoryAndTagsCaches *cache.VarCache[[]models.TermsMy]
|
|
var recentPostsCaches *cache.VarCache[[]models.Posts]
|
|
var recentCommentsCaches *cache.VarCache[[]models.Comments]
|
|
var postCommentCaches *cache.MapCache[uint64, []uint64]
|
|
var postsCache *cache.MapCache[uint64, models.Posts]
|
|
|
|
var postMetaCache *cache.MapCache[uint64, map[string]any]
|
|
|
|
var monthPostsCache *cache.MapCache[string, []uint64]
|
|
var postListIdsCache *cache.MapCache[string, dao.PostIds]
|
|
var searchPostIdsCache *cache.MapCache[string, dao.PostIds]
|
|
var maxPostIdCache *cache.VarCache[uint64]
|
|
|
|
var usersCache *cache.MapCache[uint64, models.Users]
|
|
var usersNameCache *cache.MapCache[string, models.Users]
|
|
var commentsCache *cache.MapCache[uint64, models.Comments]
|
|
|
|
var feedCache *cache.VarCache[[]string]
|
|
|
|
var postFeedCache *cache.MapCache[string, string]
|
|
|
|
var commentsFeedCache *cache.VarCache[[]string]
|
|
|
|
var newCommentCache *cache.MapCache[string, string]
|
|
|
|
var allUsernameCache *cache.VarCache[map[string]struct{}]
|
|
|
|
var headerImagesCache *cache.MapCache[string, []models.PostThumbnail]
|
|
|
|
var ctx context.Context
|
|
|
|
func InitActionsCommonCache() {
|
|
c := config.GetConfig()
|
|
archivesCaches = &Arch{
|
|
mutex: &sync.Mutex{},
|
|
fn: dao.Archives,
|
|
}
|
|
|
|
searchPostIdsCache = cache.NewMemoryMapCacheByFn[string](dao.SearchPostIds, c.CacheTime.SearchPostCacheTime)
|
|
|
|
postListIdsCache = cache.NewMemoryMapCacheByFn[string](dao.SearchPostIds, c.CacheTime.PostListCacheTime)
|
|
|
|
monthPostsCache = cache.NewMemoryMapCacheByFn[string](dao.MonthPost, c.CacheTime.MonthPostCacheTime)
|
|
|
|
postContextCache = cache.NewMemoryMapCacheByFn[uint64](dao.GetPostContext, c.CacheTime.ContextPostCacheTime)
|
|
|
|
postsCache = cache.NewMemoryMapCacheByBatchFn(dao.GetPostsByIds, c.CacheTime.PostDataCacheTime)
|
|
|
|
postMetaCache = cache.NewMemoryMapCacheByBatchFn(dao.GetPostMetaByPostIds, c.CacheTime.PostDataCacheTime)
|
|
|
|
categoryAndTagsCaches = cache.NewVarCache(dao.CategoriesAndTags, c.CacheTime.CategoryCacheTime)
|
|
|
|
recentPostsCaches = cache.NewVarCache(dao.RecentPosts, c.CacheTime.RecentPostCacheTime)
|
|
|
|
recentCommentsCaches = cache.NewVarCache(dao.RecentComments, c.CacheTime.RecentCommentsCacheTime)
|
|
|
|
postCommentCaches = cache.NewMemoryMapCacheByFn[uint64](dao.PostComments, c.CacheTime.PostCommentsCacheTime)
|
|
|
|
maxPostIdCache = cache.NewVarCache(dao.GetMaxPostId, c.CacheTime.MaxPostIdCacheTime)
|
|
|
|
usersCache = cache.NewMemoryMapCacheByFn[uint64](dao.GetUserById, c.CacheTime.UserInfoCacheTime)
|
|
|
|
usersNameCache = cache.NewMemoryMapCacheByFn[string](dao.GetUserByName, c.CacheTime.UserInfoCacheTime)
|
|
|
|
commentsCache = cache.NewMemoryMapCacheByBatchFn(dao.GetCommentByIds, c.CacheTime.CommentsCacheTime)
|
|
|
|
allUsernameCache = cache.NewVarCache(dao.AllUsername, c.CacheTime.UserInfoCacheTime)
|
|
|
|
headerImagesCache = cache.NewMemoryMapCacheByFn[string](getHeaderImages, c.CacheTime.ThemeHeaderImagCacheTime)
|
|
|
|
feedCache = cache.NewVarCache(feed, time.Hour)
|
|
|
|
postFeedCache = cache.NewMemoryMapCacheByFn[string](postFeed, time.Hour)
|
|
|
|
commentsFeedCache = cache.NewVarCache(commentsFeed, time.Hour)
|
|
|
|
newCommentCache = cache.NewMemoryMapCacheByFn[string, string](nil, 15*time.Minute)
|
|
|
|
ctx = context.Background()
|
|
|
|
InitFeed()
|
|
}
|
|
|
|
func ClearCache() {
|
|
searchPostIdsCache.ClearExpired(ctx)
|
|
searchPostIdsCache.ClearExpired(ctx)
|
|
postsCache.ClearExpired(ctx)
|
|
postMetaCache.ClearExpired(ctx)
|
|
postListIdsCache.ClearExpired(ctx)
|
|
monthPostsCache.ClearExpired(ctx)
|
|
postContextCache.ClearExpired(ctx)
|
|
usersCache.ClearExpired(ctx)
|
|
commentsCache.ClearExpired(ctx)
|
|
usersNameCache.ClearExpired(ctx)
|
|
postFeedCache.ClearExpired(ctx)
|
|
newCommentCache.ClearExpired(ctx)
|
|
headerImagesCache.ClearExpired(ctx)
|
|
}
|
|
func FlushCache() {
|
|
searchPostIdsCache.Flush(ctx)
|
|
postsCache.Flush(ctx)
|
|
postMetaCache.Flush(ctx)
|
|
postListIdsCache.Flush(ctx)
|
|
monthPostsCache.Flush(ctx)
|
|
postContextCache.Flush(ctx)
|
|
usersCache.Flush(ctx)
|
|
commentsCache.Flush(ctx)
|
|
usersCache.Flush(ctx)
|
|
postFeedCache.Flush(ctx)
|
|
newCommentCache.Flush(ctx)
|
|
headerImagesCache.Flush(ctx)
|
|
}
|
|
|
|
func Archives(ctx context.Context) (r []models.PostArchive) {
|
|
return archivesCaches.getArchiveCache(ctx)
|
|
}
|
|
|
|
type Arch struct {
|
|
data []models.PostArchive
|
|
mutex *sync.Mutex
|
|
fn func(context.Context) ([]models.PostArchive, error)
|
|
month time.Month
|
|
}
|
|
|
|
func (a *Arch) getArchiveCache(ctx context.Context) []models.PostArchive {
|
|
l := len(a.data)
|
|
m := time.Now().Month()
|
|
if l > 0 && a.month != m || l < 1 {
|
|
r, err := a.fn(ctx)
|
|
if err != nil {
|
|
logs.ErrPrintln(err, "set cache err[%s]")
|
|
return nil
|
|
}
|
|
a.mutex.Lock()
|
|
defer a.mutex.Unlock()
|
|
a.month = m
|
|
a.data = r
|
|
}
|
|
return a.data
|
|
}
|
|
|
|
func CategoriesTags(ctx context.Context, t ...int) []models.TermsMy {
|
|
r, err := categoryAndTagsCaches.GetCache(ctx, time.Second, ctx)
|
|
logs.ErrPrintln(err, "get category err")
|
|
if len(t) > 0 {
|
|
return slice.Filter(r, func(my models.TermsMy) bool {
|
|
return helper.Or(t[0] == plugins.Tag, "post_tag", "category") == my.Taxonomy
|
|
})
|
|
}
|
|
return r
|
|
}
|
|
func AllCategoryTagsNames(ctx context.Context, c int) map[string]struct{} {
|
|
r, err := categoryAndTagsCaches.GetCache(ctx, time.Second, ctx)
|
|
logs.ErrPrintln(err, "get category err")
|
|
return slice.FilterAndToMap(r, func(t models.TermsMy) (string, struct{}, bool) {
|
|
if helper.Or(c == plugins.Tag, "post_tag", "category") == t.Taxonomy {
|
|
return t.Name, struct{}{}, true
|
|
}
|
|
return "", struct{}{}, false
|
|
})
|
|
}
|