765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
1
|
package models
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
2
3
|
import (
|
4255fd8e
zhangqijia
feat: 更新字段
|
4
|
"google.golang.org/protobuf/reflect/protoreflect"
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
5
|
"pro2d/common/components"
|
436e0af4
zhangqijia
reactor: dir; Ac...
|
6
|
"pro2d/common/db/mongoproxy"
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
7
|
"pro2d/common/logger"
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
8
9
10
11
|
"reflect"
"strings"
)
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
12
13
14
15
16
17
18
19
|
type SchemaOption func(schema *Schema)
func WithSchemaDB(idb components.IDB) SchemaOption {
return func(schema *Schema) {
schema.db = idb
}
}
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
20
21
|
type SchemaMap map[string]components.ISchema
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
22
|
type Schema struct {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
23
|
conn components.IConnection
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
24
|
db components.IDB
|
33ea26ab
zhangqijia
使用schema封装mongo
|
25
|
reflectValue *reflect.Value
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
26
|
reflectIndex map[string]int
|
33ea26ab
zhangqijia
使用schema封装mongo
|
27
|
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
28
|
cacheFields map[string]interface{}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
29
|
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
30
|
pri interface{}
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
31
32
33
|
schema interface{}
}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
34
35
|
func NewSchema(key string, schema interface{}) *Schema {
s := reflect.ValueOf(schema)
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
36
|
if s.Kind() == reflect.Ptr {
|
33ea26ab
zhangqijia
使用schema封装mongo
|
37
|
s = reflect.ValueOf(schema).Elem()
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
38
|
}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
39
40
|
sch := &Schema{
reflectValue: &s,
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
41
42
|
cacheFields: make(map[string]interface{}),
schema: schema,
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
43
44
45
46
|
reflectIndex: make(map[string]int),
}
for i := 0; i < s.Type().NumField(); i++ {
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
47
48
49
50
51
|
name := s.Type().Field(i).Name
if strings.Compare(name[0:1], strings.ToLower(name[0:1])) == 0 {
continue
}
sch.reflectIndex[strings.ToLower(strings.ToLower(name))] = i
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
52
|
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
53
|
|
436e0af4
zhangqijia
reactor: dir; Ac...
|
54
|
sch.db = mongoproxy.NewMongoColl(sch.GetSchemaName(), sch)
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
55
|
sch.pri = mongoproxy.GetBsonD(sch.getPriTag(), key)
|
33ea26ab
zhangqijia
使用schema封装mongo
|
56
|
return sch
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
57
58
|
}
|
101d1cc1
zhangqijia
feat: 一个基于redis的自...
|
59
60
61
62
63
64
65
66
67
68
69
|
func (s *Schema) getPriTag() string {
var pri string
for i := 0; i < s.reflectValue.Type().NumField(); i++ {
if s.reflectValue.Type().Field(i).Tag.Get("pri") == "1" {
pri = strings.ToLower(s.reflectValue.Type().Field(i).Name)
break
}
}
return pri
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
70
71
|
func (s *Schema) FindIndex() (string, []string) {
var index []string
|
4255fd8e
zhangqijia
feat: 更新字段
|
72
73
74
|
for i := 0; i < s.reflectValue.Type().NumField(); i++ {
if s.reflectValue.Type().Field(i).Tag.Get("index") != "" {
js := strings.Split(s.reflectValue.Type().Field(i).Tag.Get("json"), ",")
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
75
76
77
78
79
80
|
if len(js) == 0 {
continue
}
index = append(index, js[0])
}
}
|
4255fd8e
zhangqijia
feat: 更新字段
|
81
|
return strings.ToLower(s.reflectValue.Type().Name()), index
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
82
83
|
}
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
84
|
func (s *Schema) Init() {
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
85
|
coll, keys := s.FindIndex()
|
0ce6c418
zhangqijia
fix: 修复 bug RoleM...
|
86
|
for _, index := range keys {
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
87
|
s.db.CreateTable()
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
88
|
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
89
90
91
92
93
|
logger.Debug("InitDoc collect: %v, createIndex: %s", coll, index)
res, err := s.db.SetUnique(index)
if err != nil {
logger.Error("InitDoc unique: %s, err: %v", res, err)
continue
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
94
95
|
}
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
96
97
98
99
|
}
func (s *Schema) GetDB() components.IDB {
return s.db
|
98b0736d
zhangqijia
添加定时器, 检查心跳
|
100
|
}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
101
102
103
104
105
106
107
108
109
|
func (s *Schema) GetPri() interface{} {
return s.pri
}
func (s *Schema) GetSchema() interface{} {
return s.schema
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
110
|
func (s *Schema) GetSchemaName() string {
|
4255fd8e
zhangqijia
feat: 更新字段
|
111
|
return strings.ToLower(s.reflectValue.Type().Name())
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
112
113
|
}
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
func (s *Schema) UpdateSchema(schema interface{}) {
sch := reflect.ValueOf(schema)
if sch.Kind() == reflect.Ptr {
sch = reflect.ValueOf(schema).Elem()
}
for i := 0; i < sch.Type().NumField(); i++ {
name := sch.Type().Field(i).Name
if _, ok := s.reflectIndex[strings.ToLower(name)]; !ok {
continue
}
s.SetProperty(sch.Type().Field(i).Name, sch.Field(i).Interface())
}
}
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
128
129
130
131
132
133
134
135
|
func (s *Schema) SetConn(conn components.IConnection) {
s.conn = conn
}
func (s *Schema) GetConn() components.IConnection {
return s.conn
}
|
33ea26ab
zhangqijia
使用schema封装mongo
|
136
|
func (s *Schema) Load() error {
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
137
|
return s.db.Load()
|
33ea26ab
zhangqijia
使用schema封装mongo
|
138
139
140
|
}
func (s *Schema) Create() error {
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
141
|
_, err := s.db.Create()
|
33ea26ab
zhangqijia
使用schema封装mongo
|
142
143
144
|
return err
}
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
145
|
//更新缓存字段到数据库
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
146
|
func (s *Schema) Update() {
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
147
|
if len(s.cacheFields) > 0 {
|
a24dea4c
zhangqijia
fix: id自增做了写更新。阵容...
|
148
149
150
151
|
if err := s.db.UpdateProperties(s.cacheFields); err != nil {
logger.Error("%s, UpdateErr: %s", s.GetSchemaName(), err.Error())
return
}
|
38dd96b4
zhangqijia
定时器+网络数据 peer 在一条...
|
152
153
154
155
|
s.cacheFields = make(map[string]interface{})
}
}
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
156
|
//更新内存,并把字段缓存
|
7f269318
zhangqijia
add pb.go; 添加关闭连接...
|
157
|
func (s *Schema) SetProperty(key string, val interface{}) {
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
158
159
160
161
162
|
idx, ok := s.reflectIndex[strings.ToLower(key)]
if !ok {
return
}
s.reflectValue.Field(idx).Set(reflect.ValueOf(val))
|
7f269318
zhangqijia
add pb.go; 添加关闭连接...
|
163
|
s.cacheFields[strings.ToLower(key)] = val
|
33ea26ab
zhangqijia
使用schema封装mongo
|
164
165
|
}
|
eadc9aff
zhangqijia
feat: 增加上阵下阵协议,增加...
|
166
|
//更新内存,并把字段缓存
|
7f269318
zhangqijia
add pb.go; 添加关闭连接...
|
167
|
func (s *Schema) SetProperties(properties map[string]interface{}) {
|
33ea26ab
zhangqijia
使用schema封装mongo
|
168
|
for key, val := range properties {
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
169
170
171
172
173
174
|
idx, ok := s.reflectIndex[strings.ToLower(key)]
if !ok {
continue
}
s.reflectValue.Field(idx).Set(reflect.ValueOf(val))
|
7f269318
zhangqijia
add pb.go; 添加关闭连接...
|
175
|
s.cacheFields[strings.ToLower(key)] = val
|
33ea26ab
zhangqijia
使用schema封装mongo
|
176
|
}
|
765431a4
zhangqijia
增加schema接口, 抽象 mo...
|
177
178
|
}
|
c8509ef6
zhangqijia
fix: notify equip...
|
179
|
func (s *Schema) IncrProperty(key string, val int64) int64 {
|
8aaf28dd
zhangqijia
fix: 修复gm系统修改role...
|
180
181
|
idx, ok := s.reflectIndex[strings.ToLower(key)]
if !ok {
|
c8509ef6
zhangqijia
fix: notify equip...
|
182
|
return 0
|
8aaf28dd
zhangqijia
fix: 修复gm系统修改role...
|
183
184
185
186
187
188
189
190
191
192
|
}
field := s.reflectValue.Field(idx)
var v int64
switch field.Kind() {
case reflect.Int64:
v = field.Int() + val
case reflect.Int:
v = field.Int() + val
}
s.SetProperty(key, v)
|
c8509ef6
zhangqijia
fix: notify equip...
|
193
|
return v
|
8aaf28dd
zhangqijia
fix: 修复gm系统修改role...
|
194
195
|
}
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
196
|
func (s *Schema) ParseFields(message protoreflect.Message, properties map[string]interface{}) []int32 {
|
4255fd8e
zhangqijia
feat: 更新字段
|
197
198
|
ids := make([]int32, 0, len(properties))
for k, v := range properties {
|
d771e9e3
zhangqijia
fix: 优化FieldByNam...
|
199
|
field := message.Descriptor().Fields().ByName(protoreflect.Name(strings.ToLower(k)))
|
4255fd8e
zhangqijia
feat: 更新字段
|
200
201
202
203
204
205
206
207
208
209
210
211
|
if field == nil {
continue
}
ids = append(ids, int32(field.Index()))
message.Set(field, protoreflect.ValueOf(v))
s.SetProperty(k, v)
}
return ids
}
|