269 lines
7.5 KiB
Go
269 lines
7.5 KiB
Go
|
package service
|
|||
|
|
|||
|
import (
|
|||
|
"context"
|
|||
|
"go-common/app/interface/bbq/app-bbq/api/http/v1"
|
|||
|
"go-common/app/interface/bbq/app-bbq/model"
|
|||
|
user "go-common/app/service/bbq/user/api"
|
|||
|
"go-common/library/ecode"
|
|||
|
"go-common/library/log"
|
|||
|
)
|
|||
|
|
|||
|
// UserBase 获取用户信息
|
|||
|
func (s *Service) UserBase(c context.Context, mid int64) (res *v1.UserInfo, err error) {
|
|||
|
res = new(v1.UserInfo)
|
|||
|
var userInfos map[int64]*v1.UserInfo
|
|||
|
userInfos, err = s.dao.BatchUserInfo(c, mid, []int64{mid}, true, false, false)
|
|||
|
if err != nil {
|
|||
|
log.Errorv(c, log.KV("event", "user_base failed"), log.KV("err", err))
|
|||
|
err = ecode.GetUserBaseErr
|
|||
|
return
|
|||
|
}
|
|||
|
userInfo, exists := userInfos[mid]
|
|||
|
if exists && userInfo != nil {
|
|||
|
res = userInfo
|
|||
|
} else {
|
|||
|
log.Errorv(c, log.KV("event", "UserBase empty"), log.KV("err", err))
|
|||
|
err = ecode.GetUserBaseErr
|
|||
|
}
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//SpaceUserProfile ...
|
|||
|
func (s *Service) SpaceUserProfile(c context.Context, mid int64, upMid int64) (res *v1.UserInfo, err error) {
|
|||
|
if upMid == 0 {
|
|||
|
err = ecode.UPMIDNotExists
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
res = &v1.UserInfo{}
|
|||
|
userInfos, err := s.dao.BatchUserInfo(c, mid, []int64{upMid}, true, true, true)
|
|||
|
if err != nil {
|
|||
|
log.Errorv(c, log.KV("event", "batch_user_info"), log.KV("err", err))
|
|||
|
return
|
|||
|
}
|
|||
|
res, exists := userInfos[upMid]
|
|||
|
if !exists {
|
|||
|
err = ecode.UPMIDNotExists
|
|||
|
log.Errorv(c, log.KV("event", "user_info_not_found"), log.KV("up_mid", upMid), log.KV("err", err))
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// UserEdit 完善用户信息
|
|||
|
// 该请求需要保证请求的mid已经存在,如果不存在,该接口会返回失败
|
|||
|
func (s *Service) UserEdit(c context.Context, userBase *user.UserBase) (res *v1.NumResponse, err error) {
|
|||
|
res = new(v1.NumResponse)
|
|||
|
if err = s.dao.EditUserBase(c, userBase); err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//AddUserLike 点赞
|
|||
|
func (s *Service) AddUserLike(c context.Context, mid, svid int64) (res *v1.NumResponse, err error) {
|
|||
|
res = new(v1.NumResponse)
|
|||
|
var upMid, num int64
|
|||
|
|
|||
|
videoBase, err := s.dao.VideoBase(c, mid, svid)
|
|||
|
if err != nil {
|
|||
|
log.Warnw(c, "log", "get video base fail", "svid", svid)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
upMid = videoBase.Mid
|
|||
|
|
|||
|
likeNum, err := s.dao.AddLike(c, mid, upMid, svid)
|
|||
|
if err != nil {
|
|||
|
log.Warnv(c, log.KV("log", "add like fail"))
|
|||
|
return
|
|||
|
}
|
|||
|
if likeNum == 0 {
|
|||
|
log.Infow(c, "log", "repeated like", "mid", mid, "svid", svid)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// TODO:考虑消息队列解耦等
|
|||
|
tx, err := s.dao.BeginTran(c)
|
|||
|
if err != nil {
|
|||
|
log.Error("add user like begin tran err(%v) mid(%d) svid(%d)", err, mid, svid)
|
|||
|
err = ecode.AddUserLikeErr
|
|||
|
return
|
|||
|
}
|
|||
|
if num, err = s.dao.TxIncrVideoStatisticsLike(tx, svid); err != nil {
|
|||
|
err = ecode.AddUserLikeErr
|
|||
|
tx.Rollback()
|
|||
|
return
|
|||
|
}
|
|||
|
if num == 0 {
|
|||
|
log.Errorw(c, "log", "incr video statistics fail maybe due to the missing in video_statistics table", "svid", svid)
|
|||
|
videoStatistics := &model.VideoStatistics{SVID: svid, Like: 1}
|
|||
|
if num, err = s.dao.TxAddVideoStatistics(tx, videoStatistics); err != nil || num == 0 {
|
|||
|
err = ecode.AddUserLikeErr
|
|||
|
tx.Rollback()
|
|||
|
return
|
|||
|
}
|
|||
|
res.Num = 1
|
|||
|
}
|
|||
|
tx.Commit()
|
|||
|
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//CancelUserLike 取消点赞
|
|||
|
func (s *Service) CancelUserLike(c context.Context, mid, svid int64) (res *v1.NumResponse, err error) {
|
|||
|
res = new(v1.NumResponse)
|
|||
|
var upMid, num int64
|
|||
|
videoBase, err := s.dao.VideoBase(c, mid, svid)
|
|||
|
if ecode.IsCancelSvLikeAvailable(err) {
|
|||
|
err = nil
|
|||
|
log.Infow(c, "log", "allow cancel like when video unreachable", "svid", svid, "mid", mid)
|
|||
|
} else if err != nil {
|
|||
|
log.Warnw(c, "log", "get video base fail", "svid", svid)
|
|||
|
return
|
|||
|
}
|
|||
|
upMid = videoBase.Mid
|
|||
|
|
|||
|
likeNum, err := s.dao.CancelLike(c, mid, upMid, svid)
|
|||
|
if err != nil {
|
|||
|
log.Warnv(c, log.KV("log", "cancel like fail"))
|
|||
|
return
|
|||
|
}
|
|||
|
if likeNum == 0 {
|
|||
|
log.Infow(c, "log", "repeated cancel like", "mid", mid, "svid", svid)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
tx, err := s.dao.BeginTran(c)
|
|||
|
if err != nil {
|
|||
|
log.Error("cancel user like begin tran err(%v) mid(%d) svid(%d)", err, mid, svid)
|
|||
|
err = ecode.CancelUserLikeErr
|
|||
|
return
|
|||
|
}
|
|||
|
if num, err = s.dao.TxDecrVideoStatisticsLike(tx, svid); err != nil {
|
|||
|
err = ecode.CancelUserLikeErr
|
|||
|
tx.Rollback()
|
|||
|
return
|
|||
|
}
|
|||
|
if num == 0 {
|
|||
|
log.Errorw(c, "log", "desc video statistics fail maybe due to the missing in video_statistics table", "svid", svid)
|
|||
|
videoStatistics := &model.VideoStatistics{SVID: svid, Like: 0}
|
|||
|
if num, err = s.dao.TxAddVideoStatistics(tx, videoStatistics); err != nil || num == 0 {
|
|||
|
err = ecode.AddUserLikeErr
|
|||
|
tx.Rollback()
|
|||
|
return
|
|||
|
}
|
|||
|
res.Num = 1
|
|||
|
}
|
|||
|
tx.Commit()
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// UserLikeList 用户点赞列表
|
|||
|
// TODO: 这段代码和SpaceSvList基本一样,后面抽出共同代码
|
|||
|
func (s *Service) UserLikeList(c context.Context, req *v1.SpaceSvListRequest) (res v1.SpaceSvListResponse, err error) {
|
|||
|
// 0.前期校验
|
|||
|
// 这里就不校验up主是否存在
|
|||
|
upMid := req.UpMid
|
|||
|
if upMid == 0 {
|
|||
|
err = ecode.ReqParamErr
|
|||
|
log.Errorv(c, log.KV("event", "req_param"), log.KV("up_mid", 0))
|
|||
|
return
|
|||
|
}
|
|||
|
res.List = make([]*v1.SvDetail, 0)
|
|||
|
|
|||
|
// 1. 获取svid列表
|
|||
|
likeReply, err := s.dao.UserLikeList(c, upMid, req.CursorPrev, req.CursorNext)
|
|||
|
if err != nil {
|
|||
|
log.Errorv(c, log.KV("event", "user_like_list"), log.KV("error", err))
|
|||
|
return
|
|||
|
}
|
|||
|
res.HasMore = likeReply.HasMore
|
|||
|
|
|||
|
var svids []int64
|
|||
|
// svid, LikeSv
|
|||
|
likeSvs := make(map[int64]*user.LikeSv)
|
|||
|
for _, likeSv := range likeReply.List {
|
|||
|
svids = append(svids, likeSv.Svid)
|
|||
|
likeSvs[likeSv.Svid] = likeSv
|
|||
|
}
|
|||
|
|
|||
|
// 2.获取sv详情
|
|||
|
detailMap, err := s.getVideoDetail(c, req.MID, req.Qn, req.Device, svids, true)
|
|||
|
if err != nil {
|
|||
|
log.Warnv(c, log.KV("event", "get video detail fail"))
|
|||
|
return
|
|||
|
}
|
|||
|
for _, svID := range svids {
|
|||
|
item, exists := detailMap[svID]
|
|||
|
if !exists {
|
|||
|
item = new(v1.SvDetail)
|
|||
|
item.SVID = svID
|
|||
|
// TODO: 操蛋的客户端,这里等版本收敛之后可以删除
|
|||
|
item.IsLike = true
|
|||
|
item.Play.SVID = svID
|
|||
|
item.Play.FileInfo = []*v1.FileInfo{
|
|||
|
{},
|
|||
|
}
|
|||
|
item.Play.SupportQuality = make([]int64, 0)
|
|||
|
}
|
|||
|
if likeSv, exists := likeSvs[svID]; exists {
|
|||
|
item.CursorValue = likeSv.CursorValue
|
|||
|
}
|
|||
|
res.List = append(res.List, item)
|
|||
|
}
|
|||
|
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// ModifyRelation 关注、取关、拉黑、取消拉黑
|
|||
|
func (s *Service) ModifyRelation(c context.Context, mid, upMid int64, action int32) (res *user.ModifyRelationReply, err error) {
|
|||
|
res, err = s.dao.ModifyRelation(c, mid, upMid, action)
|
|||
|
if err != nil {
|
|||
|
log.Warnv(c, log.KV("log", "modify reltaion fail"))
|
|||
|
}
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// UserFollowList 关注列表
|
|||
|
// 注意:这里出现3种mid,visitor/host/host关注的mid,按顺序缩写为V、H、HF,其中根据H获取HF,然后计算V和HF的关注关系
|
|||
|
func (s *Service) UserFollowList(c context.Context, req *user.ListRelationUserInfoReq) (res *v1.UserRelationListResponse, err error) {
|
|||
|
res, err = s.dao.UserRelationList(c, req, user.Follow)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// UserFanList 粉丝列表
|
|||
|
func (s *Service) UserFanList(c context.Context, req *user.ListRelationUserInfoReq) (res *v1.UserRelationListResponse, err error) {
|
|||
|
res, err = s.dao.UserRelationList(c, req, user.Fan)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
// UserBlackList 黑名单列表
|
|||
|
func (s *Service) UserBlackList(c context.Context, req *user.ListRelationUserInfoReq) (res *v1.UserRelationListResponse, err error) {
|
|||
|
// 强制只能访问自己的拉黑名单
|
|||
|
req.UpMid = req.Mid
|
|||
|
res, err = s.dao.UserRelationList(c, req, user.Black)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//Login .
|
|||
|
func (s *Service) Login(c context.Context, req *user.UserBase) (res *user.UserBase, err error) {
|
|||
|
res, err = s.dao.Login(c, req)
|
|||
|
return
|
|||
|
}
|
|||
|
|
|||
|
//PhoneCheck ..
|
|||
|
func (s *Service) PhoneCheck(c context.Context, mid int64) (err error) {
|
|||
|
telStatus, err := s.dao.PhoneCheck(c, mid)
|
|||
|
if err != nil {
|
|||
|
return
|
|||
|
}
|
|||
|
if telStatus == 0 {
|
|||
|
err = ecode.BBQNoBindPhone
|
|||
|
return
|
|||
|
}
|
|||
|
return
|
|||
|
}
|