您最多能選擇 25 個主題
主題必須以字母或數字為開頭,可包含連接號「-」且最長為 35 個字元。
199 行
4.3 KiB
199 行
4.3 KiB
package service
|
|
|
|
import (
|
|
"github.com/astaxie/beego/orm"
|
|
"beeblog/models"
|
|
"beeblog/utils"
|
|
)
|
|
|
|
func count(num int, size int, cat int64) (*utils.Page, error) {
|
|
o := orm.NewOrm()
|
|
qs := o.QueryTable(&models.Blog{})
|
|
qs.Filter("Delflag", 0)
|
|
if cat != -1 {
|
|
qs = qs.Filter("CategoryId", cat)
|
|
}
|
|
totalCount, err := qs.Count()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return utils.PageUtil(totalCount, num, size), nil
|
|
}
|
|
|
|
func countByUser(num int, size int, uid int64) (*utils.Page, error) {
|
|
o := orm.NewOrm()
|
|
qs := o.QueryTable(&models.Blog{})
|
|
totalCount, err := qs.Filter("Delflag", 0).Filter("UserId", uid).Count()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return utils.PageUtil(totalCount, num, size), nil
|
|
}
|
|
|
|
func EditBlogBrows(id int64) {
|
|
o := orm.NewOrm()
|
|
blog := &models.Blog{Id: id}
|
|
err := o.Read(blog)
|
|
if err == nil {
|
|
blog.Browses += 1
|
|
o.Update(blog, "Browses")
|
|
}
|
|
}
|
|
|
|
func TopBlogByUser(uid int64) ([]*models.Blog, error) {
|
|
o := orm.NewOrm()
|
|
var blogs []*models.Blog
|
|
o.QueryTable(models.Blog{}).Filter("UserId", uid).Limit(12, 0).OrderBy("-Browses").All(&blogs)
|
|
return blogs, nil
|
|
}
|
|
|
|
func GetBlog(id int64) (*models.Blog, error) {
|
|
o := orm.NewOrm()
|
|
blog := &models.Blog{Id: id}
|
|
err := o.Read(blog)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
user := &models.User{Id: blog.UserId}
|
|
err = o.Read(user)
|
|
if err == nil {
|
|
blog.User = user
|
|
}
|
|
var labels []*models.NLabel
|
|
qs := o.QueryTable(&models.NLabel{})
|
|
_, err = qs.Filter("BlogId", id).All(&labels)
|
|
if err == nil {
|
|
blog.Lables = labels
|
|
}
|
|
return blog, nil
|
|
}
|
|
|
|
func DelBlog(blog *models.Blog) error {
|
|
o := orm.NewOrm()
|
|
_, err := o.Update(blog, "Delflag")
|
|
return err
|
|
}
|
|
|
|
func FindBlogs(num int, size int, cat int64, flag int) (*utils.Page, error) {
|
|
page, err := count(num, size, cat)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var blogs []*models.Blog
|
|
o := orm.NewOrm()
|
|
qs := o.QueryTable(&models.Blog{})
|
|
qs = qs.Filter("Delflag", 0)
|
|
if cat != -1 {
|
|
qs = qs.Filter("CategoryId", cat)
|
|
}
|
|
if flag == 0 {
|
|
qs = qs.OrderBy("-Ctime")
|
|
} else {
|
|
qs = qs.OrderBy("-Browses")
|
|
}
|
|
|
|
qs = qs.Limit(size, (page.PageNo-1)*size)
|
|
_, err = qs.All(&blogs)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if len(blogs) > 0 {
|
|
for i := 0; i < len(blogs); i++ {
|
|
user := &models.User{Id: blogs[i].UserId}
|
|
err = o.Read(user)
|
|
if err == nil {
|
|
blogs[i].UserName = user.UserName
|
|
blogs[i].HeadImg = user.Headimg
|
|
}
|
|
category := &models.Category{Id: blogs[i].CategoryId}
|
|
err = o.Read(category)
|
|
if err == nil {
|
|
blogs[i].CateName = category.Title
|
|
}
|
|
}
|
|
}
|
|
page.List = blogs
|
|
return page, nil
|
|
}
|
|
|
|
func SaveBlog(blog *models.Blog, strs []string) error {
|
|
o := orm.NewOrm()
|
|
o.Begin()
|
|
id, eror := o.Insert(blog)
|
|
if eror != nil {
|
|
o.Rollback()
|
|
return eror
|
|
} else {
|
|
blog.Id = id
|
|
if strs != nil && len(strs) > 0 {
|
|
nlabels := make([]*models.NLabel, len(strs))
|
|
for i := 0; i < len(strs); i++ {
|
|
nlabels[i] = &models.NLabel{Title: strs[i], BlogId: id, UserId: blog.UserId}
|
|
}
|
|
if _, err := o.InsertMulti(len(nlabels), nlabels); err != nil {
|
|
o.Rollback()
|
|
return err
|
|
}
|
|
}
|
|
o.Commit()
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func EditBlog(blog *models.Blog, strs []string) error {
|
|
o := orm.NewOrm()
|
|
o.Begin()
|
|
id, eror := o.Update(blog)
|
|
if eror != nil {
|
|
o.Rollback()
|
|
return eror
|
|
} else {
|
|
o.QueryTable(models.NLabel{}).Filter("BlogId",blog.Id).Delete()
|
|
if strs != nil && len(strs) > 0 {
|
|
nlabels := make([]*models.NLabel, len(strs))
|
|
for i := 0; i < len(strs); i++ {
|
|
nlabels[i] = &models.NLabel{Title: strs[i], BlogId: id, UserId: blog.UserId}
|
|
}
|
|
if _, err := o.InsertMulti(len(nlabels), nlabels); err != nil {
|
|
o.Rollback()
|
|
return err
|
|
}
|
|
}
|
|
o.Commit()
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func MeBlogs(num int, size int, flag int, uid int64) (*utils.Page, error) {
|
|
page, err := countByUser(num, size, uid)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
var blogs []*models.Blog
|
|
o := orm.NewOrm()
|
|
qs := o.QueryTable(&models.Blog{})
|
|
qs = qs.Filter("Delflag", 0)
|
|
qs = qs.Filter("UserId", uid)
|
|
if flag == 0 {
|
|
qs = qs.OrderBy("-Ctime")
|
|
} else {
|
|
qs = qs.OrderBy("-Browses")
|
|
}
|
|
qs = qs.Limit(size, (page.PageNo-1)*size)
|
|
_, err = qs.All(&blogs)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
page.List = blogs
|
|
return page, nil
|
|
}
|
|
|
|
func GetNLabel(id int64) ([]*models.NLabel, error) {
|
|
var labels []*models.NLabel
|
|
o := orm.NewOrm()
|
|
_, err := o.QueryTable(&models.NLabel{}).Filter("BlogId", id).All(&labels)
|
|
if err != nil {
|
|
return labels, err
|
|
}
|
|
return labels, nil
|
|
}
|
|
|