diff --git a/modules/comp_configure.go b/modules/comp_configure.go index 10c38f7d2..7b2722190 100644 --- a/modules/comp_configure.go +++ b/modules/comp_configure.go @@ -275,6 +275,17 @@ func (this *MCompConfigure) GetItemConfigureByType(useType int32) (item []*cfg.G } return } + +func (this *MCompConfigure) GetItemConfigureByBagType(bagType int32) (item []*cfg.GameItemData) { + if v, err := this.GetConfigure(game_item); err == nil { + for _, v1 := range v.(*cfg.GameItem).GetDataMap() { + if v1.Bagtype == bagType { + item = append(item, v1) + } + } + } + return +} func (this *MCompConfigure) GetEquipmentConfigureById(equipmentId string) (configure *cfg.GameEquipData) { if v, err := this.GetConfigure(game_equip); err == nil { diff --git a/modules/gm/module.go b/modules/gm/module.go index 94f6ab466..b265f3b38 100644 --- a/modules/gm/module.go +++ b/modules/gm/module.go @@ -463,6 +463,40 @@ func (this *GM) CreateCmd(session comm.IUserSession, cmd string) (errdata *pb.Er log.Field{Key: "1", Value: datas[1]}, log.Field{Key: "2", Value: datas[2]}, ) + } else if len(datas) == 3 && (datas[0] == "bagtype") { + num1, err := strconv.Atoi(datas[1]) + if err != nil { + errdata = &pb.ErrorData{ + Code: pb.ErrorCode_ReqParameterError, + Title: pb.ErrorCode_ReqParameterError.ToString(), + } + return + } + num2, err := strconv.Atoi(datas[2]) + if err != nil { + errdata = &pb.ErrorData{ + Code: pb.ErrorCode_ReqParameterError, + Title: pb.ErrorCode_ReqParameterError.ToString(), + } + return + } + _data := this.configure.GetItemConfigureByBagType(int32(num1)) + for _, v := range _data { + res := &cfg.Gameatn{ + A: "item", + T: v.Id, + N: int32(num2), + } + if errdata = this.DispenseRes(session, []*cfg.Gameatn{res}, true); errdata != nil { + this.Debugf("DispenseRes err :uid = %s,code = %d", datas[0], errdata) + } + } + this.Debug("使用bingo命令:uid = %s ", + log.Field{Key: "uid", Value: session.GetUserId()}, + log.Field{Key: "0", Value: datas[0]}, + log.Field{Key: "1", Value: datas[1]}, + log.Field{Key: "2", Value: datas[2]}, + ) } else if len(datas) == 2 && (datas[0] == "viplv") { // 玩家等级 module1, err := this.service.GetModule(comm.ModuleUser) if err != nil { diff --git a/modules/plunder/api_getlist.go b/modules/plunder/api_getlist.go index be03bde28..40ee60bcd 100644 --- a/modules/plunder/api_getlist.go +++ b/modules/plunder/api_getlist.go @@ -41,6 +41,14 @@ func (this *apiComp) GetList(session comm.IUserSession, req *pb.PlunderGetListRe this.module.modelPlunder.changePlunderData(session.GetUserId(), map[string]interface{}{ "landid": list.Landid, }) + } else { + if land, err = this.module.modelLand.getPlunderLandData(list.Landid); err != nil { + errdata = &pb.ErrorData{ + Code: pb.ErrorCode_DBError, + Message: err.Error(), + } + return + } } session.SendMsg(string(this.module.GetType()), "getlist", &pb.PlunderGetListResp{ List: list,