All checks were successful
ci/woodpecker/push/my-first-workflow Pipeline was successful
feat(game): 实现扭蛋系统批量物品添加功能并优化地图逻辑 - 新增ItemAddBatch方法用于批量添加物品,支持普通道具和特殊道具的分别处理 - 优化扭蛋游戏玩法中的物品添加逻辑,使用新的批量接口提升性能 - 在扭蛋机器人命令中实现完整的物品检查和批量添加流程 refactor(map): 重构地图控制器代码结构并添加注释 - 为EnterMap、LeaveMap、GetMapPlayerList等方法添加中文注释 - 统一地图相关的命名规范,如enter
239 lines
5.2 KiB
Go
239 lines
5.2 KiB
Go
package service
|
|
|
|
import (
|
|
"context"
|
|
|
|
"blazing/common/utils"
|
|
"blazing/cool"
|
|
|
|
"blazing/modules/dict/model"
|
|
|
|
"github.com/gogf/gf/v2/database/gdb"
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
)
|
|
|
|
type DictInfoService struct {
|
|
*cool.Service
|
|
}
|
|
|
|
// func init() {
|
|
|
|
// t, _ := NewDictInfoService().Data(context.TODO(), []string{"mapid"})
|
|
// fmt.Println(t)
|
|
|
|
// }
|
|
|
|
// Data方法, 用于获取数据
|
|
func (s *DictInfoService) Data(ctx context.Context, types []string) (data interface{}, err error) {
|
|
var (
|
|
dictInfoModel = model.NewDictInfo()
|
|
dictTypeModel = model.NewDictType()
|
|
)
|
|
mType := cool.DBM(dictTypeModel).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
})
|
|
// 如果types不为空, 则查询指定类型的数据
|
|
if len(types) > 0 {
|
|
mType = mType.Where("key in (?)", types)
|
|
}
|
|
// 查询所有类型
|
|
typeData, err := mType.All()
|
|
// 如果typeData为空, 则返回空
|
|
if typeData.IsEmpty() {
|
|
return g.Map{}, nil
|
|
}
|
|
data = g.Map{}
|
|
for _, v := range typeData {
|
|
m := cool.DBM(dictInfoModel)
|
|
result, err := m.Where("typeId", v["id"]).FieldsEx("id").Order("ordernum asc").All()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if result.IsEmpty() {
|
|
continue
|
|
}
|
|
data.(g.Map)[v["key"].String()] = result
|
|
}
|
|
return
|
|
}
|
|
|
|
func (s *DictInfoService) GetData(types string) (data map[uint32]model.DictInfo) {
|
|
var (
|
|
dictInfoModel = model.NewDictInfo()
|
|
dictTypeModel = model.NewDictType()
|
|
)
|
|
// 如果typeData为空, 则返回空
|
|
var ty *model.DictType
|
|
mType := cool.DBM(dictTypeModel)
|
|
mType.Where("key in (?)", types).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Scan(&ty)
|
|
|
|
// 如果typeData为空, 则返回空
|
|
if ty == nil {
|
|
return nil
|
|
}
|
|
m := cool.DBM(dictInfoModel)
|
|
var ress []model.DictInfo
|
|
m.Where("typeId", ty.ID).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Scan(&ress)
|
|
fusions := utils.ToMap(ress, func(t model.DictInfo) uint32 {
|
|
|
|
return gconv.Uint32(t.Value) //物品id转id
|
|
})
|
|
return fusions
|
|
|
|
}
|
|
func (s *DictInfoService) GetNameData(types string) (data map[string]model.DictInfo) {
|
|
var (
|
|
dictInfoModel = model.NewDictInfo()
|
|
dictTypeModel = model.NewDictType()
|
|
)
|
|
// 如果typeData为空, 则返回空
|
|
var ty *model.DictType
|
|
mType := cool.DBM(dictTypeModel)
|
|
mType.Where("key in (?)", types).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Scan(&ty)
|
|
|
|
// 如果typeData为空, 则返回空
|
|
if ty == nil {
|
|
return nil
|
|
}
|
|
m := cool.DBM(dictInfoModel)
|
|
var ress []model.DictInfo
|
|
m.Where("typeId", ty.ID).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Scan(&ress)
|
|
fusions := utils.ToMap(ress, func(t model.DictInfo) string {
|
|
|
|
return t.Name //物品id转id
|
|
})
|
|
return fusions
|
|
|
|
}
|
|
|
|
// 获取物品的最大数限制
|
|
func (s *DictInfoService) GetMax(value int64) (max uint32) {
|
|
|
|
m := cool.DBM(s.Model)
|
|
var ress *model.DictInfo
|
|
m.Where("value", value).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Scan(&ress)
|
|
if ress == nil {
|
|
return 0
|
|
}
|
|
|
|
return uint32(ress.Ordernum)
|
|
|
|
}
|
|
|
|
// 获取稀有精灵的光环显示
|
|
// GetMaxMap 批量获取物品最大持有上限。
|
|
func (s *DictInfoService) GetMaxMap(values ...uint32) map[uint32]uint32 {
|
|
if len(values) == 0 {
|
|
return nil
|
|
}
|
|
|
|
var ress []model.DictInfo
|
|
cool.DBM(s.Model).WhereIn("value", values).Cache(gdb.CacheOption{
|
|
Force: false,
|
|
}).Scan(&ress)
|
|
|
|
result := make(map[uint32]uint32, len(ress))
|
|
for _, item := range ress {
|
|
result[gconv.Uint32(item.Value)] = uint32(item.Ordernum)
|
|
}
|
|
return result
|
|
}
|
|
|
|
func (s *DictInfoService) GetShiny() []int {
|
|
//获取精灵的排序作为精灵的数组
|
|
m := cool.DBM(s.Model)
|
|
|
|
res, _ := m.Where("typeId", 10).Where("ordernum", 1).Cache(gdb.CacheOption{
|
|
// Duration: time.Hour,
|
|
|
|
Force: false,
|
|
}).Fields("value").All()
|
|
|
|
return res.Array("value").Ints()
|
|
|
|
}
|
|
func (s *DictInfoService) SetItemRemark(id int, b string) {
|
|
//获取精灵的排序作为精灵的数组
|
|
m := cool.DBM(s.Model)
|
|
|
|
m.Where("typeId", 6).Where("value", id).Data("remark", b).Update()
|
|
|
|
}
|
|
|
|
// ModifyAfter 修改后
|
|
func (s *DictInfoService) ModifyAfter(ctx context.Context, method string, param map[string]interface{}) (err error) {
|
|
defer s.Service.ModifyAfter(ctx, method, param)
|
|
if method == "Delete" {
|
|
// 删除后,同时删除子节点
|
|
ids, ok := param["ids"]
|
|
if !ok {
|
|
return
|
|
}
|
|
for _, v := range ids.([]interface{}) {
|
|
err = delChildDict(gconv.Int64(v))
|
|
if err != nil {
|
|
return
|
|
}
|
|
}
|
|
}
|
|
return
|
|
}
|
|
|
|
// delChildDict 删除子字典
|
|
func delChildDict(id int64) error {
|
|
var (
|
|
dictInfoModel = model.NewDictInfo()
|
|
)
|
|
m := cool.DBM(dictInfoModel)
|
|
result, err := m.Where("parentId=?", id).Fields("id").All()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if result.IsEmpty() {
|
|
return nil
|
|
}
|
|
for _, v := range result {
|
|
delChildDict(v["id"].Int64())
|
|
}
|
|
_, err = m.Where("parentId=?", id).Delete()
|
|
return err
|
|
}
|
|
|
|
// NewDictInfoService 初始化 DictInfoService
|
|
func NewDictInfoService() *DictInfoService {
|
|
return &DictInfoService{
|
|
&cool.Service{
|
|
//UniqueKey: map[string]string{"name": "名称不能重复"},
|
|
Model: model.NewDictInfo(),
|
|
ListQueryOp: &cool.QueryOp{
|
|
FieldEQ: []string{"typeId"},
|
|
KeyWordField: []string{"name", "value"},
|
|
AddOrderby: g.MapStrStr{"createTime": "ASC"},
|
|
},
|
|
},
|
|
}
|
|
}
|