refactor(service): 重构物品、宠物和任务服务,统一使用EX模型和回调函数处理数据操作
This commit is contained in:
@@ -3,47 +3,17 @@ package service
|
||||
import (
|
||||
"blazing/cool"
|
||||
"blazing/modules/blazing/model"
|
||||
"encoding/json"
|
||||
)
|
||||
|
||||
func (s *UserService) ItemExec(t func([]model.SingleItemInfo) []model.SingleItemInfo) {
|
||||
//todo待测试
|
||||
var player model.Item
|
||||
m1 := cool.DBM(s.info.Model).Where("player_id", s.userid)
|
||||
m1.Scan(&player)
|
||||
var tt []model.SingleItemInfo
|
||||
json.Unmarshal([]byte(player.Data), &tt)
|
||||
t(tt)
|
||||
tmep, _ := json.Marshal(tt)
|
||||
player.Data = string(tmep)
|
||||
m1.Save(player)
|
||||
|
||||
}
|
||||
func (s *UserService) ItemCheak() map[uint32]model.SingleItemInfo {
|
||||
func (s *UserService) Item(t func(map[uint32]model.SingleItemInfo) bool) {
|
||||
|
||||
//todo待测试
|
||||
var player model.Item
|
||||
var player model.ItemEX
|
||||
m1 := cool.DBM(s.item.Model).Where("player_id", s.userid)
|
||||
var rer map[uint32]model.SingleItemInfo
|
||||
m1.Scan(&player)
|
||||
json.Unmarshal([]byte(player.Data), &rer)
|
||||
//return gjson.Parse(player.Data)
|
||||
return rer
|
||||
}
|
||||
func (s *UserService) ItemAdd(t []model.SingleItemInfo) {
|
||||
|
||||
//todo待测试
|
||||
var player model.Item
|
||||
m1 := cool.DBM(s.item.Model).Where("player_id", s.userid)
|
||||
var rer map[uint32]model.SingleItemInfo
|
||||
rer = make(map[uint32]model.SingleItemInfo)
|
||||
m1.Scan(&player)
|
||||
json.Unmarshal([]byte(player.Data), &rer)
|
||||
player.PlayerID = uint64(s.userid)
|
||||
if len(rer) == 0 {
|
||||
fff, _ := json.Marshal(rer)
|
||||
player.Data = string(fff)
|
||||
|
||||
err := m1.Scan(&player)
|
||||
if err != nil {
|
||||
player.Data = make(map[uint32]model.SingleItemInfo)
|
||||
_, err := m1.Insert(player)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
@@ -51,24 +21,28 @@ func (s *UserService) ItemAdd(t []model.SingleItemInfo) {
|
||||
|
||||
}
|
||||
|
||||
for _, v := range t {
|
||||
tt, ok := rer[v.ItemId]
|
||||
if ok {
|
||||
tt.ItemCnt += v.ItemCnt
|
||||
rer[v.ItemId] = tt
|
||||
} else {
|
||||
rer[v.ItemId] = v
|
||||
}
|
||||
|
||||
if !t(player.Data) {
|
||||
return
|
||||
}
|
||||
|
||||
fff, _ := json.Marshal(rer)
|
||||
player.Data = string(fff)
|
||||
|
||||
_, err := m1.Update(player)
|
||||
_, err = m1.Update(player)
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
//return gjson.Parse(player.Data)
|
||||
}
|
||||
func (s *UserService) ItemAdd(t []model.SingleItemInfo) {
|
||||
|
||||
s.Item(func(rer map[uint32]model.SingleItemInfo) bool {
|
||||
for _, v := range t {
|
||||
tt, ok := rer[v.ItemId]
|
||||
if ok {
|
||||
tt.ItemCnt += v.ItemCnt
|
||||
rer[v.ItemId] = tt
|
||||
} else {
|
||||
rer[v.ItemId] = v
|
||||
}
|
||||
|
||||
}
|
||||
return true
|
||||
})
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user