You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
799 lines
24 KiB
799 lines
24 KiB
package service |
|
|
|
import ( |
|
"context" |
|
"time" |
|
|
|
adminmodel "go-common/app/admin/main/mcn/model" |
|
"go-common/app/interface/main/mcn/dao/cache" |
|
"go-common/app/interface/main/mcn/dao/global" |
|
"go-common/app/interface/main/mcn/model" |
|
"go-common/app/interface/main/mcn/model/mcnmodel" |
|
accgrpc "go-common/app/service/main/account/api" |
|
memgrpc "go-common/app/service/main/member/api" |
|
memmdl "go-common/app/service/main/member/model" |
|
"go-common/app/service/main/member/model/block" |
|
"go-common/library/ecode" |
|
"go-common/library/log" |
|
"go-common/library/net/metadata" |
|
|
|
"go-common/app/interface/main/mcn/conf" |
|
"go-common/app/interface/main/mcn/dao/mcndao" |
|
|
|
"strings" |
|
|
|
"github.com/jinzhu/gorm" |
|
) |
|
|
|
// getMcnWithState |
|
// if state is nil, state is not checked |
|
func (s *Service) getMcnWithState(c context.Context, mcnmid int64, state ...model.MCNSignState) (mcnSign *mcnmodel.McnSign, err error) { |
|
mcnSign, err = s.mcndao.McnSign(c, mcnmid) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
if mcnSign == nil { |
|
err = ecode.NothingFound |
|
return |
|
} |
|
var ok = false |
|
if state == nil { |
|
ok = true |
|
} else { |
|
for _, s := range state { |
|
if mcnSign.State == s { |
|
ok = true |
|
break |
|
} |
|
} |
|
} |
|
|
|
if !ok { |
|
log.Info("mcnmid=%d, mcn is in %d, should in (%v)", mcnmid, mcnSign.State, state) |
|
err = ecode.MCNNotAllowed |
|
return |
|
} |
|
return |
|
} |
|
|
|
func (s *Service) checkPermission(c context.Context, mcnMid, upMid int64, permissions ...adminmodel.AttrBasePermit) (res bool) { |
|
var permLen = len(permissions) |
|
if permLen == 0 { |
|
return |
|
} else if permLen == 1 { |
|
// 基础权限直接放过 |
|
if permissions[0] == adminmodel.AttrBasePermitBit { |
|
return true |
|
} |
|
} |
|
|
|
mcnSign, err := s.getMcnWithState(c, mcnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
log.Error("get mcn fail, mcnmid=%d, err=%v", mcnMid, err) |
|
return |
|
} |
|
|
|
permForUp, err := s.mcndao.UpPermission(c, mcnSign.ID, upMid) |
|
if err != nil || permForUp == nil { |
|
log.Error("get up permission fail, signID=%d, upmid=%d, err=%v or up not found", mcnSign.ID, upMid, err) |
|
return |
|
} |
|
|
|
// 比较mcn与up的权限 |
|
var wantPermission uint32 |
|
for _, v := range permissions { |
|
wantPermission = wantPermission | (1 << v) |
|
} |
|
var resultPermission = wantPermission & mcnSign.Permission & permForUp.Permission |
|
if resultPermission != wantPermission { |
|
log.Warn("mcn doesnt have permission, mcn perm=0x%x, up perm=0x%x, want=0x%x, lack=0x%x", mcnSign.Permission, permForUp.Permission, wantPermission, resultPermission^wantPermission) |
|
return |
|
} |
|
res = true |
|
return |
|
} |
|
|
|
//McnGetState mcn state |
|
func (s *Service) McnGetState(c context.Context, arg *mcnmodel.GetStateReq) (res *mcnmodel.McnGetStateReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
res = new(mcnmodel.McnGetStateReply) |
|
res.State = int8(mcnSign.State) |
|
if mcnSign.State == model.MCNSignStateOnReject { |
|
res.RejectReason = mcnSign.RejectReason |
|
} |
|
log.Info("mcn_state=%d, mcn_id=%d", res.State, arg.McnMid) |
|
return |
|
} |
|
|
|
//McnExist . |
|
func (s *Service) McnExist(c context.Context, arg *mcnmodel.GetStateReq) (res *mcnmodel.McnExistReply, err error) { |
|
res = new(mcnmodel.McnExistReply) |
|
_, err = s.getMcnWithState(c, arg.McnMid) |
|
if err == ecode.NothingFound { |
|
res.Exist = 0 |
|
return |
|
} else if err != nil { |
|
log.Error("error get state, err=%s", err) |
|
return |
|
} |
|
|
|
res.Exist = 1 |
|
return |
|
} |
|
|
|
// McnBaseInfo . |
|
func (s *Service) McnBaseInfo(c context.Context, arg *mcnmodel.GetStateReq) (res *mcnmodel.McnBaseInfoReply, err error) { |
|
res = new(mcnmodel.McnBaseInfoReply) |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
res.CopyFromMcnInfo(mcnSign) |
|
return |
|
} |
|
|
|
//McnApply . |
|
func (s *Service) McnApply(c context.Context, arg *mcnmodel.McnApplyReq) (res *mcnmodel.CommonReply, err error) { |
|
|
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnReject, model.MCNSignStateNoApply) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
var sign mcnmodel.McnSign |
|
if err = s.uniqueChecker.CheckIsUniqe(arg); err != nil { |
|
log.Info("check unique fail, err=%s, arg=%v", err, arg) |
|
return |
|
} |
|
|
|
arg.CopyTo(&sign) |
|
sign.ID = mcnSign.ID |
|
sign.State = model.MCNSignStateOnReview |
|
var db = s.mcndao.GetMcnDB() |
|
if err = db.Table(sign.TableName()).Where("id=?", sign.ID).Updates(map[string]interface{}{ |
|
"company_name": sign.CompanyName, |
|
"company_license_id": sign.CompanyLicenseID, |
|
"contact_name": sign.ContactName, |
|
"contact_title": sign.ContactTitle, |
|
"contact_idcard": sign.ContactIdcard, |
|
"contact_phone": sign.ContactPhone, |
|
"company_license_link": sign.CompanyLicenseLink, |
|
"contract_link": sign.ContractLink, |
|
"state": sign.State, |
|
}).Error; err != nil { |
|
log.Error("save mcn fail, mcn mid=%d, row id=%d", sign.McnMid, sign.ID) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
s.mcndao.DelCacheMcnSign(c, arg.McnMid) |
|
s.worker.Add(func() { |
|
s.loadMcnUniqueCache() |
|
}) |
|
return |
|
} |
|
|
|
//McnBindUpApply . |
|
func (s *Service) McnBindUpApply(c context.Context, arg *mcnmodel.McnBindUpApplyReq) (res *mcnmodel.McnBindUpApplyReply, err error) { |
|
if arg.BeginDate > arg.EndDate { |
|
err = ecode.MCNUpBindUpSTimeLtETime |
|
return |
|
} |
|
// 查询mcn状态 |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
// 0.检查是否封禁 |
|
var blockArg = memgrpc.MemberMidReq{Mid: arg.UpMid, RemoteIP: metadata.String(c, metadata.RemoteIP)} |
|
var blockInfo, e = global.GetMemGRPC().BlockInfo(c, &blockArg) |
|
if e == nil { |
|
if blockInfo.BlockStatus > int32(block.BlockStatusFalse) { |
|
log.Info("up is blocked, mid=%d, blockstatus=%d", arg.UpMid, blockInfo.BlockStatus) |
|
err = ecode.MCNUpBindUpIsBlocked |
|
return |
|
} |
|
} else { |
|
log.Error("get block info error, err=%s", e) |
|
} |
|
|
|
// 1.检查是否是蓝V用户 |
|
var ( |
|
memberInfo *memgrpc.MemberInfoReply |
|
memberArg = memgrpc.MemberMidReq{Mid: arg.UpMid, RemoteIP: metadata.String(c, metadata.RemoteIP)} |
|
) |
|
if memberInfo, err = global.GetMemGRPC().Member(c, &memberArg); err != nil { |
|
log.Error("get member info error, err=%s", err) |
|
} else { |
|
if memberInfo.OfficialInfo != nil && |
|
(memberInfo.OfficialInfo.Role == memmdl.OfficialRoleBusiness || |
|
memberInfo.OfficialInfo.Role == memmdl.OfficialRoleGov || |
|
memberInfo.OfficialInfo.Role == memmdl.OfficialRoleMedia || |
|
memberInfo.OfficialInfo.Role == memmdl.OfficialRoleOther) { |
|
err = ecode.MCNUpBindUpIsBlueUser |
|
return |
|
} |
|
} |
|
|
|
// 2.查询当前up状态 |
|
upList, err := s.mcndao.GetUpBind("up_mid=?", arg.UpMid) |
|
if err != nil { |
|
log.Error("get up bind fail, err=%s", err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
|
|
// 3.可以申请绑定的up主才能绑定 |
|
var mcnUp *mcnmodel.McnUp |
|
for _, v := range upList { |
|
if !v.IsBindable() { |
|
log.Info("up is in state(%d), cannot be bind again. id=%d, upmid=%d, signid=%d, mcnSign=%d", v.State, v.ID, v.UpMid, v.SignID, v.McnMid) |
|
err = ecode.MCNUpCannotBind |
|
return |
|
} |
|
if v.IsBeingBindedWithMcn(mcnSign) { |
|
log.Info("up is being binded with mcnSign, state=%d, id=%d, signid=%d, mcnSign=%d, mcn_mid=%d", v.State, v.State, v.ID, v.SignID, v.McnMid) |
|
err = ecode.MCNUpBindUpAlreadyInProgress |
|
return |
|
} |
|
if v.SignID == mcnSign.ID { |
|
mcnUp = v |
|
} |
|
} |
|
|
|
if arg.UpType == 1 { |
|
// 站外up主需要满足条件: |
|
// 1.粉丝数≤100 或 2. 投稿数<2及90天内未投稿 (1,2并列关系,满足其一即可申请) |
|
baseInfoMap, e := s.mcndao.GetUpBaseInfo("article_count_accumulate, activity, fans_count, mid", []int64{arg.UpMid}) |
|
if e == nil { |
|
var upInfo, ok = baseInfoMap[arg.UpMid] |
|
if ok && upInfo != nil { |
|
//upInfo.Activity 1高,2中,3低,4流失 |
|
//高=30天内有投稿 |
|
//中=31~90天内有投稿 |
|
//低=91~180天内有投稿 |
|
//流失=180内以上未投稿 |
|
if !(upInfo.FansCount <= 100 || (upInfo.ArticleCountAccumulate < 2 && upInfo.Activity > 2)) { |
|
err = ecode.MCNUpOutSiteIsNotQualified |
|
log.Error("outsite cannot bind, up fans count(%d) > 100", upInfo.FansCount) |
|
return |
|
} |
|
} else { |
|
log.Warn("up info is not found in up base info, up=%d", arg.UpMid) |
|
} |
|
} |
|
} |
|
|
|
// 站外信息是否OK |
|
if !arg.IsSiteInfoOk() { |
|
err = ecode.MCNUpBindInvalidURL |
|
log.Warn("arg error, up is out site up, but site url is not valid, arg=%v", arg) |
|
return |
|
} |
|
|
|
// 只能设置mcn自己有的权限,如果要设置其他权限,返回错误。 |
|
// 只有mcn有的权限,才可以申请up主的权限 |
|
_, err = mcnShouldContainUpPermission(mcnSign.Permission, arg.GetAttrPermitVal()) |
|
if err != nil { |
|
return |
|
} |
|
|
|
// 3.绑定Up主,如果已有记录,则更新记录 |
|
bindup, affectedRow, err := s.mcndao.BindUp(mcnUp, mcnSign, arg) |
|
if err != nil { |
|
log.Error("fail to bind up, mcnmid=%d, upmid=%d err=%s", arg.McnMid, arg.UpMid, err) |
|
return |
|
} |
|
res = new(mcnmodel.McnBindUpApplyReply) |
|
res.BindID = bindup.ID |
|
// 4.发送站内信息 |
|
if arg.UpMid != arg.McnMid { |
|
var nickname = global.GetName(c, arg.McnMid) |
|
var msg = adminmodel.ArgMsg{ |
|
MSGType: adminmodel.McnUpBindAuthApply, |
|
MIDs: []int64{arg.UpMid}, |
|
McnName: nickname, |
|
McnMid: arg.McnMid, |
|
CompanyName: mcnSign.CompanyName, |
|
SignUpID: bindup.ID, |
|
} |
|
s.sendMsg(&msg) |
|
} |
|
log.Info("bind up apply success, mcn=%d, upmid=%d, rowaffected=%d", arg.McnMid, arg.UpMid, affectedRow) |
|
return |
|
} |
|
|
|
//McnUpConfirm . |
|
func (s *Service) McnUpConfirm(c context.Context, arg *mcnmodel.McnUpConfirmReq) (res *mcnmodel.CommonReply, err error) { |
|
|
|
// 1.查询当前up状态 |
|
upList, err := s.mcndao.GetUpBind("id=? and up_mid=? and state=?", arg.BindID, arg.UpMid, model.MCNUPStateNoAuthorize) |
|
if err != nil { |
|
log.Error("get up bind fail, err=%s", err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
|
|
// 不存在 |
|
if len(upList) == 0 { |
|
log.Info("bind id not found, id=%d", arg.BindID) |
|
err = ecode.MCNNotAllowed |
|
return |
|
} |
|
|
|
var upBind = upList[0] |
|
// 查询mcn状态 |
|
mcnSign, err := s.getMcnWithState(c, upBind.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.MCNStateInvalid { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
if mcnSign.ID != upBind.SignID { |
|
log.Error("bind id not same with mcn signid, bind id=%d, signid=%d", upBind.ID, upBind.SignID) |
|
err = ecode.MCNUpBindInvalid |
|
return |
|
} |
|
|
|
var state = model.MCNUPStateOnRefuse |
|
if arg.Choice { |
|
state = model.MCNUPStateOnReview |
|
} |
|
// 更新状态 |
|
err = s.mcndao.UpConfirm(arg, state) |
|
if err != nil { |
|
log.Error("fail to update up bind, bind id=%d, upmid=%d, err=%s", arg.BindID, arg.UpMid, err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
// 同意 |
|
if arg.Choice { |
|
var mcnName = global.GetName(c, mcnSign.McnMid) |
|
var msg = adminmodel.ArgMsg{ |
|
MSGType: adminmodel.McnUpBindAuthReview, |
|
MIDs: []int64{arg.UpMid}, |
|
McnName: mcnName, |
|
McnMid: mcnSign.McnMid, |
|
CompanyName: mcnSign.CompanyName, |
|
} |
|
s.sendMsg(&msg) |
|
} else { |
|
var upName = global.GetName(c, arg.UpMid) |
|
var msg = adminmodel.ArgMsg{ |
|
MSGType: adminmodel.McnUpBindAuthApplyRefuse, |
|
MIDs: []int64{mcnSign.McnMid}, |
|
UpMid: arg.UpMid, |
|
UpName: upName, |
|
} |
|
s.sendMsg(&msg) |
|
} |
|
log.Info("up bind change, bind id=%d, upmid=%d, isaccept=%t", arg.BindID, arg.UpMid, arg.Choice) |
|
return |
|
} |
|
|
|
//McnUpGetBind . |
|
func (s *Service) McnUpGetBind(c context.Context, arg *mcnmodel.McnUpGetBindReq) (res *mcnmodel.McnGetBindReply, err error) { |
|
res, err = s.mcndao.GetBindInfo(arg) |
|
if err != nil { |
|
log.Error("fail to get bind info, err=%s", err) |
|
return |
|
} |
|
|
|
accInfo, err := global.GetInfo(c, int64(res.McnMid)) |
|
if err == nil && accInfo != nil { |
|
res.McnName = accInfo.Name |
|
} |
|
|
|
res.Finish() |
|
res.UpAuthLink = model.BuildBfsURL(res.UpAuthLink, s.c.BFS.Key, s.c.BFS.Secret, s.c.BFS.Bucket, model.BfsEasyPath) |
|
return |
|
} |
|
|
|
//McnDataSummary . |
|
func (s *Service) McnDataSummary(c context.Context, arg *mcnmodel.McnGetDataSummaryReq) (res *mcnmodel.McnGetDataSummaryReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
var today = time.Now().Add(-12 * time.Hour) |
|
res, err = s.datadao.GetMcnSummaryCache(c, mcnSign.ID, today) |
|
if err != nil { |
|
log.Error("fail to get mcn data, sign id=%d, mcnmid=%d, err=%s", mcnSign.ID, mcnSign.McnMid, err) |
|
return |
|
} |
|
// today is not found, try yesterday |
|
if res == nil { |
|
res, err = s.mcndao.McnDataSummary(c, mcnSign.ID, today.AddDate(0, 0, -1)) |
|
if err != nil { |
|
log.Error("fail to get mcn data, sign id=%d, mcnmid=%d, err=%s", mcnSign.ID, mcnSign.McnMid, err) |
|
return |
|
} |
|
} |
|
|
|
if res == nil { |
|
log.Error("fail to get mcn data, res = nil, sign id=%d", mcnSign.ID) |
|
res = new(mcnmodel.McnGetDataSummaryReply) |
|
} |
|
return |
|
} |
|
|
|
//McnDataUpList . |
|
func (s *Service) McnDataUpList(c context.Context, arg *mcnmodel.McnGetUpListReq) (res *mcnmodel.McnGetUpListReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
generateDate, err := s.mcndao.GetDataUpLatestDate(mcnmodel.DataTypeAccumulate, mcnSign.ID) |
|
if err != nil { |
|
if err == gorm.ErrRecordNotFound { |
|
err = nil |
|
log.Warn("no data list found for mcn=%d, sign id=%d", mcnSign.McnMid, mcnSign.ID) |
|
var now = time.Now() |
|
generateDate = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, time.Local) |
|
} else { |
|
log.Error("fail to get latest generate up date, err=%s", err) |
|
return |
|
} |
|
} |
|
|
|
// 获取数据 |
|
upData, err := s.mcndao.GetAllUpData(int64(mcnSign.ID), arg.UpMid, generateDate) |
|
// 在正式数据出来之前,临时使用 |
|
//upData, err := s.mcndao.GetAllUpDataTemp(int64(mcnSign.ID), arg.UpMid, time.Now()) |
|
var mids []int64 |
|
for _, v := range upData { |
|
mids = append(mids, v.UpMid) |
|
v.Permission = v.Permission & mcnSign.Permission |
|
} |
|
var infosReply *accgrpc.InfosReply |
|
var midtidmap map[int64]int64 |
|
var accInfos map[int64]*accgrpc.Info |
|
if len(mids) > 0 { |
|
var e error |
|
infosReply, e = global.GetAccGRPC().Infos3(c, &accgrpc.MidsReq{Mids: mids}) |
|
if e != nil { |
|
log.Warn("fail to get info, err=%s", e) |
|
} else { |
|
accInfos = infosReply.Infos |
|
} |
|
|
|
midtidmap, e = s.mcndao.GetActiveTid(mids) |
|
if e != nil { |
|
log.Warn("fail to get activit, err=%s", e) |
|
} |
|
} |
|
res = new(mcnmodel.McnGetUpListReply) |
|
for _, v := range upData { |
|
var info, ok = accInfos[v.UpMid] |
|
if ok { |
|
v.Name = info.Name |
|
} |
|
if v.State != int8(model.MCNUPStateOnSign) { |
|
// MCNUPStateOnSign 与 MCNUPStateOnPreOpen 状态下 不隐藏时间 |
|
v.HideData(!(v.State == int8(model.MCNUPStateOnSign) || |
|
v.State == int8(model.MCNUPStateOnPreOpen))) |
|
} |
|
|
|
tid, ok := midtidmap[v.UpMid] |
|
if ok { |
|
v.TidName = cache.GetTidName(tid) |
|
v.ActiveTid = int16(tid) |
|
} |
|
res.Result = append(res.Result, v) |
|
} |
|
res.Finish() |
|
return |
|
} |
|
|
|
//McnGetOldInfo . |
|
func (s *Service) McnGetOldInfo(c context.Context, arg *mcnmodel.McnGetMcnOldInfoReq) (res *mcnmodel.McnGetMcnOldInfoReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateNoApply) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
info, err := s.mcndao.GetMcnOldInfo(mcnSign.McnMid) |
|
if err != nil { |
|
if err == ecode.NothingFound { |
|
err = nil |
|
} else { |
|
log.Error("fail get mcn old info err=%s", err) |
|
return |
|
} |
|
} |
|
|
|
res = new(mcnmodel.McnGetMcnOldInfoReply) |
|
res.Copy(info) |
|
return |
|
} |
|
|
|
func getUpPermitString(permission uint32) (ps []string) { |
|
for permit := range adminmodel.PermitMap { |
|
var p = adminmodel.AttrVal(permission, uint(permit)) |
|
if p <= 0 { |
|
continue |
|
} |
|
ps = append(ps, permit.String()) |
|
} |
|
return |
|
} |
|
|
|
// 检查up主权限,是否是mcn的子集 |
|
// mcnPermission mcn自己的permission |
|
// upPermission up的permission |
|
// return finalPermission = mcnPermission &upPermission |
|
func mcnShouldContainUpPermission(mcnPermission, upPermission uint32) (finalPermission uint32, err error) { |
|
// 3.只能设置mcn自己有的权限,如果要设置其他权限,返回错误。 |
|
// 只有mcn有的权限,才可以申请up主的权限 |
|
finalPermission = mcnPermission & upPermission |
|
if finalPermission != upPermission { |
|
log.Error("mcn has no permission to change, mcn=0x%x, wantup=0x%x, notallowd=0x%x", mcnPermission, upPermission, finalPermission^upPermission) |
|
err = ecode.MCNChangePermissionLackPermission |
|
return |
|
} |
|
return |
|
} |
|
|
|
//McnChangePermit change up's permission |
|
func (s *Service) McnChangePermit(c context.Context, arg *mcnmodel.McnChangePermitReq) (res *mcnmodel.McnChangePermitReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
// 1.检查Up主关系,只有“已签约”,“待开启”状态的Up主可以修改 |
|
// 2.查询当前up状态 |
|
upList, err := s.mcndao.GetUpBind("up_mid=? and sign_id=? and state in (?)", arg.UpMid, mcnSign.ID, mcndao.UpSignedStates) |
|
if err != nil { |
|
log.Error("get up bind fail, err=%v", err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
|
|
if len(upList) == 0 { |
|
log.Error("up is not in signed state with mcn, up_mid=%d and sign_id=%d , need state in (%v)", arg.UpMid, mcnSign.ID, mcndao.UpSignedStates) |
|
err = ecode.MCNUpSignStateInvalid |
|
return |
|
} |
|
var oldUp = upList[0] |
|
var newPermission = arg.GetAttrPermitVal() |
|
if oldUp.Permission == uint32(newPermission) { |
|
log.Error("permission not changed, arg=%+v", arg) |
|
err = ecode.MCNChangePermissionSamePermission |
|
return |
|
} |
|
// 2.只能设置mcn自己有的权限,如果要设置其他权限,返回错误。 |
|
// 只有mcn有的权限,才可以申请up主的权限 |
|
maskedPermission, err := mcnShouldContainUpPermission(mcnSign.Permission, newPermission) |
|
if err != nil { |
|
return |
|
} |
|
|
|
// 如果是自己,则直接进行修改 |
|
if arg.UpMid == mcnSign.McnMid { |
|
var _, e = s.mcndao.UpdateBindUp(map[string]interface{}{ |
|
"permission": maskedPermission, |
|
}, "up_mid=? and sign_id=?", arg.UpMid, mcnSign.ID) |
|
if e != nil { |
|
err = e |
|
log.Error("fail to change up permission, err=%v, arg=%v", err, arg) |
|
return |
|
} |
|
return |
|
} |
|
|
|
// 3.检查是否有对应up主的修改请求,如果有就拒绝这次修改 |
|
existedApply, _ := s.mcndao.GetUpPermissionApply("id", "sign_id=? and up_mid=? and state in (?)", mcnSign.ID, arg.UpMid, mcndao.UpPermissionApplyCannotApplyStates) |
|
if len(existedApply) > 0 { |
|
log.Error("apply already exist, id=%d, sign id=%d, mid=%d", existedApply[0].ID, existedApply[0].SignID, existedApply[0].UpMid) |
|
err = ecode.MCNChangePermissionAlreadyInProgress |
|
return |
|
} |
|
|
|
// 真的去增加permission |
|
var permissionApply = mcnmodel.McnUpPermissionApply{ |
|
SignID: mcnSign.ID, |
|
McnMid: mcnSign.McnMid, |
|
UpMid: arg.UpMid, |
|
NewPermission: maskedPermission, |
|
OldPermission: oldUp.Permission, |
|
UpAuthLink: arg.UpAuthLink, |
|
} |
|
|
|
var db = s.mcndao.GetMcnDB() |
|
err = db.Create(&permissionApply).Error |
|
if err != nil { |
|
log.Error("create permission apply fail, err=%v, arg=%+v", err, arg) |
|
return |
|
} |
|
// 返回bind_id |
|
res = &mcnmodel.McnChangePermitReply{BindID: permissionApply.ID} |
|
// 4.发送站内信息 |
|
if arg.UpMid != arg.McnMid { |
|
var nickname = global.GetName(c, arg.McnMid) |
|
var msg = adminmodel.ArgMsg{ |
|
MSGType: adminmodel.McnApplyUpChangePermit, |
|
MIDs: []int64{arg.UpMid}, |
|
McnName: nickname, |
|
McnMid: arg.McnMid, |
|
CompanyName: mcnSign.CompanyName, |
|
SignUpID: permissionApply.ID, |
|
Permission: strings.Join(getUpPermitString(maskedPermission), "、"), |
|
} |
|
s.sendMsg(&msg) |
|
} |
|
return |
|
} |
|
|
|
//McnPermitApplyGetBind get permit apply bind |
|
func (s *Service) McnPermitApplyGetBind(c context.Context, arg *mcnmodel.McnUpGetBindReq) (res *mcnmodel.McnGetBindReply, err error) { |
|
res, err = s.mcndao.GetUpPermissionBindInfo(arg) |
|
if err != nil { |
|
log.Error("fail to get bind info, err=%s", err) |
|
return |
|
} |
|
|
|
accInfo, err := global.GetInfo(c, int64(res.McnMid)) |
|
if err == nil && accInfo != nil { |
|
res.McnName = accInfo.Name |
|
} |
|
|
|
res.Finish() |
|
res.UpAuthLink = model.BuildBfsURL(res.UpAuthLink, s.c.BFS.Key, s.c.BFS.Secret, s.c.BFS.Bucket, model.BfsEasyPath) |
|
return |
|
} |
|
|
|
//McnUpPermitApplyConfirm permit apply confirm |
|
func (s *Service) McnUpPermitApplyConfirm(c context.Context, arg *mcnmodel.McnUpConfirmReq) (res *mcnmodel.CommonReply, err error) { |
|
|
|
// 1.查询当前up状态 |
|
upList, err := s.mcndao.GetUpPermissionApply("*", "id=? and up_mid=? and state=?", arg.BindID, arg.UpMid, adminmodel.MCNUPPermissionStateNoAuthorize) |
|
if err != nil { |
|
log.Error("get up bind fail, err=%s", err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
|
|
// 不存在 |
|
if len(upList) == 0 { |
|
log.Info("bind id not found, id=%d", arg.BindID) |
|
err = ecode.MCNNotAllowed |
|
return |
|
} |
|
|
|
var upBind = upList[0] |
|
// 查询mcn状态 |
|
mcnSign, err := s.getMcnWithState(c, upBind.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.MCNStateInvalid { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
if mcnSign.ID != upBind.SignID { |
|
log.Error("bind id not same with mcn signid, bind id=%d, signid=%d", upBind.ID, upBind.SignID) |
|
err = ecode.MCNUpBindInvalid |
|
return |
|
} |
|
|
|
var state = adminmodel.MCNUPPermissionStateOnRefuse |
|
if arg.Choice { |
|
state = adminmodel.MCNUPPermissionStateReview |
|
} |
|
// 更新状态 |
|
err = s.mcndao.UpPermissionConfirm(arg, state) |
|
if err != nil { |
|
log.Error("fail to update up bind, bind id=%d, upmid=%d, err=%s", arg.BindID, arg.UpMid, err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
// 同意 |
|
if arg.Choice { |
|
// do nothing. |
|
} else { |
|
var upName = global.GetName(c, arg.UpMid) |
|
var msg = adminmodel.ArgMsg{ |
|
MSGType: adminmodel.McnUpNotAgreeChangePermit, |
|
MIDs: []int64{mcnSign.McnMid}, |
|
UpMid: arg.UpMid, |
|
UpName: upName, |
|
} |
|
s.sendMsg(&msg) |
|
} |
|
log.Info("up permission bind change, bind id=%d, upmid=%d, isaccept=%t", arg.BindID, arg.UpMid, arg.Choice) |
|
return |
|
} |
|
|
|
//McnPublicationPriceChange . |
|
func (s *Service) McnPublicationPriceChange(c context.Context, arg *mcnmodel.McnPublicationPriceChangeReq) (res *mcnmodel.McnPublicationPriceChangeReply, err error) { |
|
mcnSign, err := s.getMcnWithState(c, arg.McnMid, model.MCNSignStateOnSign) |
|
if err != nil { |
|
if err != ecode.NothingFound { |
|
log.Error("error get state, err=%s", err) |
|
} |
|
return |
|
} |
|
|
|
// 1.检查上次刊例价修改时间,如果时间内不能修改返回错误 |
|
publicationPriceCache, e := s.mcndao.CachePublicationPrice(c, mcnSign.ID, arg.UpMid) |
|
if e != nil { |
|
log.Warn("get modify time from cache fail, arg=%+v, err=%v", arg, err) |
|
} |
|
|
|
if publicationPriceCache == nil { |
|
// 初始化为0值 |
|
publicationPriceCache = &mcnmodel.PublicationPriceCache{} |
|
} |
|
|
|
var lastModifyTime = publicationPriceCache.ModifyTime // 从缓存中获取 |
|
var now = time.Now() |
|
if now.Before(lastModifyTime.Add(time.Duration(conf.Conf.Other.PublicationPriceChangeLimit))) { |
|
log.Error("publication change fail, last modify time=%s, timelimit=%+v, arg=%+v", lastModifyTime, conf.Conf.Other.PublicationPriceChangeLimit, arg) |
|
err = ecode.MCNPublicationFailTimeLimit |
|
return |
|
} |
|
|
|
// 2.检查Up主关系,只有“已签约”,“待开启”状态的Up主可以修改 |
|
upList, err := s.mcndao.GetUpBind("up_mid=? and sign_id=? and state in (?)", arg.UpMid, mcnSign.ID, mcndao.UpSignedStates) |
|
if err != nil { |
|
log.Error("get up bind fail, err=%v", err) |
|
err = ecode.ServerErr |
|
return |
|
} |
|
|
|
if len(upList) == 0 { |
|
log.Error("up is not in signed state with mcn, up_mid=%d and sign_id=%d , need state in (%v)", arg.UpMid, mcnSign.ID, mcndao.UpSignedStates) |
|
err = ecode.MCNUpSignStateInvalid |
|
return |
|
} |
|
|
|
var up = upList[0] |
|
// 3.修改刊例价,更新上次修改时间 |
|
var db = s.mcndao.GetMcnDB() |
|
err = db.Table(mcnmodel.TableNameMcnUp).Where("id=?", up.ID).Update("publication_price", arg.Price).Error |
|
if err != nil { |
|
log.Error("change publication price fail, err=%v, arg=%+v", err, arg) |
|
return |
|
} |
|
publicationPriceCache.ModifyTime = now |
|
e = s.mcndao.AddCachePublicationPrice(c, mcnSign.ID, publicationPriceCache, arg.UpMid) |
|
if e != nil { |
|
log.Warn("fail to add cache, arg=%+v, err=%v", arg, e) |
|
} |
|
return |
|
}
|
|
|