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.UserAssets 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 = this.module.DispenseRes(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 } } wtask.Completes = append(wtask.Completes, req.Tid) session.SendMsg(string(this.module.GetType()), "finish", &pb.WTaskFinishResp{Tid: req.Tid, Award: award}) this.module.fishtask(session, wtask) if err = this.module.modelwtask.Change(session.GetUserId(), map[string]interface{}{ "activations": wtask.Activations, "accepts": wtask.Accepts, "completes": wtask.Completes, }); err != nil { errdata = &pb.ErrorData{ Code: pb.ErrorCode_DBError, Title: pb.ErrorCode_DBError.ToString(), Message: err.Error(), } return } return }