重构 Talk 方法中物品奖励的获取方式,使用新的配置服务以支持多物品 ID 奖励机制。 移除了对 github.com/gogf/gf/v2/util/grand 包的依赖,改为通过服务获取实际物品数量。 同时更新了相关模型定义: - 修改 MineralCollectionConfig 中 ItemID 为数组形式以支持多个物品配置 - 调整 ItemGift 模型字段
50 lines
2.3 KiB
Go
50 lines
2.3 KiB
Go
package model
|
||
|
||
import (
|
||
"blazing/cool"
|
||
)
|
||
|
||
// 表名常量定义:物品奖励表(存储物品奖励的核心配置信息)
|
||
const (
|
||
TableNameItemGift = "item_gift" // 物品奖励配置表(包含物品关联、数量、启用状态、扭蛋标识及备注信息)
|
||
)
|
||
|
||
// ItemGift 物品奖励基础配置模型(与数据库表 item_gift 字段一一对应,核心存储结构)
|
||
type ItemGift struct {
|
||
*cool.Model // 嵌入通用Model(包含ID/创建时间/更新时间等通用字段,保持与现有模型一致性)
|
||
|
||
// 核心业务字段(按需求实现:物品id、备注、是否启用、是否为扭蛋、物品数量)
|
||
ItemID uint32 `gorm:"not null;default:0;comment:'物品ID,关联物品配置表主键'" json:"item_id"`
|
||
Remark string `gorm:"size:512;default:'';comment:'物品奖励备注说明(如使用场景、特殊说明等)'" json:"remark"`
|
||
IsEnabled uint32 `gorm:"not null;default:1;comment:'是否启用(0-禁用 1-启用)'" json:"is_enabled"`
|
||
IsEgg uint32 `gorm:"not null;default:0;comment:'是否蛋'" json:"is_egg"` //奖励是否为扭蛋奖励
|
||
//ItemCount uint32 `gorm:"not null;default:1;comment:'物品奖励数量'" json:"item_count"`
|
||
ItemMinCount uint32 `gorm:"column:item_min_count;not null;comment:单次采集最小产出数量" json:"item_min_count"`
|
||
// ItemMaxCount 单次采集最大产出数量
|
||
ItemMaxCount uint32 `gorm:"column:item_max_count;not null;comment:单次采集最大产出数量" json:"item_max_count"`
|
||
}
|
||
|
||
// TableName 指定ItemGift对应的数据库表名(遵循现有代码规范)
|
||
func (*ItemGift) TableName() string {
|
||
return TableNameItemGift
|
||
}
|
||
|
||
// GroupName 指定表所属的分组(与现有BossConfig、PetReward保持一致,统一为default分组)
|
||
func (*ItemGift) GroupName() string {
|
||
return "default"
|
||
}
|
||
|
||
// NewItemGift 创建一个新的ItemGift实例(初始化通用Model字段+默认值,与现有实例创建逻辑一致)
|
||
func NewItemGift() *ItemGift {
|
||
return &ItemGift{
|
||
Model: cool.NewModel(), // 初始化通用Model字段(ID/创建时间/更新时间等)
|
||
// 字段默认值与gorm tag中default配置保持一致
|
||
IsEnabled: 1,
|
||
}
|
||
}
|
||
|
||
// init 程序启动时自动创建/同步item_gift表结构(与现有表同步逻辑保持一致)
|
||
func init() {
|
||
cool.CreateTable(&ItemGift{})
|
||
}
|