go-common/app/admin/main/videoup/service/search.go

926 lines
24 KiB
Go
Raw Normal View History

2019-04-22 10:49:16 +00:00
package service
import (
"context"
"github.com/pkg/errors"
"go-common/app/admin/main/videoup/model/archive"
"go-common/app/admin/main/videoup/model/manager"
"go-common/app/admin/main/videoup/model/search"
accApi "go-common/app/service/main/account/api"
"go-common/library/database/elastic"
"go-common/library/ecode"
"go-common/library/log"
bm "go-common/library/net/http/blademaster"
"go-common/library/xstr"
"strconv"
"strings"
"sync"
)
// SearchVideo search video
func (s *Service) SearchVideo(c context.Context, p *search.VideoParams) (result *search.VideoResultData, err error) {
var (
aids, cids,
vids, mids,
tids, tagIds,
xcodes []int64
fNames []string
ps = 30
sort string
order string
isMonitor bool //是否查看监控列表
moniTotal int //监控列表的总数量
moniMap map[int64]int //监控列表的视频id map。键vidtime进入监控的时间
tags map[int64]string
aStates, vStates map[int64]int
members map[int64]*accApi.Info
eReq *elastic.Request
wg sync.WaitGroup
)
es := elastic.NewElastic(nil)
//Page
if p.Ps != 0 {
ps = p.Ps
}
if p.Pn == 0 {
p.Pn = 1
}
if p.OrderType == "1" {
eReq = es.NewRequest("archive_video_score")
} else {
eReq = es.NewRequest("archive_video")
}
eReq.Index("archive_video")
if p.Keywords != "" {
eReq.WhereLike([]string{"arc_title", "arc_author"}, []string{p.Keywords}, true, elastic.LikeLevelLow)
}
if p.ArcTitle != "" {
eReq.WhereLike([]string{"arc_title"}, []string{p.ArcTitle}, false, elastic.LikeLevelLow)
}
if p.Aids != "" {
p.Aids = strings.Join(Slice2String(SliceUnique(Slice2Interface(strings.Split(p.Aids, ",")))), ",")
if aids, err = s.SplitInts(p.Aids); err != nil {
err = ecode.RequestErr
return
}
if len(aids) > ps {
ps = len(aids)
}
eReq.WhereIn("aid", aids)
}
//监控结果列表逻辑
if p.MonitorList != "" {
isMonitor = true
var (
rid int
)
moniP := strings.Split(p.MonitorList, "_")
if len(moniP) != 3 {
err = errors.New("监控列表标识字段格式错误")
return
}
if rid, err = strconv.Atoi(moniP[2]); err != nil {
return
}
if moniMap, err = s.MonitorStayOids(c, int64(rid)); err != nil {
return
}
moniTotal = len(moniMap)
for vid := range moniMap {
vids = append(vids, vid)
}
if len(vids) == 0 {
result = &search.VideoResultData{
Result: []*search.Video{},
}
return
}
if len(vids) > ps {
ps = len(vids)
}
eReq.WhereIn("vid", vids)
}
if p.Cids != "" {
p.Cids = strings.Join(Slice2String(SliceUnique(Slice2Interface(strings.Split(p.Cids, ",")))), ",")
if cids, err = s.SplitInts(p.Cids); err != nil {
err = ecode.RequestErr
return
}
if len(cids) > ps {
ps = len(cids)
}
eReq.WhereIn("cid", cids)
}
if p.Vids != "" {
if vids, err = s.SplitInts(p.Vids); err != nil {
err = ecode.RequestErr
return
}
if len(vids) > ps {
ps = len(vids)
}
eReq.WhereIn("vid", vids)
}
if p.ArcMids != "" {
if mids, err = s.SplitInts(p.ArcMids); err != nil {
err = ecode.RequestErr
return
}
if len(mids) > ps {
ps = len(mids)
}
eReq.WhereIn("arc_mid", mids)
}
if p.Xcode != "" {
if xcodes, err = s.SplitInts(p.Xcode); err != nil {
err = ecode.RequestErr
return
}
eReq.WhereIn("xcode_state", xcodes)
}
if p.TypeID != "" {
if tids, err = s.SplitInts(p.TypeID); err != nil {
err = ecode.RequestErr
return
}
for _, tid := range tids {
if ids, ok := s.typeCache2[int16(tid)]; ok {
tids = append(tids, ids...)
}
}
eReq.WhereIn("arc_typeid", tids)
}
if p.Filename != "" {
if fNames = strings.Split(p.Filename, ","); err != nil {
err = ecode.RequestErr
return
}
eReq.WhereIn("filename", fNames)
}
if p.TagID != "" {
eReq.WhereEq("tag_id", p.TagID)
}
if p.Status != "" {
if p.Status == "-100" {
eReq.WhereEq("relation_state", "-100")
p.Status = ""
} else {
eReq.WhereEq("relation_state", "0")
eReq.WhereEq("status", p.Status)
}
}
if p.UserType != "" {
eReq.WhereEq("user_type", p.UserType)
}
if p.DurationFrom != "" && p.DurationTo != "" {
eReq.WhereRange("duration", p.DurationFrom, p.DurationTo, elastic.RangeScopeLcRc)
} else if p.DurationFrom != "" && p.DurationTo == "" {
eReq.WhereRange("duration", p.DurationFrom, "", elastic.RangeScopeLcRc)
} else if p.DurationFrom == "" && p.DurationTo != "" {
eReq.WhereRange("duration", "", p.DurationTo, elastic.RangeScopeLcRc)
}
//Order by
if p.Order != "" {
order = p.Order
} else if p.Action == "trash" {
order = "v_mtime"
} else {
order = "arc_senddate"
}
if p.Sort == 1 {
sort = "asc"
} else {
sort = "desc"
}
eReq.Order(order, sort)
//Page
eReq.Ps(ps)
eReq.Pn(p.Pn)
//Execute
log.Info("s.SearchVideo(%+v) SearchVideoQuery(%s)", p, eReq.Params())
if err = eReq.Scan(c, &result); err != nil {
log.Error("SearchVideoScan() error(%v)", err)
return
}
if result == nil {
log.Error("s.SearchVideo(%+v) search return nil result", p)
result = &search.VideoResultData{
Result: []*search.Video{},
}
return
}
if result.Result == nil {
log.Error("s.SearchVideo(%+v) search return nil video", p)
result.Result = []*search.Video{}
return
}
if len(result.Result) == 0 {
return
}
if isMonitor {
result.Page.Total = moniTotal
}
aids = []int64{}
vids = []int64{}
mids = []int64{}
for _, v := range result.Result {
if v.TagID != 0 {
tagIds = append(tagIds, v.TagID)
}
aids = append(aids, v.Aid)
vids = append(vids, v.Vid)
if v.ArcMid != 0 {
mids = append(mids, v.ArcMid)
}
}
//获取Tag名称
wg.Add(1)
go func(tags *map[int64]string) {
defer wg.Done()
if *tags, err = s.arc.TagNameMap(c, tagIds); err != nil {
log.Error("s.arc.TagNameMap(%v) error(%v)", tagIds, err)
err = nil
}
log.Info("s.arc.TagNameMap(%v) result(%v)", tagIds, tags)
}(&tags)
//获取数据库中的稿件状态
wg.Add(1)
go func(aStates *map[int64]int) {
defer wg.Done()
if *aStates, err = s.arc.ArcStateMap(c, aids); err != nil {
log.Error("s.arc.ArcStateMap(%v) error(%v)", aids, err)
err = nil
}
}(&aStates)
//获取数据库中视频的状态
wg.Add(1)
go func(vStates *map[int64]int) {
defer wg.Done()
if *vStates, err = s.arc.VideoStateMap(c, vids); err != nil {
log.Error("s.arc.VideoStateMap(%v) error(%v)", vids, err)
err = nil
}
}(&vStates)
//获取UP主信息
wg.Add(1)
go func(members *map[int64]*accApi.Info) {
defer wg.Done()
var infosReply *accApi.InfosReply
if infosReply, err = s.accRPC.Infos3(c, &accApi.MidsReq{Mids: mids}); err != nil {
log.Error("s.accRPC.Infos3(%v) error(%v)", mids, err)
err = nil
return
}
*members = infosReply.Infos
}(&members)
wg.Wait()
sInt, _ := strconv.Atoi(p.Status)
for i := 0; i < len(result.Result); i++ {
v := result.Result[i]
result.Result[i].ID = v.Vid
if vs, ok := vStates[v.Vid]; ok {
result.Result[i].Status = vs
}
//需要将status与查询条件中status不一致的视频剔除
if p.Status != "" && v.Status != sInt {
result.Result = append(result.Result[:i], result.Result[i+1:]...)
i--
continue
}
if tn, ok := tags[v.TagID]; ok {
result.Result[i].TagName = tn
}
if as, ok := aStates[v.Aid]; ok {
result.Result[i].ArcState = as
}
if m, ok := members[v.ArcMid]; ok {
result.Result[i].ArcAuthor = m.Name
}
if v.UserType == nil {
v.UserType = []int64{}
}
if v.UserGroup == nil {
v.UserGroup = []*manager.UpGroup{}
}
for _, tp := range v.UserType {
if up, ok := s.allUpGroupCache[tp]; ok {
result.Result[i].UserGroup = append(result.Result[i].UserGroup, up)
}
}
}
return
}
// SearchCopyright search video copyright
func (s *Service) SearchCopyright(c context.Context, kw string) (result *search.CopyrightResultData, err error) {
return s.search.SearchCopyright(c, kw)
}
// SearchArchive 稿件搜索列表
func (s *Service) SearchArchive(c *bm.Context, p *search.ArchiveParams) (result *search.ArchiveResultData, err error) {
var (
round int
aids []int64
froms []int8
forbid string
tids []int64
pn = 1
ps = 30
isMonitor bool //是否查看监控列表
moniMap map[int64]int //监控列表的视频id map。键vidtime进入监控的时间
nPGCAids, sPGCAids, cPGCAids, misAids []int64
additMap map[int64]*archive.Addit
tips string
orders = map[string]string{
"mtime": "",
"pubtime": "",
"ctime": "",
"dm_count": "",
"fav_count": "",
}
eReq *elastic.Request
)
es := elastic.NewElastic(nil)
if p.OrderType != "" {
eReq = es.NewRequest("archive_score")
} else {
eReq = es.NewRequest("archive")
}
eReq.Index("archive")
if p.Ps != 0 {
ps = p.Ps
}
if ps > 1000 {
ps = 1000
}
//分区 逻辑
if p.TypeID != "" {
if tids, err = s.SplitInts(p.TypeID); err != nil {
return
}
for _, tid := range tids {
if ids, ok := s.typeCache2[int16(tid)]; ok {
tids = append(tids, ids...)
}
}
}
//特殊分区逻辑
if p.SpecialType != "" {
for i := 0; i < len(tids); i++ { //剔除特殊/普通分区id
_, ok := s.adtTpsCache[int16(tids[i])]
if (ok && p.SpecialType == "0") || (!ok && p.SpecialType == "1") {
tids = append(tids, tids...)
i--
continue
}
}
}
if len(tids) > 0 {
eReq.WhereIn("typeid", tids)
if len(tids) > ps {
ps = len(tids)
}
}
if p.UserType != "" && p.UserType != "0" {
eReq.WhereEq("user_type", p.UserType)
}
//up_from 逻辑
if p.UpFroms != "" {
var upFroms []int64
if upFroms, err = s.SplitInts(p.UpFroms); err != nil {
return
}
eReq.WhereIn("up_from", upFroms)
} else { //默认去除PGC稿件
eReq.WhereIn("up_from", []int8{archive.UpFromPGC, archive.UpFromSecretPGC, archive.UpFromCoopera})
eReq.WhereNot(elastic.NotTypeIn, "up_from")
}
//Round 逻辑
if p.Round != "" {
if round, err = strconv.Atoi(p.Round); err != nil {
log.Warn("http.searchArchive() http.PGCListLogic() err(%v)", err)
return
}
if round == 1 {
eReq.WhereIn("round", []int8{1, archive.RoundReviewSecond})
} else if round == 2 {
eReq.WhereIn("round", []int8{2, archive.RoundEnd})
} else {
eReq.WhereIn("round", []int{round})
}
}
//Aid 逻辑
if p.Aids != "" {
p.Aids = strings.Replace(p.Aids, "\n", ",", -1)
p.Aids = strings.Join(Slice2String(SliceUnique(Slice2Interface(strings.Split(p.Aids, ",")))), ",")
if aids, err = s.SplitInts(p.Aids); err != nil {
return
}
eReq.WhereIn("id", aids)
}
//Mid 逻辑
if p.Mids != "" {
var mids []int64
p.Mids = strings.Replace(p.Mids, "\n", ",", -1)
if mids, err = s.SplitInts(p.Mids); err != nil {
return
}
eReq.WhereIn("mid", mids)
if len(mids) > ps {
ps = len(mids)
}
}
if p.State != "" {
states := strings.Split(p.State, ",")
eReq.WhereIn("state", states)
}
if p.Access != "" {
eReq.WhereEq("access", p.Access)
}
if p.Copyright != "" {
eReq.WhereEq("copyright", p.Copyright)
}
if p.IsFirst != "" {
eReq.WhereEq("is_first", p.IsFirst)
}
//PGC 列表逻辑
if p.PGCList != "" {
if err = s.PGCListLogic(c, p.PGCList, p.State, froms, eReq); err != nil {
return
}
if c.IsAborted() { //检查鉴权
return
}
}
//搜索关键字逻辑
if p.Keywords != "" {
fields := []string{"title", "content", "tag"}
if p.KwFields != "" {
fields = strings.Split(p.KwFields, ",")
for i := 0; i < len(fields); i++ {
if fields[i] == "channel" {
fields[i] = "tid_names"
break
}
}
}
eReq.WhereLike(fields, []string{p.Keywords}, true, elastic.LikeLevelLow)
}
if p.NoMission == "" { //默认去掉活动稿件
p.NoMission = "1"
}
//禁止项逻辑
if p.Attr == strconv.Itoa(archive.ForbidAttrChannel) {
forbid = "channel"
eReq.WhereEq("channel_group_id", archive.FlowGroupNoChannel)
eReq.WhereEq("channel_pool", archive.PoolArcForbid)
eReq.WhereEq("channel_state", archive.FlowOpen)
} else if p.Attr == strconv.Itoa(archive.ForbidAttrHot) {
forbid = "hot"
eReq.WhereEq("hot_group_id", archive.FlowGroupNoHot)
eReq.WhereEq("hot_pool", archive.PoolArcForbid)
eReq.WhereEq("hot_state", archive.FlowOpen)
} else if p.Attr != "" {
attr := 0
attr, err = strconv.Atoi(p.Attr)
if err != nil {
return
}
if (uint(attr-1) == archive.AttrBitIsPorder) && int8(round) != archive.RoundReviewFlow {
s.auth.Permit("PRIVATE_ORDER_ALL")(c) //鉴权
if c.IsAborted() {
return
}
p.NoMission = "" //不做活动稿件剔除
}
eReq.WhereEq("attribute", attr)
}
//回查列表逻辑
if p.Review != "" {
if p.ReviewState == "" {
p.ReviewState = strconv.Itoa(archive.RecheckStateWait)
}
switch p.Review {
case strconv.Itoa(archive.TypeChannelRecheck):
s.auth.Permit("CHANNEL_REVIEW")(c)
eReq.WhereEq("recheck_ch_type", p.Review)
eReq.WhereEq("recheck_ch_staten", p.ReviewState)
case strconv.Itoa(archive.TypeHotRecheck):
p.NoMission = ""
s.auth.Permit("ARC_HOT_REVIEW")(c)
eReq.WhereEq("recheck_hot_type", p.Review)
eReq.WhereEq("recheck_hot_staten", p.ReviewState)
case strconv.Itoa(archive.TypeInspireRecheck):
p.NoMission = ""
s.auth.Permit("ARC_INSPIRE_REVIEW")(c)
eReq.WhereEq("recheck_inspire_type", p.Review)
eReq.WhereEq("recheck_inspire_staten", p.ReviewState)
}
if c.IsAborted() {
return
}
p.IsOrder = 0
} else if p.Round == strconv.Itoa(int(archive.RoundAuditUGCPayFlow)) { //付费列表需要展示活动稿件
p.NoMission = ""
}
//活动逻辑
if p.MissionID != "" {
eReq.WhereEq("mission_id", p.MissionID)
}
if p.MissionID != "" || p.NoMission == "0" { //需要活动稿件
eReq.WhereRange("mission_id", 1, nil, elastic.RangeScopeLcRo)
} else if p.NoMission == "1" { //不需要活动稿件
eReq.WhereRange("mission_id", 0, nil, elastic.RangeScopeLoRo)
eReq.WhereNot(elastic.NotTypeRange, "mission_id")
}
//商单逻辑
if p.IsOrder == 1 { //商单 order_id 大于0
eReq.WhereRange("order_id", 0, nil, elastic.RangeScopeLoRo)
if p.OrderId != "" {
eReq.WhereEq("order_id", p.OrderId)
}
} else if forbid == "" && p.Review == "" { //除了禁止列表和回查列表都要去除商单order_id <= 0
eReq.WhereRange("order_id", 0, nil, elastic.RangeScopeLoRo)
eReq.WhereNot(elastic.NotTypeRange, "order_id")
}
//监控结果列表逻辑
if p.MonitorList != "" {
eReq = es.NewRequest("archive_score") //去掉其它条件
eReq.Index("archive")
isMonitor = true
var (
rid int
)
moniP := strings.Split(p.MonitorList, "_")
if len(moniP) != 3 {
err = errors.New("监控列表标识字段格式错误")
return
}
if rid, err = strconv.Atoi(moniP[2]); err != nil {
return
}
if moniMap, err = s.MonitorStayOids(c, int64(rid)); err != nil {
return
}
for aid := range moniMap {
aids = append(aids, aid)
}
if len(aids) == 0 {
result = &search.ArchiveResultData{
Result: []*search.Archive{},
}
return
}
/*if len(aids) > ps {
ps = len(aids)
}*/
eReq.WhereIn("id", aids)
}
//分页、排序
if p.Pn > 0 {
pn = p.Pn
}
if _, ok := orders[p.Order]; !ok {
p.Order = "ctime"
}
if p.Order == "" {
p.Order = "ctime"
}
eReq.OrderScoreFirst(p.ScoreFirst != "0")
if p.Sort == "" {
p.Sort = "desc"
}
eReq.Order(p.Order, p.Sort)
eReq.Pn(pn)
eReq.Ps(ps)
log.Info("SearchArchiveQuery(%s)", eReq.Params())
if err = eReq.Scan(c, &result); err != nil {
log.Error("SearchArchiveQuery() error(%v)", err)
return
}
if isMonitor {
result.MoniAids = moniMap
}
if len(aids) > 0 && !isMonitor {
//获取稿件addit
if additMap, err = s.arc.AdditBatch(c, aids); err != nil {
log.Error("s.arc.AdditBatch(%v) error(%v) additMap(%v)", aids, err, additMap)
err = nil
}
for _, v := range aids {
if _, ok := additMap[v]; ok {
switch additMap[v].UpFrom {
case archive.UpFromPGC:
nPGCAids = append(nPGCAids, v)
case archive.UpFromSecretPGC:
sPGCAids = append(sPGCAids, v)
case archive.UpFromCoopera:
cPGCAids = append(cPGCAids, v)
}
if additMap[v].MissionID > 0 {
misAids = append(misAids, v)
}
}
}
if len(nPGCAids) > 0 {
tips += "PGC稿件" + xstr.JoinInts(nPGCAids)
}
if len(sPGCAids) > 0 {
tips += "PGC机密" + xstr.JoinInts(sPGCAids)
}
if len(cPGCAids) > 0 {
tips += "PGC嵌套" + xstr.JoinInts(cPGCAids)
}
if len(misAids) > 0 {
tips += "活动稿件:" + xstr.JoinInts(misAids)
}
result.Tips = tips
}
if err = s.KneadArchiveResult(c, result, p, additMap); err != nil {
return
}
return
}
// PGCListLogic PGC列表查询相关逻辑
func (s *Service) PGCListLogic(c *bm.Context, lnStr string, pState string, froms []int8, eReq *elastic.Request) (err error) {
var (
state int ////临时存储PGC列表中查询的state状态需要和pState字符串配合使用
lni int
ln int8
pgcConfig map[int8]*search.ArcPGCConfig
)
if lni, err = strconv.Atoi(lnStr); err != nil {
log.Warn("s.PGCListLogic() err(%v)", err)
return
}
ln = int8(lni)
if state, err = strconv.Atoi(pState); err != nil {
err = errors.New("PGC列表中的state参数错误")
return
}
if len(froms) != 0 {
for _, v := range froms {
if v != archive.UpFromPGC && v != archive.UpFromSecretPGC && v != archive.UpFromCoopera {
err = errors.New("PGC列表中的from参数错误")
break
}
}
}
pgcConfig = make(map[int8]*search.ArcPGCConfig)
//PGC常规二审列表 round=10 state=-1,-30,-40,-6 upfrom=1
pgcConfig[1] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromPGC},
Rounds: []int8{
archive.RoundBegin,
archive.RoundAuditSecond,
},
States: []int8{
archive.RecheckStateWait,
archive.StateForbidSubmit,
archive.StateForbidUserDelay,
archive.StateForbidFixed,
},
InState: pState != "" && state < 0,
Auth: "PGC_NORMAL_2",
}
//PGC常规三审列表 round=20 state=-1,-30,-40,-6 upfrom=1
pgcConfig[2] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromPGC},
Rounds: []int8{archive.RoundAuditThird},
States: []int8{
archive.RecheckStateWait,
archive.StateForbidSubmit,
archive.StateForbidUserDelay,
archive.StateForbidFixed,
},
InState: pState != "" && state < 0,
Auth: "PGC_NORMAL_3",
}
//PGC机密待审列表 state=-1,-30,-40,-6 upfrom=5
pgcConfig[3] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromSecretPGC},
Rounds: []int8{},
States: []int8{
archive.RecheckStateWait,
archive.StateForbidSubmit,
archive.StateForbidUserDelay,
archive.StateForbidFixed,
},
InState: pState != "" && state < 0,
Auth: "PGC_SECRET_WAIT",
}
//PGC机密回查列表 round=90 state≥0 upfrom=5
pgcConfig[4] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromSecretPGC},
Rounds: []int8{archive.RoundTriggerClick},
States: []int8{
archive.StateOpen,
archive.StateOrange,
},
InState: pState != "" && state >= 0,
Auth: "PGC_SECRET_RECHECK",
}
//PGC全部已过审 round=99 state≥0 upfrom=1,5,6
pgcConfig[5] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromPGC, archive.UpFromSecretPGC, archive.UpFromCoopera},
Rounds: []int8{archive.RoundEnd},
States: []int8{
archive.StateOpen,
archive.StateOrange,
},
InState: pState != "" && state >= 0,
Auth: "PGC_OPEN",
}
//全部打回列表 state=-2,-3,-4,-7,-11,-16,-100 up_from=1,5,6
pgcConfig[6] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromPGC, archive.UpFromSecretPGC, archive.UpFromCoopera},
Rounds: []int8{},
States: []int8{
archive.StateForbidRecycle,
archive.StateForbidPolice,
archive.StateForbidLock,
archive.StateForbidLater,
archive.StateForbidFixing,
archive.StateForbidXcodeFail,
archive.StateForbidUpDelete,
},
InState: pState != "" && state < 0,
Auth: "PGC_RECICLE",
}
//合作方嵌套列表 state=-1,-30,-6,-40 up_from=6
pgcConfig[7] = &search.ArcPGCConfig{
UPFrom: []int8{archive.UpFromCoopera},
Rounds: []int8{},
States: []int8{
archive.StateForbidWait,
archive.StateForbidSubmit,
archive.StateForbidFixed,
archive.StateForbidUserDelay,
},
InState: pState != "" && state < 0,
Auth: "PGC_PARTNER",
}
if _, ok := pgcConfig[ln]; !ok || pgcConfig[ln] == nil {
err = errors.New("PGC列表不存在")
return
}
if !pgcConfig[ln].InState { //如果前端传了合法的state则加上state条件
pgcConfig[ln].States = []int8{int8(state)}
}
if len(froms) != 0 { //如果前端传了up_from则加上up_from条件
pgcConfig[ln].UPFrom = froms
}
if len(pgcConfig[ln].UPFrom) == 0 {
err = errors.New("PGC列表中的UPFrom不能设置为空")
return
}
s.auth.Permit(pgcConfig[ln].Auth)(c) //鉴权
eReq.WhereIn("up_from", pgcConfig[ln].UPFrom)
eReq.WhereIn("state", pgcConfig[ln].States)
eReq.WhereIn("round", pgcConfig[ln].Rounds)
return
}
// KneadArchiveResult 拼接稿件数据
func (s *Service) KneadArchiveResult(c *bm.Context, result *search.ArchiveResultData, p *search.ArchiveParams, additMap map[int64]*archive.Addit) (err error) {
var (
mids, aids []int64
ups map[int64]*accApi.Card
rStates map[int64]int8
chNames map[int64][]string
archives = result.Result
dbArchives map[int64]*archive.Archive
wg sync.WaitGroup
)
for _, v := range archives {
if v.Mid != 0 {
mids = append(mids, v.Mid)
}
aids = append(aids, v.ID)
}
//获取频道信息
wg.Add(1)
go func(chNames *map[int64][]string) {
defer wg.Done()
*chNames = s.ChannelNamesByAids(c, aids)
}(&chNames)
wg.Add(1)
go func(dbArchives *map[int64]*archive.Archive) {
defer wg.Done()
if *dbArchives, err = s.arc.Archives(c, aids); err != nil || dbArchives == nil {
log.Error("s.arc.Archives(%v) error(%v) archives(%v)", mids, err, dbArchives)
err = nil
}
}(&dbArchives)
//获取UP主信息
wg.Add(1)
go func(ups *map[int64]*accApi.Card) {
defer wg.Done()
if *ups, err = s.upCards(c, mids); err != nil || ups == nil {
log.Error("s.upCards(%v) error(%v) ups(%v)", mids, err, ups)
err = nil
*ups = make(map[int64]*accApi.Card)
}
}(&ups)
//获取回查稿件实时状态
if p.Review != "" && p.ReviewState != "" {
wg.Add(1)
go func(rStates *map[int64]int8) {
defer wg.Done()
tp, _ := strconv.Atoi(p.Review)
if *rStates, err = s.arc.RecheckStateMap(c, tp, aids); err != nil || rStates == nil {
log.Error("s.arc.RecheckStateMap(%v,%v) error(%v) rStates(%v)", tp, aids, err, rStates)
err = nil
}
}(&rStates)
}
wg.Wait()
for i := 0; i < len(archives); i++ {
v := archives[i]
if a, ok := dbArchives[v.ID]; ok && a.Cover != "" {
archives[i].Cover = coverURL(a.Cover)
}
if m, ok := ups[v.Mid]; ok {
archives[i].Official = m.Official
archives[i].Author = m.Name
}
if p.Review != "" && p.ReviewState != "" {
if state, ok := rStates[v.ID]; ok { //将与查询条件中回查状态不一致的稿件剔除
rState, err := strconv.Atoi(p.ReviewState)
if err != nil {
log.Error("s.KneadArchive() error(%v) reviewState(%v)", err, p.ReviewState)
err = nil
continue
}
if state != int8(rState) {
archives = append(archives[:i], archives[i+1:]...)
i--
continue
}
}
}
if _, ok := additMap[v.ID]; ok {
archives[i].UpFrom = additMap[v.ID].UpFrom
if additMap[v.ID].MissionID > 0 {
archives[i].MissionID = additMap[v.ID].MissionID
}
}
if names, ok := chNames[v.ID]; ok {
archives[i].TagNames = names
}
if archives[i].TagNames == nil {
archives[i].TagNames = []string{}
}
if archives[i].UserType == nil {
archives[i].UserType = []int64{}
}
if v.UserGroup == nil {
v.UserGroup = []*manager.UpGroup2{}
}
if v.Attribute == nil {
v.Attribute = []int{}
}
v.Attrs = v.Attribute
for _, tp := range v.UserType {
if up, ok := s.allUpGroupCache[tp]; ok {
//因为前端希望稿件列表返回的up_group与任务质检结构一致所以在这做一次转换
gp := &manager.UpGroup2{
GroupID: up.ID,
GroupName: up.Name,
GroupTag: up.ShortTag,
}
result.Result[i].UserGroup = append(result.Result[i].UserGroup, gp)
}
}
}
result.Result = archives
return
}