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