Blame view

models/schema.go 4.71 KB
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
  }