基础项目
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

This commit is contained in:
2026-04-26 15:32:21 +08:00
parent cc40d743cb
commit 1e33640629
102 changed files with 4088 additions and 197 deletions

View File

@@ -0,0 +1,53 @@
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 BookReadRecordService struct{}
func (s *BookReadRecordService) CreateBookReadRecord(item book.BookReadRecord) error {
if err := validateBookReadRecord(item); err != nil {
return err
}
return global.GVA_DB.Create(&item).Error
}
func (s *BookReadRecordService) DeleteBookReadRecord(item book.BookReadRecord) error {
return global.GVA_DB.Delete(&item).Error
}
func (s *BookReadRecordService) DeleteBookReadRecordByIds(ids commonReq.IdsReq) error {
return deleteByIDs[book.BookReadRecord](ids.Ids)
}
func (s *BookReadRecordService) UpdateBookReadRecord(item book.BookReadRecord) error {
if err := validateBookReadRecord(item); err != nil {
return err
}
return global.GVA_DB.Save(&item).Error
}
func (s *BookReadRecordService) GetBookReadRecord(id uint) (item book.BookReadRecord, err error) {
err = global.GVA_DB.Where("id = ?", id).First(&item).Error
return
}
func (s *BookReadRecordService) GetBookReadRecordInfoList(info bookReq.BookReadRecordSearch) (list []book.BookReadRecord, total int64, err error) {
db := global.GVA_DB.Model(&book.BookReadRecord{})
if info.MemberUserID != nil {
db = db.Where("member_user_id = ?", *info.MemberUserID)
}
if info.BookID != nil {
db = db.Where("book_id = ?", *info.BookID)
}
err = db.Count(&total).Error
if err != nil {
return
}
err = db.Scopes(paginate(info.PageInfo)).Order("last_read_at desc, id desc").Find(&list).Error
return
}