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 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.GetUserId(), 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 && 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.ModuleSys.CheckOpenCond(session.Clone(), comm.OpencondTypeWorldtaskid, req.Tid) return }