Files
novel_server/internal/logic/bookshelve/bookshelve.go
2025-07-16 15:16:40 +08:00

58 lines
1.5 KiB
Go

package bookshelve
import (
"context"
"server/internal/dao"
"server/internal/model"
"server/internal/model/do"
"server/internal/service"
"server/utility/ecode"
)
type sBookshelve struct{}
func New() service.IBookshelve {
return &sBookshelve{}
}
func init() {
service.RegisterBookshelve(New())
}
// Add 添加书架
func (s *sBookshelve) Add(ctx context.Context, in *model.BookshelveAddIn) (out *model.BookshelveCRUDOut, err error) {
exist, err := dao.Bookshelves.Ctx(ctx).
Where(dao.Bookshelves.Columns().UserId, in.UserId).
Where(dao.Bookshelves.Columns().BookId, in.BookId).
Exist()
if err != nil {
return nil, ecode.Fail.Sub("bookshelve_query_failed")
}
if exist {
return nil, ecode.Params.Sub("bookshelve_exists")
}
if _, err := dao.Bookshelves.Ctx(ctx).Data(do.Bookshelves{
UserId: in.UserId,
BookId: in.BookId,
ReadStatus: 1, // 默认为正在读
}).Insert(); err != nil {
return nil, ecode.Fail.Sub("bookshelve_create_failed")
}
return &model.BookshelveCRUDOut{Success: true}, nil
}
// Delete 批量删除书架
func (s *sBookshelve) Delete(ctx context.Context, in *model.BookshelveDelIn) (out *model.BookshelveCRUDOut, err error) {
if len(in.BookIds) == 0 {
return nil, ecode.Params.Sub("bookshelve_bookids_empty")
}
_, err = dao.Bookshelves.Ctx(ctx).
Where(dao.Bookshelves.Columns().UserId, in.UserId).
WhereIn(dao.Bookshelves.Columns().BookId, in.BookIds).
Delete()
if err != nil {
return nil, ecode.Fail.Sub("bookshelve_delete_failed")
}
return &model.BookshelveCRUDOut{Success: true}, nil
}