130 lines
3.3 KiB
Go
130 lines
3.3 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.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
|
|
}
|