2025-12-26 03:51:24 +08:00
|
|
|
package service
|
|
|
|
|
|
|
|
|
|
import (
|
2025-12-26 23:46:10 +08:00
|
|
|
"blazing/common/data"
|
2026-02-17 22:36:18 +08:00
|
|
|
"blazing/common/utils"
|
2025-12-26 03:51:24 +08:00
|
|
|
"blazing/cool"
|
|
|
|
|
"blazing/modules/config/model"
|
2025-12-26 20:38:08 +08:00
|
|
|
"context"
|
2025-12-26 23:46:10 +08:00
|
|
|
"encoding/json"
|
2025-12-26 20:38:08 +08:00
|
|
|
|
|
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
2025-12-28 23:43:31 +08:00
|
|
|
"github.com/gogf/gf/v2/util/gconv"
|
2025-12-26 23:46:10 +08:00
|
|
|
"github.com/gogf/gf/v2/util/grand"
|
2025-12-26 03:51:24 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type ShinyService struct {
|
|
|
|
|
*cool.Service
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewShinyService() *ShinyService {
|
|
|
|
|
return &ShinyService{
|
|
|
|
|
&cool.Service{
|
|
|
|
|
Model: model.NewColorfulSkin(),
|
2025-12-26 20:38:08 +08:00
|
|
|
InsertParam: func(ctx context.Context) g.MapStrAny {
|
|
|
|
|
admin := cool.GetAdmin(ctx)
|
|
|
|
|
userId := admin.UserId
|
|
|
|
|
return g.MapStrAny{
|
|
|
|
|
"author": userId,
|
|
|
|
|
}
|
|
|
|
|
},
|
2025-12-26 03:51:24 +08:00
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-12-28 23:43:31 +08:00
|
|
|
func (s *ShinyService) ModifyBefore(ctx context.Context, method string, param g.MapStrAny) (err error) {
|
|
|
|
|
var t data.GlowFilter
|
2025-12-26 23:46:10 +08:00
|
|
|
|
2025-12-31 00:29:38 +08:00
|
|
|
if method == "Delete" {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2025-12-28 23:43:31 +08:00
|
|
|
r := json.Unmarshal([]byte(gconv.String(param["color"])), &t)
|
|
|
|
|
if r != nil {
|
|
|
|
|
return r
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2026-02-21 17:41:49 +08:00
|
|
|
func (s *ShinyService) RandShiny(id uint32) *data.GlowFilter {
|
2026-02-21 17:32:40 +08:00
|
|
|
|
2025-12-26 23:46:10 +08:00
|
|
|
var ret []model.ColorfulSkin
|
|
|
|
|
|
|
|
|
|
// 执行 Raw SQL 并扫描返回值
|
2026-02-14 23:14:43 +08:00
|
|
|
dbm_enable(s.Model).
|
2025-12-31 21:00:29 +08:00
|
|
|
Wheref(`bind_elf_ids @> ?::jsonb`, id).
|
2026-02-13 22:57:05 +08:00
|
|
|
Wheref(`jsonb_typeof(bind_elf_ids) = ?`, "array").Scan(&ret)
|
2025-12-26 23:46:10 +08:00
|
|
|
|
|
|
|
|
for _, v := range ret {
|
2026-02-21 17:32:40 +08:00
|
|
|
//print(v.ID)
|
2026-02-17 22:56:55 +08:00
|
|
|
|
2026-02-21 17:32:40 +08:00
|
|
|
id := v.ID
|
2026-02-17 22:56:55 +08:00
|
|
|
|
2026-02-21 17:32:40 +08:00
|
|
|
if grand.Meet(int(v.ElfProbability), 1000) {
|
2026-02-17 22:56:55 +08:00
|
|
|
|
2026-02-21 17:32:40 +08:00
|
|
|
if cool.Config.ServerInfo.IsVip == 0 {
|
|
|
|
|
m := cool.DBM(s.Model).Where("id", id)
|
|
|
|
|
m.Increment("usage_count", 1)
|
|
|
|
|
}
|
2025-12-30 00:45:23 +08:00
|
|
|
|
2026-02-21 17:41:49 +08:00
|
|
|
return &v.Color
|
2025-12-30 00:45:23 +08:00
|
|
|
|
2026-02-21 17:32:40 +08:00
|
|
|
}
|
2026-02-08 17:57:42 +08:00
|
|
|
}
|
2026-02-21 18:07:46 +08:00
|
|
|
if len(ret) == 0 {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
2026-02-28 22:31:33 +08:00
|
|
|
|
2026-02-21 17:41:49 +08:00
|
|
|
var t = data.GetDef()
|
|
|
|
|
|
2026-02-28 22:31:33 +08:00
|
|
|
t.ColorMatrixFilter = model.GenerateRandomOffspringMatrix().Get()
|
2026-02-21 17:41:49 +08:00
|
|
|
|
|
|
|
|
return &t
|
2026-02-17 22:36:18 +08:00
|
|
|
}
|
2026-02-21 17:32:40 +08:00
|
|
|
|
2026-02-21 17:41:49 +08:00
|
|
|
func (s *ShinyService) RandomByWeightShiny(id uint32) *data.GlowFilter {
|
2026-02-21 17:32:40 +08:00
|
|
|
|
2026-02-17 22:36:18 +08:00
|
|
|
var ret []model.ColorfulSkin
|
|
|
|
|
|
|
|
|
|
// 执行 Raw SQL 并扫描返回值
|
|
|
|
|
dbm_enable(s.Model).
|
|
|
|
|
Wheref(`bind_elf_ids @> ?::jsonb`, id).
|
|
|
|
|
Wheref(`jsonb_typeof(bind_elf_ids) = ?`, "array").Scan(&ret)
|
|
|
|
|
if len(ret) == 0 {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
var rets []model.ColorfulSkin
|
|
|
|
|
var props []int
|
|
|
|
|
|
|
|
|
|
for _, v := range ret {
|
|
|
|
|
rets = append(rets, v)
|
|
|
|
|
props = append(props, int(v.ElfProbability))
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
r, _ := utils.RandomByWeight(rets, props)
|
|
|
|
|
if cool.Config.ServerInfo.IsVip == 0 {
|
|
|
|
|
m := cool.DBM(s.Model).Where("id", r.ID)
|
2026-02-21 17:32:40 +08:00
|
|
|
m.Increment("refresh_count", 1)
|
2026-02-17 22:36:18 +08:00
|
|
|
}
|
|
|
|
|
|
2026-02-21 17:41:49 +08:00
|
|
|
return &r.Color
|
2026-02-17 22:36:18 +08:00
|
|
|
|
2026-02-08 17:57:42 +08:00
|
|
|
}
|
|
|
|
|
func (s *ShinyService) GetShiny(id int) *data.GlowFilter {
|
|
|
|
|
var ret []model.ColorfulSkin
|
|
|
|
|
|
|
|
|
|
// 执行 Raw SQL 并扫描返回值
|
2026-02-18 22:07:50 +08:00
|
|
|
dbm_nocache_noenable(s.Model).
|
2026-02-08 17:57:42 +08:00
|
|
|
Where("id", id).Scan(&ret)
|
|
|
|
|
if len(ret) == 0 {
|
|
|
|
|
return nil
|
2025-12-30 00:45:23 +08:00
|
|
|
}
|
2026-02-08 17:57:42 +08:00
|
|
|
v := ret[grand.Intn(len(ret))]
|
|
|
|
|
|
|
|
|
|
return &v.Color
|
2025-12-30 00:45:23 +08:00
|
|
|
|
|
|
|
|
}
|