2025-08-31 00:27:07 +08:00
|
|
|
package service
|
|
|
|
|
|
|
|
|
|
import (
|
2025-11-16 20:30:17 +00:00
|
|
|
"blazing/cool"
|
2026-01-19 18:51:56 +08:00
|
|
|
"blazing/modules/player/model"
|
2025-12-04 00:26:49 +08:00
|
|
|
"context"
|
2025-11-02 18:56:16 +08:00
|
|
|
|
2026-03-31 06:51:40 +08:00
|
|
|
dictservice "blazing/modules/dict/service"
|
|
|
|
|
|
2025-11-02 18:56:16 +08:00
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
2025-08-31 00:27:07 +08:00
|
|
|
)
|
|
|
|
|
|
2026-02-12 22:49:29 +08:00
|
|
|
func (s *ItemService) Exist(itemid uint32) bool {
|
|
|
|
|
|
|
|
|
|
var ttt *model.Item
|
2026-02-13 22:57:05 +08:00
|
|
|
s.dbm(s.Model).Where("item_id", itemid).Scan(&ttt)
|
2026-02-12 22:49:29 +08:00
|
|
|
|
|
|
|
|
return ttt != nil
|
|
|
|
|
|
|
|
|
|
}
|
2025-11-16 20:30:17 +00:00
|
|
|
func (s *ItemService) Get(min, max uint32) []model.Item {
|
2026-01-08 03:30:18 +08:00
|
|
|
|
|
|
|
|
var ttt []model.Item
|
2026-03-11 12:19:13 +08:00
|
|
|
s.dbm(s.Model).WhereBetween("item_id", min, max).Where("item_cnt >", 0).Scan(&ttt)
|
2025-09-11 01:07:00 +08:00
|
|
|
|
2025-11-02 18:56:16 +08:00
|
|
|
return ttt
|
2025-09-11 01:07:00 +08:00
|
|
|
|
2025-11-02 18:56:16 +08:00
|
|
|
}
|
2026-03-19 14:50:11 +08:00
|
|
|
func (s *ItemService) UPDATE(id uint32, count int) error {
|
2026-01-08 03:30:18 +08:00
|
|
|
if cool.Config.ServerInfo.IsVip != 0 && count < 0 {
|
2026-02-04 00:25:41 +08:00
|
|
|
|
2026-03-19 14:50:11 +08:00
|
|
|
return nil
|
2026-01-08 03:30:18 +08:00
|
|
|
}
|
2026-02-22 22:57:49 +08:00
|
|
|
if id == 0 {
|
2026-03-19 14:50:11 +08:00
|
|
|
return nil
|
2026-02-22 22:57:49 +08:00
|
|
|
}
|
|
|
|
|
m := s.dbm(s.Model)
|
2026-02-22 23:09:51 +08:00
|
|
|
ok, err := m.Where("item_id", id).Exist()
|
|
|
|
|
if err != nil {
|
2026-03-19 14:50:11 +08:00
|
|
|
return err
|
2026-02-22 23:09:51 +08:00
|
|
|
}
|
|
|
|
|
if ok {
|
2026-02-22 22:57:49 +08:00
|
|
|
_, err := s.dbm(s.Model).Where("item_id", id).Increment("item_cnt", count)
|
|
|
|
|
if err != nil {
|
2026-03-19 14:50:11 +08:00
|
|
|
return err
|
2026-02-22 22:57:49 +08:00
|
|
|
}
|
2026-02-22 23:09:51 +08:00
|
|
|
|
2026-02-22 22:57:49 +08:00
|
|
|
} else {
|
|
|
|
|
m := s.dbm(s.Model)
|
|
|
|
|
data := g.Map{
|
|
|
|
|
"player_id": s.userid,
|
|
|
|
|
"item_id": id,
|
|
|
|
|
"item_cnt": count,
|
|
|
|
|
"is_vip": cool.Config.ServerInfo.IsVip,
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-19 14:50:11 +08:00
|
|
|
_, err := m.Data(data).Insert()
|
|
|
|
|
return err
|
2026-02-22 22:57:49 +08:00
|
|
|
}
|
2026-03-19 14:50:11 +08:00
|
|
|
return nil
|
2025-11-02 18:56:16 +08:00
|
|
|
}
|
2026-02-26 10:40:41 +08:00
|
|
|
|
2026-03-31 06:51:40 +08:00
|
|
|
// AddUniqueItems 为一组互不重复的物品各增加 1 个。
|
|
|
|
|
// 返回值只包含本次实际成功增加的物品 id。
|
|
|
|
|
func (s *ItemService) AddUniqueItems(ids []uint32) ([]uint32, error) {
|
|
|
|
|
if len(ids) == 0 {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
currentItems := s.CheakItemM(ids...)
|
|
|
|
|
currentMap := make(map[uint32]int64, len(currentItems))
|
|
|
|
|
for _, item := range currentItems {
|
|
|
|
|
currentMap[item.ItemId] = item.ItemCnt
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
updateIDs := make([]uint32, 0, len(ids))
|
|
|
|
|
insertData := g.List{}
|
|
|
|
|
successIDs := make([]uint32, 0, len(ids))
|
|
|
|
|
|
|
|
|
|
for _, id := range ids {
|
|
|
|
|
if id == 0 {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
itemmax := dictservice.NewDictInfoService().GetMax(int64(id))
|
|
|
|
|
if itemmax == 0 {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
if currentMap[id]+1 > int64(itemmax) {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
successIDs = append(successIDs, id)
|
|
|
|
|
if _, ok := currentMap[id]; ok {
|
|
|
|
|
updateIDs = append(updateIDs, id)
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
insertData = append(insertData, g.Map{
|
|
|
|
|
"player_id": s.userid,
|
|
|
|
|
"item_id": id,
|
|
|
|
|
"item_cnt": 1,
|
|
|
|
|
"is_vip": cool.Config.ServerInfo.IsVip,
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(updateIDs) > 0 {
|
|
|
|
|
if _, err := s.dbm(s.Model).WhereIn("item_id", updateIDs).Increment("item_cnt", 1); err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(insertData) > 0 {
|
|
|
|
|
if _, err := s.dbm(s.Model).Data(insertData).Insert(); err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return successIDs, nil
|
|
|
|
|
}
|
|
|
|
|
|
2026-02-26 22:32:15 +08:00
|
|
|
// func (s *ItemService) UPDATEM(ids map[uint32]int) {
|
|
|
|
|
// if cool.Config.ServerInfo.IsVip != 0 {
|
2025-11-02 18:56:16 +08:00
|
|
|
|
2026-02-26 22:32:15 +08:00
|
|
|
// return
|
|
|
|
|
// }
|
2026-02-26 10:40:41 +08:00
|
|
|
|
2026-02-26 22:32:15 +08:00
|
|
|
// m := s.dbm(s.Model)
|
|
|
|
|
// data := g.List{}
|
|
|
|
|
// for k, v := range ids {
|
|
|
|
|
// data = append(data, g.Map{
|
|
|
|
|
// "player_id": s.userid,
|
|
|
|
|
// "item_id": k,
|
|
|
|
|
// "item_cnt": v,
|
|
|
|
|
// "is_vip": cool.Config.ServerInfo.IsVip,
|
|
|
|
|
// })
|
|
|
|
|
// }
|
2026-02-26 10:40:41 +08:00
|
|
|
|
2026-02-26 22:32:15 +08:00
|
|
|
// m.Data(data).Insert()
|
|
|
|
|
|
|
|
|
|
// }
|
2026-02-12 04:28:20 +08:00
|
|
|
func (s *ItemService) CheakItem(id uint32) int64 {
|
2025-11-02 18:56:16 +08:00
|
|
|
var ttt model.Item
|
2026-02-13 22:57:05 +08:00
|
|
|
m := s.dbm(s.Model)
|
2026-01-08 03:30:18 +08:00
|
|
|
|
|
|
|
|
m.Where("item_id", id).Scan(&ttt)
|
2025-11-02 18:56:16 +08:00
|
|
|
return ttt.ItemCnt
|
2025-09-23 15:01:52 +00:00
|
|
|
}
|
2026-02-26 10:24:30 +08:00
|
|
|
func (s *ItemService) CheakItemM(id ...uint32) []model.Item {
|
|
|
|
|
var ttt []model.Item
|
|
|
|
|
m := s.dbm(s.Model)
|
|
|
|
|
|
|
|
|
|
m.WhereIn("item_id", id).Scan(&ttt)
|
|
|
|
|
return ttt
|
|
|
|
|
}
|
2025-09-23 15:01:52 +00:00
|
|
|
|
2025-10-25 15:06:05 +08:00
|
|
|
// /添加进来的物品一定是保证存在的
|
2025-11-16 20:30:17 +00:00
|
|
|
type ItemService struct {
|
|
|
|
|
BaseService
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewItemService(id uint32) *ItemService {
|
|
|
|
|
return &ItemService{
|
|
|
|
|
|
|
|
|
|
BaseService: BaseService{userid: id,
|
|
|
|
|
|
|
|
|
|
Service: &cool.Service{Model: model.NewPlayerBag(), UniqueKey: map[string]string{
|
|
|
|
|
"player_id": "角色名称不能重复",
|
2025-12-04 00:26:49 +08:00
|
|
|
}, PageQueryOp: &cool.QueryOp{
|
2025-12-04 01:33:37 +08:00
|
|
|
KeyWordField: []string{"player_id"},
|
2026-02-12 00:49:18 +08:00
|
|
|
FieldEQ: []string{"player_id"},
|
2025-12-04 00:26:49 +08:00
|
|
|
Where: func(ctx context.Context) [][]interface{} {
|
|
|
|
|
var (
|
|
|
|
|
//admin = cool.GetAdmin(ctx)
|
|
|
|
|
//userId = admin.UserId
|
|
|
|
|
)
|
|
|
|
|
return [][]interface{}{
|
|
|
|
|
// {"player_id", userId, true},
|
|
|
|
|
// {"free", 0, true},
|
|
|
|
|
}
|
|
|
|
|
},
|
2025-11-16 20:30:17 +00:00
|
|
|
}},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|