mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	feat: GroupApplicationAgreeMemberEnterNotification splitting (#3297)
* pb * fix: Modifying other fields while setting IsPrivateChat does not take effect * fix: quote message error revoke * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * upgrading pkg tools * fix * fix * optimize log output * feat: support GetLastMessage * feat: support GetLastMessage * feat: s3 switch * feat: s3 switch * fix: GetUsersOnline * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: seq conversion failed without exiting * fix: DeleteDoc crash * fix: fill send time * fix: fill send time * fix: crash caused by withdrawing messages from users who have left the group * fix: user msg timestamp * seq read config * seq read config * fix: the source message of the reference is withdrawn, and the referenced message is deleted * feat: optimize the default notification.yml * fix: shouldPushOffline * fix: the sorting is wrong after canceling the administrator in group settings * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * fix: oss specifies content-type when uploading * fix: the version number contains a line break * fix: the version number contains a line break * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * fix: transferring the group owner to a muted member, incremental version error * feat: GroupApplicationAgreeMemberEnterNotification splitting, rpc body size limit * feat: GroupApplicationAgreeMemberEnterNotification splitting, rpc body size limit
This commit is contained in:
		
							parent
							
								
									4b3a2b7483
								
							
						
					
					
						commit
						c1844f471e
					
				| @ -77,34 +77,6 @@ func getConfigRpcMaxRequestBody(value reflect.Value) *conf.MaxRequestBody { | |||||||
| 	return nil | 	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, | ||||||
| @ -116,20 +88,12 @@ func Start[T any](ctx context.Context, disc *conf.Discovery, prometheusConfig *c | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	maxRequestBody := getConfigRpcMaxRequestBody(reflect.ValueOf(config)) | 	maxRequestBody := getConfigRpcMaxRequestBody(reflect.ValueOf(config)) | ||||||
| 	shareConfig := getConfigShare(reflect.ValueOf(config)) |  | ||||||
| 
 | 
 | ||||||
| 	log.ZDebug(ctx, "rpc start", "rpcMaxRequestBody", maxRequestBody, "rpcRegisterName", rpcRegisterName, "registerIP", registerIP, "listenIP", listenIP) | 	log.ZDebug(ctx, "rpc start", "rpcMaxRequestBody", maxRequestBody, "rpcRegisterName", rpcRegisterName, "registerIP", registerIP, "listenIP", listenIP) | ||||||
| 
 | 
 | ||||||
| 	options = append(options, | 	options = append(options, | ||||||
| 		grpcsrv.GrpcServerMetadataContext(), | 		mw.GrpcServer(), | ||||||
| 		grpcsrv.GrpcServerLogger(), |  | ||||||
| 		grpcsrv.GrpcServerErrorConvert(), |  | ||||||
| 		grpcsrv.GrpcServerRequestValidate(), |  | ||||||
| 		grpcsrv.GrpcServerPanicCapture(), |  | ||||||
| 	) | 	) | ||||||
| 	if shareConfig != nil && len(shareConfig.IMAdminUserID) > 0 { |  | ||||||
| 		options = append(options, grpcServerIMAdminUserID(shareConfig.IMAdminUserID)) |  | ||||||
| 	} |  | ||||||
| 	var clientOptions []grpc.DialOption | 	var clientOptions []grpc.DialOption | ||||||
| 	if maxRequestBody != nil { | 	if maxRequestBody != nil { | ||||||
| 		if maxRequestBody.RequestMaxBodySize > 0 { | 		if maxRequestBody.RequestMaxBodySize > 0 { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user