119 lines
3.0 KiB
Go
119 lines
3.0 KiB
Go
|
package service
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
"go-common/app/interface/main/playlist/model"
|
||
|
favmdl "go-common/app/service/main/favorite/model"
|
||
|
"go-common/library/log"
|
||
|
"go-common/library/net/metadata"
|
||
|
)
|
||
|
|
||
|
func (s *Service) plsByMid(c context.Context, mid int64) (res []*model.PlStat, err error) {
|
||
|
if res, err = s.dao.StatsCache(c, mid); err != nil || len(res) == 0 {
|
||
|
err = nil
|
||
|
if res, err = s.dao.PlsByMid(c, mid); err != nil {
|
||
|
log.Error("s.dao.PlsByMid(%d) error(%v)", mid, err)
|
||
|
return
|
||
|
}
|
||
|
if len(res) > 0 {
|
||
|
s.cache.Save(func() {
|
||
|
s.dao.SetStatsCache(context.Background(), mid, res)
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
|
||
|
func (s *Service) plByPid(c context.Context, pid int64) (res *model.PlStat, err error) {
|
||
|
var pls []*model.PlStat
|
||
|
pids := []int64{pid}
|
||
|
if pls, err = s.dao.PlsCache(c, pids); err != nil {
|
||
|
err = nil
|
||
|
} else if len(pls) != 0 {
|
||
|
res = pls[0]
|
||
|
return
|
||
|
}
|
||
|
if res, err = s.dao.PlByPid(c, pid); err != nil {
|
||
|
log.Error("s.dao.PlByPid(%d) error(%v)", pid, err)
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
func (s *Service) plsByPid(c context.Context, pids []int64) (res []*model.PlStat, err error) {
|
||
|
var (
|
||
|
tmpRs []*model.PlStat
|
||
|
rsMap map[int64]*model.PlStat
|
||
|
)
|
||
|
if tmpRs, err = s.dao.PlsCache(c, pids); err != nil || len(pids) != len(tmpRs) || len(tmpRs) == 0 {
|
||
|
err = nil
|
||
|
if tmpRs, err = s.dao.PlsByPid(c, pids); err != nil {
|
||
|
log.Error("s.dao.PlsByPid(%+v) error(%v)", pids, err)
|
||
|
}
|
||
|
if len(tmpRs) > 0 {
|
||
|
s.cache.Save(func() {
|
||
|
s.dao.SetPlCache(context.Background(), tmpRs)
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
rsMap = make(map[int64]*model.PlStat)
|
||
|
for _, v := range tmpRs {
|
||
|
rsMap[v.ID] = v
|
||
|
}
|
||
|
for _, v := range pids {
|
||
|
if rsMap[v] == nil {
|
||
|
continue
|
||
|
}
|
||
|
res = append(res, rsMap[v])
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// SetStat set playlist stat cache.
|
||
|
func (s *Service) SetStat(c context.Context, arg *model.PlStat) (err error) {
|
||
|
var fav *favmdl.Folder
|
||
|
argFav := &favmdl.ArgFolder{Type: favmdl.TypePlayVideo, Fid: arg.Fid, Mid: arg.Mid, RealIP: ""}
|
||
|
if fav, err = s.fav.Folder(c, argFav); err != nil || fav == nil {
|
||
|
log.Error("SetStat s.fav.Folder(%+v) error(%v)", argFav, err)
|
||
|
return
|
||
|
}
|
||
|
log.Info("service SetStat(%v) favState(%d)", arg, fav.State)
|
||
|
if fav.State == favmdl.StateNormal {
|
||
|
if err = s.dao.SetPlStatCache(c, arg.Mid, arg.ID, arg); err != nil {
|
||
|
log.Error("SetStat s.dao.SetPlStatCache(%d,%d) error(%v)", arg.Mid, arg.ID, err)
|
||
|
}
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// PubView pub playlist view.
|
||
|
func (s *Service) PubView(c context.Context, pid, aid int64) (err error) {
|
||
|
var (
|
||
|
pls *model.PlStat
|
||
|
ip = metadata.String(c, metadata.RemoteIP)
|
||
|
)
|
||
|
if pls, err = s.plInfo(c, 0, pid, ip); err != nil {
|
||
|
return
|
||
|
}
|
||
|
//TODO aid in playlist
|
||
|
err = s.cache.Save(func() {
|
||
|
s.dao.PubView(context.Background(), pid, aid, pls.View)
|
||
|
})
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// PubShare pub playlist share.
|
||
|
func (s *Service) PubShare(c context.Context, pid, aid int64) (err error) {
|
||
|
var (
|
||
|
pls *model.PlStat
|
||
|
ip = metadata.String(c, metadata.RemoteIP)
|
||
|
)
|
||
|
if pls, err = s.plInfo(c, 0, pid, ip); err != nil {
|
||
|
return
|
||
|
}
|
||
|
//TODO aid in playlist
|
||
|
err = s.cache.Save(func() {
|
||
|
s.dao.PubShare(context.Background(), pid, aid, pls.Share)
|
||
|
})
|
||
|
return
|
||
|
}
|