Files
bl/modules/config/service/shiny.go
昔念 cde64b1898 ```
feat(config): 添加服务器screen参数字段

添加OldScreen字段用于存储服务器的screen会话名称

---

fix(fight): 修复攻击值结构体格式

格式化AttackValue结构体字段对齐,并添加Offensive字段用于存储攻击力

---

feat(fight): 计算并存储技能攻击力

在技能计算过程中添加攻击力计算并存储到AttackValue结构体中

---

fix(base): 修正JWT密钥配置

将JWT密钥从
2026-01-09 08:31:30 +08:00

98 lines
1.9 KiB
Go

package service
import (
"blazing/common/data"
"blazing/cool"
"blazing/modules/config/model"
"context"
"encoding/json"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/util/gconv"
"github.com/gogf/gf/v2/util/grand"
)
type ShinyService struct {
*cool.Service
}
func NewShinyService() *ShinyService {
return &ShinyService{
&cool.Service{
Model: model.NewColorfulSkin(),
InsertParam: func(ctx context.Context) g.MapStrAny {
admin := cool.GetAdmin(ctx)
userId := admin.UserId
return g.MapStrAny{
"author": userId,
}
},
},
}
}
func (s *ShinyService) ModifyBefore(ctx context.Context, method string, param g.MapStrAny) (err error) {
var t data.GlowFilter
if method == "Delete" {
return nil
}
r := json.Unmarshal([]byte(gconv.String(param["color"])), &t)
if r != nil {
return r
}
return nil
}
func (s *ShinyService) RandShiny(id uint32) *data.GlowFilter {
var ret []model.ColorfulSkin
// 执行 Raw SQL 并扫描返回值
dbm(s.Model).
Wheref(`bind_elf_ids @> ?::jsonb`, id).
Wheref(`jsonb_typeof(bind_elf_ids) = ?`, "array").
Where("is_enabled", 1).Scan(&ret)
for _, v := range ret {
//print(v.ID)
id := v.ID
if grand.Meet(int(v.ElfProbability), 1000) {
var t data.GlowFilter
r := json.Unmarshal([]byte(v.Color), &t)
if r == nil {
m := cool.DBM(s.Model).Where("id", id)
m.Increment("refresh_count", 1)
return &t
}
}
}
return nil
}
func (s *ShinyService) FixShiny(id uint32) *data.GlowFilter {
var ret []model.ColorfulSkin
// 执行 Raw SQL 并扫描返回值
dbm(s.Model).
Wheref(`bind_elf_ids @> ?::jsonb`, id).
Wheref(`jsonb_typeof(bind_elf_ids) = ?`, "array").
Where("is_enabled", 1).Scan(&ret)
if len(ret) == 0 {
return nil
}
v := ret[grand.Intn(len(ret))]
var t data.GlowFilter
r := json.Unmarshal([]byte(v.Color), &t)
if r == nil {
m := cool.DBM(s.Model).Where("id", v.ID)
m.Increment("usage_count", 1)
return &t
}
return nil
}