165 lines
4.8 KiB
Go
165 lines
4.8 KiB
Go
package wtask
|
|
|
|
import (
|
|
"fmt"
|
|
"go_dreamfactory/comm"
|
|
"go_dreamfactory/lego/sys/log"
|
|
"go_dreamfactory/pb"
|
|
cfg "go_dreamfactory/sys/configure/structs"
|
|
)
|
|
|
|
// 参数校验
|
|
func (this *apiComp) FinishCheck(session comm.IUserSession, req *pb.WTaskFinishReq) (errdata *pb.ErrorData) {
|
|
|
|
return
|
|
}
|
|
|
|
// /获取系统公告
|
|
func (this *apiComp) Finish(session comm.IUserSession, req *pb.WTaskFinishReq) (errdata *pb.ErrorData) {
|
|
var (
|
|
conf *cfg.GameWorldTaskData
|
|
wtask *pb.DBWTask
|
|
condis []*pb.ConIProgress
|
|
award []*pb.UserAtno
|
|
completesMap map[int32]struct{} = make(map[int32]struct{})
|
|
err error
|
|
isfinsh bool
|
|
tasks []*pb.BuriedParam = make([]*pb.BuriedParam, 0)
|
|
ok bool
|
|
)
|
|
if errdata = this.FinishCheck(session, req); errdata != nil {
|
|
return
|
|
}
|
|
|
|
if conf, err = this.module.configure.gettaskconfconfigure(req.Tid); err != nil {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_ConfigNoFound,
|
|
Title: pb.ErrorCode_ConfigNoFound.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
return
|
|
}
|
|
|
|
if wtask, err = this.module.modelwtask.getUserWTasks(session.GetUserId()); err != nil {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_DBError,
|
|
Title: pb.ErrorCode_DBError.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
return
|
|
}
|
|
ok = false
|
|
for _, v := range wtask.Accepts {
|
|
if v == req.Tid {
|
|
ok = true
|
|
}
|
|
}
|
|
if !ok {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_ReqParameterError,
|
|
Title: pb.ErrorCode_ReqParameterError.ToString(),
|
|
Message: fmt.Sprintf("task:%d no in accepttask:%v", req.Tid, wtask.Accepts),
|
|
}
|
|
return
|
|
}
|
|
|
|
if len(conf.Completetask) > 0 {
|
|
if _, condis, err = this.module.ModuleBuried.CheckCondition(session, conf.Completetask...); err != nil {
|
|
this.module.Error("校验玩家子任务进度数据 失败", log.Field{Key: "err", Value: err.Error()})
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_ExternalModule,
|
|
Title: pb.ErrorCode_ExternalModule.ToString(),
|
|
Message: fmt.Sprintf("Progress:%s", err.Error()),
|
|
}
|
|
return
|
|
}
|
|
}
|
|
isfinsh = true
|
|
for _, v := range condis {
|
|
if v.State == pb.BuriedItemFinishState_buried_unfinish {
|
|
isfinsh = false
|
|
}
|
|
}
|
|
if !isfinsh {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_WorldtaskNoComplete,
|
|
Title: pb.ErrorCode_WorldtaskNoComplete.ToString(),
|
|
Message: fmt.Sprintf("ModuleBuried.CheckCondition Error:%+v", condis),
|
|
}
|
|
return
|
|
}
|
|
|
|
if len(conf.TaskendRemoveitem) > 0 { //交付物品
|
|
if errdata = this.module.ConsumeRes(session, conf.TaskendRemoveitem, true); errdata != nil {
|
|
return
|
|
}
|
|
}
|
|
|
|
if errdata, award = this.module.DispenseAtno(session, conf.Reword, true); errdata != nil {
|
|
return
|
|
}
|
|
// award = make([]*pb.UserAssets, 0)
|
|
// for _, v := range conf.Reword {
|
|
// award = append(award, &pb.UserAssets{
|
|
// A: v.A,
|
|
// T: v.T,
|
|
// N: v.N,
|
|
// })
|
|
// }
|
|
for i, v := range wtask.Accepts {
|
|
if v == req.Tid {
|
|
wtask.Accepts = append(wtask.Accepts[0:i], wtask.Accepts[i+1:]...)
|
|
break
|
|
}
|
|
}
|
|
for _, v := range wtask.Completes {
|
|
completesMap[v] = struct{}{}
|
|
}
|
|
|
|
if conf.Des == 5 && conf.IdAfter == 0 { //商队任务 一组任务完成后 重置
|
|
tasks, _ := this.module.configure.getgroupTask()[conf.Group]
|
|
completes := make([]int32, 0, len(wtask.Completes))
|
|
for _, task := range tasks {
|
|
if _, ok := completesMap[task.Key]; ok {
|
|
delete(completesMap, task.Key)
|
|
}
|
|
}
|
|
for k, _ := range completesMap {
|
|
completes = append(completes, k)
|
|
}
|
|
wtask.Completes = completes
|
|
} else {
|
|
wtask.Completes = append(wtask.Completes, req.Tid)
|
|
}
|
|
|
|
if conf.Des == 1 {
|
|
tasks = append(tasks, comm.GetBuriedParam(comm.Rtype240, 1))
|
|
}
|
|
tasks = append(tasks, comm.GetBuriedParam(comm.Rtype252, 1, conf.Key))
|
|
if conf.Des == 1 && conf.IdAfter != 0 { //日常任务 自动接取下一个
|
|
wtask.Activations = append(wtask.Activations, conf.IdAfter)
|
|
session.SendMsg(string(this.module.GetType()), "activationschange", &pb.WTaskActivationsChangePush{Activations: wtask.Activations})
|
|
}
|
|
|
|
this.module.checkgroupState(session, wtask, conf.Group)
|
|
session.SendMsg(string(this.module.GetType()), "finish", &pb.WTaskFinishResp{Tid: req.Tid, Award: award, Completes: wtask.Completes, Groups: wtask.Groups})
|
|
this.module.fishtask(session, wtask, true)
|
|
if err = this.module.modelwtask.updateUserWTasks(session.GetUserId(), wtask); err != nil {
|
|
errdata = &pb.ErrorData{
|
|
Code: pb.ErrorCode_DBError,
|
|
Title: pb.ErrorCode_DBError.ToString(),
|
|
Message: err.Error(),
|
|
}
|
|
return
|
|
}
|
|
if conf.Des == 5 {
|
|
this.module.caravan.TaskComplete(session, req.Tid)
|
|
}
|
|
go this.module.AsynHandleSession(session.Clone(), func(session comm.IUserSession) {
|
|
this.module.WriteUserLog(session.GetUserId(), req, comm.GMResAddType, "WTaskFinishReq", award)
|
|
this.module.WriteUserLog(session.GetUserId(), req, comm.GMResDelType, "WTaskFinishReq", conf.TaskendRemoveitem)
|
|
this.module.ModuleBuried.TriggerBuried(session, tasks...)
|
|
})
|
|
return
|
|
}
|