码农笔录博客源码
Não pode escolher mais do que 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

72 linhas
1.8 KiB

há 6 anos
package service
import (
"beeblog/models"
"github.com/astaxie/beego/orm"
"fmt"
há 6 anos
"beeblog/utils"
há 6 anos
)
há 6 anos
type LikeService struct {
}
func (this *LikeService) SaveLike(like *models.Like) (int64, error) {
há 6 anos
return orm.NewOrm().Insert(like)
}
há 6 anos
func (this *LikeService) DelLike(like *models.Like) (int64, error) {
há 6 anos
return orm.NewOrm().QueryTable(models.Like{}).Filter("BlogId", like.BlogId).Filter("UserId", like.UserId).Delete()
há 6 anos
}
há 6 anos
func (this *LikeService) IsLike(bid int64, uid int64) (bool, error) {
há 6 anos
totalCount, err := orm.NewOrm().QueryTable(&models.Like{}).Filter("BlogId", bid).Filter("UserId", uid).Count()
if err == nil {
há 6 anos
fmt.Println(totalCount, "like count")
há 6 anos
if totalCount > 0 {
return true, nil
} else {
return false, nil
}
há 6 anos
} else {
há 6 anos
fmt.Println(err)
há 6 anos
return false, err
há 6 anos
}
}
há 6 anos
há 6 anos
func (this *LikeService) MeLikes(num int, size int, uid int64) (*utils.Page, error) {
page, err := this.countLike(num, size, uid)
há 6 anos
if err != nil {
return nil, err
}
var likes []*models.Like
o := orm.NewOrm()
qs := o.QueryTable(&models.Like{})
qs = qs.Filter("UserId", uid)
qs = qs.Limit(size, (page.PageNo-1)*size)
if _, err = qs.All(&likes); err != nil {
return nil, err
}
if len(likes) > 0 {
for i := 0; i < len(likes); i++ {
blog := &models.Blog{Id: likes[i].BlogId}
if err := o.Read(blog); err == nil {
likes[i].Blog = blog
}
}
}
page.List = likes
return page, nil
}
há 6 anos
func (this *LikeService) countLike(num int, size int, uid int64) (*utils.Page, error) {
há 6 anos
o := orm.NewOrm()
qs := o.QueryTable(&models.Like{})
totalCount, err := qs.Filter("UserId", uid).Count()
if err != nil {
return nil, err
}
return utils.PageUtil(totalCount, num, size), nil
}
func (likeService LikeService) DelLikeByBlog(id int64) {
orm.NewOrm().QueryTable(models.Like{}).Filter("BlogId", id).Delete()
}