码农笔录博客源码
Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.

72 righe
1.8 KiB

6 anni fa
package service
import (
"beeblog/models"
"github.com/astaxie/beego/orm"
"fmt"
6 anni fa
"beeblog/utils"
6 anni fa
)
6 anni fa
type LikeService struct {
}
func (this *LikeService) SaveLike(like *models.Like) (int64, error) {
6 anni fa
return orm.NewOrm().Insert(like)
}
6 anni fa
func (this *LikeService) DelLike(like *models.Like) (int64, error) {
6 anni fa
return orm.NewOrm().QueryTable(models.Like{}).Filter("BlogId", like.BlogId).Filter("UserId", like.UserId).Delete()
6 anni fa
}
6 anni fa
func (this *LikeService) IsLike(bid int64, uid int64) (bool, error) {
6 anni fa
totalCount, err := orm.NewOrm().QueryTable(&models.Like{}).Filter("BlogId", bid).Filter("UserId", uid).Count()
if err == nil {
6 anni fa
fmt.Println(totalCount, "like count")
6 anni fa
if totalCount > 0 {
return true, nil
} else {
return false, nil
}
6 anni fa
} else {
6 anni fa
fmt.Println(err)
6 anni fa
return false, err
6 anni fa
}
}
6 anni fa
6 anni fa
func (this *LikeService) MeLikes(num int, size int, uid int64) (*utils.Page, error) {
page, err := this.countLike(num, size, uid)
6 anni fa
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
}
6 anni fa
func (this *LikeService) countLike(num int, size int, uid int64) (*utils.Page, error) {
6 anni fa
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()
}