All checks were successful
ci/woodpecker/push/my-first-workflow Pipeline was successful
feat(player): 宠物购买功能优化 - 使用PetInfo_One_ID方法替代直接数据库查询 - 调整宠物购买时的价格计算逻辑,买入价格从*100调整为*102 - 卖出价格从*100调整为*98,买入扣款也相应调整为*102 - 删除宠物时使用Pet_del方法替代直接数据库删除操作 - 新增PetInfo_One_ID方法
235 lines
4.9 KiB
Go
235 lines
4.9 KiB
Go
package service
|
|
|
|
import (
|
|
"blazing/cool"
|
|
"blazing/modules/base/service"
|
|
"blazing/modules/player/model"
|
|
"context"
|
|
"fmt"
|
|
)
|
|
|
|
// 获取精灵信息 0是仓库,1是放生
|
|
func (s *PetService) PetInfo(flag int) []model.Pet {
|
|
var tt []model.Pet
|
|
err := s.dbm(s.Model).Where("free", flag).Scan(&tt)
|
|
if err != nil {
|
|
return []model.Pet{}
|
|
}
|
|
|
|
for i := 0; i < len(tt); i++ {
|
|
tt[i].Data.CatchTime = tt[i].CatchTime
|
|
|
|
}
|
|
|
|
return tt
|
|
|
|
}
|
|
func (s *PetService) PetCount(flag int) int {
|
|
|
|
ret, err := s.dbm(s.Model).Where("free", flag).Count()
|
|
|
|
if err != nil {
|
|
return 0
|
|
}
|
|
|
|
return ret
|
|
|
|
}
|
|
|
|
func (s *PetService) UPdateFree(ctime uint32, free uint32) {
|
|
|
|
s.dbm(s.Model).Where("catch_time", ctime).Data(
|
|
|
|
"free", free,
|
|
).Update()
|
|
|
|
}
|
|
func (s *PetService) UPdatePrice(ctime uint32, Price float32) {
|
|
|
|
s.dbm(s.Model).Where("catch_time", ctime).Data("sale_price", Price).Update()
|
|
|
|
}
|
|
func (s *PetService) BuyPet(pid uint32) error {
|
|
|
|
tt := NewPetService(0).PetInfo_One_ID(pid)
|
|
|
|
if tt == nil {
|
|
return fmt.Errorf("没有此精灵")
|
|
}
|
|
if tt.IsVip != 0 {
|
|
return fmt.Errorf("不允许交易")
|
|
}
|
|
if tt.IsSale == 0 {
|
|
return fmt.Errorf("未上架")
|
|
}
|
|
if tt.SalePrice == 0 {
|
|
return fmt.Errorf("未设置价格")
|
|
}
|
|
|
|
if service.NewBaseSysUserService().GetGold(uint(s.userid)) < int64(tt.SalePrice)*102 {
|
|
return fmt.Errorf("余额不足")
|
|
}
|
|
service.NewBaseSysUserService().UpdateGold(tt.PlayerID, int64(tt.SalePrice)*98)
|
|
service.NewBaseSysUserService().UpdateGold(s.userid, -int64(tt.SalePrice)*102)
|
|
s.PetAdd(&tt.Data)
|
|
NewPetService(tt.PlayerID).Pet_del(tt.CatchTime)
|
|
|
|
return nil
|
|
|
|
}
|
|
func (s *PetService) UPdate(t model.PetInfo) {
|
|
|
|
m := s.dbm(s.Model).Where("catch_time", t.CatchTime)
|
|
var tt *model.Pet
|
|
m.Scan(&tt)
|
|
if tt == nil {
|
|
return
|
|
}
|
|
tt.Data = t
|
|
_, err := m.OnConflict("catch_time").Update(tt)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
func (s *PetService) PetInfo_One(cachetime uint32) *model.Pet {
|
|
|
|
m := s.dbm(s.Model).Where("catch_time", cachetime)
|
|
var tt *model.Pet
|
|
|
|
m.Scan(&tt)
|
|
if tt == nil {
|
|
return nil
|
|
}
|
|
|
|
tt.Data.CatchTime = tt.CatchTime
|
|
return tt
|
|
}
|
|
func (s *PetService) PetInfo_One_ID(Pid uint32) *model.Pet {
|
|
|
|
m := s.dbm(s.Model).Where("id", Pid)
|
|
var tt *model.Pet
|
|
|
|
m.Scan(&tt)
|
|
if tt == nil {
|
|
return nil
|
|
}
|
|
|
|
tt.Data.CatchTime = tt.CatchTime
|
|
return tt
|
|
}
|
|
func (s *PetService) PetInfo_One_ohter(userid, cachetime uint32) model.Pet {
|
|
|
|
m := s.dbm(s.Model).Where("catch_time", cachetime)
|
|
var tt model.Pet
|
|
|
|
m.Scan(&tt)
|
|
tt.Data.CatchTime = tt.CatchTime
|
|
return tt
|
|
}
|
|
func (s *PetService) PetInfo_One_Unscoped(cachetime uint32) *model.Pet {
|
|
|
|
m := s.dbm(s.Model).Where("catch_time", cachetime).Unscoped()
|
|
var tt *model.Pet
|
|
|
|
m.Scan(&tt)
|
|
if tt == nil {
|
|
return nil
|
|
|
|
}
|
|
tt.Data.CatchTime = tt.CatchTime
|
|
return tt
|
|
}
|
|
func (s *PetService) Pet_del(cachetime uint32) {
|
|
|
|
s.dbm(s.Model).Where("catch_time", cachetime).Delete()
|
|
|
|
}
|
|
func (s *PetService) Pet_LEVEL_all() []model.Pet {
|
|
var tt []model.Pet
|
|
|
|
s.dbm(s.Model).Fields().Wheref(`(pp.data->>'Level')::INT > 100`, "array").OrderDesc("(pp.data->>'Level')::INT").Scan(&tt)
|
|
return tt
|
|
}
|
|
|
|
// 精灵真正添加后的捕捉时间才是真正的时间
|
|
func (s *PetService) PetAdd(y *model.PetInfo) uint32 {
|
|
if y == nil {
|
|
return 0
|
|
}
|
|
sql := fmt.Sprintf(`
|
|
UPDATE %s
|
|
SET max_ts = CASE
|
|
WHEN max_ts < EXTRACT(EPOCH FROM NOW())::INT THEN EXTRACT(EPOCH FROM NOW())::INT
|
|
ELSE max_ts + 1
|
|
END
|
|
WHERE id = ? AND deleted_at IS NULL
|
|
RETURNING max_ts;
|
|
`, service.NewBaseSysUserService().Model.TableName())
|
|
|
|
// 执行 Raw SQL 并扫描返回值
|
|
ret, _ := cool.DBM(service.NewBaseSysUserService().Model).Raw(sql, s.userid).All()
|
|
//fmt.Println(ret, err)
|
|
y.CatchTime = ret.Array()[0].Uint32()
|
|
m1 := cool.DBM(s.Model).Where("player_id", s.userid)
|
|
var player model.Pet
|
|
player.PlayerID = s.userid
|
|
player.Data = *y
|
|
player.CatchTime = y.CatchTime
|
|
player.Free = 0
|
|
player.IsVip = cool.Config.ServerInfo.IsVip
|
|
|
|
_, err := m1.Insert(player)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return y.CatchTime
|
|
}
|
|
|
|
// func (s *PetService) ModifyBefore(ctx context.Context, method string, param map[string]interface{}) (err error) {
|
|
// admin := cool.GetAdmin(ctx)
|
|
// userId := admin.UserId
|
|
// s.userid = uint32(userId)
|
|
// // if method == "Update" {
|
|
|
|
// // if gconv.Uint(param["free"]) != 0 {
|
|
// // err = fmt.Errorf("修改失败")
|
|
// // }
|
|
// // if userId != gconv.Uint(param["player_id"]) {
|
|
// // err = fmt.Errorf("修改失败")
|
|
// // }
|
|
|
|
// // }
|
|
|
|
// return
|
|
// }
|
|
|
|
type PetService struct {
|
|
BaseService
|
|
}
|
|
|
|
func NewPetService(userid uint32) *PetService {
|
|
return &PetService{
|
|
BaseService: BaseService{
|
|
userid: userid,
|
|
Service: &cool.Service{
|
|
Model: model.NewPet(),
|
|
PageQueryOp: &cool.QueryOp{
|
|
FieldEQ: []string{"player_id", "free", "is_sale"},
|
|
Where: func(ctx context.Context) [][]interface{} {
|
|
// var (
|
|
// admin = cool.GetAdmin(ctx)
|
|
// // userId = admin.UserId
|
|
// )
|
|
return [][]interface{}{
|
|
// {"player_id", userId, true},
|
|
{"free", 1, true},
|
|
{"is_vip", 0, true},
|
|
}
|
|
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
}
|