#33705 子任务 【梦工场系统】 <-后端-> 【铁匠破】图鉴需要一键激活

This commit is contained in:
meixiongfeng 2023-09-05 11:43:17 +08:00
parent 4871c79f75
commit bf96d301b0
3 changed files with 72 additions and 53 deletions

View File

@ -7,12 +7,7 @@ import (
// 参数校验 // 参数校验
func (this *apiComp) AtlasActivateCheck(session comm.IUserSession, req *pb.SmithyAtlasActivateReq) (errdata *pb.ErrorData) { func (this *apiComp) AtlasActivateCheck(session comm.IUserSession, req *pb.SmithyAtlasActivateReq) (errdata *pb.ErrorData) {
if req.Id == "" {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_ReqParameterError,
Title: pb.ErrorCode_ReqParameterError.ToString(),
}
}
return return
} }
@ -21,7 +16,9 @@ func (this *apiComp) AtlasActivate(session comm.IUserSession, req *pb.SmithyAtla
var ( var (
addScore int32 // 更新图鉴增加的积分 addScore int32 // 更新图鉴增加的积分
szTask []*pb.BuriedParam szTask []*pb.BuriedParam
update map[string]interface{}
) )
update = make(map[string]interface{}, 0)
if errdata = this.AtlasActivateCheck(session, req); errdata != nil { if errdata = this.AtlasActivateCheck(session, req); errdata != nil {
return // 参数校验失败直接返回 return // 参数校验失败直接返回
} }
@ -34,67 +31,89 @@ func (this *apiComp) AtlasActivate(session comm.IUserSession, req *pb.SmithyAtla
} }
return return
} }
conf, err := this.module.configure.GetSmithyAtlasConf(req.Id)
if err != nil { if req.Id == "" { // 一键激活
errdata = &pb.ErrorData{ for _, v := range atlas.Atlas {
Code: pb.ErrorCode_SmithyNoFoundAtlas, if !v.Activate {
Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(),
}
return
}
if conf.TypeId == 1 {
if v, ok := atlas.Atlas[req.Id]; ok {
if !v.Activate { // 激活
v.Activate = true v.Activate = true
addScore = v.Data1.Score addScore = v.Data1.Score
} else { //更新操作 }
if v.Data2 != nil { if v.Data2 != nil {
addScore = v.Data2.Score - v.Data1.Score addScore = v.Data2.Score - v.Data1.Score
if addScore < 0 { // 异常校验 防止配置修改导致分数减少 if addScore < 0 { // 异常校验 防止配置修改导致分数减少
addScore = 0 addScore = 0
}
v.Data1 = v.Data2
v.Data2 = nil
} else {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoActivateAtlas,
Title: pb.ErrorCode_SmithyNoActivateAtlas.ToString(),
}
return
} }
v.Data1 = v.Data2
v.Data2 = nil
} }
update := make(map[string]interface{}, 0)
update["atlas"] = atlas.Atlas
atlas.Score += addScore atlas.Score += addScore
update["score"] = atlas.Score
this.module.modelAtlas.modifySmithyAtlasList(session.GetUserId(), update)
} else {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoFoundAtlas,
Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(),
}
return
} }
update["atlas"] = atlas.Atlas
} else if conf.TypeId == 2 { for _, v := range atlas.Collect {
if v, ok := atlas.Collect[req.Id]; ok {
if !v.Activate { // 激活 if !v.Activate { // 激活
v.Activate = true v.Activate = true
update := make(map[string]interface{}, 0)
update["collect"] = atlas.Collect
atlas.Score += v.Score atlas.Score += v.Score
update["score"] = atlas.Score
this.module.modelAtlas.modifySmithyAtlasList(session.GetUserId(), update)
} }
} else { }
} else {
conf, err := this.module.configure.GetSmithyAtlasConf(req.Id)
if err != nil {
errdata = &pb.ErrorData{ errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoFoundAtlas, Code: pb.ErrorCode_SmithyNoFoundAtlas,
Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(), Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(),
} }
return return
} }
if conf.TypeId == 1 {
if v, ok := atlas.Atlas[req.Id]; ok {
if !v.Activate { // 激活
v.Activate = true
addScore = v.Data1.Score
} else { //更新操作
if v.Data2 != nil {
addScore = v.Data2.Score - v.Data1.Score
if addScore < 0 { // 异常校验 防止配置修改导致分数减少
addScore = 0
}
v.Data1 = v.Data2
v.Data2 = nil
} else {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoActivateAtlas,
Title: pb.ErrorCode_SmithyNoActivateAtlas.ToString(),
}
return
}
}
update["atlas"] = atlas.Atlas
atlas.Score += addScore
update["score"] = atlas.Score
} else {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoFoundAtlas,
Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(),
}
return
}
} else if conf.TypeId == 2 {
if v, ok := atlas.Collect[req.Id]; ok {
if !v.Activate { // 激活
v.Activate = true
atlas.Score += v.Score
}
} else {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_SmithyNoFoundAtlas,
Title: pb.ErrorCode_SmithyNoFoundAtlas.ToString(),
}
return
}
}
} }
update["score"] = atlas.Score
update["collect"] = atlas.Collect
this.module.modelAtlas.modifySmithyAtlasList(session.GetUserId(), update)
szTask = append(szTask, comm.GetBuriedParam(comm.Rtype165, 1)) szTask = append(szTask, comm.GetBuriedParam(comm.Rtype165, 1))
szTask = append(szTask, comm.GetBuriedParam(comm.Rtype166, int32(len(atlas.Collect)))) szTask = append(szTask, comm.GetBuriedParam(comm.Rtype166, int32(len(atlas.Collect))))
szTask = append(szTask, comm.GetBuriedParam(comm.Rtype167, atlas.Score)) szTask = append(szTask, comm.GetBuriedParam(comm.Rtype167, atlas.Score))

View File

@ -32,7 +32,7 @@ func (this *apiComp) AtlasAward(session comm.IUserSession, req *pb.SmithyAtlasAw
return return
} }
for { for {
conf, err := this.module.configure.GetSmithyAtlasLvConf(atlas.Award + 1) conf, err := this.module.configure.GetSmithyAtlasLvConf(atlas.Award)
if err != nil { if err != nil {
break break
} }

View File

@ -76,7 +76,7 @@ func (this *Smithy) CheckActivateAtlasCollect(uid string, id string) {
atlas.Collect[id] = &pb.CollectData{ atlas.Collect[id] = &pb.CollectData{
Id: id, Id: id,
Score: 0, Score: atlasConf.AtlasScore,
Time: configure.Now().Unix(), Time: configure.Now().Unix(),
Activate: false, Activate: false,
} }
@ -94,7 +94,7 @@ func (this *Smithy) CheckActivateAtlasCollect(uid string, id string) {
if _, ok := atlas.Collect[id]; !ok { if _, ok := atlas.Collect[id]; !ok {
atlas.Collect[id] = &pb.CollectData{ atlas.Collect[id] = &pb.CollectData{
Id: id, Id: id,
Score: 0, Score: atlasConf.AtlasScore,
Time: configure.Now().Unix(), Time: configure.Now().Unix(),
Activate: false, Activate: false,
} }