mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	fix: merge conflicts
This commit is contained in:
		
							parent
							
								
									b40bc731e6
								
							
						
					
					
						commit
						8e7457febb
					
				
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -13,7 +13,7 @@ require ( | ||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||
| 	github.com/mitchellh/mapstructure v1.5.0 | ||||
| 	github.com/openimsdk/protocol v0.0.73-alpha.6 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.81 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.82 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
| 	github.com/stretchr/testify v1.9.0 | ||||
|  | ||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -349,8 +349,8 @@ github.com/openimsdk/gomake v0.0.15-alpha.5 h1:eEZCEHm+NsmcO3onXZPIUbGFCYPYbsX5b | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.73-alpha.6 h1:sna9coWG7HN1zObBPtvG0Ki/vzqHXiB4qKbA5P3w7kc= | ||||
| github.com/openimsdk/protocol v0.0.73-alpha.6/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.81 h1:VbuJKtigNXLkCKB/Q6f2UHsqoSaTOAwS8F51c1nhOCA= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.81/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.82 h1://ttur+x/zjrYxVj86xpAbHYXdurklISnztksIEN3yo= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.82/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | ||||
| github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||
|  | ||||
| @ -136,6 +136,7 @@ func Start(ctx context.Context, config *Config, client discovery.Conn, server gr | ||||
| } | ||||
| 
 | ||||
| func (s *userServer) GetDesignateUsers(ctx context.Context, req *pbuser.GetDesignateUsersReq) (resp *pbuser.GetDesignateUsersResp, err error) { | ||||
| 	return nil, errs.ErrRecordNotFound.WrapMsg("test error") | ||||
| 	resp = &pbuser.GetDesignateUsersResp{} | ||||
| 	users, err := s.db.Find(ctx, req.UserIDs) | ||||
| 	if err != nil { | ||||
|  | ||||
| @ -47,64 +47,6 @@ func init() { | ||||
| 	prommetrics.RegistryAll() | ||||
| } | ||||
| 
 | ||||
| func getConfigRpcMaxRequestBody(value reflect.Value) *conf.MaxRequestBody { | ||||
| 	for value.Kind() == reflect.Pointer { | ||||
| 		value = value.Elem() | ||||
| 	} | ||||
| 	if value.Kind() == reflect.Struct { | ||||
| 		num := value.NumField() | ||||
| 		for i := 0; i < num; i++ { | ||||
| 			field := value.Field(i) | ||||
| 			if !field.CanInterface() { | ||||
| 				continue | ||||
| 			} | ||||
| 			for field.Kind() == reflect.Pointer { | ||||
| 				field = field.Elem() | ||||
| 			} | ||||
| 			switch elem := field.Interface().(type) { | ||||
| 			case conf.Share: | ||||
| 				return &elem.RPCMaxBodySize | ||||
| 			case conf.MaxRequestBody: | ||||
| 				return &elem | ||||
| 			} | ||||
| 			if field.Kind() == reflect.Struct { | ||||
| 				if elem := getConfigRpcMaxRequestBody(field); elem != nil { | ||||
| 					return elem | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func getConfigShare(value reflect.Value) *conf.Share { | ||||
| 	for value.Kind() == reflect.Pointer { | ||||
| 		value = value.Elem() | ||||
| 	} | ||||
| 	if value.Kind() == reflect.Struct { | ||||
| 		num := value.NumField() | ||||
| 		for i := 0; i < num; i++ { | ||||
| 			field := value.Field(i) | ||||
| 			if !field.CanInterface() { | ||||
| 				continue | ||||
| 			} | ||||
| 			for field.Kind() == reflect.Pointer { | ||||
| 				field = field.Elem() | ||||
| 			} | ||||
| 			switch elem := field.Interface().(type) { | ||||
| 			case conf.Share: | ||||
| 				return &elem | ||||
| 			} | ||||
| 			if field.Kind() == reflect.Struct { | ||||
| 				if elem := getConfigShare(field); elem != nil { | ||||
| 					return elem | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func Start[T any](ctx context.Context, disc *conf.Discovery, prometheusConfig *conf.Prometheus, listenIP, | ||||
| 	registerIP string, autoSetPorts bool, rpcPorts []int, index int, rpcRegisterName string, notification *conf.Notification, config T, | ||||
| 	watchConfigNames []string, watchServiceNames []string, | ||||
| @ -122,8 +64,8 @@ func Start[T any](ctx context.Context, disc *conf.Discovery, prometheusConfig *c | ||||
| 
 | ||||
| 	options = append(options, | ||||
| 		grpcsrv.GrpcServerMetadataContext(), | ||||
| 		grpcsrv.GrpcServerLogger(), | ||||
| 		grpcsrv.GrpcServerErrorConvert(), | ||||
| 		grpcsrv.GrpcServerLogger(), | ||||
| 		grpcsrv.GrpcServerRequestValidate(), | ||||
| 		grpcsrv.GrpcServerPanicCapture(), | ||||
| 	) | ||||
|  | ||||
							
								
								
									
										39
									
								
								pkg/common/startrpc/tools.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								pkg/common/startrpc/tools.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | ||||
| package startrpc | ||||
| 
 | ||||
| import ( | ||||
| 	"reflect" | ||||
| 
 | ||||
| 	conf "github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| ) | ||||
| 
 | ||||
| func getConfig[T any](value reflect.Value) *T { | ||||
| 	for value.Kind() == reflect.Pointer { | ||||
| 		value = value.Elem() | ||||
| 	} | ||||
| 	if value.Kind() == reflect.Struct { | ||||
| 		num := value.NumField() | ||||
| 		for i := 0; i < num; i++ { | ||||
| 			field := value.Field(i) | ||||
| 			for field.Kind() == reflect.Pointer { | ||||
| 				field = field.Elem() | ||||
| 			} | ||||
| 			if field.Kind() == reflect.Struct { | ||||
| 				if elem, ok := field.Interface().(T); ok { | ||||
| 					return &elem | ||||
| 				} | ||||
| 				if elem := getConfig[T](field); elem != nil { | ||||
| 					return elem | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func getConfigRpcMaxRequestBody(value reflect.Value) *conf.MaxRequestBody { | ||||
| 	return getConfig[conf.MaxRequestBody](value) | ||||
| } | ||||
| 
 | ||||
| func getConfigShare(value reflect.Value) *conf.Share { | ||||
| 	return getConfig[conf.Share](value) | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user