57 lines
1.5 KiB
Go
Raw Normal View History

2025-02-17 17:21:15 +08:00
package services
import (
2025-02-17 17:58:26 +08:00
"fmt"
2025-02-17 17:21:15 +08:00
"git.solsynth.dev/hypernet/interactive/pkg/internal/database"
"git.solsynth.dev/hypernet/interactive/pkg/internal/models"
2025-02-17 17:58:26 +08:00
"github.com/samber/lo"
2025-02-17 17:21:15 +08:00
"gorm.io/gorm"
2025-02-17 17:58:26 +08:00
"gorm.io/gorm/clause"
2025-02-17 17:21:15 +08:00
)
var postViewQueue []models.PostView
func AddPostView(post models.Post, account uint) {
postViewQueue = append(postViewQueue, models.PostView{
AccountID: account,
PostID: post.ID,
})
}
func AddPostViews(posts []models.Post, account uint) {
for _, post := range posts {
postViewQueue = append(postViewQueue, models.PostView{
AccountID: account,
PostID: post.ID,
})
}
}
func FlushPostViews() {
if len(postViewQueue) == 0 {
return
}
workingQueue := make([]models.PostView, len(postViewQueue))
copy(workingQueue, postViewQueue)
clear(postViewQueue)
updateRequiredPost := make(map[uint]bool)
for _, item := range workingQueue {
updateRequiredPost[item.PostID] = true
}
2025-02-17 17:58:26 +08:00
workingQueue = lo.UniqBy(workingQueue, func(item models.PostView) string {
return fmt.Sprintf("%d:%d", item.PostID, item.AccountID)
})
_ = database.C.Clauses(clause.OnConflict{DoNothing: true}).CreateInBatches(workingQueue, 1000).Error
2025-02-17 17:21:15 +08:00
for k := range updateRequiredPost {
var count int64
if err := database.C.Model(&models.PostView{}).Where("post_id = ?", k).Count(&count).Error; err != nil {
continue
}
database.C.Model(&models.Post{}).Where("id = ?", k).Updates(map[string]any{
"total_views": count,
"total_aggressive_views": gorm.Expr("total_aggressive_views + ?", count),
})
}
}