mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 12:42:12 +08:00 
			
		
		
		
	Merge branch 'openimsdk:3.8.3-patch' into 3.8.3-patch
This commit is contained in:
		
						commit
						e254bbf1fc
					
				| @ -16,3 +16,7 @@ imAdminUserID: [ imAdmin ] | ||||
| multiLogin: | ||||
|   policy: 1 | ||||
|   maxNumOneEnd: 30 | ||||
| 
 | ||||
| rpcMaxBodySize: | ||||
|   requestMaxBodySize: 8388608 | ||||
|   responseMaxBodySize: 8388608 | ||||
|  | ||||
| @ -18,13 +18,14 @@ import ( | ||||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"errors" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||
| 
 | ||||
| 	"github.com/IBM/sarama" | ||||
| @ -289,6 +290,7 @@ func (och *OnlineHistoryRedisConsumerHandler) handleMsg(ctx context.Context, key | ||||
| 		} | ||||
| 
 | ||||
| 		if isNewConversation { | ||||
| 			ctx := storageList[0].ctx | ||||
| 			switch msg.SessionType { | ||||
| 			case constant.ReadGroupChatType: | ||||
| 				log.ZDebug(ctx, "group chat first create conversation", "conversationID", | ||||
|  | ||||
| @ -142,6 +142,7 @@ func (c *ConsumerHandler) ConsumeClaim(sess sarama.ConsumerGroupSession, claim s | ||||
| 
 | ||||
| 	for msg := range claim.Messages() { | ||||
| 		ctx := c.pushConsumerGroup.GetContextFromMsg(msg) | ||||
| 		ctx = mcontext.WithOpUserIDContext(ctx, c.config.Share.IMAdminUserID[0]) | ||||
| 		c.handleMs2PsChat(ctx, msg.Value) | ||||
| 		sess.MarkMessage(msg, "") | ||||
| 	} | ||||
|  | ||||
| @ -33,6 +33,9 @@ func (s *groupServer) GetGroupInfoCache(ctx context.Context, req *pbgroup.GetGro | ||||
| } | ||||
| 
 | ||||
| func (s *groupServer) GetGroupMemberCache(ctx context.Context, req *pbgroup.GetGroupMemberCacheReq) (*pbgroup.GetGroupMemberCacheResp, error) { | ||||
| 	if err := s.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	members, err := s.db.TakeGroupMember(ctx, req.GroupID, req.GroupMemberID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -453,13 +453,26 @@ func (g *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	if err := g.db.CreateGroup(ctx, nil, groupMembers); err != nil { | ||||
| 	const singleQuantity = 50 | ||||
| 	for start := 0; start < len(groupMembers); start += singleQuantity { | ||||
| 		end := start + singleQuantity | ||||
| 		if end > len(groupMembers) { | ||||
| 			end = len(groupMembers) | ||||
| 		} | ||||
| 		currentMembers := groupMembers[start:end] | ||||
| 
 | ||||
| 		if err := g.db.CreateGroup(ctx, nil, currentMembers); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 
 | ||||
| 	if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, req.SendMessage, opUserID, req.InvitedUserIDs...); err != nil { | ||||
| 		userIDs := datautil.Slice(currentMembers, func(e *model.GroupMember) string { | ||||
| 			return e.UserID | ||||
| 		}) | ||||
| 
 | ||||
| 		if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, req.SendMessage, opUserID, userIDs...); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	return &pbgroup.InviteUserToGroupResp{}, nil | ||||
| } | ||||
| 
 | ||||
| @ -478,7 +491,25 @@ func (g *groupServer) GetGroupAllMember(ctx context.Context, req *pbgroup.GetGro | ||||
| 	return &resp, nil | ||||
| } | ||||
| 
 | ||||
| func (g *groupServer) checkAdminOrInGroup(ctx context.Context, groupID string) error { | ||||
| 	if authverify.IsAppManagerUid(ctx, g.config.Share.IMAdminUserID) { | ||||
| 		return nil | ||||
| 	} | ||||
| 	opUserID := mcontext.GetOpUserID(ctx) | ||||
| 	members, err := g.db.FindGroupMembers(ctx, groupID, []string{opUserID}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if len(members) == 0 { | ||||
| 		return errs.ErrNoPermission.WrapMsg("op user not in group") | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (g *groupServer) GetGroupMemberList(ctx context.Context, req *pbgroup.GetGroupMemberListReq) (*pbgroup.GetGroupMemberListResp, error) { | ||||
| 	if err := g.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	var ( | ||||
| 		total   int64 | ||||
| 		members []*model.GroupMember | ||||
| @ -487,7 +518,7 @@ func (g *groupServer) GetGroupMemberList(ctx context.Context, req *pbgroup.GetGr | ||||
| 	if req.Keyword == "" { | ||||
| 		total, members, err = g.db.PageGetGroupMember(ctx, req.GroupID, req.Pagination) | ||||
| 	} else { | ||||
| 		members, err = g.db.FindGroupMemberAll(ctx, req.GroupID) | ||||
| 		total, members, err = g.db.SearchGroupMember(ctx, req.GroupID, req.Keyword, req.Pagination) | ||||
| 	} | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -495,27 +526,6 @@ func (g *groupServer) GetGroupMemberList(ctx context.Context, req *pbgroup.GetGr | ||||
| 	if err := g.PopulateGroupMember(ctx, members...); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if req.Keyword != "" { | ||||
| 		groupMembers := make([]*model.GroupMember, 0) | ||||
| 		for _, member := range members { | ||||
| 			if member.UserID == req.Keyword { | ||||
| 				groupMembers = append(groupMembers, member) | ||||
| 				total++ | ||||
| 				continue | ||||
| 			} | ||||
| 			if member.Nickname == req.Keyword { | ||||
| 				groupMembers = append(groupMembers, member) | ||||
| 				total++ | ||||
| 				continue | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		members := datautil.Paginate(groupMembers, int(req.Pagination.GetPageNumber()), int(req.Pagination.GetShowNumber())) | ||||
| 		return &pbgroup.GetGroupMemberListResp{ | ||||
| 			Total:   uint32(total), | ||||
| 			Members: datautil.Batch(convert.Db2PbGroupMember, members), | ||||
| 		}, nil | ||||
| 	} | ||||
| 	return &pbgroup.GetGroupMemberListResp{ | ||||
| 		Total:   uint32(total), | ||||
| 		Members: datautil.Batch(convert.Db2PbGroupMember, members), | ||||
| @ -639,6 +649,9 @@ func (g *groupServer) GetGroupMembersInfo(ctx context.Context, req *pbgroup.GetG | ||||
| 	if req.GroupID == "" { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("groupID empty") | ||||
| 	} | ||||
| 	if err := g.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	members, err := g.getGroupMembersInfo(ctx, req.GroupID, req.UserIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -1284,6 +1297,9 @@ func (g *groupServer) GetGroups(ctx context.Context, req *pbgroup.GetGroupsReq) | ||||
| } | ||||
| 
 | ||||
| func (g *groupServer) GetGroupMembersCMS(ctx context.Context, req *pbgroup.GetGroupMembersCMSReq) (*pbgroup.GetGroupMembersCMSResp, error) { | ||||
| 	if err := g.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	total, members, err := g.db.SearchGroupMember(ctx, req.UserName, req.GroupID, req.Pagination) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -1659,6 +1675,11 @@ func (g *groupServer) GetGroupAbstractInfo(ctx context.Context, req *pbgroup.Get | ||||
| 	if datautil.Duplicate(req.GroupIDs) { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("groupIDs duplicate") | ||||
| 	} | ||||
| 	for _, groupID := range req.GroupIDs { | ||||
| 		if err := g.checkAdminOrInGroup(ctx, groupID); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 	groups, err := g.db.FindGroup(ctx, req.GroupIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -1687,6 +1708,9 @@ func (g *groupServer) GetUserInGroupMembers(ctx context.Context, req *pbgroup.Ge | ||||
| 	if len(req.GroupIDs) == 0 { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("groupIDs empty") | ||||
| 	} | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.UserID, g.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	members, err := g.db.FindGroupMemberUser(ctx, req.GroupIDs, req.UserID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -1706,6 +1730,11 @@ func (g *groupServer) GetGroupMemberUserIDs(ctx context.Context, req *pbgroup.Ge | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if !authverify.IsAppManagerUid(ctx, g.config.Share.IMAdminUserID) { | ||||
| 		if !datautil.Contain(mcontext.GetOpUserID(ctx), userIDs...) { | ||||
| 			return nil, errs.ErrNoPermission.WrapMsg("opUser no permission") | ||||
| 		} | ||||
| 	} | ||||
| 	return &pbgroup.GetGroupMemberUserIDsResp{ | ||||
| 		UserIDs: userIDs, | ||||
| 	}, nil | ||||
| @ -1715,6 +1744,9 @@ func (g *groupServer) GetGroupMemberRoleLevel(ctx context.Context, req *pbgroup. | ||||
| 	if len(req.RoleLevels) == 0 { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("RoleLevels empty") | ||||
| 	} | ||||
| 	if err := g.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	members, err := g.db.FindGroupMemberRoleLevels(ctx, req.GroupID, req.RoleLevels) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -521,6 +521,10 @@ func (g *NotificationSender) MemberKickedNotification(ctx context.Context, tips | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupApplicationAgreeMemberEnterNotification(ctx context.Context, groupID string, SendMessage *bool, invitedOpUserID string, entrantUserID ...string) error { | ||||
| 	return g.groupApplicationAgreeMemberEnterNotification(ctx, groupID, SendMessage, invitedOpUserID, entrantUserID...) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) groupApplicationAgreeMemberEnterNotification(ctx context.Context, groupID string, SendMessage *bool, invitedOpUserID string, entrantUserID ...string) error { | ||||
| 	var err error | ||||
| 	defer func() { | ||||
| 		if err != nil { | ||||
|  | ||||
| @ -18,6 +18,7 @@ import ( | ||||
| 	"context" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| 	"github.com/openimsdk/protocol/group" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| ) | ||||
| @ -26,6 +27,9 @@ func (s *groupServer) GroupCreateCount(ctx context.Context, req *group.GroupCrea | ||||
| 	if req.Start > req.End { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("start > end: %d > %d", req.Start, req.End) | ||||
| 	} | ||||
| 	if err := authverify.CheckAdmin(ctx, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	total, err := s.db.CountTotal(ctx, nil) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -11,16 +11,24 @@ import ( | ||||
| 	"github.com/openimsdk/protocol/constant" | ||||
| 	pbgroup "github.com/openimsdk/protocol/group" | ||||
| 	"github.com/openimsdk/protocol/sdkws" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/mcontext" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| ) | ||||
| 
 | ||||
| const versionSyncLimit = 500 | ||||
| 
 | ||||
| func (g *groupServer) GetFullGroupMemberUserIDs(ctx context.Context, req *pbgroup.GetFullGroupMemberUserIDsReq) (*pbgroup.GetFullGroupMemberUserIDsResp, error) { | ||||
| 	vl, err := g.db.FindMaxGroupMemberVersionCache(ctx, req.GroupID) | ||||
| 	userIDs, err := g.db.FindGroupMemberUserID(ctx, req.GroupID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	userIDs, err := g.db.FindGroupMemberUserID(ctx, req.GroupID) | ||||
| 	if !authverify.IsAppManagerUid(ctx, g.config.Share.IMAdminUserID) { | ||||
| 		if !datautil.Contain(mcontext.GetOpUserID(ctx), userIDs...) { | ||||
| 			return nil, errs.ErrNoPermission.WrapMsg("op user not in group") | ||||
| 		} | ||||
| 	} | ||||
| 	vl, err := g.db.FindMaxGroupMemberVersionCache(ctx, req.GroupID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -37,6 +45,9 @@ func (g *groupServer) GetFullGroupMemberUserIDs(ctx context.Context, req *pbgrou | ||||
| } | ||||
| 
 | ||||
| func (s *groupServer) GetFullJoinGroupIDs(ctx context.Context, req *pbgroup.GetFullJoinGroupIDsReq) (*pbgroup.GetFullJoinGroupIDsResp, error) { | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.UserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	vl, err := s.db.FindMaxJoinGroupVersionCache(ctx, req.UserID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -58,6 +69,9 @@ func (s *groupServer) GetFullJoinGroupIDs(ctx context.Context, req *pbgroup.GetF | ||||
| } | ||||
| 
 | ||||
| func (s *groupServer) GetIncrementalGroupMember(ctx context.Context, req *pbgroup.GetIncrementalGroupMemberReq) (*pbgroup.GetIncrementalGroupMemberResp, error) { | ||||
| 	if err := s.checkAdminOrInGroup(ctx, req.GroupID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	group, err := s.db.TakeGroup(ctx, req.GroupID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -16,6 +16,7 @@ package relation | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/mq/memamq" | ||||
| @ -280,6 +281,9 @@ func (s *friendServer) SetFriendRemark(ctx context.Context, req *relation.SetFri | ||||
| } | ||||
| 
 | ||||
| func (s *friendServer) GetFriendInfo(ctx context.Context, req *relation.GetFriendInfoReq) (*relation.GetFriendInfoResp, error) { | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.OwnerUserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	friends, err := s.db.FindFriendsWithError(ctx, req.OwnerUserID, req.FriendUserIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -292,6 +296,9 @@ func (s *friendServer) GetDesignatedFriends(ctx context.Context, req *relation.G | ||||
| 	if datautil.Duplicate(req.FriendUserIDs) { | ||||
| 		return nil, errs.ErrArgs.WrapMsg("friend userID repeated") | ||||
| 	} | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.OwnerUserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	friends, err := s.getFriend(ctx, req.OwnerUserID, req.FriendUserIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -426,6 +433,10 @@ func (s *friendServer) GetSpecifiedFriendsInfo(ctx context.Context, req *relatio | ||||
| 		return nil, errs.ErrArgs.WrapMsg("userIDList repeated") | ||||
| 	} | ||||
| 
 | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.OwnerUserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	userMap, err := s.userClient.GetUsersInfoMap(ctx, req.UserIDList) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @ -505,6 +516,10 @@ func (s *friendServer) UpdateFriends( | ||||
| 		return nil, errs.ErrArgs.WrapMsg("friendIDList repeated") | ||||
| 	} | ||||
| 
 | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.OwnerUserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	_, err := s.db.FindFriendsWithError(ctx, req.OwnerUserID, req.FriendUserIDs) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -2,10 +2,11 @@ package relation | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"slices" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/util/hashutil" | ||||
| 	"github.com/openimsdk/protocol/sdkws" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"slices" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/internal/rpc/incrversion" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| @ -39,6 +40,9 @@ func (s *friendServer) NotificationUserInfoUpdate(ctx context.Context, req *rela | ||||
| } | ||||
| 
 | ||||
| func (s *friendServer) GetFullFriendUserIDs(ctx context.Context, req *relation.GetFullFriendUserIDsReq) (*relation.GetFullFriendUserIDsResp, error) { | ||||
| 	if err := authverify.CheckAccessV3(ctx, req.UserID, s.config.Share.IMAdminUserID); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	vl, err := s.db.FindMaxFriendVersionCache(ctx, req.UserID) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
|  | ||||
| @ -384,6 +384,12 @@ type Share struct { | ||||
| 	RpcRegisterName RpcRegisterName `mapstructure:"rpcRegisterName"` | ||||
| 	IMAdminUserID   []string        `mapstructure:"imAdminUserID"` | ||||
| 	MultiLogin      MultiLogin      `mapstructure:"multiLogin"` | ||||
| 	RPCMaxBodySize  MaxRequestBody  `mapstructure:"rpcMaxBodySize"` | ||||
| } | ||||
| 
 | ||||
| type MaxRequestBody struct { | ||||
| 	RequestMaxBodySize  int `mapstructure:"requestMaxBodySize"` | ||||
| 	ResponseMaxBodySize int `mapstructure:"responseMaxBodySize"` | ||||
| } | ||||
| 
 | ||||
| type MultiLogin struct { | ||||
|  | ||||
| @ -22,6 +22,7 @@ import ( | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"os/signal" | ||||
| 	"reflect" | ||||
| 	"strconv" | ||||
| 	"syscall" | ||||
| 	"time" | ||||
| @ -43,6 +44,36 @@ import ( | ||||
| 	"google.golang.org/grpc/credentials/insecure" | ||||
| ) | ||||
| 
 | ||||
| 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 | ||||
| } | ||||
| 
 | ||||
| // Start rpc server. | ||||
| func Start[T any](ctx context.Context, discovery *conf.Discovery, prometheusConfig *conf.Prometheus, listenIP, | ||||
| 	registerIP string, autoSetPorts bool, rpcPorts []int, index int, rpcRegisterName string, share *conf.Share, config T, | ||||
| @ -50,6 +81,19 @@ func Start[T any](ctx context.Context, discovery *conf.Discovery, prometheusConf | ||||
| 	rpcFn func(ctx context.Context, config T, client discovery.SvcDiscoveryRegistry, server *grpc.Server) error, | ||||
| 	options ...grpc.ServerOption) error { | ||||
| 
 | ||||
| 	maxRequestBody := &share.RPCMaxBodySize | ||||
| 	var clientOptions []grpc.DialOption | ||||
| 	if maxRequestBody != nil { | ||||
| 		if maxRequestBody.RequestMaxBodySize > 0 { | ||||
| 			options = append(options, grpc.MaxRecvMsgSize(maxRequestBody.RequestMaxBodySize)) | ||||
| 			clientOptions = append(clientOptions, grpc.WithDefaultCallOptions(grpc.MaxCallSendMsgSize(maxRequestBody.RequestMaxBodySize))) | ||||
| 		} | ||||
| 		if maxRequestBody.ResponseMaxBodySize > 0 { | ||||
| 			options = append(options, grpc.MaxSendMsgSize(maxRequestBody.ResponseMaxBodySize)) | ||||
| 			clientOptions = append(clientOptions, grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(maxRequestBody.ResponseMaxBodySize))) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	var ( | ||||
| 		rpcTcpAddr     string | ||||
| 		netDone        = make(chan struct{}, 2) | ||||
| @ -93,6 +137,10 @@ func Start[T any](ctx context.Context, discovery *conf.Discovery, prometheusConf | ||||
| 	defer client.Close() | ||||
| 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials()), grpc.WithDefaultServiceConfig(fmt.Sprintf(`{"LoadBalancingPolicy": "%s"}`, "round_robin"))) | ||||
| 
 | ||||
| 	if len(clientOptions) > 0 { | ||||
| 		client.AddOption(clientOptions...) | ||||
| 	} | ||||
| 
 | ||||
| 	// var reg *prometheus.Registry | ||||
| 	// var metric *grpcprometheus.ServerMetrics | ||||
| 	if prometheusConfig.Enable { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user