Files

120 lines
3.3 KiB
Go
Raw Normal View History

2021-10-09 11:55:54 +08:00
package technology
import (
2021-10-15 15:06:02 +08:00
"SciencesServer/app/api/enterprise/model"
2022-01-05 11:29:27 +08:00
"SciencesServer/app/basic/controller"
2021-10-09 11:55:54 +08:00
model2 "SciencesServer/app/common/model"
2021-11-24 10:50:09 +08:00
"SciencesServer/app/session"
2021-10-09 11:55:54 +08:00
"SciencesServer/utils"
"errors"
"time"
)
// Paper 论文管理
2021-10-12 17:27:41 +08:00
type Paper struct {
2021-11-24 10:50:09 +08:00
*session.Enterprise
2022-01-15 16:48:49 +08:00
tenantID uint64
2021-10-12 17:27:41 +08:00
}
2021-10-09 11:55:54 +08:00
2022-01-15 16:48:49 +08:00
type PaperHandle func(session *session.Enterprise, tenantID uint64) *Paper
2021-10-09 11:55:54 +08:00
type (
PaperInfo struct {
ID string `json:"id"`
*model2.TechnologyPaper
2022-03-05 15:31:22 +08:00
Keywords []string `json:"keywords"`
Tags []string `json:"tags"`
2021-10-09 11:55:54 +08:00
}
PaperParams struct {
2021-12-24 15:28:46 +08:00
ID uint64
Title, Ext, Author, PublishAt, Remark string
Keywords, Tags []string
2021-10-09 11:55:54 +08:00
}
)
// List 列表信息
func (c *Paper) List(title string, page, pageSize int) (*controller.ReturnPages, error) {
mTechnologyPaper := model.NewTechnologyPaper()
where := []*model2.ModelWhereOrder{&model2.ModelWhereOrder{
Order: model2.NewOrder("id", model2.OrderModeToDesc),
2021-10-12 17:27:41 +08:00
}, &model2.ModelWhereOrder{
2022-01-15 16:48:49 +08:00
Where: model2.NewWhere("tenant_id", c.tenantID),
2021-10-09 11:55:54 +08:00
}}
if title != "" {
where = append(where, &model2.ModelWhereOrder{Where: model2.NewWhereLike("title", title)})
}
out := make([]*model2.TechnologyPaper, 0)
var count int64
if err := model2.Pages(mTechnologyPaper.TechnologyPaper, &out, page, pageSize, &count, where...); err != nil {
return nil, err
}
list := make([]*PaperInfo, 0)
for _, v := range out {
2022-03-05 15:31:22 +08:00
list = append(list, &PaperInfo{ID: v.GetEncodeID(), TechnologyPaper: v, Keywords: v.GetKeywordAttribute(),
Tags: v.GetTagAttribute()})
2021-10-09 11:55:54 +08:00
}
return &controller.ReturnPages{Data: list, Count: count}, nil
}
// Form 参数信息
func (c *Paper) Form(params *PaperParams) error {
mTechnologyPaper := model.NewTechnologyPaper()
if params.ID > 0 {
mTechnologyPaper.ID = params.ID
if isExist, err := model2.First(mTechnologyPaper.TechnologyPaper); err != nil {
return err
} else if !isExist {
return errors.New("当前论文信息不存在")
2021-11-30 16:09:04 +08:00
} else if mTechnologyPaper.UID != c.UID {
2021-10-09 11:55:54 +08:00
return errors.New("无权限操作")
}
}
mTechnologyPaper.Title = params.Title
mTechnologyPaper.Ext = params.Ext
mTechnologyPaper.Author = params.Author
mTechnologyPaper.PublishAt = utils.DateTimeToTime(params.PublishAt)
2021-12-24 15:28:46 +08:00
mTechnologyPaper.SetKeywordAttribute(params.Keywords)
2021-10-09 11:55:54 +08:00
mTechnologyPaper.SetTagAttribute(params.Tags)
mTechnologyPaper.Remark = params.Remark
if params.ID <= 0 {
2021-11-30 16:09:04 +08:00
mTechnologyPaper.UID = c.UID
2022-01-15 16:48:49 +08:00
mTechnologyPaper.TenantID = c.tenantID
2021-10-09 11:55:54 +08:00
return model2.Create(mTechnologyPaper.TechnologyPaper)
}
mTechnologyPaper.UpdatedAt = time.Now()
return model2.Updates(mTechnologyPaper.TechnologyPaper, mTechnologyPaper.TechnologyPaper)
}
// Delete 删除操作
func (c *Paper) Delete(id uint64) error {
mTechnologyPaper := model.NewTechnologyPaper()
mTechnologyPaper.ID = id
var count int64
2021-12-07 16:10:12 +08:00
err := model2.Count(mTechnologyPaper.TechnologyPaper, &count, model2.NewWhere("id", id), model2.NewWhere("uid", c.UID))
2021-10-09 11:55:54 +08:00
if err != nil {
return err
} else if count <= 0 {
2021-11-30 16:09:04 +08:00
return errors.New("操作错误,当前论文信息不存在或已被删除")
2021-10-09 11:55:54 +08:00
}
if err = model2.Delete(mTechnologyPaper.TechnologyPaper); err != nil {
return err
}
return nil
}
func NewPaper() PaperHandle {
2022-01-15 16:48:49 +08:00
return func(session *session.Enterprise, tenantID uint64) *Paper {
return &Paper{Enterprise: session, tenantID: tenantID}
2021-10-09 11:55:54 +08:00
}
}