mirror of https://github.com/rocboss/paopao-ce
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
362 lines
9.0 KiB
362 lines
9.0 KiB
3 years ago
|
package jinzhu
|
||
|
|
||
|
import (
|
||
|
"strings"
|
||
|
"time"
|
||
|
|
||
|
"github.com/rocboss/paopao-ce/internal/core"
|
||
|
"github.com/rocboss/paopao-ce/internal/model"
|
||
|
"gorm.io/gorm"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
_ core.TweetService = (*tweetServant)(nil)
|
||
|
_ core.TweetManageService = (*tweetManageServant)(nil)
|
||
|
_ core.TweetHelpService = (*tweetHelpServant)(nil)
|
||
|
)
|
||
|
|
||
|
type tweetServant struct {
|
||
|
db *gorm.DB
|
||
|
}
|
||
|
|
||
|
type tweetManageServant struct {
|
||
|
cacheIndex core.CacheIndexService
|
||
|
db *gorm.DB
|
||
|
}
|
||
|
|
||
|
type tweetHelpServant struct {
|
||
|
db *gorm.DB
|
||
|
}
|
||
|
|
||
|
func newTweetService(db *gorm.DB) core.TweetService {
|
||
|
return &tweetServant{
|
||
|
db: db,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func newTweetManageService(db *gorm.DB, cacheIndex core.CacheIndexService) core.TweetManageService {
|
||
|
return &tweetManageServant{
|
||
|
cacheIndex: cacheIndex,
|
||
|
db: db,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func newTweetHelpService(db *gorm.DB) core.TweetHelpService {
|
||
|
return &tweetHelpServant{
|
||
|
db: db,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// MergePosts post数据整合
|
||
|
func (s *tweetHelpServant) MergePosts(posts []*model.Post) ([]*model.PostFormated, error) {
|
||
|
postIds := make([]int64, 0, len(posts))
|
||
|
userIds := make([]int64, 0, len(posts))
|
||
|
for _, post := range posts {
|
||
|
postIds = append(postIds, post.ID)
|
||
|
userIds = append(userIds, post.UserID)
|
||
|
}
|
||
|
|
||
|
postContents, err := s.getPostContentsByIDs(postIds)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
users, err := s.getUsersByIDs(userIds)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
userMap := make(map[int64]*model.UserFormated, len(users))
|
||
|
for _, user := range users {
|
||
|
userMap[user.ID] = user.Format()
|
||
|
}
|
||
|
|
||
|
contentMap := make(map[int64][]*model.PostContentFormated, len(postContents))
|
||
|
for _, content := range postContents {
|
||
|
contentMap[content.PostID] = append(contentMap[content.PostID], content.Format())
|
||
|
}
|
||
|
|
||
|
// 数据整合
|
||
|
postsFormated := make([]*model.PostFormated, 0, len(posts))
|
||
|
for _, post := range posts {
|
||
|
postFormated := post.Format()
|
||
|
postFormated.User = userMap[post.UserID]
|
||
|
postFormated.Contents = contentMap[post.ID]
|
||
|
postsFormated = append(postsFormated, postFormated)
|
||
|
}
|
||
|
return postsFormated, nil
|
||
|
}
|
||
|
|
||
|
// RevampPosts post数据整形修复
|
||
|
func (s *tweetHelpServant) RevampPosts(posts []*model.PostFormated) ([]*model.PostFormated, error) {
|
||
|
postIds := make([]int64, 0, len(posts))
|
||
|
userIds := make([]int64, 0, len(posts))
|
||
|
for _, post := range posts {
|
||
|
postIds = append(postIds, post.ID)
|
||
|
userIds = append(userIds, post.UserID)
|
||
|
}
|
||
|
|
||
|
postContents, err := s.getPostContentsByIDs(postIds)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
users, err := s.getUsersByIDs(userIds)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
userMap := make(map[int64]*model.UserFormated, len(users))
|
||
|
for _, user := range users {
|
||
|
userMap[user.ID] = user.Format()
|
||
|
}
|
||
|
|
||
|
contentMap := make(map[int64][]*model.PostContentFormated, len(postContents))
|
||
|
for _, content := range postContents {
|
||
|
contentMap[content.PostID] = append(contentMap[content.PostID], content.Format())
|
||
|
}
|
||
|
|
||
|
// 数据整合
|
||
|
for _, post := range posts {
|
||
|
post.User = userMap[post.UserID]
|
||
|
post.Contents = contentMap[post.ID]
|
||
|
}
|
||
|
return posts, nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetHelpServant) getPostContentsByIDs(ids []int64) ([]*model.PostContent, error) {
|
||
|
return (&model.PostContent{}).List(s.db, &model.ConditionsT{
|
||
|
"post_id IN ?": ids,
|
||
|
"ORDER": "sort ASC",
|
||
|
}, 0, 0)
|
||
|
}
|
||
|
|
||
|
func (s *tweetHelpServant) getUsersByIDs(ids []int64) ([]*model.User, error) {
|
||
|
user := &model.User{}
|
||
|
|
||
|
return user.List(s.db, &model.ConditionsT{
|
||
|
"id IN ?": ids,
|
||
|
}, 0, 0)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) CreatePostCollection(postID, userID int64) (*model.PostCollection, error) {
|
||
|
collection := &model.PostCollection{
|
||
|
PostID: postID,
|
||
|
UserID: userID,
|
||
|
}
|
||
|
|
||
|
return collection.Create(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) DeletePostCollection(p *model.PostCollection) error {
|
||
|
return p.Delete(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) CreatePostContent(content *model.PostContent) (*model.PostContent, error) {
|
||
|
return content.Create(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) CreateAttachment(attachment *model.Attachment) (*model.Attachment, error) {
|
||
|
return attachment.Create(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) CreatePost(post *model.Post) (*model.Post, error) {
|
||
|
post.LatestRepliedOn = time.Now().Unix()
|
||
|
p, err := post.Create(s.db)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
s.cacheIndex.SendAction(core.IdxActCreatePost)
|
||
|
return p, nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) DeletePost(post *model.Post) error {
|
||
|
if err := post.Delete(s.db); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
s.cacheIndex.SendAction(core.IdxActDeletePost)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) LockPost(post *model.Post) error {
|
||
|
post.IsLock = 1 - post.IsLock
|
||
|
return post.Update(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) StickPost(post *model.Post) error {
|
||
|
post.IsTop = 1 - post.IsTop
|
||
|
if err := post.Update(s.db); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
s.cacheIndex.SendAction(core.IdxActStickPost)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) VisiblePost(post *model.Post, visibility model.PostVisibleT) error {
|
||
|
oldVisibility := post.Visibility
|
||
|
post.Visibility = visibility
|
||
|
// TODO: 这个判断是否可以不要呢
|
||
|
if oldVisibility == visibility {
|
||
|
return nil
|
||
|
}
|
||
|
// 私密推文 特殊处理
|
||
|
if visibility == model.PostVisitPrivate {
|
||
|
// 强制取消置顶
|
||
|
// TODO: 置顶推文用户是否有权设置成私密? 后续完善
|
||
|
post.IsTop = 0
|
||
|
}
|
||
|
db := s.db.Begin()
|
||
|
err := post.Update(db)
|
||
|
if err != nil {
|
||
|
db.Rollback()
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// tag处理
|
||
|
tags := strings.Split(post.Tags, ",")
|
||
|
for _, t := range tags {
|
||
|
tag := &model.Tag{
|
||
|
Tag: t,
|
||
|
}
|
||
|
// TODO: 暂时宽松不处理错误,这里或许可以有优化,后续完善
|
||
|
if oldVisibility == model.PostVisitPrivate {
|
||
|
// 从私密转为非私密才需要重新创建tag
|
||
|
createTag(db, tag)
|
||
|
} else if visibility == model.PostVisitPrivate {
|
||
|
// 从非私密转为私密才需要删除tag
|
||
|
deleteTag(db, tag)
|
||
|
}
|
||
|
}
|
||
|
db.Commit()
|
||
|
s.cacheIndex.SendAction(core.IdxActVisiblePost)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) UpdatePost(post *model.Post) error {
|
||
|
if err := post.Update(s.db); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
s.cacheIndex.SendAction(core.IdxActUpdatePost)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) CreatePostStar(postID, userID int64) (*model.PostStar, error) {
|
||
|
star := &model.PostStar{
|
||
|
PostID: postID,
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return star.Create(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetManageServant) DeletePostStar(p *model.PostStar) error {
|
||
|
return p.Delete(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPostByID(id int64) (*model.Post, error) {
|
||
|
post := &model.Post{
|
||
|
Model: &model.Model{
|
||
|
ID: id,
|
||
|
},
|
||
|
}
|
||
|
return post.Get(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPosts(conditions *model.ConditionsT, offset, limit int) ([]*model.Post, error) {
|
||
|
return (&model.Post{}).List(s.db, conditions, offset, limit)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPostCount(conditions *model.ConditionsT) (int64, error) {
|
||
|
return (&model.Post{}).Count(s.db, conditions)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostStar(postID, userID int64) (*model.PostStar, error) {
|
||
|
star := &model.PostStar{
|
||
|
PostID: postID,
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return star.Get(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostStars(userID int64, offset, limit int) ([]*model.PostStar, error) {
|
||
|
star := &model.PostStar{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
|
||
|
return star.List(s.db, &model.ConditionsT{
|
||
|
"ORDER": s.db.NamingStrategy.TableName("PostStar") + ".id DESC",
|
||
|
}, offset, limit)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostStarCount(userID int64) (int64, error) {
|
||
|
star := &model.PostStar{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return star.Count(s.db, &model.ConditionsT{})
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostCollection(postID, userID int64) (*model.PostCollection, error) {
|
||
|
star := &model.PostCollection{
|
||
|
PostID: postID,
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return star.Get(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostCollections(userID int64, offset, limit int) ([]*model.PostCollection, error) {
|
||
|
collection := &model.PostCollection{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
|
||
|
return collection.List(s.db, &model.ConditionsT{
|
||
|
"ORDER": s.db.NamingStrategy.TableName("PostCollection") + ".id DESC",
|
||
|
}, offset, limit)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserPostCollectionCount(userID int64) (int64, error) {
|
||
|
collection := &model.PostCollection{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return collection.Count(s.db, &model.ConditionsT{})
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserWalletBills(userID int64, offset, limit int) ([]*model.WalletStatement, error) {
|
||
|
statement := &model.WalletStatement{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
|
||
|
return statement.List(s.db, &model.ConditionsT{
|
||
|
"ORDER": "id DESC",
|
||
|
}, offset, limit)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetUserWalletBillCount(userID int64) (int64, error) {
|
||
|
statement := &model.WalletStatement{
|
||
|
UserID: userID,
|
||
|
}
|
||
|
return statement.Count(s.db, &model.ConditionsT{})
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPostAttatchmentBill(postID, userID int64) (*model.PostAttachmentBill, error) {
|
||
|
bill := &model.PostAttachmentBill{
|
||
|
PostID: postID,
|
||
|
UserID: userID,
|
||
|
}
|
||
|
|
||
|
return bill.Get(s.db)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPostContentsByIDs(ids []int64) ([]*model.PostContent, error) {
|
||
|
return (&model.PostContent{}).List(s.db, &model.ConditionsT{
|
||
|
"post_id IN ?": ids,
|
||
|
"ORDER": "sort ASC",
|
||
|
}, 0, 0)
|
||
|
}
|
||
|
|
||
|
func (s *tweetServant) GetPostContentByID(id int64) (*model.PostContent, error) {
|
||
|
return (&model.PostContent{
|
||
|
Model: &model.Model{
|
||
|
ID: id,
|
||
|
},
|
||
|
}).Get(s.db)
|
||
|
}
|