mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 20:52:11 +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/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||||
| 	github.com/mitchellh/mapstructure v1.5.0 | 	github.com/mitchellh/mapstructure v1.5.0 | ||||||
| 	github.com/openimsdk/protocol v0.0.73-alpha.6 | 	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/pkg/errors v0.9.1 // indirect | ||||||
| 	github.com/prometheus/client_golang v1.18.0 | 	github.com/prometheus/client_golang v1.18.0 | ||||||
| 	github.com/stretchr/testify v1.9.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/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 h1:sna9coWG7HN1zObBPtvG0Ki/vzqHXiB4qKbA5P3w7kc= | ||||||
| github.com/openimsdk/protocol v0.0.73-alpha.6/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | 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.82 h1://ttur+x/zjrYxVj86xpAbHYXdurklISnztksIEN3yo= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.81/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | 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 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | 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= | 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) { | 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{} | 	resp = &pbuser.GetDesignateUsersResp{} | ||||||
| 	users, err := s.db.Find(ctx, req.UserIDs) | 	users, err := s.db.Find(ctx, req.UserIDs) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  | |||||||
| @ -47,64 +47,6 @@ func init() { | |||||||
| 	prommetrics.RegistryAll() | 	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, | 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, | 	registerIP string, autoSetPorts bool, rpcPorts []int, index int, rpcRegisterName string, notification *conf.Notification, config T, | ||||||
| 	watchConfigNames []string, watchServiceNames []string, | 	watchConfigNames []string, watchServiceNames []string, | ||||||
| @ -122,8 +64,8 @@ func Start[T any](ctx context.Context, disc *conf.Discovery, prometheusConfig *c | |||||||
| 
 | 
 | ||||||
| 	options = append(options, | 	options = append(options, | ||||||
| 		grpcsrv.GrpcServerMetadataContext(), | 		grpcsrv.GrpcServerMetadataContext(), | ||||||
| 		grpcsrv.GrpcServerLogger(), |  | ||||||
| 		grpcsrv.GrpcServerErrorConvert(), | 		grpcsrv.GrpcServerErrorConvert(), | ||||||
|  | 		grpcsrv.GrpcServerLogger(), | ||||||
| 		grpcsrv.GrpcServerRequestValidate(), | 		grpcsrv.GrpcServerRequestValidate(), | ||||||
| 		grpcsrv.GrpcServerPanicCapture(), | 		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