265 lines
6.6 KiB
Go
265 lines
6.6 KiB
Go
package service
|
||
|
||
import (
|
||
"context"
|
||
"fmt"
|
||
"strings"
|
||
"time"
|
||
|
||
"go-common/app/admin/main/videoup-task/model"
|
||
"go-common/library/database/sql"
|
||
"go-common/library/log"
|
||
"go-common/library/xstr"
|
||
)
|
||
|
||
// ErrTaskMISS .
|
||
var ErrTaskMISS = fmt.Errorf("任务缓存查找失败")
|
||
|
||
// ReviewForm 复审表单
|
||
func (s *Service) ReviewForm(c context.Context, tid int64) (form *model.SubmitForm, err error) {
|
||
return s.dao.ReviewForm(c, tid)
|
||
}
|
||
|
||
// CheckReview 检查任务复审
|
||
func (s *Service) CheckReview(c context.Context, form *model.SubmitForm) (isReview bool, err error) {
|
||
var (
|
||
v *model.Video
|
||
attr int32
|
||
tx *sql.Tx
|
||
rows int64
|
||
tp *model.TaskPriority
|
||
)
|
||
|
||
attr, err = s.dao.VideoAttribute(c, form.CID)
|
||
if err != nil {
|
||
log.Error("CheckReview VideoAttribute(aid%d,cid%d) miss(%v)", form.AID, form.CID, err)
|
||
return false, ErrTaskMISS
|
||
}
|
||
v = &model.Video{Attribute: attr}
|
||
|
||
tp, err = s.getReviewParams(c, form)
|
||
if err != nil || tp == nil {
|
||
log.Info("CheckReview(%d) 不需要复审(%+v)", form.TaskID, tp)
|
||
return false, err
|
||
}
|
||
|
||
s.SyncRC(c)
|
||
ck := s.reviewCache.Check(c, tp, form.UID)
|
||
if !ck {
|
||
log.Info("CheckReview(%d) 不需要复审(%+v)", form.TaskID, tp)
|
||
return false, nil
|
||
}
|
||
|
||
if _, err = s.dao.InReviewForm(c, form, form.UID, form.Uname); err != nil {
|
||
return false, err
|
||
}
|
||
|
||
if tx, err = s.dao.BeginTran(c); err != nil {
|
||
return false, err
|
||
}
|
||
|
||
if rows, err = s.dao.TxUpTaskByID(tx, form.TaskID, map[string]interface{}{"state": model.TypeReview}); err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
if rows > 0 {
|
||
if _, err = s.dao.TxAddTaskHis(tx, 0, model.ActionSubmit, form.TaskID, form.CID, form.UID, 0, form.Status, "TaskReview"); err != nil {
|
||
tx.Rollback()
|
||
return false, err
|
||
}
|
||
}
|
||
if err = tx.Commit(); err != nil {
|
||
log.Error("tx.Commit error(%v)", err)
|
||
return false, err
|
||
}
|
||
|
||
// log
|
||
attrs := map[uint]int32{
|
||
model.AttrBitNoRank: form.Norank,
|
||
model.AttrBitNoDynamic: form.Noindex,
|
||
model.AttrBitNoRecommend: form.NoRecommend,
|
||
model.AttrBitNoSearch: form.Nosearch,
|
||
model.AttrBitOverseaLock: form.OverseaBlock,
|
||
model.AttrBitPushBlog: form.PushBlog,
|
||
}
|
||
|
||
var conts []string
|
||
const template = "[%s]从[%s]设为[%s]"
|
||
var yesOrNo = map[int32]string{model.AttrYes: "是", model.AttrNo: "否"}
|
||
for bit, attr := range attrs {
|
||
v.AttrSet(attr, bit)
|
||
if attr == 1 {
|
||
conts = append(conts, fmt.Sprintf(template, model.BitDesc(bit), yesOrNo[^attr&1], yesOrNo[attr]))
|
||
log.Info("vid(%d) update video bit(%d) bitdesc(%s) attrs(%d)", form.ID, bit, model.BitDesc(bit), attr)
|
||
}
|
||
}
|
||
|
||
vp := &model.VideoParam{
|
||
ID: form.ID,
|
||
Aid: form.AID,
|
||
Mid: form.MID,
|
||
RegionID: tp.TypeID,
|
||
Status: form.Status,
|
||
Cid: form.CID,
|
||
Title: form.Eptitle,
|
||
Desc: form.Description,
|
||
|
||
UID: form.UID,
|
||
TaskID: form.TaskID,
|
||
Oname: form.Uname,
|
||
TagID: form.TID,
|
||
Reason: form.Reason,
|
||
ReasonID: form.ReasonID,
|
||
Note: form.Note,
|
||
Attribute: v.Attribute,
|
||
}
|
||
oper := &model.VideoOper{Aid: form.AID, UID: form.UID, Vid: form.ID, Attribute: vp.Attribute, Status: form.Status, Remark: form.Note}
|
||
operConts := append([]string{fmt.Sprintf("初审提交")}, conts...)
|
||
operConts = append(operConts, s.diffVideoOper(vp)...)
|
||
oper.Content = strings.Join(operConts, ",")
|
||
s.addVideoOper(c, oper)
|
||
|
||
s.sendVideoLog(c, vp, oper.Content)
|
||
|
||
return true, nil
|
||
}
|
||
|
||
// ListReviewConfs 配置列表
|
||
func (s *Service) ListReviewConfs(c context.Context, unames, bt, et, sort string, pn, ps int64) (rcs []*model.ReviewConf, count int64, err error) {
|
||
var uids []int64
|
||
|
||
if len(unames) > 0 {
|
||
res, _ := s.dao.Uids(c, strings.Split(unames, ","))
|
||
for _, uid := range res {
|
||
uids = append(uids, uid)
|
||
}
|
||
}
|
||
|
||
rcs, count, err = s.dao.ListConfs(c, uids, bt, et, sort, pn, ps)
|
||
for _, v := range rcs {
|
||
if v.Bt.TimeValue().IsZero() {
|
||
v.Bt = ""
|
||
}
|
||
if v.Et.TimeValue().IsZero() {
|
||
v.Et = ""
|
||
}
|
||
|
||
if len(v.Uids) > 0 {
|
||
if unames, _ := s.dao.Unames(c, v.Uids); len(unames) > 0 {
|
||
for _, uname := range unames {
|
||
v.Unames = append(v.Unames, uname)
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return
|
||
}
|
||
|
||
// AddReviewConf 添加配置
|
||
func (s *Service) AddReviewConf(c context.Context, rc *model.ReviewConf) (err error) {
|
||
if len(rc.Types) > 0 {
|
||
stypes, _ := xstr.SplitInts(s.tarnsType(c, xstr.JoinInts(rc.Types)))
|
||
rc.Types = stypes
|
||
}
|
||
|
||
if _, err = s.dao.InReviewConf(c, rc); err != nil {
|
||
log.Error("s.AddReviewConf(%+v) error(%v)", rc, err)
|
||
return err
|
||
}
|
||
s.SyncRC(c)
|
||
return
|
||
}
|
||
|
||
// EditReviewConf 修改配置
|
||
func (s *Service) EditReviewConf(c context.Context, rc *model.ReviewConf) (err error) {
|
||
if len(rc.Types) > 0 {
|
||
stypes, _ := xstr.SplitInts(s.tarnsType(c, xstr.JoinInts(rc.Types)))
|
||
rc.Types = stypes
|
||
}
|
||
|
||
if _, err = s.dao.UpReviewConf(c, rc); err != nil {
|
||
log.Error("s.EditReviewConf(%+v) error(%v)", rc, err)
|
||
return err
|
||
}
|
||
s.SyncRC(c)
|
||
return
|
||
}
|
||
|
||
// DelReviewConf 删除配置
|
||
func (s *Service) DelReviewConf(c context.Context, id int) (err error) {
|
||
if _, err = s.dao.DelReviewConf(c, id); err != nil {
|
||
log.Error("s.DelReviewConf(%d) error(%v)", id, err)
|
||
return err
|
||
}
|
||
s.SyncRC(c)
|
||
return
|
||
}
|
||
|
||
// SyncRC sync from db
|
||
func (s *Service) SyncRC(c context.Context) {
|
||
rcs, err := s.dao.ReviewConfs(context.TODO())
|
||
if err != nil {
|
||
log.Error("loadRC error(%v)", err)
|
||
return
|
||
}
|
||
|
||
if len(rcs) > 0 {
|
||
s.reviewCache.Mux.Lock()
|
||
defer s.reviewCache.Mux.Unlock()
|
||
s.reviewCache.MRC = make(map[int64]*model.ReviewConf)
|
||
for _, item := range rcs {
|
||
s.reviewCache.MRC[item.ID] = item
|
||
}
|
||
}
|
||
}
|
||
|
||
func (s *Service) loadRC() {
|
||
s.SyncRC(context.TODO())
|
||
}
|
||
|
||
func (s *Service) loadRCproc() {
|
||
for {
|
||
time.Sleep(3 * time.Minute)
|
||
s.SyncRC(context.TODO())
|
||
}
|
||
}
|
||
|
||
func (s *Service) getReviewParams(c context.Context, form *model.SubmitForm) (tp *model.TaskPriority, err error) {
|
||
t, err := s.dao.TaskByID(c, form.TaskID)
|
||
if err != nil || t == nil {
|
||
return nil, ErrTaskMISS
|
||
}
|
||
if t.State != model.TypeDispatched {
|
||
log.Info("CheckReview(%d) 不需要复审 state(%d)", form.TaskID, t.State)
|
||
return nil, nil
|
||
}
|
||
|
||
mp, err := s.dao.GetWeightRedis(c, []int64{form.TaskID})
|
||
if err != nil || len(mp) == 0 {
|
||
if mp, err = s.dao.GetWeightDB(c, []int64{form.TaskID}); err != nil || len(mp) == 0 {
|
||
log.Error("GetWeightDB(%d) miss", form.TaskID)
|
||
return nil, ErrTaskMISS
|
||
}
|
||
}
|
||
if _, ok := mp[form.TaskID]; !ok {
|
||
log.Error("mp(%d) miss", form.TaskID)
|
||
return nil, ErrTaskMISS
|
||
}
|
||
tp = mp[form.TaskID]
|
||
|
||
// 补充复审判断的参数
|
||
if tp.TypeID == 0 {
|
||
s.setReviewParams(c, form.MID, form.AID, tp)
|
||
}
|
||
return
|
||
}
|
||
|
||
func (s *Service) setReviewParams(c context.Context, mid, aid int64, tp *model.TaskPriority) {
|
||
typeid, upfrom, err := s.dao.ArchiveParam(c, aid)
|
||
if err == nil {
|
||
tp.TypeID = typeid
|
||
tp.UpFrom = upfrom
|
||
}
|
||
tp.UpGroups = s.getSpecial(mid)
|
||
}
|