Some checks failed
CI / init (pull_request) Has been cancelled
CI / Frontend node 18.16.0 (pull_request) Has been cancelled
CI / Backend go (1.22) (pull_request) Has been cancelled
CI / release-pr (pull_request) Has been cancelled
CI / devops-test (1.22, 18.16.0) (pull_request) Has been cancelled
CI / release-please (pull_request) Has been cancelled
CI / devops-prod (1.22, 18.x) (pull_request) Has been cancelled
CI / docker (pull_request) Has been cancelled
60 lines
1.8 KiB
Go
60 lines
1.8 KiB
Go
package book
|
|
|
|
import (
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/book"
|
|
bookReq "github.com/flipped-aurora/gin-vue-admin/server/model/book/request"
|
|
commonReq "github.com/flipped-aurora/gin-vue-admin/server/model/common/request"
|
|
)
|
|
|
|
type BookCommentService struct{}
|
|
|
|
func (s *BookCommentService) CreateBookComment(item book.BookComment) error {
|
|
if err := validateBookComment(item); err != nil {
|
|
return err
|
|
}
|
|
return global.GVA_DB.Create(&item).Error
|
|
}
|
|
|
|
func (s *BookCommentService) DeleteBookComment(item book.BookComment) error {
|
|
return global.GVA_DB.Delete(&item).Error
|
|
}
|
|
|
|
func (s *BookCommentService) DeleteBookCommentByIds(ids commonReq.IdsReq) error {
|
|
return deleteByIDs[book.BookComment](ids.Ids)
|
|
}
|
|
|
|
func (s *BookCommentService) UpdateBookComment(item book.BookComment) error {
|
|
if err := validateBookComment(item); err != nil {
|
|
return err
|
|
}
|
|
return global.GVA_DB.Save(&item).Error
|
|
}
|
|
|
|
func (s *BookCommentService) GetBookComment(id uint) (item book.BookComment, err error) {
|
|
err = global.GVA_DB.Where("id = ?", id).First(&item).Error
|
|
return
|
|
}
|
|
|
|
func (s *BookCommentService) GetBookCommentInfoList(info bookReq.BookCommentSearch) (list []book.BookComment, total int64, err error) {
|
|
db := global.GVA_DB.Model(&book.BookComment{})
|
|
if info.MemberUserID != nil {
|
|
db = db.Where("member_user_id = ?", *info.MemberUserID)
|
|
}
|
|
if info.BookID != nil {
|
|
db = db.Where("book_id = ?", *info.BookID)
|
|
}
|
|
if info.ChapterID != nil {
|
|
db = db.Where("chapter_id = ?", *info.ChapterID)
|
|
}
|
|
if info.CommentStatus != "" {
|
|
db = db.Where("comment_status = ?", info.CommentStatus)
|
|
}
|
|
err = db.Count(&total).Error
|
|
if err != nil {
|
|
return
|
|
}
|
|
err = db.Scopes(paginate(info.PageInfo)).Order("id desc").Find(&list).Error
|
|
return
|
|
}
|