package worldtask import ( "go_dreamfactory/comm" "go_dreamfactory/lego/sys/log" "go_dreamfactory/pb" "google.golang.org/protobuf/proto" ) // 世界任务完成 func (this *apiComp) FinishCheck(session comm.IUserSession, req *pb.WorldtaskFinishReq) (code pb.ErrorCode) { if req.GroupId == 0 || req.TaskId == 0 { this.module.Error("世界任务完成参数错误", log.Fields{"uid": session.GetUserId(), "params": req}) code = pb.ErrorCode_ReqParameterError } return } func (this *apiComp) Finish(session comm.IUserSession, req *pb.WorldtaskFinishReq) (code pb.ErrorCode, data proto.Message) { if code = this.FinishCheck(session, req); code != pb.ErrorCode_Success { return } uid := session.GetUserId() // 获取用户信息 user := this.module.ModuleUser.GetUser(uid) if user == nil { code = pb.ErrorCode_UserSessionNobeing return } // 当前任务配置 curTaskConf, err := this.module.configure.getWorldtaskById(req.TaskId) if err != nil || curTaskConf == nil { code = pb.ErrorCode_ConfigNoFound return } if curTaskConf.Group != req.GroupId { code = pb.ErrorCode_ReqParameterError return } // 判断玩家等级要求 if user.Lv < curTaskConf.Lock { code = pb.ErrorCode_WorldtaskLvNotEnough return } // 当前玩家世界任务 userTask, err := this.module.modelWorldtask.getWorldtask(uid) if err != nil { code = pb.ErrorCode_DBError return } if userTask.Uid == "" { userTask.Uid = uid } // 前置任务ID 只有世界任务才校验前置 if curTaskConf.Des == 2 { if !this.module.modelWorldtask.IsPreFinished(userTask, curTaskConf) { this.module.Debug("前置任务未完成", log.Fields{"uid": uid, "preTaskId": curTaskConf.Ontxe, "taskId": curTaskConf.Key}) code = pb.ErrorCode_WorldtaskLastUnFinished return } } //判断任务是否已完成 for _, t := range userTask.TaskList { if t.TaskId == req.TaskId { code = pb.ErrorCode_WorldtaskFinihed return } } var nextTaskId int32 finishCall := func() { nextTaskId = curTaskConf.IdAfter defer func() { this.module.Debug("世界任务完成", log.Fields{"uid": uid, "params": req, "nextTaskId": nextTaskId}) }() // 完成任务 if err := this.module.modelWorldtask.finishTask(req.GroupId, req.TaskId, userTask); err != nil { code = pb.ErrorCode_WorldtaskFinish this.module.Error("完成任务失败", log.Fields{"uid": uid, "groupId": req.GroupId, "taskId": req.TaskId, "err": err.Error()}) return } // 发奖 if code = this.module.DispenseRes(session, curTaskConf.Reword, true); code != pb.ErrorCode_Success { this.module.Error("资源发放", log.Fields{"uid": uid, "groupId": req.GroupId, "taskId": req.TaskId, "reword": curTaskConf.Reword, "code": code}) } } if curTaskConf.Completetask != 0 { if c := this.module.ModuleRtask.CheckCondi(uid, curTaskConf.Completetask); c == pb.ErrorCode_Success { finishCall() } else { this.module.Debug("任务完成条件未通过", log.Fields{"uid": uid, "condiId": curTaskConf.Completetask}) return } } else { finishCall() } rsp := &pb.WorldtaskFinishResp{ GroupId: req.GroupId, TaskId: req.TaskId, } if err := session.SendMsg(string(this.module.GetType()), WorldtaskSubtypeFinish, rsp); err != nil { code = pb.ErrorCode_SystemError } // 世界任务类型 if curTaskConf.Des == 2 { // 任务完成推送 if err := session.SendMsg(string(this.module.GetType()), WorldtaskNexttaskPush, &pb.WorldtaskNexttaskPush{ NextTaskId: nextTaskId, }); err != nil { code = pb.ErrorCode_SystemError } } return }