Create & Init Project...

This commit is contained in:
2019-04-22 18:49:16 +08:00
commit fc4fa37393
25440 changed files with 4054998 additions and 0 deletions

View File

@ -0,0 +1,177 @@
package service
import (
"context"
"time"
"go-common/app/interface/main/dm2/model"
"go-common/library/database/sql"
"go-common/library/ecode"
"go-common/library/log"
)
// AuditSubtitle audit subtitle by uper pr assitant
func (s *Service) AuditSubtitle(c context.Context, oid int64, subtitleID int64, mid int64, pass bool, rejectComment string) (err error) {
var (
draft *model.Subtitle
subject *model.Subject
)
if draft, err = s.getSubtitle(c, oid, subtitleID); err != nil {
log.Error("s.getSubtitle(oid:%v,subtitleID:%v),error(%v)", oid, subtitleID, err)
return
}
if draft == nil {
err = ecode.NothingFound
return
}
// up主协管有权限
if subject, err = s.subject(c, draft.Type, draft.Oid); err != nil {
return
}
// 非up主无权限
if subject.Mid != mid {
err = ecode.SubtitlePermissionDenied
return
}
if draft.Status != model.SubtitleStatusToAudit && draft.Status != model.SubtitleStatusPublish {
err = ecode.SubtitleUnValid
return
}
draft.RejectComment = rejectComment
if !pass {
if draft.Status == model.SubtitleStatusPublish {
if err = s.backPubSubtitle(c, draft); err != nil {
return
}
return
}
if err = s.auditReject(c, draft); err != nil {
log.Error("params(draft:%+v).error(%v)", draft, err)
return
}
} else {
if err = s.auditPass(c, draft); err != nil {
log.Error("params(draft:%+v).error(%v)", draft, err)
return
}
}
return
}
// auditReject subtitle submit
func (s *Service) auditReject(c context.Context, subtitle *model.Subtitle) (err error) {
subtitle.Status = model.SubtitleStatusAuditBack
subtitle.PubTime = time.Now().Unix()
if err = s.dao.UpdateSubtitle(c, subtitle); err != nil {
log.Error("params(%+v).error(%v)", subtitle, err)
return
}
s.dao.DelSubtitleDraftCache(context.Background(), subtitle.Oid, subtitle.Type, subtitle.Mid, subtitle.Lan)
s.dao.DelSubtitleCache(context.Background(), subtitle.Oid, subtitle.ID)
return
}
func (s *Service) auditPass(c context.Context, subtitle *model.Subtitle) (err error) {
var (
tx *sql.Tx
subtitlePub *model.SubtitlePub
)
defer func() {
if err != nil {
tx.Rollback()
log.Error("params(subtitle:%+v).err(%v)", subtitle, err)
return
}
if err = tx.Commit(); err != nil {
log.Error("params(subtitle:%+v).err(%v)", subtitle, err)
return
}
}()
subtitle.Status = model.SubtitleStatusPublish
subtitle.PubTime = time.Now().Unix()
if tx, err = s.dao.BeginBiliDMTrans(c); err != nil {
log.Error("error(%v)", err)
return
}
if err = s.dao.TxUpdateSubtitle(tx, subtitle); err != nil {
log.Error("params(%+v).error(%v)", subtitle, err)
return
}
subtitlePub = &model.SubtitlePub{
Oid: subtitle.Oid,
Type: subtitle.Type,
Lan: subtitle.Lan,
SubtitleID: subtitle.ID,
}
if err = s.dao.TxAddSubtitlePub(tx, subtitlePub); err != nil {
log.Error("params(%+v).error(%v)", subtitlePub, err)
return
}
if err = s.dao.DelSubtitleDraftCache(c, subtitle.Oid, subtitle.Type, subtitle.Mid, subtitle.Lan); err != nil {
log.Error("DelSubtitleDraftCache.params(subtitle:%+v).err(%v)", subtitle, err)
return
}
if err = s.dao.DelSubtitleCache(c, subtitle.Oid, subtitle.ID); err != nil {
log.Error("DelSubtitleCache.params(subtitle:%+v).err(%v)", subtitle, err)
return
}
if err = s.dao.DelVideoSubtitleCache(c, subtitle.Oid, subtitle.Type); err != nil {
log.Error("DelVideoSubtitleCache.params(subtitle:%+v).err(%v)", subtitle, err)
return
}
return
}
func (s *Service) backPubSubtitle(c context.Context, subtitle *model.Subtitle) (err error) {
var (
tx *sql.Tx
subtitleNew *model.Subtitle
subtitlePub *model.SubtitlePub
)
defer func() {
if err != nil {
tx.Rollback()
return
}
if err = tx.Commit(); err != nil {
return
}
}()
subtitle.Status = model.SubtitleStatusAuditBack
subtitle.PubTime = time.Now().Unix()
if tx, err = s.dao.BeginBiliDMTrans(c); err != nil {
log.Error("error(%v)", err)
return
}
if err = s.dao.TxUpdateSubtitle(tx, subtitle); err != nil {
log.Error("params(%+v) error(%v)", subtitle, err)
return
}
if subtitleNew, err = s.dao.TxGetSubtitleOne(tx, subtitle.Oid, subtitle.Type, subtitle.Lan); err != nil {
log.Error("params(%+v) error(%v)", subtitle, err)
return
}
subtitlePub = &model.SubtitlePub{
Oid: subtitle.Oid,
Type: subtitle.Type,
Lan: subtitle.Lan,
}
if subtitleNew == nil {
subtitlePub.IsDelete = true
} else {
subtitlePub.SubtitleID = subtitleNew.ID
}
if err = s.dao.TxAddSubtitlePub(tx, subtitlePub); err != nil {
log.Error("params(%+v) error(%v)", subtitlePub, err)
return
}
if err = s.dao.DelSubtitleCache(context.Background(), subtitle.Oid, subtitle.ID); err != nil {
log.Error("params(oid:%v,subtitleID:%v) error(%v)", subtitle.Oid, subtitle.ID, err)
return
}
if err = s.dao.DelVideoSubtitleCache(context.Background(), subtitle.Oid, subtitle.Type); err != nil {
log.Error("params(oid:%v,subtitleID:%v) error(%v)", subtitle.Oid, subtitle.ID, err)
return
}
return
}