码农笔录博客源码
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

109 строки
2.0 KiB

6 лет назад
package service
import (
"beeblog/models"
"github.com/astaxie/beego/orm"
"errors"
"fmt"
6 лет назад
)
type NoteService struct {
}
6 лет назад
func EditNote(note *models.Note) error {
o := orm.NewOrm()
id, err := o.Update(note)
if err == nil {
note.Id = id
}
return err
}
6 лет назад
func SaveNote(note *models.Note) error {
o := orm.NewOrm()
id, err := o.Insert(note)
if err == nil {
note.Id = id
}
return err
}
func GetNote(note *models.Note) error {
o := orm.NewOrm()
return o.Read(note)
}
6 лет назад
func DelNote(note *models.Note) error {
o := orm.NewOrm()
6 лет назад
_, err := o.Delete(note)
6 лет назад
return err
}
6 лет назад
func GetNoteByPid(pid int64) ([]*models.Note, error) {
var notes []*models.Note
o := orm.NewOrm()
qs := o.QueryTable(models.Note{})
6 лет назад
_, err := qs.Filter("Pid", pid).All(&notes)
6 лет назад
return notes, err
6 лет назад
}
6 лет назад
func CountNote(pid int64) (int64, error) {
o := orm.NewOrm()
totalCount, err := o.QueryTable(&models.Note{}).Filter("Pid", pid).Count()
if err != nil {
return 0, err
6 лет назад
}
return totalCount, nil
}
6 лет назад
func SaveNoteColl(note *models.NoteColl) error {
o := orm.NewOrm()
id, err := o.Insert(note)
if err == nil {
note.Id = id
}
return err
}
func EditNoteColl(title string, id int64, uid int64) error {
o := orm.NewOrm()
noteColl := &models.NoteColl{Id: id}
if err := o.Read(noteColl); err != nil {
return err
}
if noteColl.UserId != uid {
return errors.New("403")
}
noteColl.Title = title
_, err := o.Update(noteColl, "Title")
return err
}
6 лет назад
func GetNoteColl(uid int64) ([]*models.NoteColl, error) {
var notes []*models.NoteColl
o := orm.NewOrm()
qs := o.QueryTable(models.NoteColl{})
6 лет назад
_, err := qs.Filter("UserId", uid).All(&notes)
6 лет назад
return notes, err
}
func DelNoteColl(id int64, uid int64) error {
o := orm.NewOrm()
noteColl := &models.NoteColl{Id: id}
if err := o.Read(noteColl); err != nil {
fmt.Println(err)
return err
}
if uid != noteColl.UserId {
return errors.New("403")
}
_, err := o.QueryTable(models.Note{}).Filter("Pid", id).Delete()
fmt.Println(err)
if err == nil {
_, err = o.Delete(noteColl)
}
return err
}